/* ==========================================================
   TOBI LEARNING CENTER
   Official Website v1.0
   ----------------------------------------------------------
   Brand Colors
   Primary : #053059
   Background : #F4F4F4
   Accent : #DD0000
   Font : Inter
========================================================== */

/* ==========================================================
   CSS VARIABLES
========================================================== */

:root{

    --primary:#053059;
    --primary-dark:#042746;
    --accent:#DD0000;

    --background:#F4F4F4;
    --surface:#FFFFFF;

    --text:#25313B;
    --text-light:#667085;

    --border:#E4E7EC;

    --container:1150px;
    --reading:760px;

    --radius:18px;
    --radius-large:24px;
    --pill:999px;

    --shadow:
        0 12px 32px rgba(5,48,89,.08);

    --transition:.25s ease;

}

/* ==========================================================
   RESET
========================================================== */

*,
*::before,
*::after{

    margin:0;
    padding:0;

    box-sizing:border-box;

}

html{

    scroll-behavior:smooth;

}

body{

    background:var(--background);

    color:var(--text);

    font-family:"Inter",sans-serif;

    font-size:18px;

    line-height:1.75;

    text-rendering:optimizeLegibility;

    -webkit-font-smoothing:antialiased;

}

img{

    display:block;

    max-width:100%;

}

a{

    color:inherit;

    text-decoration:none;

}

button{

    font:inherit;

}

ul{

    list-style:none;

}

/* ==========================================================
   TYPOGRAPHY
========================================================== */

h1,
h2,
h3,
h4{

    color:var(--primary);

    font-weight:700;

    line-height:1.2;

    letter-spacing:-0.03em;

}

h1{

    font-size:clamp(3rem,6vw,4rem);

    margin-bottom:1.5rem;

}

h2{

    font-size:clamp(2rem,4vw,2.5rem);

    margin-bottom:1rem;

}

h3{

    font-size:1.5rem;

    margin-bottom:.75rem;

}

p{

    margin-bottom:1.5rem;

    color:var(--text-light);

}

strong{

    color:var(--text);

    font-weight:600;

}

/* ==========================================================
   LAYOUT
========================================================== */

.container{

    width:min(var(--container),92%);

    margin-inline:auto;

}

.narrow{

    width:min(var(--reading),92%);

    margin-inline:auto;

}

.section{

    padding:96px 0;

}

.section-header{

    text-align:center;

    margin-bottom:64px;

}

.section-header p{

    max-width:640px;

    margin-inline:auto;

}

/* ==========================================================
   NAVIGATION
========================================================== */

.navbar{

    position:sticky;

    top:0;

    z-index:1000;

    background:rgba(244,244,244,.94);

    backdrop-filter:blur(14px);

    border-bottom:1px solid rgba(0,0,0,.05);

}

.navbar.scrolled{

    box-shadow:0 6px 24px rgba(5,48,89,.08);

}

.nav-container{

    display:flex;

    justify-content:space-between;

    align-items:center;

    min-height:82px;

}

.logo img{

    height:58px;

    width:auto;

}

nav ul{

    display:flex;

    align-items:center;

    gap:2rem;

}

nav a{

    position:relative;

    font-size:.95rem;

    font-weight:600;

    transition:var(--transition);

}

nav a:hover{

    color:var(--primary);

}

nav a.active{

    color:var(--primary);

}

nav a.active::after{

    content:"";

    position:absolute;

    left:0;

    bottom:-10px;

    width:100%;

    height:2px;

    background:var(--accent);

    border-radius:999px;

}

/* ==========================================================
   HERO
========================================================== */

.hero{

    padding:96px 0;

}

.hero-grid{

    display:grid;

    grid-template-columns:1.1fr .9fr;

    gap:64px;

    align-items:center;

}

.hero-content p{

    max-width:620px;

    font-size:1.1rem;

}

.hero-image img{

    width:100%;

    aspect-ratio:4 / 3;

    object-fit:cover;

    border-radius:var(--radius-large);

    box-shadow:var(--shadow);

}

.page-hero{

    padding:72px 0 40px;

    text-align:center;

}

.page-hero p{

    max-width:620px;

    margin-inline:auto;

}

/* ==========================================================
   BUTTONS
========================================================== */

.btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:.5rem;

    padding:15px 34px;

    border:none;

    border-radius:var(--pill);

    cursor:pointer;

    font-weight:600;

    transition:var(--transition);

}

.btn-primary{

    background:var(--primary);

    color:#FFFFFF;

}

.btn-primary:hover{

    background:var(--primary-dark);

    transform:translateY(-2px);

}

.btn-primary:active{

    transform:translateY(0);

}

/* ==========================================================
   LINKS
========================================================== */

.text-link{

    color:var(--primary);

    font-weight:600;

    transition:var(--transition);

}

.text-link:hover{

    color:var(--accent);

}
/* ==========================================================
   CARDS
========================================================== */

.card-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:30px;

}

.card{

    background:var(--surface);

    border-radius:var(--radius);

    padding:36px;

    box-shadow:var(--shadow);

    transition:var(--transition);

    height:100%;

}

.card:hover{

    transform:translateY(-6px);

}

.card h2{

    font-size:1.65rem;

    margin-bottom:1rem;

}

.card h3{

    margin-top:1.5rem;

}

.card p:last-child{

    margin-bottom:0;

}

.card ul{

    margin-top:1rem;

    padding-left:1.2rem;

    list-style:disc;

}

.card li{

    color:var(--text-light);

    margin-bottom:.65rem;

}

.card li:last-child{

    margin-bottom:0;

}

/* ==========================================================
   FEATURE GRID
========================================================== */

.feature-grid{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:30px;

}

.feature{

    background:var(--surface);

    padding:36px;

    border-radius:var(--radius);

    box-shadow:var(--shadow);

    transition:var(--transition);

}

.feature:hover{

    transform:translateY(-6px);

}

.feature h3{

    margin-bottom:1rem;

}

.feature p{

    margin-bottom:0;

}

/* ==========================================================
   IMAGE PLACEHOLDERS
========================================================== */

.image-placeholder{

    display:flex;

    align-items:center;

    justify-content:center;

    width:100%;

    aspect-ratio:16/9;

    border-radius:var(--radius-large);

    background:#DDE3E8;

    color:#7B8794;

    font-weight:600;

    text-align:center;

    box-shadow:var(--shadow);

}

.image-placeholder.tall{

    aspect-ratio:4/5;

}

.image-placeholder.square{

    aspect-ratio:1/1;

}

/* ==========================================================
   GALLERY
========================================================== */

.gallery{

    display:grid;

    grid-template-columns:2fr 1fr 1fr;

    gap:24px;

}

.gallery-main{

    grid-row:span 2;

}

.gallery-main .image-placeholder{

    height:100%;

    aspect-ratio:auto;

    min-height:420px;

}

.gallery-side{

    display:flex;

}

.gallery-side .image-placeholder{

    width:100%;

}

/* ==========================================================
   CONTACT CARDS
========================================================== */

.contact-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:30px;

}

.contact-card{

    background:var(--surface);

    border-radius:var(--radius);

    padding:36px;

    text-align:center;

    box-shadow:var(--shadow);

}

.contact-card h3{

    margin-bottom:1rem;

}

.contact-card p{

    margin-bottom:1.5rem;

}

.contact-card a{

    word-break:break-word;

}

/* ==========================================================
   CALL TO ACTION
========================================================== */

.cta{

    padding:96px 0;

}

.cta-box{

    background:var(--primary);

    color:#FFFFFF;

    border-radius:var(--radius-large);

    padding:64px;

    text-align:center;

    box-shadow:var(--shadow);

}

.cta-box h2{

    color:#FFFFFF;

    margin-bottom:1rem;

}

.cta-box p{

    color:rgba(255,255,255,.88);

    max-width:620px;

    margin:0 auto 2rem;

}

/* ==========================================================
   FOOTER
========================================================== */

footer{

    margin-top:96px;

    background:var(--primary-dark);

    color:#D8E0E7;

}

.footer{

    padding:56px 0 40px;

    display:flex;

    flex-direction:column;

    align-items:center;

    text-align:center;

    gap:1.5rem;

}

.footer img{

    height:56px;

    width:auto;

}

.footer-tagline{

    color:rgba(255,255,255,.88);

    font-weight:500;

    margin:0;

}

.footer-nav{

    display:flex;

    gap:2rem;

    flex-wrap:wrap;

    justify-content:center;

}

.footer-nav a{

    color:#D8E0E7;

    transition:var(--transition);

}

.footer-nav a:hover{

    color:#FFFFFF;

}

.footer-copy{

    font-size:.95rem;

    color:rgba(255,255,255,.72);

    margin:0;

}

/* ==========================================================
   UTILITIES
========================================================== */

.text-center{

    text-align:center;

}

.mt-2{

    margin-top:2rem;

}

.mt-3{

    margin-top:3rem;

}

.mb-0{

    margin-bottom:0;

}

.hidden{

    display:none;

}
/* ==========================================================
   RESPONSIVE DESIGN
========================================================== */

@media (max-width: 1024px){

    .hero-grid{

        grid-template-columns:1fr;

        gap:48px;

        text-align:center;

    }

    .hero-content{

        display:flex;

        flex-direction:column;

        align-items:center;

    }

    .hero-content p{

        max-width:640px;

    }

    .card-grid{

        grid-template-columns:1fr 1fr;

    }

    .feature-grid{

        grid-template-columns:1fr 1fr;

    }

    .contact-grid{

        grid-template-columns:1fr;

    }

    .gallery{

        grid-template-columns:1fr 1fr;

    }

    .gallery-main{

        grid-column:1 / -1;

        grid-row:auto;

    }

    .gallery-main .image-placeholder{

        min-height:320px;

    }

}

/* ==========================================================
   MOBILE
========================================================== */

@media (max-width:768px){

    body{

        font-size:17px;

    }

    .section{

        padding:72px 0;

    }

    .hero{

        padding:72px 0;

    }

    .page-hero{

        padding:64px 0 24px;

    }

    .nav-container{

        flex-direction:column;

        justify-content:center;

        gap:20px;

        padding:18px 0;

    }

    nav ul{

        flex-wrap:wrap;

        justify-content:center;

        gap:20px;

    }

    .logo img{

        height:52px;

    }

    h1{

        font-size:2.8rem;

    }

    h2{

        font-size:2rem;

    }

    h3{

        font-size:1.3rem;

    }

    .card-grid{

        grid-template-columns:1fr;

    }

    .feature-grid{

        grid-template-columns:1fr;

    }

    .gallery{

        grid-template-columns:1fr;

    }

    .gallery-main .image-placeholder{

        min-height:240px;

    }

    .gallery-side{

        display:block;

    }

    .image-placeholder{

        aspect-ratio:16/10;

    }

    .cta-box{

        padding:48px 32px;

    }

    .footer-nav{

        gap:1rem;

    }

}

/* ==========================================================
   SMALL MOBILE
========================================================== */

@media (max-width:480px){

    body{

        font-size:16px;

    }

    .container,

    .narrow{

        width:92%;

    }

    h1{

        font-size:2.3rem;

    }

    h2{

        font-size:1.8rem;

    }

    .btn{

        width:100%;

    }

    .card,

    .feature,

    .contact-card{

        padding:28px;

    }

    .cta-box{

        padding:36px 24px;

    }

}

/* ==========================================================
   ACCESSIBILITY
========================================================== */

:focus-visible{

    outline:3px solid var(--accent);

    outline-offset:3px;

}

::selection{

    background:rgba(221,0,0,.15);

}

img{

    user-select:none;

}

/* ==========================================================
   MOTION
========================================================== */

@media (prefers-reduced-motion: reduce){

    html{

        scroll-behavior:auto;

    }

    *{

        animation:none !important;

        transition:none !important;

    }

}

/* ==========================================================
   PRINT
========================================================== */

@media print{

    .navbar,

    footer,

    .btn{

        display:none;

    }

    body{

        background:#FFFFFF;

        color:#000000;

    }

    .section{

        padding:24px 0;

    }

}

/* ==========================================================
   END OF STYLESHEET
========================================================== */