/* ============================================================
   ANOVA — shared cinematic stylesheet
   Near-black canvas, champagne-gold accents, Cormorant + Inter
   ============================================================ */

:root{
  --bg:#050506;
  --bg2:#070708;
  --bg3:#0c0c0f;
  --text:#f4f0ea;
  --muted:#8e8a83;
  --gold:#e8c9a0;
  --gold2:#c79b63;
  --champ:#f0dcc0;
  --line:rgba(232,201,160,.12);
  --maxw:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:300;
  overflow-x:hidden;
  cursor:none;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--gold2);color:#050506}

h1,h2,h3,h4,.serif{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  line-height:1.04;
  letter-spacing:.01em;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

.grad{
  background:linear-gradient(120deg,#fff,var(--champ) 45%,var(--gold2));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 36px}

/* ---------- accessible focus ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible,.btn:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:4px;
}
.skip{
  position:absolute;left:-999px;top:0;z-index:2000;
  background:var(--gold);color:#050506;padding:12px 20px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-radius:0 0 8px 0;
}
.skip:focus{left:0}

/* ---------- intro loader ---------- */
#intro{
  position:fixed;inset:0;z-index:1000;background:var(--bg);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;
  transition:opacity 1s 0s,visibility 1s;
}
#intro.gone{opacity:0;visibility:hidden}
#intro .word{
  font-family:'Cormorant Garamond',serif;font-size:clamp(40px,9vw,120px);
  letter-spacing:.3em;padding-left:.3em;overflow:hidden;display:flex;
}
#intro .word span{opacity:0;transform:translateY(110%);display:inline-block;animation:up .9s forwards}
@keyframes up{to{opacity:1;transform:none}}
#intro .bar{width:160px;height:1px;background:rgba(255,255,255,.12);position:relative;overflow:hidden}
#intro .bar::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--gold2),var(--champ));transform:translateX(-100%);animation:load 1.8s .4s forwards}
@keyframes load{to{transform:translateX(0)}}

/* ---------- custom cursor ---------- */
.cur,.cdot{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}
.cur{width:36px;height:36px;border:1px solid var(--gold);mix-blend-mode:difference}
.cdot{width:5px;height:5px;background:var(--gold)}
.cur.grow{width:78px;height:78px;background:rgba(232,201,160,.07);border-color:transparent}
@media(hover:none),(pointer:coarse){.cur,.cdot{display:none}body{cursor:auto}}

/* ---------- ambient layers ---------- */
#scene{position:fixed;inset:0;z-index:0}
.aurora{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(40% 50% at 50% 38%,rgba(199,155,99,.16),transparent 70%),
    radial-gradient(45% 40% at 18% 22%,rgba(232,201,160,.10),transparent 70%),
    radial-gradient(50% 45% at 82% 70%,rgba(240,220,192,.08),transparent 70%);
  animation:drift 18s ease-in-out infinite alternate;
}
@keyframes drift{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(0,-3%,0) scale(1.08)}
}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 50% 40%,transparent 30%,rgba(5,5,6,.55) 80%,#050506 100%)}
.grain{position:fixed;inset:0;z-index:2;opacity:.05;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.content{position:relative;z-index:5}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:24px 0;transition:.4s}
nav.s{padding:14px 0;background:rgba(5,5,6,.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;justify-content:space-between;align-items:center}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:30px;width:auto}
.brand .wordmark{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:600;letter-spacing:.34em;padding-left:.34em}
.nl{display:flex;gap:34px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);align-items:center}
.nl a{transition:.3s;position:relative}
.nl a:hover,.nl a[aria-current="page"]{color:var(--text)}
.nl a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:linear-gradient(90deg,var(--gold2),var(--champ))}
.nav-right{display:flex;align-items:center;gap:22px}
@media(max-width:820px){.nl{display:none}}

/* language switcher (EN ⇄ FR) */
.lang{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(232,201,160,.26);border-radius:999px;padding:6px 13px;line-height:1}
.lang .on{color:var(--champ)}
.lang a{color:var(--muted);transition:.3s}
.lang a:hover{color:var(--text)}
@media(max-width:820px){.nav-right .lang{display:none}}
.drawer .lang{font-family:'Inter',sans-serif;font-size:15px;letter-spacing:.12em;padding:9px 20px;margin-top:4px}

/* hamburger */
.burger{display:none;width:30px;height:20px;position:relative;background:none;border:0;cursor:none}
.burger span{position:absolute;left:0;right:0;height:1.5px;background:var(--text);transition:.4s}
.burger span:nth-child(1){top:0}.burger span:nth-child(2){top:9px}.burger span:nth-child(3){top:18px}
.burger.open span:nth-child(1){top:9px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:9px;transform:rotate(-45deg)}
@media(max-width:820px){.burger{display:block}.nav-right .btn{display:none}}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:190;background:rgba(5,5,6,.97);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px;
  opacity:0;visibility:hidden;transition:.5s;
}
.drawer.open{opacity:1;visibility:visible}
.drawer a{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--text);letter-spacing:.04em}
.drawer a:hover{color:var(--gold)}
.drawer .btn{margin-top:14px}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;padding:13px 30px;border:1px solid var(--gold);color:var(--gold);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;border-radius:40px;
  overflow:hidden;position:relative;transition:.4s;background:none;cursor:none;font-family:inherit;
}
.btn span{position:relative;z-index:1}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--gold2),var(--champ));transform:translateY(101%);transition:.45s}
.btn:hover{color:#050506;border-color:transparent}
.btn:hover::before{transform:translateY(0)}
.btn.solid{background:linear-gradient(120deg,var(--gold2),var(--champ));color:#050506;border-color:transparent}
.btn.solid::before{background:#fff}
@media(hover:none),(pointer:coarse){.btn{cursor:pointer}.burger{cursor:pointer}}

/* ---------- hero ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;padding:120px 0 80px}
.hero .eye{font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:34px;opacity:0;animation:fade 1.2s 2s forwards}
.hero h1{font-size:clamp(44px,8.5vw,128px);font-weight:300}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln b{font-weight:300;display:inline-block;transform:translateY(110%);opacity:0;animation:up 1.1s forwards}
.hero h1 .ln:nth-child(1) b{animation-delay:2.05s}
.hero h1 .ln:nth-child(2) b{animation-delay:2.2s}
.hero p{margin-top:30px;max-width:520px;color:var(--muted);font-size:clamp(16px,1.8vw,20px);opacity:0;animation:fade 1.2s 2.6s forwards;padding:0 20px}
.hero .cta{margin-top:44px;display:flex;gap:18px;flex-wrap:wrap;justify-content:center;opacity:0;animation:fade 1.2s 2.8s forwards}
@keyframes fade{to{opacity:1}}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:fade 1.2s 3.2s forwards}
.scrollcue .b{width:1px;height:48px;background:linear-gradient(var(--gold),transparent);animation:pls 2s infinite}
@keyframes pls{0%,100%{opacity:.3}50%{opacity:1}}

/* sub-page hero (lighter) */
.phero{min-height:62vh;display:flex;flex-direction:column;justify-content:center;text-align:center;align-items:center;padding:170px 0 80px;position:relative}
.phero .eye{font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:26px}
.phero h1{font-size:clamp(44px,7.5vw,104px);font-weight:300}
.phero p{margin-top:26px;max-width:560px;color:var(--muted);font-size:clamp(16px,1.8vw,20px)}

/* ---------- sections ---------- */
section{padding:140px 0;position:relative}
@media(max-width:820px){section{padding:90px 0}}
.reveal{opacity:0;transform:translateY(60px);transition:1.1s cubic-bezier(.16,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .aurora{animation:none}
  *{animation-duration:.001s!important}
}
.kicker{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:block}
.big{font-size:clamp(36px,6vw,82px);font-weight:300;max-width:15ch}
.lead{color:var(--muted);font-size:clamp(17px,1.9vw,21px);max-width:600px;margin-top:26px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* pinned statement */
.statement{height:130vh}
.statement .stick{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;text-align:center}
.statement h2{font-size:clamp(40px,7vw,104px);font-weight:300;max-width:16ch}
@media(max-width:820px){.statement{height:auto}.statement .stick{position:static;height:auto;padding:60px 0}}

/* card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-top:70px}
@media(max-width:880px){.grid{grid-template-columns:1fr}}
.grid.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:760px){.grid.two{grid-template-columns:1fr}}
.cell{background:var(--bg2);padding:46px 38px;transition:.5s;position:relative}
.cell:hover{background:var(--bg3)}
.cell .ic{font-size:22px;color:var(--gold);margin-bottom:24px}
.cell .ic.num{font-family:'Cormorant Garamond',serif;font-size:48px}
.cell h3{font-size:26px;margin-bottom:12px}
.cell p{color:var(--muted);font-size:15px;line-height:1.6}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;margin-top:50px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:50px 20px}}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,7vw,86px);line-height:1}
.stat .l{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ---------- demo / transcript ---------- */
.demo-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;margin-top:60px}
@media(max-width:900px){.demo-wrap{grid-template-columns:1fr;gap:44px}}
.wave{display:flex;align-items:center;gap:5px;height:120px;margin-bottom:30px}
.wave i{display:block;width:4px;border-radius:4px;background:linear-gradient(var(--champ),var(--gold2));animation:eq 1.1s ease-in-out infinite}
@keyframes eq{0%,100%{height:10px;opacity:.5}50%{height:var(--h,60px);opacity:1}}
.transcript{
  background:linear-gradient(160deg,rgba(12,12,15,.9),rgba(7,7,8,.9));
  border:1px solid var(--line);border-radius:22px;padding:36px;
  max-height:520px;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.transcript::-webkit-scrollbar{width:6px}
.transcript::-webkit-scrollbar-thumb{background:var(--gold2);border-radius:6px}
.bubble{margin-bottom:18px;max-width:84%;padding:14px 18px;border-radius:16px;font-size:15px;line-height:1.5}
.bubble.a{background:rgba(232,201,160,.10);border:1px solid var(--line);color:var(--champ);border-bottom-left-radius:4px}
.bubble.c{background:rgba(255,255,255,.04);margin-left:auto;text-align:right;border-bottom-right-radius:4px;color:var(--text)}
.bubble .who{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}

/* ---------- pricing ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px;align-items:stretch}
@media(max-width:900px){.tiers{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}}
.tier{
  background:var(--bg2);border:1px solid var(--line);border-radius:22px;padding:42px 34px;
  display:flex;flex-direction:column;transition:.5s;position:relative;
}
.tier:hover{transform:translateY(-6px);border-color:rgba(232,201,160,.3)}
.tier.feat{
  background:linear-gradient(180deg,rgba(199,155,99,.10),var(--bg2));
  border-color:rgba(232,201,160,.4);
}
.tier .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(120deg,var(--gold2),var(--champ));color:#050506;font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:6px 16px;border-radius:30px;font-weight:500}
.tier h3{font-size:30px;margin-bottom:8px}
.tier .price{font-family:'Cormorant Garamond',serif;font-size:34px;margin:14px 0 4px;color:var(--champ)}
.tier .price small{font-size:14px;color:var(--muted);font-family:'Inter',sans-serif}
.tier .sub{color:var(--muted);font-size:13px;margin-bottom:26px}
.tier ul{list-style:none;flex:1;margin-bottom:30px}
.tier li{color:var(--muted);font-size:14.5px;padding:11px 0 11px 26px;position:relative;border-bottom:1px solid rgba(255,255,255,.04)}
.tier li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:12px;top:12px}

/* ---------- about prose ---------- */
.prose-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;margin-top:70px}
@media(max-width:880px){.prose-grid{grid-template-columns:1fr;gap:44px}}
.prose-grid h3{font-size:30px;margin-bottom:16px}
.prose-grid p{color:var(--muted);font-size:16px;line-height:1.75}
.prose-grid .n{font-family:'Cormorant Garamond',serif;font-size:40px;color:var(--gold);opacity:.5;margin-bottom:18px;display:block}

/* ---------- contact form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:60px;align-items:start}
@media(max-width:900px){.form-grid{grid-template-columns:1fr;gap:44px}}
.field{margin-bottom:22px}
.field label{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.field input,.field select,.field textarea{
  width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;
  padding:15px 16px;color:var(--text);font-family:inherit;font-size:15px;font-weight:300;transition:.3s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);background:rgba(232,201,160,.05)}
.field textarea{min-height:130px;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c79b63' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:520px){.form-row{grid-template-columns:1fr}}
.form-note{color:var(--muted);font-size:13px;margin-top:18px}
.form-ok{display:none;text-align:center;padding:50px 30px;border:1px solid var(--line);border-radius:22px;background:var(--bg2)}
.form-ok.show{display:block}
.form-ok .mk{font-size:40px;color:var(--gold);margin-bottom:18px}
.form-ok h3{font-size:32px;margin-bottom:12px}
.form-ok p{color:var(--muted)}
.contact-aside h3{font-size:30px;margin-bottom:18px}
.contact-aside p{color:var(--muted);font-size:16px;line-height:1.7;margin-bottom:22px}
.contact-aside a.mail{color:var(--champ);font-size:18px;border-bottom:1px solid var(--line);padding-bottom:3px}
.contact-aside a.mail:hover{border-color:var(--gold)}

/* ---------- final cta ---------- */
.cta-final{min-height:90vh;display:flex;align-items:center;justify-content:center;text-align:center}
.cta-final h2{font-size:clamp(44px,9vw,120px);font-weight:300}
.cta-final p{color:var(--muted);font-size:19px;margin:24px auto 40px;max-width:480px}

/* ---------- footer ---------- */
footer{padding:64px 0;border-top:1px solid var(--line);position:relative;z-index:5}
footer .ftop{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:40px}
footer .fbrand{max-width:280px}
footer .fbrand .wordmark{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;letter-spacing:.34em;padding-left:.34em;margin-bottom:16px;display:block}
footer .fbrand p{color:var(--muted);font-size:14px;line-height:1.6}
footer .fcols{display:flex;gap:70px;flex-wrap:wrap}
footer .fcol h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;font-family:'Inter',sans-serif;font-weight:400}
footer .fcol a{display:block;color:var(--text);font-size:14px;margin-bottom:12px;transition:.3s}
footer .fcol a:hover{color:var(--gold)}
footer .fbot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;color:var(--muted);font-size:13px;border-top:1px solid rgba(255,255,255,.04);padding-top:28px}

/* ============================================================
   TALK-TO-ANOVA ORB  (live Retell web call, audio-reactive)
   ============================================================ */
.orb-section{text-align:center}
.orb-stage{
  position:relative;display:flex;flex-direction:column;align-items:center;
  gap:34px;margin-top:64px;
}
.orb-shell{
  position:relative;width:min(340px,72vw);height:min(340px,72vw);
  display:flex;align-items:center;justify-content:center;
  /* --amp is set by JS 0..1 to drive reactivity */
  --amp:0;
}
/* outer glow halo */
.orb-halo{
  position:absolute;inset:-18%;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 50% 42%,rgba(240,220,192,.36),rgba(199,155,99,.12) 45%,transparent 70%);
  filter:blur(26px);
  opacity:calc(.5 + var(--amp)*.5);
  transform:scale(calc(1 + var(--amp)*.18));
  transition:opacity .12s linear,transform .12s linear;
}
/* the sphere */
.orb-ball{
  position:relative;width:74%;height:74%;border-radius:50%;cursor:pointer;
  background:
    radial-gradient(circle at 36% 30%,#fff6e9 0%,var(--champ) 22%,var(--gold) 46%,var(--gold2) 72%,#7c5a31 100%);
  box-shadow:
    inset 0 0 50px rgba(255,247,233,.5),
    inset -22px -26px 60px rgba(80,52,22,.55),
    0 24px 70px rgba(199,155,99,.35);
  transform:scale(calc(1 + var(--amp)*.10));
  transition:transform .10s linear;
  animation:orbBreath 6s ease-in-out infinite;
  border:0;outline-offset:8px;
}
.orb-ball::before{
  content:"";position:absolute;inset:0;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 50% 50%,transparent 58%,rgba(255,247,233,.22) 72%,transparent 80%);
  transform:scale(calc(1 + var(--amp)*.30));opacity:calc(.4 + var(--amp)*.6);
  transition:transform .12s linear,opacity .12s linear;
}
/* specular highlight */
.orb-ball::after{
  content:"";position:absolute;top:14%;left:20%;width:34%;height:26%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.85),transparent 70%);
  filter:blur(3px);pointer-events:none;
}
@keyframes orbBreath{0%,100%{filter:brightness(1)}50%{filter:brightness(1.12)}}
@media(prefers-reduced-motion:reduce){.orb-ball{animation:none}}
@media(hover:hover){.orb-ball:hover{filter:brightness(1.08)}}

/* concentric reactive rings */
.orb-rings{position:absolute;inset:0;pointer-events:none}
.orb-rings i{
  position:absolute;inset:8%;border:1px solid rgba(232,201,160,.30);border-radius:50%;
  opacity:0;transform:scale(.8);
}
.orb-shell.live .orb-rings i{animation:orbRing 2.6s ease-out infinite}
.orb-shell.live .orb-rings i:nth-child(2){animation-delay:.85s}
.orb-shell.live .orb-rings i:nth-child(3){animation-delay:1.7s}
@keyframes orbRing{0%{opacity:.5;transform:scale(.85)}100%{opacity:0;transform:scale(1.35)}}
@media(prefers-reduced-motion:reduce){.orb-shell.live .orb-rings i{animation:none;display:none}}

/* status label + caption inside stage */
.orb-status{
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);
  min-height:16px;
}
.orb-hint{color:var(--muted);font-size:15px;max-width:440px;line-height:1.6}
.orb-controls{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.orb-shell.connecting .orb-ball{animation:orbBreath 1.1s ease-in-out infinite}

/* live transcript line under orb (optional, populated by JS) */
.orb-live-cap{color:var(--champ);font-size:14px;min-height:20px;max-width:520px;opacity:.85}

/* fallback demo note */
.orb-fallback-note{
  color:var(--muted);font-size:13px;margin-top:6px;display:none;
}
.orb-stage.fallback .orb-fallback-note{display:block}

/* floating orb button (all pages) */
.orb-float{
  position:fixed;right:26px;bottom:26px;z-index:180;
  width:64px;height:64px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:radial-gradient(circle at 36% 30%,#fff6e9,var(--gold) 50%,var(--gold2) 100%);
  box-shadow:0 12px 34px rgba(199,155,99,.45),inset -6px -8px 18px rgba(80,52,22,.5);
  animation:orbBreath 6s ease-in-out infinite;
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s;
}
.orb-float:hover{transform:scale(1.07)}
.orb-float svg{width:26px;height:26px}
.orb-float .lab{
  position:absolute;right:74px;white-space:nowrap;background:rgba(5,5,6,.9);
  border:1px solid var(--line);color:var(--champ);padding:8px 14px;border-radius:30px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:0;pointer-events:none;
  transform:translateX(8px);transition:.3s;
}
.orb-float:hover .lab{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.orb-float{animation:none}}
@media(hover:none),(pointer:coarse){.orb-float{cursor:pointer}}
@media(max-width:520px){.orb-float{width:56px;height:56px;right:16px;bottom:16px}}
