/* ============================================================
   Zentric — Landing custom styles
   Extends Tailwind via utility overrides + brand-specific blocks.
   ============================================================ */

/* Design tokens — mirror of the portal's palette so the two feel
   like siblings without us having to import the portal's CSS. */
:root{
  --ink:#1b1f1a;
  --ink-soft:#3d4337;
  --paper:#f4efe6;
  --paper-2:#ece4d4;
  --paper-3:#e2d7c0;
  --card:#fbf8f1;
  --line:#d8cdb4;
  --line-soft:#e8dec7;
  --forest:#1f3a2e;
  --forest-2:#2a4d3d;
  --moss:#6b7a4f;
  --terracotta:#b9532e;
  --terracotta-soft:#d17a55;
  --ochre:#c9923b;
  --plum:#6b3b4a;
  --sky:#3d6b78;
  --whatsapp:#128c7e;
  --whatsapp-2:#25d366;
}

/* Hide the page until Tailwind CDN and custom CSS are both applied.
   Prevents the flash of unstyled content Tailwind CDN is notorious for. */
html.no-fouc body{visibility:hidden}
html.ready body{visibility:visible}

body{
  font-family:'Inter Tight',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(circle at 6% -4%, rgba(185,83,46,.08), transparent 40%),
    radial-gradient(circle at 110% 18%, rgba(31,58,46,.07), transparent 42%);
}

.serif{font-family:'Fraunces',ui-serif,serif;font-optical-sizing:auto;letter-spacing:-0.025em}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}

/* ─── Typography primitives ─────────────────────────── */
.eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--terracotta);font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--terracotta)}

.hero-h1{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(42px, 6vw, 76px);line-height:1.02;letter-spacing:-0.035em;
}
.hero-h1 em{font-style:italic;color:var(--forest)}
.hero-h1 .underline-accent{
  position:relative;white-space:nowrap;
}
.hero-h1 .underline-accent::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:0.08em;height:0.22em;
  background:var(--ochre);opacity:.45;z-index:-1;border-radius:1px;
}

h2.section-title{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(34px, 4.2vw, 52px);line-height:1.05;letter-spacing:-0.028em;
  margin:0;
}
h2.section-title em{font-style:italic;color:var(--terracotta)}
h2.section-title b{font-weight:500;color:var(--forest)}

/* ─── Buttons ───────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:10px;
  background:var(--ink);color:var(--paper);
  font:500 15px/1 'Inter Tight',sans-serif;letter-spacing:-.005em;
  transition:all .2s ease;cursor:pointer;border:0;
  box-shadow:0 1px 0 rgba(27,31,26,.04), 0 10px 22px -12px rgba(27,31,26,.35);
}
.btn-primary:hover{background:var(--forest);transform:translateY(-1px);box-shadow:0 18px 30px -12px rgba(31,58,46,.4)}
.btn-primary svg{width:17px;height:17px;stroke-width:1.8;transition:transform .2s}
.btn-primary:hover svg{transform:translateX(3px)}

.btn-accent{
  background:var(--terracotta);color:#fff;
}
.btn-accent:hover{background:#a24624}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:10px;
  background:transparent;color:var(--ink);border:1px solid var(--line);
  font:500 14.5px/1 'Inter Tight',sans-serif;cursor:pointer;transition:all .15s;
}
.btn-ghost:hover{border-color:var(--ink);background:var(--card)}

/* ─── Nav ───────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(244,239,230,.78);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  max-width:1180px;margin:0 auto;
  display:flex;align-items:center;gap:24px;
  padding:16px 28px;
}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--forest) 0%,var(--forest-2) 100%);
  display:grid;place-items:center;color:var(--paper);
  font-family:'Fraunces',serif;font-weight:500;font-size:22px;font-style:italic;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 2px 6px -2px rgba(27,31,26,.35);
  position:relative;
  letter-spacing:-.02em;
}
/* Editorial accent dot (top-right) */
.brand-mark::after{
  content:"";position:absolute;top:5px;right:5px;
  width:6px;height:6px;border-radius:50%;
  background:var(--terracotta);
  box-shadow:0 0 0 2px var(--paper);
}
.brand-name{font-family:'Fraunces',serif;font-size:23px;font-weight:500;letter-spacing:-.025em;line-height:1}
.brand-name em{font-style:italic;color:var(--terracotta);font-weight:400}

/* Subtle hover lift on the brand */
.brand{transition:transform .2s ease}
a.brand:hover{transform:translateY(-1px)}

/* Footer brand — slightly larger, more presence */
.foot-brand .brand-mark{width:42px;height:42px;font-size:24px;border-radius:11px}
.foot-brand .brand-name{font-size:26px}

.nav-links{display:flex;gap:30px;margin-left:auto;align-items:center}
.nav-links a{color:var(--ink-soft);font-weight:500;font-size:14px;transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  padding:9px 18px;border-radius:8px;background:var(--ink);color:var(--paper);
  font-size:13.5px;font-weight:500;transition:all .15s;
}
.nav-cta:hover{background:var(--forest)}

/* ─── Hero ──────────────────────────────────────────── */
.hero{
  max-width:1180px;margin:0 auto;padding:80px 28px 60px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
.hero-sub{
  font-size:18px;color:var(--ink-soft);line-height:1.55;max-width:52ch;
  margin:28px 0 36px;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-meta{
  margin-top:32px;display:flex;gap:28px;align-items:center;flex-wrap:wrap;
  padding-top:22px;border-top:1px dashed var(--line);
}
.hero-meta .stat{font-family:'Fraunces',serif;font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1}
.hero-meta .stat-label{font-size:12px;color:var(--ink-soft);margin-top:4px;letter-spacing:.02em}
.hero-meta > div{min-width:110px}

/* Mockup — inline SVG-heavy composition for performance */
.hero-visual{position:relative;min-height:520px;isolation:isolate}
.phone{
  position:relative;background:#1b1f1a;border-radius:38px;padding:10px;
  width:300px;box-shadow:0 40px 80px -30px rgba(27,31,26,.45),0 0 0 1px rgba(27,31,26,.9);
  margin:0 auto;
  transform:rotate(-3deg);
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
  z-index:1;
}
.phone:hover{transform:rotate(-1deg) translateY(-4px)}
/* Subtle floating animation on the phone */
@keyframes phoneFloat{
  0%,100%{transform:rotate(-3deg) translateY(0)}
  50%{transform:rotate(-3deg) translateY(-6px)}
}
.phone{animation:phoneFloat 5s ease-in-out infinite}
.phone:hover{animation-play-state:paused}

.phone-screen{
  background:#ece4d4;
  background-image:
    radial-gradient(rgba(31,58,46,.04) 1px, transparent 1px),
    radial-gradient(rgba(185,83,46,.03) 1px, transparent 1px);
  background-size:22px 22px, 33px 33px;
  border-radius:28px;overflow:hidden;height:560px;
  display:flex;flex-direction:column;
}
.phone-top{
  background:#128c7e;color:#fff;padding:14px 16px 10px;
  display:flex;align-items:center;gap:10px;
}
.phone-top .avatar-mock{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#c9923b,#b9532e);display:grid;place-items:center;font-weight:600;font-size:12px;color:#fff}
.phone-top b{font-size:14px;display:block}
.phone-top small{font-size:11px;opacity:.75}
.phone-msgs{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:8px;overflow:hidden}
.bubble{max-width:82%;padding:8px 12px;border-radius:10px;font-size:12.5px;line-height:1.35;box-shadow:0 1px 1px rgba(0,0,0,.06)}
.bubble.in{align-self:flex-start;background:#fff;border-top-left-radius:3px}
.bubble.ai{align-self:flex-end;background:#e4ecdf;border:1px solid #c9d6be;border-top-right-radius:3px;position:relative}
.bubble.ai::before{
  content:"IA";position:absolute;top:-7px;right:7px;
  font-size:9px;font-weight:700;letter-spacing:.1em;
  background:var(--forest);color:#fff;padding:1px 5px;border-radius:3px;
}
.bubble .t{display:block;font-size:9px;color:var(--ink-soft);margin-top:2px;text-align:right;font-variant-numeric:tabular-nums}

/* Typing indicator (three dots) */
.typing-bubble{
  align-self:flex-end;background:#e4ecdf;border:1px solid #c9d6be;border-top-right-radius:3px;
  padding:10px 14px;border-radius:10px;display:inline-flex;gap:4px;align-items:center;
}
.typing-bubble span{width:5px;height:5px;border-radius:50%;background:var(--forest);opacity:.4;animation:typingDot 1.2s ease-in-out infinite}
.typing-bubble span:nth-child(2){animation-delay:.15s}
.typing-bubble span:nth-child(3){animation-delay:.3s}
@keyframes typingDot{
  0%,60%,100%{opacity:.4;transform:translateY(0)}
  30%{opacity:1;transform:translateY(-3px)}
}

/* Calendar card floating next to the phone */
.cal-card{
  position:absolute;right:-20px;bottom:40px;
  width:260px;background:var(--card);border:1px solid var(--line-soft);
  border-radius:14px;padding:16px 18px;
  box-shadow:0 30px 60px -25px rgba(27,31,26,.35);
  transform:rotate(4deg);
  transition:transform .4s ease;
  z-index:2;
  animation:cardFloat 6s ease-in-out infinite;
  animation-delay:.8s;
}
@keyframes cardFloat{
  0%,100%{transform:rotate(4deg) translateY(0)}
  50%{transform:rotate(4deg) translateY(-5px)}
}
.cal-card:hover{transform:rotate(2deg) translateY(-3px);animation-play-state:paused}
.cal-card .cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.cal-card .cal-head b{color:var(--forest);font-weight:600}
.cal-card .cal-day{display:flex;gap:10px;padding:8px 10px;border-radius:8px;margin-bottom:6px;font-size:12px;align-items:center}
.cal-card .cal-day.new{background:#e0ead8;border-left:3px solid var(--forest);animation:fadeSlide .6s ease}
.cal-card .cal-day .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cal-card .cal-day b{font-weight:600}
.cal-card .cal-day small{color:var(--ink-soft);display:block;font-size:10.5px;margin-top:1px}
@keyframes fadeSlide{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:none}
}

/* Flash badge — FIX: must render ABOVE the phone (z-index:10) */
.flash-badge{
  position:absolute;left:-28px;top:30px;
  background:var(--ink);color:#fff;padding:8px 14px;border-radius:999px;
  font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 10px 24px -10px rgba(27,31,26,.5), 0 0 0 1px rgba(232,226,210,.1);
  transform:rotate(-6deg) translateY(-10px);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease, transform .45s cubic-bezier(.2,.8,.2,1);
  z-index:10;
}
.flash-badge.visible{
  opacity:1;
  transform:rotate(-6deg) translateY(0);
}
.flash-badge .ping{width:8px;height:8px;border-radius:50%;background:var(--whatsapp-2);box-shadow:0 0 0 0 rgba(37,211,102,.6);animation:ping 1.8s ease infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(37,211,102,.6)}70%{box-shadow:0 0 0 8px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* Bubble entrance animation — only applied to the newest message per step */
@keyframes bubbleIn{
  from{opacity:0;transform:translateY(8px) scale(.96)}
  to{opacity:1;transform:none}
}
.bubble.bubble-in{animation:bubbleIn .35s cubic-bezier(.2,.8,.2,1.1) both}

/* ─── Section framing ───────────────────────────────── */
section.block{max-width:1180px;margin:0 auto;padding:90px 28px}
section.block.tight{padding:60px 28px}

.section-head{max-width:720px;margin:0 auto 48px;text-align:center}
.section-head p{color:var(--ink-soft);margin:18px auto 0;max-width:54ch;font-size:16.5px;line-height:1.6}

/* ─── Ecosystem grid ────────────────────────────────── */
.eco-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.eco-card{
  background:var(--card);border:1px solid var(--line-soft);border-radius:14px;
  padding:26px 26px 28px;position:relative;overflow:hidden;
  transition:all .25s ease;
}
.eco-card:hover{border-color:var(--forest);transform:translateY(-3px);box-shadow:0 20px 40px -20px rgba(27,31,26,.25)}
.eco-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent,var(--forest)),transparent);
}
.eco-card.forest{--accent:var(--forest)}
.eco-card.terracotta{--accent:var(--terracotta)}
.eco-card.ochre{--accent:var(--ochre)}
.eco-card.sky{--accent:var(--sky)}
.eco-card.plum{--accent:var(--plum)}
.eco-card.moss{--accent:var(--moss)}
.eco-icon{
  width:48px;height:48px;border-radius:11px;margin-bottom:18px;
  display:grid;place-items:center;color:var(--accent,var(--forest));
  background:var(--paper-2);
}
.eco-card.terracotta .eco-icon{background:#f2dfd1;color:#7a3517}
.eco-card.ochre .eco-icon{background:#f1e3c3;color:#6e4f13}
.eco-card.sky .eco-icon{background:#dde3ea;color:var(--sky)}
.eco-card.plum .eco-icon{background:#ead9de;color:var(--plum)}
.eco-card.moss .eco-icon{background:#e0e5d3;color:var(--moss)}
.eco-icon svg{width:22px;height:22px;stroke-width:1.7}
.eco-card h3{font-family:'Fraunces',serif;font-weight:500;font-size:20px;letter-spacing:-.015em;margin:0 0 8px}
.eco-card p{color:var(--ink-soft);font-size:14px;line-height:1.55;margin:0}
.eco-badge{
  display:inline-block;margin-top:14px;font-size:10.5px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--accent,var(--forest));font-weight:600;
}

/* ─── DFY section (trust) ───────────────────────────── */
.dfy-section{
  background:var(--forest);color:#e8e2d2;
  padding:90px 0;position:relative;overflow:hidden;
}
.dfy-section::before{
  content:"";position:absolute;right:-100px;top:-100px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(201,146,59,.2),transparent 60%);
}
.dfy-inner{max-width:1180px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.dfy-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.dfy-grid h2{color:#fff;font-family:'Fraunces',serif;font-weight:400;font-size:clamp(32px,3.8vw,48px);letter-spacing:-.025em;line-height:1.08;margin:0 0 18px}
.dfy-grid h2 em{font-style:italic;color:var(--ochre)}
.dfy-grid > div > p{color:rgba(232,226,210,.7);font-size:16px;line-height:1.6}
.dfy-grid .eyebrow{color:var(--ochre)}
.dfy-grid .eyebrow::before{background:var(--ochre)}

.dfy-steps{display:flex;flex-direction:column;gap:14px}
.dfy-step{
  display:grid;grid-template-columns:auto 1fr;gap:18px;
  background:rgba(255,255,255,.04);border:1px solid rgba(232,226,210,.12);
  padding:18px 22px;border-radius:12px;backdrop-filter:blur(10px);
}
.dfy-num{
  width:36px;height:36px;border-radius:50%;
  background:var(--ochre);color:var(--forest);
  display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;font-size:16px;
  flex-shrink:0;
}
.dfy-step b{color:#fff;font-size:15px;font-weight:600;display:block;margin-bottom:4px}
.dfy-step p{color:rgba(232,226,210,.7);font-size:13.5px;line-height:1.5;margin:0}

/* ─── ROI callout ───────────────────────────────────── */
.roi-callout{
  background:linear-gradient(135deg,#f2dfd1 0%,#f1e3c3 100%);
  border-radius:18px;padding:56px 48px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;
}
.roi-callout::before{
  content:"€";position:absolute;right:-20px;bottom:-80px;font-size:400px;
  font-family:'Fraunces',serif;color:rgba(185,83,46,.08);line-height:1;font-style:italic;
}
.roi-callout h2{margin:0}
.roi-math{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:26px 28px;position:relative;z-index:2;
}
.roi-math .row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;font-size:14px;
}
.roi-math .row:not(:last-child){border-bottom:1px dashed var(--line-soft)}
.roi-math .row span{color:var(--ink-soft)}
.roi-math .row b{font-family:'Fraunces',serif;font-size:20px;font-weight:500;letter-spacing:-.015em}
.roi-math .total{background:var(--forest);color:#fff;margin:12px -28px -26px;padding:16px 28px;border-radius:0 0 14px 14px}
.roi-math .total span{color:rgba(255,255,255,.7)}
.roi-math .total b{color:var(--ochre);font-size:28px}

/* ─── Social proof strip ────────────────────────────── */
.proof-strip{
  background:var(--card);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  padding:32px 28px;
}
.proof-inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
}
.proof-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:8px 20px;
  position:relative;
  gap:6px;
}
.proof-item + .proof-item::before{
  content:"";
  position:absolute;
  left:0;
  top:20%;
  bottom:20%;
  width:1px;
  background:var(--line-soft);
}
.proof-stars{
  color:var(--ochre);
  letter-spacing:3px;
  font-size:13px;
  display:block;
}
.proof-title{
  color:var(--ink);
  font-weight:600;
  font-size:14.5px;
  line-height:1.2;
  display:block;
}
.proof-desc{
  color:var(--ink-soft);
  font-size:12.5px;
  line-height:1.4;
  display:block;
  max-width:30ch;
}

@media (max-width: 860px){
  .proof-inner{grid-template-columns:repeat(2, 1fr)}
  .proof-item + .proof-item::before{display:none}
  .proof-item:nth-child(3), .proof-item:nth-child(4){margin-top:18px;padding-top:18px;border-top:1px dashed var(--line-soft)}
  .proof-item:nth-child(3)::before, .proof-item:nth-child(4)::before{display:none}
}
@media (max-width: 520px){
  .proof-inner{grid-template-columns:1fr}
  .proof-item{padding:16px 20px}
  .proof-item + .proof-item{border-top:1px dashed var(--line-soft);margin-top:0}
  .proof-item:nth-child(3), .proof-item:nth-child(4){margin-top:0;padding-top:16px}
}

/* ─── Testimonial ──────────────────────────────────── */
.testimonial{
  max-width:860px;margin:0 auto;padding:0 28px;text-align:center;
}
.testimonial blockquote{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(24px, 2.6vw, 32px);line-height:1.35;letter-spacing:-.015em;
  margin:0;color:var(--ink);
}
.testimonial blockquote::before{
  content:"“";color:var(--ochre);font-size:80px;line-height:0;
  position:relative;top:28px;margin-right:6px;
}
.testimonial cite{
  display:block;margin-top:22px;font-style:normal;font-size:14px;color:var(--ink-soft);
}
.testimonial cite b{
  color:var(--forest);font-family:'Fraunces',serif;font-size:16px;
  font-weight:500;display:block;margin-bottom:2px;
}

/* ─── Final CTA ─────────────────────────────────────── */
.final-cta{
  background:var(--ink);color:#fff;border-radius:18px;
  padding:64px 48px;position:relative;overflow:hidden;text-align:center;
  margin:30px 28px 0;
}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 100%, rgba(185,83,46,.25), transparent 50%),
    radial-gradient(circle at 80% 0%,  rgba(201,146,59,.15), transparent 50%);
}
.final-cta h2{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(34px, 4.2vw, 52px);line-height:1.05;letter-spacing:-.025em;
  margin:0 0 16px;position:relative;z-index:2;
}
.final-cta h2 em{font-style:italic;color:var(--ochre)}
.final-cta p{color:rgba(255,255,255,.72);max-width:52ch;margin:0 auto 32px;position:relative;z-index:2;font-size:16px}
.final-cta .ctas{position:relative;z-index:2;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.final-cta .btn-primary{background:var(--paper);color:var(--ink);box-shadow:0 18px 30px -12px rgba(244,239,230,.3)}
.final-cta .btn-primary:hover{background:#fff;color:var(--forest)}
.final-cta .btn-ghost{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.85)}
.final-cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.05);color:#fff}

/* ─── Footer ────────────────────────────────────────── */
footer{
  padding:48px 28px 32px;max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  border-top:1px solid var(--line-soft);margin-top:80px;
}
footer .foot-brand p{color:var(--ink-soft);margin:14px 0 0;font-size:13px;line-height:1.55;max-width:32ch}
footer h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin:0 0 14px}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
footer ul a{color:var(--ink);font-size:13.5px;transition:color .15s}
footer ul a:hover{color:var(--terracotta)}
.foot-bottom{
  max-width:1180px;margin:22px auto 0;padding:22px 28px 40px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-size:12px;color:var(--ink-soft);
}

/* ─── Demo modal ────────────────────────────────────── */
.demo-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(27,31,26,.55);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  animation:fadeIn .25s ease;padding:24px;
}
.demo-modal.active{display:flex}

.demo-panel{
  background:var(--card);border-radius:18px;
  width:100%;max-width:480px;
  box-shadow:0 40px 80px -30px rgba(27,31,26,.5), 0 0 0 1px var(--line-soft);
  animation:demoIn .4s cubic-bezier(.2,.8,.2,1.05);
  overflow:hidden;
}
@keyframes demoIn{
  from{opacity:0;transform:scale(.94) translateY(14px)}
  to{opacity:1;transform:none}
}

.demo-head{
  padding:28px 30px 20px;
  background:linear-gradient(180deg, #e6efe5 0%, var(--card) 100%);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line-soft);
}
.demo-head::before{
  content:"";position:absolute;top:-40px;right:-40px;
  width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(185,83,46,.15),transparent 60%);
}
.demo-head .eyebrow{color:var(--terracotta);margin-bottom:10px;position:relative;z-index:2}
.demo-head h3{
  font-family:'Fraunces',serif;font-weight:400;font-size:26px;letter-spacing:-.02em;
  margin:0 0 6px;position:relative;z-index:2;
}
.demo-head h3 em{font-style:italic;color:var(--forest)}
.demo-head p{color:var(--ink-soft);font-size:13.5px;margin:0;position:relative;z-index:2;max-width:38ch}

.demo-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:8px;border:0;
  background:rgba(255,255,255,.7);color:var(--ink-soft);
  display:grid;place-items:center;cursor:pointer;transition:all .15s;z-index:3;
}
.demo-close:hover{background:#fff;color:var(--ink)}
.demo-close svg{width:16px;height:16px}

.demo-body{padding:22px 30px 26px}

.demo-field{margin-bottom:14px}
.demo-field label{
  display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin-bottom:6px;
}
.demo-field label .req{color:var(--terracotta);margin-left:3px}
.demo-field input,
.demo-field textarea,
.demo-field select{
  width:100%;padding:11px 14px;border:1px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink);
  font:400 14px 'Inter Tight',sans-serif;
  transition:all .15s;
}
.demo-field input:focus,
.demo-field textarea:focus,
.demo-field select:focus{
  outline:none;border-color:var(--forest);
  box-shadow:0 0 0 3px rgba(31,58,46,.08);
}
.demo-field textarea{min-height:72px;resize:vertical;font-family:inherit}

.demo-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.demo-privacy{
  margin-top:10px;font-size:12px;color:var(--ink-soft);
  padding:12px 14px;background:var(--paper);border-radius:10px;
  border:1px dashed var(--line);line-height:1.5;
}
.demo-privacy a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px}

.demo-submit{
  width:100%;justify-content:center;margin-top:16px;padding:14px;font-size:14.5px;
}
.demo-submit:disabled{opacity:.75;cursor:wait}
.spinner{
  width:18px;height:18px;border:2px solid rgba(244,239,230,.3);
  border-top-color:var(--paper);border-radius:50%;
  display:inline-block;animation:spin .7s linear infinite;vertical-align:middle;
}
@keyframes spin{to{transform:rotate(360deg)}}

.demo-alt{
  margin-top:14px;text-align:center;font-size:12.5px;color:var(--ink-soft);
}
.demo-alt a{color:var(--whatsapp);font-weight:600;text-decoration:underline;text-decoration-color:rgba(18,140,126,.35);text-underline-offset:3px}
.demo-alt a:hover{text-decoration-color:var(--whatsapp)}

/* ─── Responsive ────────────────────────────────────── */
@media (max-width: 980px){
  .hero{grid-template-columns:1fr;padding:60px 28px 40px}
  .hero-visual{min-height:auto;margin-top:20px}
  .eco-grid{grid-template-columns:repeat(2,1fr)}
  .dfy-grid{grid-template-columns:1fr;gap:40px}
  .roi-callout{grid-template-columns:1fr;padding:40px 32px}
  footer{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width: 640px){
  .nav-links{display:none}
  .nav-links.cta-only{display:flex}
  .eco-grid{grid-template-columns:1fr}
  footer{grid-template-columns:1fr}
  section.block{padding:60px 24px}
  .cal-card{position:relative;right:auto;bottom:auto;margin:-40px auto 0;transform:rotate(0);animation:none}
  .flash-badge{left:12px;top:12px;transform:rotate(0) translateY(-6px)}
  .flash-badge.visible{transform:rotate(0) translateY(0)}
  .phone{transform:rotate(0);animation:none}
  .final-cta{padding:48px 24px;margin:20px 16px 0}
  .demo-head{padding:24px 22px 16px}
  .demo-body{padding:18px 22px 22px}
  .demo-row{grid-template-columns:1fr}
}

/* ─── Reveal-on-scroll ────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}

/* Cards get a gentle tilt on hover for life */
.eco-card{transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .35s ease}
.eco-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(27,31,26,.2);border-color:var(--ink)}

/* Counter animation — applied via JS, just sets tabular-nums by default */
.count-up{font-variant-numeric:tabular-nums}

/* ROI bar animation */
.roi-bar{
  height:8px;border-radius:999px;background:var(--line-soft);overflow:hidden;
  margin-top:22px;position:relative;
}
.roi-bar::after{
  content:"";position:absolute;inset:0;width:0;
  background:linear-gradient(90deg, var(--forest), var(--terracotta));
  border-radius:999px;
  transition:width 1.6s cubic-bezier(.25,.1,.25,1);
}
.roi-bar.in::after{width:100%}

/* Gentle pulse on the primary CTA — subtle, not aggressive */
@keyframes ctaPulse{
  0%,100%{box-shadow:0 12px 28px -12px rgba(27,31,26,.45), 0 0 0 0 rgba(185,83,46,0)}
  50%{box-shadow:0 12px 28px -12px rgba(27,31,26,.45), 0 0 0 8px rgba(185,83,46,.12)}
}
.btn-primary.btn-accent{animation:ctaPulse 3.2s ease-in-out infinite}
.btn-primary.btn-accent:hover{animation-play-state:paused}

/* Section separator with editorial flourish */
.flourish{
  display:flex;align-items:center;justify-content:center;gap:14px;margin:40px 0 18px;
  color:var(--ochre);opacity:.6;
}
.flourish::before,.flourish::after{
  content:"";height:1px;width:80px;background:currentColor;
}
.flourish svg{width:14px;height:14px;opacity:.8}

/* Respect reduced-motion preference */
@media (prefers-reduced-motion:reduce){
  .phone, .cal-card, .flash-badge, .btn-primary.btn-accent{animation:none !important}
  .reveal{opacity:1;transform:none;transition:none}
  .roi-bar::after{transition:none;width:100%}
}

/* ─── Stat quote (reemplaza testimonio) ──────────────── */
.stat-quote{
  max-width:760px;margin:0 auto;text-align:center;
  padding:20px 20px 30px;
}
.stat-quote .big-stat{margin:14px 0 24px}
.stat-quote .stat-num{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(88px, 14vw, 156px);line-height:.9;letter-spacing:-.04em;
  color:var(--forest);
  background:linear-gradient(135deg,var(--forest) 40%,var(--terracotta));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  display:inline-block;font-variant-numeric:tabular-nums;
}
.stat-quote blockquote{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(22px,2.8vw,30px);line-height:1.25;letter-spacing:-.015em;
  margin:0 auto;max-width:26ch;color:var(--ink);
}
.stat-quote blockquote em{font-style:italic;color:var(--terracotta)}
.stat-quote cite{
  display:block;margin-top:18px;color:var(--ink-soft);
  font-style:normal;font-size:13.5px;letter-spacing:.01em;
}

/* ─── Globe / connection visualization ─────────────── */
.globe-section{
  background:var(--card);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  padding:80px 28px;
  overflow:hidden;
}
.globe-wrap{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.globe-text .eyebrow{margin-bottom:14px}
.globe-text h2{
  font-family:'Fraunces',serif;
  font-weight:400;
  font-size:clamp(28px, 3.5vw, 42px);
  line-height:1.1;
  letter-spacing:-.025em;
  margin:0 0 18px;
}
.globe-text h2 em{font-style:italic;color:var(--forest)}
.globe-text p{
  color:var(--ink-soft);
  font-size:15.5px;
  line-height:1.6;
  max-width:42ch;
  margin:0;
}
.globe-stats{
  display:grid;
  grid-template-columns:repeat(3, auto);
  gap:30px;
  margin-top:30px;
}
.globe-stats > div{line-height:1.2}
.globe-stats .num{
  font-family:'Fraunces',serif;
  font-weight:400;
  font-size:34px;
  letter-spacing:-.02em;
  color:var(--forest);
  font-variant-numeric:tabular-nums;
}
.globe-stats .lbl{
  font-size:11.5px;
  color:var(--ink-soft);
  margin-top:4px;
  letter-spacing:.03em;
}

.globe-viz{
  width:100%;
  max-width:500px;
  margin:0 auto;
  display:block;
}
.globe-svg{
  width:100%;
  height:auto;
  display:block;
  max-height:500px;
}

.globe-line{
  animation:lineDash 12s linear infinite;
}
@keyframes lineDash{
  to{stroke-dashoffset:-120}
}

/* SVG message bubbles — cycle in/out */
.msg-bubble{
  transform-origin:center;
  animation:svgMsgFloat 7.2s ease-in-out infinite;
  opacity:0;
}
@keyframes svgMsgFloat{
  0%, 8%, 100%{opacity:0;transform:translateY(6px)}
  18%, 70%{opacity:1;transform:translateY(0)}
  82%{opacity:0;transform:translateY(-4px)}
}

@media (max-width: 860px){
  .globe-wrap{grid-template-columns:1fr;gap:40px}
  .globe-stats{justify-content:center}
  .globe-viz{max-width:420px}
}

/* ─── Self-pay grid (8 ways Zentric pays itself back) ── */
.selfpay-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
  margin-top:50px;
}
@media (max-width: 1080px){.selfpay-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width: 560px){.selfpay-grid{grid-template-columns:1fr}}

.selfpay-card{
  background:var(--card);
  border:1px solid var(--line-soft);
  border-radius:16px;
  padding:24px 22px;
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .35s ease;
  position:relative;
  overflow:hidden;
}
.selfpay-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(185,83,46,.04));
  opacity:0;
  transition:opacity .35s;
  pointer-events:none;
}
.selfpay-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px -20px rgba(27,31,26,.18);
  border-color:var(--ink);
}
.selfpay-card:hover::before{opacity:1}

.selfpay-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:4px;
}
.selfpay-icon{
  width:42px;
  height:42px;
  border-radius:10px;
  display:grid;
  place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.15), 0 2px 6px -2px rgba(27,31,26,.35);
}
.selfpay-icon svg{width:20px;height:20px}
.selfpay-num{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;
  font-weight:500;
  color:var(--ink-soft);
  letter-spacing:.1em;
  padding-top:6px;
}

.selfpay-card h3{
  font-family:'Fraunces',serif;
  font-weight:500;
  font-size:18px;
  line-height:1.2;
  letter-spacing:-.015em;
  margin:0;
  color:var(--ink);
}
.selfpay-card p{
  color:var(--ink-soft);
  font-size:13.5px;
  line-height:1.5;
  margin:0;
  flex:1;
}

.selfpay-stat{
  margin-top:8px;
  padding-top:14px;
  border-top:1px dashed var(--line-soft);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.selfpay-stat .n{
  font-family:'Fraunces',serif;
  font-weight:400;
  font-size:32px;
  line-height:1;
  letter-spacing:-.025em;
  color:var(--forest);
  font-variant-numeric:tabular-nums;
}
.selfpay-stat .u{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:600;
  margin-top:2px;
}
.selfpay-stat .m{
  font-size:12px;
  color:var(--terracotta);
  font-weight:500;
  margin-top:6px;
}

/* Summary block at the bottom */
.selfpay-sum{
  margin-top:40px;
  background:linear-gradient(135deg, var(--forest) 0%, var(--forest-2) 100%);
  color:var(--paper);
  border-radius:20px;
  padding:40px 48px;
  position:relative;
  overflow:hidden;
}
.selfpay-sum::before{
  content:"";
  position:absolute;
  top:-40%;
  right:-10%;
  width:360px;
  height:360px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(185,83,46,.18), transparent 70%);
  pointer-events:none;
}
.selfpay-sum-inner{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:40px;
  align-items:center;
  position:relative;
  z-index:1;
}
.selfpay-sum h3{
  font-family:'Fraunces',serif;
  font-weight:400;
  font-size:clamp(28px, 3vw, 38px);
  line-height:1.1;
  letter-spacing:-.025em;
  margin:8px 0 14px;
  color:var(--paper);
}
.selfpay-sum h3 em{font-style:italic;color:var(--ochre)}
.selfpay-sum p{
  color:rgba(244,239,230,.85);
  font-size:15px;
  line-height:1.55;
  margin:0;
}
.selfpay-sum p b{color:var(--ochre);font-weight:600}

.selfpay-total{
  text-align:right;
  border-left:1px solid rgba(244,239,230,.15);
  padding-left:40px;
}
.selfpay-total-label{
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(244,239,230,.65);
  font-weight:600;
  margin-bottom:10px;
}
.selfpay-total-num{
  font-family:'Fraunces',serif;
  font-weight:300;
  font-size:clamp(54px, 7vw, 82px);
  line-height:1;
  letter-spacing:-.03em;
  color:var(--ochre);
  font-variant-numeric:tabular-nums;
}
.selfpay-total-footnote{
  font-size:11.5px;
  color:rgba(244,239,230,.55);
  margin-top:8px;
  font-style:italic;
}

@media (max-width: 860px){
  .selfpay-sum{padding:32px 28px}
  .selfpay-sum-inner{grid-template-columns:1fr;gap:24px}
  .selfpay-total{border-left:0;border-top:1px solid rgba(244,239,230,.15);padding-left:0;padding-top:24px;text-align:left}
}
