:root{
  --bg:#FFFCFD; --surface:#FFF6F8; --surface-2:#FCECEF; --primary:#8A1538; --secondary:#5E0E27;
  --accent:#B08D57; --ink:#1F1115; --muted:#7A5B66; --line:#EFD6DE;
  --font-head:"Changa",system-ui,sans-serif;
  --font-body:"Tajawal",system-ui,sans-serif;
  --radius:16px; --maxw:1200px;
  --on-grad:#ffffff; --glow:rgba(138,21,56,.30);
  --grad:linear-gradient(135deg,var(--primary),var(--secondary));
  --grad-soft:linear-gradient(135deg,rgba(138,21,56,.12),rgba(176,141,87,.10));
  --body-2:#44403C; --nav-bg:rgba(255,253,249,.82);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(58vw 48vh at 8% -6%,rgba(180,83,9,.13),transparent 62%),
    radial-gradient(46vw 40vh at 96% 4%,rgba(14,116,144,.11),transparent 58%),
    radial-gradient(52vw 50vh at 70% 110%,rgba(124,45,18,.08),transparent 62%),
    linear-gradient(180deg,rgba(248,241,231,.55),transparent 30%);
  animation:bg-drift 28s ease-in-out infinite alternate}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(44vw 46vh at 86% 22%,rgba(14,116,144,.10),transparent 60%),radial-gradient(30vw 34vh at 12% 64%,rgba(180,83,9,.07),transparent 62%);
  animation:bg-drift2 34s ease-in-out infinite alternate}
@keyframes bg-drift{to{transform:translate3d(-4%,3%,0) scale(1.10)}}
@keyframes bg-drift2{to{transform:translate3d(4%,-4%,0) scale(1.13)}}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.13;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.3rem,5.5vw,4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
h3{font-size:1.2rem}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{color:var(--muted)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);
  font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);padding:6px 14px;border:1px solid var(--line);border-radius:999px;background:var(--surface)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.section{padding:96px 0}
.section-head{max-width:640px;margin-bottom:48px}
.section-head p{margin-top:14px;font-size:1.05rem}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-head);font-weight:600;
  font-size:.98rem;padding:14px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s,box-shadow .25s,background .25s}
.btn-primary{background:var(--grad);color:var(--on-grad);box-shadow:0 12px 30px -10px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px var(--glow)}
.btn-ghost{background:var(--surface);border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--primary);transform:translateY(-2px)}
.btn:focus-visible{outline:2px solid var(--primary);outline-offset:3px}

.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:var(--nav-bg);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:700;font-size:1.22rem}
.logo img{width:34px;height:34px;border-radius:9px}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{font-size:.95rem;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{padding:10px 20px;color:var(--on-grad)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;
  width:44px;height:44px;cursor:pointer;color:var(--ink);font-size:1.3rem}

.hero{padding:72px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{margin:22px 0 20px}
.hero p.lead{font-size:1.15rem;max-width:520px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:32px 0 26px}
.platforms{display:flex;gap:10px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--muted);
  padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:var(--surface)}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}
.hero-visual{position:relative}
.hero-visual img{width:100%;border-radius:24px;border:1px solid var(--line);
  box-shadow:0 40px 80px -36px rgba(15,23,42,.30)}

.puzzle-card{position:absolute;bottom:-26px;inset-inline-end:-14px;background:var(--surface);
  border:1px solid var(--line);border-radius:18px;padding:16px;width:236px;
  box-shadow:0 30px 60px -24px rgba(15,23,42,.28)}
.puzzle-card h4{font-size:.82rem;color:var(--muted);font-weight:500;margin-bottom:11px;
  display:flex;justify-content:space-between;align-items:center}
.puzzle{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.puzzle button{aspect-ratio:1;border:none;border-radius:11px;background:var(--grad);
  color:var(--on-grad);font-family:var(--font-head);font-weight:700;font-size:1.15rem;cursor:pointer;
  transition:transform .15s,filter .15s}
.puzzle button:hover{filter:brightness(1.08)}
.puzzle button.empty{background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--line);cursor:default}
.puzzle-win{font-size:.8rem;color:var(--primary);font-weight:600;text-align:center;margin-top:10px;min-height:1.1em}
.link-btn{background:none;border:none;color:var(--primary);font-size:.78rem;cursor:pointer;font-family:var(--font-head);font-weight:600}

.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0;margin-top:48px}
.metric .v{font-family:var(--font-head);font-weight:700;font-size:clamp(1.8rem,3vw,2.5rem);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.metric .l{color:var(--muted);font-size:.92rem;margin-top:4px}

.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.chip{font-family:var(--font-head);font-size:.88rem;font-weight:500;padding:9px 18px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;transition:.2s}
.chip:hover{color:var(--ink)}
.chip.active{background:var(--grad);color:var(--on-grad);border-color:transparent}
.games-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.game{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:22px;
  transition:transform .3s,border-color .3s,box-shadow .3s}
.game:hover{transform:translateY(-6px);border-color:var(--primary);box-shadow:0 24px 50px -28px var(--glow)}
.game-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.game-top img{width:62px;height:62px;border-radius:15px;border:1px solid var(--line)}
.game-title{font-family:var(--font-head);font-weight:700;font-size:1.12rem}
.game-genre{font-size:.78rem;color:var(--primary);font-weight:600;font-family:var(--font-head)}
.rating{margin-inline-start:auto;font-family:var(--font-head);font-weight:700;font-size:.95rem;color:var(--ink)}
.rating span{color:#D97706}
.game p{font-size:.92rem;margin-bottom:16px}
.badges{display:flex;gap:8px;flex-wrap:wrap}
.badge{font-size:.74rem;color:var(--muted);padding:5px 11px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2)}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery figure{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.gallery img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .5s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;font-size:.84rem;font-weight:500;
  background:linear-gradient(transparent,rgba(15,23,42,.78));color:#fff}

.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{padding:28px;border:1px solid var(--line);border-radius:18px;background:var(--surface)}
.step .num{font-family:var(--font-head);font-weight:700;font-size:1.6rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.step h3{margin:10px 0 8px}
.step p{font-size:.92rem}

.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:30px}
.mission-card{padding:32px;border-radius:20px;border:1px solid var(--line);background:var(--grad-soft)}
.mission-card h3{font-size:1.35rem;margin-bottom:12px}
.mission-card p{color:var(--body-2)}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value{padding:22px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}
.value h4{font-family:var(--font-head);font-size:1rem;margin-bottom:7px}
.value p{font-size:.88rem}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.member{text-align:center}
.member img{width:118px;height:118px;border-radius:50%;margin:0 auto 16px;object-fit:cover;
  border:2px solid var(--line);background:var(--surface-2)}
.member .name{font-family:var(--font-head);font-weight:700}
.member .role{color:var(--accent);font-weight:500;font-size:.85rem;font-family:var(--font-head)}

.form-wrap{background:var(--surface);border:1px solid var(--line);border-radius:24px;
  padding:clamp(28px,4vw,52px);display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.form-wrap .intro h2{margin-bottom:14px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.85rem;margin-bottom:7px;font-family:var(--font-head);font-weight:500}
.field input,.field textarea{width:100%;padding:13px 15px;border-radius:12px;
  border:1px solid var(--line);background:var(--surface);color:var(--ink);font:inherit;transition:border .2s,box-shadow .2s}
.field textarea{min-height:104px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,118,110,.16)}
.field .err{display:none;color:#DC2626;font-size:.8rem;margin-top:5px}
.field.invalid .err{display:block}
.field.invalid input,.field.invalid textarea{border-color:#DC2626}
.form-note{font-size:.8rem;color:var(--muted);margin-top:6px}
.form-ok{display:none;color:var(--primary);font-weight:600;font-family:var(--font-head);margin-top:14px}
.form-ok.show{display:block}

.footer{border-top:1px solid var(--line);padding:56px 0 30px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer h4{font-family:var(--font-head);font-size:.95rem;margin-bottom:16px;color:var(--ink)}
.footer ul{list-style:none}
.footer li{margin-bottom:9px}
.footer a,.footer p{color:var(--muted);font-size:.92rem}
.footer a:hover{color:var(--ink)}
.footer-brand p{margin-top:14px;max-width:320px}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-top:24px;border-top:1px solid var(--line);font-size:.85rem;color:var(--muted)}

.page-hero{padding:72px 0 24px}
.page-hero h1{margin-top:18px}
.prose{max-width:720px}
.prose h2{margin:36px 0 14px}
.prose p{margin-bottom:14px;color:var(--body-2)}
.prose ul{margin:0 0 14px 20px;color:var(--body-2)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:920px){
  .hero-grid,.mission-grid,.form-wrap{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr);gap:28px}
  .games-grid,.gallery-grid,.process-grid,.values{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-visual{margin-top:20px}
  .puzzle-card{position:static;width:100%;margin-top:18px}
  .nav-links{position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--surface);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .3s}
  .nav-links.open{max-height:360px}
  .nav-links li{width:100%;border-top:1px solid var(--line)}
  .nav-links a{display:block;padding:16px 24px}
  .nav-links .nav-cta{margin:16px 24px;text-align:center}
  .nav-toggle{display:block}
}
@media(max-width:560px){
  .games-grid,.gallery-grid,.process-grid,.values,.team-grid,.footer-grid{grid-template-columns:1fr}
  .section{padding:68px 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}


/* model comparison table (signature) */
.cmp{overflow-x:auto;border:1px solid var(--line);border-radius:18px;background:var(--surface)}
.cmp-table{width:100%;border-collapse:collapse;min-width:720px;font-size:.92rem}
.cmp-table th,.cmp-table td{padding:15px 18px;text-align:start;border-bottom:1px solid var(--line)}
.cmp-table tbody tr:last-child td{border-bottom:none}
.cmp-table thead th{font-family:var(--font-head);font-weight:700;color:var(--muted);
  font-size:.74rem;text-transform:uppercase;letter-spacing:.05em}
.cmp-table tbody tr{transition:background .25s}
.cmp-table tr.hl{background:var(--grad-soft)}
.cmp-name{font-family:var(--font-head);font-weight:700;color:var(--ink)}
.cmp-best{display:block;font-size:.8rem;color:var(--muted);font-weight:400;margin-top:3px;max-width:200px}
.dots{letter-spacing:3px;color:var(--accent);font-size:.9rem;white-space:nowrap}
.dots .off{color:var(--line)}
.tier-tag{display:inline-block;font-size:.66rem;font-family:var(--font-head);font-weight:700;color:#fff;
  background:var(--grad);padding:3px 9px;border-radius:6px;margin-inline-start:8px;vertical-align:middle}
.cmp-pick{margin-top:20px;padding:15px 18px;border:1px solid var(--line);border-radius:12px;
  background:var(--grad-soft);font-size:.96rem;color:var(--ink)}
.cmp-pick b{color:var(--accent)}

/* use cases */
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.uc{padding:24px;border:1px solid var(--line);border-radius:16px;background:var(--surface);
  transition:transform .3s,border-color .3s}
.uc:hover{transform:translateY(-4px);border-color:var(--accent)}
.uc h4{font-family:var(--font-head);font-size:1.02rem;margin-bottom:8px;color:var(--ink)}
.uc p{font-size:.9rem}
@media(max-width:920px){.uc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.uc-grid{grid-template-columns:1fr}}

/* hero trust chips — variants picked per build by seed (data-variant) */
.platforms[data-variant="tick"]{gap:20px}
.platforms[data-variant="tick"] .pill{background:none;border:none;padding:0;color:var(--ink);font-weight:500}
.platforms[data-variant="tick"] .pill::before{content:"\2713";width:auto;height:auto;border-radius:0;background:none;color:var(--accent);font-weight:800;margin-inline-end:3px}
.platforms[data-variant="bar"]{gap:22px}
.platforms[data-variant="bar"] .pill{background:none;border:none;border-inline-start:2px solid var(--accent);border-radius:0;padding-block:3px;padding-inline:11px 0;color:var(--ink);font-weight:500}
.platforms[data-variant="bar"] .pill::before{display:none}
.platforms[data-variant="solid"] .pill{background:var(--grad-soft);border-color:transparent;color:var(--ink)}
.platforms[data-variant="plain"]{gap:0;align-items:center}
.platforms[data-variant="plain"] .pill{background:none;border:none;padding:0;color:var(--muted)}
.platforms[data-variant="plain"] .pill::before{display:none}
.platforms[data-variant="plain"] .pill:not(:last-child)::after{content:"/";margin:0 12px;color:var(--line)}


/* animated hero visual (replaces raster image) */
.hero-anim{width:100%;aspect-ratio:4/3;display:block;border-radius:24px;border:1px solid var(--line);
  background:linear-gradient(140deg,var(--surface),var(--bg));box-shadow:0 40px 80px -40px rgba(124,45,18,.20)}

/* FAQ accordion (content depth + FAQPage schema) */
.faq{max-width:780px}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--surface);margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:start;background:none;border:none;cursor:pointer;font-family:var(--font-head);
  font-weight:600;font-size:1.02rem;color:var(--ink);padding:18px 20px;display:flex;
  justify-content:space-between;align-items:center;gap:16px}
.faq-q:focus-visible{outline:2px solid var(--accent);outline-offset:-3px}
.faq-ic{color:var(--accent);font-size:1.5rem;line-height:1;transition:transform .25s;flex:none}
.faq-q.open .faq-ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{padding:0 20px 18px;margin:0;color:var(--body-2);font-size:.95rem}

/* cookie consent banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:60;max-width:780px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px;display:none;
  align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  box-shadow:0 24px 60px -24px rgba(15,23,42,.30)}
.cookie-banner.show{display:flex}
.cookie-banner p{font-size:.9rem;color:var(--body-2);margin:0;flex:1;min-width:230px}
.cookie-banner a{color:var(--accent)}
.cookie-actions{display:flex;gap:10px}
.cookie-actions .btn{padding:10px 18px;font-size:.9rem}
@media(prefers-reduced-motion:reduce){.faq-a,.faq-ic{transition:none}}

/* texture overlay pool (self-hosted SVG/CSS, picked per build by seed) */
.tex{position:fixed;inset:0;z-index:-1;pointer-events:none}
[data-texture="none"]{background:none}
[data-texture="grain"]{opacity:.34;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:140px 140px}
[data-texture="dots"]{opacity:.6;background-image:radial-gradient(var(--line) 1.3px,transparent 1.4px);background-size:22px 22px}
[data-texture="lines"]{opacity:.5;background-image:repeating-linear-gradient(45deg,var(--line) 0 1px,transparent 1px 15px)}
[data-texture="mesh"]{opacity:.45;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:34px 34px}

/* category cards */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{display:flex;gap:14px;align-items:center;padding:18px 20px;border:1px solid var(--line);border-radius:16px;background:var(--surface);transition:transform .3s,border-color .3s}
.cat:hover{transform:translateY(-3px);border-color:var(--primary)}
.cat img{width:46px;height:46px;border-radius:11px;border:1px solid var(--line);flex:none}
.cat h4{font-family:var(--font-head);font-size:1rem;margin-bottom:3px;color:var(--ink)}
.cat p{font-size:.84rem;margin:0;color:var(--body-2)}
@media(max-width:820px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cat-grid{grid-template-columns:1fr}}

/* game cards (catalog) */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.chip{font-family:var(--font-head);font-weight:600;font-size:.85rem;color:var(--body-2);background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;transition:all .2s}
.chip:hover{color:var(--ink);border-color:var(--primary)}
.chip.active{background:var(--grad);color:var(--on-grad);border-color:transparent}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--surface);transition:transform .3s,border-color .3s,box-shadow .3s}
.card:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:0 24px 50px -28px var(--glow)}
.card .cover{position:relative;display:block;aspect-ratio:16/10;overflow:hidden}
.card .cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.card:hover .cover img{transform:scale(1.05)}
.card .genre{position:absolute;top:10px;inset-inline-start:10px;font-size:.68rem;font-family:var(--font-head);font-weight:700;
  color:#fff;background:rgba(11,11,22,.55);backdrop-filter:blur(4px);padding:4px 11px;border-radius:999px}
.card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:11px}
.card .row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.card h3{font-family:var(--font-head);font-size:1.02rem;margin:0;color:var(--ink)}
.card .rate{font-size:.85rem;color:var(--accent);font-weight:700;white-space:nowrap}
.card .play{width:100%;padding:11px;border-radius:12px;background:var(--grad);color:var(--on-grad);
  font-family:var(--font-head);font-weight:700;font-size:.9rem;border:none;cursor:pointer}
.card.hide{display:none}
@media(max-width:880px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cards{grid-template-columns:1fr}}


/* connection-type cards (reuse .cat look, standalone class) */
.conn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.conn{padding:22px;border:1px solid var(--line);border-radius:16px;background:var(--surface);transition:transform .3s,border-color .3s}
.conn:hover{transform:translateY(-4px);border-color:var(--primary)}
.conn img{width:46px;height:46px;border-radius:11px;border:1px solid var(--line);margin-bottom:12px}
.conn h4{font-family:var(--font-head);font-size:1.05rem;margin-bottom:6px;color:var(--ink)}
.conn p{font-size:.9rem;margin:0;color:var(--body-2)}
@media(max-width:880px){.conn-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.conn-grid{grid-template-columns:1fr}}

/* speed comparison bars (signature) */
.speed{display:grid;gap:16px;border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:26px}
.speed-row{display:grid;grid-template-columns:150px 1fr 110px;gap:14px;align-items:center}
.speed-row .name{font-family:var(--font-head);font-weight:600;font-size:.98rem;color:var(--ink)}
.speed-row .name small{display:block;font-family:var(--font-body);font-weight:400;font-size:.76rem;color:var(--muted)}
.speed-track{height:14px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.speed-fill{height:100%;width:0;border-radius:999px;background:var(--grad);transition:width 1.2s cubic-bezier(.2,.7,.2,1)}
.speed-row .val{font-family:var(--font-head);font-weight:700;font-size:.9rem;color:var(--accent);text-align:end;white-space:nowrap}
.speed-note{font-size:.82rem;color:var(--muted);margin-top:14px}
@media(max-width:640px){.speed-row{grid-template-columns:110px 1fr 90px}}
@media(prefers-reduced-motion:reduce){.speed-fill{transition:none}}

/* tariff cards + billing toggle (signature) */
.bill-toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;background:var(--surface);padding:4px;gap:4px;margin-bottom:26px}
.bill-toggle button{font-family:var(--font-head);font-weight:600;font-size:.88rem;color:var(--body-2);background:none;border:none;border-radius:999px;padding:9px 20px;cursor:pointer;transition:all .2s}
.bill-toggle button.active{background:var(--grad);color:var(--on-grad)}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.plan{border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:26px;display:flex;flex-direction:column;gap:14px;transition:transform .3s,border-color .3s,box-shadow .3s;position:relative}
.plan:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:0 24px 50px -28px var(--glow)}
.plan.featured{border-color:var(--primary);background:linear-gradient(180deg,var(--surface),var(--bg))}
.plan .flag{position:absolute;top:-13px;inset-inline-start:22px;font-family:var(--font-head);font-weight:700;font-size:.7rem;color:#fff;background:var(--grad);padding:4px 13px;border-radius:999px}
.plan h3{font-family:var(--font-head);font-size:1.15rem;margin:0;color:var(--ink)}
.plan .price{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--primary);line-height:1}
.plan .price small{font-size:.85rem;font-weight:500;color:var(--muted)}
.plan ul{list-style:none;display:grid;gap:9px;margin:0;padding:0}
.plan li{font-size:.9rem;color:var(--body-2);padding-inline-start:22px;position:relative}
.plan li::before{content:"\2713";position:absolute;inset-inline-start:0;color:var(--accent);font-weight:800}
.plan .btn{margin-top:auto;justify-content:center}
@media(max-width:880px){.plans{grid-template-columns:1fr;max-width:440px;margin:0 auto}}


/* ---- structured page bands (real-site rhythm) ---- */
.section.band{background:linear-gradient(180deg,var(--surface),var(--bg));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding-top:88px;padding-bottom:88px}
.section.band + .section{padding-top:88px}
.hero{position:relative}
.hero::before{content:"";position:absolute;inset:-40% -20% auto;height:120%;pointer-events:none;z-index:-1;
  background:radial-gradient(46% 60% at 72% 30%,rgba(14,116,144,.12),transparent 70%),
             radial-gradient(40% 55% at 18% 20%,rgba(180,83,9,.10),transparent 70%)}
/* decorative corner arcs on band sections (theme: signal) */
.band{position:relative;overflow:hidden}
.band::after{content:"";position:absolute;inset-inline-end:-140px;top:-140px;width:340px;height:340px;
  border:1.5px solid var(--line);border-radius:50%;pointer-events:none;
  box-shadow:0 0 0 46px rgba(234,223,206,.35),0 0 0 96px rgba(234,223,206,.18)}

/* glossary grid */
.gloss-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gloss{padding:18px 20px;border:1px solid var(--line);border-radius:14px;background:var(--bg)}
.gloss dt{font-family:var(--font-head);font-weight:700;font-size:.98rem;color:var(--primary);margin-bottom:6px}
.gloss dd{font-size:.86rem;color:var(--body-2);margin:0;line-height:1.65}
@media(max-width:980px){.gloss-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gloss-grid{grid-template-columns:1fr}}

/* guide cards (long-form) */
.guides{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.guide{border:1px solid var(--line);border-radius:18px;background:var(--bg);padding:26px;
  display:flex;flex-direction:column;gap:12px;transition:transform .3s,border-color .3s}
.guide:hover{transform:translateY(-4px);border-color:var(--accent)}
.guide .no{font-family:var(--font-head);font-weight:800;font-size:.8rem;color:var(--accent);letter-spacing:.06em}
.guide h3{font-family:var(--font-head);font-size:1.12rem;margin:0;color:var(--ink)}
.guide p{font-size:.92rem;margin:0;color:var(--body-2);line-height:1.8}
.guide ul{list-style:none;margin:4px 0 0;padding:0;display:grid;gap:8px}
.guide li{font-size:.88rem;color:var(--body-2);padding-inline-start:20px;position:relative;line-height:1.7}
.guide li::before{content:"—";position:absolute;inset-inline-start:0;color:var(--primary);font-weight:700}
@media(max-width:900px){.guides{grid-template-columns:1fr;max-width:560px;margin:0 auto}}
