@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
img,video{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none}

:root{
  --bg:   #f7f6f2;
  --bg2:  #eeecea;
  --bg3:  #e2dfd9;
  --ink:  #16140f;
  --ink2: #3b3828;
  --ink3: #8a8575;
  --gold: #a07840;
  --gold2:#7a5c2e;
  --line: rgba(22,20,15,.1);
  --P:    'Playfair Display',Georgia,serif;
  --D:    'DM Sans',system-ui,sans-serif;
}

body{background:var(--bg);color:var(--ink);font-family:var(--D);font-size:16px;line-height:1.75;overflow-x:hidden}
::selection{background:var(--ink);color:var(--bg)}
::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-thumb{background:var(--gold)}

/* grain */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.03'/%3E%3C/svg%3E");
  background-size:200px;mix-blend-mode:multiply;opacity:.55}

/* ── PRELOADER ────────────────────────────── */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.pre-compass{position:relative;width:140px;height:140px;margin-bottom:28px}
.pre-c-outer{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.1)}
.pre-c-mid{position:absolute;inset:16px;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
/* cardinal ticks */
.pre-ticks{position:absolute;inset:0;animation:spinTicks 12s linear infinite}
.pre-ticks::before,.pre-ticks::after{
  content:'';position:absolute;left:50%;background:rgba(255,255,255,.2);
  transform:translateX(-50%);
}
.pre-ticks::before{top:0;width:1px;height:10px}
.pre-ticks::after{bottom:0;width:1px;height:10px}
@keyframes spinTicks{to{transform:rotate(360deg)}}
/* needle */
.pre-needle{
  position:absolute;top:50%;left:50%;
  width:2px;height:52px;
  transform-origin:bottom center;
  transform:translate(-50%,-100%);
  animation:needleSpin 3s cubic-bezier(.4,0,.2,1) infinite;
}
.pre-needle-n{
  position:absolute;top:0;left:0;right:0;height:60%;
  background:linear-gradient(to bottom,var(--gold),rgba(160,120,64,.4));
  border-radius:2px 2px 0 0;
}
.pre-needle-s{
  position:absolute;bottom:0;left:0;right:0;height:40%;
  background:rgba(255,255,255,.15);
  border-radius:0 0 2px 2px;
}
.pre-dot{
  position:absolute;top:50%;left:50%;
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);
  transform:translate(-50%,-50%);
  box-shadow:0 0 12px rgba(160,120,64,.6);
}
@keyframes needleSpin{
  0%{transform:translate(-50%,-100%) rotate(-15deg)}
  25%{transform:translate(-50%,-100%) rotate(12deg)}
  50%{transform:translate(-50%,-100%) rotate(-8deg)}
  75%{transform:translate(-50%,-100%) rotate(6deg)}
  100%{transform:translate(-50%,-100%) rotate(-15deg)}
}
/* coords */
.pre-coords{
  font-family:var(--D);font-size:10px;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(255,255,255,.3);
  margin-bottom:20px;
}
.pre-coords span{color:var(--gold);opacity:.8}
.pre-title{
  font-family:var(--P);font-size:clamp(20px,3vw,28px);font-weight:400;
  color:rgba(255,255,255,.85);letter-spacing:.02em;margin-bottom:6px;
}
.pre-sub{
  font-family:var(--D);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:28px;
}
.pre-bar-outer{width:200px;height:1px;background:rgba(255,255,255,.1)}
.pre-bar-fill{height:100%;background:var(--gold);width:0%;transition:width .2s linear}
#preloader.out{animation:preOut .6s forwards}
@keyframes preOut{to{opacity:0;visibility:hidden}}

/* ── NAV ──────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 56px;transition:all .45s;
}
#nav.scrolled{
  background:rgba(247,246,242,.95);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding:13px 56px;
}
.nav-logo{display:flex;flex-direction:column;gap:1px}
.nav-logo-main{font-family:var(--P);font-size:17px;font-weight:700;color:var(--ink);letter-spacing:.01em;line-height:1}
.nav-logo-sub{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{font-size:13px;font-weight:400;color:var(--ink3);transition:color .3s;position:relative;letter-spacing:.01em}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--ink);transition:width .3s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 22px;border:1px solid var(--line);color:var(--ink2);
  transition:all .3s;border-radius:2px;
}
.nav-cta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* ── HERO ─────────────────────────────────── */
#hero{
  position:relative;height:100vh;overflow:hidden;
  display:flex;align-items:flex-end;
  background:var(--ink);
}
.hero-media{position:absolute;inset:0}
.hero-media video,.hero-media iframe,.hero-media .hero-canvas{
  width:100%;height:100%;object-fit:cover;border:none;
}
.hero-media iframe{position:absolute;inset:0;pointer-events:none;
  top:50%;left:50%;width:100vw;height:56.25vw;min-height:100vh;min-width:177.78vh;
  transform:translate(-50%,-50%)}
.hero-media .hero-canvas{position:absolute;inset:0}
/* YouTube top/bottom blockers */
.yt-block-t{position:absolute;top:0;left:0;right:0;height:72px;background:var(--ink);z-index:5;pointer-events:none}
.yt-block-b{position:absolute;bottom:0;left:0;right:0;height:72px;background:var(--ink);z-index:5;pointer-events:none}
.yt-block-full{position:absolute;inset:0;z-index:4}
.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(to bottom,rgba(22,20,15,.15) 0%,rgba(22,20,15,.08) 40%,rgba(22,20,15,.82) 100%);
}
.hero-content{position:relative;z-index:3;padding:0 56px 76px;max-width:860px}
.hero-pre{
  font-family:var(--D);font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(247,246,242,.45);margin-bottom:16px;
  display:flex;align-items:center;gap:12px;
  opacity:0;animation:fadeUp .8s .2s forwards;
}
.hero-pre .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);display:block;flex-shrink:0}
.hero-h1{
  font-family:var(--P);font-size:clamp(52px,9vw,116px);
  font-weight:400;line-height:.93;letter-spacing:-.02em;color:var(--bg);
  opacity:0;animation:fadeUp .9s .35s forwards;
}
.hero-h1 em{font-style:italic;font-weight:400}
.hero-h1 strong{font-weight:700;display:block}
.hero-p{
  font-family:var(--D);font-size:clamp(14px,1.5vw,17px);
  color:rgba(247,246,242,.55);margin-top:20px;max-width:460px;line-height:1.7;font-weight:300;
  opacity:0;animation:fadeUp .8s .6s forwards;
}
.hero-scroll{
  position:absolute;right:56px;bottom:76px;z-index:3;
  font-family:var(--D);font-size:9px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(247,246,242,.25);display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hs-line{width:1px;height:52px;background:rgba(247,246,242,.15);overflow:hidden;position:relative}
.hs-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold);animation:scanV 2s infinite}
@keyframes scanV{to{top:200%}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* ── REVEAL ───────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── SECTIONS ─────────────────────────────── */
section{padding:104px 0;border-bottom:1px solid var(--line)}
.wrap{max-width:1180px;margin:0 auto;padding-inline:56px}
.sec-lbl{
  font-family:var(--D);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.sec-lbl::before{content:'';width:20px;height:1px;background:var(--gold);display:block}
.h2{font-family:var(--P);font-size:clamp(32px,4.5vw,58px);font-weight:400;line-height:1.05;letter-spacing:-.015em;color:var(--ink)}
.h2 em{font-style:italic}
.h2 strong{font-weight:700}
.lead{font-size:17px;color:var(--ink3);line-height:1.85;font-weight:300}

/* ── STATS ───────────────────────────────── */
#stats{background:var(--ink);padding:0;border:none}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{padding:52px 32px;text-align:center;border-right:1px solid rgba(247,246,242,.06)}
.stat-cell:last-child{border-right:none}
.stat-n{font-family:var(--P);font-size:clamp(44px,6vw,72px);font-weight:400;color:var(--bg);line-height:1;margin-bottom:8px}
.stat-l{font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,246,242,.35)}

/* ── QUIÉNES ─────────────────────────────── */
#quienes{background:var(--bg)}
.q-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:56px}
.q-text .lead{margin-top:20px;max-width:480px}
.q-img{position:relative;border-radius:2px;overflow:hidden;aspect-ratio:4/5}
.q-img img,.q-img .q-ph{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.04)}
.q-img .q-ph{background:var(--bg3);display:flex;align-items:center;justify-content:center}
.q-img .q-ph span{font-family:var(--P);font-size:80px;font-weight:700;font-style:italic;color:rgba(22,20,15,.07)}
.q-cap{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(22,20,15,.75),transparent);
  padding:20px 18px 14px;
  font-family:var(--D);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(247,246,242,.7);
}
.tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:24px}
.tag{font-size:11px;font-weight:400;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--line);color:var(--ink3);border-radius:1px;transition:all .3s}
.tag:hover{border-color:var(--gold);color:var(--gold)}

/* ── PIES ────────────────────────────────── */
#pies{background:var(--bg2)}
.pies-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:56px}
.pies-badge{
  background:var(--ink);border-radius:2px;padding:44px;color:var(--bg);
  position:relative;overflow:hidden;
}
.pies-badge::before{
  content:'PIES';font-family:var(--P);font-size:120px;font-weight:700;
  position:absolute;right:-8px;bottom:-24px;opacity:.05;line-height:1;letter-spacing:-.04em;
}
.pies-badge .pb-tag{
  display:inline-block;font-family:var(--D);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);border-bottom:1px solid rgba(160,120,64,.3);
  padding-bottom:3px;margin-bottom:18px;
}
.pies-badge h3{font-family:var(--P);font-size:clamp(22px,2.8vw,34px);font-weight:400;line-height:1.1;margin-bottom:6px}
.pies-badge h3 strong{font-weight:700;display:block}
.pies-badge p{font-size:15px;color:rgba(247,246,242,.55);line-height:1.75;position:relative;z-index:1;margin-top:14px}
.pillars{display:flex;flex-direction:column;gap:14px}
.pillar{padding:20px 22px;border:1px solid var(--line);border-radius:2px;background:var(--bg);transition:all .3s}
.pillar:hover{border-color:var(--gold);box-shadow:0 4px 18px rgba(22,20,15,.06)}
.pillar h4{font-family:var(--P);font-size:16px;font-weight:500;color:var(--ink);margin-bottom:5px}
.pillar p{font-size:13px;color:var(--ink3);line-height:1.6}

/* ── LÍNEAS ──────────────────────────────── */
#lineas{background:var(--bg)}
.lineas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:56px}
.linea{background:var(--bg);padding:40px 28px;position:relative;overflow:hidden;transition:background .3s}
.linea::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.linea:hover{background:var(--bg2)}
.linea:hover::before{transform:scaleX(1)}
.linea-n{font-family:var(--P);font-size:52px;font-weight:700;color:rgba(22,20,15,.05);line-height:1;position:absolute;top:14px;right:18px;letter-spacing:-.03em}
.linea h3{font-family:var(--P);font-size:20px;font-weight:500;color:var(--ink);margin-bottom:10px;line-height:1.2}
.linea p{font-size:14px;color:var(--ink3);line-height:1.7;margin-bottom:14px}
.linea-pills{display:flex;flex-wrap:wrap;gap:5px}
.lpill{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:3px 9px;background:rgba(160,120,64,.08);color:var(--gold2);border-radius:1px}

/* ── PROYECTOS SLIDER ────────────────────── */
#proyectos{background:var(--bg2);overflow:hidden}
.sl-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;flex-wrap:wrap;gap:16px}
.sl-controls{display:flex;align-items:center;gap:10px}
.sl-btn{width:40px;height:40px;border:1px solid var(--line);border-radius:1px;display:flex;align-items:center;justify-content:center;color:var(--ink2);font-size:14px;transition:all .3s}
.sl-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.sl-dots{display:flex;gap:5px}
.sl-dot{width:6px;height:6px;border-radius:50%;background:var(--bg3);transition:all .3s;padding:0;border:none;cursor:pointer}
.sl-dot.on{background:var(--gold);width:20px;border-radius:3px}
.sl-cnt{font-family:var(--D);font-size:12px;color:var(--ink3);margin-left:8px}
.sl-viewport{overflow:hidden}
.sl-track{display:flex;gap:18px;transition:transform .75s cubic-bezier(.77,0,.175,1)}
.proj-card{flex:0 0 calc(33.333% - 12px);background:var(--bg);border:1px solid var(--line);border-radius:1px;overflow:hidden;transition:all .35s}
.proj-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(22,20,15,.09)}
.proj-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg3);position:relative}
.proj-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.4,0,.2,1);filter:grayscale(.1) contrast(1.04)}
.proj-card:hover .proj-thumb img{transform:scale(1.04)}
.proj-thumb .proj-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg3)}
.proj-thumb .proj-ph span{font-family:var(--P);font-size:48px;font-weight:700;font-style:italic;color:rgba(22,20,15,.08)}
.proj-body{padding:22px}
.proj-cat{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.proj-title{font-family:var(--P);font-size:18px;font-weight:500;color:var(--ink);margin-bottom:7px;line-height:1.2}
.proj-text{font-size:13px;color:var(--ink3);line-height:1.6;margin-bottom:14px}
.proj-cta{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);display:inline-flex;align-items:center;gap:6px;transition:gap .3s}
.proj-cta:hover{gap:10px;color:var(--gold)}

/* ── GALERÍA SLIDER ──────────────────────── */
#galeria{background:var(--ink);padding:0;border:none}
.gal-wrap{position:relative;aspect-ratio:21/9;overflow:hidden}
.gal-strip-t,.gal-strip-b{position:absolute;left:0;right:0;height:14px;z-index:5;background:rgba(22,20,15,.9)}
.gal-strip-t{top:0}.gal-strip-b{bottom:0}
.gal-track{display:flex;height:100%;transition:transform .8s cubic-bezier(.77,0,.175,1)}
.gal-slide{flex:0 0 100%;height:100%;position:relative}
.gal-slide img,.gal-slide .gal-ph{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05)}
.gal-slide .gal-ph{display:flex;align-items:center;justify-content:center}
.gal-ph-inner{text-align:center}
.gal-ph-inner .gal-ph-num{font-family:var(--P);font-size:80px;font-weight:700;font-style:italic;color:rgba(247,246,242,.06);line-height:1}
.gal-ph-inner .gal-ph-txt{font-family:var(--D);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:rgba(247,246,242,.2);margin-top:8px}
.gal-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(22,20,15,.7) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px 28px;z-index:3}
.gal-loc{font-family:var(--D);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:rgba(247,246,242,.4);margin-bottom:5px}
.gal-cap{font-family:var(--P);font-style:italic;font-size:15px;color:rgba(247,246,242,.65);max-width:500px}
.gal-nav{position:absolute;bottom:14px;right:16px;z-index:6;display:flex;gap:0}
.gal-btn{width:44px;height:44px;background:rgba(247,246,242,.08);border:none;color:rgba(247,246,242,.5);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}
.gal-btn:hover{background:var(--gold);color:var(--bg)}
.gal-dots{position:absolute;bottom:20px;left:28px;z-index:6;display:flex;gap:5px}
.gal-dot{width:5px;height:5px;border-radius:50%;background:rgba(247,246,242,.2);border:none;cursor:pointer;transition:all .3s;padding:0}
.gal-dot.on{background:var(--bg);width:18px;border-radius:3px}
.gal-counter{position:absolute;top:14px;right:16px;z-index:6;font-family:var(--D);font-size:9px;letter-spacing:.2em;color:rgba(247,246,242,.2)}

/* ── ENFOQUE ─────────────────────────────── */
#enfoque{background:var(--bg2);padding:120px 0}
.enf-wrap{max-width:800px;margin:0 auto;padding-inline:56px}
.enf-lbl{font-family:var(--D);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:56px}
.enf-lbl::before{content:'';width:20px;height:1px;background:var(--gold);display:block}
.enf-item{padding:36px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:48px 1fr;gap:20px;align-items:start}
.enf-item:first-of-type{border-top:1px solid var(--line)}
.enf-n{font-family:var(--D);font-size:10px;letter-spacing:.18em;color:var(--gold);padding-top:6px;font-weight:500}
.enf-q{font-family:var(--P);font-size:clamp(20px,2.8vw,34px);font-weight:400;font-style:italic;color:var(--ink);line-height:1.25;letter-spacing:-.01em}

/* ── REDES ───────────────────────────────── */
#redes-sec{background:var(--bg);padding:60px 0;border-bottom:1px solid var(--line)}
.redes-row{max-width:1180px;margin:0 auto;padding-inline:56px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.redes-lbl{font-family:var(--D);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3)}
.redes-pills{display:flex;gap:8px;flex-wrap:wrap}
.red-pill{font-family:var(--D);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:9px 18px;border:1px solid var(--line);color:var(--ink2);border-radius:1px;transition:all .3s;display:inline-flex;align-items:center;gap:7px}
.red-pill:hover{border-color:var(--ink);color:var(--ink)}

/* ── CONTACTO ────────────────────────────── */
#contacto{background:var(--bg)}
.c-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:56px}
.c-info .lead{margin-top:16px;max-width:380px}
.c-details{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.c-item{display:flex;gap:12px;align-items:flex-start}
.c-ico{width:32px;height:32px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border-radius:1px}
.c-txt strong{display:block;font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:1px}
.c-txt span{font-size:14px;color:var(--ink2)}
.cf{display:flex;flex-direction:column;gap:14px}
.cf-g{display:flex;flex-direction:column;gap:5px}
.cf-g label{font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3)}
.cf-g input,.cf-g textarea,.cf-g select{
  background:var(--bg2);border:1px solid var(--line);color:var(--ink);
  font-family:var(--D);font-size:14px;padding:11px 14px;border-radius:1px;outline:none;
  transition:border-color .3s;width:100%;
}
.cf-g input:focus,.cf-g textarea:focus{border-color:var(--gold)}
.cf-g textarea{resize:none;min-height:90px}
.btn-ink{
  background:var(--ink);color:var(--bg);font-family:var(--D);font-size:12px;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  padding:13px 36px;border:none;border-radius:1px;cursor:pointer;transition:background .3s;
}
.btn-ink:hover{background:var(--gold)}

/* ── FOOTER ──────────────────────────────── */
#footer{background:var(--ink);padding:40px 56px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;border:none}
.ft-logo{display:flex;flex-direction:column;gap:2px}
.ft-logo-main{font-family:var(--P);font-size:17px;font-weight:700;color:var(--bg);letter-spacing:.01em;line-height:1}
.ft-logo-sub{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,246,242,.3)}
.ft-copy{font-family:var(--D);font-size:10px;letter-spacing:.1em;color:rgba(247,246,242,.25)}

/* ── MODAL PROYECTO ─────────────────────── */
#pmodal{position:fixed;inset:0;z-index:3000;display:none;background:rgba(22,20,15,.93);overflow-y:auto;padding:48px 24px}
#pmodal.open{display:block}
.pm-close{position:fixed;top:24px;right:36px;background:var(--bg);border:none;border-radius:1px;padding:8px 18px;font-family:var(--D);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);cursor:pointer;z-index:10;transition:all .3s}
.pm-close:hover{background:var(--gold);color:var(--bg)}
.pm-in{max-width:880px;margin:0 auto}
.pm-vid{width:100%;aspect-ratio:16/9;background:rgba(247,246,242,.04);border-radius:1px;overflow:hidden;margin-bottom:28px;position:relative}
.pm-vid iframe,.pm-vid video{position:absolute;inset:0;width:100%;height:100%;border:none}
.pm-vid-cover{position:absolute;top:0;left:0;right:0;height:64px;background:rgba(22,20,15,.95);z-index:5;pointer-events:none}
.pm-cat{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pm-title{font-family:var(--P);font-size:clamp(28px,5vw,52px);font-weight:400;color:var(--bg);line-height:1;margin-bottom:6px}
.pm-year{font-size:11px;letter-spacing:.16em;color:rgba(247,246,242,.25);margin-bottom:28px}
.pm-text{font-family:var(--P);font-style:italic;font-size:17px;color:rgba(247,246,242,.55);line-height:1.9}

/* ── TOAST ───────────────────────────────── */
.toast{position:fixed;bottom:32px;right:32px;background:var(--ink);color:var(--bg);font-family:var(--D);font-size:12px;font-weight:400;letter-spacing:.08em;padding:12px 20px;border-left:2px solid var(--gold);opacity:0;transform:translateY(8px);transition:all .35s;pointer-events:none;z-index:9999}
.toast.show{opacity:1;transform:none}
.toast.err{border-left-color:#b03030}

/* ── RESPONSIVE ─────────────────────────── */
@media(max-width:1024px){
  .lineas-grid{grid-template-columns:repeat(2,1fr)}
  .pies-grid{grid-template-columns:1fr}
  .q-grid{grid-template-columns:1fr}
  .proj-card{flex:0 0 calc(50% - 9px)}
}
@media(max-width:768px){
  #nav{padding:14px 24px}#nav.scrolled{padding:11px 24px}
  .nav-links{display:none}
  .wrap{padding-inline:24px}
  .hero-content{padding:0 24px 60px}
  section{padding:72px 0}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .lineas-grid{grid-template-columns:1fr}
  .c-grid{grid-template-columns:1fr;gap:48px}
  #footer{padding:28px 24px;flex-direction:column;align-items:flex-start}
  .redes-row{padding-inline:24px;flex-direction:column;align-items:flex-start}
  .enf-wrap{padding-inline:24px}
  .proj-card{flex:0 0 100%}
  .gal-wrap{aspect-ratio:4/3}
}
