/* ============================================================
   SOPHIE AI · MEMBRESÍAS · DESIGN SYSTEM
   Dark Premium + Light Professional (semantic theming)
   ============================================================ */

/* ---------- THEME TOKENS ---------- */
:root,
[data-theme="dark"] {
  --page:      #060609;
  --section:   #0C0C10;
  --card:      #111115;
  --card-2:    #16161B;
  --card-soft: #0F0F13;
  --ink:       #F5F3EF;
  --ink-2:     #B8B4A8;
  --ink-3:     #6E6A60;
  --line:      rgba(255,255,255,.09);
  --line-2:    rgba(255,255,255,.14);

  --teal:   #0EA5B5;
  --teal-d: #0B7A84;
  --teal-l: #21C7D6;
  --teal-soft: rgba(14,165,181,.12);
  --teal-line: rgba(14,165,181,.30);

  --gold:    #C9A84C;
  --gold-l:  #E8C96A;
  --gold-xl: #F5E8C0;
  --gold-soft: rgba(201,168,76,.10);
  --gold-line: rgba(201,168,76,.38);

  --green:  #3CB371;
  --green-soft: rgba(60,179,113,.12);

  --glow-teal: rgba(14,165,181,.16);
  --glow-gold: rgba(201,168,76,.13);

  --nav-bg: rgba(8,8,11,.72);
  --hero-tint: linear-gradient(108deg,#060609 26%,rgba(6,6,9,.82) 56%,rgba(6,6,9,.45) 100%);
  --img-soft: rgba(255,255,255,.05);
  --shadow-card: 0 1px 0 rgba(255,255,255,.04) inset, 0 20px 50px -24px rgba(0,0,0,.8);
  --shadow-pop: 0 0 0 1px var(--gold-line), 0 24px 60px -22px var(--glow-gold);
  --grain-op: .045;
  --scheme: dark;
}

[data-theme="light"] {
  --page:      #ECF2F3;
  --section:   #FFFFFF;
  --card:      #FFFFFF;
  --card-2:    #F6FBFB;
  --card-soft: #F1F8F9;
  --ink:       #16242A;
  --ink-2:     #46606A;
  --ink-3:     #80979F;
  --line:      #DBE6E9;
  --line-2:    #C6D8DC;

  --teal:   #0B95A4;
  --teal-d: #0A6E78;
  --teal-l: #11B5C4;
  --teal-soft: rgba(11,149,164,.08);
  --teal-line: rgba(11,149,164,.26);

  --gold:    #A8842A;
  --gold-l:  #B89238;
  --gold-xl: #7E6324;
  --gold-soft: rgba(168,132,42,.08);
  --gold-line: rgba(168,132,42,.36);

  --green:  #138A52;
  --green-soft: rgba(19,138,82,.09);

  --glow-teal: rgba(11,149,164,.16);
  --glow-gold: rgba(168,132,42,.16);

  --nav-bg: rgba(255,255,255,.82);
  --hero-tint: linear-gradient(108deg,rgba(236,242,243,.97) 20%,rgba(236,242,243,.88) 50%,rgba(236,242,243,.55) 100%);
  --img-soft: rgba(0,0,0,.04);
  --shadow-card: 0 1px 2px rgba(20,40,50,.04), 0 18px 44px -30px rgba(20,40,50,.34);
  --shadow-pop: 0 0 0 1px var(--gold-line), 0 26px 60px -28px rgba(20,40,50,.28);
  --grain-op: 0;
  --scheme: light;

  /* premium charcoal accent (logo dark circle) — used in light for premium bands */
  --charcoal:  #1C2226;
  --charcoal-2:#232A2F;
}

/* charcoal token also defined for dark (already dark surfaces) */
[data-theme="dark"] { --charcoal:#0E0E12; --charcoal-2:#16161B; }

/* ---------- RESET ---------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Outfit',sans-serif;
  background:var(--page);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s ease, color .5s ease;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection { background:var(--teal); color:#fff; }

/* ---------- HELPERS ---------- */
.wrap { width:100%; max-width:1200px; margin:0 auto; padding:0 40px; }
.mono { font-family:'IBM Plex Mono',monospace; }
.display { font-family:'Sora',sans-serif; letter-spacing:-.02em; }

.eyebrow {
  font-family:'IBM Plex Mono',monospace;
  font-size:.72rem; font-weight:500; letter-spacing:.28em; text-transform:uppercase;
  color:var(--teal);
  display:inline-flex; align-items:center; gap:11px;
}
.eyebrow::before { content:''; width:22px; height:1px; background:var(--teal); opacity:.7; }

h1,h2,h3 { font-family:'Sora',sans-serif; font-weight:700; letter-spacing:-.02em; line-height:1.08; }

.sec { position:relative; padding:120px 0; }
.sec-head { max-width:760px; margin-bottom:56px; }
.sec-head h2 { font-size:clamp(2rem,4.2vw,3.1rem); font-weight:800; margin:18px 0 16px; }
.sec-head p { font-size:1.12rem; color:var(--ink-2); font-weight:300; max-width:640px; }

/* ---------- ATMOSPHERICS ---------- */
.grain {
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:var(--grain-op);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.glow {
  position:absolute; border-radius:50%; pointer-events:none; z-index:0;
  filter:blur(8px);
}

/* ---------- PROGRESS BAR ---------- */
.progress {
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg,var(--teal-d),var(--teal),var(--teal-l));
  z-index:10000; transition:width .12s linear;
}

/* ---------- NAV ---------- */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:9000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px;
  transition:padding .3s ease, background .3s ease, border-color .3s ease, backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled {
  background:var(--nav-bg);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);
  padding:13px 40px;
}
.brand { display:flex; align-items:center; gap:12px; }
.brand img { width:38px; height:38px; object-fit:contain; }
.brand .bt { display:flex; flex-direction:column; line-height:1.05; }
.brand .bt .n1 { font-family:'Sora',sans-serif; font-weight:700; font-size:1.04rem; color:var(--ink); }
.brand .bt .n1 b { color:var(--teal); font-weight:700; }
.brand .bt .n2 {
  font-family:'IBM Plex Mono',monospace; font-size:.54rem; letter-spacing:.32em;
  text-transform:uppercase; color:var(--ink-3); margin-top:3px;
}
.nav-mid { display:flex; align-items:center; gap:34px; }
.nav-mid a {
  font-size:.92rem; color:var(--ink-2); font-weight:400;
  position:relative; transition:color .2s;
}
.nav-mid a:hover { color:var(--ink); }
.nav-mid a::after {
  content:''; position:absolute; left:0; bottom:-6px; height:1.5px; width:0;
  background:var(--teal); transition:width .25s cubic-bezier(.2,0,0,1);
}
.nav-mid a:hover::after { width:100%; }
.nav-right { display:flex; align-items:center; gap:14px; }

.theme-toggle {
  width:42px; height:42px; border-radius:50%;
  border:1.5px solid var(--line-2);
  display:grid; place-items:center;
  color:var(--ink-2);
  transition:all .25s cubic-bezier(.2,0,0,1);
}
.theme-toggle:hover { color:var(--teal); border-color:var(--teal-line); transform:rotate(18deg); }
.theme-toggle svg { width:18px; height:18px; }
.theme-toggle .ic-sun { display:none; }
[data-theme="light"] .theme-toggle .ic-sun { display:block; }
[data-theme="light"] .theme-toggle .ic-moon { display:none; }

.btn-nav {
  padding:11px 22px; border-radius:100px;
  font-size:.9rem; font-weight:600;
  background:linear-gradient(135deg,var(--teal-d),var(--teal));
  color:#fff;
  box-shadow:0 8px 24px -10px var(--glow-teal);
  transition:transform .2s cubic-bezier(.2,0,0,1), box-shadow .2s;
}
.btn-nav:hover { transform:translateY(-2px); box-shadow:0 14px 30px -10px var(--glow-teal); }

/* ---------- BUTTONS ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight:600; font-size:1rem; border-radius:100px;
  padding:16px 30px; position:relative; overflow:hidden;
  transition:transform .2s cubic-bezier(.2,0,0,1), box-shadow .25s, background .25s, color .25s;
}
.btn:active { transform:scale(.98); }
.btn-teal { background:linear-gradient(135deg,var(--teal-d),var(--teal),var(--teal-l)); color:#fff; box-shadow:0 14px 34px -14px var(--glow-teal); }
.btn-teal:hover { transform:translateY(-2px); box-shadow:0 20px 44px -14px var(--glow-teal); }
.btn-gold { background:linear-gradient(135deg,var(--gold-l),var(--gold),var(--gold-xl)); color:#0c0c0c; box-shadow:0 14px 34px -14px var(--glow-gold); }
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 20px 44px -14px var(--glow-gold); }
.btn-ghost-gold { background:transparent; color:var(--gold-l); border:1.5px solid var(--gold-line); }
.btn-ghost-gold:hover { background:var(--gold); border-color:var(--gold); color:#0c0c0c; transform:translateY(-2px); }
.btn-ghost-teal { background:transparent; color:var(--teal); border:1.5px solid var(--teal-line); }
.btn-ghost-teal:hover { background:var(--teal); border-color:var(--teal); color:#fff; transform:translateY(-2px); }
.btn-white { background:#fff; color:#0a2a30; box-shadow:0 14px 34px -16px rgba(0,0,0,.5); }
.btn-white:hover { transform:translateY(-2px); }
.btn-outline-white { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.5); }
.btn-outline-white:hover { background:rgba(255,255,255,.14); border-color:#fff; transform:translateY(-2px); }
.btn-full { width:100%; }

/* ---------- HERO ---------- */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:110px; }
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-bg::after { content:''; position:absolute; inset:0; background:var(--hero-tint); }
.hero .wrap { position:relative; z-index:2; }
.hero-inner { max-width:840px; }

.hero-pill {
  display:inline-flex; align-items:center; gap:9px;
  padding:8px 16px; border-radius:100px;
  background:var(--teal-soft); border:1px solid var(--teal-line);
  font-family:'IBM Plex Mono',monospace; font-size:.68rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--teal); margin-bottom:30px;
}
.hero-pill .dot { width:7px; height:7px; border-radius:50%; background:var(--teal-l); box-shadow:0 0 0 0 var(--teal-l); animation:pulse 2.4s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(33,199,214,.5);} 70%{box-shadow:0 0 0 9px rgba(33,199,214,0);} 100%{box-shadow:0 0 0 0 rgba(33,199,214,0);} }

.hero h1 { font-size:clamp(2.7rem,6.6vw,5.4rem); font-weight:800; margin-bottom:24px; }
.hero h1 em { font-style:normal; background:linear-gradient(120deg,var(--teal-l),var(--teal)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.hero-sub { font-size:clamp(1.1rem,1.7vw,1.4rem); color:var(--ink-2); font-weight:300; max-width:610px; margin-bottom:34px; }

.hero-pills { display:flex; flex-wrap:wrap; gap:11px; margin-bottom:56px; }
.hp {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; border-radius:100px; font-size:.9rem; font-weight:500;
  border:1.5px solid var(--line-2); color:var(--ink-2);
  transition:all .2s cubic-bezier(.2,0,0,1); cursor:pointer;
}
.hp:hover { color:var(--ink); border-color:var(--teal-line); transform:translateY(-2px); }
.hp.is-star { background:linear-gradient(135deg,var(--gold-l),var(--gold)); color:#0c0c0c; border-color:transparent; font-weight:600; }
.hp.is-star:hover { color:#0c0c0c; }
.hp small { font-family:'IBM Plex Mono',monospace; font-size:.72rem; opacity:.7; }

/* stat strip */
.stats {
  display:grid; grid-template-columns:repeat(4,1fr);
  background:var(--card); border:1px solid var(--line); border-radius:22px;
  overflow:hidden; box-shadow:var(--shadow-card); max-width:760px;
}
.stat { padding:26px 28px; position:relative; }
.stat + .stat::before { content:''; position:absolute; left:0; top:22%; height:56%; width:1px; background:var(--line); }
.stat .sv { font-family:'Sora',sans-serif; font-weight:800; font-size:1.95rem; color:var(--ink); letter-spacing:-.03em; }
.stat .sv b { color:var(--teal); }
.stat .sl { font-size:.82rem; color:var(--ink-3); margin-top:3px; font-weight:400; }

/* ---------- ECOSYSTEM ---------- */
.eco { background:var(--section); }
.eco-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:24px; overflow:hidden;
}
.eco-card {
  background:var(--card); padding:34px 30px; position:relative;
  transition:background .3s ease;
}
.eco-card:hover { background:var(--card-2); }
.eco-card .ec-num {
  position:absolute; top:24px; right:26px;
  font-family:'IBM Plex Mono',monospace; font-size:.72rem; letter-spacing:.1em;
  color:var(--ink-3);
}
.eco-ic {
  width:52px; height:52px; border-radius:15px;
  display:grid; place-items:center; margin-bottom:22px;
  background:var(--teal-soft); border:1.5px solid var(--teal-line);
  color:var(--teal); transition:all .3s ease;
}
.eco-card:hover .eco-ic { background:var(--teal); color:#fff; transform:translateY(-3px); }
.eco-ic svg { width:24px; height:24px; }
.eco-card h3 { font-size:1.18rem; font-weight:700; margin-bottom:9px; }
.eco-card p { font-size:.95rem; color:var(--ink-2); font-weight:300; line-height:1.55; }

/* ---------- PRICING ---------- */
.pricing { position:relative; }
.toggle-wrap { display:flex; justify-content:center; margin-bottom:46px; }
.toggle {
  display:inline-flex; gap:5px; padding:7px;
  background:var(--card); border:1.5px solid var(--line-2); border-radius:20px;
  box-shadow:var(--shadow-card); position:relative; flex-wrap:wrap; justify-content:center;
}
.tg {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 20px; border-radius:14px;
  font-family:'IBM Plex Mono',monospace; font-size:.74rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-3); font-weight:500;
  transition:color .3s cubic-bezier(.2,0,0,1), background .3s; white-space:nowrap;
}
.tg:hover { color:var(--ink-2); }
.tg .tg-badge {
  font-size:.6rem; padding:3px 8px; border-radius:100px;
  background:var(--line); color:var(--ink-2); letter-spacing:.05em;
}
.tg.active { color:#fff; }
.tg[data-plan="smartdoc"].active { background:linear-gradient(135deg,var(--teal-d),var(--teal)); }
.tg[data-plan="g6"].active { background:linear-gradient(135deg,var(--gold-xl),var(--gold)); color:#0c0c0c; }
.tg[data-plan="g12"].active { background:linear-gradient(135deg,var(--gold-l),var(--gold),var(--gold-xl)); color:#0c0c0c; box-shadow:0 8px 22px -10px var(--glow-gold); }
.tg[data-plan="self"].active { background:linear-gradient(135deg,#E9EEF0,#C5D2D6); color:#15242c; }
.tg.active .tg-badge { background:rgba(0,0,0,.18); color:inherit; }
.tg[data-plan="smartdoc"].active .tg-badge { background:rgba(255,255,255,.22); color:#fff; }

/* panels */
.panels { position:relative; }
.panel { display:none; }
.panel.active { display:block; animation:panelIn .5s cubic-bezier(.2,0,0,1); }
@keyframes panelIn { from{opacity:0; transform:translateY(16px);} to{opacity:1; transform:translateY(0);} }

.plan {
  display:grid; grid-template-columns:42% 58%;
  background:var(--card); border:1.5px solid var(--line-2);
  border-radius:28px; overflow:hidden; box-shadow:var(--shadow-card);
  position:relative;
}
.plan::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; z-index:3; }
.plan[data-accent="teal"]::before { background:linear-gradient(90deg,var(--teal-d),var(--teal),var(--teal-l)); }
.plan[data-accent="gold"]::before { background:linear-gradient(90deg,var(--gold-xl),var(--gold),var(--gold-l)); }
.plan[data-accent="silver"]::before { background:linear-gradient(90deg,#9fb0b5,#dce5e8,#9fb0b5); }
.plan.featured { border:1.5px solid var(--gold-line); box-shadow:var(--shadow-pop); }
.plan.featured::before { background:linear-gradient(90deg,var(--gold-l),var(--gold)); height:4px; }

.plan-left { padding:44px 40px; position:relative; }
.plan-badges { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:24px; }
.pbadge {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'IBM Plex Mono',monospace; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase;
  padding:7px 13px; border-radius:100px; font-weight:500;
}
.pbadge.teal { background:var(--teal-soft); color:var(--teal); border:1px solid var(--teal-line); }
.pbadge.gold { background:var(--gold-soft); color:var(--gold-l); border:1px solid var(--gold-line); }
.pbadge.gold-fill { background:linear-gradient(135deg,var(--gold-l),var(--gold)); color:#0c0c0c; }
.pbadge.green { background:var(--green-soft); color:var(--green); border:1px solid rgba(60,179,113,.3); }
.pbadge.silver { background:rgba(220,229,232,.1); color:var(--ink-2); border:1px solid var(--line-2); }

.plan-tag { font-family:'IBM Plex Mono',monospace; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px; }
.price { display:flex; align-items:baseline; gap:6px; margin-bottom:6px; }
.price .cur { font-family:'Sora',sans-serif; font-weight:700; font-size:1.6rem; color:var(--ink-2); }
.price .amt { font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(3.4rem,6vw,4.8rem); line-height:.92; letter-spacing:-.04em; }
.plan[data-accent="teal"] .price .amt { color:var(--teal); }
.plan[data-accent="gold"] .price .amt { color:var(--ink); }
.plan.featured .price .amt { color:var(--gold-l); }
.plan[data-accent="silver"] .price .amt { color:var(--ink); }
.price-period { font-size:.92rem; color:var(--ink-3); margin-bottom:18px; }
.monthly-chip {
  display:inline-block; font-size:.85rem; font-weight:500;
  padding:9px 15px; border-radius:11px; margin-bottom:22px;
  background:var(--teal-soft); color:var(--teal); border:1px solid var(--teal-line);
}
.plan[data-accent="gold"] .monthly-chip,
.plan.featured .monthly-chip { background:var(--gold-soft); color:var(--gold-l); border-color:var(--gold-line); }
.plan[data-accent="silver"] .monthly-chip { background:rgba(220,229,232,.08); color:var(--ink-2); border-color:var(--line-2); }

.plan-tagline { font-family:'Sora',sans-serif; font-size:1.32rem; font-weight:600; line-height:1.3; margin-bottom:24px; color:var(--ink); }

.roi {
  border:1.5px solid var(--line); border-radius:18px; padding:20px 22px;
  background:var(--card-soft); margin-bottom:26px;
}
.plan.featured .roi { background:var(--gold-soft); border-color:var(--gold-line); }
.roi .roi-l { font-family:'IBM Plex Mono',monospace; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); margin-bottom:9px; }
.plan[data-accent="gold"] .roi .roi-l, .plan.featured .roi .roi-l, .plan[data-accent="silver"] .roi .roi-l { color:var(--gold-l); }
.roi p { font-size:.92rem; color:var(--ink-2); line-height:1.6; font-weight:300; }
.roi p b { color:var(--ink); font-weight:600; }

.plan-cta { margin-bottom:14px; }
.trust-row {
  font-family:'IBM Plex Mono',monospace; font-size:.64rem; letter-spacing:.04em;
  color:var(--ink-3); display:flex; flex-wrap:wrap; gap:6px 14px; line-height:1.5;
}
.trust-row span { display:inline-flex; align-items:center; gap:6px; }
.trust-row span::before { content:'·'; color:var(--teal); font-weight:700; }

/* right column */
.plan-right { padding:44px 40px; background:var(--card-soft); border-left:1px solid var(--line); }
.feat-head { font-family:'IBM Plex Mono',monospace; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-bottom:22px; }
.feat-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px 22px; margin-bottom:28px; }
.feat { display:flex; align-items:flex-start; gap:10px; font-size:.92rem; color:var(--ink-2); line-height:1.4; }
.feat .fk {
  flex-shrink:0; width:19px; height:19px; border-radius:6px; margin-top:1px;
  display:grid; place-items:center; font-size:.7rem;
}
.feat.yes .fk { background:var(--teal-soft); color:var(--teal); }
.feat.yes-gold .fk { background:var(--gold-soft); color:var(--gold-l); }
.feat.yes-gold { color:var(--ink); }
.feat.no { color:var(--ink-3); }
.feat.no .fk { background:var(--line); color:var(--ink-3); }
.feat.hi { color:var(--ink); font-weight:600; }
.feat.hi .fk { background:var(--green-soft); color:var(--green); }
.feat b { font-weight:600; color:var(--ink); }

.vs-strip { display:flex; flex-wrap:wrap; gap:10px; padding-top:24px; border-top:1px solid var(--line); }
.vs {
  font-family:'IBM Plex Mono',monospace; font-size:.68rem; letter-spacing:.05em;
  padding:8px 13px; border-radius:9px; background:var(--card); border:1px solid var(--line);
  color:var(--ink-2); display:inline-flex; align-items:center; gap:7px;
}
.vs.good { color:var(--teal); border-color:var(--teal-line); }
.vs.gold { color:var(--gold-l); border-color:var(--gold-line); }
.vs.bad { color:var(--ink-3); text-decoration:line-through; opacity:.7; }

/* ---------- COMPARISON TABLE ---------- */
.compare { background:var(--section); }
.table-card { border:1.5px solid var(--line-2); border-radius:22px; overflow:hidden; box-shadow:var(--shadow-card); }
.table-scroll { overflow-x:auto; }
table.cmp { width:100%; border-collapse:collapse; min-width:760px; }
table.cmp thead th {
  position:sticky; top:0;
  background:var(--card); padding:22px 18px; text-align:left; vertical-align:bottom;
  border-bottom:1px solid var(--line-2);
}
table.cmp thead th .th-name { font-family:'Sora',sans-serif; font-weight:700; font-size:1.02rem; }
table.cmp thead th .th-price { font-family:'IBM Plex Mono',monospace; font-size:.74rem; color:var(--ink-3); margin-top:3px; }
table.cmp thead th.feat-col { width:30%; }
table.cmp thead th.col-12 { background:var(--gold-soft); }
table.cmp thead th.col-12 .th-name { color:var(--gold-l); }
table.cmp td { padding:14px 18px; border-bottom:1px solid var(--line); font-size:.9rem; color:var(--ink-2); text-align:center; }
table.cmp td:first-child { text-align:left; color:var(--ink); font-weight:500; }
table.cmp td.col-12 { background:var(--gold-soft); }
table.cmp tr.cat td {
  background:var(--teal-soft); font-family:'IBM Plex Mono',monospace;
  font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--teal);
  font-weight:500; text-align:left; padding:11px 18px;
}
table.cmp tbody tr:not(.cat):hover td { background:var(--card-2); }
table.cmp tbody tr:not(.cat):hover td.col-12 { background:var(--gold-soft); }
.ck { color:var(--teal); font-weight:700; }
.ck.gold { color:var(--gold-l); }
.ck.no { color:var(--ink-3); }
.cval { font-family:'IBM Plex Mono',monospace; font-size:.82rem; color:var(--ink); }

/* ---------- FINAL CTA ---------- */
.final { padding:120px 0; }
.cta-card {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,var(--teal-d),var(--teal) 55%,var(--teal-l));
  border-radius:32px; padding:80px 60px; text-align:center;
  box-shadow:0 30px 80px -30px var(--glow-teal);
}
.cta-card::before {
  content:''; position:absolute; width:520px; height:520px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 65%);
  top:-220px; right:-120px; pointer-events:none;
}
.cta-card .eyebrow { color:rgba(255,255,255,.85); }
.cta-card .eyebrow::before { background:rgba(255,255,255,.85); }
.cta-card h2 { font-size:clamp(2.2rem,4.6vw,3.6rem); font-weight:800; color:#fff; margin:20px 0 18px; position:relative; z-index:2; }
.cta-card .cta-sub { font-size:1.2rem; color:rgba(255,255,255,.88); font-weight:300; max-width:560px; margin:0 auto 36px; position:relative; z-index:2; }
.cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:34px; position:relative; z-index:2; }
.cta-trust { font-family:'IBM Plex Mono',monospace; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.7); position:relative; z-index:2; }
.cta-quote { margin-top:48px; font-family:'Sora',sans-serif; font-style:italic; font-size:1.4rem; color:var(--ink-2); font-weight:300; text-align:center; max-width:600px; margin-left:auto; margin-right:auto; }
.cta-quote b { color:var(--teal); font-style:normal; font-weight:600; }

/* ---------- PAYMENT METHODS ---------- */
.pay { padding-top:0; }
.pay-head { text-align:center; margin-bottom:30px; }
.pay-head .eyebrow { justify-content:center; }
.pay-head h3 { font-size:1.5rem; font-weight:700; margin-top:14px; }
.pay-head p { color:var(--ink-2); font-weight:300; margin-top:8px; }
.pay-grid { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; max-width:840px; margin:0 auto; }
.pay-chip {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 20px; border-radius:13px;
  background:var(--card); border:1.5px solid var(--line); color:var(--ink-2);
  font-size:.92rem; font-weight:500; box-shadow:var(--shadow-card);
  transition:transform .2s, border-color .2s;
}
.pay-chip:hover { transform:translateY(-2px); border-color:var(--teal-line); }
.pay-chip svg { width:20px; height:20px; color:var(--teal); }

/* ---------- FOOTER ---------- */
.footer { background:var(--section); border-top:1px solid var(--line); padding:64px 0 40px; }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1.05fr 1.35fr 1.2fr; gap:34px; margin-bottom:46px; align-items:start; }
.footer-brand { max-width:300px; }
.footer-brand img { width:54px; height:54px; border-radius:50%; margin-bottom:18px; }
.footer-brand p { font-size:.9rem; color:var(--ink-2); font-weight:300; }
.footer-rate { display:flex; align-items:center; gap:9px; margin-top:16px; }
.footer-rate .fr-stars { color:#FFC857; font-size:.85rem; letter-spacing:1.5px; }
.footer-rate .fr-tx { font-size:.76rem; color:rgba(245,243,239,.55); }
.footer-rate .fr-tx b { color:rgba(245,243,239,.85); font-weight:600; }
.footer-cols { display:contents; }
@media (max-width:1024px){ .footer-top{ grid-template-columns:1fr 1fr 1fr; row-gap:38px; } .footer-brand{ grid-column:1 / -1; max-width:none; } }
@media (max-width:600px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:380px){ .footer-top{ grid-template-columns:1fr; } }
.footer-cols { display:flex; gap:64px; flex-wrap:wrap; }
.fcol h4 { font-family:'IBM Plex Mono',monospace; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-bottom:16px; font-weight:500; }
.fcol a { display:block; font-size:.92rem; color:var(--ink-2); margin-bottom:10px; transition:color .2s; }
.fcol a:hover { color:var(--teal); }
.footer-bottom { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-top:28px; border-top:1px solid var(--line); }
.footer-bottom p { font-size:.82rem; color:var(--ink-3); }
.footer-bottom .mono { font-family:'IBM Plex Mono',monospace; letter-spacing:.05em; }

/* ---------- REVEAL ---------- */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,0,0,1), transform .7s cubic-bezier(.2,0,0,1); }
.reveal.visible { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) { .reveal { opacity:1; transform:none; transition:none; } }

/* ---------- RESPONSIVE ---------- */
@media (max-width:1080px) {
  .eco-grid { grid-template-columns:repeat(2,1fr); }
  .plan { grid-template-columns:1fr; }
  .plan-right { border-left:none; border-top:1px solid var(--line); }
}
@media (max-width:860px) {
  .nav-mid { display:none; }
  .sec { padding:88px 0; }
  .final { padding:88px 0; }
  .cta-card { padding:56px 28px; }
}
@media (max-width:680px) {
  .wrap { padding:0 22px; }
  .nav { padding:14px 22px; }
  .nav.scrolled { padding:11px 22px; }
  .stats { grid-template-columns:repeat(2,1fr); }
  .stat + .stat:nth-child(3)::before { display:none; }
  .feat-grid { grid-template-columns:1fr; }
  .plan-left, .plan-right { padding:34px 26px; }
  .eco-card { padding:28px 24px; }
  .toggle { width:100%; }
  .tg { flex:1; justify-content:center; padding:11px 12px; }
}
@media (max-width:460px) {
  .eco-grid { grid-template-columns:1fr; }
  .brand .bt .n2 { display:none; }
  .hero-pills .hp small { display:none; }
}

/* ============================================================
   V2 · PREMIUM ADDITIONS
   ============================================================ */

/* ---------- HERO RATING (inline social proof) ---------- */
.hero-rate { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:34px; }
.hero-rate .avatars { display:flex; }
.hero-rate .avatars span {
  width:38px; height:38px; border-radius:50%; border:2px solid var(--page);
  margin-left:-12px; background-size:cover; background-position:center;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
}
.hero-rate .avatars span:first-child { margin-left:0; }
.hero-rate .rate-txt { display:flex; flex-direction:column; line-height:1.25; }
.hero-rate .stars { color:#FFC857; font-size:.95rem; letter-spacing:1px; }
.hero-rate .rate-sub { font-size:.86rem; color:var(--ink-2); }
.hero-rate .rate-sub b { color:var(--ink); font-weight:600; }

/* ---------- TRUST BAR ---------- */
.trustbar { border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--section); }
.trustbar .wrap { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; padding-top:26px; padding-bottom:26px; }
.trust-item { display:flex; align-items:center; gap:12px; }
.trust-item .ti-ic { width:40px; height:40px; border-radius:11px; display:grid; place-items:center; background:var(--teal-soft); border:1px solid var(--teal-line); color:var(--teal); flex-shrink:0; }
.trust-item .ti-ic svg { width:20px; height:20px; }
.trust-item .ti-v { font-family:'Sora',sans-serif; font-weight:700; font-size:1.15rem; color:var(--ink); line-height:1.1; }
.trust-item .ti-l { font-size:.78rem; color:var(--ink-3); }
.trust-sep { width:1px; height:40px; background:var(--line); }
@media (max-width:900px){ .trust-sep{display:none;} .trustbar .wrap{justify-content:flex-start; gap:20px 32px;} }

/* ---------- VSL / VIDEO (cinema dark in both themes) ---------- */
.vsl { background:#070709; position:relative; overflow:hidden; }
[data-theme="light"] .vsl { background:#11161A; }
.vsl::before { content:''; position:absolute; width:680px; height:680px; border-radius:50%; background:radial-gradient(circle,rgba(14,165,181,.18),transparent 64%); top:-260px; left:50%; transform:translateX(-50%); pointer-events:none; }
.vsl .sec-head { text-align:center; margin-left:auto; margin-right:auto; position:relative; z-index:2; }
.vsl .sec-head h2 { color:#F5F3EF; }
.vsl .sec-head p { color:rgba(245,243,239,.6); margin-left:auto; margin-right:auto; }
.vsl .eyebrow { justify-content:center; color:var(--teal-l); }
.vsl .eyebrow::before { background:var(--teal-l); }
.video-frame {
  position:relative; z-index:2; max-width:920px; margin:0 auto;
  aspect-ratio:16/9; border-radius:24px; overflow:hidden;
  border:1.5px solid rgba(255,255,255,.12);
  box-shadow:0 40px 100px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(14,165,181,.1);
  background:linear-gradient(135deg,#0d1418,#0a0d10);
  cursor:pointer;
}
.video-frame .vf-poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.55; transition:opacity .4s, transform .6s cubic-bezier(.2,0,0,1); }
.video-frame:hover .vf-poster { opacity:.7; transform:scale(1.04); }
.video-frame .vf-overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(7,7,9,.2),rgba(7,7,9,.75)); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; }
.vf-play { width:84px; height:84px; border-radius:50%; background:rgba(255,255,255,.95); display:grid; place-items:center; box-shadow:0 0 0 0 rgba(255,255,255,.4); animation:playPulse 2.6s infinite; transition:transform .25s cubic-bezier(.2,0,0,1); }
.video-frame:hover .vf-play { transform:scale(1.08); }
.vf-play svg { width:30px; height:30px; margin-left:4px; color:#0b1416; }
@keyframes playPulse { 0%{box-shadow:0 0 0 0 rgba(255,255,255,.35);} 70%{box-shadow:0 0 0 22px rgba(255,255,255,0);} 100%{box-shadow:0 0 0 0 rgba(255,255,255,0);} }
.vf-label { font-family:'IBM Plex Mono',monospace; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; }
.vf-dur { position:absolute; bottom:16px; right:18px; font-family:'IBM Plex Mono',monospace; font-size:.74rem; color:#fff; background:rgba(0,0,0,.55); padding:5px 11px; border-radius:8px; }
.vsl-note { text-align:center; margin-top:24px; position:relative; z-index:2; font-family:'IBM Plex Mono',monospace; font-size:.72rem; letter-spacing:.1em; color:rgba(245,243,239,.4); }
.vsl-note code { background:rgba(255,255,255,.08); padding:3px 8px; border-radius:5px; color:var(--teal-l); }

/* video modal */
.vmodal { position:fixed; inset:0; z-index:11000; background:rgba(4,4,6,.92); backdrop-filter:blur(8px); display:none; align-items:center; justify-content:center; padding:30px; opacity:0; transition:opacity .3s ease; }
.vmodal.open { display:flex; opacity:1; }
.vmodal-inner { width:100%; max-width:1000px; aspect-ratio:16/9; border-radius:18px; overflow:hidden; box-shadow:0 40px 120px -20px rgba(0,0,0,.9); }
.vmodal-inner iframe, .vmodal-inner video { width:100%; height:100%; border:0; display:block; }
.vmodal-close { position:absolute; top:24px; right:30px; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; display:grid; place-items:center; font-size:1.5rem; transition:background .2s; }
.vmodal-close:hover { background:rgba(255,255,255,.25); }

/* ---------- REVIEWS / SOCIAL PROOF ---------- */
.reviews { position:relative; }
.reviews-top { display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:48px; }
.google-card { display:flex; align-items:center; gap:18px; padding:20px 26px; border:1.5px solid var(--line-2); border-radius:18px; background:var(--card); box-shadow:var(--shadow-card); }
.google-logo { font-family:'Sora',sans-serif; font-weight:700; font-size:1.4rem; letter-spacing:-.02em; }
.google-logo .g-b{color:#4285F4;} .google-logo .g-r{color:#EA4335;} .google-logo .g-y{color:#FBBC05;} .google-logo .g-g{color:#34A853;}
.google-card .gc-meta { line-height:1.2; }
.google-card .gc-score { font-family:'Sora',sans-serif; font-weight:800; font-size:1.8rem; color:var(--ink); display:flex; align-items:baseline; gap:8px; }
.google-card .gc-score .gc-stars { font-size:.95rem; color:#FFC857; letter-spacing:1px; -webkit-text-fill-color:#FFC857; }
.google-card .gc-sub { font-size:.84rem; color:var(--ink-3); }

.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review {
  background:var(--card); border:1.5px solid var(--line); border-radius:20px; padding:28px 26px;
  box-shadow:var(--shadow-card); display:flex; flex-direction:column; gap:14px;
  transition:transform .25s cubic-bezier(.2,0,0,1), border-color .25s;
}
.review:hover { transform:translateY(-4px); border-color:var(--teal-line); }
.review .r-stars { color:#FFC857; font-size:1rem; letter-spacing:2px; }
.review .r-text { font-size:.98rem; color:var(--ink); line-height:1.6; font-weight:400; }
.review .r-text b { color:var(--teal); font-weight:600; }
.review .r-foot { display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:8px; }
.review .r-av { width:44px; height:44px; border-radius:50%; background-size:cover; background-position:center; flex-shrink:0; border:2px solid var(--line); }
.review .r-name { font-weight:600; font-size:.92rem; color:var(--ink); }
.review .r-spec { font-size:.78rem; color:var(--ink-3); }
.review .r-g { margin-left:auto; font-family:'Sora',sans-serif; font-weight:700; font-size:.85rem; }
.review .r-g .g-b{color:#4285F4;}.review .r-g .g-r{color:#EA4335;}.review .r-g .g-y{color:#FBBC05;}.review .r-g .g-g{color:#34A853;}
@media (max-width:960px){ .reviews-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:640px){ .reviews-grid{grid-template-columns:1fr;} }

/* ---------- GUARANTEE BAND ---------- */
.guarantee { padding:0 0 120px; }
.guar-card {
  position:relative; overflow:hidden; border-radius:28px;
  background:var(--charcoal); border:1.5px solid rgba(255,255,255,.08);
  padding:60px 56px; display:grid; grid-template-columns:auto 1fr auto; gap:40px; align-items:center;
  box-shadow:0 30px 70px -34px rgba(0,0,0,.6);
}
.guar-card::before { content:''; position:absolute; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle,rgba(14,165,181,.16),transparent 65%); top:-180px; right:-100px; pointer-events:none; }
.guar-seal { width:128px; height:128px; border-radius:50%; display:grid; place-items:center; text-align:center; background:linear-gradient(135deg,var(--teal-d),var(--teal)); box-shadow:0 0 0 8px rgba(14,165,181,.14), 0 16px 40px -12px rgba(14,165,181,.5); position:relative; z-index:2; }
.guar-seal .gs-n { font-family:'Sora',sans-serif; font-weight:800; font-size:2.4rem; color:#fff; line-height:.9; }
.guar-seal .gs-l { font-family:'IBM Plex Mono',monospace; font-size:.56rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.85); margin-top:2px; }
.guar-body { position:relative; z-index:2; }
.guar-body .eyebrow { color:var(--teal-l); }
.guar-body .eyebrow::before { background:var(--teal-l); }
.guar-body h3 { font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(1.6rem,3vw,2.3rem); color:#F5F3EF; margin:14px 0 12px; }
.guar-body p { color:rgba(245,243,239,.65); font-weight:300; font-size:1.05rem; max-width:520px; }
.guar-cta { position:relative; z-index:2; display:flex; flex-direction:column; gap:10px; align-items:stretch; }
.guar-points { list-style:none; display:flex; flex-direction:column; gap:9px; }
.guar-points li { display:flex; align-items:center; gap:10px; color:rgba(245,243,239,.85); font-size:.92rem; }
.guar-points li svg { width:18px; height:18px; color:var(--teal-l); flex-shrink:0; }
@media (max-width:900px){ .guar-card{ grid-template-columns:1fr; text-align:center; gap:28px; padding:48px 30px; } .guar-seal{margin:0 auto;} .guar-body p{margin:0 auto;} .guar-body .eyebrow{justify-content:center;} .guar-cta{align-items:center;} }

/* ---------- WHATSAPP FLOAT + BACK TO TOP ---------- */
.wa-float {
  position:fixed; bottom:26px; right:26px; z-index:9500;
  display:flex; align-items:center; gap:0;
  height:60px; border-radius:100px; overflow:hidden;
  background:#25D366; box-shadow:0 12px 30px -8px rgba(37,211,102,.55);
  text-decoration:none; transition:box-shadow .25s, transform .25s cubic-bezier(.2,0,0,1);
}
.wa-float:hover { transform:translateY(-3px); box-shadow:0 18px 40px -8px rgba(37,211,102,.65); }
.wa-ic { width:60px; height:60px; display:grid; place-items:center; flex-shrink:0; position:relative; }
.wa-ic svg { width:30px; height:30px; color:#fff; }
.wa-ic::after { content:''; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:waPulse 2.4s infinite; }
@keyframes waPulse { 0%{box-shadow:0 0 0 0 rgba(37,211,102,.5);} 70%{box-shadow:0 0 0 16px rgba(37,211,102,0);} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0);} }
.wa-label { color:#fff; font-weight:600; font-size:.95rem; max-width:0; opacity:0; white-space:nowrap; transition:max-width .35s cubic-bezier(.2,0,0,1), opacity .25s, padding .35s; padding:0; }
.wa-float:hover .wa-label { max-width:230px; opacity:1; padding:0 22px 0 4px; }
@media (max-width:560px){ .wa-float:hover .wa-label{ max-width:0; opacity:0; padding:0; } .wa-float{ bottom:20px; right:20px; } }

/* ---------- LIGHT-PREMIUM TOUCHES ---------- */
[data-theme="light"] .footer { background:var(--charcoal); border-top-color:rgba(255,255,255,.06); }
[data-theme="light"] .footer .footer-brand p,
[data-theme="light"] .footer .fcol a { color:rgba(245,243,239,.6); }
[data-theme="light"] .footer .fcol a:hover { color:var(--teal-l); }
[data-theme="light"] .footer .fcol h4 { color:rgba(245,243,239,.4); }
[data-theme="light"] .footer .footer-bottom { border-top-color:rgba(255,255,255,.08); }
[data-theme="light"] .footer .footer-bottom p { color:rgba(245,243,239,.4); }
[data-theme="light"] .footer-brand img { background:transparent; }
[data-theme="light"] .plan.featured { box-shadow:0 0 0 1px var(--gold-line), 0 30px 70px -30px rgba(20,40,50,.28); }

/* ============================================================
   V2.1 · BOOKING (Cal.com) · BLOG · SOCIAL · SWIPE HINT
   ============================================================ */

/* ---------- BOOKING (dark stage in both themes) ---------- */
.booking { background:#070709; position:relative; overflow:hidden; }
[data-theme="light"] .booking { background:#11161A; }
.booking::before { content:''; position:absolute; width:620px; height:620px; border-radius:50%; background:radial-gradient(circle,rgba(14,165,181,.16),transparent 64%); top:-240px; right:-140px; pointer-events:none; }
.booking .sec-head { text-align:center; margin-left:auto; margin-right:auto; position:relative; z-index:2; }
.booking .sec-head h2 { color:#F5F3EF; }
.booking .sec-head p { color:rgba(245,243,239,.62); margin-left:auto; margin-right:auto; }
.booking .eyebrow { justify-content:center; color:var(--teal-l); }
.booking .eyebrow::before { background:var(--teal-l); }
.book-perks { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:0 auto 36px; max-width:680px; position:relative; z-index:2; }
.book-perk { display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:100px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); color:rgba(245,243,239,.85); font-size:.86rem; }
.book-perk svg { width:16px; height:16px; color:var(--teal-l); }
.cal-frame {
  max-width:1080px; margin:0 auto; position:relative; z-index:2;
  border:1.5px solid rgba(255,255,255,.12); border-radius:24px; overflow:hidden;
  background:#0c0f12; box-shadow:0 40px 100px -34px rgba(0,0,0,.8);
}
.cal-frame #cal-inline { width:100%; height:720px; overflow:auto; }
.cal-fallback { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; height:100%; min-height:520px; padding:40px; text-align:center; color:#7BCAD4; font-family:'IBM Plex Mono',monospace; font-size:.85rem; line-height:1.8; }
.cal-fallback .cf-ic { width:60px; height:60px; border-radius:16px; display:grid; place-items:center; background:rgba(14,165,181,.12); border:1px solid rgba(14,165,181,.3); }
.cal-fallback .cf-ic svg { width:28px; height:28px; }
.cal-fallback a { color:#fff; text-decoration:underline; }
@media (max-width:680px){ .cal-frame #cal-inline { height:640px; } }

/* ---------- BLOG ---------- */
.blog .sec-head { display:flex; flex-direction:column; }
.blog-top { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:46px; }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post {
  background:var(--card); border:1.5px solid var(--line); border-radius:22px; overflow:hidden;
  box-shadow:var(--shadow-card); display:flex; flex-direction:column;
  transition:transform .25s cubic-bezier(.2,0,0,1), border-color .25s; cursor:pointer;
}
.post:hover { transform:translateY(-5px); border-color:var(--teal-line); }
.post .p-img { aspect-ratio:16/10; position:relative; overflow:hidden; background:var(--card-2); }
.post .p-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.2,0,0,1); }
.post:hover .p-img img { transform:scale(1.05); }
.post .p-cat { position:absolute; top:14px; left:14px; font-family:'IBM Plex Mono',monospace; font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; padding:6px 11px; border-radius:100px; background:rgba(7,8,10,.7); color:var(--teal-l); backdrop-filter:blur(8px); border:1px solid rgba(14,165,181,.3); }
.post .p-body { padding:24px 24px 26px; display:flex; flex-direction:column; gap:11px; flex:1; }
.post h3 { font-size:1.18rem; font-weight:700; line-height:1.25; }
.post .p-ex { font-size:.93rem; color:var(--ink-2); font-weight:300; line-height:1.55; flex:1; }
.post .p-meta { display:flex; align-items:center; gap:10px; font-family:'IBM Plex Mono',monospace; font-size:.7rem; color:var(--ink-3); margin-top:4px; }
.post .p-meta .dotp { width:3px; height:3px; border-radius:50%; background:var(--ink-3); }
.post .p-more { display:inline-flex; align-items:center; gap:7px; color:var(--teal); font-weight:600; font-size:.9rem; margin-top:6px; }
.post .p-more svg { width:15px; height:15px; transition:transform .25s; }
.post:hover .p-more svg { transform:translateX(4px); }
@media (max-width:960px){ .blog-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .blog-grid{ grid-template-columns:1fr; } }

/* ---------- SOCIAL / INSTAGRAM ---------- */
.social { background:var(--section); }
.social-wrap { display:grid; grid-template-columns:1.15fr 1fr; gap:40px; align-items:start; }
.ig-card { background:var(--card); border:1.5px solid var(--line); border-radius:24px; overflow:hidden; box-shadow:var(--shadow-card); }
.ig-head { display:flex; align-items:center; gap:16px; padding:22px 24px; border-bottom:1px solid var(--line); }
.ig-head .ig-av { width:60px; height:60px; border-radius:50%; padding:2.5px; background:linear-gradient(45deg,#FEDA75,#FA7E1E,#D62976,#962FBF,#4F5BD5); flex-shrink:0; }
.ig-head .ig-av img { width:100%; height:100%; border-radius:50%; border:2.5px solid var(--card); object-fit:cover; background:var(--charcoal); }
.ig-head .ig-meta { flex:1; }
.ig-head .ig-handle { font-weight:700; font-size:1rem; color:var(--ink); display:flex; align-items:center; gap:6px; }
.ig-head .ig-handle svg { width:15px; height:15px; color:#3897F0; }
.ig-head .ig-stats { display:flex; gap:16px; margin-top:4px; font-size:.8rem; color:var(--ink-3); }
.ig-head .ig-stats b { color:var(--ink); font-weight:600; }
.ig-follow { padding:9px 18px; border-radius:10px; background:linear-gradient(45deg,#FA7E1E,#D62976,#962FBF); color:#fff; font-weight:600; font-size:.85rem; }
.ig-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; }
.ig-post { position:relative; aspect-ratio:1; overflow:hidden; cursor:pointer; }
.ig-post img { width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.2,0,0,1); }
.ig-post:hover img { transform:scale(1.08); }
.ig-post .ig-ov { position:absolute; inset:0; background:rgba(7,8,10,.55); display:flex; align-items:center; justify-content:center; gap:18px; opacity:0; transition:opacity .25s; color:#fff; font-weight:600; font-size:.85rem; }
.ig-post:hover .ig-ov { opacity:1; }
.ig-post .ig-ov span { display:inline-flex; align-items:center; gap:6px; }
.ig-post .ig-ov svg { width:17px; height:17px; }
.ig-note { font-family:'IBM Plex Mono',monospace; font-size:.68rem; color:var(--ink-3); text-align:center; padding:13px; border-top:1px solid var(--line); }

.social-side { display:flex; flex-direction:column; gap:16px; }
.social-side h3 { font-family:'Sora',sans-serif; font-weight:800; font-size:1.7rem; }
.social-side p { color:var(--ink-2); font-weight:300; margin-bottom:6px; }
.social-links { display:flex; flex-direction:column; gap:12px; }
.s-btn { display:flex; align-items:center; gap:15px; padding:17px 20px; border-radius:16px; border:1.5px solid var(--line); background:var(--card); box-shadow:var(--shadow-card); transition:transform .22s cubic-bezier(.2,0,0,1), border-color .22s; }
.s-btn:hover { transform:translateY(-3px); }
.s-btn .s-ic { width:46px; height:46px; border-radius:13px; display:grid; place-items:center; flex-shrink:0; color:#fff; }
.s-btn .s-ic svg { width:24px; height:24px; }
.s-btn.ig .s-ic { background:linear-gradient(45deg,#FEDA75,#FA7E1E,#D62976,#962FBF,#4F5BD5); }
.s-btn.fb .s-ic { background:#1877F2; }
.s-btn.tt .s-ic { background:#0b0b0b; }
[data-theme="light"] .s-btn.tt .s-ic { background:#111; }
.s-btn .s-tx { flex:1; }
.s-btn .s-h { font-weight:600; font-size:1rem; color:var(--ink); }
.s-btn .s-s { font-size:.82rem; color:var(--ink-3); }
.s-btn .s-arrow { color:var(--ink-3); transition:transform .22s, color .22s; }
.s-btn:hover .s-arrow { transform:translateX(4px); color:var(--teal); }
.s-btn.ig:hover { border-color:#D62976; }
.s-btn.fb:hover { border-color:#1877F2; }
.s-btn.tt:hover { border-color:var(--ink); }
@media (max-width:880px){ .social-wrap{ grid-template-columns:1fr; } }

/* ---------- TABLE SWIPE HINT (mobile) ---------- */
.swipe-hint { display:none; }
.table-card { position:relative; }
@media (max-width:760px){
  .swipe-hint {
    display:flex; align-items:center; justify-content:center; gap:10px;
    margin:0 0 14px; padding:11px 16px; border-radius:100px;
    background:var(--teal-soft); border:1px solid var(--teal-line); color:var(--teal);
    font-family:'IBM Plex Mono',monospace; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  }
  .swipe-hint svg { width:18px; height:18px; animation:swipeMove 1.6s ease-in-out infinite; }
  .table-card::after {
    content:''; position:absolute; top:0; right:0; bottom:0; width:46px; z-index:5; pointer-events:none;
    background:linear-gradient(90deg,transparent,var(--card));
  }
}
@keyframes swipeMove { 0%,100%{ transform:translateX(-4px); } 50%{ transform:translateX(4px); } }

/* ---------- RESPONSIVE POLISH ---------- */
@media (max-width:680px){
  .toggle { display:grid; grid-template-columns:1fr 1fr; gap:6px; width:100%; }
  .tg { justify-content:center; padding:12px 8px; font-size:.7rem; flex:none; }
  .hero { padding-top:96px; min-height:auto; padding-bottom:60px; }
  .hero-rate { gap:11px; }
  .sec { padding:72px 0; }
  .sec-head { margin-bottom:40px; }
  .final { padding:72px 0; }
  .guarantee { padding-bottom:72px; }
  .cta-card { padding:48px 24px; }
  .cta-btns { flex-direction:column; }
  .cta-btns .btn { width:100%; }
  .blog-top { flex-direction:column; align-items:flex-start; gap:16px; }
  .price .amt { font-size:3.2rem; }
}
@media (max-width:420px){
  .hero-rate .rate-sub { font-size:.8rem; }
  .ig-follow { display:none; }
  .pay-chip { font-size:.84rem; padding:11px 15px; }
}

/* ============================================================
   V2.2 · HERO BENEFITS · BANNER · PORTFOLIO · CAL FIX · COOKIES · FOOTER SOCIAL
   ============================================================ */

/* ---------- HERO BENEFITS ROW ---------- */
.hero-benefits { display:flex; flex-wrap:wrap; gap:9px 22px; margin-bottom:30px; }
.hero-benefits span { display:inline-flex; align-items:center; gap:8px; font-size:.94rem; color:var(--ink-2); font-weight:500; }
.hero-benefits svg { width:17px; height:17px; color:var(--teal-l); flex-shrink:0; }
.hero-benefits b { color:var(--ink); font-weight:600; }

/* ---------- IMPACT (Resultados + Especialidades, una sola sección) ---------- */
.impact { position:relative; padding:110px 0; background:#070709;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 7%, #000 93%, transparent 100%);
          mask-image:linear-gradient(to bottom, transparent 0%, #000 7%, #000 93%, transparent 100%); }
[data-theme="light"] .impact { background:#11161A; }

.impact-card {
  position:relative; overflow:hidden; min-height:380px; display:flex; align-items:center;
  border-radius:28px; border:1.5px solid rgba(255,255,255,.1);
  box-shadow:0 30px 70px -34px rgba(0,0,0,.65), 0 1px 0 rgba(255,255,255,.05) inset;
}
.impact-card .ic-bg { position:absolute; inset:0; z-index:0; }
.impact-card .ic-bg img { width:100%; height:100%; object-fit:cover; opacity:.42; }
.impact-card::after { content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(100deg,#0a0a0d 16%,rgba(10,10,13,.74) 50%,rgba(10,10,13,.34) 100%); }
.impact-card .ic-in { position:relative; z-index:2; padding:50px 54px; max-width:660px; }
.impact-card .eyebrow { color:var(--teal-l); }
.impact-card .eyebrow::before { background:var(--teal-l); }
.impact-card h2 { font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(1.9rem,4vw,3rem); color:#F5F3EF; margin:16px 0 14px; line-height:1.1; }
.impact-card h2 em { font-style:normal; color:var(--teal-l); }
.impact-card p { color:rgba(245,243,239,.72); font-weight:300; font-size:1.08rem; max-width:500px; margin-bottom:30px; }
.banner-stats { display:flex; gap:38px; flex-wrap:wrap; }
.banner-stat .bs-v { font-family:'Sora',sans-serif; font-weight:800; font-size:2.2rem; color:#fff; letter-spacing:-.03em; }
.banner-stat .bs-v b { color:var(--teal-l); }
.banner-stat .bs-l { font-size:.84rem; color:rgba(245,243,239,.55); }

.impact-specs { margin-top:84px; }
.impact-specs .sec-head h2 { color:#F5F3EF; }
.impact-specs .sec-head p { color:rgba(245,243,239,.6); }
.impact-specs .eyebrow { color:var(--teal-l); }
.impact-specs .eyebrow::before { background:var(--teal-l); }
.impact .spec { background:rgba(255,255,255,.04); border:1.5px solid rgba(255,255,255,.1); box-shadow:0 1px 0 rgba(255,255,255,.04) inset; }
.impact .spec:hover { background:rgba(255,255,255,.07); border-color:var(--teal-line); }
.impact .spec .sp-tx { color:#F5F3EF; }
.impact .spec .sp-ic { background:rgba(14,165,181,.14); border-color:rgba(14,165,181,.3); }
@media (max-width:760px){ .impact{ padding:84px 0; } .impact-card .ic-in{ padding:38px 28px; } .banner-stats{ gap:24px; } .banner-stat .bs-v{ font-size:1.7rem; } .impact-specs{ margin-top:60px; } }

/* ---------- PORTFOLIO / CLIENTES ---------- */
.portfolio { background:var(--section); }
.pf-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pf-card { background:var(--card); border:1.5px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:var(--shadow-card); transition:transform .25s cubic-bezier(.2,0,0,1), border-color .25s; }
.pf-card:hover { transform:translateY(-5px); border-color:var(--teal-line); }
.pf-bar { display:flex; align-items:center; gap:10px; padding:10px 14px; border-bottom:1px solid var(--line); background:var(--card-2); }
.pf-dots { display:flex; gap:6px; }
.pf-dots i { width:9px; height:9px; border-radius:50%; display:block; }
.pf-dots i:nth-child(1){ background:#FF5F57; } .pf-dots i:nth-child(2){ background:#FEBC2E; } .pf-dots i:nth-child(3){ background:#28C840; }
.pf-url { flex:1; font-family:'IBM Plex Mono',monospace; font-size:.7rem; color:var(--ink-3); background:var(--page); border:1px solid var(--line); border-radius:7px; padding:5px 12px; text-align:center; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pf-shot { position:relative; aspect-ratio:16/10; overflow:hidden; }
.pf-shot img { width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.2,0,0,1); }
.pf-card:hover .pf-shot img { transform:scale(1.05); }
.pf-ov { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:22px; gap:8px; background:linear-gradient(180deg,rgba(7,8,10,.05) 30%,rgba(7,8,10,.82)); }
.pf-ov .pf-spec { font-family:'IBM Plex Mono',monospace; font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-l); }
.pf-ov .pf-name { font-family:'Sora',sans-serif; font-weight:700; font-size:1.15rem; color:#fff; line-height:1.15; }
.pf-ov .pf-pill { align-self:flex-start; margin-top:4px; font-size:.66rem; font-weight:600; padding:5px 11px; border-radius:100px; background:var(--teal); color:#fff; }
.pf-foot { display:flex; align-items:center; justify-content:space-between; padding:15px 18px; }
.pf-foot .pf-tag { font-family:'IBM Plex Mono',monospace; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); display:inline-flex; align-items:center; gap:7px; }
.pf-foot .pf-tag::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px var(--green-soft); }
.pf-foot .pf-link { font-size:.84rem; font-weight:600; color:var(--teal); display:inline-flex; align-items:center; gap:6px; }
.pf-foot .pf-link svg { width:14px; height:14px; transition:transform .25s; }
.pf-card:hover .pf-foot .pf-link svg { transform:translateX(3px); }
.pf-note { text-align:center; margin-top:30px; font-family:'IBM Plex Mono',monospace; font-size:.7rem; letter-spacing:.06em; color:var(--ink-3); }
@media (max-width:960px){ .pf-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .pf-grid{ grid-template-columns:1fr; } }

/* ---------- CAL RATING (social proof on booking) ---------- */
.cal-rate { display:flex; align-items:center; justify-content:center; gap:12px; flex-wrap:wrap; margin:0 auto 26px; position:relative; z-index:2; }
.cal-rate .cr-stars { color:#FFC857; font-size:1.05rem; letter-spacing:2px; }
.cal-rate .cr-tx { font-size:.92rem; color:rgba(245,243,239,.72); }
.cal-rate .cr-tx b { color:#fff; font-weight:600; }
.cal-rate .cr-av { display:flex; }
.cal-rate .cr-av span { width:30px; height:30px; border-radius:50%; margin-left:-9px; border:2px solid #0a0d10; background-size:cover; background-position:center; }
.cal-rate .cr-av span:first-child { margin-left:0; }

/* cal frame uses the user's exact embed id */
.cal-frame { position:relative; }
.cal-frame #my-cal-inline-growthpartner { position:relative; z-index:2; width:100%; height:760px; overflow:auto; background:transparent; }
.cal-frame .cal-fallback { position:absolute; inset:0; z-index:1; }
@media (max-width:680px){ .cal-frame #my-cal-inline-growthpartner { height:640px; } }

/* ---------- COOKIE BANNER ---------- */
.cookie {
  position:fixed; bottom:22px; left:22px; z-index:9600; width:360px; max-width:calc(100vw - 44px);
  background:var(--card); border:1.5px solid var(--line-2); border-radius:18px;
  padding:20px 22px; box-shadow:0 24px 60px -20px rgba(0,0,0,.5);
  transform:translateY(160%); opacity:0; transition:transform .55s cubic-bezier(.2,0,0,1), opacity .4s;
}
.cookie.show { transform:none; opacity:1; }
.cookie-h { display:flex; align-items:center; gap:10px; margin-bottom:9px; }
.cookie-h svg { width:20px; height:20px; color:var(--teal); }
.cookie-h h5 { font-family:'Sora',sans-serif; font-weight:700; font-size:1rem; color:var(--ink); }
.cookie p { font-size:.85rem; color:var(--ink-2); font-weight:300; line-height:1.5; margin-bottom:16px; }
.cookie p a { color:var(--teal); text-decoration:underline; }
.cookie-btns { display:flex; gap:10px; }
.cookie-btns button { flex:1; padding:11px 14px; border-radius:11px; font-weight:600; font-size:.86rem; transition:transform .2s, background .2s, border-color .2s; }
.cookie-btns .ck-accept { background:linear-gradient(135deg,var(--teal-d),var(--teal)); color:#fff; }
.cookie-btns .ck-accept:hover { transform:translateY(-2px); }
.cookie-btns .ck-deny { background:transparent; border:1.5px solid var(--line-2); color:var(--ink-2); }
.cookie-btns .ck-deny:hover { border-color:var(--ink-3); color:var(--ink); }
@media (max-width:560px){ .cookie{ left:14px; right:14px; bottom:14px; width:auto; max-width:none; } }

/* ---------- FOOTER SOCIAL ICONS ---------- */
.footer-social { display:flex; gap:11px; margin-top:20px; }
.fs-ic {
  width:42px; height:42px; border-radius:12px; display:grid; place-items:center;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  color:rgba(245,243,239,.6); transition:all .22s cubic-bezier(.2,0,0,1);
}
.fs-ic svg { width:20px; height:20px; }
.fs-ic:hover { transform:translateY(-3px); color:#fff; }
.fs-ic.ig:hover { background:linear-gradient(45deg,#FA7E1E,#D62976,#962FBF); border-color:transparent; }
.fs-ic.fb:hover { background:#1877F2; border-color:transparent; }
.fs-ic.tt:hover { background:#0b0b0b; border-color:rgba(255,255,255,.3); }
.fs-ic.wa:hover { background:#25D366; border-color:transparent; }
/* footer is dark in both themes, keep brand wordmark teal accent */
.footer .brand .bt .n1, [data-theme="light"] .footer .brand { color:#F5F3EF; }

/* ---------- ESPECIALIDADES ---------- */
.specs { background:var(--section); }
.spec-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.spec {
  display:flex; align-items:center; gap:14px; padding:18px 20px;
  border:1.5px solid var(--line); border-radius:16px; background:var(--card);
  box-shadow:var(--shadow-card); transition:transform .22s cubic-bezier(.2,0,0,1), border-color .22s;
}
.spec:hover { transform:translateY(-3px); border-color:var(--teal-line); }
.spec .sp-ic { width:44px; height:44px; border-radius:12px; flex-shrink:0; display:grid; place-items:center; background:var(--teal-soft); border:1px solid var(--teal-line); color:var(--teal); transition:all .22s; }
.spec:hover .sp-ic { background:var(--teal); color:#fff; }
.spec .sp-ic svg { width:22px; height:22px; }
.spec .sp-tx { font-weight:600; font-size:.96rem; color:var(--ink); line-height:1.2; }
@media (max-width:920px){ .spec-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .spec-grid{ grid-template-columns:1fr; } }
