@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&family=Jost:wght@300;400;500;600;700&display=swap');

:root{
  --ink:#1b1b1b;
  --ink-soft:#3a3a3a;
  --muted:#7a756d;
  --paper:#ffffff;
  --cream:#f7f4ee;
  --cream-2:#efe9df;
  --line:rgba(20,20,20,.12);
  --line-soft:rgba(20,20,20,.07);
  --accent:#9c7c4f;
  --accent-2:#b9986a;
  --navy:#1b1b1b;
  --gold:#9c7c4f;
  --gold-2:#b9986a;
  --shadow:0 18px 50px rgba(20,20,20,.08);
  --shadow-dark:0 24px 70px rgba(0,0,0,.35);
  --radius:2px;
  --radius-sm:2px;
  --max:1320px;
  --font-display:'Fraunces', Georgia, serif;
  --font-sans:'Jost', Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--paper);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
::selection{background:rgba(156,124,79,.25)}

/* ============ LOADER ============ */
.page-loader{
  position:fixed; inset:0; z-index:9999; display:grid; place-items:center; gap:14px;
  background:var(--paper);
  transition:opacity .55s ease, visibility .55s ease;
}
.page-loader img{width:64px; animation:pulseLogo 1.6s ease-in-out infinite}
.page-loader span{font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); font-family:var(--font-sans)}
.page-loader.hide{opacity:0; visibility:hidden}
@keyframes pulseLogo{50%{opacity:.45}}

/* ============ HEADER ============ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:99;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:26px max(22px,calc((100% - var(--max))/2));
  background:transparent;
  border-bottom:1px solid transparent;
  transition:all .35s ease;
}
.site-header.scrolled{
  padding:14px max(22px,calc((100% - var(--max))/2));
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
}
.brand{display:flex; align-items:center; flex:0 0 auto}
.brand img{width:148px; height:auto; filter:brightness(0) invert(1); transition:filter .3s ease}
.site-header.scrolled .brand img{filter:none}
.main-nav{display:flex; align-items:center; justify-content:center; gap:26px; margin-left:auto}
.main-nav a{
  position:relative; padding:4px 0; font-weight:500; font-size:.76rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink);
  transition:.25s ease;
}
.main-nav a::after{
  content:""; position:absolute; left:0; bottom:-4px; width:0; height:1px; background:var(--accent);
  transition:.25s ease;
}
.main-nav a:hover::after{width:100%}
.site-header:not(.scrolled) .main-nav a{color:#fff}
.site-header:not(.scrolled) .main-nav a::after{background:#fff}
.site-header:not(.scrolled) .header-cta{border-color:rgba(255,255,255,.6); color:#fff}
.site-header:not(.scrolled) .header-cta:hover{background:#fff; color:var(--ink)}
.site-header:not(.scrolled) .menu-toggle span{background:#fff}
.menu-toggle{display:none; width:40px; height:40px; border:0; background:transparent; padding:10px; cursor:pointer}
.menu-toggle span{display:block; height:1px; margin:6px 0; background:var(--ink); transition:.25s ease}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex; align-items:center; gap:10px; padding:14px 26px; border-radius:var(--radius);
  font-size:.74rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; border:1px solid var(--ink);
  cursor:pointer; transition:.3s ease; background:transparent; color:var(--ink); white-space:nowrap;
}
.btn:hover{background:var(--ink); color:var(--paper)}
.btn-primary{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.btn-primary:hover{background:transparent; color:var(--ink)}
.btn-gold{background:transparent; color:var(--ink); border-color:var(--accent)}
.btn-gold:hover{background:var(--accent); color:#fff; border-color:var(--accent)}
.btn-outline{background:transparent; color:var(--ink); border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--ink)}
.btn-outline.light{color:#fff; border-color:rgba(255,255,255,.4)}
.btn-outline.light:hover{background:#fff; color:var(--ink)}
.btn-soft{background:transparent; color:var(--ink); border:1px solid var(--line); box-shadow:none}
.btn-soft:hover{border-color:var(--ink); background:transparent; color:var(--ink)}
.btn-dynamic::before,.btn-dynamic::after{display:none!important}
.link-button{
  appearance:none; -webkit-appearance:none; background:none; border:0; border-radius:0;
  padding:0; margin:0; color:var(--ink); font:inherit; cursor:pointer; display:inline-flex; align-items:center; gap:8px;
}
.link-button span:last-child{transition:.2s ease}
.link-button:hover span:last-child{margin-left:4px}

/* ============ SECTION / TITLES ============ */
.section{padding:110px 22px}
#quienes,#inspiracion,#lineas,#departamentos,#catalogo,#alianzas,#contacto{scroll-margin-top:88px}
.section-title{max-width:760px; margin:0 auto 56px; text-align:center}
.section-title span,.section-kicker,.eyebrow{
  display:inline-flex; align-items:center; gap:12px; font-size:.72rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--muted); font-weight:600; margin-bottom:6px;
}
.section-title h2,.copy-block h2,.mission-card h3,.logistics-card h2,.contact-copy h2,.modal-card h2{
  margin:18px 0 0; font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,4vw,3.4rem);
  line-height:1.18; color:var(--ink); letter-spacing:-.01em;
}
.section-title h2{font-size:clamp(1.85rem,3.2vw,2.85rem)}

/* ============ HERO ============ */
.hero{
  position:relative; z-index:0; min-height:100vh; overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end;
}
.hero-bg{position:absolute; inset:0; z-index:0}
.hero-slider{overflow:hidden}
.hero-slide{
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.6s ease;
}
.hero-slide.active{opacity:1}
.hero-gradient{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(10,10,10,.05) 0%, rgba(10,10,10,.12) 45%, rgba(10,10,10,.66) 100%);
}
.hero-orb{display:none}
.hero-content{
  position:relative; z-index:2; width:min(100%,var(--max)); margin:0 auto; padding:128px 22px 50px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:60px;
  box-sizing:border-box;
}
.hero-copy{color:#fff; max-width:680px}
.hero-logo-card{display:none}
.hero-logo{display:none}
.hero h1{
  font-family:var(--font-display); font-weight:400; font-size:clamp(1.9rem,3.6vw,3.2rem); line-height:1.12;
  letter-spacing:-.01em; margin:0 0 16px; text-wrap:balance; text-shadow:none;
}
.hero p{font-size:clamp(.85rem,1vw,.96rem); line-height:1.7; color:rgba(255,255,255,.86); max-width:520px; font-weight:300}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin:22px 0 16px}
.hero-actions .btn{border-color:rgba(255,255,255,.55); color:#fff}
.hero-actions .btn:hover{background:#fff; color:var(--ink)}
.hero-actions .btn-gold{border-color:var(--accent-2)}
.hero-actions .btn-gold:hover{background:var(--accent-2); color:#1b1b1b}
.hero-note{
  font-size:.78rem; line-height:1.6; color:rgba(255,255,255,.7); max-width:520px; font-weight:300;
  border-top:1px solid rgba(255,255,255,.22); padding-top:12px; margin-top:4px;
}
.hero-note strong{color:#fff; font-weight:600}
.hero-badges{display:flex; flex-wrap:wrap; gap:0; margin-top:12px}
.hero-badges span{
  font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.65); font-weight:500;
  padding:0 14px; border-right:1px solid rgba(255,255,255,.25);
}
.hero-badges span:first-child{padding-left:0}
.hero-badges span:last-child{border-right:0}
.hero-visual-nav{display:flex; gap:18px; margin-top:18px; flex-wrap:wrap}
.hero-visual-nav button{
  background:none; border:0; padding:0 0 8px; cursor:pointer; color:rgba(255,255,255,.55);
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; font-weight:500; border-bottom:1px solid transparent;
  transition:.25s ease;
}
.hero-visual-nav button:hover,.hero-visual-nav button.active{color:#fff; border-bottom-color:var(--accent-2)}

.hero-panel{
  position:relative; flex:0 0 auto; width:300px; color:#fff; padding-bottom:6px;
  border-left:1px solid rgba(255,255,255,.25); padding-left:28px;
  display:none;
}
.hero-panel span{font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.6); font-weight:600}
.hero-panel h2{font-family:var(--font-display); font-weight:400; font-size:1.5rem; line-height:1.25; letter-spacing:0; margin:10px 0 22px; color:#fff}
.mini-lines{display:grid; gap:12px}
.mini-lines div{padding:0; border:0; background:none; border-bottom:1px solid rgba(255,255,255,.18); padding-bottom:10px}
.mini-lines b{display:block; color:#fff; font-weight:600; font-size:.85rem; letter-spacing:.08em; text-transform:uppercase}
.mini-lines small{color:rgba(255,255,255,.6); font-size:.78rem}

.hero-stats{
  position:relative; z-index:2; width:min(100%,var(--max)); margin:0 auto; padding:14px 22px 22px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
  border-top:1px solid rgba(255,255,255,.18);
}
.hero-stats div{display:flex; align-items:baseline; gap:8px}
.hero-stats strong{font-family:var(--font-display); font-size:1.4rem; font-weight:400; color:#fff}
.hero-stats span{font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.6); font-weight:500}

/* ============ AMBIENTES / INSPIRE ============ */
.inspire-section{position:relative; overflow:hidden; background:var(--paper)}
.inspire-section::before{display:none}
.inspire-stage{
  position:relative; z-index:1; width:min(100%,var(--max)); margin:auto;
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); grid-auto-rows:370px; gap:2px;
}
.inspire-stage-4{grid-template-columns:repeat(2,minmax(0,1fr)); grid-auto-rows:480px}
.inspire-card,.inspire-card.large,.inspire-card.wide{
  position:relative; overflow:hidden; border-radius:0; background:var(--ink); min-height:370px; isolation:isolate;
  box-shadow:none; border:0;
}
.inspire-card::before{
  content:""; position:absolute; inset:0; background-image:var(--bg); background-size:cover; background-position:var(--pos,center);
  opacity:1; filter:grayscale(.06); transform:scale(1.0); transition:transform 1.4s ease;
}
.inspire-card:hover::before{transform:scale(1.045)}
.inspire-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,0) 38%, rgba(10,10,10,.62) 100%);
}
.inspire-card div{position:absolute; left:34px; right:34px; bottom:30px; color:#fff}
.inspire-tag{
  display:inline-block; margin-bottom:10px; padding:0; background:none; border:0;
  font-size:.68rem; letter-spacing:.28em; text-transform:uppercase; font-weight:600; color:rgba(255,255,255,.78);
}
.inspire-card h3{
  margin:0 0 14px; max-width:480px; font-family:var(--font-display); font-weight:400;
  font-size:clamp(1.5rem,2.1vw,2.2rem); line-height:1.18; letter-spacing:0; text-shadow:none;
}
.inspire-card .link-button{color:#fff; background:none; border:0; border-bottom:1px solid rgba(255,255,255,.5); border-radius:0; padding:0 0 4px; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; font-weight:600}
.inspire-card .link-button:hover{border-color:#fff}

.ambientes-tabs{
  width:min(100%,var(--max)); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border-top:1px solid var(--line);
}
.ambientes-tabs article{
  padding:34px 28px; border-right:1px solid var(--line); background:transparent; border-radius:0; box-shadow:none;
}
.ambientes-tabs article:last-child{border-right:0}
.ambientes-tabs h3{margin:0 0 12px; font-family:var(--font-display); font-weight:400; font-size:1.3rem; color:var(--ink)}
.ambientes-tabs p{margin:0 0 18px; font-size:.88rem; line-height:1.7; color:var(--muted); font-weight:300}
.ambientes-tabs .link-button{color:var(--ink); font-weight:600; border-bottom:1px solid var(--ink); border-radius:0; padding-bottom:3px; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase}

/* ============ LANGUAGE SWITCH ============ */
.lang-switch{display:flex; align-items:center; gap:2px; flex:0 0 auto}
.lang-switch button{
  border:0; background:transparent; padding:6px 9px; font-size:.7rem; font-weight:600; letter-spacing:.12em;
  color:rgba(255,255,255,.55); cursor:pointer; transition:.2s ease; border-radius:0;
}
.site-header.scrolled .lang-switch button{color:var(--muted)}
.lang-switch button:hover{color:#fff}
.site-header.scrolled .lang-switch button:hover{color:var(--ink)}
.lang-switch button.active{color:#fff; text-decoration:underline}
.site-header.scrolled .lang-switch button.active{color:var(--ink)}

/* ============ QUIENES SOMOS ============ */
.intro-section{background:var(--cream)}
.section-grid{width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:1fr .85fr; gap:64px; align-items:center}
.copy-block p{font-size:1rem; line-height:1.85; color:var(--ink-soft); font-weight:300}
.pill-row{display:flex; flex-wrap:wrap; gap:0; margin-top:30px; border-top:1px solid var(--line); padding-top:18px}
.pill-row span{
  background:none; border:0; padding:0 18px; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); font-weight:600; border-right:1px solid var(--line);
}
.pill-row span:first-child{padding-left:0}
.pill-row span:last-child{border-right:0}
.mission-card{position:relative}
.mission-photo{border-radius:0; overflow:hidden; margin-bottom:0; box-shadow:none}
.mission-photo img{width:100%; height:260px; object-fit:cover}
.glass-card{position:relative; overflow:hidden; padding:38px; border-radius:0; background:var(--paper); border:1px solid var(--line); box-shadow:none; backdrop-filter:none}
.glass-card::before{display:none}
.glass-card h3{font-family:var(--font-display); font-weight:400; font-size:1.7rem; margin:0 0 14px}
.glass-card p,.glass-card li{color:var(--muted); line-height:1.8; font-weight:300; font-size:.95rem}
.glass-card ul{padding-left:18px; margin-top:18px}
.glass-card li{margin-bottom:8px}

/* ============ LINEAS ============ */
.lines-section{position:relative; overflow:hidden; background:var(--paper)}
.lines-section::before{display:none}
.lines-grid{position:relative; z-index:1; width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line)}
.line-card{
  position:relative; overflow:hidden; padding:48px 38px; background:var(--paper);
  border:0; border-top:3px solid var(--line-accent,var(--line)); border-radius:0; box-shadow:none; transition:.3s ease;
}
.line-card.essential{--line-accent:#b9a294}
.line-card.comfort{--line-accent:#2c3d63}
.line-card.luxury{--line-accent:#cda349}
.line-card::after{display:none}
.line-glow{display:none}
.line-card img{position:relative; top:auto; left:auto; width:auto; height:48px; max-height:48px; object-fit:contain; object-position:left center; margin-bottom:34px; filter:none}
.line-card h3{font-family:var(--font-display); font-weight:400; font-size:1.9rem; margin:0 0 14px; color:var(--ink)}
.line-card p{line-height:1.8; color:var(--muted); min-height:auto; font-weight:300; font-size:.92rem; margin-bottom:30px}
.line-card:hover{transform:none; background:var(--cream)}

/* ============ DEPARTAMENTOS ============ */
.departments-section{background:var(--cream)}
.dept-grid{width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line)}
.dept-card{
  border-radius:0; overflow:hidden; background:var(--paper); border:0; box-shadow:none; transition:.3s ease;
}
.dept-card:hover{transform:none; box-shadow:none}
.dept-card:hover .dept-media::before{transform:scale(1.04)}
.dept-media{position:relative; min-height:260px; background-size:cover!important; background-position:center!important; overflow:hidden; isolation:isolate}
.dept-media::before{content:""; position:absolute; inset:0; background:inherit; transition:transform 1.2s ease}
.dept-tag{
  position:relative; z-index:1; display:inline-block; margin:20px; padding:0; background:none; border:0;
  font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:#fff; font-weight:600;
}
.dept-content{padding:26px 28px 30px}
.dept-content h3{font-family:var(--font-display); font-weight:400; font-size:1.4rem; margin:0 0 10px; color:var(--ink)}
.dept-content p{font-size:.86rem; line-height:1.7; color:var(--muted); font-weight:300; min-height:48px; margin:0 0 18px}
.dept-content .link-button{font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; font-weight:600; color:var(--ink); border-bottom:1px solid var(--ink); border-radius:0; padding-bottom:3px}

/* ============ LOGISTICS ============ */
.logistics-section{background:var(--paper)}
.logistics-card{
  width:min(100%,var(--max)); margin:auto; border-radius:0; overflow:hidden; padding:64px;
  display:grid; grid-template-columns:1.2fr .8fr; gap:50px; align-items:center;
  background:var(--ink); color:#fff;
}
.logistics-card h2{color:#fff}
.logistics-card .section-kicker{color:rgba(255,255,255,.55)}
.logistics-card p{color:rgba(255,255,255,.75); font-size:.96rem; line-height:1.8; font-weight:300; margin-top:18px}
.logistics-metrics{display:grid; gap:22px}
.logistics-metrics div{border-top:1px solid rgba(255,255,255,.2); padding-top:14px; display:flex; justify-content:space-between; align-items:baseline}
.logistics-metrics b{font-family:var(--font-display); font-weight:400; font-size:1.5rem; color:#fff}
.logistics-metrics span{font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.5); font-weight:500}

/* ============ CATALOGO ============ */
.catalog-section{background:var(--cream)}
.catalog-toolbar{
  width:min(100%,var(--max)); margin:0 auto 44px; display:flex; flex-wrap:wrap; gap:18px; align-items:center;
  justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:24px;
}
.filter-group{display:flex; flex-wrap:wrap; gap:0}
.filter{
  background:none; border:0; padding:6px 14px; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  font-weight:600; color:var(--muted); cursor:pointer; border-right:1px solid var(--line); transition:.2s ease;
}
.filter-group .filter:first-child{padding-left:0}
.filter-group .filter:last-child{border-right:0}
.filter:hover{color:var(--ink)}
.filter.active{color:var(--ink); text-decoration:underline; text-decoration-color:var(--accent); text-decoration-thickness:2px}
.segment-filter{border-top:1px solid var(--line); padding-top:14px; margin-top:4px; width:100%}
.search-box{display:flex; flex-direction:column; gap:6px; min-width:220px}
.search-box span{font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:600}
.search-box input{
  border:0; border-bottom:1px solid var(--line); background:transparent; padding:6px 0; font-size:.92rem; color:var(--ink);
}
.search-box input:focus{outline:none; border-color:var(--ink)}
.gallery-grid{width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--line)}
.gallery-card{
  position:relative; min-height:300px; border-radius:0; overflow:hidden; background:#ddd; box-shadow:none; border:0; cursor:pointer; isolation:isolate;
}
.gallery-card img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0; transition:transform .6s ease}
.gallery-card:hover img{transform:scale(1.04)}
.gallery-card::after{content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(10,10,10,.8) 0%,transparent 56%); z-index:1}
.gallery-info{position:absolute; z-index:2; left:18px; right:18px; bottom:16px; color:#fff}
.gallery-info h3{margin:0 0 6px; font-size:.94rem; font-weight:600; letter-spacing:-.01em}
.gallery-info span{display:inline-block; margin-right:10px; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.7)}
.zoom-dot{position:absolute; top:14px; right:14px; z-index:2; width:30px; height:30px; display:grid; place-items:center; border:1px solid rgba(255,255,255,.5); border-radius:50%; color:#fff; font-size:.85rem; opacity:0; transition:.25s ease}
.gallery-card:hover .zoom-dot{opacity:1}
.catalog-actions{width:min(100%,var(--max)); margin:46px auto 0; display:flex; flex-wrap:wrap; gap:16px; justify-content:center}

/* ============ WHY ============ */
.why-section{background:var(--paper)}
.why-grid{width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line)}
.why-card{background:var(--paper); padding:40px 32px; border-radius:0; box-shadow:none; border:0; transition:.3s ease}
.why-card:hover{background:var(--cream)}
.why-card b{display:block; font-family:var(--font-display); font-size:.95rem; color:var(--accent); margin-bottom:18px; letter-spacing:.1em}
.why-card h3{font-family:var(--font-display); font-weight:400; font-size:1.3rem; margin:0 0 12px; color:var(--ink)}
.why-card p{font-size:.88rem; line-height:1.75; color:var(--muted); font-weight:300; margin:0}

/* ============ ALIANZAS ============ */
.alliances-section{background:var(--ink); color:var(--paper)}
.alliances-section .section-title{text-align:center}
.alliances-section .section-kicker{color:rgba(255,255,255,.45)}
.alliances-section h2{color:var(--paper)}
.alliances-intro{max-width:720px; margin:16px auto 0; font-size:.95rem; line-height:1.9; color:rgba(255,255,255,.6); font-weight:300; text-align:center}
.alliance-pillars{width:min(100%,var(--max)); margin:64px auto 0; display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid rgba(255,255,255,.1); border-left:1px solid rgba(255,255,255,.1)}
.alliance-pillar{padding:44px 32px; border-right:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1); transition:background .3s}
.alliance-pillar:hover{background:rgba(255,255,255,.04)}
.pillar-icon{width:52px; height:52px; margin-bottom:24px; color:rgba(255,255,255,.4)}
.pillar-icon svg{width:100%; height:100%}
.alliance-pillar h3{font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; color:var(--paper); margin-bottom:14px; line-height:1.4}
.alliance-pillar p{font-size:.88rem; line-height:1.85; color:rgba(255,255,255,.5); font-weight:300}
.alliance-statement{width:min(100%,var(--max)); margin:72px auto 0; padding:0 40px; text-align:center}
.alliance-statement blockquote{font-size:clamp(1.1rem,2.2vw,1.5rem); font-weight:300; line-height:1.7; color:rgba(255,255,255,.8); font-style:italic; margin:0 0 20px; max-width:820px; margin-left:auto; margin-right:auto}
.alliance-statement cite{font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.3); font-style:normal}

/* ============ MISION/VISION ============ */
.mission-vision{display:grid; grid-template-columns:1fr 1fr; gap:0; width:100%; padding:0}
.mission-vision article{padding:90px max(40px,calc((100% - var(--max))/2 + 40px)); background:var(--ink); border-radius:0; border-right:1px solid rgba(255,255,255,.12)}
.mission-vision article:last-child{background:#2b2b2b; border-right:0}
.mission-vision .section-kicker{color:rgba(255,255,255,.5)}
.mission-vision h2{font-family:var(--font-display); font-weight:400; font-size:clamp(1.4rem,2.1vw,2rem); line-height:1.4; letter-spacing:0; color:#fff; margin-top:18px}

/* ============ CONTACTO ============ */
.contact-section{padding-top:0}
.contact-panel{
  width:min(100%,var(--max)); margin:auto; display:grid; grid-template-columns:.9fr 1.1fr; gap:64px; padding:0;
  border-radius:0;
}
.contact-copy p{color:var(--muted); line-height:1.8; font-weight:300; font-size:.96rem; margin:18px 0 28px}
.contact-list{display:flex; flex-direction:column; gap:10px}
.contact-list a{font-size:.92rem; color:var(--ink); border-bottom:1px solid transparent; transition:.2s ease; align-self:flex-start}
.contact-list a:hover{border-bottom-color:var(--ink)}
.contact-form{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.contact-form label,.modal-card form label{
  display:flex; flex-direction:column; gap:8px; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); font-weight:600;
}
.contact-form input,.contact-form select,.contact-form textarea,
.modal-card input,.modal-card select,.modal-card textarea{
  border:0; border-bottom:1px solid var(--line); background:transparent; padding:8px 0; font-size:1rem; color:var(--ink);
  font-weight:400; text-transform:none; letter-spacing:normal; border-radius:0;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus,
.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus{outline:none; border-color:var(--ink)}
.contact-form label:nth-child(6),.contact-form button{grid-column:1 / -1}
.contact-form button{justify-self:start; margin-top:10px}

/* ============ FOOTER ============ */
.site-footer{
  position:relative; overflow:hidden; padding:80px max(22px,calc((100% - var(--max))/2)) 40px;
  background:var(--ink); color:#fff;
}
.footer-topline{display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,.14)}
.footer-brand-wrap{display:flex; align-items:center}
.footer-logo-panel{background:none; box-shadow:none; padding:0; border-radius:0}
.footer-logo-panel::before{display:none}
.site-footer img.footer-logo{width:160px; filter:brightness(0) invert(1)}
.footer-main-info{display:flex; flex-direction:column; gap:6px}
.footer-main-info strong{font-family:var(--font-display); font-size:1.1rem; font-weight:400; letter-spacing:.02em}
.footer-main-info p{color:rgba(255,255,255,.55); margin:0; font-size:.86rem; font-weight:300}
.footer-cta{border-color:rgba(255,255,255,.35)}
.footer-icon-seal{display:none}
.footer-trust{display:flex; flex-wrap:wrap; gap:36px; padding-top:30px}
.footer-trust span{display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.45)}
.footer-trust svg{width:18px; height:18px; fill:rgba(255,255,255,.45)}
.footer-trust small{font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; line-height:1.5; font-weight:500}

/* ============ MODAL ============ */
.modal{position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:.3s ease}
.modal.active{opacity:1; visibility:visible}
.modal-backdrop{position:absolute; inset:0; background:rgba(10,10,10,.6)}
.modal-card{
  position:relative; width:min(92%,520px); background:var(--paper); border-radius:0; padding:48px;
  box-shadow:none; border:1px solid var(--line);
}
.modal-card h2{font-size:1.7rem; margin:12px 0 24px}
.modal-card form{display:grid; grid-template-columns:1fr 1fr; gap:22px}
.modal-card label:nth-child(4),.modal-card button{grid-column:1 / -1}
.modal-card button{justify-self:start; margin-top:6px}
.modal-close{position:absolute; top:18px; right:18px; width:34px; height:34px; border:0; background:none; font-size:1.6rem; color:var(--muted); cursor:pointer; line-height:1}
.modal-close:hover{color:var(--ink)}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:.3s ease; background:rgba(10,10,10,.94)}
.lightbox.active{opacity:1; visibility:visible}
.lightbox figure{margin:0; max-width:90vw; max-height:90vh; padding:60px 90px; text-align:center}
.lightbox img{max-width:100%; max-height:78vh; margin:0 auto; border-radius:0}
.lightbox figcaption{color:rgba(255,255,255,.7); margin-top:16px; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase}
.lightbox-close{position:absolute; top:24px; right:28px; background:none; border:0; color:#fff; font-size:2rem; cursor:pointer; line-height:1}
.lightbox-arrow{position:absolute; top:50%; transform:translateY(-50%); background:none; border:0; color:#fff; font-size:2.8rem; cursor:pointer; padding:20px; opacity:.6; transition:.2s ease}
.lightbox-arrow:hover{opacity:1}
.lightbox-arrow.prev{left:6px}
.lightbox-arrow.next{right:6px}

/* ============ BACK TO TOP ============ */
.back-top{
  position:fixed; bottom:26px; right:26px; z-index:60; width:46px; height:46px; border-radius:50%;
  background:var(--ink); color:#fff; border:0; font-size:1.1rem; cursor:pointer; opacity:0; visibility:hidden;
  transition:.3s ease; display:grid; place-items:center;
}
.back-top.show{opacity:1; visibility:visible}
.back-top:hover{background:var(--accent)}

/* ============ REVEAL ============ */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s ease}
.reveal.visible{opacity:1; transform:translateY(0)}

/* ============ MEDIA QUERIES ============ */
@media (max-width:1180px){
  .section-grid,.contact-panel{grid-template-columns:1fr; gap:40px}
  .lines-grid{grid-template-columns:repeat(3,1fr)}
  .dept-grid{grid-template-columns:repeat(2,1fr)}
    .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid,.ambientes-tabs{grid-template-columns:repeat(2,1fr)}
  .ambientes-tabs article:nth-child(2){border-right:0}
  .why-card:nth-child(2){border-right:0}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .mission-vision{grid-template-columns:1fr}
  .mission-vision article{border-right:0; border-bottom:1px solid rgba(255,255,255,.12)}
  .mission-vision article:last-child{border-bottom:0}
  .logistics-card{grid-template-columns:1fr; padding:46px}
}
@media (max-width:980px){
  .main-nav{display:none}
  .menu-toggle{display:block; order:3}
  .lang-switch{order:2}
  .header-cta{display:none}
  .site-header.scrolled .main-nav,.main-nav.open{
    display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0;
    background:#fff; padding:10px 24px 24px; border-bottom:1px solid var(--line);
  }
  .main-nav.open a{padding:12px 0; border-bottom:1px solid var(--line-soft)}
  .site-header:not(.scrolled) .main-nav.open a{color:var(--ink)}
  .site-header:not(.scrolled) .main-nav.open a::after{background:var(--accent)}
  .inspire-stage,.inspire-stage-4{grid-template-columns:1fr; grid-auto-rows:360px}
  .lines-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .alliance-pillars{grid-template-columns:1fr 1fr}
  .alliance-pillar{padding:32px 24px}
  .ambientes-tabs,.why-grid{grid-template-columns:1fr}
  .ambientes-tabs article,.why-card{border-right:0; border-bottom:1px solid var(--line)}
  .ambientes-tabs article:last-child,.why-card:last-child{border-bottom:0}
}
@media (max-width:720px){
  .site-header{padding:18px 18px}
  .site-header.scrolled{padding:12px 18px}
  .brand img{width:118px}
  .hero h1{font-size:clamp(1.9rem,9vw,2.8rem); margin-bottom:14px}
  .hero p{font-size:.85rem}
  .hero-content{flex-direction:column; align-items:flex-start; gap:30px; padding:90px 18px 36px}
  .hero-panel{display:none}
  .hero-badges{display:none}
  .hero-visual-nav{display:none}
  .hero-note{font-size:.74rem}
  .hero-stats{grid-template-columns:repeat(2,1fr); gap:18px; padding:12px 18px 18px}
  .hero-stats strong{font-size:1.15rem}
  .section{padding:70px 18px}
  .dept-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .alliance-pillars{grid-template-columns:1fr}
  .alliance-pillar{padding:28px 18px}
  .alliance-statement{padding:0 18px}
  .contact-form label:nth-child(6),.contact-form button,.modal-card label:nth-child(4),.modal-card button{grid-column:auto}
  .catalog-toolbar{flex-direction:column; align-items:flex-start}
  .pill-row span{padding:0 12px}
}
@media (prefers-reduced-motion: reduce){
  .hero-slide,.inspire-card::before{transition:none!important}
}
