/* =================================================================
   NUTRICIONISTA EXPERT v4 · Premium ÉPICO
   3D devices · cursor glow · magnetic CTAs · animated chat
   Performance: transform/opacity only, IntersectionObserver, lazy.
   ================================================================= */

:root {
  /* paleta refinada */
  --cream:    #FAF7F0;
  --cream-2:  #F4F0E5;
  --cream-3:  #ECE6D5;
  --paper:    #FFFFFF;
  --paper-2:  #FBFAF5;
  --ink:      #0F1110;
  --ink-2:    #1F2220;
  --ink-3:    #3A3D3A;
  --walnut:   #4A4239;
  --muted:    #5F6660;
  --muted-2:  #8E938B;
  --line:     #E8E4DA;
  --line-2:   #F0EBDE;
  --line-3:   #D8D2C2;

  /* sage (principal) */
  --sage:     #3A7D5C;
  --sage-d:   #2D6347;
  --sage-l:   #5A9C7C;
  --sage-xl:  #8FC2A8;
  --sage-bg:  #E8F0EA;
  --sage-bg2: #D5E4D9;
  --sage-dark:#0E2E22;

  /* amber/gold (calor, premium) */
  --amber:    #C26B2C;
  --amber-l:  #E89A56;
  --gold:     #B89060;
  --gold-l:   #D4B889;
  --amber-bg: #FAEFE0;

  --rose-bg:  #F7E7E5;
  --blue-bg:  #E5EEF3;

  --serif: "Fraunces","Iowan Old Style","Georgia",serif;
  --sans:  "Manrope",system-ui,-apple-system,sans-serif;

  --wrap: 1200px;
  --gutter: clamp(20px, 4vw, 60px);
  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-xl: 28px;

  --ease: cubic-bezier(.2,.65,.2,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
}

/* ============ RESET ============ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--cream)}
body{
  margin:0;font-family:var(--sans);font-size:15.5px;line-height:1.6;
  color:var(--walnut);background:var(--cream);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;position:relative;
}
::selection{background:var(--sage);color:var(--cream)}
a{color:inherit;text-decoration:none}
a:focus-visible{outline:2px solid var(--sage);outline-offset:3px;border-radius:4px}
button{font-family:inherit;cursor:pointer}
img,svg,video{max-width:100%;display:block}

h1,h2,h3,h4{
  font-family:var(--serif);font-weight:400;letter-spacing:-0.022em;
  margin:0;line-height:1.1;color:var(--ink);
  font-variation-settings:"opsz" 96,"SOFT" 50;
}
h1 em,h2 em,h3 em{
  font-style:italic;color:var(--sage);
  font-variation-settings:"opsz" 144,"SOFT" 100,"wght" 400;
}
p{margin:0}ul,ol{margin:0;padding:0;list-style:none}

/* ============ OVERLAYS GLOBAIS ============ */
.cursor-glow{
  position:fixed;top:0;left:0;
  width:600px;height:600px;border-radius:50%;
  pointer-events:none;z-index:1;
  background:radial-gradient(circle, rgba(58,125,92,0.10), rgba(58,125,92,0) 70%);
  mix-blend-mode:multiply;
  opacity:0;
  transition:opacity 0.6s var(--ease);
  will-change:transform;
}
@media (pointer:coarse), (max-width:899px){
  .cursor-glow{display:none}
}

.scroll-bar{
  position:fixed;top:0;left:0;right:0;
  height:2px;background:transparent;
  z-index:200;pointer-events:none;
}
.scroll-bar span{
  display:block;height:100%;width:100%;
  background:linear-gradient(90deg, var(--sage), var(--sage-l));
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.06s linear;
}

#ambient-canvas{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  opacity:0.85;
}

/* ============ HELPERS ============ */
.eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--sage-d);
  padding:6px 12px;background:var(--sage-bg);
  border-radius:999px;margin-bottom:18px;
  border:1px solid var(--sage-bg2);
}
.eyebrow i{font-size:13px}
.eyebrow-amber{background:var(--amber-bg);color:var(--amber);border-color:#f0d4a8}

.section-head{
  text-align:center;max-width:660px;margin:0 auto 56px;
}
.section-head h2{
  font-size:clamp(32px,4.2vw,54px);margin-bottom:14px;
}
.sec-sub{
  font-size:16px;color:var(--muted);line-height:1.55;max-width:520px;margin:0 auto;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;font-size:14px;font-weight:600;
  border-radius:999px;border:1px solid transparent;
  transition:transform 0.3s var(--ease), background 0.3s var(--ease), box-shadow 0.3s var(--ease), color 0.3s var(--ease);
  text-decoration:none;white-space:nowrap;
  letter-spacing:-0.005em;position:relative;overflow:hidden;
}
.btn i{font-size:17px;transition:transform 0.3s var(--ease);position:relative;z-index:2}
.btn span{position:relative;z-index:2}
.btn:hover i{transform:translateX(2px)}
.btn-primary{
  background:var(--ink);color:var(--cream);border-color:var(--ink);
  box-shadow:0 1px 0 rgba(255,255,255,0.08) inset, 0 4px 14px -4px rgba(15,17,16,0.3);
}
.btn-primary:hover{
  background:var(--sage);border-color:var(--sage);
  box-shadow:0 14px 32px -8px rgba(58,125,92,0.55);
}
.btn-glow{
  position:absolute;top:50%;left:50%;
  width:140%;height:140%;border-radius:50%;
  background:radial-gradient(circle, rgba(232,154,86,0.5), transparent 60%);
  transform:translate(-50%,-50%) scale(0);
  pointer-events:none;z-index:1;
  transition:transform 0.5s var(--ease), opacity 0.5s var(--ease);
  opacity:0;
}
.btn-primary:hover .btn-glow{transform:translate(-50%,-50%) scale(1);opacity:1}

.btn-ghost{
  background:transparent;color:var(--ink-2);
  border-color:var(--line-3);
}
.btn-ghost:hover{
  background:var(--paper);border-color:var(--ink);color:var(--ink);
}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-sm i{font-size:15px}
.btn-xl{padding:20px 36px;font-size:16px;border-radius:999px}
.btn-xl i{font-size:20px}

.magnetic{will-change:transform;transition:transform 0.4s var(--ease), background 0.3s var(--ease), box-shadow 0.3s var(--ease), color 0.3s var(--ease)}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:14px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  transition:padding 0.3s var(--ease), background 0.3s var(--ease), backdrop-filter 0.3s var(--ease), border-color 0.3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding:10px var(--gutter);
  backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  background:rgba(250,247,240,0.78);
  border-bottom-color:var(--line-2);
}
.logo{display:flex;align-items:center;gap:11px;color:var(--ink)}
.logo-mark{
  width:36px;height:36px;border-radius:9px;
  background:linear-gradient(135deg, var(--sage) 0%, var(--sage-d) 100%);
  position:relative;overflow:hidden;
  display:grid;place-items:center;
  transition:transform 0.4s var(--ease);
  box-shadow:0 4px 12px -4px rgba(58,125,92,0.5);
}
.logo-mark::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,0.25) 0%, transparent 50%);
  pointer-events:none;
}
.logo-mark-inner{
  font-family:var(--serif);font-size:16px;font-weight:600;
  color:var(--cream);letter-spacing:-0.04em;line-height:1;
  position:relative;z-index:1;
}
.logo-mark-inner em{font-style:italic;color:var(--amber-l)}
.logo:hover .logo-mark{transform:rotate(-8deg) scale(1.05)}
.logo-name{
  font-family:var(--serif);font-size:17px;font-weight:500;
  letter-spacing:-0.01em;color:var(--ink);
}
.logo-name em{font-style:italic;color:var(--sage);font-variation-settings:"opsz" 144,"SOFT" 100}

.nav-links{display:flex;gap:28px}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--ink-2);
  transition:color 0.25s var(--ease);position:relative;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-5px;
  width:0;height:1.5px;background:var(--sage);
  transition:width 0.3s var(--ease);
}
.nav-links a:hover{color:var(--sage-d)}
.nav-links a:hover::after{width:100%}

/* ============ HERO ============ */
.hero{
  position:relative;
  padding:130px var(--gutter) 70px;
  max-width:calc(var(--wrap) + var(--gutter)*2);
  margin:0 auto;
  min-height:min(820px, 95vh);
  display:flex;align-items:center;
  overflow:visible;
  isolation:isolate;
}
.hero-orb{
  position:absolute;border-radius:50%;
  pointer-events:none;z-index:-1;
  filter:blur(60px);
  opacity:0.5;
}
.hero-orb-1{
  top:8%;right:8%;
  width:340px;height:340px;
  background:radial-gradient(circle, var(--sage-xl), transparent 60%);
}
.hero-orb-2{
  bottom:5%;left:5%;
  width:280px;height:280px;
  background:radial-gradient(circle, var(--amber-l), transparent 60%);
  opacity:0.35;
}

.hero-grid{
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:60px;align-items:center;
  width:100%;
}

.hero-text{padding-right:8px;position:relative;z-index:2}

.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;background:var(--paper);
  border:1px solid var(--line);border-radius:999px;
  font-size:12.5px;font-weight:500;color:var(--ink-2);
  margin-bottom:22px;
  box-shadow:0 1px 0 rgba(15,17,16,0.04), 0 8px 24px -12px rgba(15,17,16,0.10);
}
.pill strong{color:var(--sage-d);font-weight:700}
.pill-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--sage);
  box-shadow:0 0 0 0 rgba(58,125,92,0.6);
  animation:pulseDot 2.4s var(--ease) infinite;
}
@keyframes pulseDot{
  0%{box-shadow:0 0 0 0 rgba(58,125,92,0.6)}
  70%{box-shadow:0 0 0 8px rgba(58,125,92,0)}
  100%{box-shadow:0 0 0 0 rgba(58,125,92,0)}
}

.hero h1{
  font-size:clamp(38px,5.2vw,72px);
  line-height:0.98;letter-spacing:-0.038em;
  margin-bottom:24px;font-weight:400;
}
.hero h1 .line{
  display:block;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.hero h1 .line em{
  padding-left:0.15em;
}

.hero-sub{
  font-size:clamp(15px,1.15vw,17.5px);line-height:1.55;
  color:var(--muted);margin-bottom:28px;max-width:50ch;
}
.hero-sub strong{color:var(--ink);font-weight:600}

.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}

.hero-meta{
  display:flex;flex-wrap:wrap;gap:18px;
  padding-top:22px;border-top:1px solid var(--line);
  max-width:520px;
}
.hm-item{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:500;color:var(--ink-2);
}
.hm-item i{color:var(--sage);font-size:16px}

/* ============ HERO STAGE (3D real) ============ */
.hero-stage{
  position:relative;
  perspective:1500px;
  perspective-origin:50% 40%;
  height:600px;
  display:flex;align-items:center;justify-content:center;
}

.device-cluster{
  position:relative;
  transform-style:preserve-3d;
  transition:transform 0.18s var(--ease-soft);
  width:100%;height:100%;
  will-change:transform;
}

/* Laptop atrás */
.d-laptop{
  position:absolute;
  top:18%;right:-4%;
  width:78%;
  transform-style:preserve-3d;
  transform: rotateY(-18deg) rotateX(8deg) translateZ(-80px);
  filter:drop-shadow(0 40px 50px rgba(15,17,16,0.22));
  animation:laptopFloat 7s ease-in-out infinite;
}
@keyframes laptopFloat{
  0%,100%{transform:rotateY(-18deg) rotateX(8deg) translateZ(-80px) translateY(0)}
  50%{transform:rotateY(-18deg) rotateX(8deg) translateZ(-80px) translateY(-6px)}
}
.laptop-frame{position:relative}
.laptop-screen{
  background:#0F1110;
  border-radius:10px 10px 0 0;
  padding:8px;
  border:1px solid #25282A;
  position:relative;
  overflow:hidden;
}
.laptop-screen::before{
  content:"";position:absolute;
  top:8px;left:8px;right:8px;bottom:0;
  border-radius:6px 6px 0 0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,0.04) 0%, transparent 30%);
  z-index:3;
}
.laptop-bar{
  display:flex;align-items:center;gap:5px;
  padding:6px 8px 8px;
  background:#1A1D1F;
  border-radius:6px 6px 0 0;
}
.laptop-bar > span{width:8px;height:8px;border-radius:50%;background:#3a3a40}
.laptop-bar > span:nth-child(1){background:#FF5F57}
.laptop-bar > span:nth-child(2){background:#FFBD2E}
.laptop-bar > span:nth-child(3){background:#28C840}
.laptop-url{
  flex:1;margin-left:8px;
  background:#0F1110;
  border-radius:4px;
  padding:4px 10px;
  font-size:9.5px;color:#8E938B;
  display:flex;align-items:center;gap:4px;
}
.laptop-url i{font-size:10px;color:var(--sage-xl)}

.laptop-content{
  background:var(--paper);
  padding:14px;min-height:180px;
}
.lcb-head{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:8px;margin-bottom:10px;
  border-bottom:1px solid var(--line-2);
}
.lcb-title{font-family:var(--serif);font-size:12.5px;font-weight:500;color:var(--ink)}
.lcb-badge{
  font-size:9.5px;color:var(--sage-d);font-weight:600;
  background:var(--sage-bg);padding:2px 7px;border-radius:999px;
}
.lcb-rows{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.lcb-row{
  display:grid;grid-template-columns:auto 1fr auto;
  gap:8px;align-items:center;
  padding:6px 9px;background:var(--cream);
  border-radius:5px;font-size:10.5px;
}
.lcb-row .dot{width:6px;height:6px;border-radius:50%}
.lcb-row .dot.ok{background:var(--sage)}
.lcb-row .dot.warn{background:var(--amber)}
.lcb-row .nm{color:var(--ink-2);font-weight:500}
.lcb-row .vl{font-size:10px;font-weight:700}
.lcb-row .vl.up{color:var(--sage-d)}
.lcb-row .vl.warn{color:var(--amber)}
.lcb-chart{
  height:50px;background:linear-gradient(180deg, var(--cream), var(--paper));
  border-radius:5px;padding:6px;
  border:1px solid var(--line-2);
}
.lcb-chart svg{width:100%;height:100%}

.laptop-keys{
  height:16px;
  background:linear-gradient(180deg,#2A2D2F 0%,#1A1D1F 100%);
  border-radius:0 0 16px 16px;
  margin:0 -8px;
  position:relative;
  transform:translateZ(-2px);
}
.laptop-keys::before{
  content:"";position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:30%;height:5px;background:#0F1110;
  border-radius:0 0 6px 6px;
}
.laptop-hinge{
  height:5px;margin:0 -8px;
  background:linear-gradient(180deg,#1A1D1F 0%,#0F1110 100%);
}

/* Phone na frente */
.d-phone{
  position:absolute;
  bottom:6%;left:8%;
  width:230px;
  transform: rotateY(12deg) rotateX(-4deg) translateZ(60px);
  z-index:3;
  animation:phoneFloat 6s ease-in-out infinite;
}
@keyframes phoneFloat{
  0%,100%{transform:rotateY(12deg) rotateX(-4deg) translateZ(60px) translateY(0)}
  50%{transform:rotateY(12deg) rotateX(-4deg) translateZ(60px) translateY(-10px)}
}
.phone-frame{
  position:relative;
  width:100%;aspect-ratio:230/480;
  background:linear-gradient(135deg, #1a1a1f 0%, #0a0a0c 50%, #1a1a1f 100%);
  border-radius:40px;
  padding:7px;
  box-shadow:
    inset 0 0 0 1.5px #2a2a30,
    inset 0 1px 0 rgba(255,255,255,0.1),
    0 30px 70px -20px rgba(15,17,16,0.5),
    0 60px 120px -40px rgba(58,125,92,0.3);
  overflow:hidden;
}
.phone-notch{
  position:absolute;top:14px;left:50%;
  transform:translateX(-50%);
  width:80px;height:22px;
  background:#0a0a0c;
  border-radius:0 0 14px 14px;z-index:3;
  display:flex;align-items:center;justify-content:flex-end;padding-right:14px;
}
.phone-notch::after{
  content:"";width:9px;height:9px;border-radius:50%;
  background:#1a1d20;
  box-shadow:inset 0 0 4px rgba(0,0,0,0.5);
}
.phone-video{
  width:100%;height:100%;
  border-radius:34px;object-fit:cover;
  display:block;
  background:var(--sage-bg);
}
.phone-glare{
  position:absolute;top:0;left:0;right:0;bottom:0;
  border-radius:40px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.18) 0%, transparent 28%, transparent 72%, rgba(255,255,255,0.08) 100%);
  pointer-events:none;z-index:4;
}
.phone-side{
  position:absolute;
  right:-4px;top:120px;
  width:4px;height:60px;
  background:linear-gradient(90deg, #0a0a0c, #2a2a30);
  border-radius:0 2px 2px 0;
}

/* Floating cards */
.f-card{
  position:absolute;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  box-shadow:0 20px 40px -16px rgba(15,17,16,0.18), 0 1px 0 rgba(255,255,255,0.6) inset;
  z-index:4;
  animation:floatY 5.5s ease-in-out infinite;
  backdrop-filter:blur(8px);
}
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.f-card-1{
  top:8%;right:-5%;width:230px;
  animation-delay:0.6s;
  transform:rotate(2deg);
}
.f-card-2{
  bottom:30%;left:-8%;width:170px;
  animation-delay:1.4s;
  transform:rotate(-3deg);
}
.f-card-3{
  bottom:5%;right:8%;width:175px;
  display:flex;align-items:center;gap:10px;
  animation-delay:2.2s;
}
.f-card-3 > i{
  width:34px;height:34px;border-radius:9px;
  background:var(--amber-bg);color:var(--amber);
  display:grid;place-items:center;font-size:18px;
  flex-shrink:0;
}
.fc-icon{
  width:32px;height:32px;border-radius:8px;
  background:var(--sage-bg);color:var(--sage-d);
  display:grid;place-items:center;
  font-size:17px;margin-bottom:8px;
}
.fc-title{font-size:11.5px;font-weight:700;color:var(--ink);margin-bottom:3px}
.fc-text{font-size:11px;color:var(--muted);line-height:1.4;margin-bottom:4px}
.fc-time{font-size:9.5px;color:var(--muted-2);font-weight:500}

.fc-stat-row{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.fc-num{
  font-family:var(--serif);font-style:italic;
  font-size:28px;font-weight:500;color:var(--sage-d);
  letter-spacing:-0.02em;line-height:1;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.fc-lbl{font-size:9.5px;font-weight:600;letter-spacing:0.06em;color:var(--muted);text-transform:uppercase;line-height:1.3}
.fc-bar{height:5px;background:var(--line);border-radius:999px;overflow:hidden;margin-bottom:5px}
.fc-fill{
  height:100%;width:92%;
  background:linear-gradient(90deg, var(--sage), var(--sage-l));
  border-radius:999px;
  animation:barGrow 2.4s var(--ease) infinite alternate;
}
@keyframes barGrow{
  from{width:88%}
  to{width:96%}
}
.fc-hint{font-size:9.5px;color:var(--sage-d);font-weight:600}
.fc-mini-title{font-size:11.5px;font-weight:700;color:var(--ink)}
.fc-mini-sub{font-size:10px;color:var(--muted)}

.stage-floor{
  position:absolute;
  bottom:-30px;left:10%;right:10%;
  height:24px;
  background:radial-gradient(ellipse at center, rgba(15,17,16,0.20), transparent 70%);
  filter:blur(8px);
  z-index:0;
}

/* Hero scroll hint */
.hero-scroll-hint{
  position:absolute;
  bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--sans);font-size:10.5px;font-weight:600;
  letter-spacing:0.15em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  transition:color 0.3s var(--ease);
}
.hero-scroll-hint:hover{color:var(--ink)}
.hsh-line{
  width:1px;height:36px;
  background:linear-gradient(180deg, transparent, var(--muted));
  animation:scrollLn 2.4s var(--ease) infinite;
}
@keyframes scrollLn{
  0%{transform:scaleY(0);transform-origin:top}
  45%,55%{transform:scaleY(1);transform-origin:top}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ============ CREDENTIALS MARQUEE ============ */
.credentials{
  background:var(--ink);color:var(--cream);
  overflow:hidden;
  padding:16px 0;
  border-top:1px solid var(--ink-3);
  border-bottom:1px solid var(--ink-3);
}
.marquee{overflow:hidden}
.marquee-track{
  display:inline-flex;align-items:center;gap:32px;
  white-space:nowrap;
  animation:marquee 50s linear infinite;
  font-size:13px;font-weight:500;
  color:var(--cream-2);
}
.marquee-track > span{
  display:inline-flex;align-items:center;gap:8px;
}
.marquee-track i{font-size:16px;color:var(--sage-xl)}
.marquee-track .sep{color:var(--muted-2)}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ============ STRIP PROBLEMA ============ */
.strip-section{
  padding:50px var(--gutter);
  max-width:calc(var(--wrap) + var(--gutter)*2);
  margin:0 auto;
}
.strip-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px 32px;
  display:flex;align-items:center;gap:20px;
  box-shadow:0 1px 0 rgba(255,255,255,0.7) inset, 0 8px 24px -16px rgba(15,17,16,0.08);
}
.strip-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg, var(--amber-l), var(--amber));
  color:var(--cream);
  display:grid;place-items:center;
  font-size:26px;flex-shrink:0;
  box-shadow:0 8px 20px -8px rgba(194,107,44,0.4);
}
.strip-body{flex:1}
.strip-body h2{
  font-size:21px;font-weight:400;line-height:1.2;margin-bottom:3px;
  letter-spacing:-0.01em;
}
.strip-body h2 strong{
  font-style:italic;color:var(--sage-d);font-weight:500;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.strip-body p{font-size:14.5px;color:var(--muted);line-height:1.5}
.strip-tag{
  font-size:12px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;
  padding:8px 14px;background:var(--ink);color:var(--cream);
  border-radius:999px;flex-shrink:0;
  transition:transform 0.3s var(--ease), background 0.3s var(--ease);
}

/* ============ OFERTA ============ */
.offer{
  padding:80px var(--gutter) 60px;
  max-width:calc(var(--wrap) + var(--gutter)*2);margin:0 auto;
}
.offer-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-bottom:24px;
}
.ocard{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 22px 22px;
  transition:transform 0.4s var(--ease), border-color 0.3s var(--ease), box-shadow 0.4s var(--ease);
  position:relative;overflow:hidden;
}
.ocard::before{
  content:"";position:absolute;top:0;left:0;
  width:0;height:2px;background:var(--sage);
  transition:width 0.6s var(--ease);
}
.ocard:hover{
  transform:translateY(-3px);
  border-color:var(--sage-bg2);
  box-shadow:0 14px 30px -14px rgba(58,125,92,0.18), 0 4px 12px -6px rgba(15,17,16,0.08);
}
.ocard:hover::before{width:100%}
.ocard-num{
  position:absolute;top:18px;right:20px;
  font-family:var(--mono, monospace);
  font-size:10.5px;font-weight:700;letter-spacing:0.14em;
  color:var(--muted-2);
}
.ocard-icon{
  width:42px;height:42px;border-radius:11px;
  background:linear-gradient(135deg, var(--sage-bg), var(--paper));
  border:1px solid var(--sage-bg2);
  color:var(--sage-d);
  display:grid;place-items:center;font-size:21px;
  margin-bottom:18px;
}
.ocard h3{
  font-size:21px;margin-bottom:6px;letter-spacing:-0.02em;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-weight:500;
}
.ocard > p{
  font-size:13.5px;line-height:1.5;color:var(--muted);
  margin-bottom:16px;
}
.ocard ul{
  display:flex;flex-direction:column;gap:5px;
  padding-top:14px;border-top:1px solid var(--line-2);
}
.ocard li{
  font-size:12.5px;line-height:1.5;color:var(--ink-2);
  padding-left:14px;position:relative;
}
.ocard li::before{
  content:"";position:absolute;left:0;top:8px;
  width:7px;height:1.5px;background:var(--sage);
}
.ocard-soon{background:linear-gradient(180deg, var(--cream-2) 0%, var(--paper) 100%)}
.ocard-soon .ocard-icon{
  background:linear-gradient(135deg, var(--amber-bg), var(--paper));
  border-color:#f0d4a8;color:var(--amber);
}
.tag-soon{
  font-size:9.5px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;
  padding:3px 7px;background:var(--amber-bg);color:var(--amber);
  border-radius:4px;border:1px solid #f0d4a8;
}

/* Card HERO IA full-width */
.ocard-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--ink) 0%, #1A2520 70%, var(--sage-dark) 100%);
  border-radius:var(--radius-lg);
  padding:48px;
  border:1px solid #1A2520;
  box-shadow:0 30px 80px -30px rgba(58,125,92,0.5);
  color:var(--cream);
}
.ohero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(40% 60% at 80% 30%, rgba(143,194,168,0.18), transparent 60%),
    radial-gradient(50% 50% at 10% 90%, rgba(232,154,86,0.10), transparent 60%);
}
.ohero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:48px;align-items:center;
}
.ohero-tag{
  display:inline-block;
  font-size:11px;font-weight:700;letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--amber-l);
  margin-bottom:18px;
  padding:5px 12px;background:rgba(232,154,86,0.15);
  border:1px solid rgba(232,154,86,0.3);
  border-radius:999px;
}
.ocard-hero h3{
  font-size:clamp(28px,3.2vw,42px);line-height:1.05;
  margin-bottom:16px;color:var(--cream);font-weight:400;
}
.ocard-hero h3 em{color:var(--sage-xl)}
.ocard-hero p{
  font-size:15.5px;line-height:1.6;color:rgba(250,247,240,0.78);
  max-width:55ch;margin-bottom:22px;
}
.ohero-link{
  font-size:13px;font-weight:600;color:var(--sage-xl);
  display:inline-flex;align-items:center;gap:5px;
  padding-bottom:4px;border-bottom:1px solid rgba(143,194,168,0.4);
  transition:gap 0.3s var(--ease), color 0.3s var(--ease);
}
.ohero-link:hover{gap:10px;color:var(--cream)}

.ohero-features{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
.ohf{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 16px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
  transition:background 0.3s var(--ease), border-color 0.3s var(--ease);
}
.ohf:hover{background:rgba(143,194,168,0.08);border-color:rgba(143,194,168,0.25)}
.ohf i{color:var(--sage-xl);font-size:22px}
.ohf span{font-size:12.5px;font-weight:600;color:var(--cream);letter-spacing:-0.005em}

/* ============ IA SECTION ============ */
.ia-section{
  padding:100px var(--gutter);
  max-width:calc(var(--wrap) + var(--gutter)*2);margin:0 auto;
  position:relative;
}
.ia-orb{
  position:absolute;
  top:40%;right:-100px;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle, var(--sage-xl), transparent 60%);
  filter:blur(80px);opacity:0.4;z-index:-1;
  pointer-events:none;
}
.ia-grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:60px;align-items:center;
}
.ia-text h2{
  font-size:clamp(30px,4vw,52px);line-height:1.04;
  letter-spacing:-0.03em;margin-bottom:18px;
}
.ia-lead{
  font-size:16.5px;line-height:1.6;color:var(--muted);
  margin-bottom:28px;max-width:48ch;
}
.ia-lead strong{color:var(--ink);font-weight:600}

.ia-features-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  margin-bottom:32px;
}
.iaf{
  display:flex;gap:12px;align-items:flex-start;
  padding:16px;background:var(--paper);
  border:1px solid var(--line);border-radius:12px;
  transition:transform 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.iaf:hover{
  transform:translateY(-2px);
  border-color:var(--sage-bg2);
  box-shadow:0 12px 24px -12px rgba(58,125,92,0.18);
}
.iaf-ic{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg, var(--sage-bg), var(--paper));
  border:1px solid var(--sage-bg2);
  color:var(--sage-d);
  display:grid;place-items:center;font-size:19px;
  flex-shrink:0;
}
.iaf strong{
  display:block;font-size:14px;font-weight:600;
  color:var(--ink);margin-bottom:2px;letter-spacing:-0.005em;
}
.iaf span{font-size:12.5px;color:var(--muted);line-height:1.4}

.ia-cta-row{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.ia-cta-note{
  font-size:12.5px;color:var(--muted);
  display:inline-flex;align-items:center;gap:5px;
}
.ia-cta-note i{color:var(--sage);font-size:14px}
.ia-cta-note strong{color:var(--ink);font-weight:600}

/* === Chat animado === */
.ia-chat{
  position:relative;
  display:flex;justify-content:center;align-items:center;
  min-height:560px;
}
.chat-window{
  width:100%;max-width:380px;
  background:var(--paper);
  border-radius:24px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.8) inset,
    0 40px 80px -30px rgba(15,17,16,0.22),
    0 80px 120px -50px rgba(58,125,92,0.25);
  position:relative;
  z-index:2;
}
.chat-header{
  display:grid;grid-template-columns:auto 1fr auto;
  gap:12px;align-items:center;
  padding:18px 20px;
  background:var(--cream);
  border-bottom:1px solid var(--line-2);
}
.chat-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg, var(--sage), var(--sage-d));
  color:var(--cream);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:18px;font-weight:600;font-style:italic;
}
.chat-name{font-size:14px;font-weight:600;color:var(--ink)}
.chat-status{
  font-size:11px;color:var(--sage-d);
  display:flex;align-items:center;gap:5px;font-weight:500;
}
.status-dot{
  width:6px;height:6px;border-radius:50%;background:var(--sage);
  box-shadow:0 0 8px var(--sage);
  animation:statPulse 2s ease-in-out infinite;
}
@keyframes statPulse{
  0%,100%{opacity:1}
  50%{opacity:0.5}
}
.chat-actions{color:var(--muted-2);font-size:18px}

.chat-body{
  padding:20px;
  display:flex;flex-direction:column;gap:14px;
  background:linear-gradient(180deg, var(--paper-2) 0%, var(--paper) 100%);
  min-height:340px;
}
.chat-msg{
  display:flex;flex-direction:column;gap:4px;
  max-width:85%;
  opacity:0;
  animation:msgIn 0.5s var(--ease) forwards;
}
.chat-msg.c-user{align-self:flex-end;align-items:flex-end}
.chat-msg.c-bot{align-self:flex-start;align-items:flex-start}
.chat-msg:nth-child(1){animation-delay:0.5s}
.chat-msg:nth-child(2){animation-delay:1.3s}
.chat-msg:nth-child(3){animation-delay:2.1s}
.c-show-delayed{animation-delay:3.3s !important}
.c-show-delayed-2{animation-delay:4.0s !important}
@keyframes msgIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

.cm-bubble{
  padding:11px 14px;
  border-radius:18px;
  font-size:13.5px;line-height:1.45;
  position:relative;
  word-wrap:break-word;
}
.c-bot .cm-bubble{
  background:var(--paper);
  border:1px solid var(--line);
  color:var(--ink-2);
  border-bottom-left-radius:5px;
  display:flex;gap:8px;align-items:flex-start;
  box-shadow:0 4px 14px -6px rgba(15,17,16,0.06);
}
.c-bot .cm-bubble strong{color:var(--sage-d);font-weight:700}
.c-user .cm-bubble{
  background:linear-gradient(135deg, var(--sage), var(--sage-d));
  color:var(--cream);
  border-bottom-right-radius:5px;
  box-shadow:0 6px 16px -8px rgba(58,125,92,0.4);
}
.c-spark{
  color:var(--sage);font-size:16px;flex-shrink:0;
  margin-top:1px;
}
.cm-time{
  font-size:10px;color:var(--muted-2);
  padding:0 6px;
}

.c-typing .cm-bubble{padding:14px 16px}
.typing-dots{display:inline-flex;gap:4px;align-items:center}
.typing-dots span{
  width:6px;height:6px;border-radius:50%;background:var(--sage);
  animation:dotPulse 1.4s infinite ease-in-out;
}
.typing-dots span:nth-child(2){animation-delay:0.2s}
.typing-dots span:nth-child(3){animation-delay:0.4s}
@keyframes dotPulse{
  0%,100%{opacity:0.3;transform:scale(0.7)}
  50%{opacity:1;transform:scale(1.1)}
}
/* esconde o typing depois do delayed aparecer */
.c-typing{
  animation:msgIn 0.5s var(--ease) forwards, msgOut 0.5s var(--ease) 3.3s forwards;
}
@keyframes msgOut{
  from{opacity:1;max-height:60px;margin-bottom:0;transform:translateY(0)}
  to{opacity:0;max-height:0;margin-bottom:-14px;transform:translateY(-8px)}
}

.chat-input{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  background:var(--cream);
  border-top:1px solid var(--line-2);
}
.chat-input i{color:var(--muted-2);font-size:18px}
.chat-input span{
  flex:1;font-size:13px;color:var(--muted-2);
  font-style:italic;
}

.chat-toast{
  position:absolute;
  top:30px;right:-20px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 20px 40px -16px rgba(15,17,16,0.15);
  animation:floatY 5s ease-in-out infinite;
  animation-delay:1.5s;
  z-index:3;
}
.chat-toast > i{color:var(--sage);font-size:22px}
.chat-toast strong{display:block;font-size:12px;font-weight:700;color:var(--ink);margin-bottom:1px}
.chat-toast span{font-size:11px;color:var(--muted)}

/* ============ RESULTADOS ============ */
.results{
  padding:90px var(--gutter);
  max-width:calc(var(--wrap) + var(--gutter)*2);margin:0 auto;
}
.results-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:2px solid var(--ink);
}
.result-card{
  padding:36px 28px 30px 0;
  border-right:1px solid var(--line-3);
  display:flex;flex-direction:column;gap:6px;
}
.result-card:last-child{border-right:0;padding-right:0}
.result-num{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(56px, 7vw, 96px);
  line-height:0.9;letter-spacing:-0.04em;
  color:var(--ink);margin-bottom:12px;
  font-variation-settings:"opsz" 144,"SOFT" 30;
  display:flex;align-items:baseline;
}
.result-num [data-counter]{
  font-style:italic;color:var(--sage-d);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.result-num .suffix{
  font-size:0.55em;color:var(--ink-3);font-style:italic;margin-left:2px;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.result-lbl{
  font-size:14.5px;color:var(--ink);font-weight:500;
  max-width:24ch;line-height:1.35;
}
.result-meta{
  font-size:12px;color:var(--muted);margin-top:4px;
}

/* ============ PROCESSO ============ */
.process{
  padding:90px var(--gutter);
  max-width:calc(var(--wrap) + var(--gutter)*2);margin:0 auto;
}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);
}
.steps li{
  padding:32px 28px 26px 0;
  border-right:1px solid var(--line);
  position:relative;
}
.steps li:last-child{border-right:0}
.steps li::before{
  content:"";position:absolute;
  top:-1px;left:0;
  width:40px;height:2px;background:var(--sage);
}
.step-n{
  font-family:var(--serif);font-style:italic;
  font-size:32px;font-weight:400;
  color:var(--sage-d);
  margin-bottom:14px;line-height:1;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.steps h3{
  font-size:19px;margin-bottom:6px;letter-spacing:-0.015em;font-weight:500;
}
.steps p{font-size:13.5px;line-height:1.5;color:var(--muted);margin-bottom:14px}
.step-time{
  font-size:10.5px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--sage-d);
  padding:4px 10px;background:var(--sage-bg);
  border-radius:999px;display:inline-block;
}

/* ============ CTA FINAL ============ */
.cta-final{
  padding:120px var(--gutter);
  text-align:center;
  position:relative;overflow:hidden;
  background:
    radial-gradient(60% 70% at 50% 0%, var(--sage-bg) 0%, transparent 70%),
    var(--cream);
}
.cta-orb{
  position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:800px;height:300px;
  background:radial-gradient(ellipse at center, var(--sage-bg2), transparent 70%);
  filter:blur(40px);
  pointer-events:none;
}
.cta-inner{max-width:620px;margin:0 auto;position:relative;z-index:1}
.cta-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--sage-d);
  margin-bottom:22px;
}
.ce-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--amber-l);
  box-shadow:0 0 0 0 rgba(232,154,86,0.6);
  animation:pulseDot 2.4s var(--ease) infinite;
}
.cta-inner h2{
  font-size:clamp(36px,5vw,68px);line-height:1.02;margin-bottom:18px;
  letter-spacing:-0.03em;
}
.cta-inner > p{
  font-size:16px;color:var(--muted);margin-bottom:32px;
  max-width:46ch;margin-left:auto;margin-right:auto;line-height:1.6;
}
.cta-note{
  margin-top:24px;display:flex;justify-content:center;flex-wrap:wrap;gap:20px;
}
.cta-note span{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12.5px;color:var(--muted);font-weight:500;
}
.cta-note i{color:var(--sage);font-size:14px}

/* ============ FOOTER ============ */
.ft{
  background:var(--ink);color:rgba(250,247,240,0.75);
  padding:60px var(--gutter) 28px;
  position:relative;
}
.ft::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--sage-xl), transparent);
  opacity:0.4;
}
.ft-grid{
  max-width:var(--wrap);margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;
  padding-bottom:36px;
  border-bottom:1px solid rgba(250,247,240,0.10);
}
.ft-brand p{
  font-size:13px;line-height:1.55;color:rgba(250,247,240,0.55);
  max-width:34ch;margin-top:10px;margin-bottom:18px;
}
.ft-logo{
  font-family:var(--serif);font-size:24px;font-weight:500;
  color:var(--cream);letter-spacing:-0.02em;
}
.ft-logo em{
  font-style:italic;color:var(--sage-xl);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.ft-socials{display:flex;gap:8px}
.ft-socials a{
  width:36px;height:36px;border-radius:9px;
  background:rgba(250,247,240,0.06);
  display:grid;place-items:center;
  transition:background 0.3s var(--ease), color 0.3s var(--ease);
  color:var(--cream);
}
.ft-socials a:hover{background:var(--sage);color:var(--cream)}
.ft-socials i{font-size:17px}

.ft-h{
  font-size:10.5px;font-weight:700;letter-spacing:0.15em;
  text-transform:uppercase;color:rgba(250,247,240,0.5);
  margin-bottom:14px;
}
.ft-grid > div a{
  display:flex;align-items:center;gap:7px;
  font-size:13px;color:var(--cream);
  padding:5px 0;
  transition:color 0.25s var(--ease);
}
.ft-grid > div a:hover{color:var(--sage-xl)}
.ft-grid > div a i{font-size:15px;color:var(--sage-xl)}
.ft-cnpj{
  display:block;font-size:12px;color:rgba(250,247,240,0.55);
  line-height:1.5;margin-top:14px;padding-top:14px;
  border-top:1px solid rgba(250,247,240,0.10);
}

.ft-bottom{
  max-width:var(--wrap);margin:24px auto 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:11.5px;color:rgba(250,247,240,0.45);
}
.ft-tag-end{
  font-family:var(--serif);font-style:italic;
  color:var(--sage-xl);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}

/* ============ REVEAL ============ */
.reveal{
  opacity:0;transform:translateY(24px);
  transition:opacity 0.85s var(--ease), transform 0.85s var(--ease);
}
.reveal.in{opacity:1;transform:none}
.offer-grid .reveal:nth-child(2){transition-delay:0.06s}
.offer-grid .reveal:nth-child(3){transition-delay:0.10s}
.offer-grid .reveal:nth-child(4){transition-delay:0.14s}
.offer-grid .reveal:nth-child(5){transition-delay:0.18s}
.offer-grid .reveal:nth-child(6){transition-delay:0.22s}
.results-grid .reveal:nth-child(2){transition-delay:0.08s}
.results-grid .reveal:nth-child(3){transition-delay:0.16s}
.results-grid .reveal:nth-child(4){transition-delay:0.24s}
.steps .reveal:nth-child(2){transition-delay:0.08s}
.steps .reveal:nth-child(3){transition-delay:0.16s}
.steps .reveal:nth-child(4){transition-delay:0.24s}
.ia-features-row .reveal:nth-child(2){transition-delay:0.06s}
.ia-features-row .reveal:nth-child(3){transition-delay:0.12s}
.ia-features-row .reveal:nth-child(4){transition-delay:0.18s}

/* ============ RESPONSIVE ============ */
@media (max-width: 1080px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-stage{height:520px}
  .ia-grid{grid-template-columns:1fr;gap:48px}
  .ia-chat{min-height:420px}
  .ohero-grid{grid-template-columns:1fr;gap:32px}
  .offer-grid{grid-template-columns:repeat(2,1fr)}
  .results-grid{grid-template-columns:repeat(2,1fr);border-top:0}
  .result-card{border-right:0;border-bottom:1px solid var(--line-3);padding:32px 0 24px}
  .result-card:nth-child(odd){border-right:1px solid var(--line-3);padding-right:24px}
  .result-card:nth-child(even){padding-left:24px}
  .result-card:nth-last-child(-n+2){border-bottom:0;padding-bottom:0}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps li:nth-child(2){border-right:0}
  .ft-grid{grid-template-columns:repeat(2,1fr);gap:32px}
}

@media (max-width: 720px){
  .nav-links{display:none}
  .nav{padding:12px var(--gutter)}
  .hero{padding:110px var(--gutter) 50px;min-height:auto}
  .hero h1{font-size:clamp(34px,8vw,46px)}
  .hero-stage{height:460px}
  .d-laptop{width:90%;right:-8%;top:8%}
  .d-phone{width:180px;bottom:8%;left:5%}
  .f-card-1{width:190px;top:0;right:-10px}
  .f-card-2{width:140px;bottom:12%;left:-5px}
  .f-card-3{width:160px;bottom:-5px;right:5%}
  .strip-card{flex-direction:column;text-align:center;padding:24px 20px}
  .offer-grid{grid-template-columns:1fr;gap:10px}
  .ocard-hero{padding:32px 24px}
  .ohero-features{grid-template-columns:1fr 1fr}
  .ia-features-row{grid-template-columns:1fr}
  .ia-chat{min-height:auto;padding:0}
  .chat-toast{right:0;top:-10px}
  .results-grid{grid-template-columns:1fr}
  .result-card{border-right:0 !important;border-bottom:1px solid var(--line-3) !important;padding:28px 0 !important}
  .result-card:last-child{border-bottom:0 !important}
  .steps{grid-template-columns:1fr}
  .steps li{border-right:0;border-bottom:1px solid var(--line);padding:24px 0}
  .cta-final{padding:80px var(--gutter)}
  .cta-note{gap:12px}
  .ft-grid{grid-template-columns:1fr;gap:28px}
  .ft-bottom{flex-direction:column;gap:6px}
}

/* ============ A11Y ============ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    transition-duration:0.01ms !important;
  }
  .reveal{opacity:1;transform:none}
  .pill-dot,.fc-fill,.status-dot,.ce-dot,
  .d-phone,.d-laptop,.f-card,.chat-toast,
  .typing-dots span,.marquee-track{animation:none}
  .cursor-glow{display:none}
}

/* ============ LEGAL PAGES ============ */
.legal-page{
  padding:120px var(--gutter) 80px;
  max-width:calc(820px + var(--gutter)*2);margin:0 auto;
}
.legal-page h1{
  font-size:clamp(34px,4.4vw,52px);line-height:1.02;margin-bottom:10px;
}
.legal-page .legal-eyebrow{
  font-size:11px;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--sage-d);
  margin-bottom:14px;display:block;
}
.legal-page .legal-updated{font-size:12.5px;color:var(--muted);font-style:italic;margin-bottom:44px}
.legal-page h2{
  font-size:clamp(22px,2.5vw,28px);margin:42px 0 14px;font-weight:400;
}
.legal-page{counter-reset:sec}
.legal-page h2::before{
  content:counter(sec,decimal-leading-zero) ". ";
  counter-increment:sec;color:var(--sage);font-style:italic;
}
.legal-page h3{font-family:var(--sans);font-size:15px;font-weight:700;margin:24px 0 8px}
.legal-page p,.legal-page li{font-size:15px;line-height:1.65;color:var(--ink-2);margin-bottom:10px}
.legal-page p strong{color:var(--ink);font-weight:600}
.legal-page ul{margin-bottom:14px}
.legal-page ul li{position:relative;padding-left:20px;margin-bottom:6px}
.legal-page ul li::before{content:"—";position:absolute;left:0;color:var(--sage)}
.legal-page a{color:var(--sage-d);border-bottom:1px solid var(--sage)}
.legal-back{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12.5px;color:var(--muted);
  margin-bottom:24px;text-decoration:none;border-bottom:0 !important;
}
.legal-back:hover{color:var(--ink)}
