:root{
    --text:#233342;
    --bg:#ffffff;
    --muted:#6b7785;
    --accent:#2D98DA;
    --accent-dark:#1d7dbb;
    --cta-bg:#303952;
    --card-bg:#fafbfc;
    --card-bg-hover:#f3f5f7;
    --border:#e6e8eb;
    --radius:14px;
    --radius-sm:8px;
    --shadow:0 1px 3px rgba(35,51,66,.06),0 8px 24px rgba(35,51,66,.04);
    --container:1100px;
    --gap:24px;
    --font-title:'Ubuntu',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    --font-body:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:var(--font-body);
    font-size:16px;
    line-height:1.55;
    color:var(--text);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,h5,h6{
    font-family:var(--font-title);
    font-weight:700;
    line-height:1.2;
    margin:0 0 .5em;
    color:var(--text);
}
h1{font-size:clamp(28px,4vw,40px)}
h2{font-size:clamp(24px,3vw,32px)}
h3{font-size:clamp(20px,2.4vw,24px)}
h4{font-size:clamp(18px,2vw,20px)}
h5{font-size:17px}
p{margin:0 0 1em}
small{color:var(--muted)}
.container{
    max-width:var(--container);
    margin:0 auto;
    padding:0 20px;
}
section{padding:60px 0}
@media(max-width:640px){section{padding:40px 0}}

/* Header */
.site-header{
    border-bottom:1px solid var(--border);
    background:#fff;
    position:sticky;
    top:0;
    z-index:100;
    backdrop-filter:saturate(180%) blur(8px);
}
.site-header__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:14px 20px;
    max-width:var(--container);
    margin:0 auto;
    gap:16px;
}
.site-logo{
    font-family:var(--font-title);
    font-weight:700;
    font-size:18px;
    color:var(--text);
    display:flex;
    align-items:center;
    gap:10px;
}
.site-logo:hover{text-decoration:none}
.site-logo img{width:36px;height:36px;border-radius:50%}
.site-nav{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.site-nav a{
    color:var(--text);
    padding:8px 12px;
    border-radius:var(--radius-sm);
    font-size:14px;
    font-weight:500;
}
.site-nav a:hover{background:var(--card-bg);text-decoration:none}
.site-nav a.cta{
    background:var(--accent);
    color:#fff;
}
.site-nav a.cta:hover{background:var(--accent-dark)}
.nav-toggle{
    display:none;
    background:none;
    border:none;
    width:36px;
    height:36px;
    cursor:pointer;
    padding:0;
    border-radius:var(--radius-sm);
}
.nav-toggle:hover{background:var(--card-bg)}
.nav-toggle span{
    display:block;
    width:22px;
    height:2px;
    background:var(--text);
    margin:5px auto;
    transition:transform .25s,opacity .25s;
}
@media(max-width:880px){
    .nav-toggle{display:block}
    .site-nav{
        display:none;
        position:absolute;
        top:100%;
        left:0;
        right:0;
        background:#fff;
        border-bottom:1px solid var(--border);
        padding:8px 20px 16px;
        flex-direction:column;
        align-items:stretch;
        gap:2px;
    }
    .site-nav.open{display:flex}
    .site-nav a{padding:12px 14px;font-size:15px}
}

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:14px 28px;
    border-radius:999px;
    font-family:var(--font-body);
    font-weight:600;
    font-size:15px;
    line-height:1;
    cursor:pointer;
    border:1px solid transparent;
    transition:background .15s,border-color .15s,transform .05s;
    text-align:center;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
    background:var(--accent);
    color:#fff;
}
.btn-primary:hover{background:var(--accent-dark);text-decoration:none;color:#fff}
.btn-outline{
    background:transparent;
    color:var(--accent);
    border-color:var(--accent);
}
.btn-outline:hover{background:var(--accent);color:#fff;text-decoration:none}
.btn-white{
    background:#fff;
    color:var(--cta-bg);
}
.btn-white:hover{background:#f0f3f8;text-decoration:none;color:var(--cta-bg)}
.btn-block{width:100%}

/* Hero */
.hero{
    padding:80px 0 40px;
}
.hero__inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:48px;
    align-items:center;
}
@media(max-width:760px){
    .hero{padding:40px 0 20px}
    .hero__inner{grid-template-columns:1fr;gap:24px}
}
.hero__img{
    border-radius:var(--radius);
    overflow:hidden;
    aspect-ratio:1/1;
    background:var(--card-bg);
}
.hero__img img{width:100%;height:100%;object-fit:cover}
.hero h1{margin-bottom:16px}
.hero__lead{font-size:18px;color:var(--muted);margin:0}

/* CTA section */
.cta-section{
    background:var(--cta-bg);
    color:#fff;
    text-align:center;
}
.cta-section h2{color:#fff}
.cta-section p{color:rgba(255,255,255,.85);font-size:18px;margin-bottom:24px}

/* Cards grid */
.grid{
    display:grid;
    gap:var(--gap);
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:760px){
    .grid-3,.grid-2{grid-template-columns:1fr}
}
.card{
    background:var(--card-bg);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:28px;
    display:flex;
    flex-direction:column;
}
.card h3,.card h4,.card h5{margin-top:0}
.card__img{
    border-radius:var(--radius-sm);
    margin-bottom:16px;
    aspect-ratio:1/1;
    object-fit:cover;
    width:100%;
}
.card__caption{color:var(--muted);font-size:14px}

/* Interactive feature tiles (one block per format on /buy.html) */
.ff-block{
    background:#fff;
    border:1px solid var(--border);
    border-radius:24px;
    padding:32px;
    margin:28px 0 36px;
    box-shadow:0 4px 16px rgba(35,51,66,.04);
}
@media(max-width:600px){.ff-block{padding:24px 18px;border-radius:18px}}
.ff-block__title{
    font-size:20px;
    margin:0 0 18px;
    color:var(--navy);
}
.ff-tiles{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
    gap:12px;
}
.ff-tile{
    background:var(--card-bg);
    border:1.5px solid var(--border);
    border-radius:16px;
    padding:18px 16px;
    cursor:pointer;
    font:inherit;
    text-align:left;
    display:flex;
    flex-direction:column;
    gap:10px;
    align-items:flex-start;
    transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease, color .15s ease;
    color:var(--text);
}
.ff-tile:hover{
    transform:translateY(-3px);
    box-shadow:0 10px 22px rgba(45,152,218,.12);
    border-color:var(--accent);
    background:#fff;
}
.ff-tile:hover .ff-tile__emoji{
    transform:rotate(-6deg) scale(1.12);
}
.ff-tile:focus-visible{
    outline:none;
    border-color:var(--accent);
    box-shadow:0 0 0 4px rgba(45,152,218,.18);
}
.ff-tile.is-active{
    background:linear-gradient(135deg, var(--accent), var(--accent-dark));
    color:#fff;
    border-color:transparent;
    box-shadow:0 14px 28px rgba(45,152,218,.32);
}
.ff-tile.is-active .ff-tile__emoji{
    transform:scale(1.12);
}
.ff-tile__emoji{
    font-size:30px;
    display:inline-block;
    transition:transform .25s cubic-bezier(.5,1.6,.5,1);
    line-height:1;
}
.ff-tile__text{
    font-size:14.5px;
    font-weight:600;
    line-height:1.3;
}
@keyframes ff-pop{
    0%   {transform:scale(1)}
    35%  {transform:scale(1.06)}
    100% {transform:scale(1)}
}
.ff-tile.is-popping{
    animation:ff-pop .32s ease;
}
.ff-detail{
    margin-top:18px;
    padding:18px 22px;
    background:var(--card-bg);
    border:1.5px dashed var(--border);
    border-radius:14px;
    color:var(--muted);
    font-size:15px;
    line-height:1.55;
    min-height:62px;
    display:flex;
    align-items:center;
    gap:14px;
    transition:background .25s, border-color .25s, color .25s;
}
.ff-detail__icon{
    font-size:28px;
    display:inline-block;
    line-height:1;
    flex-shrink:0;
}
.ff-detail p{margin:0}
.ff-detail.is-detailed{
    background:linear-gradient(135deg, #f6fbff, #eef7fd);
    border-style:solid;
    border-color:#c7e3f5;
    color:var(--text);
}

/* Product cards */
.products{
    display:grid;
    gap:24px;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
}
.product{
    background:var(--card-bg);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:28px;
    display:flex;
    flex-direction:column;
    transition:border-color .15s,transform .15s,box-shadow .15s;
}
.product:hover{
    border-color:var(--accent);
    transform:translateY(-2px);
    box-shadow:var(--shadow);
}
.product__title{
    font-size:20px;
    margin:0 0 12px;
    line-height:1.3;
}
.product__price{
    font-family:var(--font-title);
    font-size:30px;
    font-weight:700;
    color:var(--text);
    margin:0 0 4px;
}
.product__price-per{
    color:var(--muted);
    font-size:14px;
    margin:0 0 4px;
}
.product__discount{
    color:#1aa974;
    font-size:13px;
    font-weight:600;
    margin:0 0 16px;
}
.product__features{
    list-style:none;
    padding:0;
    margin:16px 0 24px;
    font-size:14px;
    color:var(--text);
    flex:1;
}
.product__features li{
    padding:6px 0;
}
.product__buy{margin-top:auto}

/* Three formats / numbered */
.formats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
    align-items:center;
}
@media(max-width:760px){.formats{grid-template-columns:1fr}}
.formats__list{display:flex;flex-direction:column;gap:24px}
.format-item{display:flex;gap:16px;align-items:flex-start}
.format-num{
    flex:0 0 44px;
    height:44px;
    border-radius:50%;
    background:var(--card-bg);
    border:2px solid var(--accent);
    color:var(--accent);
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:700;
    font-family:var(--font-title);
    font-size:18px;
}
.format-item h5{margin:0 0 4px}
.format-item p{margin:0;color:var(--muted)}

/* Footer */
.site-footer{
    border-top:1px solid var(--border);
    padding:48px 0 32px;
    background:#fff;
}
.site-footer__inner{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:24px;
    text-align:center;
}
.site-footer__logo img{width:80px;height:80px;border-radius:50%}
.site-footer__nav{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:8px 24px;
}
.site-footer__nav a{color:var(--text);font-size:14px}
.site-footer__legal{
    color:var(--muted);
    font-size:13px;
    line-height:1.6;
    border-top:1px solid var(--border);
    padding-top:20px;
    width:100%;
    max-width:600px;
}

/* Generic content blocks */
.lead{font-size:18px;color:var(--muted)}
.center{text-align:center}
.muted{color:var(--muted)}
.divider{
    border:0;
    border-top:1px solid var(--border);
    margin:48px 0;
}
.legal-content{
    max-width:760px;
    margin:0 auto;
}
.legal-content h2{margin-top:32px}
.legal-content h3{margin-top:24px;font-size:18px}
.legal-content p,
.legal-content li{font-size:15px;line-height:1.7}
.legal-content ul,.legal-content ol{padding-left:20px;margin:0 0 1em}

/* Contacts cards */
.contacts{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
}
@media(max-width:640px){.contacts{grid-template-columns:1fr}}
.contact-card{
    background:var(--card-bg);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:32px 24px;
    text-align:center;
}
.contact-card img{
    width:120px;
    height:120px;
    border-radius:50%;
    margin:0 auto 16px;
    object-fit:cover;
}
.contact-card h3{margin:0 0 8px}
.contact-card p{color:var(--muted);margin:0 0 16px;font-size:14px}

/* Highlight box */
.highlight{
    background:#eef7fd;
    border:1px solid #c6e3f5;
    border-radius:var(--radius);
    padding:24px;
    margin:24px 0;
}
.highlight h3{margin-top:0;color:var(--accent-dark)}

/* Tabs / category headings */
.category-block{margin-bottom:72px}
.category-block:last-child{margin-bottom:0}
.category-block__intro{
    margin-bottom:32px;
}
.category-block h2{
    font-size:clamp(24px,2.4vw,30px);
    margin-bottom:8px;
    line-height:1.2;
}
.category-block__price-hint{
    color:var(--accent);
    font-weight:600;
    font-size:16px;
    margin:0 0 16px;
}
.category-block__header{
    display:grid;
    grid-template-columns:240px 1fr;
    gap:36px;
    align-items:center;
    margin-bottom:28px;
}
@media(max-width:760px){
    .category-block__header{
        grid-template-columns:1fr;
        gap:20px;
        text-align:center;
    }
}
.category-block__visual{
    aspect-ratio:1/1;
    border-radius:24px;
    overflow:hidden;
    background:var(--card-bg);
    box-shadow:0 10px 30px rgba(35,51,66,.10);
}
.category-block__visual img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.category-block__heading h2{margin:0 0 8px}
.category-block__heading > p:not(.category-block__price-hint){
    color:var(--muted);
    line-height:1.55;
    margin:0;
}

/* Reviews placeholder */
.reviews-empty{
    text-align:center;
    color:var(--muted);
    padding:48px 0;
    font-size:18px;
}

/* Pay status pages */
.status-page{
    padding:80px 0;
    text-align:center;
}
.status-page__icon{
    font-size:64px;
    margin-bottom:24px;
    display:block;
}
.status-page h1{margin-bottom:16px}
.status-page p{font-size:18px;color:var(--muted);margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}

/* =====================================================
   HOMEPAGE — premium redesign with motion + interactions
   ===================================================== */

:root{
    --warm:#ff9f43;
    --warm-soft:#fff4e6;
    --navy:#1a2440;
    --navy-soft:#f0f4fb;
    --gradient-hero: radial-gradient(at 20% 20%, rgba(45,152,218,.10), transparent 50%),
                     radial-gradient(at 85% 70%, rgba(255,159,67,.10), transparent 50%);
}

html{scroll-behavior:smooth}

/* Reveal-on-scroll baseline */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* ===== HERO ===== */
.home-hero{
    position:relative;
    overflow:hidden;
    padding:80px 0 60px;
    background:var(--gradient-hero);
}
.home-hero__inner{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:64px;
    align-items:center;
    position:relative;
}
@media(max-width:880px){
    .home-hero{padding:48px 0 40px}
    .home-hero__inner{grid-template-columns:1fr;gap:32px;text-align:center}
}
.home-hero__eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:6px 14px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:999px;
    font-size:13px;
    color:var(--accent);
    font-weight:600;
    margin-bottom:24px;
    box-shadow:var(--shadow);
}
.home-hero__eyebrow::before{
    content:"";
    width:8px;height:8px;border-radius:50%;
    background:#1aa974;
    box-shadow:0 0 0 3px rgba(26,169,116,.2);
    animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
    0%,100%{box-shadow:0 0 0 3px rgba(26,169,116,.2)}
    50%{box-shadow:0 0 0 6px rgba(26,169,116,.05)}
}
.home-hero__title{
    font-size:clamp(40px,7vw,72px);
    line-height:1;
    margin:0 0 20px;
    letter-spacing:-.02em;
    color:var(--navy);
}
.home-hero__title em{
    font-style:normal;
    background:linear-gradient(135deg, var(--accent), #5dd5ff);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
}
.home-hero__lead{
    font-size:clamp(17px,1.6vw,20px);
    color:var(--muted);
    margin:0 0 32px;
    max-width:480px;
    line-height:1.55;
}
@media(max-width:880px){.home-hero__lead{margin-left:auto;margin-right:auto}}
.home-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:880px){.home-hero__cta{justify-content:center}}
.home-hero__btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:16px 32px;
    border-radius:999px;
    font-weight:700;
    font-size:16px;
    border:2px solid transparent;
    transition:transform .15s, box-shadow .15s, background .15s;
}
.home-hero__btn-primary{
    background:linear-gradient(135deg, var(--accent), var(--accent-dark));
    color:#fff;
    box-shadow:0 8px 24px rgba(45,152,218,.35);
}
.home-hero__btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(45,152,218,.45);text-decoration:none;color:#fff}
.home-hero__btn-ghost{
    background:transparent;
    color:var(--navy);
    border-color:var(--border);
}
.home-hero__btn-ghost:hover{background:#fff;border-color:var(--accent);text-decoration:none}

/* Hero visual */
.home-hero__visual{
    position:relative;
    aspect-ratio:1/1;
    max-width:480px;
    margin-left:auto;
}
@media(max-width:880px){.home-hero__visual{margin:0 auto;max-width:340px}}
.home-hero__photo{
    position:relative;
    width:100%;
    height:100%;
    border-radius:32px;
    overflow:hidden;
    box-shadow:0 30px 60px rgba(35,51,66,.18);
    animation:float 8s ease-in-out infinite;
}
.home-hero__photo img{width:100%;height:100%;object-fit:cover}
@keyframes float{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-10px)}
}
.home-hero__badge{
    position:absolute;
    background:#fff;
    border-radius:18px;
    padding:14px 18px;
    box-shadow:0 12px 32px rgba(35,51,66,.12);
    display:flex;
    align-items:center;
    gap:12px;
    font-size:14px;
    font-weight:600;
    animation:float 6s ease-in-out infinite;
}
.home-hero__badge--1{top:8%;left:-8%;animation-delay:.3s}
.home-hero__badge--2{bottom:14%;right:-10%;animation-delay:1.2s}
.home-hero__badge--3{top:55%;left:-12%;animation-delay:.8s}
@media(max-width:880px){
    .home-hero__badge--1{left:-2%}
    .home-hero__badge--2{right:-2%}
    .home-hero__badge--3{display:none}
}
.home-hero__badge-emoji{font-size:22px}
.home-hero__badge-text{line-height:1.2}
.home-hero__badge-text small{display:block;color:var(--muted);font-weight:500;font-size:12px}

/* Hero stats strip */
.home-stats{
    margin-top:60px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:0;
    border-top:1px solid var(--border);
    padding-top:32px;
}
@media(max-width:720px){.home-stats{grid-template-columns:repeat(2,1fr);gap:24px}}
.home-stat{padding:0 16px;text-align:center;border-right:1px solid var(--border)}
.home-stat:last-child{border-right:none}
@media(max-width:720px){.home-stat{border-right:none}}
.home-stat__num{
    font-family:var(--font-title);
    font-size:clamp(28px,3vw,40px);
    font-weight:700;
    color:var(--navy);
    line-height:1;
    margin:0 0 6px;
}
.home-stat__num em{font-style:normal;color:var(--accent)}
.home-stat__label{font-size:13px;color:var(--muted);margin:0}

/* ===== SECTION HEADINGS ===== */
.home-section{padding:88px 0;position:relative}
@media(max-width:720px){.home-section{padding:56px 0}}
.home-section--tinted{background:var(--navy-soft)}
.home-section--dark{background:var(--navy);color:#fff}
.home-section--dark h2,.home-section--dark h3{color:#fff}
.home-section--dark .home-eyebrow{color:#5dd5ff}

.home-eyebrow{
    display:inline-block;
    font-size:13px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:var(--accent);
    margin-bottom:14px;
}
.home-h2{
    font-size:clamp(28px,3.5vw,40px);
    line-height:1.15;
    letter-spacing:-.01em;
    margin:0 0 14px;
    max-width:680px;
}
.home-section__lead{
    font-size:17px;
    color:var(--muted);
    max-width:560px;
    line-height:1.55;
}
.home-section--dark .home-section__lead{color:rgba(255,255,255,.7)}

/* ===== 3P CARDS ===== */
.home-3p{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:48px;
}
@media(max-width:880px){.home-3p{grid-template-columns:1fr}}
.home-3p__card{
    background:#fff;
    border:1px solid var(--border);
    border-radius:24px;
    padding:32px 28px;
    transition:transform .25s, box-shadow .25s, border-color .25s;
    position:relative;
    overflow:hidden;
}
.home-3p__card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(35,51,66,.10);
    border-color:transparent;
}
.home-3p__card::after{
    content:"";
    position:absolute;
    inset:auto -40px -40px auto;
    width:140px;
    height:140px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(45,152,218,.12), transparent 60%);
    opacity:0;
    transition:opacity .3s;
}
.home-3p__card:hover::after{opacity:1}
.home-3p__img{
    width:100%;
    aspect-ratio:335/478;
    object-fit:cover;
    border-radius:18px;
    margin:0 0 22px;
    display:block;
}
.home-3p__num{
    font-family:var(--font-title);
    font-weight:700;
    font-size:13px;
    color:var(--accent);
    letter-spacing:.1em;
    margin-bottom:8px;
}
.home-3p__title{
    font-size:22px;
    margin:0 0 10px;
    line-height:1.2;
}
.home-3p__desc{
    color:var(--muted);
    font-size:15px;
    line-height:1.55;
    margin:0;
}

/* ===== BEFORE/AFTER COMPARE SLIDER ===== */
.compare-wrap{margin-top:48px;max-width:980px}
.compare{
    position:relative;
    aspect-ratio:16/9;
    overflow:hidden;
    border-radius:24px;
    user-select:none;
    touch-action:none;
    cursor:ew-resize;
    box-shadow:0 30px 60px rgba(0,0,0,.30);
    background:#000;
}
@media(max-width:600px){.compare{aspect-ratio:4/5}}
.compare__img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    user-select:none;
    -webkit-user-drag:none;
    pointer-events:none;
}
.compare__clip{
    position:absolute;
    inset:0;
    width:50%;
    overflow:hidden;
    will-change:width;
}
.compare__handle{
    position:absolute;
    top:0;
    bottom:0;
    width:3px;
    left:50%;
    transform:translateX(-50%);
    background:#fff;
    box-shadow:0 0 18px rgba(0,0,0,.45);
    pointer-events:none;
    will-change:left;
}
.compare__handle-circle{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:56px;
    height:56px;
    background:#fff;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--navy);
    box-shadow:0 8px 22px rgba(0,0,0,.30);
}
.compare__handle-circle svg{width:24px;height:24px}
.compare__label{
    position:absolute;
    top:20px;
    padding:8px 16px;
    background:rgba(0,0,0,.7);
    color:#fff;
    border-radius:999px;
    font-size:14px;
    font-weight:600;
    letter-spacing:.02em;
    backdrop-filter:blur(8px);
    pointer-events:none;
    z-index:2;
}
.compare__label--left{left:20px}
.compare__label--right{right:20px}
.compare__hint{
    margin-top:18px;
    text-align:center;
    color:var(--muted);
    font-size:14px;
}
.compare__hint kbd{
    display:inline-block;
    padding:2px 8px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:6px;
    font-family:inherit;
    font-size:12px;
    color:var(--navy);
}

/* ===== FORMATS TABS ===== */
.formats-tabs{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin-top:32px;
    padding:6px;
    background:#fff;
    border-radius:999px;
    border:1px solid var(--border);
    width:fit-content;
}
@media(max-width:600px){.formats-tabs{width:100%;border-radius:18px}}
.formats-tab{
    padding:12px 22px;
    background:transparent;
    border:none;
    cursor:pointer;
    border-radius:999px;
    font:inherit;
    font-weight:600;
    font-size:15px;
    color:var(--muted);
    transition:background .2s, color .2s;
    display:inline-flex;
    align-items:center;
    gap:8px;
}
.formats-tab:hover{color:var(--navy)}
.formats-tab.is-active{
    background:var(--navy);
    color:#fff;
}
@media(max-width:600px){.formats-tab{flex:1;justify-content:center;padding:10px 14px;font-size:14px}}

.formats-panel{
    display:none;
    margin-top:40px;
    grid-template-columns:1fr 1fr;
    gap:48px;
    align-items:center;
}
.formats-panel.is-active{display:grid}
@media(max-width:880px){.formats-panel{grid-template-columns:1fr;gap:24px}}
.formats-panel__visual{
    aspect-ratio:1/1;
    border-radius:24px;
    overflow:hidden;
    max-width:420px;
    width:100%;
}
.formats-panel__visual img{width:100%;height:100%;object-fit:cover}
.formats-panel h3{font-size:clamp(24px,2.5vw,32px);margin:0 0 16px}
.formats-panel__features{
    list-style:none;
    padding:0;
    margin:24px 0 32px;
}
.formats-panel__features li{
    padding:10px 0;
    border-bottom:1px solid var(--border);
    display:flex;
    gap:12px;
    font-size:15px;
}
.formats-panel__features li::before{
    content:"✓";
    color:var(--accent);
    font-weight:700;
}
.formats-panel__price{
    display:flex;
    align-items:baseline;
    gap:12px;
    margin-bottom:20px;
}
.formats-panel__price-num{
    font-family:var(--font-title);
    font-size:32px;
    font-weight:700;
    color:var(--navy);
}
.formats-panel__price-label{color:var(--muted);font-size:14px}

/* ===== REVIEWS MARQUEE ===== */
.reviews-marquee{
    overflow:hidden;
    margin:48px 0 0;
    position:relative;
    mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.reviews-marquee__track{
    display:flex;
    gap:18px;
    width:max-content;
    animation:marquee 60s linear infinite;
}
.reviews-marquee:hover .reviews-marquee__track{animation-play-state:paused}
@keyframes marquee{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
}
.reviews-marquee__item{
    flex:0 0 auto;
    width:240px;
    height:160px;
    border-radius:16px;
    overflow:hidden;
    background:#fff;
    border:1px solid var(--border);
    transition:transform .25s, box-shadow .25s;
    cursor:pointer;
}
.reviews-marquee__item:hover{
    transform:translateY(-4px);
    box-shadow:0 16px 32px rgba(0,0,0,.10);
}
.reviews-marquee__item img{width:100%;height:100%;object-fit:cover}

/* ===== TEAM CARDS ===== */
.home-team{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:32px;
    margin-top:48px;
}
@media(max-width:720px){.home-team{grid-template-columns:1fr}}
.home-team__card{
    position:relative;
    aspect-ratio:4/5;
    border-radius:24px;
    overflow:hidden;
    cursor:default;
}
.home-team__card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .6s ease;
}
.home-team__card:hover img{transform:scale(1.04)}
.home-team__card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(26,36,64,.85) 0%, rgba(26,36,64,0) 50%);
}
.home-team__caption{
    position:absolute;
    left:24px;right:24px;bottom:24px;
    color:#fff;
    z-index:1;
}
.home-team__role{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:rgba(255,255,255,.7);
    margin:0 0 4px;
}
.home-team__name{font-size:24px;margin:0;color:#fff;font-family:var(--font-title);font-weight:700}

/* ===== CONTACTS ===== */
.home-contacts{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
    margin-top:48px;
}
@media(max-width:720px){.home-contacts{grid-template-columns:1fr}}
.home-contact{
    background:#fff;
    border:1px solid var(--border);
    border-radius:24px;
    padding:32px;
    display:flex;
    gap:20px;
    align-items:center;
    transition:border-color .2s, transform .2s;
}
.home-contact:hover{border-color:var(--accent);transform:translateY(-2px)}
.home-contact__avatar{
    width:80px;height:80px;
    border-radius:50%;
    object-fit:cover;
    flex-shrink:0;
}
.home-contact__body{flex:1;min-width:0}
.home-contact h3{font-size:20px;margin:0 0 4px}
.home-contact p{color:var(--muted);font-size:14px;margin:0 0 14px;line-height:1.4}
.home-contact__tg{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:var(--accent);
    font-weight:600;
    font-size:15px;
}
.home-contact__tg:hover{color:var(--accent-dark);text-decoration:none}
.home-contact__tg::before{
    content:"";
    width:18px;height:18px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232D98DA'%3E%3Cpath d='M9.78 18.65l.28-4.23 7.68-6.92c.34-.31-.07-.46-.52-.19L7.74 13.3 3.64 12c-.88-.25-.89-.86.2-1.3l15.97-6.16c.73-.33 1.43.18 1.15 1.3l-2.72 12.81c-.19.91-.74 1.13-1.5.71L12.6 16.3l-1.99 1.93c-.23.23-.42.42-.83.42z'/%3E%3C/svg%3E");
    background-size:contain;
    background-repeat:no-repeat;
}

/* ===== TEACHERS CTA ===== */
.home-teachers{
    background:linear-gradient(135deg, var(--navy) 0%, #243056 100%);
    color:#fff;
    border-radius:32px;
    padding:64px;
    position:relative;
    overflow:hidden;
    text-align:center;
}
@media(max-width:720px){.home-teachers{padding:40px 24px;border-radius:24px}}
.home-teachers::before{
    content:"";
    position:absolute;
    top:-50%;right:-20%;
    width:600px;height:600px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(93,213,255,.15), transparent 60%);
}
.home-teachers__inner{position:relative;z-index:1}
.home-teachers h2{color:#fff;margin-bottom:14px}
.home-teachers p{color:rgba(255,255,255,.75);font-size:17px;max-width:520px;margin:0 auto 28px}
.home-teachers__btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:18px 36px;
    background:var(--warm);
    color:var(--navy);
    border-radius:999px;
    font-weight:700;
    font-size:16px;
    transition:transform .15s, box-shadow .15s;
    box-shadow:0 10px 28px rgba(255,159,67,.35);
}
.home-teachers__btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(255,159,67,.45);text-decoration:none;color:var(--navy)}

/* ===== HOMEPAGE BODY ADJUSTMENTS ===== */
body.home main > section{padding:0}  /* override generic padding for home sections */
body.home main > .home-hero{padding:80px 0 60px}
@media(max-width:880px){body.home main > .home-hero{padding:48px 0 40px}}
body.home main > .home-section{padding:88px 0}
@media(max-width:720px){body.home main > .home-section{padding:56px 0}}

