/* ===== TOKENS ===== */
:root {
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --bg:#F5F0E8; --bg-s:#FAF8F3; --bg-m:#EDE8DC;
  --dark:#100F0B; --dark-s:#1C1A14;
  --txt:#1A1510; --txt2:#6A5E4A; --txt-inv:#F5F0E8;
  --gold:#C9A84C; --gold-h:#DEB95A;
  --gold-d:rgba(201,168,76,.1); --gold-b:rgba(201,168,76,.28);
  --gold-grad:linear-gradient(135deg,#C9A84C,#DEB95A 50%,#C9A84C);
  --green:#25D366;
  --bdr:rgba(26,21,16,.09); --bdr2:rgba(26,21,16,.18);
  --r:3px; --r-md:6px; --r-lg:12px;
  --sh-sm:0 1px 3px rgba(26,21,16,.05),0 4px 12px rgba(26,21,16,.07);
  --sh-md:0 4px 8px rgba(26,21,16,.07),0 16px 40px rgba(26,21,16,.11);
  --sh-gold:0 4px 24px rgba(201,168,76,.32);
  --ease:cubic-bezier(.16,1,.3,1); --ease2:cubic-bezier(.4,0,.6,1);
  --t:240ms; --nav:68px;
  /* compat aliases for nosotros/vlog pages */
  --bg1:var(--bg-m); --bg2:var(--bg-s); --bg3:var(--bg);
  --txt3:var(--txt2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--txt);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
.container{max-width:1280px;margin:0 auto;padding:0 2.5rem}
.section{padding:7rem 0}

/* ===== TYPOGRAPHY ===== */
.label{display:inline-flex;align-items:center;gap:10px;font-size:.68rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.label::before{content:'';display:block;width:28px;height:1px;background:var(--gold);flex-shrink:0}
.h2{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.06;letter-spacing:-.01em;margin-bottom:1rem;color:var(--txt)}
.h2 em{font-style:italic;color:var(--gold)}
.muted{color:var(--txt2);line-height:1.85;font-size:.95rem}
.sec-hdr{margin-bottom:3.5rem}
.sec-hdr .muted{max-width:540px;margin-top:.5rem}

/* ===== SCROLL PROGRESS ===== */
#scroll-progress{position:fixed;top:0;left:0;z-index:9999;height:2px;background:var(--gold-grad);width:0%;transition:width .1s linear;pointer-events:none}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav);background:var(--dark);transition:transform .4s var(--ease2)}
.navbar.hide{transform:translateY(-100%)}
.nav-wrap{max-width:1280px;margin:0 auto;padding:0 2.5rem;height:100%;display:flex;align-items:center;gap:2rem}
.logo{display:flex;align-items:center;flex-shrink:0}
.logo-img{height:32px;width:auto;filter:brightness(0) invert(1);transition:opacity .2s}
.logo-img:hover{opacity:.8}
.nav-links{display:flex;align-items:center;gap:2rem;margin-left:auto}
.nav-links a{font-size:.7rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:rgba(245,240,232,.5);transition:color var(--t)}
.nav-links a:hover{color:var(--gold)}
.nav-wa{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;background:rgba(37,211,102,.08);color:var(--green);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border:1px solid rgba(37,211,102,.25);border-radius:var(--r);transition:all var(--t)}
.nav-wa:hover{background:rgba(37,211,102,.18);border-color:var(--green)}
.burger{display:none;flex-direction:column;gap:5px;padding:4px;margin-left:auto}
.burger span{display:block;width:22px;height:1.5px;background:rgba(245,240,232,.6);border-radius:1px;transition:all var(--t)}

/* ===== BUTTONS ===== */
.btn-gold{display:inline-flex;align-items:center;gap:9px;padding:13px 28px;background:var(--gold);color:var(--dark);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:2px solid var(--gold);border-radius:var(--r);transition:all var(--t);white-space:nowrap}
.btn-gold:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}
.btn-gold svg,.btn-outline svg{transition:transform var(--t)}
.btn-gold:hover svg,.btn-outline:hover svg{transform:translateX(3px)}
.btn-outline{display:inline-flex;align-items:center;gap:9px;padding:13px 28px;background:transparent;color:var(--txt);font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:2px solid var(--bdr2);border-radius:var(--r);transition:all var(--t)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-full{width:100%;justify-content:center}
.btn-wa{display:inline-flex;align-items:center;gap:12px;padding:15px 28px;background:var(--green);color:#fff;font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:var(--r);transition:all var(--t);margin-top:2rem}
.btn-wa:hover{background:#1ebd5b;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.35)}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.88)}}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes wap{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}

.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--d,0ms)}
.rv.visible{opacity:1;transform:translateY(0)}
.fi{animation:fadeUp .85s var(--ease) both}
.fi:nth-child(2){animation-delay:.12s}
.fi:nth-child(3){animation-delay:.24s}
.fi:nth-child(4){animation-delay:.38s}

/* ===== HERO — full-screen background ===== */
.hero{position:relative;display:flex;flex-direction:column;min-height:100vh}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg-img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(12,10,6,.72) 0%,rgba(12,10,6,.52) 45%,rgba(12,10,6,.76) 100%)}
.hero-inner{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:calc(var(--nav) + 4rem) clamp(1.5rem,5vw,4rem) 4rem}
.hero-chip{display:inline-flex;align-items:center;gap:8px;font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:2rem;width:fit-content}
.chip-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite;flex-shrink:0}
.hero-h1{font-family:var(--serif);font-weight:400;line-height:.92;letter-spacing:-.005em;color:#fff;margin-bottom:1.75rem;display:flex;flex-direction:column;align-items:center;gap:.15em}
.hero-h1-pre,.hero-h1-post{font-family:'Inter',sans-serif;font-size:clamp(.95rem,1.5vw,1.2rem);font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:rgba(245,240,232,.78)}
.hero-h1-pre::before,.hero-h1-pre::after,.hero-h1-post::before,.hero-h1-post::after{content:'';display:inline-block;width:42px;height:1px;background:rgba(201,168,76,.55);vertical-align:middle;margin:0 1em}
.hero-h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold);font-size:clamp(6.5rem,16vw,14rem);line-height:.95;display:block;margin:.12em 0;text-shadow:0 2px 36px rgba(0,0,0,.45)}
.hero-p{font-size:1rem;color:rgba(245,240,232,.7);max-width:520px;line-height:1.85;margin:0 auto 2.5rem;text-align:center}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* Hero stats bar */
.hero-stats{position:relative;z-index:1;background:rgba(12,10,6,.82);border-top:1px solid rgba(201,168,76,.18);backdrop-filter:blur(12px)}
.hs-grid{display:flex;align-items:stretch;max-width:1280px;margin:0 auto;padding:0 2.5rem}
.hs-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.6rem 1rem}
.hs-num{font-family:var(--serif);font-size:2.6rem;font-weight:600;font-style:italic;color:var(--gold);line-height:1;margin-bottom:.3rem}
.hs-label{font-size:.63rem;color:rgba(245,240,232,.42);letter-spacing:.12em;text-transform:uppercase}
.hs-sep{width:1px;background:rgba(201,168,76,.15);flex-shrink:0;margin:1.25rem 0}

/* ===== TICKER ===== */
.ticker{background:var(--bg-m);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);padding:.8rem 0;overflow:hidden;position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--bg-m),transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,var(--bg-m),transparent)}
.ticker-inner{display:flex;animation:ticker 30s linear infinite}
.ticker-group{display:flex;flex-shrink:0;white-space:nowrap}
.ticker-item{display:inline-flex;align-items:center;gap:.75rem;font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--txt2);padding:0 2.5rem}
.ticker-item svg{color:var(--gold);opacity:.8;flex-shrink:0}

/* ===== POR QUÉ ===== */
.why{background:var(--bg-s)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr)}
.why-card{background:var(--bg-s);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:background var(--t),transform .3s var(--ease),box-shadow .3s var(--ease)}
.why-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold-grad);transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left}
.why-card:hover{background:var(--bg-m);transform:translateY(-3px);box-shadow:var(--sh-md)}
.why-card:hover::after{transform:scaleX(1)}
.why-bg-num{position:absolute;top:.25rem;right:1.25rem;font-family:var(--serif);font-size:5.5rem;font-weight:700;font-style:italic;color:rgba(201,168,76,.05);line-height:1;pointer-events:none;user-select:none}
.why-icon{width:44px;height:44px;background:var(--gold-d);border:1px solid var(--gold-b);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1.25rem;transition:all var(--t);flex-shrink:0}
.why-card:hover .why-icon{background:var(--gold);color:var(--dark);box-shadow:var(--sh-gold)}
.why-num{font-family:var(--serif);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:500;font-style:italic;color:var(--gold);line-height:1;margin-bottom:.4rem}
.why-label{font-size:.88rem;font-weight:700;color:var(--txt);margin-bottom:.6rem;line-height:1.3}
.why-desc{font-size:.84rem;color:var(--txt2);line-height:1.78}

/* ===== PROCESO TABBED ===== */
.proc{background:var(--bg)}
.pn{display:flex;align-items:center;gap:0;margin-bottom:2rem;overflow-x:auto;padding-bottom:.5rem}
.pn::-webkit-scrollbar{height:2px}.pn::-webkit-scrollbar-thumb{background:var(--gold-b)}
.pn-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px;padding:.5rem;background:none;border:none;cursor:pointer;transition:opacity var(--t)}
.pn-step:not(.active){opacity:.45}
.pn-circle{width:44px;height:44px;border-radius:50%;background:var(--bg-m);border:1.5px solid var(--bdr2);display:flex;align-items:center;justify-content:center;transition:all var(--t)}
.pn-step.active .pn-circle{background:var(--gold);border-color:var(--gold);box-shadow:var(--sh-gold)}
.pn-circle span{font-size:.72rem;font-weight:600;color:var(--txt2);transition:color var(--t)}
.pn-step.active .pn-circle span{color:var(--dark)}
.pn-name{font-size:.62rem;font-weight:600;color:var(--txt2);letter-spacing:.06em;text-align:center;text-transform:uppercase}
.pn-conn{flex:1;height:1.5px;background:var(--bdr2);min-width:20px}
.proc-stage{display:grid;min-height:480px;border-radius:var(--r-md);overflow:hidden;background:var(--bg-m);border:1px solid var(--bdr);box-shadow:var(--sh-sm)}
.proc-panel{display:none;grid-template-columns:1fr 1fr;width:100%}
.proc-panel.active{display:grid}
.proc-img{background-size:cover;background-position:center;min-height:340px;position:relative}
.stage-photo-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(12,10,6,.2),rgba(12,10,6,.04));z-index:1;pointer-events:none}
.stage-info-bar{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:1.5rem 2rem;background:linear-gradient(to top,rgba(12,10,6,.9) 0%,rgba(12,10,6,.5) 60%,transparent)}
.sib-top{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}
.sib-num{font-family:var(--serif);font-size:1.5rem;font-weight:700;font-style:italic;color:var(--gold);min-width:2.5rem;line-height:1}
.sib-progress{flex:1;height:2px;background:rgba(255,255,255,.2);border-radius:1px;overflow:hidden}
.sib-fill{height:100%;background:var(--gold);transition:width .8s var(--ease);border-radius:1px}
.sib-pct{font-size:.68rem;font-weight:600;color:var(--gold);letter-spacing:.08em;min-width:32px;text-align:right}
.sib-name{font-size:1.35rem;font-weight:600;color:#fff;line-height:1.2}
.proc-info{padding:2.5rem;display:flex;flex-direction:column;overflow-y:auto}
.proc-num{font-size:.68rem;font-weight:600;color:var(--gold);letter-spacing:.22em;margin-bottom:.5rem}
.proc-title{font-family:var(--serif);font-size:1.8rem;font-weight:700;line-height:1.08;color:var(--txt);margin-bottom:1rem}
.proc-title em{font-style:italic;color:var(--gold)}
.proc-desc{font-size:.88rem;color:var(--txt2);line-height:1.8;margin-bottom:1.5rem}
.proc-mats{display:flex;flex-direction:column;gap:.6rem;margin-top:auto}
.proc-mats li{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:var(--txt2)}
.mat-dot{width:8px;height:8px;border-radius:50%;background:var(--c,var(--gold));flex-shrink:0}

/* ===== PORTFOLIO ===== */
.portfolio{background:var(--bg-m)}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:3px;margin:0 0 2rem}
.port-item{position:relative;overflow:hidden;cursor:pointer}
.port-item.large{grid-column:span 2;grid-row:span 2}
.port-img{width:100%;height:100%;min-height:260px;background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.port-item:hover .port-img{transform:scale(1.04)}
.port-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,10,6,.92) 0%,rgba(12,10,6,.2) 55%,transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;opacity:0;transition:opacity var(--t)}
.port-item:hover .port-over{opacity:1}
.port-cat{font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem}
.port-over h3{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:#fff;margin-bottom:3px}
.port-over p{font-size:.76rem;color:rgba(255,255,255,.6)}
.port-cta{text-align:center;padding:1rem 0 2rem}

/* ===== TESTIMONIOS CARRUSEL ===== */
.testi{background:var(--bg)}
.testi-slider-wrap{margin-top:2.5rem}
.testi-slider{overflow:hidden;border-radius:var(--r-md)}
.testi-track{display:flex;transition:transform .45s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.testi-card{flex:0 0 100%;min-width:0;background:var(--bg-s);border:1px solid var(--bdr);border-radius:var(--r-md);padding:2.25rem 2.75rem;position:relative;box-sizing:border-box}
.testi-card::before{content:'\201C';position:absolute;top:1rem;right:2rem;font-family:var(--serif);font-size:5rem;font-weight:700;font-style:italic;color:rgba(201,168,76,.07);line-height:1;pointer-events:none}
.tc-stars{color:var(--gold);font-size:.85rem;letter-spacing:2px;margin-bottom:1rem}
.testi-card p{font-size:.96rem;color:var(--txt2);line-height:1.9;font-style:italic;margin-bottom:1.75rem;max-width:760px}
.tc-author{display:flex;align-items:center;gap:.85rem}
.tc-av{width:40px;height:40px;border-radius:50%;background:var(--gold);color:var(--dark);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tc-author strong{display:block;font-size:.83rem;font-weight:700;color:var(--txt)}
.tc-author span{display:block;font-size:.73rem;color:var(--txt3)}
/* Barra de progreso */
.testi-progress{height:2px;background:var(--bdr);border-radius:1px;margin-top:1.5rem;overflow:hidden}
.testi-progress-fill{height:100%;background:var(--gold);border-radius:1px;width:7.69%;transition:width .45s cubic-bezier(.25,.46,.45,.94)}
/* Controles */
.testi-controls{display:flex;align-items:center;gap:1rem;margin-top:1.25rem}
.testi-counter{font-size:.75rem;color:var(--txt3);font-weight:500;min-width:3rem;text-align:center}
.testi-arrow{width:40px;height:40px;border-radius:50%;background:var(--bg2);border:1px solid var(--bdr2);display:flex;align-items:center;justify-content:center;color:var(--txt2);cursor:pointer;transition:all .2s var(--ease);flex-shrink:0}
.testi-arrow:hover:not(:disabled){background:var(--gold);border-color:var(--gold);color:#080808}
.testi-arrow:disabled{opacity:.3;cursor:not-allowed}
/* Formulario de testimonio */
.testi-submit-wrap{margin-top:3rem;padding-top:3rem;border-top:1px solid var(--bdr)}
.testi-submit-hdr{margin-bottom:1.5rem}
.testi-submit-title{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:400;color:var(--txt);margin:.5rem 0 0}
.testi-submit-title em{font-style:italic;color:var(--gold)}
.testi-form{background:var(--bg-s);border:1px solid var(--bdr);border-radius:var(--r-md);padding:2rem;display:flex;flex-direction:column;gap:1rem}
.testi-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.testi-form-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:.25rem}
.testi-stars-pick{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.testi-stars-label{font-size:.78rem;color:var(--txt3);font-weight:500}
.star-btn{font-size:.85rem;color:var(--txt3);background:none;border:1px solid var(--bdr);cursor:pointer;padding:5px 9px;border-radius:4px;transition:all .15s var(--ease);font-family:inherit}
.star-btn.active{color:var(--gold);background:var(--gold-d);border-color:var(--gold-b)}
.testi-sent{font-size:.95rem;color:var(--gold);padding:2rem 0;text-align:center;font-style:italic}
@media(max-width:640px){.testi-form-row{grid-template-columns:1fr}.testi-form-footer{flex-direction:column;align-items:flex-start}}

/* ===== ANATOMIA DEL MURO ===== */
.wall-sec{background:var(--bg-s)}
.wall-hero{position:relative;margin:2rem 0;overflow:hidden;border-radius:var(--r-md);cursor:crosshair}
.wall-img{width:100%;max-height:580px;object-fit:cover;transition:transform .1s linear;border-radius:var(--r-md)}
.wall-bottom-grad{position:absolute;bottom:0;left:0;right:0;height:200px;background:linear-gradient(to top,var(--bg-s) 0%,transparent 100%);pointer-events:none;z-index:1}
.hs{position:absolute;left:var(--lx);top:var(--ly);width:28px;height:28px;border-radius:50%;background:none;border:none;cursor:pointer;transform:translate(-50%,-50%);z-index:2}
.hs-ring{position:absolute;inset:-4px;border-radius:50%;border:1.5px solid rgba(201,168,76,.4);animation:pulse 2.5s infinite;transition:border-color var(--t)}
.hs-dot{position:absolute;inset:4px;border-radius:50%;background:var(--gold);transition:transform var(--t),background var(--t)}
.hs.active .hs-ring{border-color:var(--gold)}
.hs.active .hs-dot{transform:scale(1.3)}
.hs:hover .hs-dot{transform:scale(1.2)}
.wall-tilt-hint{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);z-index:4;padding:5px 14px;background:rgba(12,10,6,.6);border:1px solid rgba(201,168,76,.3);border-radius:100px;font-size:.7rem;color:rgba(245,240,232,.75);pointer-events:none;letter-spacing:.06em}
.wxs-wrap{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}
.wxs-label-side{font-size:.65rem;font-weight:600;letter-spacing:.12em;color:var(--txt2);text-transform:uppercase;white-space:nowrap}
.wxs-scene{display:flex;align-items:stretch;gap:2px;flex:1;height:100px;border-radius:var(--r);overflow:hidden;background:var(--bg-m);border:1px solid var(--bdr)}
.wxs-bar{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:var(--flex,1);background:var(--col);padding:4px;cursor:pointer;transition:filter var(--t),flex var(--t) var(--ease);border:none;gap:3px}
.wxs-bar.active{flex:calc(var(--flex)*2.2);filter:brightness(1.08)}
.wxs-bar:not(.active){filter:brightness(.78) saturate(.7)}
.wxs-bname{font-size:.5rem;font-weight:700;color:rgba(255,255,255,.92);text-align:center;line-height:1.3;text-shadow:0 1px 4px rgba(0,0,0,.7);text-transform:uppercase;letter-spacing:.04em;pointer-events:none}
.wxs-bthk{font-size:.48rem;color:rgba(255,255,255,.7);text-shadow:0 1px 3px rgba(0,0,0,.6);pointer-events:none}
.wall-detail-panel{background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r-md);overflow:hidden;margin:0 0 1.5rem;box-shadow:var(--sh-sm)}
.wdp-layer-strip{display:flex;overflow-x:auto;border-bottom:1px solid var(--bdr)}
.wdp-layer-strip::-webkit-scrollbar{height:2px}.wdp-layer-strip::-webkit-scrollbar-thumb{background:var(--gold-b)}
.wdp-btn{padding:.65rem 1.1rem;font-size:.68rem;font-weight:600;color:var(--txt2);background:none;border:none;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--t);letter-spacing:.06em;text-transform:uppercase}
.wdp-btn.active{color:var(--gold);border-bottom-color:var(--gold);background:var(--gold-d)}
.wdp-content{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem}
.wdp-icon{width:40px;height:40px;background:var(--gold-d);border:1px solid var(--gold-b);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.wdp-content h4{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--txt);margin-bottom:.4rem}
.wdp-content p{font-size:.82rem;color:var(--txt2);line-height:1.65;margin-bottom:.6rem}
.wdp-specs{display:flex;flex-wrap:wrap;gap:.4rem}
.wdp-tag{font-size:.64rem;font-weight:600;padding:.3rem .7rem;background:var(--bg-s);border:1px solid var(--bdr2);border-radius:var(--r);color:var(--txt2);letter-spacing:.04em}
.wall-total{display:flex;align-items:stretch;background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r-md);overflow:hidden}
.wt-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem;gap:.35rem}
.wt-val{font-family:var(--serif);font-size:1.6rem;font-weight:600;font-style:italic;color:var(--gold);letter-spacing:-.01em}
.wt-lbl{font-size:.65rem;color:var(--txt2);text-transform:uppercase;letter-spacing:.08em}
.wt-sep{width:1px;background:var(--bdr);flex-shrink:0;margin:.75rem 0}

/* ===== COMPARACION ===== */
.compare{background:var(--bg)}
.compare-grid{border:1px solid var(--bdr);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm)}
.compare-header{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-m);padding:1rem 1.5rem;gap:.75rem;border-bottom:1px solid var(--bdr)}
.ch-a{font-size:.72rem;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}
.ch-b{font-size:.72rem;font-weight:600;color:var(--txt2);letter-spacing:.08em;text-transform:uppercase}
.compare-row{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-s);padding:.9rem 1.5rem;gap:.75rem;align-items:center;border-bottom:1px solid var(--bdr);transition:background var(--t)}
.compare-row:hover{background:var(--bg-m)}
.compare-row:last-child{border-bottom:none}
.cr-label{font-size:.82rem;color:var(--txt2)}
.cr-bar{height:3px;border-radius:2px;position:relative;overflow:hidden;width:0%;transition:width 1.5s var(--ease)}
.cr-bar::after{content:attr(data-val);position:absolute;top:-20px;right:0;font-size:.68rem;font-weight:600;color:var(--gold);white-space:nowrap;opacity:0;transition:opacity .3s .8s}
.compare-row:hover .cr-bar::after{opacity:1}
.cr-a .cr-bar{background:linear-gradient(90deg,var(--gold-d),var(--gold))}
.cr-b .cr-bar{background:rgba(180,60,60,.25)}

/* ===== NO-INCLUYE ===== */
.ni-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.ni-item{display:flex;align-items:center;gap:7px;padding:6px 9px;background:var(--bg-s);border:1px solid var(--bdr);border-radius:var(--r)}
.ni-cb{width:14px;height:14px;accent-color:var(--gold);cursor:pointer;flex-shrink:0}
.ni-lbl{font-size:.8rem;color:var(--txt2);cursor:pointer;flex:1;line-height:1.3}
.ni-del{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--txt2);cursor:pointer;font-size:13px;border-radius:var(--r);transition:color .14s;flex-shrink:0}
.ni-del:hover{color:#C94040}
.ni-add{display:flex;align-items:center;gap:5px;grid-column:1/-1;padding:5px 9px;background:transparent;border:1px dashed var(--bdr2);border-radius:var(--r);color:var(--txt2);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .17s}
.ni-add:hover{border-color:var(--gold-b);color:var(--gold);background:var(--gold-d)}

/* ===== FAQ ===== */
.faq{background:var(--bg-m)}
.faq-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:6rem;align-items:start}
.faq-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.faq-badge{font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.4rem .9rem;border:1px solid var(--gold-b);color:var(--gold);border-radius:var(--r);background:var(--gold-d)}
.faq-item{background:var(--bg-s);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;transition:border-color var(--t);margin-bottom:.5rem}
.faq-item.open{border-color:var(--gold-b)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--txt);cursor:pointer;transition:color var(--t);background:none;border:none;text-align:left}
.faq-q:hover{color:var(--gold)}
.faq-item.open .faq-q{color:var(--gold)}
.faq-icon{flex-shrink:0;transition:transform .3s var(--ease);color:var(--txt2)}
.faq-item.open .faq-icon{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding:.75rem 1.25rem 1.25rem;font-size:.84rem;color:var(--txt2);line-height:1.8}

/* ===== CTA ===== */
.cta-sec{background:var(--dark);position:relative;overflow:hidden}
.cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(201,168,76,.08) 0%,transparent 60%)}
.cta-sec::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold-grad)}
.cta-inner{max-width:800px;margin:0 auto;padding:6rem 2.5rem;text-align:center}
.cta-tag{display:inline-flex;align-items:center;gap:8px;font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.75rem;border:1px solid var(--gold-b);padding:7px 16px;border-radius:var(--r);background:var(--gold-d)}
.cta-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite}
.cta-h2{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:700;color:var(--txt-inv);line-height:1.06;margin-bottom:1.25rem}
.cta-h2 em{color:var(--gold);font-style:italic}
.cta-p{font-size:1rem;color:rgba(245,240,232,.55);line-height:1.82;max-width:500px;margin:0 auto 2.5rem}
.cta-btns{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.cta-note{display:block;margin-top:1.25rem;font-size:.68rem;color:rgba(245,240,232,.28);letter-spacing:.08em;text-transform:uppercase}

/* ===== CONTACTO ===== */
.contact{background:var(--bg-s)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.ci-items{display:flex;flex-direction:column;gap:1rem;margin:1.75rem 0}
.ci-item{display:flex;align-items:center;gap:1rem}
.ci-ico{width:40px;height:40px;background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.ci-item strong{display:block;font-size:.83rem;font-weight:700;color:var(--txt)}
.ci-item span{font-size:.8rem;color:var(--txt2)}
.cf{background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r-md);padding:2.5rem;box-shadow:var(--sh-sm)}
.fg{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.fg label{font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--txt2)}
.fg input,.fg select,.fg textarea{width:100%;background:var(--bg-s);border:1px solid var(--bdr);border-radius:var(--r);padding:11px 14px;font-family:var(--sans);font-size:.88rem;color:var(--txt);outline:none;appearance:none;transition:border-color var(--t)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold)}
.fg textarea{resize:vertical;min-height:100px}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239C9488' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* ===== PRESUPUESTOS (presupuestos.html) ===== */
.pay-cur-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--bdr);flex-wrap:wrap}
.pay-cur-lbl{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--txt2)}
.pay-cur-toggle{display:flex;border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.pct{padding:5px 14px;background:none;border:none;color:var(--txt2);cursor:pointer;font-size:.75rem;font-weight:700;transition:all .17s}
.pct.on{background:var(--gold);color:var(--dark)}
.rate-inp{background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:5px 9px;color:var(--txt);outline:none;width:110px;font-size:.78rem;transition:border-color .15s}
.rate-inp:focus{border-color:var(--gold)}
.pay-form-toggle{display:flex;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--bdr)}
.pf-radio{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.8rem;color:var(--txt2)}
.pf-radio input{accent-color:var(--gold);width:14px;height:14px;cursor:pointer}
.pay-total-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.pay-cur-sym{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--gold)}
.pay-amt-inp{background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:8px 12px;color:var(--gold);outline:none;font-family:var(--serif);font-size:1.25rem;font-weight:600;width:180px;text-align:right;transition:border-color .15s}
.pay-amt-inp:focus{border-color:var(--gold)}
.pay-stages-a,.pay-stages-b{display:flex;flex-direction:column;gap:8px}
.ps{display:flex;align-items:flex-start;gap:12px;padding:12px 15px;background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r-md)}
.ps-num{width:28px;height:28px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--dark);flex-shrink:0;margin-top:2px}
.ps-info{flex:1}.ps-nm{font-size:.8rem;font-weight:600;color:var(--txt);margin-bottom:1px}
.ps-ds{font-size:.72rem;color:var(--txt2);line-height:1.4}
.ps-amt{text-align:right;flex-shrink:0}.ps-usd{font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--gold);font-variant-numeric:tabular-nums}
.ps-pct{font-size:.68rem;color:var(--txt2)}
.wk-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.wk-lbl{font-size:.8rem;color:var(--txt2)}
.wk-inp{background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:5px 9px;color:var(--txt);outline:none;width:60px;text-align:center;font-size:.85rem;font-weight:600;transition:border-color .15s}
.wk-inp:focus{border-color:var(--gold)}
.ms-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r)}
.ms-name{flex:1;background:transparent;border:none;color:var(--txt);outline:none;font-size:.8rem}
.ms-pct{width:55px;background:transparent;border:none;border-bottom:1px solid var(--bdr);color:var(--gold);outline:none;font-size:.8rem;font-weight:700;text-align:right;padding:0 2px}
.ms-pct:focus{border-color:var(--gold)}
.ms-amt-disp{font-family:var(--serif);font-size:.8rem;font-weight:600;color:var(--gold);min-width:90px;text-align:right;font-variant-numeric:tabular-nums}
.ms-sum-warn{font-size:.72rem;padding:5px 10px;border-radius:var(--r);margin-top:4px;display:none}
.ms-sum-warn.err{display:block;background:rgba(201,64,64,.08);color:#C94040;border:1px solid rgba(201,64,64,.2)}
.ms-sum-warn.ok{display:block;background:rgba(61,143,98,.08);color:#3D8F62;border:1px solid rgba(61,143,98,.2)}
.m2-price-row{display:flex;align-items:flex-end;gap:12px;margin-top:10px;padding:10px 14px;background:var(--bg-m);border:1px solid var(--bdr);border-radius:var(--r);flex-wrap:wrap}
.m2-pr-lbl{font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--txt2);padding-bottom:9px;white-space:nowrap}
.m2-pr-inp{width:82px!important}
.m2-result{margin-left:auto;text-align:right}
.m2-result-lbl{display:block;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--txt2);margin-bottom:2px}
.m2-result-val{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:var(--gold);font-variant-numeric:tabular-nums}
.save-toast{position:fixed;bottom:20px;right:20px;background:var(--bg-m);border:1px solid var(--bdr);color:var(--txt2);font-size:.78rem;padding:9px 15px;border-radius:var(--r);opacity:0;pointer-events:none;transition:opacity .25s;z-index:999;box-shadow:var(--sh-sm)}
.save-toast.show{opacity:1}
.bgo{background:var(--gold);color:var(--dark)}.bgo:hover{background:var(--gold-h)}
.type-btn.on,.tipo-btn.on{background:var(--gold);color:var(--dark)}
.modal-num{width:20px;height:20px;border-radius:50%;background:var(--gold);color:var(--dark);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:7px}

/* ===== FOOTER ===== */
.footer{background:var(--dark);border-top:1px solid rgba(201,168,76,.15);padding:5rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(201,168,76,.08)}
.footer-tag{font-size:.85rem;color:rgba(245,240,232,.38);line-height:1.7;margin-bottom:1.25rem}
.foot-soc{display:flex;gap:8px}
.foot-soc a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(245,240,232,.04);border:1px solid rgba(201,168,76,.18);border-radius:var(--r);color:rgba(245,240,232,.42);transition:all var(--t)}
.foot-soc a:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-d)}
.fn h4{font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,240,232,.8);margin-bottom:1rem}
.fn ul{display:flex;flex-direction:column;gap:.5rem}
.fn a{font-size:.82rem;color:rgba(245,240,232,.36);transition:color var(--t)}
.fn a:hover{color:var(--gold)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;flex-wrap:wrap;gap:.75rem}
.footer-bot p{font-size:.7rem;color:rgba(245,240,232,.26)}
.footer-bot a{font-size:.7rem;color:rgba(245,240,232,.26);transition:color var(--t)}
.footer-bot a:hover{color:var(--gold)}

/* ===== WA FAB ===== */
.wa-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:99;width:52px;height:52px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:all var(--t);animation:wap 3s ease-in-out infinite}
.wa-fab:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,.5)}

/* ===== PRINT ===== */
@media print{#pv{display:block!important}body>*:not(#pv){display:none!important}}
.pv-bname{font-size:12px;font-weight:700;letter-spacing:.22em;color:#1A1612;display:block}
.pv-modal-item{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:#2A2A2A;line-height:1.5}
.pv-sec ul li{display:flex;align-items:flex-start;gap:8px;font-size:11.5px;color:#2A2A2A;line-height:1.5}
.pv-ni-item{display:flex;align-items:center;gap:8px;font-size:11.5px;color:#2A2A2A;padding:6px 0;border-bottom:1px solid #F4F1EB}
.pv-total-sub{font-size:10px;color:#aaa;margin-top:4px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .hero-inner{padding:calc(var(--nav) + 3rem) 2.5rem 3.5rem}
  .why-grid{grid-template-columns:1fr 1fr}
  .proc-panel.active{grid-template-columns:1fr}
  .proc-img{min-height:240px}
  .faq-layout{grid-template-columns:1fr;gap:2rem}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:768px){
  .container{padding:0 1.25rem}
  .section{padding:4.5rem 0}
  .hero-inner{padding:calc(var(--nav) + 2.5rem) 1.25rem 2.5rem}
  .hero-h1 em{font-size:clamp(4.5rem,19vw,7.5rem)}
  .hero-h1-pre,.hero-h1-post{font-size:.85rem;letter-spacing:.3em}
  .hero-h1-pre::before,.hero-h1-pre::after,.hero-h1-post::before,.hero-h1-post::after{width:22px;margin:0 .65em}
  .hs-grid{flex-wrap:wrap}
  .hs-sep{display:none}
  .hs-item{min-width:50%;padding:.75rem .5rem}
  .why-grid{grid-template-columns:1fr;gap:1px}
  .compare-header,.compare-row{grid-template-columns:1fr;gap:.5rem}
  .port-grid{grid-template-columns:1fr 1fr}
  .port-item.large{grid-column:span 2;grid-row:span 1}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bot{flex-direction:column;text-align:center}
  .nav-links{display:none;margin-left:0}
  .burger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:var(--nav);left:0;right:0;background:var(--dark);border-bottom:1px solid rgba(201,168,76,.15);padding:1.5rem 1.25rem;gap:1.25rem;z-index:99}
  .nav-links.open a{color:rgba(245,240,232,.62)}
  .nav-links.open a:hover{color:var(--gold)}
  .nav-wa{display:none}
  .pn{gap:0}
  .faq-layout{gap:2rem}
}
