*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#faf8f5;--bg2:#f2efe9;--white:#fff;
  --text:#1c1c1a;--text2:#4a4540;--muted:#8a8480;
  --accent:#7a6552;--accent2:#9b8068;
  --border:rgba(28,28,26,.1);
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'Inter',system-ui,sans-serif;
  --max:1240px;
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--fb);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* WHATSAPP */
#wa{position:fixed;bottom:2rem;right:2rem;z-index:999;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.35);transition:transform .2s,box-shadow .2s}
#wa:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.45)}
#wa svg{width:30px;height:30px;fill:#fff}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.6rem 3rem;transition:background .35s,padding .35s,box-shadow .35s}
#nav.scrolled{background:rgba(250,248,245,.97);backdrop-filter:blur(10px);padding:1rem 3rem;box-shadow:0 1px 0 var(--border)}
.logo{font-family:var(--fd);font-size:1.4rem;font-weight:400;letter-spacing:.04em;color:var(--text)}
.logo small{display:block;font-family:var(--fb);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:-2px;font-weight:300}
.nav-links{display:flex;align-items:center;gap:2.2rem;list-style:none}
.nav-links a{font-size:.7rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--text2);transition:color .2s}
.nav-links a:hover{color:var(--accent)}
.nav-btn{background:var(--text)!important;color:var(--bg)!important;padding:.5rem 1.4rem!important;letter-spacing:.1em!important;transition:background .2s!important}
.nav-btn:hover{background:var(--accent)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{display:block;width:22px;height:1px;background:var(--text)}
#mob-nav{display:none;position:fixed;inset:0;z-index:99;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:2.2rem}
#mob-nav.open{display:flex}
#mob-nav a{font-family:var(--fd);font-size:1.9rem;font-weight:300;color:var(--text)}
#mob-nav a:hover{color:var(--accent)}
#mob-close{position:absolute;top:1.5rem;right:2rem;font-size:1.3rem;cursor:pointer;background:none;border:none;color:var(--muted);font-family:var(--fb)}

/* BREADCRUMB */
.breadcrumb{max-width:var(--max);margin:0 auto;padding:.8rem 3rem;font-size:.72rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;margin-top:80px}
.breadcrumb a{color:var(--muted);transition:color .2s}
.breadcrumb a:hover{color:var(--text)}
.breadcrumb span{color:var(--border)}

/* PAGE HERO */
.page-hero{position:relative;height:70vh;min-height:440px;overflow:hidden;display:flex;align-items:flex-end}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(28,28,26,.68) 0%,rgba(28,28,26,.15) 60%,transparent 100%)}
.page-hero-body{position:relative;z-index:2;max-width:var(--max);width:100%;margin:0 auto;padding:3rem}
.page-hero-tag{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(250,248,245,.6);margin-bottom:.6rem}
.page-hero h1{font-family:var(--fd);font-size:clamp(2.5rem,5vw,5rem);font-weight:300;color:#fff;line-height:1.05;max-width:16ch}
.page-hero h1 em{font-style:italic}
.page-hero-desc{font-size:.95rem;color:rgba(250,248,245,.7);margin-top:1rem;max-width:40ch;line-height:1.7}

/* VIDEO HERO */
.video-hero{position:relative;height:70vh;min-height:440px;overflow:hidden;display:flex;align-items:flex-end}
.video-hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(28,28,26,.68) 0%,transparent 60%)}
.video-hero .page-hero-body{z-index:2}

/* SHARED SECTION */
.sec{padding:6rem 3rem}
.sec-in{max-width:var(--max);margin:0 auto}
.sec-tag{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:.7rem}
.sec-h2{font-family:var(--fd);font-size:clamp(1.9rem,3.5vw,3rem);font-weight:300;color:var(--text);line-height:1.15;margin-bottom:1rem}
.sec-h2 em{font-style:italic}
.sec-head{margin-bottom:3rem}
.sec-head.c{text-align:center}

/* CONTENT GRID */
.content-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;align-items:start}
.content-grid.rev{grid-template-columns:1fr 1.2fr}
.content-text p{font-size:.92rem;color:var(--text2);line-height:1.9;margin-bottom:1.2rem}
.content-text strong{color:var(--text);font-weight:500}
.content-text ul{margin:1rem 0 1.2rem 0;list-style:none}
.content-text ul li{font-size:.88rem;color:var(--text2);padding:.4rem 0;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:.6rem}
.content-text ul li::before{content:'—';color:var(--accent);font-size:.7rem;flex-shrink:0}
.content-text ul li:last-child{border-bottom:none}
.content-img img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top}
.content-img img.wide{aspect-ratio:4/3}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.gallery.three-col{grid-template-columns:repeat(3,1fr)}
.gallery-item{overflow:hidden;aspect-ratio:3/4;background:var(--bg2)}
.gallery-item.wide{aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.04)}

/* PRICES MINI */
.prices-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pm{background:var(--white);border:1px solid var(--border);padding:2.2rem 1.8rem;position:relative;transition:border-color .3s,transform .3s}
.pm:hover{border-color:var(--accent2);transform:translateY(-3px)}
.pm.feat{border-color:var(--accent)}
.pm-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .9rem;white-space:nowrap}
.pm-nm{font-family:var(--fd);font-size:1.3rem;font-weight:400;color:var(--text);margin-bottom:.3rem}
.pm-price{font-family:var(--fd);font-size:3.2rem;font-weight:300;color:var(--text);line-height:1;margin:.5rem 0}
.pm-price sup{font-size:1rem;vertical-align:top;margin-top:.5rem;display:inline-block}
.pm-list{list-style:none;margin:.8rem 0 1.5rem}
.pm-list li{font-size:.78rem;color:var(--text2);padding:.4rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.5rem}
.pm-list li::before{content:'—';color:var(--accent);font-size:.68rem;flex-shrink:0}
.pm-list li:last-child{border-bottom:none}
.pm-btn{display:block;text-align:center;border:1px solid var(--border);padding:.7rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:border-color .2s,color .2s}
.pm-btn:hover,.pm.feat .pm-btn{border-color:var(--accent);color:var(--accent)}

/* STEPS MINI */
.steps-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.step-mini{border-top:1px solid var(--border);padding-top:1.3rem}
.step-n{font-family:var(--fd);font-size:3rem;font-weight:300;color:rgba(28,28,26,.1);line-height:1;margin-bottom:.7rem}
.step-t{font-size:.88rem;font-weight:500;color:var(--text);margin-bottom:.4rem}
.step-d{font-size:.8rem;color:var(--muted);line-height:1.7}

/* CTA BAND */
.cta-band{background:var(--text);padding:6rem 3rem;text-align:center}
.cta-tag{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(250,248,245,.4);margin-bottom:1rem}
.cta-h{font-family:var(--fd);font-size:clamp(2rem,4.5vw,3.8rem);font-weight:300;color:var(--bg);margin-bottom:.8rem}
.cta-h em{font-style:italic}
.cta-sub{font-size:.88rem;color:rgba(250,248,245,.55);margin-bottom:2.5rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-cream{background:var(--bg);color:var(--text);padding:.9rem 2.2rem;font-size:.73rem;font-weight:400;letter-spacing:.13em;text-transform:uppercase;transition:background .2s;display:inline-block}
.btn-cream:hover{background:var(--bg2)}
.btn-wa{background:#25D366;color:#fff;padding:.9rem 2.2rem;font-size:.73rem;font-weight:400;letter-spacing:.13em;text-transform:uppercase;transition:background .2s;display:inline-flex;align-items:center;gap:.6rem}
.btn-wa:hover{background:#20ba5a}
.btn-wa svg{width:18px;height:18px;fill:#fff}
.btn-dark{background:var(--text);color:var(--bg);padding:.85rem 2rem;font-size:.73rem;font-weight:400;letter-spacing:.13em;text-transform:uppercase;transition:background .2s;display:inline-block}
.btn-dark:hover{background:var(--accent)}
.btn-line{border:1px solid var(--text);color:var(--text);padding:.85rem 2rem;font-size:.73rem;font-weight:400;letter-spacing:.13em;text-transform:uppercase;transition:border-color .2s,color .2s;display:inline-block}
.btn-line:hover{border-color:var(--accent);color:var(--accent)}
.btns{display:flex;gap:1rem;flex-wrap:wrap}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:start}
.form-group{margin-bottom:1.4rem}
.form-group label{display:block;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text2);margin-bottom:.5rem;font-weight:400}
.form-group input,.form-group textarea,.form-group select{width:100%;background:var(--white);border:1px solid var(--border);padding:.85rem 1rem;font-size:.9rem;font-family:var(--fb);color:var(--text);font-weight:300;transition:border-color .2s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent)}
.form-group textarea{resize:vertical;min-height:130px}
.form-check{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:1.5rem}
.form-check input{margin-top:4px;flex-shrink:0;accent-color:var(--accent)}
.form-check label{font-size:.78rem;color:var(--muted);line-height:1.6}
.form-check label a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color .2s}
.form-check label a:hover{border-color:var(--accent)}
.form-submit{width:100%;background:var(--text);color:var(--bg);border:none;padding:1rem 2rem;font-size:.78rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:background .2s;font-family:var(--fb)}
.form-submit:hover{background:var(--accent)}
.contact-info h3{font-family:var(--fd);font-size:1.8rem;font-weight:300;margin-bottom:1.5rem}
.contact-info h3 em{font-style:italic}
.info-row{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.2rem}
.info-row svg{width:18px;height:18px;stroke:var(--accent);fill:none;flex-shrink:0;margin-top:2px}
.info-row p{font-size:.88rem;color:var(--text2);line-height:1.6}
.info-row p strong{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem;font-weight:400}
.wa-big{display:flex;align-items:center;gap:.8rem;background:#25D366;color:#fff;padding:1rem 1.5rem;margin-top:2rem;transition:background .2s}
.wa-big:hover{background:#20ba5a}
.wa-big svg{width:24px;height:24px;fill:#fff;flex-shrink:0}
.wa-big-t{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:400}
.wa-big-s{font-size:.72rem;opacity:.8;margin-top:1px}
.alert{padding:1rem 1.2rem;margin-bottom:1.5rem;font-size:.85rem;border-left:3px solid}
.alert-ok{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}
.alert-err{background:#fce4ec;border-color:#e91e63;color:#880e4f}

/* PRECIOS PAGE */
.precios-all{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pc{background:var(--white);border:1px solid var(--border);padding:2.5rem 2rem;position:relative;transition:border-color .3s,transform .3s}
.pc:hover{border-color:var(--accent2);transform:translateY(-3px)}
.pc.feat{border-color:var(--accent)}
.pc-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:.3rem 1rem;white-space:nowrap}
.pc-nm{font-family:var(--fd);font-size:1.35rem;font-weight:400;color:var(--text)}
.pc-price{font-family:var(--fd);font-size:3.5rem;font-weight:300;color:var(--text);line-height:1;margin:.5rem 0}
.pc-price sup{font-size:1.1rem;vertical-align:top;margin-top:.5rem;display:inline-block}
.pc-desc{font-size:.78rem;color:var(--muted);margin-bottom:1.5rem;line-height:1.6}
.pc-list{list-style:none;margin-bottom:1.8rem}
.pc-list li{font-size:.8rem;color:var(--text2);padding:.45rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.55rem}
.pc-list li::before{content:'—';color:var(--accent);font-size:.68rem;flex-shrink:0}
.pc-list li:last-child{border-bottom:none}
.pc-btn{display:block;text-align:center;border:1px solid var(--border);padding:.75rem;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:border-color .2s,color .2s}
.pc-btn:hover,.pc.feat .pc-btn{border-color:var(--accent);color:var(--accent)}

/* LEGAL PAGES */
.legal-content{max-width:800px;margin:0 auto;padding:5rem 3rem 7rem}
.legal-content h1{font-family:var(--fd);font-size:3rem;font-weight:300;margin-bottom:.5rem}
.legal-content .date{font-size:.78rem;color:var(--muted);margin-bottom:3rem;letter-spacing:.05em}
.legal-content h2{font-family:var(--fd);font-size:1.6rem;font-weight:400;margin:2.5rem 0 .8rem}
.legal-content p{font-size:.9rem;color:var(--text2);line-height:1.9;margin-bottom:1rem}
.legal-content ul{margin:.5rem 0 1rem 1.2rem}
.legal-content ul li{font-size:.9rem;color:var(--text2);line-height:1.8;margin-bottom:.3rem}
.legal-content a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color .2s}
.legal-content a:hover{border-color:var(--accent)}
.legal-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.85rem}
.legal-content th{background:var(--bg2);padding:.7rem 1rem;text-align:left;font-weight:500;border-bottom:1px solid var(--border)}
.legal-content td{padding:.7rem 1rem;border-bottom:1px solid var(--border);color:var(--text2)}

/* 404 */
.page-404{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:3rem}
.page-404 h1{font-family:var(--fd);font-size:8rem;font-weight:300;color:var(--border);line-height:1}
.page-404 h2{font-family:var(--fd);font-size:2rem;font-weight:300;margin-bottom:1rem}
.page-404 p{font-size:.9rem;color:var(--muted);margin-bottom:2rem}

/* FOOTER */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:5rem 3rem 2.5rem}
.footer-g{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
.f-logo{font-family:var(--fd);font-size:1.4rem;font-weight:400;color:var(--text)}
.f-logo small{display:block;font-size:.6rem;font-family:var(--fb);letter-spacing:.26em;text-transform:uppercase;color:var(--muted);font-weight:300}
.f-desc{font-size:.82rem;color:var(--muted);line-height:1.75;margin-top:1rem;max-width:26ch}
.f-social{display:flex;gap:1.2rem;margin-top:1.5rem}
.f-social a{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid transparent;padding-bottom:1px;transition:color .2s,border-color .2s}
.f-social a:hover{color:var(--text);border-color:var(--text)}
.f-col h4{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text2);margin-bottom:1.2rem;font-weight:500}
.f-col ul{list-style:none}
.f-col ul li{margin-bottom:.55rem}
.f-col ul li a{font-size:.8rem;color:var(--muted);transition:color .2s}
.f-col ul li a:hover{color:var(--text)}
.footer-b{max-width:var(--max);margin:0 auto;padding-top:2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-b p{font-size:.72rem;color:var(--muted)}
.footer-b div{display:flex;gap:1.5rem}
.footer-b div a{font-size:.72rem;color:var(--muted);transition:color .2s}
.footer-b div a:hover{color:var(--text)}

/* ESTUDIO PAGE */
.estudio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3px}
.estudio-item{overflow:hidden;position:relative}
.estudio-item.tall{grid-row:span 2}
.estudio-item img{width:100%;height:100%;object-fit:cover;min-height:280px;transition:transform .6s}
.estudio-item:hover img{transform:scale(1.04)}

/* REVEAL */
.rv{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.rv.on{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .footer-g{grid-template-columns:1fr 1fr;gap:2.5rem}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .precios-all{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  #nav{padding:1.2rem 1.5rem}
  #nav.scrolled{padding:.9rem 1.5rem}
  .nav-links,.nav-btn-wrap{display:none}
  .hamburger{display:flex}
  .breadcrumb{padding:.8rem 1.5rem}
  .page-hero{height:55vw;min-height:320px}
  .page-hero-body{padding:2rem 1.5rem}
  .sec{padding:4rem 1.5rem}
  .content-grid,.content-grid.rev{grid-template-columns:1fr;gap:2.5rem}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .steps-mini{grid-template-columns:1fr}
  .prices-mini,.precios-all{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
  .footer-g{grid-template-columns:1fr}
  .estudio-grid{grid-template-columns:1fr}
  .estudio-item.tall{grid-row:auto}
}
@media(max-width:600px){
  .gallery{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  #wa{bottom:1.2rem;right:1.2rem}
}
/* ===============================
   HOME PAGE - VENTADEFOTOS 2026
   =============================== */
#hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(420px,52vw);
  align-items:stretch;
  background:var(--bg);
}
.hero-l{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:8rem 3rem 4rem max(3rem,calc((100vw - var(--max))/2 + 3rem));
  min-width:0;
}
.eyebrow{
  font-size:.68rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.2rem;
  font-weight:400;
}
#hero h1{
  font-family:var(--fd);
  font-size:clamp(3.1rem,7vw,7rem);
  font-weight:300;
  line-height:.94;
  letter-spacing:-.04em;
  color:var(--text);
  max-width:9ch;
}
#hero h1 em{font-style:italic;color:var(--accent)}
.hero-desc{
  max-width:48ch;
  margin:1.7rem 0 2rem;
  font-size:1rem;
  line-height:1.9;
  color:var(--text2);
}
.hero-r{position:relative;min-height:100vh;overflow:hidden;background:var(--bg2)}
.hero-r img{width:100%;height:100%;object-fit:cover;object-position:center top}
.stats{display:flex;gap:2rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.stats>div{min-width:72px}
.stat-n{display:block;font-family:var(--fd);font-size:2rem;font-weight:300;line-height:1;color:var(--text)}
.stat-l{display:block;margin-top:.35rem;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}

#servicios{background:var(--bg);overflow:hidden}
.svcs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:3px;
  width:100%;
}
.svc{
  position:relative;
  display:block;
  overflow:hidden;
  min-height:360px;
  background:var(--bg2);
  isolation:isolate;
}
.svc.tall{min-height:520px}
.svc.sq{min-height:360px}
.svc img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  position:absolute;inset:0;z-index:0;
  transition:transform .7s ease,filter .7s ease;
}
.svc::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(28,28,26,.72),rgba(28,28,26,.12) 55%,transparent)}
.svc:hover img{transform:scale(1.045);filter:saturate(1.04)}
.svc-body{position:absolute;left:1.5rem;right:1.5rem;bottom:1.5rem;z-index:2;color:#fff}
.svc-cat{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:.35rem}
.svc-nm{font-family:var(--fd);font-size:1.85rem;font-weight:300;line-height:1.05;color:#fff}
.svc-arr{display:inline-block;margin-top:.9rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78)}

#reel{position:relative;height:72vh;min-height:430px;overflow:hidden;background:var(--text)}
.reel-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.84}
#reel::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,28,26,.72),rgba(28,28,26,.22),rgba(28,28,26,.62))}
.reel-overlay{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;height:100%;text-align:center;padding:3rem}
.reel-overlay h2{font-family:var(--fd);font-size:clamp(3rem,7vw,7rem);line-height:.95;font-weight:300;color:#fff}
.reel-overlay h2 em{font-style:italic}

.vids{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.yt-wrap{position:relative;aspect-ratio:16/9;background:var(--bg2);overflow:hidden;cursor:pointer}
.yt-thumb{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.yt-wrap:hover .yt-thumb{transform:scale(1.04)}
.yt-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(28,28,26,.18)}
.yt-play>div{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px rgba(0,0,0,.22)}
.yt-play svg{width:24px;height:24px;fill:var(--text);margin-left:4px}
.yt-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid-lbl{margin-top:.8rem;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.step{border-top:1px solid var(--border);padding-top:1.4rem}
.step .step-n{font-family:var(--fd);font-size:3.8rem;font-weight:300;color:rgba(28,28,26,.1);line-height:1;margin-bottom:.9rem}
.step .step-t{font-size:.92rem;font-weight:500;color:var(--text);margin-bottom:.55rem}
.step .step-d{font-size:.82rem;color:var(--text2);line-height:1.8}

.oscar-g{display:grid;grid-template-columns:.9fr 1.1fr;gap:5rem;align-items:center}
.oscar-img-wrap{background:var(--bg2);overflow:hidden}
.oscar-img-wrap img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top}
.oscar-t p{font-size:.92rem;color:var(--text2);line-height:1.9;margin-bottom:1.1rem;max-width:62ch}
.oscar-t strong{color:var(--text);font-weight:500}
.oscar-t .btn-dark{margin-top:.8rem}

.precios-g{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.precios-foot{text-align:center;margin-top:1.7rem;font-size:.85rem;color:var(--muted)}
.precios-foot a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color .2s}
.precios-foot a:hover{border-color:var(--accent)}

#cta-band{background:var(--text);padding:6rem 3rem;text-align:center}
#cta-band .cta-tag{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(250,248,245,.4);margin-bottom:1rem}
#cta-band .cta-h{font-family:var(--fd);font-size:clamp(2rem,4.5vw,3.8rem);font-weight:300;color:var(--bg);margin-bottom:.8rem;line-height:1.08}
#cta-band .cta-h em{font-style:italic}
#cta-band .cta-sub{font-size:.88rem;color:rgba(250,248,245,.55);margin-bottom:2.5rem}

@media(max-width:1100px){
  #hero{grid-template-columns:1fr 48vw}
  .svcs{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  #hero{grid-template-columns:1fr;min-height:auto;padding-top:74px}
  .hero-l{padding:4rem 1.5rem 2.5rem}
  #hero h1{font-size:clamp(3rem,14vw,5rem)}
  .hero-r{min-height:58vh}
  .stats{gap:1.4rem}
  .svcs{grid-template-columns:repeat(2,1fr)}
  .svc,.svc.tall,.svc.sq{min-height:420px}
  .vids{grid-template-columns:1fr;gap:2rem}
  .oscar-g{grid-template-columns:1fr;gap:2.5rem}
  .precios-g{grid-template-columns:1fr}
}
@media(max-width:600px){
  .hero-desc{font-size:.92rem}
  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
  .stat-n{font-size:1.55rem}
  .stat-l{font-size:.58rem}
  .svcs{grid-template-columns:1fr}
  .svc,.svc.tall,.svc.sq{min-height:390px}
  .steps{grid-template-columns:1fr}
  #reel{height:55vh;min-height:330px}
  #cta-band{padding:4.5rem 1.5rem}
}
