/* ============================================================
   LE GRIMOIRE — Site vitrine
   Design system extrait de l'application
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=UnifrakturMaguntia&display=swap');

:root{
  /* Surfaces — deep midnight navy → black */
  --bg-0:#06080f;
  --bg-1:#0a0d1a;
  --bg-2:#0f1326;
  --bg-3:#151a31;
  --bg-card:rgba(18,23,44,.62);
  --bg-card-solid:#121733;

  /* Ink — warm parchment whites */
  --ink:#ece7d8;
  --ink-soft:#b8b2a2;
  --ink-dim:#7e7869;

  /* Gold — the brand metal */
  --gold:#c9a85c;
  --gold-bright:#e9cf86;
  --gold-deep:#9a7d3c;
  --gold-glow:rgba(201,168,92,.35);

  /* Crimson — the action colour from the app */
  --crimson:#9e1b1b;
  --crimson-bright:#c12626;
  --crimson-deep:#6e1212;

  /* Lines */
  --line:rgba(201,168,92,.16);
  --line-strong:rgba(201,168,92,.42);
  --line-cool:rgba(120,140,200,.12);

  /* Type */
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'EB Garamond',Georgia,serif;
  --black-letter:'UnifrakturMaguntia',serif;

  --maxw:1200px;
  --radius:14px;
  --radius-sm:9px;

  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--bg-0);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:var(--bg-0)}

/* Page-wide ambient backdrop: starfield + deep radial glows */
.backdrop{position:fixed;inset:0;z-index:-2;pointer-events:none}
.backdrop::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(70,60,140,.28), transparent 60%),
    radial-gradient(900px 600px at 8% 6%, rgba(40,52,110,.22), transparent 58%),
    radial-gradient(1200px 900px at 50% 120%, rgba(120,90,40,.12), transparent 60%),
    linear-gradient(180deg,var(--bg-1),var(--bg-0) 60%);
}
.backdrop .stars{position:absolute;inset:0;opacity:.6}
@keyframes tw{0%,100%{opacity:.15;transform:scale(.7)}50%{opacity:.9;transform:scale(1)}}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* ---------------- Layout ---------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{position:relative}
.section-pad{padding:110px 0}
@media(max-width:760px){.section-pad{padding:72px 0}}

/* ---------------- Typographic helpers ---------------- */
.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.72rem;
  font-weight:500;
  color:var(--gold);
  display:inline-block;
}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.06;color:var(--ink)}
.section-head{max-width:760px;margin:0 auto 60px;text-align:center}
.section-head h2{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:18px 0 20px;letter-spacing:.01em}
.section-head p{color:var(--ink-soft);font-size:1.18rem;font-style:italic;max-width:620px;margin:0 auto}

.smallcaps{
  font-variant:small-caps;
  letter-spacing:.06em;
}

/* Ornamental divider */
.rule{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold)}
.rule::before,.rule::after{content:"";height:1px;width:64px;background:linear-gradient(90deg,transparent,var(--gold-deep))}
.rule::after{background:linear-gradient(90deg,var(--gold-deep),transparent)}
.rule .diamond{width:7px;height:7px;background:var(--gold);transform:rotate(45deg);box-shadow:0 0 8px var(--gold-glow)}

/* ---------------- Corner-bracket frame ---------------- */
.framed{position:relative}
.framed::before,.framed::after{
  content:"";position:absolute;width:18px;height:18px;pointer-events:none;
  border:1.5px solid var(--line-strong);transition:border-color .35s var(--ease);
}
.framed::before{top:10px;left:10px;border-right:0;border-bottom:0}
.framed::after{bottom:10px;right:10px;border-left:0;border-top:0}
.framed:hover::before,.framed:hover::after{border-color:var(--gold)}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:var(--radius-sm);
  font-family:var(--body);font-size:1rem;font-weight:500;
  letter-spacing:.04em;border:1px solid transparent;
  transition:all .3s var(--ease);white-space:nowrap;
}
.btn svg{width:18px;height:18px;flex:none}
.btn-primary{
  background:linear-gradient(180deg,var(--crimson-bright),var(--crimson));
  color:#f4ece0;border-color:rgba(0,0,0,.3);
  box-shadow:0 8px 26px rgba(140,20,20,.34),inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(160,24,24,.46),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-gold{
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  color:#1a1406;border-color:var(--gold-deep);font-weight:600;
  box-shadow:0 8px 26px rgba(201,168,92,.26),inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(201,168,92,.4)}
.btn-ghost{
  background:rgba(255,255,255,.02);color:var(--ink);
  border:1px solid var(--line-strong);
}
.btn-ghost:hover{border-color:var(--gold);background:rgba(201,168,92,.07);color:var(--gold-bright)}
.btn-lg{padding:17px 34px;font-size:1.08rem}

/* ---------------- Header / nav ---------------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(8,11,22,.82);backdrop-filter:blur(14px) saturate(1.1);
  border-bottom-color:var(--line);
}
.nav{display:flex;align-items:center;gap:30px;height:74px}
.brand{display:flex;align-items:center;gap:13px;flex:none}
.brand .crest{
  width:40px;height:40px;border-radius:50%;flex:none;
  border:1.5px solid var(--gold-deep);
  display:grid;place-items:center;
  background:radial-gradient(circle at 50% 35%,rgba(201,168,92,.18),transparent 70%);
  box-shadow:0 0 18px rgba(201,168,92,.18),inset 0 0 12px rgba(201,168,92,.1);
}
.brand .crest span{font-family:var(--black-letter);font-size:1.6rem;color:var(--gold-bright);line-height:1;margin-top:2px}
.brand .word{font-family:var(--display);font-size:1.36rem;font-weight:600;letter-spacing:.02em;color:var(--ink);font-variant:small-caps;white-space:nowrap}
.brand .word em{color:var(--gold);font-style:normal}
.nav-links{display:flex;align-items:center;gap:28px;margin-left:18px}
.nav-links a{
  font-size:.96rem;color:var(--ink-soft);letter-spacing:.03em;
  position:relative;padding:6px 0;transition:color .25s;
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--gold);transition:right .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}

/* Language selector */
.lang{position:relative}
.lang-btn{
  display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);color:var(--ink-soft);border-radius:8px;
  padding:9px 12px;font-size:.9rem;transition:all .25s;
}
.lang-btn:hover{border-color:var(--gold-deep);color:var(--ink)}
.lang-btn svg{width:15px;height:15px;opacity:.8}
.lang-btn .chev{transition:transform .25s}
.lang.open .lang-btn .chev{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:188px;
  background:var(--bg-2);border:1px solid var(--line-strong);border-radius:12px;
  padding:7px;box-shadow:0 24px 60px rgba(0,0,0,.6);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all .26s var(--ease);max-height:340px;overflow-y:auto;z-index:60;
}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu button{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  background:none;border:0;color:var(--ink-soft);padding:9px 11px;
  border-radius:7px;font-size:.95rem;transition:all .18s;
}
.lang-menu button:hover{background:rgba(201,168,92,.1);color:var(--ink)}
.lang-menu button.active{color:var(--gold-bright)}
.lang-menu button .flag{font-size:1.1rem;width:22px;text-align:center}
.lang-menu button .tick{margin-left:auto;opacity:0;color:var(--gold)}
.lang-menu button.active .tick{opacity:1}

/* Currency selector (mirrors .lang) */
.cur{position:relative}
.cur-btn{
  display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);color:var(--ink-soft);border-radius:8px;
  padding:9px 11px;font-size:.9rem;transition:all .25s;
}
.cur-btn:hover{border-color:var(--gold-deep);color:var(--ink)}
.cur-btn svg{width:15px;height:15px;opacity:.8}
.cur-btn .chev{transition:transform .25s}
.cur.open .cur-btn .chev{transform:rotate(180deg)}
.cur-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:140px;
  background:var(--bg-2);border:1px solid var(--line-strong);border-radius:12px;
  padding:7px;box-shadow:0 24px 60px rgba(0,0,0,.6);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all .26s var(--ease);z-index:60;
}
.cur.open .cur-menu{opacity:1;visibility:visible;transform:translateY(0)}
.cur-menu button{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:0;color:var(--ink-soft);padding:9px 11px;
  border-radius:7px;font-size:.95rem;transition:all .18s;
}
.cur-menu button:hover{background:rgba(201,168,92,.1);color:var(--ink)}
.cur-menu button.active{color:var(--gold-bright)}
.cur-menu button .tick{margin-left:auto;opacity:0;color:var(--gold)}
.cur-menu button.active .tick{opacity:1}
@media(max-width:520px){.cur-btn .cur-current{display:none}}

.nav-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:8px;padding:8px;color:var(--ink)}
.nav-toggle svg{width:22px;height:22px}

/* Back-to-top button */
.to-top{
  position:fixed;right:24px;bottom:24px;z-index:80;
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--gold-deep);color:var(--gold-bright);
  background:rgba(10,13,26,.82);backdrop-filter:blur(8px);
  display:grid;place-items:center;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  opacity:0;visibility:hidden;transform:translateY(14px) scale(.9);
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s,border-color .25s,background .25s;
}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{border-color:var(--gold);background:rgba(201,168,92,.14);color:var(--gold-bright)}
.to-top svg{width:22px;height:22px}
@media(max-width:560px){.to-top{right:16px;bottom:16px;width:44px;height:44px}}
@media(prefers-reduced-motion:reduce){.to-top{transition:opacity .2s}}

@media(max-width:980px){
  .nav-links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:flex-start;
    gap:4px;background:rgba(8,11,22,.97);backdrop-filter:blur(14px);
    padding:18px 28px 28px;margin:0;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s var(--ease);
  }
  .nav-links a{width:100%;padding:13px 0;font-size:1.1rem;border-bottom:1px solid var(--line-cool)}
  body.menu-open .nav-links{transform:translateY(0)}
  .nav-toggle{display:inline-flex}
  .nav-right .btn-cta-text{display:none}
}

/* ---------------- Hero ---------------- */
.hero{padding:150px 0 90px;position:relative;overflow:hidden}
.hero-orbits{position:absolute;top:-12%;left:50%;transform:translateX(-50%);width:1500px;height:1500px;pointer-events:none;opacity:.5;z-index:-1}
.hero-orbits circle{fill:none;stroke:rgba(201,168,92,.13);stroke-width:1}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:54px;align-items:center}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:44px;text-align:center}}

.ea-badge{
  display:inline-flex;align-items:center;gap:9px;
  border:1px solid var(--line-strong);border-radius:100px;
  padding:7px 16px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-bright);background:rgba(201,168,92,.06);margin-bottom:26px;
}
.ea-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-bright);box-shadow:0 0 10px var(--gold-bright);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.hero h1{font-size:clamp(3.4rem,8vw,6rem);margin:0 0 4px;line-height:.96}
.hero h1 .grimoire{font-family:var(--black-letter);font-weight:400;display:block;
  background:linear-gradient(180deg,#f3e2b4 8%,var(--gold) 48%,var(--gold-deep) 96%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 3px 18px rgba(201,168,92,.28));letter-spacing:.01em;
}
.hero .lede-line{font-family:var(--display);font-style:italic;font-weight:500;color:var(--ink);font-size:clamp(1.4rem,2.6vw,1.9rem);margin:14px 0 22px;display:block}
.hero p.sub{color:var(--ink-soft);font-size:1.16rem;max-width:520px;margin-bottom:34px}
@media(max-width:920px){.hero p.sub{margin-left:auto;margin-right:auto}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:920px){.hero-cta{justify-content:center}}
.hero-meta{display:flex;align-items:center;gap:10px;margin-top:26px;color:var(--ink-dim);font-size:.9rem}
@media(max-width:920px){.hero-meta{justify-content:center}}
.hero-meta svg{width:16px;height:16px;color:var(--gold)}

/* Hero visual — layered screenshots */
.hero-art{position:relative}
.hero-art .halo{position:absolute;inset:-40px;z-index:-1;border-radius:50%;
  background:radial-gradient(circle,rgba(120,90,180,.22),transparent 65%);filter:blur(20px)}
.hero-art .win{transform:perspective(1600px) rotateY(-6deg) rotateX(1.5deg)}

/* ---------------- Desktop window chrome (Windows style) ---------------- */
.win{
  border-radius:12px;overflow:hidden;background:var(--bg-2);
  border:1px solid var(--line-strong);
  box-shadow:0 40px 90px rgba(0,0,0,.6),0 0 0 1px rgba(0,0,0,.4);
  transition:transform .5s var(--ease),box-shadow .5s;
}
.win-bar{
  display:flex;align-items:center;gap:10px;height:38px;padding:0 8px 0 14px;
  background:linear-gradient(180deg,#161b32,#10142a);
  border-bottom:1px solid var(--line);
}
.win-bar .wb-crest{width:16px;height:16px;border-radius:50%;flex:none;display:grid;place-items:center;
  border:1px solid var(--gold-deep);background:radial-gradient(circle at 50% 35%,rgba(201,168,92,.25),transparent 70%)}
.win-bar .wb-crest span{font-family:var(--black-letter);font-size:.7rem;color:var(--gold-bright);line-height:1}
.win-bar .wb-title{font-family:var(--body);font-size:.82rem;color:var(--ink-soft);letter-spacing:.04em;font-variant:small-caps;white-space:nowrap;flex:none}
.win-bar .wb-ctrls{margin-left:auto;display:flex;align-items:center}
.win-bar .wb-ctrls button{width:38px;height:38px;border:0;background:none;display:grid;place-items:center;color:var(--ink-dim);transition:background .2s,color .2s}
.win-bar .wb-ctrls button svg{width:11px;height:11px}
.win-bar .wb-ctrls button:hover{background:rgba(255,255,255,.06);color:var(--ink)}
.win-bar .wb-ctrls button.close:hover{background:var(--crimson);color:#fff}
.win-body{display:block;background:var(--bg-1);position:relative}
.win-body img{width:100%;display:block}
.win:hover{box-shadow:0 48px 100px rgba(0,0,0,.66)}

/* ---------------- Gallery carousel ---------------- */
.carousel{position:relative;max-width:1000px;margin:0 auto}
.car-viewport{overflow:hidden;border-radius:var(--radius)}
.car-track{display:flex;transition:transform .6s var(--ease);will-change:transform}
.car-slide{flex:0 0 100%;min-width:100%;padding:6px 4px 0}
.gallery-item{display:flex;flex-direction:column;gap:18px}
.gallery-item .win{transition:transform .5s var(--ease),box-shadow .5s;margin:0 auto;max-width:920px}
.gallery-item:hover .win{box-shadow:0 44px 90px rgba(0,0,0,.6)}
.gallery-item .win-bar{height:34px}
.gallery-item .win-bar .wb-ctrls button{width:34px;height:34px}
.gallery-cap{text-align:center;max-width:640px;margin:0 auto;min-height:72px}
.gallery-cap h4{font-family:var(--display);font-size:1.7rem;color:var(--ink);margin-bottom:5px}
.gallery-cap p{color:var(--ink-soft);font-size:1.06rem;line-height:1.5}

.car-nav{
  position:absolute;top:38%;transform:translateY(-50%);z-index:5;
  width:52px;height:52px;border-radius:50%;border:1px solid var(--line-strong);
  background:rgba(10,13,26,.72);color:var(--ink);display:grid;place-items:center;
  transition:all .25s var(--ease);backdrop-filter:blur(8px);
}
.car-nav:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(201,168,92,.12)}
.car-nav svg{width:24px;height:24px}
.car-prev{left:-22px}
.car-next{right:-22px}
@media(max-width:1080px){.car-prev{left:6px}.car-next{right:6px}}
@media(max-width:560px){.car-nav{width:44px;height:44px}}

.car-foot{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:26px}
.car-dots{display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:center;max-width:420px}
.car-dot{
  width:9px;height:9px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--line-strong);transition:all .3s var(--ease);
}
.car-dot:hover{background:var(--gold-deep)}
.car-dot.active{background:var(--gold);width:26px;border-radius:5px;box-shadow:0 0 10px var(--gold-glow)}
.car-count{font-family:var(--display);font-size:1.15rem;color:var(--ink-soft);white-space:nowrap;min-width:62px;text-align:center}
.car-count b{color:var(--gold-bright);font-weight:600}

/* clickable zoom affordance */
.win-body.zoomable{cursor:zoom-in}
.win-body.zoomable::after{
  content:"";position:absolute;inset:0;background:rgba(6,8,15,.0);
  transition:background .3s var(--ease);pointer-events:none;
}
.win-body.zoomable .zoom-hint{
  position:absolute;bottom:14px;right:14px;z-index:2;
  display:flex;align-items:center;gap:8px;
  background:rgba(8,11,22,.78);border:1px solid var(--line-strong);
  color:var(--gold-bright);border-radius:100px;padding:8px 14px;
  font-family:var(--body);font-size:.86rem;letter-spacing:.03em;
  opacity:0;transform:translateY(8px);transition:opacity .3s var(--ease),transform .3s var(--ease);
  backdrop-filter:blur(6px);pointer-events:none;
}
.win-body.zoomable .zoom-hint svg{width:15px;height:15px}
.win:hover .win-body.zoomable .zoom-hint,
.sc-shot:hover .win-body.zoomable .zoom-hint{opacity:1;transform:translateY(0)}
.win:hover .win-body.zoomable::after,
.sc-shot:hover .win-body.zoomable::after{background:rgba(201,168,92,.06)}

/* ---------------- Lightbox ---------------- */
.lightbox{
  position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  background:rgba(4,6,12,.92);backdrop-filter:blur(10px);
  padding:clamp(16px,4vw,56px);
}
.lightbox.open{display:flex}
.lb-stage{position:relative;max-width:1280px;width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}
.lb-frame{
  width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--line-strong);
  background:var(--bg-2);box-shadow:0 50px 120px rgba(0,0,0,.7);
  transform:scale(.96);transition:transform .35s var(--ease);
}
.lightbox.open .lb-frame{transform:scale(1)}
.lb-frame .win-bar{height:42px}
.lb-imgwrap{overflow:hidden;position:relative;background:var(--bg-1);touch-action:none;display:flex;align-items:center;justify-content:center}
.lb-imgwrap img{width:100%;display:block;max-height:76vh;object-fit:contain;transform-origin:center center;transition:transform .14s ease-out;cursor:zoom-in;will-change:transform;user-select:none;-webkit-user-drag:none}
.lb-imgwrap.zoomed img{cursor:grab}
.lb-imgwrap.grabbing img{cursor:grabbing;transition:none}
.lb-caption{display:flex;flex-direction:column;gap:5px;text-align:center;max-width:680px}
.lb-cap-title{font-family:var(--display);font-size:1.6rem;font-weight:600;color:var(--gold-bright);line-height:1.1}
.lb-cap-desc{color:var(--ink-soft);font-size:1.06rem;font-style:italic}
.lb-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:center}
.lb-hint{display:flex;align-items:center;gap:8px;color:var(--ink-dim);font-size:.84rem;letter-spacing:.02em}
.lb-hint svg{width:15px;height:15px;opacity:.85}
.lb-count{font-family:var(--body);font-size:.84rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.85;white-space:nowrap}
.lb-close{
  position:absolute;top:-6px;right:-6px;transform:translate(50%,-50%);
  width:46px;height:46px;border-radius:50%;border:1px solid var(--line-strong);
  background:var(--bg-2);color:var(--ink);display:grid;place-items:center;transition:all .25s;z-index:3;
}
.lb-close:hover{border-color:var(--gold);color:var(--gold-bright);transform:translate(50%,-50%) rotate(90deg)}
.lb-close svg{width:22px;height:22px}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;border:1px solid var(--line-strong);
  background:rgba(8,11,22,.7);color:var(--ink);display:grid;place-items:center;
  transition:all .25s;backdrop-filter:blur(6px);z-index:3;
}
.lb-nav:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(201,168,92,.1)}
.lb-nav svg{width:24px;height:24px}
.lb-prev{left:-8px}
.lb-next{right:-8px}
@media(max-width:760px){
  .lb-nav{width:44px;height:44px}
  .lb-prev{left:2px}.lb-next{right:2px}
  .lb-close{top:2px;right:2px;transform:none}
  .lb-close:hover{transform:rotate(90deg)}
  .lb-frame img{max-height:64vh}
}

/* ---------------- Pillars strip ---------------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{background:linear-gradient(180deg,var(--bg-2),var(--bg-1));padding:34px 30px;text-align:center}
.pillar .ic{width:40px;height:40px;margin:0 auto 16px;color:var(--gold)}
.pillar h3{font-size:1.5rem;margin-bottom:8px}
.pillar p{color:var(--ink-soft);font-size:1rem}

/* ---------------- Features grid ---------------- */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1080px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}
.feat-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px 32px;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
  position:relative;overflow:hidden;
}
.feat-card::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 200px at 50% -30%,rgba(201,168,92,.08),transparent);opacity:0;transition:opacity .4s}
.feat-card:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:0 24px 50px rgba(0,0,0,.4)}
.feat-card:hover::after{opacity:1}
.feat-card .ic{
  width:50px;height:50px;border-radius:11px;display:grid;place-items:center;
  border:1px solid var(--line-strong);color:var(--gold);margin-bottom:20px;
  background:radial-gradient(circle at 40% 30%,rgba(201,168,92,.14),transparent);
}
.feat-card .ic svg{width:26px;height:26px}
.feat-card h3{font-size:1.46rem;margin-bottom:9px}
.feat-card p{color:var(--ink-soft);font-size:1.02rem;line-height:1.55}

/* ---------------- Showcase (zigzag) ---------------- */
.showcase-row{display:grid;grid-template-columns:1fr 1.18fr;gap:64px;align-items:center;margin-bottom:118px}
.showcase-row:last-child{margin-bottom:0}
.showcase-row.flip{grid-template-columns:1.18fr 1fr}
.showcase-row.flip .sc-text{order:2}
@media(max-width:880px){
  .showcase-row{grid-template-columns:1fr;gap:36px;margin-bottom:80px}
  .showcase-row.flip .sc-text{order:0}
}
.sc-text .eyebrow{margin-bottom:18px}
.sc-text h3{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:18px;line-height:1.08}
.sc-text p{color:var(--ink-soft);font-size:1.12rem;margin-bottom:22px}
.sc-list{list-style:none;display:flex;flex-direction:column;gap:13px}
.sc-list li{display:flex;gap:13px;align-items:flex-start;color:var(--ink-soft);font-size:1.02rem}
.sc-list li .d{flex:none;width:8px;height:8px;margin-top:9px;background:var(--gold);transform:rotate(45deg);box-shadow:0 0 8px var(--gold-glow)}
.sc-list li b{color:var(--ink);font-weight:600}

.sc-shot{
  border-radius:12px;overflow:hidden;border:1px solid var(--line-strong);
  box-shadow:0 36px 80px rgba(0,0,0,.55);position:relative;background:var(--bg-2);
  transition:transform .5s var(--ease),box-shadow .5s;
}
.sc-shot:hover{transform:translateY(-5px);box-shadow:0 46px 96px rgba(0,0,0,.62)}
.sc-shot img{width:100%;display:block}
.sc-shot .glow{position:absolute;inset:0;z-index:-1}

/* ---------------- IA / BYOK band ---------------- */
.ia-band{
  border:1px solid var(--line);border-radius:22px;overflow:hidden;position:relative;
  background:
    radial-gradient(700px 360px at 85% 20%,rgba(120,80,170,.2),transparent 60%),
    linear-gradient(160deg,var(--bg-2),var(--bg-1));
  padding:60px 56px;
}
@media(max-width:760px){.ia-band{padding:42px 26px}}
.ia-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:52px;align-items:center}
@media(max-width:880px){.ia-grid{grid-template-columns:1fr;gap:36px}}
.ia-grid h2{font-size:clamp(2rem,4vw,3rem);margin:16px 0 18px}
.ia-grid p{color:var(--ink-soft);font-size:1.12rem;margin-bottom:18px}
.ia-points{display:grid;gap:18px}
.ia-point{display:flex;gap:16px;background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.ia-point .ic{flex:none;width:42px;height:42px;border-radius:10px;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--gold);background:rgba(201,168,92,.07)}
.ia-point .ic svg{width:22px;height:22px}
.ia-point h4{font-family:var(--display);font-size:1.32rem;color:var(--ink);margin-bottom:4px}
.ia-point p{color:var(--ink-soft);font-size:.98rem;margin:0}

/* ---------------- Pricing ---------------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;margin-top:14px}
@media(max-width:920px){.price-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}}
.price-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:18px;
  padding:34px 30px 32px;display:flex;flex-direction:column;position:relative;
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.price-card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.price-card.featured{border-color:var(--gold-deep);box-shadow:0 30px 70px rgba(0,0,0,.45),0 0 0 1px rgba(201,168,92,.2)}
.price-card.featured::before{display:none}
.price-card{overflow:visible}
.pr-ribbon{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:6px 16px;border-radius:100px;white-space:nowrap;z-index:2;
  background:rgba(201,168,92,.12);color:var(--gold-bright);border:1px solid var(--gold-deep);
}
.pr-ribbon.gold{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1406;border-color:var(--gold-deep)}
.price-card .ptag{min-height:0;margin-bottom:18px}
.price-card .price-was span{color:var(--gold)}
.price-card .pname{font-family:var(--display);font-size:1.7rem;color:var(--gold-bright);margin-bottom:5px}
.price-card .ptag{color:var(--ink-dim);font-size:.96rem;margin-bottom:22px;min-height:2.6em}
.price-amount{display:flex;align-items:baseline;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.price-amount .amt{font-family:var(--display);font-size:2.8rem;font-weight:600;color:var(--ink)}
.price-amount .per{color:var(--ink-dim);font-size:.95rem}
.price-amount .amt-aside{color:var(--gold-bright);font-size:1.04rem;font-family:var(--display);font-weight:600}
.price-sub .def-mo{opacity:.7}
.price-was{color:var(--ink-dim);font-size:.92rem;margin-bottom:6px}
.price-sub{color:var(--ink-soft);font-size:.94rem;margin:2px 0 6px;font-style:italic}
.price-sub strong{color:var(--gold-bright);font-weight:600;font-style:normal}
.price-sub s{opacity:.7}
.price-was .price-eqv{color:var(--ink-soft)}

/* EA banner above the grid */
.ea-banner{
  display:flex;align-items:center;gap:12px;justify-content:center;text-align:center;
  max-width:880px;margin:0 auto 30px;padding:14px 22px;
  border:1px solid var(--line-strong);border-radius:100px;background:rgba(201,168,92,.06);
  color:var(--gold-bright);font-size:1rem;
}
.ea-banner svg{width:20px;height:20px;flex:none;color:var(--gold)}
@media(max-width:560px){.ea-banner{border-radius:16px;font-size:.94rem;padding:14px 18px}}

/* Founder-rate lock strip (subscriptions) */
.pr-lock{
  display:flex;align-items:center;gap:10px;margin:0 0 18px;
  padding:11px 14px;border-radius:10px;
  border:1px solid var(--gold-deep);background:rgba(201,168,92,.08);
  color:var(--gold-bright);font-size:.92rem;line-height:1.3;
}
.pr-lock svg{width:18px;height:18px;flex:none}
.price-was s{opacity:.7}
.price-ea{display:inline-block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line-strong);border-radius:6px;padding:3px 9px;margin-bottom:22px}
.price-feats{list-style:none;display:flex;flex-direction:column;gap:12px;margin:6px 0 28px;flex:1}
.price-feats li{display:flex;gap:11px;color:var(--ink-soft);font-size:1rem;align-items:flex-start}
.price-feats li svg{flex:none;width:18px;height:18px;color:var(--gold);margin-top:3px}
.price-feats li.feat-gift{color:var(--gold-bright);font-weight:600}
.price-feats li.feat-gift svg{color:var(--gold-bright)}
.price-card .btn{width:100%;justify-content:center}
.price-note{text-align:center;color:var(--ink-dim);font-size:.95rem;margin-top:30px;font-style:italic}

/* ---------------- Token packs strip ---------------- */
.packs{margin-top:30px;border:1px solid var(--line);border-radius:20px;padding:32px 32px 30px;background:linear-gradient(180deg,var(--bg-2),var(--bg-1))}
@media(max-width:620px){.packs{padding:24px 18px}}
.packs-head{margin-bottom:24px}
.packs-head h3{font-family:var(--display);font-size:clamp(1.5rem,2.6vw,2rem);color:var(--ink);margin-bottom:6px}
.packs-head p{color:var(--ink-soft);font-size:1.04rem;max-width:680px}
.packs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:620px){.packs-grid{grid-template-columns:1fr}}
.pack-card{
  position:relative;border:1px solid var(--line);border-radius:14px;padding:22px 22px 20px;
  background:var(--bg-card);display:flex;flex-direction:column;gap:10px;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.pack-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 22px 46px rgba(0,0,0,.36)}
.pack-card.popular{border-color:var(--gold-deep);box-shadow:0 0 0 1px rgba(201,168,92,.18)}
.pk-flag{
  position:absolute;top:-12px;right:18px;background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  color:#1a1406;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:5px 13px;border-radius:100px;
}
.pk-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.pk-name{font-family:var(--display);font-size:1.5rem;color:var(--gold-bright)}
.pk-oneoff{color:var(--ink-dim);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.pk-price{font-family:var(--display);font-size:2.3rem;font-weight:600;color:var(--ink);line-height:1;display:flex;align-items:baseline;gap:10px}
.pk-price .pk-was{font-family:var(--body);font-size:1.1rem;font-weight:400;color:var(--ink-dim);opacity:.75}
.pk-req{color:var(--ink-soft);font-size:1rem;margin-bottom:6px}
.pk-req b{color:var(--gold-bright);font-size:1.12rem;font-family:var(--display)}
.pack-card .btn{width:100%;justify-content:center;margin-top:auto}

.byok-strip{
  margin-top:22px;border:1px dashed var(--line-strong);border-radius:14px;
  padding:22px 26px;display:flex;align-items:center;gap:18px;background:rgba(255,255,255,.015);
}
.byok-strip .ic{flex:none;width:46px;height:46px;border-radius:11px;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--gold);background:rgba(201,168,92,.07)}
.byok-strip .ic svg{width:24px;height:24px}
.byok-strip h4{font-family:var(--display);font-size:1.32rem;margin-bottom:3px}
.byok-strip p{color:var(--ink-soft);font-size:.98rem}

/* BYOK block + provider cards */
.byok-block{
  margin-top:26px;border:1px solid var(--line);border-radius:20px;
  padding:34px 34px 30px;background:
    radial-gradient(620px 300px at 12% 0%,rgba(201,168,92,.07),transparent 60%),
    linear-gradient(180deg,var(--bg-2),var(--bg-1));
}
@media(max-width:620px){.byok-block{padding:26px 20px}}
.byok-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:26px}
.byok-head .ic{flex:none;width:50px;height:50px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--gold);background:rgba(201,168,92,.08)}
.byok-head .ic svg{width:26px;height:26px}
.byok-head h3{font-family:var(--display);font-size:clamp(1.5rem,2.6vw,2rem);color:var(--ink);margin-bottom:7px;line-height:1.12}
.byok-head p{color:var(--ink-soft);font-size:1.06rem;max-width:760px}
.provider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.provider-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.provider-grid{grid-template-columns:1fr}}
.provider-card{
  display:flex;flex-direction:column;gap:13px;
  border:1px solid var(--line);border-radius:14px;padding:20px 20px 18px;
  background:var(--bg-card);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.provider-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 22px 46px rgba(0,0,0,.38)}
.provider-card .pc-top{display:flex;align-items:center;gap:13px}
.pc-logo{
  flex:none;width:46px;height:46px;border-radius:11px;display:grid;place-items:center;
  border:1px solid var(--line-strong);background:#0a0d18;
}
.pc-logo svg{width:26px;height:26px;display:block}
.pc-name{font-family:var(--display);font-size:1.34rem;color:var(--ink);line-height:1.1}
.pc-tag{color:var(--ink-soft);font-size:.95rem;line-height:1.45;flex:1}
.pc-go{display:inline-flex;align-items:center;gap:8px;color:var(--gold);font-size:.96rem;font-weight:500;letter-spacing:.02em;transition:gap .25s,color .25s}
.pc-go svg{width:16px;height:16px;transition:transform .25s}
.provider-card:hover .pc-go{color:var(--gold-bright);gap:11px}
.provider-card:hover .pc-go svg{transform:translate(2px,-2px)}
.byok-note{color:var(--ink-dim);font-size:.9rem;margin-top:20px;font-style:italic}
.byok-cta{display:flex;justify-content:center;margin-top:26px}

/* ---------------- Native languages band ---------------- */
.natlang-band{
  border:1px solid var(--line);border-radius:22px;padding:54px 48px;
  background:radial-gradient(620px 320px at 15% 0%,rgba(70,60,140,.18),transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg-1));
}
@media(max-width:760px){.natlang-band{padding:40px 24px}}
.natlang-head{text-align:center;max-width:640px;margin:0 auto 38px}
.natlang-head h2{font-size:clamp(1.9rem,3.8vw,2.8rem);margin:14px 0 14px}
.natlang-head p{color:var(--ink-soft);font-size:1.12rem;font-style:italic}
.natlang-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:13px;max-width:860px;margin:0 auto}
.natlang-chip{
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--line);border-radius:100px;padding:11px 20px;
  background:rgba(255,255,255,.02);transition:border-color .3s var(--ease),transform .3s var(--ease),background .3s;
}
.natlang-chip:hover{border-color:var(--gold-deep);background:rgba(201,168,92,.06);transform:translateY(-3px)}
.natlang-chip .flag{font-size:1.4rem;line-height:1}
.natlang-chip .name{font-family:var(--display);font-size:1.16rem;color:var(--ink)}

/* ---------------- FAQ ---------------- */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:12px;background:var(--bg-card);overflow:hidden;transition:border-color .3s}
.faq-item.open{border-color:var(--line-strong)}
.faq-q{
  width:100%;text-align:left;background:none;border:0;color:var(--ink);
  display:flex;align-items:center;gap:16px;padding:22px 24px;font-family:var(--display);
  font-size:1.32rem;font-weight:500;
}
.faq-q .pm{margin-left:auto;flex:none;width:22px;height:22px;position:relative;color:var(--gold)}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:currentColor;transition:transform .3s var(--ease)}
.faq-q .pm::before{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%)}
.faq-q .pm::after{left:50%;top:0;bottom:0;width:1.5px;transform:translateX(-50%)}
.faq-item.open .pm::after{transform:translateX(-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 24px 22px;color:var(--ink-soft);font-size:1.06rem;line-height:1.62}

/* ---------------- Final CTA ---------------- */
.final-cta{text-align:center;border:1px solid var(--line-strong);border-radius:22px;padding:74px 40px;position:relative;overflow:hidden;
  background:radial-gradient(700px 360px at 50% -10%,rgba(120,90,180,.18),transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg-1))}
.final-cta h2{font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:14px}
.final-cta .grimoire-ink{font-family:var(--black-letter);background:linear-gradient(180deg,#f3e2b4,var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.final-cta p{color:var(--ink-soft);font-size:1.18rem;font-style:italic;max-width:560px;margin:0 auto 32px}
.final-cta .hero-cta{justify-content:center}

/* ---------------- Footer ---------------- */
.site-footer{border-top:1px solid var(--line);padding:64px 0 34px;margin-top:30px;background:var(--bg-1)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .word{font-family:var(--display);font-size:1.4rem;font-variant:small-caps;color:var(--ink)}
.foot-brand .word em{color:var(--gold);font-style:normal}
.foot-brand p{color:var(--ink-dim);font-size:.98rem;margin:14px 0 20px;max-width:300px}
.foot-store{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--line-strong);border-radius:10px;padding:10px 16px;transition:all .25s}
.foot-store:hover{border-color:var(--gold-deep);background:rgba(201,168,92,.05)}
.foot-store svg{width:26px;height:26px;color:var(--gold)}
.foot-store .s1{font-size:.7rem;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em}
.foot-store .s2{font-size:1rem;color:var(--ink)}
.foot-col h5{font-family:var(--body);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--gold);margin-bottom:18px;font-weight:600}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{color:var(--ink-soft);font-size:.98rem;transition:color .2s}
.foot-col a:hover{color:var(--gold-bright)}
.foot-bottom{border-top:1px solid var(--line-cool);padding-top:26px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;color:var(--ink-dim);font-size:.9rem}
.foot-social{display:flex;gap:12px}
.foot-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:9px;display:grid;place-items:center;color:var(--ink-soft);transition:all .25s}
.foot-social a:hover{border-color:var(--gold-deep);color:var(--gold-bright);transform:translateY(-2px)}
.foot-social svg{width:18px;height:18px}

/* ---------------- Contact page ---------------- */
.contact-wrap{padding:140px 0 90px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:44px}}
.form-card{background:var(--bg-card);border:1px solid var(--line);border-radius:18px;padding:40px}
@media(max-width:560px){.form-card{padding:28px 22px}}
.field{margin-bottom:22px}
.field label{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:9px}
.field input,.field textarea,.field select{
  width:100%;background:rgba(8,11,22,.6);border:1px solid var(--line-strong);
  border-radius:9px;padding:13px 15px;color:var(--ink);font-family:var(--body);
  font-size:1.04rem;transition:border-color .25s,box-shadow .25s;
}
.field textarea{resize:vertical;min-height:140px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,92,.12)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-dim)}
.form-note{color:var(--ink-dim);font-size:.9rem;margin-top:4px;font-style:italic}
.form-sent{display:none;align-items:center;gap:12px;background:rgba(40,90,50,.18);border:1px solid rgba(120,180,120,.4);border-radius:10px;padding:16px 18px;color:#bfe6bf;margin-top:18px}
.form-sent.show{display:flex}
.form-sent svg{width:22px;height:22px;flex:none}

.contact-info{display:flex;flex-direction:column;gap:18px}
.info-card{display:flex;gap:18px;background:var(--bg-card);border:1px solid var(--line);border-radius:14px;padding:24px 26px;transition:border-color .3s}
.info-card:hover{border-color:var(--line-strong)}
.info-card .ic{flex:none;width:48px;height:48px;border-radius:11px;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--gold);background:rgba(201,168,92,.07)}
.info-card .ic svg{width:24px;height:24px}
.info-card h4{font-family:var(--display);font-size:1.4rem;margin-bottom:4px}
.info-card p{color:var(--ink-soft);font-size:1rem}
.info-card a{color:var(--gold-bright)}

/* ---------------- Scroll reveal (transform-only — never hides content) ---------------- */
.reveal{transition:transform .7s var(--ease),opacity .7s var(--ease)}
html.js-anim .reveal{transform:translateY(22px)}
html.js-anim .reveal.d1{transition-delay:.07s}
html.js-anim .reveal.d2{transition-delay:.14s}
html.js-anim .reveal.d3{transition-delay:.21s}
html.js-anim .reveal.d4{transition-delay:.28s}
html.js-anim .reveal.in{transform:none}

@media(prefers-reduced-motion:reduce){
  html.js-anim .reveal{transform:none;transition:none}
  *{animation:none!important;scroll-behavior:auto}
  .hero-art .shot.main{transform:none}
}

/* ---------------- Legal pages ---------------- */
.legal-wrap{padding:128px 0 80px}
.legal{max-width:880px;margin:0 auto}
.legal-head{border-bottom:1px solid var(--line);padding-bottom:34px;margin-bottom:14px}
.legal-head .eyebrow{margin-bottom:16px}
.legal-head h1{font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.04;margin-bottom:14px}
.legal-head .legal-date{color:var(--ink-dim);font-size:.98rem;font-style:italic}
.legal-lang-note{
  display:flex;align-items:center;gap:11px;margin:26px 0 6px;
  padding:13px 18px;border:1px solid var(--line);border-radius:10px;
  background:rgba(255,255,255,.015);color:var(--ink-soft);font-size:.92rem;
}
.legal-lang-note svg{width:18px;height:18px;flex:none;color:var(--gold)}
.legal-toc{
  display:flex;flex-wrap:wrap;gap:9px;margin:28px 0 8px;
}
.legal-toc a{
  font-size:.86rem;color:var(--ink-soft);border:1px solid var(--line);
  border-radius:100px;padding:7px 15px;transition:all .25s var(--ease);
}
.legal-toc a:hover{border-color:var(--gold-deep);color:var(--gold-bright);background:rgba(201,168,92,.06)}
.legal-body{margin-top:8px}
.legal-body h2{
  font-family:var(--display);font-size:clamp(1.4rem,2.6vw,1.85rem);color:var(--gold-bright);
  margin:46px 0 16px;padding-left:16px;border-left:3px solid var(--gold-deep);line-height:1.2;
  scroll-margin-top:100px;
}
.legal-body h3{font-family:var(--display);font-size:1.24rem;color:var(--ink);margin:26px 0 10px}
.legal-body p{color:var(--ink-soft);font-size:1.04rem;line-height:1.75;margin-bottom:14px}
.legal-body strong{color:var(--ink);font-weight:600}
.legal-body a{color:var(--gold-bright);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--gold-deep)}
.legal-body a:hover{text-decoration-color:var(--gold-bright)}
.legal-body ul{list-style:none;margin:10px 0 18px;display:flex;flex-direction:column;gap:9px}
.legal-body ul li{position:relative;padding-left:22px;color:var(--ink-soft);font-size:1.04rem;line-height:1.65}
.legal-body ul li::before{content:"";position:absolute;left:2px;top:.62em;width:7px;height:7px;background:var(--gold);transform:rotate(45deg);box-shadow:0 0 7px var(--gold-glow)}
.legal-table-wrap{overflow-x:auto;margin:16px 0 22px;border:1px solid var(--line);border-radius:12px}
.legal-body table{width:100%;border-collapse:collapse;font-size:.98rem;min-width:480px}
.legal-body th{
  background:rgba(201,168,92,.1);color:var(--gold-bright);text-align:left;font-family:var(--display);
  font-weight:600;font-size:1.04rem;padding:13px 18px;border-bottom:1px solid var(--line-strong);
}
.legal-body td{padding:13px 18px;border-bottom:1px solid var(--line-cool);color:var(--ink-soft);vertical-align:top}
.legal-body tr:last-child td{border-bottom:none}
.legal-body tbody tr:nth-child(even) td{background:rgba(255,255,255,.012)}
.legal-notice{
  background:rgba(255,255,255,.02);border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:0 12px 12px 0;padding:18px 22px;margin:22px 0;color:var(--ink-soft);font-size:1rem;line-height:1.65;
}
.legal-notice strong{color:var(--gold-bright)}
.legal-back{margin-top:46px;display:inline-flex}
.legal-back svg{width:18px;height:18px}
@media(max-width:560px){.legal-wrap{padding:108px 0 64px}}

/* ---------------- API key guide ---------------- */
.guide-toc{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:30px 0 10px}
@media(max-width:760px){.guide-toc{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.guide-toc{grid-template-columns:1fr}}
.guide-toc a{
  display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;transition:all .25s var(--ease);background:var(--bg-card);
}
.guide-toc a:hover{border-color:var(--gold-deep);background:rgba(201,168,92,.05);transform:translateY(-2px)}
.guide-toc .pc-logo{width:36px;height:36px;border-radius:9px}
.guide-toc .pc-logo svg{width:21px;height:21px}
.guide-toc span{font-family:var(--display);font-size:1.12rem;color:var(--ink)}

.prov{border:1px solid var(--line);border-radius:18px;background:var(--bg-card);padding:32px 32px 30px;margin:22px 0;scroll-margin-top:96px}
@media(max-width:560px){.prov{padding:24px 20px}}
.prov-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:22px}
.prov-head .pc-logo{width:54px;height:54px;border-radius:13px}
.prov-head .pc-logo svg{width:32px;height:32px}
.prov-head h2{font-family:var(--display);font-size:1.7rem;color:var(--ink);margin:0;border:0;padding:0;line-height:1.1}
.prov-head .prov-models{color:var(--gold-bright);font-size:.94rem;letter-spacing:.02em}
.prov-link{
  margin-left:auto;display:inline-flex;align-items:center;gap:9px;
  border:1px solid var(--gold-deep);border-radius:9px;padding:10px 16px;
  color:var(--gold-bright);font-size:.95rem;transition:all .25s var(--ease);white-space:nowrap;
}
.prov-link:hover{background:rgba(201,168,92,.1);transform:translateY(-2px)}
.prov-link svg{width:15px;height:15px}
.prov-intro{color:var(--ink-soft);font-size:1.04rem;line-height:1.6;margin-bottom:22px}
.prov-steps{list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:15px}
.prov-steps li{position:relative;padding:5px 0 5px 50px;color:var(--ink-soft);font-size:1.04rem;line-height:1.6;min-height:34px}
.prov-steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:0;top:0;width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:1.05rem;
  color:var(--gold-bright);border:1px solid var(--gold-deep);background:rgba(201,168,92,.14);}
.prov-steps b{color:var(--ink);font-weight:600}
.prov-steps code{
  font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:.92em;
  background:rgba(201,168,92,.1);border:1px solid var(--line);border-radius:5px;
  padding:1px 7px;color:var(--gold-bright);
}
.prov-tip{
  display:flex;gap:12px;margin-top:18px;padding:14px 18px;border-radius:0 12px 12px 0;
  border:1px solid var(--line);border-left:3px solid var(--gold);background:rgba(255,255,255,.02);
  color:var(--ink-soft);font-size:.98rem;line-height:1.55;
}
.prov-tip svg{width:18px;height:18px;flex:none;color:var(--gold);margin-top:2px}

/* ---------------- Guides hub ---------------- */
.guides-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:10px}
@media(max-width:720px){.guides-grid{grid-template-columns:1fr}}
.guide-card{
  position:relative;display:flex;flex-direction:column;gap:14px;
  border:1px solid var(--line);border-radius:16px;padding:28px 28px 26px;
  background:var(--bg-card);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.guide-card.is-live{cursor:pointer}
.guide-card.is-live:hover{transform:translateY(-5px);border-color:var(--line-strong);box-shadow:0 26px 54px rgba(0,0,0,.4)}
.guide-card.is-soon{opacity:.66}
.gc-top{display:flex;align-items:center;gap:14px}
.gc-ic{flex:none;width:50px;height:50px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--gold);background:radial-gradient(circle at 40% 30%,rgba(201,168,92,.14),transparent 70%)}
.gc-ic svg{width:26px;height:26px}
.gc-badge{
  margin-left:auto;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:5px 12px;border-radius:100px;white-space:nowrap;
}
.gc-badge.live{color:#1a1406;background:linear-gradient(180deg,var(--gold-bright),var(--gold))}
.gc-badge.soon{color:var(--ink-dim);border:1px solid var(--line-strong)}
.guide-card h3{font-family:var(--display);font-size:1.46rem;color:var(--ink);line-height:1.15}
.guide-card p{color:var(--ink-soft);font-size:1.02rem;line-height:1.55;flex:1}
.gc-go{display:inline-flex;align-items:center;gap:8px;color:var(--gold-bright);font-size:.98rem;font-weight:500;transition:gap .25s}
.gc-go svg{width:17px;height:17px;transition:transform .25s}
.guide-card.is-live:hover .gc-go{gap:12px}
.guide-card.is-live:hover .gc-go svg{transform:translateX(3px)}

