/* ============================================================
   NÉSTOR JIMÉNEZ — PRODUCER  ·  Cinematic B/W system
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink-0:#000000;
  --ink-1:#060607;
  --ink-2:#0b0b0d;
  --ink-3:#111114;
  --ink-4:#16161a;
  --ink-5:#1d1d22;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.055);
  --line-3:rgba(255,255,255,.16);
  --paper:#ffffff;
  --paper-soft:#e9e9ea;
  --fog:#9a9a9f;
  --fog-2:#6b6b70;
  --fog-3:#4a4a4e;
  --accent:#ffffff;
  --red:#E10600;        /* rojo cine — acento quirúrgico */
  --red-soft:rgba(225,6,0,.55);

  --font-display:'Anton';
  --font-body:'Archivo', system-ui, sans-serif;
  --font-script:'Sacramento', cursive;

  --section-pad:clamp(56px,7vw,104px);   /* densidad Compacto (default) */
  --gutter:clamp(20px,5vw,72px);
  --maxw:1360px;

  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--ink-0);
  color:var(--paper);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
::selection{background:var(--paper);color:var(--ink-0);}

/* film grain overlay */
.grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:0;
  background-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScxNjAnIGhlaWdodD0nMTYwJz48ZmlsdGVyIGlkPSduJz48ZmVUdXJidWxlbmNlIHR5cGU9J2ZyYWN0YWxOb2lzZScgYmFzZUZyZXF1ZW5jeT0nLjknIG51bU9jdGF2ZXM9JzInIHN0aXRjaFRpbGVzPSdzdGl0Y2gnLz48L2ZpbHRlcj48cmVjdCB3aWR0aD0nMTAwJScgaGVpZ2h0PScxMDAlJyBmaWx0ZXI9J3VybCgjbiknIG9wYWNpdHk9Jy41Jy8+PC9zdmc+");
  mix-blend-mode:overlay;
  transition:opacity .4s ease;
}
[data-grain="1"] .grain{opacity:.06;}

/* scroll progress */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:10000;
  box-shadow:0 0 14px rgba(255,255,255,.4);}

/* ---------- Typography helpers ---------- */
.display{
  font-family:var(--font-display),'Oswald',sans-serif;
  font-weight:400;
  line-height:.86;
  letter-spacing:.005em;
  text-transform:uppercase;
}
.outline{
  -webkit-text-stroke:1.4px var(--paper);
  color:transparent;
}
.eyebrow{
  font-size:11px;font-weight:600;letter-spacing:.42em;text-transform:uppercase;
  color:var(--fog);
}
.kicker{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--fog);
}
.kicker::before{content:"";width:30px;height:1px;background:var(--line-3);}

.container{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
section{position:relative;}

/* ---------- Reveal system ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);
  transition:opacity 1s var(--ease),transform 1.1s var(--ease);
  transition-delay:var(--d,0s);}
[data-reveal="wipe"]{transform:none;clip-path:inset(0 100% 0 0);}
[data-reveal].in{opacity:1;transform:none;clip-path:inset(0 0 0 0);}
[data-motion="off"] [data-reveal]{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important;}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:9000;
  transition:background .5s var(--ease),border-color .5s,backdrop-filter .5s;
  border-bottom:1px solid transparent;}
.nav.solid{background:rgba(4,4,5,.72);backdrop-filter:blur(20px) saturate(140%);
  border-bottom-color:var(--line-2);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:18px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:center;gap:13px;}
.brand .mark{width:36px;height:36px;flex:none;}
.brand-txt{display:flex;flex-direction:column;line-height:1;}
.brand-txt b{font-size:15px;font-weight:700;letter-spacing:.22em;}
.brand-txt span{font-size:9.5px;font-weight:500;letter-spacing:.5em;color:var(--fog);margin-top:5px;}
.nav-menu{display:flex;align-items:center;gap:34px;}
.nav-menu a{font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-soft);
  position:relative;padding:6px 0;}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);
  transition:width .4s var(--ease);}
.nav-menu a:hover{color:#fff;}
.nav-menu a:hover::after{width:100%;}
.nav-cta{display:inline-flex;align-items:center;gap:12px;padding:13px 22px;border:1px solid var(--line-3);
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  transition:background .4s var(--ease),color .4s,border-color .4s;}
.nav-cta:hover{background:var(--paper);color:var(--ink-0);border-color:var(--paper);}
.nav-cta svg{width:13px;height:13px;}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line);background:none;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;}
.burger span{width:18px;height:1.5px;background:#fff;transition:.3s;}
.mobile-menu{position:fixed;inset:0;z-index:8999;background:var(--ink-0);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 var(--gutter);
  visibility:hidden;transform:translateY(-100%);transition:transform .6s var(--ease),visibility .6s;}
.mobile-menu.open{visibility:visible;transform:none;}
.mobile-menu a{font-family:var(--font-display);font-size:9vw;line-height:1;text-transform:uppercase;
  color:var(--paper);padding:8px 0;}
.mobile-menu .mm-foot{font-family:var(--font-body);font-size:12px;letter-spacing:.2em;color:var(--fog);margin-top:30px;}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden;
  padding-top:clamp(108px,15vh,150px);padding-bottom:clamp(36px,5vw,64px);}
.hero-photo{position:absolute;inset:0;z-index:0;}
.hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  filter:grayscale(1) contrast(1.06) brightness(.92);}
.hero-photo::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(100deg,var(--ink-0) 12%,rgba(0,0,0,.55) 46%,rgba(0,0,0,.15) 74%,rgba(0,0,0,.55) 100%),
    linear-gradient(to top,var(--ink-0) 2%,transparent 32%),
    linear-gradient(to bottom,rgba(0,0,0,.6) 0,transparent 24%);}
.hero-grid{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;
  padding-inline:var(--gutter);display:grid;grid-template-columns:1fr auto;align-items:end;gap:40px;}
.hero-main{max-width:920px;}
.hero-eyebrow{margin-bottom:clamp(16px,2vw,26px);}
.hero-title{font-size:clamp(50px,10.6vw,150px);margin:0;}
/* estado en reposo: el título siempre visible si JS/GSAP no corre o tarda.
   GSAP escribe opacity:0 inline al animar; esto solo garantiza el fallback. */
.hero-title .l{display:block;opacity:1;}
.hero-title .l3{font-size:.62em;}
.hero-sub{max-width:430px;margin:clamp(26px,3vw,40px) 0 0;color:var(--paper-soft);
  font-size:clamp(15px,1.15vw,17px);line-height:1.65;font-weight:300;}
.hero-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:clamp(28px,3.4vw,42px);}
.hero-side{align-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:0;
  text-align:right;padding-bottom:6px;}
.hero-note{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--fog);
  line-height:1.7;max-width:170px;}
.scroll-hint{position:absolute;right:var(--gutter);bottom:clamp(36px,5vw,64px);z-index:3;
  display:flex;align-items:center;gap:12px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--fog-2);}
.scroll-hint .bar{width:1px;height:46px;background:linear-gradient(var(--line-3),transparent);position:relative;overflow:hidden;}
.scroll-hint .bar::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--paper);
  animation:scrolldrop 2.4s var(--ease) infinite;}
@keyframes scrolldrop{0%{top:-46px;}60%,100%{top:46px;}}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:14px;cursor:pointer;border:none;
  font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  transition:transform .4s var(--ease);}
.btn-primary{background:var(--paper);color:var(--ink-0);padding:18px 30px;}
.btn-primary .arr{transition:transform .4s var(--ease);}
.btn-primary:hover .arr{transform:translateX(6px);}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--paper);padding:18px 26px;border:1px solid var(--line-3);}
.btn-ghost .play{display:grid;place-items:center;width:24px;height:24px;border:1px solid var(--line-3);border-radius:50%;
  transition:background .4s,border-color .4s;}
.btn-ghost .play svg{width:9px;height:9px;}
.btn-ghost:hover{border-color:var(--paper);}
.btn-ghost:hover .play{background:var(--paper);border-color:var(--paper);}
.btn-ghost:hover .play svg path{fill:var(--ink-0);}

/* ============================================================
   STATS
   ============================================================ */
.stats{border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:clamp(28px,3.5vw,52px) clamp(20px,2.2vw,36px);border-left:1px solid var(--line-2);}
.stat:first-child{border-left:none;}
.stat .num{font-family:var(--font-display),sans-serif;font-size:clamp(48px,6.2vw,96px);line-height:.9;
  letter-spacing:.01em;}
.stat .lbl{margin-top:16px;font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--fog);
  line-height:1.6;}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.sec-pad{padding-block:var(--section-pad);}
/* La banda de stats ya cierra con su borde inferior; la sección que sigue
   no necesita el padding superior completo (evita el vacío negro). */
.stats + .sec-pad{padding-top:clamp(36px,4vw,56px);}
/* Evita el doble espacio entre secciones consecutivas (la de arriba ya
   aporta su padding inferior). */
.about + .testi{padding-top:0;}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;
  margin-bottom:clamp(32px,3.5vw,56px);}
.sec-head .l{max-width:760px;}
.sec-title{font-family:var(--font-display),sans-serif;font-size:clamp(38px,6vw,86px);line-height:.92;
  text-transform:uppercase;margin:18px 0 0;letter-spacing:.005em;}
.sec-sub{margin-top:22px;color:var(--fog);font-size:clamp(14px,1.1vw,16.5px);font-weight:300;line-height:1.7;max-width:520px;}
.sec-link{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--paper-soft);white-space:nowrap;padding-bottom:8px;border-bottom:1px solid var(--line);
  transition:gap .4s var(--ease),color .4s;}
.sec-link:hover{gap:18px;color:#fff;}

/* ============================================================
   SERVICES
   ============================================================ */
.svc-list{border-top:1px solid var(--line-2);}
.svc{display:grid;grid-template-columns:72px 1fr minmax(280px,1.1fr) 56px;align-items:center;gap:28px;
  padding:clamp(13px,1.6vw,22px) 8px;border-bottom:1px solid var(--line-2);position:relative;cursor:default;
  transition:padding .5s var(--ease);}
.svc::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.04),transparent 60%);
  opacity:0;transition:opacity .5s var(--ease);}
.svc:hover{padding-inline:24px 20px;}
.svc:hover::before{opacity:1;}
.svc-no{font-family:var(--font-display),sans-serif;font-size:20px;color:var(--fog-2);transition:color .5s;}
.svc:hover .svc-no{color:var(--paper);}
.svc-ic{position:absolute;left:18px;opacity:0;transition:opacity .5s,transform .5s var(--ease);transform:translateX(-8px);}
.svc-name{display:flex;align-items:center;gap:22px;}
.svc-name h3{font-family:var(--font-display),sans-serif;font-weight:400;font-size:clamp(21px,2.3vw,32px);
  text-transform:uppercase;letter-spacing:.01em;margin:0;line-height:1;transition:transform .5s var(--ease);}
.svc:hover .svc-name h3{transform:translateX(6px);}
.svc-name .ic{width:30px;height:30px;color:var(--fog);transition:color .5s,transform .5s;}
.svc:hover .svc-name .ic{color:var(--paper);transform:scale(1.05);}
.svc-desc{color:var(--fog);font-size:14.5px;font-weight:300;line-height:1.6;}
.svc-go{justify-self:end;color:var(--fog-2);transition:color .5s,transform .5s var(--ease);}
.svc:hover .svc-go{color:var(--paper);transform:translate(4px,-4px);}
.svc-go svg{width:20px;height:20px;}

/* ============================================================
   CLIENTS marquee
   ============================================================ */
.clients{padding-block:clamp(36px,4vw,60px);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  overflow:hidden;}
.clients .head{text-align:center;margin-bottom:clamp(38px,4vw,58px);padding-inline:var(--gutter);}
.clients .head h4{font-family:var(--font-display),sans-serif;font-size:clamp(22px,2.6vw,34px);text-transform:uppercase;margin:14px 0 0;}
.clients .head p{color:var(--fog);font-size:14px;font-weight:300;max-width:560px;margin:16px auto 0;line-height:1.6;}
.marquee{display:flex;width:max-content;animation:marquee 38s linear infinite;}
.marquee:hover{animation-play-state:paused;}
.marquee-track{display:flex;align-items:center;}
.logo-cell{display:flex;align-items:center;justify-content:center;height:74px;padding:0 clamp(32px,4.4vw,66px);
  position:relative;}
.logo-cell::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:30px;background:var(--line-2);}
.logo-cell img{width:auto;height:auto;max-height:48px;max-width:190px;object-fit:contain;
  opacity:.48;transition:opacity .45s ease;user-select:none;-webkit-user-drag:none;}
.marquee:hover .logo-cell img{opacity:.72;}
.logo-cell:hover img{opacity:1;}
.clients .note{text-align:center;margin-top:clamp(34px,4vw,52px);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--fog-3);padding-inline:var(--gutter);}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ============================================================
   PROJECTS (featured + filter)
   ============================================================ */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:clamp(34px,3.6vw,52px);}
.filter{padding:11px 20px;border:1px solid var(--line);background:none;color:var(--fog);cursor:pointer;
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  transition:background .35s var(--ease),color .35s,border-color .35s;}
.filter:hover{color:#fff;border-color:var(--line-3);}
.filter.active{background:var(--paper);color:var(--ink-0);border-color:var(--paper);}
.proj-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.proj{position:relative;overflow:hidden;background:var(--ink-2);border:1px solid var(--line-2);
  transition:opacity .5s var(--ease),transform .5s var(--ease),filter .5s;
  aspect-ratio:4/5;}
.proj.span3{grid-column:span 3;aspect-ratio:16/10;}
.proj.span2{grid-column:span 2;aspect-ratio:4/5;}
.proj.hide{display:none;}
.proj image-slot{position:absolute;inset:0;width:100%;height:100%;}
.proj .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 50% 0,var(--ink-4),var(--ink-1));}
.proj .ph .mono{font-family:var(--font-display),sans-serif;font-size:64px;color:rgba(255,255,255,.05);letter-spacing:.04em;}
.proj-meta{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:22px 24px;
  background:linear-gradient(to top,rgba(0,0,0,.92),rgba(0,0,0,.4) 55%,transparent);
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  transform:translateY(0);transition:transform .5s var(--ease);}
.proj-meta .tag{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--fog);
  display:block;margin-bottom:10px;}
.proj-meta h3{font-family:var(--font-display),sans-serif;font-weight:400;font-size:clamp(20px,1.8vw,28px);
  text-transform:uppercase;margin:0;line-height:.95;letter-spacing:.01em;}
.proj-meta .go{flex:none;width:40px;height:40px;border:1px solid var(--line-3);border-radius:50%;display:grid;place-items:center;
  opacity:0;transform:translateY(8px);transition:.5s var(--ease);}
.proj-meta .go svg{width:14px;height:14px;}
.proj:hover .proj-meta .go{opacity:1;transform:none;}
.proj:hover{filter:none;}
.proj .ph,.proj image-slot{transition:transform .8s var(--ease);}
.proj:hover .ph,.proj:hover image-slot{transform:scale(1.04);}
.proj .corner{position:absolute;top:18px;left:20px;z-index:3;font-size:10px;letter-spacing:.2em;color:var(--fog-2);
  font-weight:600;}

/* ============================================================
   PORTFOLIO masonry
   ============================================================ */
.port-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;}
.port-cell{position:relative;overflow:hidden;border:1px solid var(--line-2);background:var(--ink-2);}
.port-cell image-slot{position:absolute;inset:0;width:100%;height:100%;}
.port-cell .ph{position:absolute;inset:0;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 50% 0,var(--ink-4),var(--ink-1));}
.port-cell .ph svg{width:30px;height:30px;color:rgba(255,255,255,.12);}
.port-cell.tall{grid-row:span 2;}
.port-cell.wide{grid-column:span 2;}

/* ============================================================
   PHOTOGRAPHY GALLERY
   ============================================================ */

/* ============================================================
   ALBUM GRID
   ============================================================ */
.alb-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(6px,0.8vw,12px);
}

.alb-card{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  cursor:pointer;
  background:var(--ink-2);
  border:1px solid var(--line-2);
  will-change:transform;
}

/* Cover image / placeholder */
.alb-cover{position:absolute;inset:0;}
.alb-cover img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;
  transition:transform .7s cubic-bezier(.25,.46,.45,.94),filter .5s ease;
  filter:brightness(.75) saturate(1.05);
}
.alb-card:hover .alb-cover img{transform:scale(1.07);filter:brightness(.55) saturate(1.1);}

/* Placeholder covers (no photo yet) */
.alb-ph{position:absolute;inset:0;transition:transform .7s cubic-bezier(.25,.46,.45,.94);}
.alb-card:hover .alb-ph{transform:scale(1.07);}
.alb-ph--artistas{background:linear-gradient(145deg,#1a0e0e 0%,#2d1212 40%,#0d0808 100%);}
.alb-ph--bodas{background:linear-gradient(145deg,#0e0e16 0%,#161622 40%,#080810 100%);}
.alb-ph--producto{background:linear-gradient(145deg,#0a100e 0%,#0f1a16 40%,#060c0a 100%);}
.alb-ph--gastro{background:linear-gradient(145deg,#0f0e08 0%,#1a1710 40%,#080706 100%);}

/* Subtle noise on placeholders */
.alb-ph::after{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.5;
}

/* Camera icon on placeholders */
.alb-ph::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 8a2 2 0 0 1 2-2h2l1.5-2h7L19 6h0a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8z' stroke='rgba(255,255,255,0.08)' stroke-width='1.5'/%3E%3Ccircle cx='12' cy='12.5' r='3.5' stroke='rgba(255,255,255,0.08)' stroke-width='1.5'/%3E%3C/svg%3E") center/48px no-repeat;
}

/* Gradient veil — always on */
.alb-card::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,10,.92) 0%,rgba(8,8,10,.3) 45%,rgba(8,8,10,0) 70%);
  pointer-events:none;z-index:1;
}

/* Info block */
.alb-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:clamp(14px,2vw,24px);
  z-index:2;
}
.alb-num{
  display:block;font-size:10px;font-weight:700;letter-spacing:.25em;
  color:var(--red);text-transform:uppercase;margin-bottom:4px;
}
.alb-title{
  font-family:var(--font-display),sans-serif;
  font-size:clamp(16px,1.8vw,24px);
  color:#fff;letter-spacing:.04em;line-height:1.05;
  margin:0 0 10px;
  transform:translateY(4px);
  transition:transform .35s ease;
}
.alb-card:hover .alb-title{transform:translateY(0);}

.alb-meta{display:flex;align-items:center;gap:10px;}
.alb-count{font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.4);text-transform:uppercase;}
.alb-dots{display:flex;gap:4px;align-items:center;}
.alb-dots span{
  width:5px;height:5px;border-radius:50%;
  background:rgba(255,255,255,.25);
  transition:background .3s ease;
}
.alb-dots span:first-child{background:rgba(255,255,255,.7);}

/* Arrow — top right, appears on hover */
.alb-arrow{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  color:#fff;z-index:3;
  transform:scale(0) rotate(-45deg);opacity:0;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;
}
.alb-card:hover .alb-arrow{transform:scale(1) rotate(0deg);opacity:1;}

/* ============================================================
   ALBUM LIGHTBOX / SLIDESHOW
   ============================================================ */
.alb-lb{
  position:fixed;inset:0;z-index:9001;
  pointer-events:none;
  visibility:hidden;
  background:rgba(8,8,10,.6);
}
.alb-lb.open{pointer-events:all;visibility:visible;}

.alb-lb-inner{
  position:fixed;
  top:0;left:0;
  width:100%;height:100%;
  background:#08080a;
  overflow:hidden;
  display:flex;flex-direction:column;
  will-change:transform,opacity;
}

/* Header bar */
.alb-lb-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(16px,3vw,36px);
  border-bottom:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.alb-lb-bar-l{display:flex;align-items:center;gap:16px;}
.alb-lb-num{font-size:10px;letter-spacing:.3em;color:var(--red);font-weight:700;text-transform:uppercase;}
.alb-lb-name{font-family:var(--font-display),sans-serif;font-size:clamp(14px,1.4vw,20px);color:var(--paper);letter-spacing:.06em;}
.alb-lb-bar-r{display:flex;align-items:center;gap:20px;}
.alb-lb-idx{font-size:11px;letter-spacing:.15em;color:var(--fog-2);}

.alb-lb-close{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--paper);
  transition:background .2s,transform .3s ease;
}
.alb-lb-close:hover{background:rgba(255,255,255,.16);transform:rotate(90deg);}

/* Stage — main photo */
.alb-lb-stage{
  flex:1;position:relative;
  display:flex;align-items:center;
  overflow:hidden;min-height:0;
  width:100%;
}
.alb-slide-wrap{
  display:flex;align-items:center;
  height:100%;
  gap:10px;
  transition:transform .45s cubic-bezier(.77,0,.18,1);
  will-change:transform;
}
.alb-slide{
  flex:0 0 auto;height:100%;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.alb-slide img{
  height:100%;width:auto;
  max-width:88vw;
  object-fit:contain;
  display:block;
  user-select:none;
  -webkit-user-drag:none;
}
@media(max-width:768px){
  .alb-slide-wrap{gap:0;}
  .alb-slide{flex:0 0 100vw;}
  .alb-slide img{max-width:100vw;}
}
/* Placeholder slide */
.alb-slide-ph{
  flex:0 0 100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:16px;color:rgba(255,255,255,.2);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
}
.alb-slide-ph svg{opacity:.15;}

/* Nav arrows */
.alb-lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:#fff;z-index:4;
  transition:background .2s,transform .25s;
}
.alb-lb-prev{left:clamp(8px,2vw,24px);}
.alb-lb-next{right:clamp(8px,2vw,24px);}
.alb-lb-prev:hover{background:rgba(255,255,255,.16);transform:translateY(-50%) translateX(-2px);}
.alb-lb-next:hover{background:rgba(255,255,255,.16);transform:translateY(-50%) translateX(2px);}

/* Thumbnails strip */
.alb-thumbs-wrap{
  flex-shrink:0;
  padding:12px clamp(16px,3vw,36px);
  border-top:1px solid rgba(255,255,255,.07);
  overflow-x:auto;
  scrollbar-width:none;
}
.alb-thumbs-wrap::-webkit-scrollbar{display:none;}
.alb-thumbs{display:flex;gap:8px;align-items:center;}
.alb-thumb{
  flex:0 0 54px;height:54px;
  border:2px solid transparent;
  overflow:hidden;cursor:pointer;
  transition:border-color .25s,opacity .25s,transform .25s;
  opacity:.45;
}
.alb-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.alb-thumb-ph{
  width:100%;height:100%;
  background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.25);
}
.alb-thumb.active{border-color:var(--red);opacity:1;transform:scale(1.05);}
.alb-thumb:hover:not(.active){opacity:.75;}

/* ============================================================
   ABOUT
   ============================================================ */
.about{position:relative;overflow:hidden;}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,92px);align-items:center;}
.about-photo{position:relative;perspective:900px;cursor:none;}
.about-photo .frame{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;transform-style:preserve-3d;will-change:transform;transition:box-shadow .3s ease;}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  filter:grayscale(1) contrast(1.05) brightness(.96);}
.about-photo .tape{position:absolute;left:-1px;bottom:26px;background:var(--paper);color:var(--ink-0);
  padding:14px 22px;font-family:var(--font-display),sans-serif;font-size:18px;letter-spacing:.06em;text-transform:uppercase;}
.about-photo .yr{position:absolute;top:18px;right:18px;font-size:10px;letter-spacing:.26em;color:var(--fog);
  writing-mode:vertical-rl;}
.about-body h2{font-family:var(--font-display),sans-serif;font-weight:400;font-size:clamp(34px,4.4vw,64px);
  text-transform:uppercase;line-height:.95;margin:20px 0 0;letter-spacing:.005em;}
.about-body .bio{color:var(--paper-soft);font-size:clamp(15px,1.1vw,17px);font-weight:300;line-height:1.75;margin-top:28px;}
.about-body .bio strong{font-weight:600;color:#fff;}
.values{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2);margin-top:40px;}
.value{background:var(--ink-1);padding:24px 22px;display:flex;align-items:center;gap:16px;}
.value .vn{font-family:var(--font-display),sans-serif;font-size:15px;color:var(--fog-2);}
.value .vt{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;}
.signature{margin-top:38px;display:flex;align-items:center;gap:24px;}
.signature .sig{font-family:var(--font-script);font-size:52px;line-height:1;color:var(--paper);}
.signature .role{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fog);border-left:1px solid var(--line);padding-left:24px;}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{position:relative;overflow:hidden;background:transparent;}
/* Layout 2 columnas: foto izq, contenido der */
.testi-inner{display:grid;grid-template-columns:1fr 1.35fr;gap:clamp(40px,5vw,80px);align-items:center;}
/* Foto contenida — se ve el cuerpo completo */
.testi-photo{position:relative;align-self:stretch;display:flex;align-items:flex-end;min-width:0;overflow:hidden;}
.testi-photo img{width:100%;height:100%;max-height:680px;object-fit:cover;object-position:50% 8%;
  filter:grayscale(1) brightness(.8) contrast(1.1);display:block;}
.testi-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to right,transparent 55%,var(--ink-0)),
             linear-gradient(to top,var(--ink-0) 0%,transparent 22%);}
.testi-content{position:relative;z-index:2;padding-block:clamp(28px,3vw,52px);min-width:0;}
.testi-content .sec-head{margin-bottom:0;}
.testi-content .l{max-width:560px;}
.testi .sec-title{font-size:clamp(26px,3.2vw,48px);}
.testi .sec-sub{font-size:clamp(13px,1vw,15px);max-width:420px;}
.testi-slider{position:relative;margin-top:clamp(30px,3vw,50px);}
.testi-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;--scroll-duration:1200ms;
  -ms-overflow-style:none;scrollbar-width:none;padding-bottom:2px;}
.testi-track::-webkit-scrollbar{display:none;}
.testi-track .quote{flex:0 0 100%;scroll-snap-align:start;min-height:220px;}
.testi-nav{display:flex;align-items:center;gap:10px;margin-top:24px;}
.t-arrow{width:54px;height:54px;flex:none;border:1px solid var(--line-3);background:rgba(8,8,10,.5);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--paper);cursor:pointer;
  display:grid;place-items:center;transition:background .4s var(--ease),color .4s,border-color .4s;}
.t-arrow:hover{background:var(--paper);color:var(--ink-0);border-color:var(--paper);}
.t-arrow svg{width:20px;height:20px;}
.testi-dots{display:flex;gap:9px;align-items:center;margin-left:auto;}
.t-dot{width:8px;height:8px;border-radius:50%;background:var(--line-3);border:none;padding:0;cursor:pointer;
  transition:background .3s,transform .3s;}
.t-dot.active{background:var(--paper);transform:scale(1.35);}
.quote{border:1px solid var(--line-2);background:rgba(8,8,10,.6);backdrop-filter:blur(6px);padding:clamp(28px,3vw,42px);
  display:flex;flex-direction:column;justify-content:space-between;gap:30px;transition:border-color .5s,transform .5s var(--ease);}
.quote:hover{border-color:var(--line-3);transform:translateY(-4px);}
.quote .mk{font-family:var(--font-display),sans-serif;font-size:54px;line-height:.5;color:var(--fog-3);}
.quote p{font-size:clamp(16px,1.5vw,21px);font-weight:300;line-height:1.55;color:var(--paper);margin:0;}
.quote .by{display:flex;align-items:center;gap:14px;}
.quote .av{width:42px;height:42px;border-radius:50%;background:var(--ink-4);border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--font-display),sans-serif;font-size:16px;color:var(--fog);}
.quote .by b{display:block;font-size:13px;font-weight:600;letter-spacing:.04em;}
.quote .by span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fog);}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,90px);align-items:start;}
.contact-left h2{font-family:var(--font-display),sans-serif;font-weight:400;font-size:clamp(40px,6vw,92px);
  text-transform:uppercase;line-height:.9;margin:20px 0 0;}
.contact-left p{color:var(--fog);font-size:clamp(15px,1.1vw,17px);font-weight:300;line-height:1.7;margin-top:26px;max-width:420px;}
.wa{display:inline-flex;align-items:center;gap:16px;margin-top:40px;padding:18px 24px;border:1px solid var(--line-3);
  transition:background .4s var(--ease),color .4s;cursor:pointer;}
.wa:hover{background:var(--paper);color:var(--ink-0);}
.wa svg{width:22px;height:22px;}
.wa .t b{display:block;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;}
.wa .t span{font-size:11px;color:var(--fog);letter-spacing:.08em;}
.wa:hover .t span{color:rgba(0,0,0,.6);}
.contact-info{margin-top:46px;display:flex;flex-direction:column;gap:2px;}
.contact-info a,.contact-info div{display:flex;justify-content:space-between;gap:20px;padding:18px 0;border-top:1px solid var(--line-2);
  font-size:13px;letter-spacing:.04em;}
.contact-info .k{color:var(--fog);font-size:11px;letter-spacing:.2em;text-transform:uppercase;}
.contact-info a:hover .v{color:#fff;}
.contact-info .v{color:var(--paper-soft);transition:color .3s;}

/* ── Form — 21st.dev style ── */
.form{
  display:flex;flex-direction:column;gap:0;
  background:#eeeeee;
  border:none;
  border-radius:3px;
  box-shadow:0 2px 4px rgba(0,0,0,.06),0 12px 40px rgba(0,0,0,.14),0 40px 80px rgba(0,0,0,.10);
  overflow:hidden;
  position:relative;
}
.field{position:relative;border-bottom:1px solid #ebebeb;}
.field:last-of-type{border-bottom:none;}
/* Focus underline animation */
.field::after{
  content:"";position:absolute;bottom:0;left:0;width:0;height:2px;
  background:var(--red);transition:width .35s cubic-bezier(.4,0,.2,1);
  z-index:2;
}
.field.focused::after{width:100%;}
.field label{
  position:absolute;left:24px;top:22px;
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#111;pointer-events:none;transition:.3s var(--ease);
}
.field input,.field select,.field textarea{
  width:100%;background:none;border:none;outline:none;
  color:#111;font-family:var(--font-body);font-size:15px;
  padding:42px 24px 18px;resize:none;
}
.field select{
  appearance:none;cursor:pointer;color:#111;
  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 fill='%23999' d='M0 0h12L6 8z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 24px center;
}
.field select option{background:#fff;color:#111;}
.field textarea{min-height:130px;}
.field.focused label,.field.filled label{top:14px;font-size:9.5px;color:#333;}
.field.error{border-color:rgba(255,80,80,.4);}
.field.error label{color:#ff4444;}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px 24px;border-top:1px solid #ebebeb;}
.form-foot .hint{font-size:11px;color:#bbb;letter-spacing:.06em;}
.submit{
  display:inline-flex;align-items:center;gap:14px;
  background:#111;color:#fff;border:none;cursor:pointer;
  padding:16px 28px;font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  transition:background .3s,transform .4s var(--ease);
}
.submit:hover{background:var(--red);transform:translateX(4px);}
.submit .arr{transition:transform .4s;}
.submit:hover .arr{transform:translateX(5px);}
.form-ok{padding:30px 24px;color:#111;font-size:14px;letter-spacing:.04em;display:none;align-items:center;gap:12px;}
.form-ok svg path{stroke:var(--red);}
.form-ok.show{display:flex;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line-2);padding-block:clamp(48px,5vw,72px) 32px;}
.footer-top{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  padding-bottom:clamp(40px,4vw,60px);border-bottom:1px solid var(--line-2);}
.footer-cta{font-family:var(--font-display),sans-serif;font-size:clamp(30px,4.6vw,68px);text-transform:uppercase;line-height:.95;}
.footer-cta a{transition:opacity .3s;}
.footer-mark{width:62px;height:62px;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:30px;}
.footer-meta{display:flex;gap:clamp(20px,3vw,48px);flex-wrap:wrap;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fog);}
.footer-meta a:hover{color:#fff;}
.socials{display:flex;gap:8px;}
.socials a{width:42px;height:42px;border:1px solid var(--line);display:grid;place-items:center;
  transition:background .4s var(--ease),color .4s,border-color .4s;color:var(--fog);}
.socials a:hover{background:var(--paper);color:var(--ink-0);border-color:var(--paper);}
.socials svg{width:17px;height:17px;}
.copyright{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fog-3);margin-top:30px;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-menu{display:none;}
  .burger{display:flex;}
  .nav-cta{display:none;}
  .hero-side{display:none;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stat:nth-child(3),.stat:nth-child(4){border-top:1px solid var(--line-2);}
  .stat:nth-child(odd){border-left:none;}
  .svc{grid-template-columns:54px 1fr;gap:16px;}
  .svc-desc,.svc-go{display:none;}
  .proj-grid{grid-template-columns:repeat(2,1fr);}
  .proj.span6{grid-column:span 2;}
  .proj.span3{grid-column:span 2;aspect-ratio:16/11;}
  .proj.span2{grid-column:span 1;}
  .port-grid{grid-template-columns:repeat(2,1fr);}
  /* album grid tablet */
  .alb-grid{grid-template-columns:repeat(2,1fr);}
  .about-grid,.contact-grid{grid-template-columns:1fr;}
  .testi-inner{grid-template-columns:1fr;}
  .testi-photo{max-height:420px;overflow:hidden;}
  .testi-photo img{object-position:50% 0%;}
  .about-photo{max-width:440px;}
}
@keyframes ripple{to{transform:scale(2.5);opacity:0;}}

@media (max-width:560px){
  .hero-grid{padding: 12px 20px 0 20px !important; margin: 0 !important;}
  .hero-photo img{object-position:57% 30%;transform:scale(0.78);transform-origin:center top;}
  .hero-title{font-size:clamp(32px,10vw,58px);}
  .hero-title .l3{font-size:.56em;}
  .hero-actions{flex-direction:column;align-items:stretch;gap:12px;}
  .hero-actions .btn{width:100%;justify-content:center;text-align:center;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stat{border-top:1px solid var(--line-2);}
  .stat:nth-child(1),.stat:nth-child(2){border-top:none;}
  .stat:nth-child(odd){border-left:none;}
  .stat:nth-child(even){border-left:1px solid var(--line-2);}
  .proj-grid{grid-template-columns:1fr;}
  .proj.span6,.proj.span3,.proj.span2{grid-column:span 1;}
  .port-grid{grid-template-columns:1fr;}
  /* album grid mobile */
  .alb-grid{grid-template-columns:repeat(2,1fr);}
  .alb-title{font-size:clamp(13px,4vw,18px);}
  /* lightbox mobile */
  .alb-lb-nav{width:40px;height:40px;}
  .alb-thumb{flex:0 0 44px;height:44px;}
  .values{grid-template-columns:1fr;}
  .form-foot{flex-direction:column;align-items:stretch;}
  .submit{justify-content:center;}
}

/* ====== VIDEO MUSICAL CARD ====== */
.proj-video-card { cursor: pointer; overflow: hidden; }

.proj-yt-wrap {
  position: absolute;
  inset: 0;
  background: #000;
  overflow: hidden;
}

.proj-yt-thumb {
  position: absolute; inset: 0;
  transition: opacity .4s ease;
}
.proj-yt-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  transition: transform .6s ease;
  filter: brightness(.75);
}
.proj-video-card:hover .proj-yt-thumb img {
  transform: scale(1.08);
  filter: brightness(.6);
}

/* Overlay */
.proj-yt-overlay {
  position: absolute; inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

/* Botón play */
.proj-yt-play-btn {
  width: 80px; height: 80px;
  display: flex; align-items: center; justify-content: center;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.proj-video-card:hover .proj-yt-play-btn {
  transform: scale(1.12);
}
.proj-yt-play-btn svg { width: 80px; height: 80px; }

/* Anillo animado */
.play-ring {
  stroke-dasharray: 245;
  stroke-dashoffset: 245;
  transition: stroke-dashoffset .6s ease;
}
.proj-video-card:hover .play-ring {
  stroke-dashoffset: 0;
}

/* Info bajo el play */
.proj-yt-info {
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 40px;
  padding: 6px 14px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease;
}
.proj-video-card:hover .proj-yt-info {
  opacity: 1; transform: translateY(0);
}

.proj-yt-badge {
  display: flex; align-items: center; gap: 5px;
  font-family: var(--ff-body); font-size: 11px;
  font-weight: 600; letter-spacing: .08em;
  color: #fff; text-transform: uppercase;
}

.proj-yt-duration {
  font-family: var(--ff-body); font-size: 11px;
  color: rgba(255,255,255,.6); letter-spacing: .05em;
}

/* iFrame player */
.proj-yt-player {
  position: absolute; inset: 0;
}
.proj-yt-player iframe {
  width: 100%; height: 100%; border: none;
}

/* Badge tag musica */
.tag-music {
  background: var(--red) !important;
  color: #fff !important;
}

.tag-live {
  background: var(--red) !important;
  color: #fff !important;
  border: none !important;
}

/* ====== CONCIERTO CARD — span completo (solo desktop) ====== */
@media (min-width:1081px) { .proj.span6 { grid-column: span 6; } }

.proj-yt-wide { aspect-ratio: 21/9; }

.proj-concert { position: relative; }

.proj-concert-badge {
  position: absolute;
  top: 20px; left: 20px;
  display: flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 40px;
  padding: 6px 14px 6px 10px;
  font-family: var(--ff-body);
  font-size: 11px; font-weight: 700;
  letter-spacing: .12em;
  color: #fff; text-transform: uppercase;
  z-index: 2;
}

.concert-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 0 0 rgba(225,6,0,.6);
  animation: pulse-dot 1.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%   { box-shadow: 0 0 0 0 rgba(255,59,59,.6); }
  70%  { box-shadow: 0 0 0 8px rgba(255,59,59,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,59,59,0); }
}

.proj-yt-play-lg { width: 100px; height: 100px; }
.proj-yt-play-lg svg { width: 100px; height: 100px; }

.tag-concert {
  background: var(--red) !important;
  color: #fff !important;
  border: none !important;
}

/* Tarjeta concierto — aspect-ratio base (grid-column se define por breakpoint) */
.proj.span6 {
  aspect-ratio: 21/9;
}
.proj-concert {
  display: block;
  overflow: hidden;
}
.proj-concert .proj-yt-wrap {
  position: absolute;
  inset: 0;
  aspect-ratio: unset;
}
.proj-concert .proj-meta {
  position: absolute;
}
.proj-concert .corner {
  top: 14px;
}

/* Responsive overrides for span6 — must come after span6 declarations */
@media (max-width:1080px) {
  .proj.span6 { grid-column: span 2; aspect-ratio: 16/10; }
  .proj-concert { display: block; }
  .proj-concert .proj-yt-wrap { position: absolute; inset: 0; aspect-ratio: unset; }
  .proj-concert .proj-meta { position: absolute; }
}
@media (max-width:560px) {
  .proj.span6 { grid-column: span 1; }
}
