:root{--red:#cf0707;--yellow:#f1b801;--ink:#111;--muted:#5a5a5a;--shadow:0 10px 30px rgba(0,0,0,.10)}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1120px,92vw);margin:0 auto}
.container-wide{width:min(1560px,96vw);margin:0 auto}
section{scroll-margin-top:90px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:9999;height:74px;display:flex;align-items:center;
background:rgba(255,255,255,.92);border-bottom:1px solid rgba(0,0,0,.06);
transition:background .25s ease, opacity .25s ease, backdrop-filter .25s ease}
.nav.scrolled{background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.18)}
.nav.scrolled:not(:hover){opacity:.35}
.nav:hover{opacity:1;background:rgba(255,255,255,.92)}
.nav-inner{width:min(1200px,94vw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:62px;width:auto}
.menu{display:flex;align-items:center;gap:14px}
.menu a{font-weight:800;padding:10px 10px;border-radius:12px}
.menu a:hover{background:rgba(241,184,1,.20)}
.menu a.cta{background:var(--red);color:#fff}
.menu a.cta:hover{background:#b00606}
.burger{display:none;border:0;background:transparent;padding:10px;border-radius:12px}
.burger:hover{background:rgba(0,0,0,.06)}
.burger svg{width:26px;height:26px}
.mobile{display:none}
@media(max-width:820px){
  .menu{display:none}
  .burger{display:inline-flex}
  .mobile{display:none;position:absolute;top:74px;left:0;right:0;background:rgba(255,255,255,.98);border-bottom:1px solid rgba(0,0,0,.06)}
  .mobile.open{display:block}
  .mobile a{display:block;padding:14px 18px;font-weight:900}
  .mobile a:hover{background:rgba(241,184,1,.18)}
  .mobile a.cta{background:var(--red);color:#fff}
}
.top-spacer{height:74px}

/* HERO */
.hero{height:100vh;position:relative;overflow:hidden}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(255,255,255,.86) 0%, rgba(255,255,255,.55) 40%, rgba(255,255,255,.08) 72%, rgba(255,255,255,0) 100%)}
.hero-content{position:relative;z-index:2;height:100%;display:flex;align-items:center;padding-top:90px}
.kicker{font-weight:900;color:var(--red);letter-spacing:.3px}
.h1{font-size:clamp(34px,5vw,60px);margin:12px 0 10px;line-height:1.05}
.p{font-size:clamp(16px,2.1vw,20px);color:#2b2b2b;max-width:56ch}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;border:1px solid rgba(0,0,0,.10);background:#fff;box-shadow:var(--shadow);font-weight:900}
.btn.primary{background:var(--red);border-color:var(--red);color:#fff;box-shadow:none}
.btn.primary:hover{background:#b00606}

/* BLOCKS */
.block{padding:72px 0}
.block-title{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}
.block-title h2{margin:0;font-size:34px}
.block-title p{margin:0;color:var(--muted)}
.small{color:var(--muted);font-size:14px}

/* SLIDER (full width, no crop, no text over image) */
.slider{position:relative;overflow:hidden;border-radius:28px;box-shadow:var(--shadow);background:#fff}
.slides{display:flex;transition:transform .55s ease}
.slide{min-width:100%;height:clamp(380px,64vh,720px);position:relative;background:transparent;padding:18px}
.slide img{width:100%;height:100%;object-fit:contain;background:#f3f3f3;border-radius:22px;box-shadow:0 18px 48px rgba(0,0,0,.14)}
.controls{position:absolute;right:24px;bottom:24px;display:flex;gap:10px;z-index:5}
.ctrl{width:48px;height:48px;border-radius:16px;border:0;background:rgba(255,255,255,.92);cursor:pointer;font-size:24px}
.ctrl:hover{background:#fff}
.dots{position:absolute;left:24px;bottom:24px;display:flex;gap:8px;z-index:5}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(255,255,255,.55);cursor:pointer}
.dot.active{background:var(--yellow)}

/* PARALLAX */
.parallax{height:52vh;min-height:340px;background:url('../img/parallax.jpg') center/cover fixed;display:flex;align-items:center}
@media(max-width:820px){.parallax{background-attachment:scroll}}
.glass{width:min(1120px,92vw);margin:0 auto;background:rgba(255,255,255,.84);backdrop-filter:blur(10px);
border:1px solid rgba(0,0,0,.06);border-radius:22px;padding:22px;box-shadow:var(--shadow)}
.glass h3{margin:0 0 6px;font-size:28px;color:var(--red)}
.glass p{margin:0;color:#2b2b2b;font-size:18px}
.row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.pill{display:inline-flex;align-items:center;padding:10px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.10);font-weight:900;background:#fff}
.pill.red{background:var(--red);border-color:var(--red);color:#fff}
.pill.yellow{background:var(--yellow);border-color:var(--yellow)}

/* CONTACT */
.grid2{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
@media(max-width:940px){.grid2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid rgba(0,0,0,.10);border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.card h3{margin:0 0 10px;font-size:22px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
label{font-weight:900;font-size:14px;color:#333}
input,textarea{width:100%;padding:12px;border-radius:14px;border:1px solid rgba(0,0,0,.16);font-size:16px;font-family:inherit}
textarea{min-height:110px;resize:vertical}

/* NOSOTROS */
.nosotros-hero{position:relative;background:#000;overflow:visible}
.nosotros-hero video{display:block;width:100vw;max-width:100%;height:auto;aspect-ratio:16/9;object-fit:contain;background:#000}
.nosotros-hero-bar{position:absolute;left:0;right:0;bottom:0;padding:18px 0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.65) 100%)}
.nosotros-hero-bar h1{margin:0 0 6px;color:#fff;font-size:clamp(30px,4.2vw,54px);letter-spacing:.2px}
.nosotros-hero-bar p{margin:0;color:rgba(255,255,255,.92);font-size:18px;max-width:60ch}

.story{padding:72px 0;background:linear-gradient(180deg, #fff 0%, #fbfbfb 100%)}
.story-grid{display:grid;grid-template-columns:1fr;gap:22px}
.story-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.story-card img{width:100%;height:auto;display:block}

@media(max-width:560px){
  .brand img{height:52px}
}

/* MAP */
.map-wrap{border-radius:22px;overflow:hidden;border:1px solid rgba(0,0,0,.10);box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:52vh;min-height:360px;border:0;display:block}

/* FOOTER */
.footer{padding:26px 0;color:var(--muted);border-top:1px solid rgba(0,0,0,.06);margin-top:40px}
.footer .container{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}