/* ============================================================
   VECTOR EMPRESARIAL — Diagnóstico estratégico
   Página de conversión · 497€ · booking
============================================================ */

:root{
  --teal:#1B6B93;
  --teal-700:#155471;
  --teal-300:#7FB9D4;
  --teal-50:#EAF2F7;
  --teal-tint:#F2F7FA;
  --ink:#0F172A;
  --ink-2:#475569;
  --ink-3:#64748B;
  --ink-4:#94A3B8;
  --line:#E5E9EE;
  --line-2:#EEF1F4;
  --bg:#FFFFFF;
  --bg-alt:#F8FAFC;
  --bg-warm:#FBFAF7;
  --bg-dark:#0A1726;
  --bg-dark-2:#091A2C;
  --green:#10B981;
  --green-700:#0a8a64;
  --green-50:#ECFDF5;
  --red:#B42318;
  --red-50:#FEF2F2;
  --orange:#F59E0B;
  --orange-50:#FFF8EB;
  --r-sm:.5rem;
  --r:.75rem;
  --r-lg:1rem;
  --r-xl:1.25rem;
  --maxw:1400px;
  --gutter:40px;
  --ease: cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter",ui-sans-serif,system-ui,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
img,svg{max-width:100%;display:block}
::selection{background:var(--teal);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);position:relative}
.mono{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace}

.eyebrow{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  color:var(--teal);display:inline-flex;align-items:center;gap:10px;margin:0;
}
.eyebrow.muted{color:var(--ink-3)}
.eyebrow.light{color:var(--teal-300)}
.eyebrow .bullet{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}
.eyebrow.flag{
  border:1px solid var(--line);padding:7px 14px 7px 12px;border-radius:999px;
  background:#fff;color:var(--ink);font-weight:500;letter-spacing:.04em;
}
.eyebrow.flag .dot{
  width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 3px rgba(27,107,147,.18);animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(27,107,147,.18)}50%{box-shadow:0 0 0 6px rgba(27,107,147,.08)}}

h1,h2,h3,h4{font-weight:700;letter-spacing:-.025em;margin:0;color:var(--ink);text-wrap:balance}
h1{font-size:clamp(48px,5.6vw,80px);line-height:.96;letter-spacing:-.035em;font-weight:800}
h2{font-size:clamp(32px,3.4vw,48px);line-height:1.06;letter-spacing:-.025em}
h3{font-size:22px;line-height:1.25}
p{margin:0;color:var(--ink-2);text-wrap:pretty}
.lead{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:62ch}
.lead em{font-style:normal;color:var(--teal);font-weight:600}
.muted-small{font-size:13px;color:var(--ink-3)}
.muted-small b{color:var(--ink);font-weight:700}

.btn{
  position:relative;display:inline-flex;align-items:center;gap:.55em;
  padding:14px 22px;border-radius:var(--r);font-weight:600;font-size:15px;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
  white-space:nowrap;will-change:transform;
}
.btn .arrow{transition:transform .3s var(--ease);display:inline-block}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 20px -10px rgba(27,107,147,.55)}
.btn-primary:hover{background:var(--teal-700);box-shadow:0 14px 36px -14px rgba(27,107,147,.65)}
.btn-primary:active{transform:translateY(1px)}
.btn-ghost{color:var(--ink);border:1px solid var(--line);background:#fff}
.btn-ghost:hover{background:var(--bg-alt);border-color:#D9DFE6}
.btn-white{background:#fff;color:var(--teal)}
.btn-white:hover{background:#F2F7FA}
.btn-lg{padding:18px 28px;font-size:16px;border-radius:var(--r)}
.btn-block{width:100%;justify-content:center}
.btn .price-pill{
  background:rgba(255,255,255,.18);color:#fff;
  padding:3px 9px;border-radius:5px;font-size:13px;font-weight:700;letter-spacing:.02em;
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;margin-left:4px;
}

.link{
  display:inline-flex;align-items:center;gap:.45em;color:var(--teal);font-weight:600;font-size:15px;
  position:relative;padding-bottom:3px;
}
.link::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;
  transform:scaleX(.25);transform-origin:left;transition:transform .35s var(--ease);
}
.link:hover::after{transform:scaleX(1)}
.link .arrow{transition:transform .3s var(--ease);display:inline-block}
.link:hover .arrow{transform:translateX(4px)}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .25s ease, background .25s ease;
}
header.site.scrolled{border-color:var(--line);background:rgba(255,255,255,.94)}
.scroll-bar{position:absolute;left:0;right:0;bottom:-1px;height:2px;background:transparent}
.scroll-bar-fill{height:100%;background:var(--teal);width:0%;transition:width .12s linear}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em;font-size:16px;color:var(--ink)}
.logo-mark{
  width:30px;height:30px;border-radius:8px;background:var(--teal);
  display:grid;place-items:center;color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18), 0 4px 12px -4px rgba(27,107,147,.45);
}
.logo-mark svg{width:14px;height:14px}
nav.primary{display:flex;align-items:center;gap:4px}
nav.primary a{
  padding:9px 14px;border-radius:8px;font-size:14.5px;color:var(--ink);font-weight:500;
  transition:background .15s ease, color .15s ease;position:relative;
}
nav.primary a:hover{background:var(--bg-alt);color:var(--teal)}

/* ============================================================
   HERO — split: copy left / booking summary card right
============================================================ */
.hero{position:relative;padding:80px 0 100px;overflow:hidden;background:#fff}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-bg .mesh{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;animation:floaty 18s ease-in-out infinite}
.hero-bg .m1{width:540px;height:540px;top:-180px;right:-120px;background:radial-gradient(circle, rgba(27,107,147,.22), transparent 65%)}
.hero-bg .m2{width:380px;height:380px;bottom:-160px;left:-120px;background:radial-gradient(circle, rgba(245,158,11,.10), transparent 65%);animation-delay:-7s}
.grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(15,23,42,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.035) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 35%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 35%, transparent 80%);
}
.grid-overlay.dark{background-image:linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px)}
@keyframes floaty{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-30px) scale(1.05)}}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:72px;align-items:center}
.hero-h1{margin:22px 0 22px}
.hero-h1 .accent{
  color:var(--teal);font-style:italic;font-family:"Lora",Georgia,serif;font-weight:500;
}
.hero-h2{
  font-size:clamp(20px,2vw,26px);line-height:1.35;color:var(--ink);
  font-weight:500;letter-spacing:-.01em;margin:0 0 36px;max-width:34ch;
}
.hero-h2 b{color:var(--ink);font-weight:600}
.hero-list-tag{font-size:12px;font-weight:700;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;display:block;margin-bottom:14px}
.hero-list{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:12px}
.hero-list li{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--ink);line-height:1.55}
.hero-list li .ck{
  width:20px;height:20px;border-radius:50%;background:var(--teal);color:#fff;
  display:grid;place-items:center;margin-top:1px;flex-shrink:0;
}
.hero-list li .ck svg{width:11px;height:11px}
.hero-foot{
  margin-top:24px;display:flex;align-items:center;gap:14px;font-size:13px;color:var(--ink-3);
  flex-wrap:wrap;
}
.hero-foot .seal{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:6px 12px 6px 10px;color:var(--ink);font-weight:500;font-size:12.5px;
}
.hero-foot .seal svg{width:14px;height:14px;color:var(--teal)}

/* ===== Booking summary card (hero right) ===== */
.book-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  box-shadow:0 30px 60px -28px rgba(15,23,42,.18), 0 6px 16px -10px rgba(15,23,42,.06);
  overflow:hidden;
}
.book-card .ribbon{
  background:linear-gradient(135deg, var(--teal), #2A86B5);color:#fff;
  padding:20px 28px;display:flex;align-items:center;justify-content:space-between;gap:10px;
  position:relative;
}
.book-card .ribbon::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(255,255,255,.18), transparent 60%);
  pointer-events:none;
}
.book-card .ribbon .label{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.book-card .ribbon .ico{
  width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.16);
  display:grid;place-items:center;
}
.book-card .price-block{
  padding:32px 32px 24px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  border-bottom:1px solid var(--line-2);
}
.book-card .price-amount{
  font-family:"Lora",Georgia,serif;font-style:italic;font-weight:500;
  font-size:64px;color:var(--ink);letter-spacing:-.04em;line-height:.9;
}
.book-card .price-amount .euro{font-family:"Inter",sans-serif;font-style:normal;font-weight:800;font-size:.55em;letter-spacing:-.02em;vertical-align:.18em;margin-left:2px;color:var(--ink-3)}
.book-card .price-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:right}
.book-card .price-side .vat{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:10.5px;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase}
.book-card .price-side .refund{
  background:var(--teal-50);color:var(--teal);font-size:11px;font-weight:600;letter-spacing:.04em;
  padding:5px 9px;border-radius:5px;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;
}
.book-card .price-side .refund::before{content:"↩";font-size:14px}

.book-card .summary{
  padding:24px 32px 24px;display:flex;flex-direction:column;gap:14px;
}
.book-card .summary .row{
  display:grid;grid-template-columns:24px 1fr auto;gap:12px;align-items:center;
  font-size:14px;color:var(--ink-2);
}
.book-card .summary .row b{color:var(--ink);font-weight:600}
.book-card .summary .row .ico{
  width:24px;height:24px;border-radius:6px;background:var(--teal-50);color:var(--teal);
  display:grid;place-items:center;
}
.book-card .summary .row .ico svg{width:13px;height:13px}
.book-card .summary .row .meta{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;
  color:var(--ink-3);letter-spacing:.06em;text-align:right;
}
.book-card .cta-block{
  padding:0 32px 32px;
}
.book-card .fineprint{
  padding:18px 32px;background:var(--bg-alt);border-top:1px solid var(--line-2);
  font-size:12px;color:var(--ink-3);line-height:1.5;display:flex;align-items:center;gap:8px;
}
.book-card .fineprint svg{width:14px;height:14px;color:var(--teal);flex-shrink:0}

/* ============================================================
   Section base
============================================================ */
section{padding:120px 0;border-top:1px solid var(--line-2);position:relative}
section.alt{background:var(--bg-alt);border-top:1px solid var(--line)}
section.dark{background:var(--bg-dark);color:#fff;border-top:0;overflow:hidden}
section.dark p, section.dark h2{color:#fff}

.section-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;margin-bottom:64px}
.section-head h2{max-width:24ch}
.section-head p{max-width:62ch}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   QUÉ PASA EN LOS 90 MIN — Gantt strip + 4 cards
============================================================ */
.gantt-wrap{margin-bottom:48px}
.gantt-axis{
  display:grid;grid-template-columns:repeat(7,1fr);
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;color:var(--ink-3);
  letter-spacing:.06em;margin-bottom:8px;padding:0 4px;
}
.gantt-axis span{text-align:left}
.gantt-axis span:last-child{text-align:right}
.gantt-strip{
  display:grid;grid-template-columns:15fr 35fr 25fr 15fr;
  gap:6px;height:64px;
  background:transparent;
}
.gantt-seg{
  position:relative;border-radius:8px;cursor:pointer;
  background:linear-gradient(180deg, var(--teal-50), #DDEAF1);
  border:1px solid var(--teal-50);
  display:flex;flex-direction:column;justify-content:flex-end;padding:8px 12px;
  transition:transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.gantt-seg .gnum{
  position:absolute;top:8px;left:12px;
  font-family:"Lora",Georgia,serif;font-style:italic;font-weight:500;
  font-size:14px;color:var(--teal);line-height:1;
}
.gantt-seg .glab{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:10.5px;
  color:var(--ink);font-weight:600;letter-spacing:.06em;line-height:1.2;
}
.gantt-seg:hover, .gantt-seg.active{
  background:linear-gradient(180deg, var(--teal), var(--teal-700));border-color:var(--teal-700);
}
.gantt-seg:hover .gnum, .gantt-seg.active .gnum{color:rgba(255,255,255,.85)}
.gantt-seg:hover .glab, .gantt-seg.active .glab{color:#fff}
.gantt-seg.cur{background:linear-gradient(180deg, var(--teal), var(--teal-700));border-color:var(--teal-700)}
.gantt-seg.cur .gnum{color:rgba(255,255,255,.85)}
.gantt-seg.cur .glab{color:#fff}

.moments{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.moment{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 24px 24px;display:flex;flex-direction:column;gap:12px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;
}
.moment:hover, .moment.active{transform:translateY(-3px);box-shadow:0 18px 38px -26px rgba(15,23,42,.22);border-color:var(--teal-300)}
.moment .m-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.moment .m-time{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;
  letter-spacing:.06em;color:var(--teal);font-weight:600;
  padding:5px 9px;border-radius:5px;background:var(--teal-50);
}
.moment .m-ico{
  width:36px;height:36px;border-radius:8px;background:var(--bg-alt);color:var(--ink-2);
  display:grid;place-items:center;
  transition:background .25s var(--ease), color .25s var(--ease);
}
.moment:hover .m-ico, .moment.active .m-ico{background:var(--teal-50);color:var(--teal)}
.moment h3{font-size:16px;letter-spacing:-.005em;line-height:1.25;font-weight:700;color:var(--ink);margin:6px 0 4px;text-transform:uppercase;letter-spacing:.03em;font-size:13.5px}
.moment p{font-size:14px;line-height:1.6;color:var(--ink-2)}

/* ============================================================
   QUÉ TE LLEVAS — 3 cards w/ visual previews
============================================================ */
.deliverables{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.dlv{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  padding:28px 28px 28px;display:flex;flex-direction:column;gap:18px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  position:relative;overflow:hidden;
}
.dlv:hover{transform:translateY(-3px);box-shadow:0 24px 52px -32px rgba(15,23,42,.22)}
.dlv .dlv-tag{
  font-size:11px;font-weight:700;color:var(--teal);letter-spacing:.14em;text-transform:uppercase;
}
.dlv h3{font-size:22px;letter-spacing:-.02em;line-height:1.18;font-weight:700;color:var(--ink)}
.dlv p{font-size:15px;line-height:1.65;color:var(--ink-2)}

/* Card 1 — Informe visual */
.dlv-visual{
  height:230px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--line-2);
  position:relative;overflow:hidden;
}
.dlv-pdf{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-3deg);
  width:152px;height:172px;background:#fff;border:1px solid var(--line);border-radius:6px;
  padding:14px 12px;display:flex;flex-direction:column;gap:5px;
  box-shadow:0 12px 24px -16px rgba(15,23,42,.22);
  transition:transform .4s var(--ease);
}
.dlv:hover .dlv-pdf{transform:translate(-50%,-50%) rotate(-1deg)}
.dlv-pdf::before{
  content:"";position:absolute;top:0;right:0;width:18px;height:18px;
  background:linear-gradient(225deg, var(--bg-alt) 50%, transparent 50%);
  border-top-right-radius:6px;
}
.dlv-pdf .pl{height:4px;border-radius:2px;background:#E2E8EC}
.dlv-pdf .pl.w70{width:70%}
.dlv-pdf .pl.w92{width:92%;background:var(--teal);opacity:.85}
.dlv-pdf .pl.w55{width:55%}
.dlv-pdf .pl.w80{width:80%}
.dlv-pdf .pt{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:8.5px;color:var(--teal);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}

/* Card 2 — Mapa visual */
.dlv-map{
  height:230px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--line-2);
  position:relative;display:grid;place-items:center;
}
.dlv-map svg{width:96%;height:96%}
.dlv-map .node{fill:#fff;stroke:var(--teal);stroke-width:1.5;transition:fill .25s var(--ease)}
.dlv-map .node.warn{stroke:var(--orange)}
.dlv-map .node.bad{stroke:var(--red);stroke-width:2}
.dlv:hover .dlv-map .node.warn{fill:var(--orange-50)}
.dlv:hover .dlv-map .node.bad{fill:var(--red-50)}
.dlv-map .edge{stroke:#BBD2DF;stroke-width:1;stroke-dasharray:3 4}
.dlv-map .label{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:9px;fill:var(--ink-2);font-weight:600;letter-spacing:.02em}
.dlv-map .label.strong{font-weight:700;fill:var(--red);font-size:9.5px}

/* Card 3 — Plan priorizado */
.dlv-plan{
  height:230px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--line-2);
  padding:16px 14px;display:flex;flex-direction:column;gap:8px;justify-content:center;
}
.dlv-plan .pi{
  background:#fff;border:1px solid var(--line-2);border-radius:6px;
  padding:8px 10px;display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;
  font-size:10.5px;color:var(--ink);
  transition:transform .25s var(--ease), border-color .25s var(--ease);
}
.dlv:hover .dlv-plan .pi{border-color:var(--teal-300)}
.dlv-plan .pi .p-pri{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:9px;font-weight:700;
  letter-spacing:.08em;padding:2px 6px;border-radius:4px;background:var(--teal-50);color:var(--teal);
}
.dlv-plan .pi .p-pri.h{background:#FEE2E2;color:var(--red)}
.dlv-plan .pi .p-pri.m{background:var(--orange-50);color:#a86c0a}
.dlv-plan .pi .p-imp{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:10px;font-weight:700;color:var(--teal)}
.dlv-foot{margin-top:28px;text-align:center;font-size:16px;line-height:1.6;color:var(--ink-2);max-width:62ch;margin-left:auto;margin-right:auto}
.dlv-foot b{color:var(--ink)}

/* ============================================================
   CALENDAR EMBED MOCKUP + summary
============================================================ */
.booking{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:flex-start}
.cal-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  padding:28px 32px 32px;box-shadow:0 18px 40px -28px rgba(15,23,42,.18);
}
.cal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}
.cal-head .ctitle{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.cal-head .cmeta{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-top:4px}
.cal-tz{
  display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);
  background:var(--bg-alt);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;
}
.cal-tz svg{width:12px;height:12px;color:var(--teal)}

.cal-month{
  display:flex;align-items:center;justify-content:space-between;
  font-size:14px;color:var(--ink);font-weight:600;margin-bottom:14px;
}
.cal-month .cnav{
  display:flex;gap:6px;
}
.cal-month .cnav button{
  width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;
  display:grid;place-items:center;color:var(--ink-2);transition:all .25s var(--ease);
}
.cal-month .cnav button:hover{background:var(--bg-alt);color:var(--ink);border-color:#D8DFE6}
.cal-grid-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.cal-grid-dow span{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:10.5px;color:var(--ink-3);
  letter-spacing:.06em;text-align:center;text-transform:uppercase;padding:4px 0;
}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:24px}
.cal-day{
  aspect-ratio:1/1;display:grid;place-items:center;
  font-size:13px;font-weight:500;color:var(--ink);border-radius:8px;border:1px solid transparent;
  transition:all .2s var(--ease);
  position:relative;cursor:default;
}
.cal-day.muted{color:var(--ink-4);font-weight:400}
.cal-day.avail{cursor:pointer;border-color:var(--teal-50);background:var(--teal-tint);color:var(--teal);font-weight:600}
.cal-day.avail:hover{background:var(--teal-50);border-color:var(--teal-300)}
.cal-day.avail.full{background:#fff;border-color:var(--line);color:var(--ink-3);text-decoration:line-through;cursor:not-allowed}
.cal-day.avail.full:hover{background:#fff;border-color:var(--line)}
.cal-day.sel{background:var(--teal);color:#fff;border-color:var(--teal-700);font-weight:700}
.cal-day.sel:hover{background:var(--teal-700)}
.cal-day.today{box-shadow:inset 0 -2px 0 var(--teal)}

.cal-slots{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;
}
.cal-slot{
  padding:10px 12px;border:1px solid var(--line);border-radius:8px;
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:12.5px;font-weight:600;
  color:var(--ink);background:#fff;transition:all .2s var(--ease);text-align:center;
}
.cal-slot:hover{background:var(--bg-alt);border-color:var(--teal-300);color:var(--teal)}
.cal-slot.sel{background:var(--teal);color:#fff;border-color:var(--teal-700)}
.cal-slot.gone{color:var(--ink-4);text-decoration:line-through;background:var(--bg-alt);cursor:not-allowed}
.cal-slot.gone:hover{background:var(--bg-alt);border-color:var(--line);color:var(--ink-4)}

.cal-legend{
  display:flex;gap:18px;font-size:12px;color:var(--ink-3);padding-top:14px;border-top:1px dashed var(--line-2);
  flex-wrap:wrap;
}
.cal-legend span{display:inline-flex;align-items:center;gap:7px}
.cal-legend .sw{width:11px;height:11px;border-radius:3px}
.cal-legend .sw.av{background:var(--teal-tint);border:1px solid var(--teal-50)}
.cal-legend .sw.fl{background:#fff;border:1px solid var(--line)}
.cal-legend .sw.se{background:var(--teal)}

/* Summary card (right side) */
.sum-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  overflow:hidden;
}
.sum-card .head{
  background:var(--ink);color:#fff;padding:20px 28px;
}
.sum-card .head h3{color:#fff;font-size:18px;letter-spacing:-.01em}
.sum-card .head .selected{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11.5px;color:rgba(255,255,255,.7);letter-spacing:.04em;margin-top:6px;display:flex;align-items:center;gap:8px}
.sum-card .head .selected .dot{width:7px;height:7px;border-radius:50%;background:var(--teal-300);animation:pulse 2.4s infinite}

.sum-card ul{list-style:none;padding:24px 28px 20px;margin:0;display:flex;flex-direction:column;gap:14px}
.sum-card ul li{display:grid;grid-template-columns:22px 1fr;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-2);line-height:1.55}
.sum-card ul li b{color:var(--ink);font-weight:600}
.sum-card ul li .ck{
  width:18px;height:18px;border-radius:50%;background:var(--teal-50);color:var(--teal);
  display:grid;place-items:center;margin-top:2px;flex-shrink:0;
}
.sum-card ul li .ck svg{width:11px;height:11px}

.sum-total{
  padding:18px 28px;background:var(--bg-alt);border-top:1px solid var(--line-2);
  display:flex;justify-content:space-between;align-items:center;
}
.sum-total .lbl{font-size:13px;color:var(--ink-3);font-weight:500}
.sum-total .amt{
  font-family:"Lora",Georgia,serif;font-style:italic;font-weight:500;font-size:38px;
  color:var(--ink);letter-spacing:-.03em;line-height:1;
}
.sum-total .amt .euro{font-family:"Inter",sans-serif;font-style:normal;font-weight:800;font-size:.5em;color:var(--ink-3);vertical-align:.18em;margin-left:2px}

.sum-card .cta-zone{padding:18px 28px 24px;display:flex;flex-direction:column;gap:10px}
.sum-card .pay-methods{
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-size:11px;color:var(--ink-3);font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;
  letter-spacing:.06em;padding-top:6px;
}
.pay-pill{
  background:#fff;border:1px solid var(--line);border-radius:6px;padding:5px 9px;
  color:var(--ink);font-family:"Inter",sans-serif;font-size:11.5px;font-weight:600;letter-spacing:0;
}

/* ============================================================
   FAQ
============================================================ */
.faq{display:flex;flex-direction:column;gap:0;max-width:920px;margin:0 auto}
.faq-item{background:#fff;border-bottom:1px solid var(--line);transition:background .25s var(--ease)}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-item summary{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:flex-start;
  padding:24px 8px;cursor:pointer;list-style:none;
  font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.35;
  transition:color .2s var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--teal)}
.faq-item summary .qnum{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:12px;font-weight:500;color:var(--teal);letter-spacing:.04em;padding-top:5px;min-width:32px}
.faq-item summary .qmark{
  width:32px;height:32px;border-radius:50%;background:var(--bg-alt);display:grid;place-items:center;color:var(--ink-2);flex-shrink:0;
  transition:transform .35s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.faq-item summary .qmark svg{transition:transform .35s var(--ease)}
.faq-item[open] summary .qmark{background:var(--teal);color:#fff}
.faq-item[open] summary .qmark svg{transform:rotate(45deg)}
.faq-item .ans{padding:0 8px 28px 58px;font-size:15.5px;line-height:1.7;color:var(--ink-2);max-width:78ch;animation:slideDown .3s var(--ease)}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ============================================================
   CTA FINAL
============================================================ */
.cta-final{padding:140px 0;text-align:center}
.dark-bg{position:absolute;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.7}
.orb.o1{top:-160px;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(ellipse, rgba(27,107,147,.55), transparent 65%);animation:floaty 14s ease-in-out infinite}
.orb.o2{bottom:-200px;left:20%;width:500px;height:400px;background:radial-gradient(ellipse, rgba(27,107,147,.35), transparent 65%);animation:floaty 18s ease-in-out infinite;animation-delay:-6s}
section.dark .grid-overlay{
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%, #000 35%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%, #000 35%, transparent 80%);
}
.cta-wrap{position:relative}
.cta-final h2{font-size:clamp(40px,5vw,68px);max-width:22ch;margin:18px auto 22px;letter-spacing:-.03em;line-height:1.04}
.cta-final p.sub{font-size:18px;line-height:1.65;color:rgba(255,255,255,.78);max-width:60ch;margin:0 auto 40px}
.cta-final p.sub b{color:#fff;font-weight:600}

/* ============================================================
   FOOTER
============================================================ */
footer.site{background:var(--bg-dark-2);color:#fff;padding:80px 0 32px;position:relative}
footer.site::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg, transparent, rgba(255,255,255,.15), transparent)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:48px}
.footer-logo{margin-bottom:14px;font-size:18px;color:#fff;display:flex;align-items:center;gap:10px}
footer.site h5{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:600;margin:0 0 18px}
footer.site ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
footer.site a{color:rgba(255,255,255,.82);font-size:14.5px;transition:color .15s ease}
footer.site a:hover{color:#fff}
footer.site .brand{font-weight:700;font-size:18px;color:#fff}
footer.site .tag{color:rgba(255,255,255,.65);font-size:14.5px;margin:8px 0 6px;font-style:italic;font-family:"Lora",Georgia,serif}
footer.site .loc{color:rgba(255,255,255,.5);font-size:13px}
.copy{margin-top:64px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:12.5px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;align-items:center}

/* ============================================================
   Responsive
============================================================ */
@media (max-width:1080px){
  .moments{grid-template-columns:1fr 1fr}
  .deliverables{grid-template-columns:1fr}
  .booking{grid-template-columns:1fr;gap:32px}
  .gantt-strip{height:84px}
}
@media (max-width:980px){
  :root{--gutter:28px}
  .hero{padding:56px 0 72px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  nav.primary{display:none}
  section{padding:72px 0}
  .moments{grid-template-columns:1fr}
}
