@font-face{font-family:Fraunces;src:url('/assets/fonts/fraunces.woff2') format('woff2');font-weight:300 900;font-style:normal;font-display:swap}
@font-face{font-family:Inter;src:url('/assets/fonts/inter.woff2') format('woff2');font-weight:300 800;font-style:normal;font-display:swap}

:root{
--c-bg:#FBF7F0;--c-bg-2:#F3EBDD;--c-surface:#FFFFFF;--c-surface-2:#FCF8F1;
--c-ink:#2A2018;--c-muted:#7A6E60;--c-line:rgba(42,32,24,.12);--c-line-2:rgba(42,32,24,.2);
--c-burg:#8E1B2E;--c-burg-2:#A8223A;--c-emerald:#1E6E52;--c-gold:#C49A55;--c-gold-soft:#F1E4CB;
--ease:cubic-bezier(.22,1,.36,1);--r-sm:10px;--r-md:16px;--r-lg:22px;--r-xl:30px;
--header-offset:70px;--shadow:0 16px 44px rgba(42,32,24,.12);--shadow-sm:0 6px 18px rgba(42,32,24,.08)}

*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:Inter,system-ui,sans-serif;background:var(--c-bg);color:var(--c-ink);line-height:1.65;overflow-x:clip;width:100%;max-width:100%;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}
main{flex:1}
h1,h2,h3,h4,h5,h6{font-family:Fraunces,Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em;overflow-wrap:break-word;word-break:break-word;text-wrap:balance}
p{overflow-wrap:break-word;word-break:break-word}
a{color:inherit;text-decoration:none;overflow-wrap:break-word;word-break:break-word}
img,svg,video{max-width:100%;display:block}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:0 0;color:inherit}
input,select,textarea{font-family:inherit;font-size:16px}
::selection{background:var(--c-burg);color:#fff}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.container{max-width:1240px;margin:0 auto;padding-inline:28px}
@media(max-width:820px){.container{padding-inline:20px}}
@media(max-width:520px){.container{padding-inline:15px}}
.section{padding-block:clamp(36px,8vw,100px)}
.section--tight{padding-block:clamp(38px,6vw,64px)}
.section--alt{background:var(--c-bg-2)}
.section__head{margin-bottom:clamp(14px,4vw,48px);max-width:760px}
.section__head--center{text-align:center;margin-inline:auto}
.kicker{display:inline-flex;align-items:center;gap:8px;font-family:Inter;font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-burg)}
.kicker svg{width:17px;height:17px}
.section__title{font-size:clamp(28px,4.4vw,46px);margin-top:10px}
.section__lead{margin-top:14px;color:var(--c-muted);font-size:clamp(15px,1.7vw,18px)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:Inter;font-weight:600;font-size:16px;letter-spacing:.01em;padding:13px 26px;border-radius:var(--r-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;user-select:none;position:relative}
.btn svg{width:19px;height:19px;flex-shrink:0}
.btn--primary{background:var(--c-burg);color:#fff;box-shadow:0 10px 26px rgba(142,27,46,.28)}
.btn--primary:hover{background:var(--c-burg-2);transform:translateY(-2px);box-shadow:0 16px 34px rgba(142,27,46,.34)}
.btn--ghost{background:var(--c-surface);color:var(--c-ink);border:1px solid var(--c-line-2)}
.btn--ghost:hover{background:var(--c-surface-2);transform:translateY(-2px)}
.btn--emerald{background:var(--c-emerald);color:#fff;box-shadow:0 10px 26px rgba(30,110,82,.24)}
.btn--emerald:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(30,110,82,.32)}
.btn--block{width:100%}
.btn--sm{padding:10px 18px;font-size:14.5px}
@media(max-width:520px){.btn{white-space:normal;text-align:center}}

.age-pill{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:50%;border:2px solid var(--c-burg);color:var(--c-burg);font-family:Fraunces;font-weight:700;font-size:15px;flex-shrink:0;background:rgba(142,27,46,.06)}
.age-pill--sm{width:38px;height:38px;font-size:13px;border-width:1.6px}

/* Header */
.site-header{position:sticky;top:0;z-index:60;backdrop-filter:blur(12px);background:rgba(251,247,240,.86);border-bottom:1px solid var(--c-line)}
.site-header__row{display:flex;align-items:center;justify-content:space-between;gap:22px;padding-block:13px}
.brand{display:flex;align-items:center;gap:11px;font-family:Fraunces;font-weight:700;font-size:21px;letter-spacing:-.01em;flex-shrink:0}
.brand__mark{width:40px;height:40px;flex-shrink:0;display:block;border-radius:11px}
.brand b{color:var(--c-burg)}
.brand span{color:var(--c-ink)}
.nav{display:flex;align-items:center;gap:4px}
.nav a:not(.nav-cta){position:relative;font-family:Inter;font-weight:600;font-size:15.5px;padding:8px 13px;border-radius:9px;color:var(--c-ink);transition:color .25s var(--ease),background .25s var(--ease)}
.nav a:not(.nav-cta)::after{content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;border-radius:2px;background:var(--c-burg);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav a:not(.nav-cta):hover{color:var(--c-burg)}
.nav a:not(.nav-cta):hover::after,.nav a:not(.nav-cta).is-active::after{transform:scaleX(1)}
.nav a.is-active:not(.nav-cta){color:var(--c-burg)}
.nav .nav-cta{margin-left:8px}
.header-tools{display:flex;align-items:center;gap:10px;flex-shrink:0}
.burger{display:none;width:44px;height:44px;position:relative;z-index:110;flex-shrink:0;border-radius:11px;background:var(--c-surface);border:1px solid var(--c-line);-webkit-tap-highlight-color:transparent;user-select:none}
.burger span{position:absolute;left:12px;right:12px;height:2px;background:var(--c-ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease),top .3s var(--ease)}
.burger span:first-child{top:calc(50% - 7px)}.burger span:nth-child(2){top:calc(50% - 1px)}.burger span:nth-child(3){top:calc(50% + 5px)}
.burger[aria-expanded=true] span:first-child{top:calc(50% - 1px);transform:rotate(45deg)}
.burger[aria-expanded=true] span:nth-child(2){opacity:0}
.burger[aria-expanded=true] span:nth-child(3){top:calc(50% - 1px);transform:rotate(-45deg)}
@media(max-width:1220px){
.burger{display:block}
.nav{position:absolute;top:100%;left:0;right:0;width:100%;max-width:100vw;max-height:calc(100dvh - var(--header-offset));z-index:100;flex-direction:column;align-items:stretch;gap:0;padding:14px 22px 26px;background:var(--c-surface);border-top:1px solid var(--c-line);box-shadow:0 18px 40px rgba(42,32,24,.16);overflow-y:auto;overscroll-behavior:contain;transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;transition:transform .3s var(--ease),opacity .25s var(--ease),visibility 0s linear .3s}
.nav[data-open=true]{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto;transition:transform .3s var(--ease),opacity .25s var(--ease),visibility 0s linear 0s}
.nav a:not(.nav-cta){width:100%;padding:15px 6px;font-size:18px;border-bottom:1px solid var(--c-line);border-radius:0}
.nav a:not(.nav-cta)::after{display:none}
.nav .nav-cta{margin:16px 0 0;width:100%}
}

/* Hero with video */
.hero{position:relative;overflow:hidden;isolation:isolate;min-height:clamp(520px,80vh,720px);display:flex;align-items:center;border-bottom:1px solid var(--c-line)}
.hero__media{position:absolute;inset:0;z-index:-2;background:#1a120c url('/assets/img/hero/poster.avif') center/cover no-repeat}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(28,18,10,.82) 0,rgba(28,18,10,.55) 48%,rgba(28,18,10,.25) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;padding-block:clamp(44px,12vw,120px)}
.hero__content{max-width:660px;color:#fff}
.hero__tag{display:inline-flex;align-items:center;gap:8px;font-family:Inter;font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:#fff;padding:7px 15px;border:1px solid rgba(255,255,255,.4);border-radius:100px;background:rgba(255,255,255,.1);margin-bottom:20px}
.hero__tag svg{width:16px;height:16px;color:var(--c-gold)}
.hero__title{font-size:clamp(36px,6.4vw,68px);line-height:1.02;color:#fff}
.hero__title .accent{color:var(--c-gold)}
.hero__desc{margin-top:18px;font-size:clamp(16px,2vw,20px);color:rgba(255,255,255,.92);max-width:560px}
.hero__actions{margin-top:30px;display:flex;flex-wrap:wrap;gap:14px}
.hero__note{margin-top:22px;display:inline-flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,.85)}
.hero__note .age-pill{border-color:rgba(255,255,255,.6);color:#fff;background:rgba(255,255,255,.12)}
@media(prefers-reduced-motion:reduce){.hero__video{display:none}}
@media(max-width:820px){.hero{min-height:auto}.hero__video{display:none}.hero__content{max-width:100%}.hero__tag,.hero__actions{display:none}}

/* Reveal */
.first-reveal{animation:firstReveal .7s var(--ease) both}
.first-reveal--1{animation-delay:.04s}.first-reveal--2{animation-delay:.14s}.first-reveal--3{animation-delay:.24s}.first-reveal--4{animation-delay:.34s}
@keyframes firstReveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.first-reveal,.reveal{opacity:1!important;transform:none!important;animation:none!important}}

/* Grid */
.grid{display:grid;gap:22px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

/* Operator card (TOP 4) */
.opcard{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;position:relative}
.opcard:hover{transform:translateY(-5px);border-color:var(--c-line-2);box-shadow:var(--shadow)}
.opcard__rank{position:absolute;top:14px;right:14px;z-index:2;width:34px;height:34px;display:grid;place-items:center;border-radius:10px;background:var(--c-gold-soft);color:var(--c-burg);font-family:Fraunces;font-weight:700;font-size:16px}
.opcard__logo{display:flex;align-items:center;justify-content:center;height:96px;padding:18px;background:var(--c-surface-2);border-bottom:1px solid var(--c-line)}
.opcard__logo img{max-height:48px;max-width:170px;width:auto;height:auto;object-fit:contain}
.top4__note{margin-top:26px;text-align:center;color:var(--c-muted);font-size:14.5px}
.opcard__body{padding:20px;display:flex;flex-direction:column;gap:14px;flex:1}
.opcard__intro{color:var(--c-muted);font-size:14.5px}
.opcard__specs{display:flex;flex-direction:column;gap:9px}
.opcard__spec{display:flex;gap:11px;align-items:flex-start;font-size:14px}
.opcard__spec svg{width:18px;height:18px;flex-shrink:0;color:var(--c-emerald);margin-top:2px}
.opcard__spec b{font-weight:600;color:var(--c-ink)}
.opcard__spec span{color:var(--c-muted)}
.opcard__foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:6px}
.opcard__lic{position:absolute;top:96px;left:50%;z-index:3;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--c-emerald);background:var(--c-surface);border:1px solid rgba(30,110,82,.35);padding:2px 12px;border-radius:100px;width:fit-content;white-space:nowrap;box-shadow:var(--shadow-sm)}
.opcard__lic svg{width:14px;height:14px;flex-shrink:0}

/* Comparison table */
.tablewrap{overflow-x:auto;border:1px solid var(--c-line);border-radius:var(--r-md);background:var(--c-surface)}
.cmptable{width:100%;border-collapse:collapse;min-width:680px}
.cmptable th,.cmptable td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--c-line);font-size:14.5px}
.cmptable thead th{font-family:Inter;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:12.5px;color:var(--c-burg);background:var(--c-surface-2)}
.cmptable tbody tr:last-child td{border-bottom:none}
.cmptable tbody tr:hover{background:var(--c-surface-2)}
.cmptable td:first-child{font-family:Fraunces;font-weight:600;font-size:16px;color:var(--c-ink)}
.cmptable .yes{color:var(--c-emerald);font-weight:600}
.cmptable .yes svg{width:17px;height:17px;display:inline-block;vertical-align:-3px}

/* Guides */
.guide{padding:26px;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;height:100%}
.guide:hover{transform:translateY(-4px);border-color:var(--c-line-2);box-shadow:var(--shadow-sm)}
.guide__ic{width:54px;height:54px;display:grid;place-items:center;border-radius:14px;background:var(--c-gold-soft);color:var(--c-burg);margin-bottom:16px}
.guide__ic svg{width:27px;height:27px}
.guide h3{font-size:21px;margin-bottom:8px}
.guide p{color:var(--c-muted);font-size:14.5px}

/* FAQ */
.faq{display:flex;flex-direction:column;gap:14px}
.faq details{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;font-family:Fraunces;font-weight:600;font-size:18.5px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:var(--c-bg-2);color:var(--c-burg);transition:transform .3s var(--ease),background .3s,color .3s}
.faq summary .ic svg{width:18px;height:18px}
.faq details.is-open summary .ic{transform:rotate(180deg);background:var(--c-burg);color:#fff}
.faq__body{padding:0 22px 20px;color:var(--c-muted);font-size:15px;overflow:hidden}

/* CTA band */
.cta-band{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:clamp(34px,5vw,60px);background:linear-gradient(120deg,var(--c-burg),#6c1322);color:#fff}
.cta-band::after{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border-radius:50%;background:rgba(196,154,85,.22)}
.cta-band__inner{position:relative;z-index:2;max-width:620px}
.cta-band h2{font-size:clamp(26px,4vw,42px);color:#fff}
.cta-band p{color:rgba(255,255,255,.9);margin-top:12px;font-size:17px}
.cta-band .btn{margin-top:24px}

/* Info tiles (contact) */
.info-tile{display:flex;gap:14px;align-items:flex-start;padding:22px;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md)}
.info-tile .ic{flex-shrink:0;width:48px;height:48px;display:grid;place-items:center;border-radius:13px;background:var(--c-gold-soft);color:var(--c-burg)}
.info-tile .ic svg{width:24px;height:24px}
.info-tile h3{font-size:18px;margin-bottom:3px}
.info-tile a,.info-tile p{color:var(--c-muted);font-size:14.5px}
.info-tile a:hover{color:var(--c-burg)}

/* Form */
.formcard{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:clamp(24px,4vw,40px)}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-family:Inter;font-weight:600;font-size:14px}
.field input,.field textarea{background:var(--c-surface-2);border:1px solid var(--c-line);border-radius:var(--r-sm);padding:13px 16px;color:var(--c-ink);transition:border-color .2s,background .2s}
.field textarea{resize:none;min-height:140px}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--c-burg);background:var(--c-surface)}

/* Disclaimer box */
.disclaimer{display:flex;gap:18px;align-items:flex-start;padding:24px;background:var(--c-surface);border:1px solid var(--c-line);border-left:4px solid var(--c-burg);border-radius:var(--r-md)}
.disclaimer .ic{flex-shrink:0;width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:var(--c-gold-soft);color:var(--c-burg)}
.disclaimer .ic svg{width:24px;height:24px}
.disclaimer p{color:var(--c-muted);font-size:14.5px}
.disclaimer strong{color:var(--c-ink)}

/* RG plate (grouped by geo) */
.rg-groups{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.rg-group{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);padding:24px;display:flex;flex-direction:column;gap:18px}
.rg-group__head{display:flex;align-items:center;gap:10px}
.rg-group__flag{width:26px;height:26px;flex-shrink:0;display:grid;place-items:center;border-radius:7px;background:var(--c-gold-soft);color:var(--c-burg)}
.rg-group__flag svg{width:16px;height:16px}
.rg-group__label{font-family:Inter;font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--c-burg)}
.rg-group__logos{display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.rg-group__logos a{display:inline-flex;align-items:center;padding:12px 16px;background:var(--c-surface-2);border:1px solid var(--c-line);border-radius:var(--r-sm);transition:border-color .25s,transform .25s,box-shadow .25s}
.rg-group__logos a:hover{border-color:var(--c-line-2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.rg-group__logos img{height:38px;width:auto}
@media(max-width:760px){.rg-groups{grid-template-columns:1fr}}

/* Page hero */
.page-hero{position:relative;padding-block:clamp(56px,9vw,96px) clamp(36px,6vw,60px);border-bottom:1px solid var(--c-line);background:var(--c-bg-2)}
.page-hero h1{font-size:clamp(32px,5.6vw,56px)}
.page-hero h1 .accent{color:var(--c-burg)}
.page-hero p{margin-top:14px;color:var(--c-muted);font-size:clamp(16px,2vw,19px);max-width:680px}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13.5px;color:var(--c-muted);margin-bottom:14px}
.breadcrumb a{display:inline-block;padding:3px 0}
.breadcrumb a:hover{color:var(--c-burg)}

/* Prose / legal */
.prose-block h2{font-size:clamp(22px,3vw,30px);margin:34px 0 12px}
.prose-block h2:first-child{margin-top:0}
.prose-block h3{font-size:20px;margin:22px 0 8px}
.prose-block li,.prose-block p{color:#544a3e;font-size:15px;margin-bottom:10px}
.prose-block ul{margin:0 0 14px 22px;list-style:disc}
.prose-block li{margin-bottom:6px}
.prose-block a{color:var(--c-burg);font-weight:600}
.lead-text{font-size:clamp(16px,2vw,19px);color:var(--c-ink);margin-bottom:20px}

/* Footer (centered stack) */
.site-footer{margin-top:auto;background:#241B13;color:#d8ccbb}
.footer-top{text-align:center;padding-block:clamp(40px,6vw,60px) 30px}
.footer-brand{display:inline-flex;align-items:center;gap:11px;font-family:Fraunces;font-weight:700;font-size:24px;color:#fff;margin-bottom:10px}
.footer-brand .brand__mark{border-radius:10px}
.footer-tagline{color:#b9ab98;font-size:15px;max-width:560px;margin:0 auto}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 4px;margin-top:24px}
.footer-nav a{padding:7px 14px;font-size:14.5px;color:#d8ccbb;border-radius:8px;transition:color .2s,background .2s}
.footer-nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.footer-nav--legal{margin-top:4px}
.footer-nav--legal a{color:#b9ab98;font-size:13.5px}
.footer-rule{height:1px;background:rgba(255,255,255,.12);margin:0 auto;max-width:760px}
.footer-disc{max-width:820px;margin:0 auto;text-align:center;padding-block:26px;display:flex;flex-direction:column;align-items:center;gap:14px}
.footer-disc .age-pill{border-color:var(--c-gold);color:var(--c-gold);background:rgba(196,154,85,.12)}
.footer-disc p{color:#b9ab98;font-size:13.5px;max-width:720px}
.footer-disc strong{color:#efe6d8}
.footer-rg{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;margin-top:4px}
.footer-rg a{display:inline-flex;align-items:center;padding:5px 8px;background:#FBF7F0;border:1px solid rgba(0,0,0,.06);border-radius:10px;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.footer-rg a:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(0,0,0,.35)}
.footer-rg img{height:32px;width:auto}
.footer-bottom{text-align:center;padding-block:22px;border-top:1px solid rgba(255,255,255,.1);color:#9c8f7d;font-size:13px}
.footer-bottom a{color:var(--c-gold)}

/* Chat */
.chat-toggle{position:fixed;right:22px;bottom:22px;z-index:90;width:62px;height:62px;border-radius:50%;background:var(--c-burg);color:#fff;display:grid;place-items:center;box-shadow:0 14px 32px rgba(142,27,46,.42);transition:transform .3s var(--ease)}
.chat-toggle svg{width:28px;height:28px}
.chat-toggle:hover{transform:scale(1.08)}
.chat-toggle__dot{position:absolute;top:3px;right:3px;width:14px;height:14px;border-radius:50%;background:var(--c-emerald);border:3px solid var(--c-bg)}
.chat-panel{position:fixed;right:22px;bottom:96px;z-index:91;width:360px;height:460px;max-width:calc(100vw - 32px);max-height:calc(100dvh - 120px);background:var(--c-surface);border:1px solid var(--c-line-2);border-radius:var(--r-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(16px) scale(.97);pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.chat-panel[data-open=true]{opacity:1;transform:none;pointer-events:auto}
.chat-head{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--c-burg);color:#fff}
.chat-head__av{width:42px;height:42px;border-radius:50%;background:#fff;color:var(--c-burg);display:grid;place-items:center;flex-shrink:0}
.chat-head__av svg{width:24px;height:24px}
.chat-head__t{flex:1;min-width:0}
.chat-head__t b{font-family:Fraunces;font-weight:700;font-size:17px;display:block;line-height:1.1}
.chat-head__t small{font-size:12px;display:flex;align-items:center;gap:5px}
.chat-head__t small::before{content:"";width:8px;height:8px;border-radius:50%;background:#5fd49b}
.chat-close{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;color:#fff;transition:background .2s}
.chat-close:hover{background:rgba(255,255,255,.18)}
.chat-close svg{width:20px;height:20px}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--c-surface-2)}
.msg{max-width:84%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5}
.msg--bot{align-self:flex-start;background:var(--c-surface);border:1px solid var(--c-line);border-bottom-left-radius:4px}
.msg--user{align-self:flex-end;background:var(--c-burg);color:#fff;border-bottom-right-radius:4px}
.chat-quick{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 10px;background:var(--c-surface-2)}
.chat-quick button{font-size:12.5px;padding:7px 12px;border-radius:100px;background:var(--c-gold-soft);border:1px solid var(--c-line);color:var(--c-burg);transition:background .2s}
.chat-quick button:hover{background:#e8d6b6}
.chat-foot{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--c-line)}
.chat-foot input{flex:1;min-width:0;background:var(--c-surface-2);border:1px solid var(--c-line);border-radius:100px;padding:11px 16px;color:var(--c-ink);font-size:14px}
.chat-foot input:focus{outline:0;border-color:var(--c-burg)}
.chat-send{width:44px;height:44px;flex-shrink:0;border-radius:50%;background:var(--c-burg);color:#fff;display:grid;place-items:center;transition:transform .2s}
.chat-send:hover{transform:scale(1.07)}
.chat-send svg{width:20px;height:20px}
.typing{display:inline-flex;gap:4px;align-items:center}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--c-muted);animation:1.2s infinite typing}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* Cookie */
body:has(.cookie.show) .chat-toggle{transform:translateY(-84px)}
.cookie{position:fixed;left:22px;bottom:22px;z-index:95;max-width:380px;background:var(--c-surface);border:1px solid var(--c-line-2);border-radius:var(--r-md);padding:20px;box-shadow:var(--shadow);transform:translateY(160%);transition:transform .45s var(--ease)}
.cookie.show{transform:none}
.cookie h3{font-size:18px;margin-bottom:6px}
.cookie p{font-size:13.5px;color:var(--c-muted)}
.cookie p a{color:var(--c-burg);font-weight:600;display:inline-block;padding:2px 0}
.cookie__btns{margin-top:14px;display:flex;gap:10px}
@media(max-width:520px){.cookie{left:14px;right:14px;bottom:14px;max-width:none}}

/* Toast */
.toast-backdrop{position:fixed;inset:0;z-index:120;background:rgba(42,32,24,.5);backdrop-filter:blur(3px);display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .3s}
.toast-backdrop.show{opacity:1;pointer-events:auto}
.toast{background:var(--c-surface);border:1px solid var(--c-line-2);border-radius:var(--r-lg);padding:30px 34px;text-align:center;max-width:380px;width:calc(100% - 40px);transform:scale(.9);transition:transform .3s var(--ease);box-shadow:var(--shadow)}
.toast-backdrop.show .toast{transform:none}
.toast__ic{width:64px;height:64px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;background:rgba(30,110,82,.12);color:var(--c-emerald)}
.toast__ic svg{width:34px;height:34px}
.toast--err .toast__ic{background:rgba(142,27,46,.12);color:var(--c-burg)}
.toast h3{font-size:23px;margin-bottom:6px}
.toast p{color:var(--c-muted);font-size:14.5px}

/* Responsive grid collapse */
@media(max-width:1100px){.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}
@media(max-width:820px){.opcard__intro{font-size:13px}.hero__desc{font-size:13px}}
@media(max-width:440px){.site-header__row{gap:10px}.brand{font-size:17px;gap:8px}.brand__mark{width:34px;height:34px}.burger{width:40px;height:40px}}
@media(max-width:340px){.brand{font-size:15px}.brand__mark{width:30px;height:30px}}
