/* ═══════════════════════════════════════════════════════════════
   MEDINAS BARBER — Sistema de diseño (Acento · Kinfolk Editorial)
   Tokens y componentes compartidos por todas las páginas.
   Paleta cream/ink/green · Anton / Lora / Inter.
   ═══════════════════════════════════════════════════════════════ */
:root {
  --bg:#FAF6EC; --surface:#FFFDF8; --cream-2:#F3ECD9; --cream-deep:#E3D9C4;
  --ink:#1A1B18; --ink-soft:#4D4A43; --muted:#7A7368; --muted-soft:#9C9588;
  --banner-bg:#24231E; --masthead-bg:#191915;
  --green:#567867; --green-700:#3F5E50; --green-soft:rgba(86,120,103,.10);
  --clay:#A67C52; --clay-soft:rgba(166,124,82,.08);
  --gold:#C9A24B;
  /* ── Marca personal de Medina (de su gráfica: carmesí + negro) ──
     El carmesí es SU acento; el verde sigue siendo el de la plataforma Acento. */
  --crimson:#E11D3C; --crimson-700:#B0132C; --crimson-soft:rgba(225,29,60,.10);
  --noir:#0F0F12; --noir-2:#17151A; --noir-line:#2A2530;
  --border:#D9D0C2; --border-soft:#E9E1D4;
  --ok:#567867; --warn:#C28A3A; --bad:#B24A3A;
  --display:"Anton",Impact,sans-serif; --serif:"Lora",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --shadow:0 14px 30px rgba(26,27,24,.10);
  --shadow-sm:0 4px 14px rgba(26,27,24,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.serif-i{font-family:var(--serif);font-style:italic}

/* ── Banner + masthead ── */
.banner{background:var(--banner-bg);color:#cdc6b6;font-family:var(--serif);font-style:italic;font-size:13px;text-align:center;padding:7px 16px;letter-spacing:.2px}
.masthead{background:var(--masthead-bg);color:#f4efe3;position:sticky;top:0;z-index:100}
.masthead .wrap{display:flex;align-items:center;height:64px}
.logo{font-family:var(--display);font-size:24px;letter-spacing:.5px;color:#fff;text-transform:uppercase;line-height:1}
.logo small{color:var(--crimson);font-size:24px}
.logo .craft{font-family:var(--serif);font-style:italic;font-weight:500;text-transform:none;color:var(--crimson);font-size:19px;letter-spacing:0;margin-left:7px}
.logo .by{display:block;font-family:var(--serif);font-style:italic;font-size:11px;letter-spacing:.3px;color:#9c9686;text-transform:none;margin-top:2px}
.masthead nav{margin-left:auto;display:flex;gap:24px;align-items:center}
.masthead nav a{font-size:13px;letter-spacing:.4px;color:#d8d2c4;text-transform:uppercase;font-weight:500}
.masthead nav a:hover{color:#fff}
.masthead nav a.active{color:#fff;border-bottom:2px solid var(--green);padding-bottom:4px}

/* ── Buttons ── */
.btn-wa,.btn-primary{background:var(--green);color:#fff;border:0;padding:13px 22px;border-radius:5px;font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;justify-content:center}
.btn-wa:hover,.btn-primary:hover{background:var(--green-700)}
.btn-ghost{padding:13px 18px;border:1px solid var(--border);background:transparent;border-radius:5px;font-weight:600;font-size:15px;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.btn-ghost:hover{background:var(--cream-2)}

/* ── Hero (microsite) ── */
.hero{padding:60px 0 36px;border-bottom:1px solid var(--border)}
.hero .kicker{font-family:var(--serif);font-style:italic;color:var(--crimson-700);font-size:18px;margin-bottom:10px}
.hero h1{font-family:var(--display);font-weight:400;font-size:clamp(42px,7.5vw,96px);line-height:.92;text-transform:uppercase;letter-spacing:-.5px;max-width:16ch}
.hero h1 em{font-family:var(--serif);font-style:italic;font-weight:500;text-transform:none;font-size:.6em;color:var(--crimson);letter-spacing:0}
.hero p.sub{font-family:var(--serif);font-size:19px;color:var(--ink-soft);max-width:50ch;margin-top:20px}

/* ── Reservar turno (booking builder) ── */
.quote{margin-top:28px;background:var(--surface);border:1.5px solid var(--ink);border-radius:6px;max-width:920px;box-shadow:6px 6px 0 var(--cream-deep);overflow:hidden}
.quote .row{display:flex;flex-wrap:wrap}
.quote .field{flex:1;min-width:160px;padding:14px 18px;border-right:1px solid var(--border)}
.quote .field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:600;margin-bottom:5px}
.quote .field select,.quote .field input{border:0;background:transparent;font-family:var(--sans);font-size:15px;color:var(--ink);width:100%;outline:none;cursor:pointer}
.quote .cta{display:block;width:100%;background:var(--green);color:#fff;border:0;padding:16px;font-family:var(--display);font-size:18px;letter-spacing:1px;text-transform:uppercase;cursor:pointer}
.quote .cta:hover{background:var(--green-700)}
.quote .cta:disabled{background:var(--muted-soft);cursor:not-allowed}
.quote .hint{padding:10px 18px;font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--muted);border-top:1px solid var(--border-soft);background:var(--cream-2)}

/* ── Trust band ── */
.trust{margin-top:18px;display:flex;flex-wrap:wrap;gap:26px;font-size:14px;color:var(--muted);font-family:var(--serif)}
.trust b{color:var(--ink);font-family:var(--sans);font-weight:600}

/* ── Section heads ── */
.section-head{display:flex;align-items:baseline;gap:18px;margin:48px 0 6px}
.section-head h2{font-family:var(--display);font-weight:400;font-size:30px;text-transform:uppercase;letter-spacing:.3px}
.section-head .line{flex:1;height:1px;background:var(--border)}
.section-head .more{font-family:var(--serif);font-style:italic;color:var(--green-700);font-size:15px}

/* ── Cards grid (especialidades) ── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:26px 0}
.svc-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px;transition:.18s}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.svc-card .ic{font-size:30px;display:block;margin-bottom:12px}
.svc-card h3{font-family:var(--serif);font-weight:600;font-size:20px;margin-bottom:8px}
.svc-card p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}

/* ── Cómo funciona (pasos) ── */
.pasos{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:26px 0}
.paso{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:26px 24px;position:relative}
.paso .num{font-family:var(--display);font-size:46px;line-height:.8;color:var(--green);opacity:.35}
.paso h3{font-family:var(--serif);font-weight:600;font-size:19px;margin:10px 0 8px}
.paso p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}

/* ── Agentforce band ── */
.af{background:var(--banner-bg);border-radius:10px;padding:42px 36px;margin:40px 0;color:#f1ebdd}
.af .af-eyebrow{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:16px}
.af h3{font-family:var(--display);font-weight:400;font-size:clamp(26px,4vw,38px);text-transform:uppercase;line-height:1;margin:6px 0 8px}
.af .af-sub{font-family:var(--serif);color:#c9c2b2;font-size:17px;max-width:62ch;margin-bottom:24px}
.af-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.af-card{border:1px solid #3a382f;border-radius:8px;padding:20px;background:rgba(255,253,248,.03)}
.af-card .ic{font-size:24px;display:block;margin-bottom:10px}
.af-card h4{font-family:var(--serif);font-weight:600;font-size:16.5px;margin-bottom:6px;color:#f4efe3}
.af-card p{font-size:13.5px;color:#b7b1a3;line-height:1.55}
.af-foot{margin-top:22px;font-family:var(--serif);font-style:italic;color:#9c9686;font-size:14px}
.af-foot b{color:#f4efe3;font-style:normal;font-weight:600}

/* ── Profesionales (roster) ── */
.muestra-tag{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--clay);background:var(--clay-soft);border:1px dashed var(--clay);border-radius:999px;padding:4px 11px;font-weight:600}
.prof-roster{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:26px 0}
.prof-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:24px;display:flex;flex-direction:column;gap:6px}
.prof-card .top{display:flex;gap:16px;align-items:center;margin-bottom:6px}
.prof-card .av{width:56px;height:56px;border-radius:50%;background:var(--green-soft);color:var(--green-700);display:grid;place-items:center;font-family:var(--display);font-size:22px;flex-shrink:0}
.prof-card .name{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.1}
.prof-card .esp{font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--clay);font-weight:600;margin-top:3px}
.prof-card .mat{font-size:12.5px;color:var(--muted-soft);margin-top:2px}
.prof-card .bio{font-size:14.5px;color:var(--ink-soft);line-height:1.6;margin:4px 0}
.prof-card .meta{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:3px;margin-top:4px}
.prof-card .meta .k{text-transform:uppercase;font-size:10.5px;letter-spacing:.6px;color:var(--muted-soft)}
.prof-card .wa{margin-top:14px}

/* ── Obras sociales ── */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin:18px 0}
.chips span{border:1px solid var(--border);background:var(--surface);border-radius:999px;padding:7px 15px;font-size:13px;color:var(--ink-soft)}

/* ── Heritage / dato band ── */
.heritage{margin:54px 0;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.heritage .big{font-family:var(--display);font-size:clamp(64px,11vw,140px);line-height:.85;color:var(--green-700);text-transform:uppercase}
.heritage .big small{display:block;font-family:var(--serif);font-style:italic;font-size:20px;color:var(--clay);text-transform:none;margin-top:10px}
.heritage p{font-family:var(--serif);font-size:18px;line-height:1.7;color:var(--ink-soft)}

/* ── Publish / CTA band ── */
.cta-band{margin:54px 0;background:var(--green);color:#fff;border-radius:10px;padding:40px 44px;display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.cta-band h3{font-family:var(--display);font-weight:400;font-size:32px;text-transform:uppercase;line-height:1}
.cta-band p{font-family:var(--serif);font-style:italic;color:#e6efe9;margin-top:8px;font-size:16px}
.cta-band .acts{margin-left:auto;display:flex;gap:12px}
.cta-band .acts .p1{background:#fff;color:var(--green-700);border:0;padding:14px 26px;border-radius:5px;font-weight:600;cursor:pointer;font-size:15px}
.cta-band .acts .p2{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);padding:14px 22px;border-radius:5px;font-weight:600;cursor:pointer;font-size:15px}

/* ── Footer ── */
.foot-pub{background:var(--masthead-bg);color:#c9c3b4;margin-top:40px;padding:54px 0 28px}
.foot-pub .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.foot-pub .logo{margin-bottom:14px}
.foot-pub p.desc{font-family:var(--serif);font-size:15px;max-width:36ch;color:#9c9686;line-height:1.6}
.foot-pub h4{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:#7d776a;margin-bottom:16px}
.foot-pub ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px}
.foot-pub ul a:hover{color:#fff}
.foot-pub .rule{height:1px;background:#33322c;margin:38px 0 18px}
.foot-pub .legal{font-size:12.5px;color:#6f6a5e;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.foot-pub .legal a:hover{color:#cdc6b6}

/* ════════ PERFIL (Acento profile parity) ════════ */
.prof{padding:30px 0 60px}
.crumb{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;margin-bottom:18px}
.crumb a:hover{color:var(--green-700)}
.prof-hero{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:21/9;display:grid;place-items:center;font-family:var(--display);font-size:90px;color:rgba(255,253,248,.92)}
.prof-hero .rate{position:absolute;left:22px;bottom:22px;background:var(--surface);border-radius:4px;padding:8px 14px;font-weight:600;color:var(--ink);display:flex;gap:8px;align-items:center;font-size:15px}
.prof-hero .gal{position:absolute;right:18px;bottom:18px;background:rgba(25,25,21,.7);color:#fff;font-size:13px;padding:7px 14px;border-radius:4px}
.prof-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;margin-top:34px}
.prof-title .cat-lbl{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:var(--clay);font-weight:600}
.prof-title h1{font-family:var(--display);font-weight:400;font-size:clamp(38px,6vw,62px);text-transform:uppercase;line-height:.96;margin:8px 0}
.prof-status{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font-size:14px;color:var(--muted);font-family:var(--serif)}
.open-dot{color:var(--green);font-weight:700;font-family:var(--sans)}
.lead{font-family:var(--serif);font-size:20px;line-height:1.55;color:var(--ink-soft);margin:26px 0;max-width:54ch}
.prof h2.blk{font-family:var(--display);font-weight:400;font-size:24px;text-transform:uppercase;margin:40px 0 14px;letter-spacing:.3px}
.prof .about{font-family:var(--serif);font-size:16.5px;line-height:1.7;color:var(--ink-soft);max-width:60ch}
.svc-rows{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 30px;margin-top:8px}
.svc-rows li{padding:13px 0;border-bottom:1px solid var(--border-soft);display:flex;justify-content:space-between;font-size:15px;gap:14px}
.svc-rows li b{font-weight:600}
.contact{position:sticky;top:88px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px}
.contact .price{font-family:var(--serif);font-size:15px;color:var(--muted);margin-bottom:16px}
.contact .price b{font-family:var(--display);font-weight:400;font-size:26px;color:var(--ink);display:block}
.contact .wa{display:block;width:100%;background:var(--green);color:#fff;border:0;padding:15px;border-radius:5px;font-weight:600;font-size:16px;cursor:pointer;text-align:center}
.contact .wa:hover{background:var(--green-700)}
.contact .row2{display:flex;gap:10px;margin-top:10px}
.contact .row2 a{flex:1;background:transparent;border:1px solid var(--border);border-radius:5px;padding:12px;font-weight:600;cursor:pointer;color:var(--ink);text-align:center;font-size:14px}
.contact dl{margin-top:20px;border-top:1px solid var(--border-soft);padding-top:18px;font-size:14px}
.contact dt{text-transform:uppercase;font-size:11px;letter-spacing:.8px;color:var(--muted);margin-top:12px}
.contact dd{color:var(--ink);margin-top:3px}

/* ════════ PANEL BI ════════ */
.panel-head{padding:30px 0 0}
.panel-head .eyebrow{font-family:var(--serif);font-style:italic;color:var(--green-700);font-size:16px}
.panel-head h1{font-family:var(--display);font-weight:400;font-size:clamp(34px,6vw,56px);text-transform:uppercase;line-height:.96;margin:6px 0}
.panel-head .demo-tag{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--clay);background:var(--clay-soft);border:1px solid var(--border);border-radius:999px;padding:5px 12px;font-weight:600}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:28px 0}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:20px}
.kpi .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600}
.kpi .val{font-family:var(--display);font-weight:400;font-size:40px;line-height:1;margin:10px 0 6px}
.kpi .delta{font-size:13px;font-weight:600}
.kpi .delta.up{color:var(--ok)} .kpi .delta.down{color:var(--bad)}
.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0}
.card-bi{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:22px}
.card-bi.full{grid-column:1 / -1}
.card-bi h3{font-family:var(--serif);font-weight:600;font-size:17px;margin-bottom:4px}
.card-bi .cap{font-size:13px;color:var(--muted);margin-bottom:16px}
.bars{display:flex;flex-direction:column;gap:10px}
.bar-row{display:grid;grid-template-columns:160px 1fr 44px;align-items:center;gap:12px;font-size:13.5px}
.bar-row .track{height:18px;background:var(--cream-2);border-radius:4px;overflow:hidden}
.bar-row .fill{height:100%;background:var(--green);border-radius:4px}
.bar-row .n{text-align:right;font-weight:600;color:var(--ink)}
.heat{display:flex;flex-direction:column;gap:8px}
.heat-row{display:grid;grid-template-columns:150px 1fr 54px;align-items:center;gap:12px;font-size:13.5px}
.heat-cell{height:26px;border-radius:4px}
.funnel{display:flex;flex-direction:column;gap:10px}
.funnel-step{position:relative;background:var(--cream-2);border-radius:5px;overflow:hidden;padding:12px 16px;font-size:14px;display:flex;justify-content:space-between;align-items:center}
.funnel-step .fbar{position:absolute;inset:0;background:var(--green-soft);border-left:3px solid var(--green)}
.funnel-step .lbl,.funnel-step .n{position:relative;z-index:1}
.funnel-step .n{font-weight:700}
.funnel-step .conv{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:12.5px;margin-left:8px}
.bi-note{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:13.5px;margin-top:6px}

/* ════════ PROPUESTA / PRICING ════════ */
.pricing{padding:30px 0 50px}
.pricing-head h1{font-family:var(--display);font-weight:400;font-size:clamp(34px,6vw,60px);text-transform:uppercase;line-height:.96}
.pricing-head .sub{font-family:var(--serif);font-size:19px;color:var(--ink-soft);max-width:54ch;margin-top:12px}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:34px 0}
.plan{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:28px}
.plan.hot{border:2px solid var(--green);box-shadow:var(--shadow)}
.plan .name{font-family:var(--display);font-size:26px;text-transform:uppercase}
.plan .tagline{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;margin-top:4px}
.plan .price{margin:18px 0}
.plan .price .big{font-family:var(--display);font-size:40px;line-height:1}
.plan .price .per{color:var(--muted);font-size:14px}
.plan .price .setup{font-size:13.5px;color:var(--ink-soft);margin-top:4px}
.plan ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:10px;font-size:14.5px}
.plan ul li{display:flex;gap:9px;align-items:flex-start}
.plan ul li .ck{color:var(--green);font-weight:700}
.plan ul li.no{color:var(--muted-soft)}
.plan ul li.no .ck{color:var(--muted-soft)}
.plan .ribbon{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.7px;background:var(--green);color:#fff;border-radius:999px;padding:4px 12px;font-weight:600;margin-bottom:10px}
.todo-flag{background:var(--clay-soft);border:1px dashed var(--clay);color:var(--clay);border-radius:5px;padding:3px 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}

/* one-pager (print) */
.onepager{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:34px;margin:30px 0}
.onepager h2{font-family:var(--display);font-size:28px;text-transform:uppercase;margin-bottom:6px}
.onepager .gain{display:grid;grid-template-columns:1fr 1fr;gap:12px 26px;margin-top:18px}
.onepager .gain .g{display:flex;gap:10px;font-size:14.5px;padding:10px 0;border-bottom:1px solid var(--border-soft)}
.onepager .gain .g .ic{color:var(--green);font-weight:700}
.print-hint{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:13.5px;margin-top:10px}

/* ════════ CALENDARIO DE TURNOS — la franja "de Medina" ════════
   La única sección en su marca personal: negro + carmesí + trama de puntos,
   como su gráfica de Instagram. Pensada también para sacarle captura. */
.cal{position:relative;overflow:hidden;background:var(--noir);color:#F4EFF0;border-radius:12px;margin:46px 0;padding:40px 34px 30px;
  background-image:radial-gradient(rgba(225,29,60,.18) 1px, transparent 1.5px);background-size:15px 15px}
.cal::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 88% -12%, rgba(225,29,60,.30), transparent 58%);pointer-events:none}
.cal>*{position:relative;z-index:1}
.cal-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.cal-emblem{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--crimson);display:grid;place-items:center;flex-shrink:0;color:var(--crimson)}
.cal-emblem svg{width:25px;height:25px;display:block}
.cal-head .ht h2{font-family:var(--display);font-weight:400;font-size:clamp(26px,4.4vw,44px);text-transform:uppercase;line-height:.95}
.cal-head .ht .cal-sub{font-family:var(--serif);font-style:italic;color:#C7BFC2;font-size:14.5px;margin-top:4px;max-width:48ch}
.cal-head .cal-when{margin-left:auto;font-family:var(--display);color:var(--crimson);font-size:14px;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--noir-line);border-radius:999px;padding:8px 16px;white-space:nowrap}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:9px;align-items:start}
.cal-col{background:rgba(255,255,255,.03);border:1px solid var(--noir-line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}
.cal-col .day{background:var(--crimson);color:#fff;font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:12.5px;letter-spacing:.4px;text-align:center;padding:9px 4px}
.cal-col.off .day{background:var(--noir-2);color:#8a8390}
.cal-slots{display:flex;flex-direction:column;padding:7px;gap:1px}
.cal-slot{font-size:13.5px;color:#E7E1E3;text-align:center;padding:6px 4px;border-radius:5px;font-variant-numeric:tabular-nums;font-weight:500;transition:.14s}
.cal-slot:hover{background:var(--crimson);color:#fff}
.cal-break{font-family:var(--serif);font-style:italic;font-size:11px;color:var(--crimson);text-transform:uppercase;letter-spacing:.5px;text-align:center;padding:5px 0;border-top:1px dashed var(--noir-line);border-bottom:1px dashed var(--noir-line);margin:3px 4px}
.cal-closed{display:grid;place-items:center;color:#7c7682;font-family:var(--serif);font-style:italic;font-size:13.5px;text-align:center;padding:26px 6px}
.cal-closed .x{font-family:var(--display);font-size:30px;color:var(--crimson);display:block;margin-bottom:6px;line-height:1}
/* Las tres reglas de la casa */
.cal-rules{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:26px;border-top:1px solid var(--noir-line);padding-top:22px}
.cal-rule{display:flex;gap:13px;align-items:baseline}
.cal-rule .n{font-family:var(--display);color:var(--crimson);font-size:22px;line-height:1;flex-shrink:0}
.cal-rule b{display:block;font-weight:600;font-size:15px;color:#fff;letter-spacing:.2px}
.cal-rule span{font-family:var(--serif);font-style:italic;font-size:13.5px;color:#aaa1a7}
.cal-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:24px}
.cal-foot .note{font-family:var(--serif);font-style:italic;color:#a39ba0;font-size:13.5px;max-width:48ch}
.cal-cta{background:var(--crimson);color:#fff;border:0;padding:13px 22px;border-radius:6px;font-weight:600;font-size:15px;display:inline-flex;gap:8px;align-items:center;white-space:nowrap}
.cal-cta:hover{background:var(--crimson-700)}

/* ── Responsive ── */
@media(max-width:900px){
  .masthead nav{gap:14px}
  .masthead nav a{font-size:11.5px}
  .grid-3,.pasos,.af-grid{grid-template-columns:1fr 1fr}
  .prof-roster,.heritage,.compare,.panel-grid,.kpis,.onepager .gain{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .prof-grid{grid-template-columns:1fr}
  .contact{position:static}
  .foot-pub .cols{grid-template-columns:1fr 1fr}
  .cta-band .acts{margin-left:0;width:100%}
}
@media(max-width:560px){
  .grid-3,.pasos,.af-grid,.kpis{grid-template-columns:1fr}
  .quote .field{border-right:0;border-bottom:1px solid var(--border)}
  .bar-row,.heat-row{grid-template-columns:110px 1fr 40px}
}
/* Calendario: en celular, cada día es una fila con sus horas — formato afiche */
@media(max-width:760px){
  .cal{padding:30px 18px 24px}
  .cal-head .cal-when{margin-left:0}
  .cal-grid{grid-template-columns:1fr;gap:8px}
  .cal-col{flex-direction:row;align-items:stretch}
  .cal-col .day{display:flex;align-items:center;justify-content:center;min-width:108px;border-right:1px solid var(--noir-line)}
  .cal-col.off .day{border-right:1px solid var(--noir-line)}
  .cal-slots{flex-direction:row;flex-wrap:wrap;align-content:center;flex:1;gap:6px}
  .cal-slot{border:1px solid var(--noir-line);min-width:54px}
  .cal-break{border:1px dashed var(--crimson);border-radius:5px;padding:5px 9px;margin:0;align-self:center}
  .cal-closed{padding:12px 8px}
  .cal-closed .x{display:inline;font-size:18px;margin:0 8px 0 0;vertical-align:-1px}
  .cal-rules{grid-template-columns:1fr;gap:12px}
}

/* ── Print: one-pager only ── */
@media print{
  .masthead,.banner,.foot-pub,.cta-band,.no-print{display:none !important}
  body{background:#fff}
  .onepager{border:0;box-shadow:none;padding:0;margin:0}
  .wrap{max-width:100%;padding:0}
  @page{margin:14mm}
}
