/* ===== Mother Theresa School — theme ===== */
:root{
    --blue:#143d8c;        /* logo ring blue */
    --blue-dark:#0e2c66;
    --blue-light:#2f5bb7;
    --gold:#f6c019;        /* logo banner gold */
    --gold-dark:#e0a800;
    --ink:#1c2433;
    --muted:#5d6677;
    --bg:#f4f7fd;
    --white:#ffffff;
    --radius:14px;
    --shadow:0 10px 30px rgba(20,61,140,.12);
    --shadow-sm:0 4px 14px rgba(20,61,140,.10);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font-family:'Poppins',system-ui,sans-serif;
    color:var(--ink);
    background:var(--bg);
    line-height:1.65;
    overflow-x:clip;          /* contain decorative overflow (hero shape, negative margins, transforms) */
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,92%);margin-inline:auto}
section{padding:72px 0}

h1,h2,h3,h4{font-weight:700;line-height:1.2;color:var(--blue-dark)}
.section-head{text-align:center;max-width:680px;margin:0 auto 48px}
.section-head .kicker{
    color:var(--gold-dark);font-weight:700;letter-spacing:2px;
    text-transform:uppercase;font-size:.8rem;
}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.5rem);margin:8px 0 12px}
.section-head p{color:var(--muted)}

/* ===== Buttons ===== */
.btn{
    display:inline-block;padding:13px 30px;border-radius:50px;
    font-weight:600;transition:.25s;cursor:pointer;border:2px solid transparent;
}
.btn-primary{background:var(--gold);color:var(--blue-dark)}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-2px)}
.btn-outline{border-color:var(--white);color:var(--white)}
.btn-outline:hover{background:var(--white);color:var(--blue)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px)}
.btn-outline-blue{border-color:var(--blue);color:var(--blue)}
.btn-outline-blue:hover{background:var(--blue);color:#fff}

/* ===== Topbar ===== */
.topbar{background:var(--blue-dark);color:#dbe6ff;font-size:.85rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:8px 0;flex-wrap:wrap;gap:6px}
.topbar-contact{display:flex;gap:18px}
.topbar a:hover{color:var(--gold)}

/* ===== Header / nav ===== */
.site-header{background:var(--white);position:sticky;top:0;z-index:50;box-shadow:0 2px 14px rgba(0,0,0,.07)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:84px;width:auto;transition:.2s}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{color:var(--blue);font-size:1.3rem;letter-spacing:.2px}
.brand-text small{color:var(--gold-dark);font-style:italic;font-family:'Playfair Display',serif;font-size:.95rem}
.brand-tag{font-style:normal;font-size:.72rem;font-weight:600;color:var(--muted);letter-spacing:.3px;margin-top:2px}

.main-nav>ul{display:flex;align-items:center;gap:2px;list-style:none}
.main-nav ul{list-style:none}
.main-nav a{
    padding:8px 10px;border-radius:8px;font-weight:500;color:var(--ink);
    font-size:.9rem;transition:.2s;white-space:nowrap;
}
.main-nav a:hover,.main-nav a.active{color:var(--blue);background:#eef3fc}
.main-nav a.nav-cta{background:var(--gold);color:var(--blue-dark);font-weight:600;margin-left:6px}
.main-nav a.nav-cta:hover{background:var(--gold-dark)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:3px;background:var(--blue);border-radius:2px;transition:.3s}

/* ===== Dropdown menu ===== */
.has-dropdown{position:relative}
.main-nav .caret{font-size:.62rem;margin-left:1px}
.dropdown{
    position:absolute;top:100%;left:0;min-width:248px;list-style:none;
    background:#fff;border-radius:12px;box-shadow:0 16px 38px rgba(20,61,140,.18);
    padding:8px;border-top:3px solid var(--gold);
    opacity:0;visibility:hidden;transform:translateY(10px);transition:.22s;z-index:60;
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li{margin:0}
.dropdown a{display:block;padding:11px 14px;border-radius:8px;font-size:.92rem;white-space:nowrap;color:var(--ink)}
.dropdown a:hover{background:#eef3fc;color:var(--blue)}

/* ===== Hero ===== */
.hero{
    position:relative;color:#fff;text-align:center;
    background:linear-gradient(135deg,rgba(14,44,102,.92),rgba(20,61,140,.85)),
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 0h60v60H0z' fill='none'/%3E%3Cpath d='M30 0v60M0 30h60' stroke='%23ffffff10' stroke-width='1'/%3E%3C/svg%3E") repeat,
        radial-gradient(circle at top right,var(--blue-light),var(--blue-dark));
    padding:100px 0 110px;
    overflow:hidden;
}
.hero::after{
    content:"";position:absolute;left:0;right:0;bottom:-1px;height:70px;
    background:var(--bg);clip-path:polygon(0 100%,100% 100%,100% 0,75% 60%,50% 0,25% 60%,0 0);
}
.hero-inner{position:relative;z-index:2;max-width:820px;margin:0 auto}
.hero .badge{
    display:inline-block;background:rgba(246,192,25,.18);color:var(--gold);
    border:1px solid var(--gold);padding:6px 18px;border-radius:50px;
    font-size:.82rem;font-weight:600;letter-spacing:1px;margin-bottom:22px;
}
.hero h1{color:#fff;font-size:clamp(2.1rem,5vw,3.6rem);margin-bottom:18px}
.hero h1 span{color:var(--gold)}
.hero p{font-size:1.12rem;color:#dce6fb;max-width:640px;margin:0 auto 32px}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-motto{
    margin-top:38px;font-family:'Playfair Display',serif;font-style:italic;
    font-size:1.35rem;color:var(--gold);
}

/* ===== Stats ===== */
.stats{background:var(--white);margin-top:-40px;position:relative;z-index:5;padding:0}
.stats-grid{
    display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
    background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
    padding:34px;transform:translateY(-50px);
}
.stat{text-align:center;border-right:1px solid #eef0f5}
.stat:last-child{border:0}
.stat .num{font-size:2.2rem;font-weight:800;color:var(--blue)}
.stat .num span{color:var(--gold-dark)}
.stat .label{color:var(--muted);font-size:.92rem;font-weight:500}

/* ===== Feature cards ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:26px}
.card{
    background:var(--white);border-radius:var(--radius);padding:34px 28px;
    box-shadow:var(--shadow-sm);transition:.3s;border-top:4px solid transparent;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-top-color:var(--gold)}
.card .icon{
    width:64px;height:64px;border-radius:16px;display:grid;place-items:center;
    font-size:1.7rem;background:#eef3fc;color:var(--blue);margin-bottom:18px;
}
.card h3{font-size:1.2rem;margin-bottom:10px;color:var(--blue-dark)}
.card p{color:var(--muted);font-size:.95rem}

/* ===== About / split rows ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split .media{
    border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
    background:linear-gradient(135deg,var(--blue),var(--blue-light));
    min-height:340px;display:grid;place-items:center;padding:40px;
}
.split .media img{max-height:260px;width:auto;filter:drop-shadow(0 12px 24px rgba(0,0,0,.25))}
.split h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:8px}
.split .kicker{color:var(--gold-dark);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:.8rem}
.split p{color:var(--muted);margin:14px 0}
.tick{list-style:none;margin:18px 0}
.tick li{padding:7px 0 7px 32px;position:relative;color:var(--ink)}
.tick li::before{content:"✓";position:absolute;left:0;top:7px;color:#fff;background:var(--gold);
    width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:.75rem;font-weight:700}

.bg-soft{background:var(--white)}
.bg-blue{background:var(--blue-dark);color:#dce6fb}
.bg-blue h2,.bg-blue h3{color:#fff}

/* ===== Mission/Vision/Values trio ===== */
.mvv{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.mvv .card{border-top:4px solid var(--gold);text-align:center}

/* ===== Academics list ===== */
.levels{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.level{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s}
.level:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.level .head{background:linear-gradient(135deg,var(--blue),var(--blue-light));color:#fff;padding:24px 26px}
.level .head h3{color:#fff;margin-bottom:2px}
.level .head span{font-size:.85rem;opacity:.85}
.level .body{padding:24px 26px}
.level .body ul{list-style:none}
.level .body li{padding:6px 0 6px 26px;position:relative;color:var(--muted);font-size:.93rem}
.level .body li::before{content:"›";position:absolute;left:6px;color:var(--gold-dark);font-weight:800}

/* ===== Steps (admissions) ===== */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px}
.step{background:var(--white);border-radius:var(--radius);padding:34px 26px 28px;box-shadow:var(--shadow-sm);position:relative}
.step::before{
    counter-increment:step;content:counter(step);
    position:absolute;top:-22px;left:26px;width:46px;height:46px;border-radius:50%;
    background:var(--gold);color:var(--blue-dark);display:grid;place-items:center;
    font-weight:800;font-size:1.2rem;box-shadow:var(--shadow-sm);
}
.step h3{margin:12px 0 8px;font-size:1.12rem}
.step p{color:var(--muted);font-size:.93rem}

/* ===== Gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.gallery-grid figure{
    border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3;
    color:#fff;box-shadow:var(--shadow-sm);
}
.gallery-grid figure div{position:absolute;inset:0;display:grid;place-items:center;
    text-align:center;font-weight:600;padding:18px;
    background:linear-gradient(135deg,var(--blue),var(--blue-light))}
.gallery-grid figure:nth-child(3n+2) div{background:linear-gradient(135deg,var(--blue-dark),var(--blue))}
.gallery-grid figure:nth-child(3n) div{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:var(--blue-dark)}
.gallery-grid figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery-grid figcaption{position:absolute;bottom:0;left:0;right:0;background:rgba(14,44,102,.85);
    padding:10px 14px;font-size:.9rem;z-index:2}

/* ===== Gallery tabs ===== */
.gallery-tabs{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.gallery-tab{
    display:inline-flex;align-items:center;gap:8px;cursor:pointer;
    padding:12px 28px;border-radius:50px;font-family:inherit;font-weight:600;font-size:.98rem;
    border:2px solid var(--blue);background:transparent;color:var(--blue);transition:.25s;
}
.gallery-tab:hover{background:#eef3fc}
.gallery-tab.active{background:var(--blue);color:#fff;box-shadow:var(--shadow-sm)}

.gallery-panel{display:none;animation:fadeIn .4s ease}
.gallery-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ===== Video gallery ===== */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.video-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--white);transition:.3s}
.video-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.video-frame,.video-placeholder{position:relative;aspect-ratio:16/9;width:100%}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-placeholder{
    display:grid;place-items:center;cursor:pointer;
    background:linear-gradient(135deg,var(--blue-dark),var(--blue-light));
}
.video-placeholder::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.15)}
.video-card .play-btn{
    position:relative;z-index:2;width:64px;height:64px;border-radius:50%;
    display:grid;place-items:center;font-size:1.4rem;color:var(--blue-dark);
    background:var(--gold);box-shadow:0 6px 18px rgba(0,0,0,.3);transition:.25s;padding-left:4px;
}
.video-card:hover .play-btn{transform:scale(1.12);background:#fff}
.video-card figcaption{padding:14px 18px;font-weight:600;color:var(--blue-dark);font-size:.98rem}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(135deg,var(--blue),var(--blue-light));color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:12px}
.cta-band p{color:#dce6fb;max-width:560px;margin:0 auto 26px}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.info-card{background:var(--white);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);margin-bottom:18px;display:flex;gap:16px;align-items:flex-start}
.info-card .ic{font-size:1.5rem;background:#eef3fc;width:50px;height:50px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}
.info-card h4{margin-bottom:4px;color:var(--blue-dark)}
.info-card p,.info-card a{color:var(--muted);font-size:.95rem}
form.contact-form{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:500;margin-bottom:6px;font-size:.92rem}
.field input,.field textarea,.field select{
    width:100%;padding:12px 14px;border:1px solid #dfe5ef;border-radius:10px;
    font-family:inherit;font-size:.95rem;transition:.2s;background:#fbfcfe;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--blue);background:#fff}
.form-note{margin-top:14px;font-size:.85rem}
.form-note.ok{color:#1a8a4a}
.form-note.err{color:#c0392b}

/* ===== Page banner ===== */
.page-banner{background:linear-gradient(135deg,var(--blue-dark),var(--blue));color:#fff;text-align:center;padding:64px 0}
.page-banner h1{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem)}
.page-banner p{color:#cdd9f3;margin-top:8px}
.breadcrumb{margin-top:14px;font-size:.9rem;color:#aebfe4}
.breadcrumb a:hover{color:var(--gold)}

/* ===== Footer ===== */
.site-footer{background:var(--blue-dark);color:#b9c6e6;padding-top:60px;font-size:.94rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.4fr 1.2fr;gap:36px;padding-bottom:42px}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer-brand img{height:48px;background:#fff;border-radius:8px;padding:3px}
.footer-brand span{color:#fff;font-weight:700;font-size:1.1rem}
.footer-motto{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);margin-bottom:8px}
.footer-col h4{color:#fff;margin-bottom:16px;font-size:1.05rem;position:relative;padding-bottom:10px}
.footer-col h4::after{content:"";position:absolute;left:0;bottom:0;width:36px;height:3px;background:var(--gold);border-radius:2px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:9px}
.footer-col a:hover{color:var(--gold)}
.footer-contact li{display:flex;gap:8px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;text-align:center;font-size:.86rem;color:#8fa1cc}

/* ===== Leader message page ===== */
.leader-photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.leader-photo img{width:100%;height:auto;display:block}
.leader-placeholder{aspect-ratio:4/5;display:grid;place-items:center;
    background:linear-gradient(135deg,var(--blue),var(--blue-light));color:#fff;font-weight:600;font-size:1.3rem}
.leader-meta{text-align:center;margin-top:16px}
.leader-meta strong{display:block;color:var(--blue-dark);font-size:1.2rem}
.leader-meta span{color:var(--gold-dark);font-weight:600}
.lead-quote{font-family:'Playfair Display',serif;font-style:italic;font-size:1.25rem;color:var(--blue);margin:16px 0 14px!important}
.signature{margin-top:22px;font-weight:600;color:var(--blue-dark)}
.signature small{color:var(--muted);font-weight:400}

/* ===== Management team grid ===== */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px}
.team-card{background:#fff;border-radius:var(--radius);padding:30px 24px;text-align:center;box-shadow:var(--shadow-sm);transition:.3s;border-bottom:4px solid transparent}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-bottom-color:var(--gold)}
.team-photo{width:118px;height:118px;margin:0 auto 16px;border-radius:50%;overflow:hidden;border:4px solid #eef3fc}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-placeholder{width:100%;height:100%;display:grid;place-items:center;
    background:linear-gradient(135deg,var(--blue),var(--blue-light));color:#fff;font-weight:700;font-size:1.9rem;letter-spacing:1px}
.team-card h3{color:var(--blue-dark);font-size:1.15rem;margin-bottom:2px}
.team-role{color:var(--gold-dark);font-weight:600;font-size:.9rem}
.team-card p{color:var(--muted);font-size:.92rem;margin-top:10px}

/* ===== Academics extras ===== */
.academics-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px}
.rules-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;max-width:980px;margin:0 auto}
.rule-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-sm)}
.rule-item p{color:var(--muted);font-size:.95rem}
.rule-no{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.9rem}
.note-box{max-width:980px;margin:30px auto 0;background:#fff8e1;border-left:4px solid var(--gold);border-radius:10px;padding:18px 22px;color:#7a5d00;font-size:.95rem}
.info-panel{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.info-panel h3{color:var(--blue-dark);margin-bottom:8px}
.steps-inline{margin:18px 0 22px}
.step-inline{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}
.step-inline span{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--gold);color:var(--blue-dark);display:grid;place-items:center;font-weight:700}
.step-inline p{color:var(--muted);font-size:.95rem}

/* ===== News ===== */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.news-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;display:flex;flex-direction:column}
.news-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.news-thumb{position:relative;display:block;aspect-ratio:16/9;overflow:hidden}
.news-thumb img{width:100%;height:100%;object-fit:cover}
.news-thumb-ph{position:absolute;inset:0;display:grid;place-items:center;font-size:2.4rem;background:linear-gradient(135deg,var(--blue),var(--blue-light))}
.news-cat{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--blue-dark);font-size:.74rem;font-weight:700;padding:4px 12px;border-radius:50px}
.news-body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.news-body time{color:var(--gold-dark);font-size:.82rem;font-weight:600}
.news-body h3{font-size:1.12rem;margin:6px 0 8px;line-height:1.35}
.news-body h3 a{color:var(--blue-dark)}
.news-body h3 a:hover{color:var(--blue)}
.news-body p{color:var(--muted);font-size:.92rem;flex:1}
.read-more{margin-top:12px;color:var(--blue);font-weight:600;font-size:.9rem}
.read-more:hover{color:var(--gold-dark)}

/* News pager */
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:42px}
.pager-btn{padding:9px 20px;border-radius:50px;background:var(--blue);color:#fff;font-weight:600;font-size:.9rem}
.pager-btn:hover{background:var(--blue-dark)}
.pager-btn.disabled{background:#cfd8e8;color:#fff;pointer-events:none}
.pager-info{color:var(--muted);font-size:.9rem}

/* News article */
.article-wrap{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
.article{background:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.article-hero{width:100%;border-radius:12px;margin-bottom:20px}
.article p{color:#384357;margin-bottom:16px}
.article-aside{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.article-aside h3{color:var(--blue-dark);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #eef0f5}
.aside-item{display:block;padding:12px 0;border-bottom:1px solid #f0f2f7}
.aside-item:last-child{border:0}
.aside-cat{display:inline-block;font-size:.7rem;font-weight:700;color:var(--gold-dark);text-transform:uppercase;letter-spacing:.5px}
.aside-item strong{display:block;color:var(--blue-dark);font-size:.96rem;margin:2px 0;line-height:1.35}
.aside-item:hover strong{color:var(--blue)}
.aside-item time{color:var(--muted);font-size:.8rem}

/* ===== Downloads ===== */
.download-group{margin-bottom:38px}
.download-cat{font-size:1.3rem;color:var(--blue-dark);margin-bottom:18px;padding-bottom:10px;border-bottom:2px solid #eef0f5;position:relative}
.download-cat::after{content:"";position:absolute;left:0;bottom:-2px;width:60px;height:2px;background:var(--gold)}
.download-list{display:grid;gap:14px}
.download-item{display:flex;align-items:center;gap:18px;background:#fff;border-radius:var(--radius);
    padding:18px 22px;box-shadow:var(--shadow-sm);transition:.25s;border-left:4px solid var(--blue)}
.download-item:hover{transform:translateX(4px);box-shadow:var(--shadow);border-left-color:var(--gold)}
.dl-icon{flex-shrink:0;width:54px;height:54px;border-radius:11px;display:grid;place-items:center;
    background:#eef3fc;color:var(--blue);font-weight:800;font-size:.74rem;letter-spacing:.3px}
.dl-info{display:flex;flex-direction:column;flex:1;min-width:0}
.dl-info strong{color:var(--blue-dark);font-size:1.03rem}
.dl-info small{color:var(--muted);font-size:.88rem;margin-top:2px}
.dl-meta{color:var(--gold-dark);font-size:.78rem;font-weight:600;margin-top:5px}
.dl-btn{flex-shrink:0;background:var(--blue);color:#fff;font-weight:600;font-size:.88rem;
    padding:9px 18px;border-radius:50px;transition:.2s;white-space:nowrap}
.download-item:hover .dl-btn{background:var(--gold);color:var(--blue-dark)}

/* ===== Testimonials ===== */
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px}
.testimonial-card{background:#fff;border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm);position:relative;transition:.3s}
.testimonial-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.quote-mark{font-family:'Playfair Display',serif;font-size:4rem;line-height:.6;color:var(--gold);height:34px}
.testimonial-card blockquote{color:#384357;font-size:.97rem;line-height:1.7;margin:10px 0 14px;font-style:italic}
.testimonial-card .stars{color:var(--gold);letter-spacing:2px;margin-bottom:16px}
.testimonial-card figcaption{display:flex;align-items:center;gap:14px;border-top:1px solid #eef0f5;padding-top:16px}
.t-avatar{width:50px;height:50px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;overflow:hidden;
    background:linear-gradient(135deg,var(--blue),var(--blue-light));color:#fff;font-weight:700}
.t-avatar img{width:100%;height:100%;object-fit:cover}
.t-meta strong{display:block;color:var(--blue-dark)}
.t-meta small{color:var(--gold-dark);font-weight:600}

/* Footer affiliation */
.footer-affil{margin-top:14px;font-size:.85rem;color:#cdd9f3}
.footer-affil small{color:#8fa1cc}

/* Honeypot — hidden from humans, visible to bots */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* ===== Skip link (accessibility) ===== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--blue);color:#fff;
    padding:12px 20px;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{left:0}

/* ===== Footer bottom bar ===== */
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.footer-bottom-inner a:hover{color:var(--gold)}

/* ===== Floating buttons ===== */
.floaters{position:fixed;right:18px;bottom:18px;z-index:90;display:flex;flex-direction:column;gap:12px}
.float-btn{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-size:1.3rem;
    cursor:pointer;border:0;box-shadow:0 6px 18px rgba(0,0,0,.22);transition:.25s;background:#fff;color:#fff}
.float-btn:hover{transform:translateY(-3px) scale(1.05)}
.float-btn.wa{background:#25d366}
.float-btn.call{background:var(--blue)}
.float-btn.top{background:var(--gold);color:var(--blue-dark);font-weight:800;opacity:0;visibility:hidden}
.float-btn.top.show{opacity:1;visibility:visible}
@media(max-width:480px){
    .floaters{right:12px;bottom:12px;gap:10px}
    .float-btn{width:46px;height:46px;font-size:1.15rem}
}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:.7s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:1080px){
    .article-wrap{grid-template-columns:1fr}
}
@media(max-width:920px){
    .split{grid-template-columns:1fr}
    .mvv{grid-template-columns:1fr}
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .stat:nth-child(2){border:0}
    .contact-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr 1fr}
}

/* Hamburger menu kicks in early since the nav has many items + a large logo,
   so the horizontal bar only shows at widths where it comfortably fits. */
@media(max-width:1200px){
    .nav-toggle{display:flex}
    .main-nav{
        position:absolute;top:100%;left:0;right:0;background:#fff;
        box-shadow:0 12px 24px rgba(0,0,0,.12);max-height:0;overflow:hidden;transition:.35s;
    }
    .main-nav.open{max-height:80vh;overflow-y:auto}
    .main-nav>ul{flex-direction:column;align-items:stretch;gap:0;padding:10px 4%}
    .main-nav a{padding:14px;border-radius:8px;font-size:.98rem}
    .main-nav a.nav-cta{margin:8px 0 4px;text-align:center}
    /* Dropdown submenus show expanded inline on mobile */
    .dropdown{
        position:static;opacity:1;visibility:visible;transform:none;
        box-shadow:none;border-top:0;border-left:3px solid var(--gold);
        border-radius:0;margin:0 0 6px 10px;padding:0;background:#f7f9fd;min-width:0;
    }
    .has-dropdown .caret{display:none}
    .dropdown a{padding:12px 14px;font-size:.92rem;white-space:normal}
}
@media(max-width:760px){
    .brand img{height:64px}
    .brand-text strong{font-size:1.08rem}
    .brand-tag{display:none}
    .topbar-inner{justify-content:center;text-align:center}
    .topbar-contact{gap:12px;flex-wrap:wrap;justify-content:center}
    .hero{padding:74px 0 90px}
    .hero-actions{flex-direction:column;align-items:stretch}
    .hero-actions .btn{width:100%}
    section{padding:52px 0}
    .article,.testimonial-card,.info-panel{padding:24px 20px}
}
@media(max-width:480px){
    .brand img{height:56px}
    .brand-text small{font-size:.82rem}
    .stats-grid{grid-template-columns:1fr;transform:translateY(-30px)}
    .stat{border:0;border-bottom:1px solid #eef0f5;padding-bottom:14px}
    .stat:last-child{border:0}
    .rules-list,.news-grid,.testimonial-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr}
    .pager{gap:10px}
    .pager-info{display:none}
    .download-item{flex-wrap:wrap}
    .dl-btn{width:100%;text-align:center;margin-top:6px}
}
