/*
Theme Name: Strategik
Theme URI: https://strategik.es/
Author: Strategik B&F Consulting
Description: Tema corporativo de Strategik B&F Consulting. Portado de la app comercial: Consultoría Inmersiva, 5 áreas de servicio, método, casos y blog. Diseño a medida, azul #2C5EFB, tipografía Manrope.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: strategik
*/

:root{
  --blue:#2C5EFB; --blue-deep:#1A3FBF; --blue-soft:#F0F4FF; --blue-line:#D6E0FF;
  --ink:#0A0E1A; --ink-2:#2A3142; --ink-3:#5A6376; --ink-4:#8A92A6;
  --paper:#FFFFFF; --paper-2:#FAFAFB; --line:#E8EAF0; --line-soft:#F2F3F7;
  --tint:#050813;
  --font:'Manrope',-apple-system,BlinkMacSystemFont,system-ui,'Segoe UI',sans-serif;
  --mono:ui-monospace,'SF Mono','IBM Plex Mono',Menlo,monospace;
  --wrap:1180px; --pad:clamp(20px,5vw,44px); --hh:66px;
  --r:14px; --r-lg:24px;
  --shadow:0 4px 14px rgba(44,94,251,.25);
  --shadow-soft:0 10px 40px rgba(10,14,26,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:0;background:none}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:6px}

/* ===== HEADER ===== */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:20px;height:var(--hh)}
.brand{display:flex;align-items:center;gap:10px}
.brand .mark{width:30px;height:24px}
.brand .wm{font-weight:800;font-size:1.12rem;letter-spacing:-.02em}
.brand .wm small{font-weight:600;font-size:.5rem;letter-spacing:.06em;color:var(--ink-4);text-transform:uppercase;display:block;line-height:1.1;margin-top:1px}
.nav{margin-left:auto;display:flex;gap:4px}
.nav button{color:var(--ink-2);font-size:.9rem;font-weight:600;padding:8px 12px;border-radius:8px;position:relative;transition:color .2s,background .2s}
.nav button:hover{color:var(--blue);background:var(--blue-soft)}
.nav button.on{color:var(--blue)}
.nav button.on::after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;background:var(--blue);border-radius:2px}
.hdr-cta{display:inline-flex;align-items:center;gap:7px;background:var(--blue);color:#fff;font-weight:700;font-size:.85rem;padding:9px 16px;border-radius:10px;box-shadow:var(--shadow);transition:transform .18s,background .2s;white-space:nowrap}
.hdr-cta:hover{transform:translateY(-1px);background:var(--blue-deep)}
.burger{display:none;margin-left:auto;width:42px;height:42px;border-radius:10px;color:var(--ink);align-items:center;justify-content:center}
.burger svg{width:22px;height:22px}

/* ===== VIEWS ===== */
.view{display:none;animation:fade .45s ease both}
.view.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.view{animation:none}}
.eyebrow{display:inline-block;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:var(--blue-soft);padding:7px 13px;border-radius:6px;margin-bottom:14px}
.eyebrow::before{content:none}
h1,h2,h3{letter-spacing:-.025em;line-height:1.08}
.sec-h{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:800;margin:14px 0 12px}
.sec-lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--ink-3);max-width:60ch;font-weight:500}
.sec-pad{padding:clamp(48px,7vw,84px) 0}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#FFFFFF 0%,#FAFAFB 100%);color:var(--ink)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-in{position:relative;z-index:1;padding:clamp(52px,8vw,96px) 0 clamp(40px,5vw,56px)}
.hero h1{font-size:clamp(2.1rem,5.4vw,3.9rem);font-weight:800;max-width:16ch;margin:20px 0 18px}
.hero h1 em{font-style:normal;color:var(--blue);font-weight:800}
.hero .lead{font-size:clamp(1.02rem,1.7vw,1.28rem);color:var(--ink-3);max-width:52ch;font-weight:400}
.hero .eyebrow{color:var(--blue)}
.hero .eyebrow::before{background:var(--blue)}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.98rem;padding:14px 24px;border-radius:12px;transition:transform .18s,background .2s,border-color .2s}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 6px 22px rgba(44,94,251,.30)}
.btn-primary:hover{transform:translateY(-2px);background:#3d6bff}
.btn-ghost{background:transparent;color:var(--blue);border:1.5px solid var(--blue-line)}
.btn-ghost:hover{border-color:var(--blue);background:var(--blue-soft)}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:34px}
.pill{font-size:.76rem;font-weight:600;color:var(--ink-2);border:1px solid var(--line);padding:6px 13px;border-radius:100px;letter-spacing:.01em}
.pill.iso{background:var(--blue-soft);border-color:transparent;color:var(--blue)}

/* hero mini-stepper */
.mini-steps{display:flex;flex-wrap:wrap;gap:0;margin-top:44px;border-top:1px solid var(--line);padding-top:22px}
.mini-steps .ms{flex:1 1 140px;min-width:120px;position:relative;padding-right:14px}
.mini-steps .ms .n{font-family:var(--mono);font-size:.78rem;color:var(--blue);font-weight:600}
.mini-steps .ms .t{font-weight:700;font-size:.98rem;margin-top:2px}
.mini-steps .ms::after{content:"/";position:absolute;right:6px;top:0;color:var(--ink-4)}
.mini-steps .ms:last-child::after{display:none}

/* ===== PROOF BAND ===== */
.proof{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.proof-in{padding:clamp(34px,5vw,52px) 0;display:grid;grid-template-columns:1.1fr 2fr;gap:34px;align-items:center;position:relative;z-index:1}
.proof .lede{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}
.proof .lede span{color:var(--blue)}
.proof .sub{color:var(--ink-3);font-size:.96rem;margin-top:8px;max-width:32ch}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.metric .v{font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:800;letter-spacing:-.03em;line-height:1}
.metric .v small{font-size:.55em;color:var(--blue);font-weight:700}
.metric .l{color:var(--ink-3);font-size:.82rem;font-weight:600;margin-top:6px;line-height:1.35}
.metric.iso-cell{display:flex;align-items:center}
.metric.iso-cell img{height:117px;width:auto}
.grid-4 .acard--wide{grid-column:1 / -1}
.acard .tag-new{position:absolute;top:18px;right:18px;font-family:var(--mono);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--accent,var(--blue));padding:4px 10px;border-radius:100px;z-index:2}
.partner-note{display:flex;align-items:center;gap:11px;margin:24px 0 2px;padding:13px 17px;background:var(--accent-soft,var(--blue-soft));border:1px solid var(--accent-line,var(--blue-line));border-radius:var(--r);color:var(--ink-2);font-size:.9rem;font-weight:600}
.partner-note b{color:var(--accent-deep,var(--blue-deep));font-weight:800}

/* ===== CARDS GRID (areas) ===== */
.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:40px}
.acard{position:relative;text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px;transition:transform .2s,box-shadow .2s,border-color .2s;overflow:hidden}
.acard::before{content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;background:var(--accent-soft,var(--blue-soft));clip-path:polygon(100% 0,100% 100%,0 100%);opacity:0;transition:opacity .25s}
.acard:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--accent-line,var(--blue-line))}
.acard:hover::before{opacity:1}
.acard .n{font-family:var(--mono);font-size:.8rem;font-weight:600;color:var(--accent,var(--blue))}
.acard h3{font-size:1.4rem;font-weight:800;margin:12px 0 8px}
.acard p{color:var(--ink-3);font-size:.96rem}
.acard .more{position:relative;z-index:1;margin-top:18px;display:inline-flex;align-items:center;gap:7px;color:var(--accent,var(--blue));font-weight:700;font-size:.9rem}
.acard:hover .more{gap:11px}

/* ===== AREA DETAIL ===== */
.back{display:inline-flex;align-items:center;gap:8px;color:var(--ink-3);font-weight:600;font-size:.9rem;padding:8px 0;transition:color .2s}
.back:hover{color:var(--blue)}
.area-head{display:flex;align-items:flex-start;gap:20px;margin:8px 0 6px}
.area-head .bignum{font-family:var(--mono);font-weight:700;font-size:clamp(2.4rem,6vw,4rem);color:var(--accent-line,var(--blue-line));line-height:.9}
.when{background:var(--accent-soft,var(--blue-soft));border:1px solid var(--accent-line,var(--blue-line));border-radius:var(--r-lg);padding:24px 26px;margin:26px 0}
.when h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-deep,var(--blue-deep));margin-bottom:14px;font-family:var(--mono)}
.when ul{list-style:none;display:grid;gap:10px}
.when li{display:flex;gap:11px;font-weight:600;color:var(--ink-2);font-size:1rem}
.when li::before{content:"";flex:0 0 auto;width:9px;height:9px;margin-top:8px;background:var(--accent,var(--blue));transform:rotate(45deg)}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-top:8px}
.svc{text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:border-color .2s,background .2s,transform .15s}
.svc:hover{border-color:var(--accent,var(--blue));background:var(--accent-soft,var(--blue-soft));transform:translateX(2px)}
.svc .sn{font-weight:700;font-size:.98rem;color:var(--ink)}
.svc .arr{color:var(--accent,var(--blue));font-weight:700;flex:0 0 auto}

/* ===== METHOD ===== */
.method-top{display:grid;grid-template-columns:1.15fr 1fr;gap:40px;align-items:center}
.video{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-soft);background:var(--tint);aspect-ratio:16/9}
.video video{width:100%;height:100%;object-fit:cover;display:block}
.video .badge{position:absolute;left:14px;top:14px;z-index:2;background:rgba(5,8,19,.7);color:#fff;font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.08em;padding:6px 11px;border-radius:100px}
.steps{margin-top:52px;display:grid;gap:0;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:88px 1fr 1fr;gap:24px;padding:28px 6px;border-bottom:1px solid var(--line);align-items:start}
.step .sn{font-family:var(--mono);font-size:1.7rem;font-weight:700;color:var(--blue)}
.step h4{font-size:1.25rem;font-weight:800;margin-bottom:6px}
.step p{color:var(--ink-3);font-size:.97rem}
.step .deliver{align-self:center}
.step .deliver .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);display:block;margin-bottom:6px}
.step .deliver .v{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--ink);background:var(--blue-soft);border:1px solid var(--blue-line);padding:9px 15px;border-radius:100px;font-size:.9rem}

/* ===== NEEDS ===== */
.needs{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:40px}
.need{text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:box-shadow .2s,border-color .2s;position:relative}
.need.open{border-color:var(--blue-line);box-shadow:var(--shadow-soft)}
.need .q{font-size:1.14rem;font-weight:800;letter-spacing:-.02em;line-height:1.25;padding-right:24px}
.need .q::before{content:"“";color:var(--blue-line);font-size:2rem;line-height:0;position:relative;top:10px;margin-right:2px}
.need .plus{position:absolute;top:24px;right:22px;color:var(--blue);font-weight:800;font-size:1.3rem;transition:transform .25s}
.need.open .plus{transform:rotate(45deg)}
.need .body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.need.open .body{max-height:340px}
.need .body-in{padding-top:18px}
.need .body-in .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:11px}
.need .chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:.85rem;font-weight:600;color:var(--accent-deep,var(--blue-deep));background:var(--accent-soft,var(--blue-soft));border:1px solid var(--accent-line,var(--blue-line));padding:8px 13px;border-radius:100px;transition:filter .2s}
.chip:hover{filter:brightness(0.96)}

/* ===== CASES ===== */
.cases{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;margin-top:40px}
.case{text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.case:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.case .top{background:var(--tint);color:#fff;padding:24px 24px 20px;position:relative;overflow:hidden}
.case .top::after{content:"";position:absolute;right:-20px;bottom:-40px;width:130px;height:130px;background:var(--blue);opacity:.5;clip-path:polygon(100% 0,100% 100%,0 100%)}
.case .tag{position:relative;z-index:1;font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#9fb6ff}
.case .big{position:relative;z-index:1;font-size:2.2rem;font-weight:800;letter-spacing:-.03em;margin-top:12px;line-height:1}
.case .bigl{position:relative;z-index:1;color:rgba(255,255,255,.7);font-size:.86rem;font-weight:600;margin-top:4px}
.case .bd{padding:22px 24px 24px;flex:1;display:flex;flex-direction:column}
.case .bd h3{font-size:1.16rem;font-weight:800;line-height:1.25;margin-bottom:8px}
.case .bd p{color:var(--ink-3);font-size:.92rem;flex:1}
.case .bd .more{margin-top:16px;color:var(--blue);font-weight:700;font-size:.9rem;display:inline-flex;gap:7px}
.blog-tools{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;margin-top:36px}
.blog-filters{display:flex;flex-wrap:wrap;gap:8px}
.blog-fbtn{all:unset;cursor:pointer;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--line);border-radius:999px;padding:8px 15px;transition:all .2s;white-space:nowrap}
.blog-fbtn:hover{border-color:var(--blue-line);color:var(--blue-deep)}
.blog-fbtn.on{background:var(--blue);border-color:var(--blue);color:#fff}
.blog-search input{font-family:var(--font);font-size:.9rem;border:1px solid var(--line);border-radius:999px;padding:9px 18px;min-width:240px;outline:none;transition:border-color .2s;color:var(--ink);background:var(--paper)}
.blog-search input:focus{border-color:var(--blue)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:26px}
.bcard{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s}
.bcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--blue-line)}
.bcard .thumb{aspect-ratio:16/9;background:var(--paper-2) center/cover no-repeat;position:relative}
.bcard .thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,19,0) 55%,rgba(5,8,19,.22));opacity:0;transition:opacity .2s}
.bcard:hover .thumb::after{opacity:1}
.bcard .bd{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.bcard .meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.bcard .cat{font-family:var(--mono);font-size:.64rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);background:var(--blue-soft);border-radius:999px;padding:4px 10px}
.bcard .date{font-family:var(--mono);font-size:.68rem;color:var(--ink-4);font-weight:600}
.bcard h3{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;line-height:1.3;margin-bottom:9px}
.bcard p{color:var(--ink-3);font-size:.9rem;line-height:1.55;flex:1}
.bcard .more{margin-top:16px;color:var(--blue);font-weight:700;font-size:.88rem;display:inline-flex;gap:7px;align-items:center}
.blog-empty{margin-top:40px;color:var(--ink-3);font-weight:500}
@media(max-width:560px){.blog-tools{flex-direction:column;align-items:stretch}.blog-search input{width:100%;min-width:0}}

/* ===== CTA / HABLEMOS ===== */
.cta-final{background:linear-gradient(135deg,#EEF3FF 0%,#F7FAFF 100%);color:var(--ink);border:1px solid var(--blue-line);border-radius:var(--r-lg);padding:clamp(38px,6vw,64px);position:relative;overflow:hidden}
.cta-final::after{content:"";position:absolute;right:-4%;top:-30%;width:46%;height:160%;background:linear-gradient(150deg,#DDE7FF,#EEF3FF);clip-path:polygon(40% 0,100% 0,100% 100%,0 100%);opacity:.85}
.cta-final .in{position:relative;z-index:1;max-width:60ch}
.cta-final h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:14px}
.cta-final p{color:var(--ink-3);font-size:1.08rem;max-width:46ch}
.contact-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.contact-row .btn-primary:hover{background:#3d6bff}
.contact-info{display:flex;flex-wrap:wrap;gap:26px;margin-top:34px;position:relative;z-index:1}
.contact-info a,.contact-info span{color:var(--ink-2);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:8px}
.contact-info a:hover{color:var(--blue)}

/* ===== MODAL (service fiche) ===== */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:flex-end;justify-content:center}
.modal.on{display:flex}
.modal .ov{position:absolute;inset:0;background:rgba(5,8,19,.55);backdrop-filter:blur(3px);animation:fade .3s}
.modal .box{position:relative;background:var(--paper);width:100%;max-width:640px;max-height:90vh;overflow:auto;border-radius:var(--r-lg) var(--r-lg) 0 0;padding:34px clamp(24px,5vw,42px) 40px;animation:slideup .35s cubic-bezier(.2,.8,.2,1)}
@keyframes slideup{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
@media (min-width:720px){.modal{align-items:center}.modal .box{border-radius:var(--r-lg)}}
.modal .x{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;background:var(--line-soft);color:var(--ink-2);font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal .x:hover{background:var(--line)}
.modal .m-eye{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--blue))}
.modal h3{font-size:1.7rem;font-weight:800;margin:8px 0 4px}
.modal .what{color:var(--ink-3);font-size:1.02rem;margin-bottom:22px}
.modal .block{margin-top:20px}
.modal .block .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:9px}
.modal .prob{background:var(--paper-2);border-left:3px solid var(--accent,var(--blue));padding:14px 16px;border-radius:0 var(--r) var(--r) 0;color:var(--ink-2);font-weight:600}
.modal .bens{list-style:none;display:grid;gap:9px}
.modal .bens li{display:flex;gap:11px;color:var(--ink-2);font-weight:500}
.modal .bens li::before{content:"";flex:0 0 auto;width:8px;height:8px;margin-top:8px;background:var(--accent,var(--blue));transform:rotate(45deg)}
.modal .pitch{background:var(--tint);color:#fff;border-radius:var(--r);padding:18px 20px;font-size:1.06rem;font-weight:700;font-style:italic;line-height:1.4}
.modal .pitch::before{content:"“";color:var(--accent,var(--blue));font-weight:800}
.modal .pitch::after{content:"”";color:var(--accent,var(--blue));font-weight:800}
.modal .m-cta{display:inline-flex;align-items:center;gap:8px;margin-top:24px;background:var(--accent,var(--blue));color:#fff;font-weight:700;padding:13px 22px;border-radius:11px;box-shadow:var(--shadow)}
.modal .m-cta:hover{background:var(--accent-deep,var(--blue-deep))}

/* ===== FOOTER ===== */
.ft{border-top:1px solid var(--line);padding:26px 0;color:var(--ink-4);font-size:.82rem;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center}

/* ===== BRAND ASSETS ===== */
.logo-img{height:30px;width:auto;display:block}
.brand{gap:0}
.hero-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 30%;opacity:.07;filter:contrast(1.02)}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,.9) 0%,rgba(238,243,255,.5) 45%,rgba(255,255,255,.12) 100%)}
.film-ref{margin-top:16px;color:var(--ink-2);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:8px}
.film-ref b{color:var(--ink)}
.video figcaption{margin-top:12px;text-align:center;color:var(--ink-4);font-size:.8rem;font-family:var(--mono);letter-spacing:.06em}
.logo-cta{height:28px;width:auto;margin-top:36px;position:relative;z-index:1;opacity:.95}
.ft-brand{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}
.logo-ft{height:19px;width:auto;vertical-align:middle}

.view[data-view="metodo"] .wrap{position:relative}
.flow{position:absolute;top:8px;left:0;width:100%;height:230px;z-index:0;pointer-events:none;-webkit-mask-image:linear-gradient(90deg,transparent,#000 20%,#000 80%,transparent);mask-image:linear-gradient(90deg,transparent,#000 20%,#000 80%,transparent)}
.flow-home{top:0;height:100%;opacity:.8}
@media (prefers-reduced-motion:no-preference){.flow{animation:drift 18s ease-in-out infinite alternate}}
@keyframes drift{from{transform:translateX(0)}to{transform:translateX(-26px)}}
.view[data-view="metodo"] .eyebrow,.view[data-view="metodo"] .method-top,.view[data-view="metodo"] .steps{position:relative;z-index:1}
.method-narr{margin-top:14px;color:var(--ink-3);font-size:1rem;font-weight:500;max-width:52ch}
.method-narr b{color:var(--ink-2);font-weight:700}

/* ===== RESPONSIVE ===== */
@media (max-width:860px){
  .nav{display:none;position:absolute;top:var(--hh);left:0;right:0;flex-direction:column;gap:2px;background:#fff;border-bottom:1px solid var(--line);padding:10px var(--pad);box-shadow:var(--shadow-soft)}
  .nav.open{display:flex}
  .nav button{padding:12px;border-radius:10px;text-align:left}
  .nav button.on::after{left:12px;right:auto;width:16px}
  .burger{display:flex}
  .hdr-cta{display:none}
  .grid-4{grid-template-columns:1fr}
  .proof-in{grid-template-columns:1fr;gap:24px}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .method-top{grid-template-columns:1fr}
  .step{grid-template-columns:52px 1fr;gap:16px}
  .step .deliver{grid-column:1/-1;padding-left:68px}
  .mini-steps .ms::after{display:none}
}
@media (max-width:520px){.metrics{grid-template-columns:1fr 1fr}}
.lead-form{margin-top:26px;background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:clamp(24px,4vw,40px);box-shadow:var(--shadow-soft);text-align:left}
.lead-form h3{font-size:clamp(1.3rem,2.4vw,1.7rem);margin:0 0 6px;letter-spacing:-.01em;color:var(--ink)}
.lead-form .lf-sub{margin:0 0 22px;color:var(--ink-3);max-width:62ch}
.lf-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 20px}
.lf-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.lf-field>span{font-size:.82rem;font-weight:600;color:var(--ink-2)}
.lf-field>span em{font-weight:400;font-style:normal;color:var(--ink-4)}
.lf-field input,.lf-field select,.lf-field textarea{font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
.lf-field input::placeholder,.lf-field textarea::placeholder{color:var(--ink-4)}
.lf-field input:focus,.lf-field select:focus,.lf-field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}
.lf-field textarea{resize:vertical;min-height:112px}
.lf-full{margin-top:16px}
.lf-actions{margin-top:20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.lf-note{font-size:.85rem;color:var(--ink-3)}
.lf-note.lf-err{color:#C0392B}
.lf-note.lf-ok{color:var(--blue-deep)}
.need-cta{border-color:var(--blue-line);background:var(--blue-soft)}
.need-cta .q{color:var(--blue-deep);font-weight:600}
.need-cta .plus{color:var(--blue)}
@media (max-width:620px){.lf-grid{grid-template-columns:1fr}}

/* ===== WORDPRESS · CONTENIDO Y BLOG ===== */
.page-head{padding:clamp(40px,6vw,72px) 0 0}
.prose{max-width:72ch;color:var(--ink-2);font-size:1.05rem;line-height:1.7;margin-top:24px}
.prose h2{font-size:1.6rem;font-weight:800;margin:34px 0 12px}
.prose h3{font-size:1.25rem;font-weight:800;margin:26px 0 10px}
.prose p{margin:0 0 16px}
.prose a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose ul,.prose ol{margin:0 0 16px 22px}
.prose li{margin-bottom:8px}
.prose img{border-radius:var(--r);margin:20px 0}
.prose blockquote{border-left:3px solid var(--blue);background:var(--paper-2);padding:14px 18px;border-radius:0 var(--r) var(--r) 0;margin:20px 0;color:var(--ink-2);font-weight:600}

/* Entrada individual */
.single-hero{border-bottom:1px solid var(--line);padding:clamp(36px,5vw,60px) 0}
.single-hero .cat{font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);background:var(--blue-soft);border-radius:999px;padding:5px 12px;display:inline-block}
.single-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin:16px 0 12px;max-width:24ch}
.single-hero .meta{color:var(--ink-4);font-family:var(--mono);font-size:.78rem;font-weight:600}
.single-thumb{aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;margin:26px 0}
.single-thumb img{width:100%;height:100%;object-fit:cover}
.single-cta{margin-top:44px;padding:28px;border:1px solid var(--blue-line);background:var(--blue-soft);border-radius:var(--r-lg);display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}
.single-cta p{font-weight:700;font-size:1.05rem}

/* Paginación blog */
.pagin{display:flex;gap:10px;justify-content:center;margin-top:44px;flex-wrap:wrap}
.pagin a,.pagin span{font-weight:700;font-size:.9rem;padding:10px 16px;border-radius:10px;border:1px solid var(--line);color:var(--ink-2)}
.pagin .current{background:var(--blue);color:#fff;border-color:var(--blue)}
.pagin a:hover{border-color:var(--blue);color:var(--blue)}

/* Menú de administración: ocultar título duplicado en algunas plantillas ya gestionado por cada template */
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ===== FIX NAV WORDPRESS: enlaces <a> y <li> igual que los <button> de la app ===== */
.nav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.nav li{list-style:none;margin:0;padding:0}
.nav a{color:var(--ink-2);font-size:.9rem;font-weight:600;padding:8px 12px;border-radius:8px;position:relative;text-decoration:none;transition:color .2s,background .2s;white-space:nowrap;display:inline-block}
.nav a:hover{color:var(--blue);background:var(--blue-soft);text-decoration:none}
.nav a:focus{text-decoration:none}
.nav .current-menu-item>a,.nav a.on{color:var(--blue)}
.nav .current-menu-item>a::after,.nav a.on::after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;background:var(--blue);border-radius:2px}
@media (max-width:860px){
  .nav ul{flex-direction:column;gap:2px}
  .nav a{padding:12px;border-radius:10px;text-align:left;display:block}
  .nav .current-menu-item>a::after,.nav a.on::after{left:12px;right:auto;width:16px}
}

/* ===== PÁGINA INDIVIDUAL DE SERVICIO ===== */
.crumbs{display:flex;gap:8px;align-items:center;font-family:var(--mono);font-size:.74rem;font-weight:600;letter-spacing:.03em;color:var(--ink-4);margin-bottom:18px;flex-wrap:wrap}
.crumbs a{color:var(--accent,var(--blue));text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.svc-hero .m-eye{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--blue))}
.svc-ficha{display:grid;grid-template-columns:1.7fr 1fr;gap:28px;margin:30px 0 8px;align-items:start}
.svc-ficha-main .block{margin-top:20px}
.svc-ficha-main .block:first-child{margin-top:0}
.svc-ficha-main .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:9px}
.svc-ficha-main .prob{background:var(--paper-2);border-left:3px solid var(--accent,var(--blue));padding:14px 16px;border-radius:0 var(--r) var(--r) 0;color:var(--ink-2);font-weight:600}
.svc-ficha-main .bens{list-style:none;display:grid;gap:9px}
.svc-ficha-main .bens li{display:flex;gap:11px;color:var(--ink-2);font-weight:500}
.svc-ficha-main .bens li::before{content:"";flex:0 0 auto;width:8px;height:8px;margin-top:8px;background:var(--accent,var(--blue));transform:rotate(45deg)}
.svc-ficha-main .pitch{background:var(--tint);color:#fff;border-radius:var(--r);padding:18px 20px;font-size:1.06rem;font-weight:700;font-style:italic;line-height:1.4}
.svc-ficha-main .pitch::before{content:"“";color:var(--accent,var(--blue));font-weight:800}
.svc-ficha-main .pitch::after{content:"”";color:var(--accent,var(--blue));font-weight:800}
.svc-ficha-cta{position:sticky;top:calc(var(--hh) + 16px);background:var(--accent-soft,var(--blue-soft));border:1px solid var(--accent-line,var(--blue-line));border-radius:var(--r-lg);padding:24px}
.svc-ficha-cta h3{font-size:1.15rem;font-weight:800;margin-bottom:8px;letter-spacing:-.01em}
.svc-ficha-cta p{color:var(--ink-3);font-size:.92rem;margin-bottom:18px}
.svc-ficha-cta .btn-primary{background:var(--accent,var(--blue))}
.svc-prose{margin-top:34px;border-top:1px solid var(--line);padding-top:30px}
.svc-related{margin-top:40px;border-top:1px solid var(--line);padding-top:28px}
@media (max-width:820px){.svc-ficha{grid-template-columns:1fr}.svc-ficha-cta{position:static}}

/* ===== FIX SUBRAYADOS EN TARJETAS-ENLACE ===== */
/* Tarjetas de área: mantener subrayado SOLO en el título; quitarlo del resto */
.acard{text-decoration:none}
.acard .n,.acard p,.acard .more{text-decoration:none}
.acard h3{text-decoration:underline;text-underline-offset:3px}
.acard:hover h3{text-decoration:underline}
/* Enlaces de servicio (parrilla de áreas y relacionados): sin subrayado */
.svc{text-decoration:none}
.svc .sn{text-decoration:none}

/* ===== NOSOTROS ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.feat{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px}
.feat-n{font-family:var(--mono);font-size:.8rem;font-weight:600;color:var(--blue)}
.feat h3{font-size:1.2rem;font-weight:800;margin:12px 0 8px;letter-spacing:-.02em}
.feat p{color:var(--ink-3);font-size:.96rem;line-height:1.6}

.founder-band{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.founder{display:grid;grid-template-columns:340px 1fr;gap:44px;align-items:center;padding:clamp(40px,6vw,68px) var(--pad)}
.founder-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow-soft);display:block}
.founder-photo--empty{width:100%;aspect-ratio:4/5;border-radius:var(--r-lg);border:1.5px dashed var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--ink-4);font-weight:600;font-size:.9rem;background:var(--paper)}
.founder-photo--empty small{color:var(--ink-4);font-weight:500;font-size:.78rem}
.founder-role{font-family:var(--mono);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--blue)}
.founder-bio{color:var(--ink-2);font-size:1.06rem;line-height:1.7;margin:18px 0 0;max-width:56ch}
.founder-quote{margin:24px 0 0;padding:18px 22px;background:var(--tint);color:#fff;border-radius:var(--r);font-size:1.08rem;font-weight:700;font-style:italic;line-height:1.45;max-width:56ch}
.founder-quote::before{content:"“";color:var(--blue)}
.founder-quote::after{content:"”";color:var(--blue)}

.coverage{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;background:linear-gradient(135deg,#EEF3FF 0%,#F7FAFF 100%);border:1px solid var(--blue-line);border-radius:var(--r-lg);padding:clamp(30px,4vw,48px)}
.coverage-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.coverage-pills .pill{font-size:.92rem;padding:10px 20px;background:#fff;border-color:var(--blue-line);color:var(--ink-2);font-weight:700}

.nos-bands{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
.nos-band{display:flex;align-items:center;gap:20px;justify-content:space-between;padding:26px 28px;border-radius:var(--r-lg);border:1px solid var(--line);text-decoration:none;color:inherit;background:var(--paper);transition:transform .2s,box-shadow .2s,border-color .2s}
.nos-band .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);display:block;margin-bottom:6px}
.nos-band h3{font-size:1.3rem;font-weight:800;margin-bottom:6px;letter-spacing:-.02em}
.nos-band p{color:var(--ink-3);font-size:.92rem}
.nos-band--method:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:var(--blue-line)}
.nos-band--method .nos-arrow{color:var(--blue);font-weight:800;font-size:1.4rem;flex:0 0 auto}
.nos-band--iso{background:var(--paper-2)}
.nos-band--iso img{height:66px;width:auto;flex:0 0 auto}

@media (max-width:860px){
  .grid-3{grid-template-columns:1fr}
  .founder{grid-template-columns:1fr;gap:24px}
  .founder-photo{max-width:300px}
  .coverage{grid-template-columns:1fr;gap:20px}
  .coverage-pills{justify-content:flex-start}
  .nos-bands{grid-template-columns:1fr}
}

/* Atribución de la cita del fundador */
.founder-quote-author{display:block;margin-top:12px;font-style:normal;font-weight:600;font-size:.82rem;color:var(--blue-line);font-family:var(--mono);letter-spacing:.04em}
.founder-quote-author::before{content:"— "}

/* ===== NOSOTROS · FIGURA DEL FUNDADOR ===== */
.founder-hero{display:grid;grid-template-columns:360px 1fr;gap:48px;align-items:center}
.founder-hero-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow-soft);display:block}
.founder-hero .founder-role{font-size:.92rem}
@media (max-width:860px){.founder-hero{grid-template-columns:1fr;gap:26px}.founder-hero-photo{max-width:300px}}

/* Timeline trayectoria */
.tl{margin-top:36px;border-top:1px solid var(--line)}
.tl-row{display:grid;grid-template-columns:130px 1.4fr 1fr;gap:20px;align-items:baseline;padding:18px 4px;border-bottom:1px solid var(--line)}
.tl-year{font-family:var(--mono);font-size:.82rem;font-weight:600;color:var(--blue)}
.tl-role{font-weight:800;font-size:1.02rem;color:var(--ink);letter-spacing:-.01em}
.tl-org{color:var(--ink-3);font-weight:600;font-size:.95rem}
@media (max-width:720px){.tl-row{grid-template-columns:1fr;gap:2px;padding:16px 4px}.tl-year{margin-bottom:2px}}

/* Formación */
.edu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:36px}
.edu{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px}
.edu-year{font-family:var(--mono);font-size:.78rem;font-weight:600;color:var(--blue);margin-bottom:6px}
.edu-title{font-weight:800;font-size:1.04rem;letter-spacing:-.01em;line-height:1.3}
.edu-place{color:var(--ink-3);font-weight:600;font-size:.9rem;margin-top:4px}
.edu-langs{margin-top:26px;color:var(--ink-2);font-weight:600}
.edu-langs .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-right:10px}
@media (max-width:640px){.edu-grid{grid-template-columns:1fr}}

/* Reconocimientos */
.recon{list-style:none;margin:34px 0 0;display:grid;gap:14px;max-width:74ch}
.recon li{display:flex;gap:14px;color:var(--ink-2);font-weight:500;font-size:1.02rem;line-height:1.55}
.recon li::before{content:"";flex:0 0 auto;width:9px;height:9px;margin-top:9px;background:var(--blue);transform:rotate(45deg)}

/* Lado personal */
.beyond{display:grid;grid-template-columns:1.5fr 1fr;gap:30px;align-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(30px,4vw,48px)}
.beyond-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.beyond-pills .pill{font-size:.92rem;padding:9px 18px;background:#fff;font-weight:700}
@media (max-width:860px){.beyond{grid-template-columns:1fr;gap:20px}.beyond-pills{justify-content:flex-start}}

/* ===== NOSOTROS · campos del equipo + ecosistema ===== */
.fields{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:34px}
.field{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent,var(--blue));border-radius:var(--r);padding:16px 16px}
.field-n{display:block;font-family:var(--mono);font-size:.72rem;font-weight:600;color:var(--accent,var(--blue))}
.field-name{display:block;font-weight:800;font-size:.98rem;letter-spacing:-.01em;margin-top:6px;line-height:1.25}
.eco{margin-top:28px;max-width:74ch;color:var(--ink-2);font-size:1.08rem;line-height:1.7;font-weight:500}
.eco b{color:var(--ink);font-weight:800}
@media (max-width:900px){.fields{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.fields{grid-template-columns:1fr}}

/* ===== NOSOTROS v3 · equipo protagonista, una vista ===== */
.nos-in{min-height:calc(100dvh - var(--hh));display:grid;grid-template-rows:1fr auto;gap:clamp(20px,3vh,36px);padding:clamp(24px,4vh,52px) 0}
.nos-top{align-self:center}
.nos-thesis{font-size:clamp(1.9rem,4.4vw,3.2rem);font-weight:800;letter-spacing:-.025em;line-height:1.08;max-width:20ch;margin:12px 0 0}
.nos-thesis em{font-style:normal;color:var(--blue)}
.nos-attrib{font-family:var(--mono);font-size:.8rem;font-weight:600;color:var(--ink-4);margin-top:16px}
.nos-attrib::before{content:"— "}
.nos-lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--ink-3);max-width:64ch;font-weight:500;margin-top:22px}
.nos .fields{margin-top:clamp(22px,3vh,34px)}
.nos-founder{align-self:end;display:flex;align-items:center;gap:22px;border-top:1px solid var(--line);padding-top:24px}
.nos-founder-photo{flex:0 0 auto;width:104px;height:104px;border-radius:50%;overflow:hidden;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.nos-founder-photo img{width:100%;height:100%;object-fit:cover}
.nos-founder-photo span{color:var(--ink-4);font-size:.78rem;font-weight:600}
.nos-founder-txt{flex:1;min-width:0}
.nos-founder-txt .k{font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}
.nos-founder-txt .nm{font-weight:800;font-size:1.05rem;margin:5px 0 6px;letter-spacing:-.01em}
.nos-founder-txt .nm span{color:var(--ink-3);font-weight:600}
.nos-founder-txt p{color:var(--ink-3);font-size:.92rem;line-height:1.55;max-width:72ch}
.nos-cta{flex:0 0 auto}
@media (max-width:760px){
  .nos-in{min-height:0;display:block}
  .nos-founder{flex-direction:column;align-items:flex-start;gap:16px;margin-top:36px}
  .nos-cta{width:100%;justify-content:center}
}

/* Enlace a LinkedIn en la ficha del fundador */
.nos-li{display:inline-flex;align-items:center;gap:8px;margin-top:14px;color:var(--blue);font-weight:700;font-size:.9rem;text-decoration:none}
.nos-li svg{width:17px;height:17px;flex:0 0 auto}
.nos-li:hover{color:var(--blue-deep)}
.nos-li span{font-weight:600}

/* Home: stepper reubicado bajo Áreas */
.home-steps{padding-bottom:clamp(28px,5vw,52px)}
.home-steps .mini-steps{margin-top:0}

/* Modal: fila de acciones (ver completo + hablar) */
.m-ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:24px}
.modal .m-ctas .m-cta{margin-top:0}
.m-cta-alt{display:inline-flex;align-items:center;gap:6px;color:var(--accent,var(--blue));font-weight:700;font-size:.92rem;text-decoration:none}
.m-cta-alt:hover{text-decoration:underline}

/* ===== Sin subrayado en botones-enlace (todo el tema) ===== */
.btn,.hdr-cta,.m-cta,.m-cta-alt,.nos-cta{text-decoration:none}
.btn:hover,.hdr-cta:hover,.m-cta:hover,.m-cta-alt:hover,.nos-cta:hover{text-decoration:none}

/* "Hablar de este servicio" como pastilla secundaria (contorno del acento) */
.m-cta-alt{display:inline-flex;align-items:center;gap:7px;padding:12px 20px;border-radius:11px;border:1.5px solid var(--accent-line,var(--blue-line));color:var(--accent-deep,var(--blue-deep));background:transparent;font-weight:700;font-size:.94rem;transition:border-color .2s,background .2s}
.m-cta-alt:hover{border-color:var(--accent,var(--blue));background:var(--accent-soft,var(--blue-soft))}

/* ===== Sin subrayado en enlaces de UI; solo en prosa (artículos/páginas) ===== */
#main a{text-decoration:none}
#main .prose a{text-decoration:underline;text-underline-offset:2px}
.back{text-decoration:none}
.back:hover{color:var(--blue);text-decoration:none}

/* ===== HABLEMOS / CONTACTO ===== */
.lf-consents{margin-top:22px;display:grid;gap:12px;border-top:1px solid var(--line);padding-top:20px}
.lf-check{display:flex;gap:11px;align-items:flex-start;cursor:pointer;font-size:.9rem;color:var(--ink-2);line-height:1.5}
.lf-check input{margin-top:3px;width:18px;height:18px;flex:0 0 auto;accent-color:var(--blue);cursor:pointer}
.lf-check a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.lf-check b{color:#C0392B}
.lf-required{margin-top:12px;font-size:.82rem;color:var(--ink-4)}
.lf-field span em{color:#C0392B;font-style:normal;font-weight:700}
.lf-age{margin-top:22px;font-size:.9rem;color:var(--ink-2);font-weight:600}

.data-clause{margin-top:20px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,32px);scroll-margin-top:calc(var(--hh) + 16px)}
.data-clause h3{font-size:1.1rem;font-weight:800;margin-bottom:12px}
.data-clause p{color:var(--ink-3);font-size:.9rem;line-height:1.6;margin-bottom:12px}
.data-clause ol{margin:0 0 0 18px;display:grid;gap:10px}
.data-clause li{color:var(--ink-3);font-size:.86rem;line-height:1.6}
.data-clause b{color:var(--ink-2)}

.offices{margin-top:clamp(48px,7vw,80px)}
.offices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.office{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--paper);display:flex;flex-direction:column}
.office-map{background:var(--paper-2)}
.office-map iframe{display:block;width:100%;height:220px;border:0}
.office-info{padding:20px 22px}
.office-info h3{font-size:1.2rem;font-weight:800;margin-bottom:8px}
.office-info p{color:var(--ink-3);font-size:.9rem;line-height:1.5;margin-bottom:12px}
.office-tel{color:var(--blue);font-weight:700;font-size:.95rem}
@media (max-width:860px){.offices-grid{grid-template-columns:1fr}}

.legal-links{margin-top:clamp(48px,7vw,80px);border-top:1px solid var(--line);padding-top:36px}
.legal-links h3{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:18px}
.legal-links ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px 28px;margin:0}
.legal-links li{margin:0}
.legal-links a{color:var(--ink-2);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}
.legal-links a:hover{color:var(--blue)}
.legal-links a span{color:var(--ink-4)}
@media (max-width:640px){.legal-links ul{grid-template-columns:1fr}}

/* ===== AVISO DE COOKIES ===== */
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;background:var(--tint);color:#fff;border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(5,8,19,.35);padding:18px 22px;display:flex;align-items:center;gap:20px;max-width:920px;margin:0 auto}
.cookie-bar p{font-size:.86rem;line-height:1.5;color:rgba(255,255,255,.85);margin:0}
.cookie-bar a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.cookie-bar .btn{flex:0 0 auto;white-space:nowrap}
@media (max-width:640px){.cookie-bar{flex-direction:column;align-items:stretch;gap:14px;text-align:left}.cookie-bar .btn{width:100%;justify-content:center}}

/* ===== Sello de partner Holistik en el pie ===== */
.ft{gap:16px 24px}
.ft-partner{display:inline-flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink-4);transition:color .2s}
.ft-partner:hover{color:var(--ink-2)}
.ft-partner-label{font-size:.78rem;font-weight:600;white-space:nowrap}
.ft-holistik{height:20px;width:auto;display:block}
@media (max-width:760px){.ft{flex-direction:column;align-items:flex-start;text-align:left}}

/* ===== PÁGINA INDIVIDUAL DE CASO ===== */
.caso-hero{border-bottom:1px solid var(--line);padding-bottom:28px;margin-bottom:8px}
.caso-metric{display:flex;gap:18px;align-items:baseline;margin:6px 0 16px}
.caso-metric .big{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;letter-spacing:-.03em;color:var(--accent,var(--blue));line-height:1}
.caso-metric .bigl{color:var(--ink-3);font-weight:600;font-size:.95rem}
.caso-body{max-width:74ch;margin-top:26px}
.caso-body .block{margin-top:24px}
.caso-body .block:first-child{margin-top:0}
.caso-body .k{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--blue));margin-bottom:8px}
.caso-body .block p{color:var(--ink-2);font-size:1.04rem;line-height:1.7}
.caso-quote{margin:30px 0 0;padding:20px 24px;background:var(--tint);color:#fff;border-radius:var(--r);font-size:1.12rem;font-weight:700;font-style:italic;line-height:1.45;max-width:74ch}
.caso-quote::before{content:"“";color:var(--accent,var(--blue))}
.caso-quote::after{content:"”";color:var(--accent,var(--blue))}
