/* ─── Inner-page styles (servicios, platos, estudio, contacto, legal) ── */
body{margin:0;background:#0a0a0a}
.pj-odoo{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border:1px solid rgba(255,255,255,.18);border-radius:999px;color:rgba(255,255,255,.7)}
.pj-odoo[data-status="loading"]{color:#e6a35a;border-color:rgba(230,163,90,.4)}
.pj-odoo[data-status="ok"]{color:#7ec97e;border-color:rgba(126,201,126,.4)}
.pj-odoo[data-status="error"]{color:#e87474;border-color:rgba(232,116,116,.4)}
.lang-toggle{position:fixed;top:18px;right:18px;z-index:90;display:inline-flex;border:1px solid rgba(255,255,255,.25);border-radius:999px;overflow:hidden;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:"JetBrains Mono",monospace;mix-blend-mode:difference}
.lang-toggle button{padding:7px 12px;font-size:10px;letter-spacing:.14em;color:rgba(255,255,255,.7);text-transform:uppercase;cursor:pointer;background:transparent;border:0}
.lang-toggle button.on{background:#fff;color:#0a0a0a;mix-blend-mode:normal}

/* Inner nav (no longer position:absolute) */
.ci-nav-inner{position:sticky;top:0;left:0;right:0;background:rgba(10,10,10,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);mix-blend-mode:normal;z-index:50}
.ci-nav-inner .ci-wm{color:var(--ink)}
.ci-nav-inner .ci-menu{color:var(--dim)}
.ci-nav-inner .ci-menu a{color:var(--dim)}
.ci-nav-inner .ci-menu a:hover,.ci-nav-inner .ci-menu a.is-current{color:var(--accent)}
.ci-nav-inner .ci-cta{color:var(--ink);border-color:var(--line-strong)}

.ci-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}
.ci-page-foot{margin-top:auto;padding:0 28px;background:var(--bg-2);border-top:1px solid var(--line)}
.ci-page-foot .ci-bigmark a{color:inherit}

/* Generic inner page hero — small, no slideshow */
.in-hero{padding:80px 28px 64px;border-bottom:1px solid var(--line);position:relative}
.in-hero-k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:32px;display:flex;gap:10px;align-items:center}
.in-hero-k .ci-pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
.in-h1{font-family:var(--serif);font-weight:400;font-size:clamp(72px,11vw,180px);line-height:.9;letter-spacing:-.035em;max-width:1500px}
.in-h1 em{font-style:italic;color:var(--accent)}
.in-h1 span{display:block}
.in-lede{font-family:var(--serif);font-style:italic;font-size:clamp(20px,1.8vw,28px);line-height:1.4;color:var(--dim);max-width:680px;margin-top:32px}
.in-crumbs{position:absolute;top:24px;right:28px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.in-crumbs em{color:var(--accent);font-style:normal;margin-left:8px}

/* SERVICIOS — long-form per-craft block */
.in-svc-block{padding:80px 28px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:80px 1fr 1.4fr;gap:48px;align-items:start}
.in-svc-block:nth-child(odd){background:var(--bg-2)}
.in-svc-num{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.12em;padding-top:14px}
.in-svc-l h2{font-family:var(--serif);font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.92;letter-spacing:-.025em;margin-bottom:20px}
.in-svc-l h2 em{font-style:italic;color:var(--accent)}
.in-svc-l .in-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:24px}
.in-svc-l .in-tags span{padding:5px 11px;border:1px solid var(--line-strong);border-radius:999px;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink)}
.in-svc-r p{font-family:var(--serif);font-style:italic;font-size:24px;line-height:1.4;color:var(--ink);margin-bottom:36px;text-wrap:pretty}
.in-svc-r h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin:24px 0 12px}
.in-svc-r ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;font-size:14px;line-height:1.6}
.in-svc-r ul li{padding:6px 0;border-bottom:1px dashed var(--line);color:var(--ink);position:relative;padding-left:18px}
.in-svc-r ul li::before{content:"●";position:absolute;left:0;color:var(--accent);font-size:9px;top:11px}
.in-svc-r .in-stack{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.in-svc-r .in-stack span{font-family:var(--mono);font-size:11.5px;color:var(--ink);letter-spacing:.04em;padding:6px 0;border-bottom:1px solid var(--accent)}
.in-svc-r .in-deliverables{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:14px;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.in-svc-r .in-deliverables div{padding:14px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink);text-transform:uppercase}
.in-svc-r .in-deliverables div b{display:block;color:var(--accent);font-size:10px;letter-spacing:.14em;margin-bottom:6px;font-weight:500}

/* PLATÓS — Fuenlabrada · 8 boxes */
.plt-hero{padding-bottom:48px}
.plt-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-top:24px}
.plt-hero-meta{display:flex;flex-direction:column;gap:24px;padding-bottom:8px}
.plt-stats{display:flex;gap:36px;padding-top:8px;border-top:1px solid var(--line)}
.plt-stat{padding-top:18px}
.plt-stat-n{font-family:var(--serif);font-weight:400;font-size:38px;letter-spacing:-.025em;line-height:1}
.plt-stat-l{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--dim);margin-top:8px}

.plt-shead{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--dim);background:var(--bg-2)}
.plt-shead h2{font-family:var(--serif);font-weight:400;font-size:14px;color:var(--ink);letter-spacing:0;text-transform:none;font-style:italic}

.plt-box{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line);min-height:520px}
.plt-box.rev{direction:rtl}
.plt-box.rev > *{direction:ltr}
.plt-box.no-img{grid-template-columns:1fr}
.plt-box-img{position:relative;overflow:hidden;background:#1a1815;min-height:380px}
.plt-box-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) brightness(.85) saturate(.9);transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
.plt-box:hover .plt-box-img img{transform:scale(1.04)}
.plt-img-ph{width:100%;height:100%;min-height:380px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--dim)}
.plt-badge{position:absolute;top:20px;left:20px;background:var(--accent);color:#0a0a09;font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.18em;font-weight:600;padding:5px 11px}
.plt-badge-up{background:transparent;color:var(--dim);border:1px solid var(--dim)}

.plt-box-info{padding:60px 28px;display:flex;flex-direction:column}
.plt-box-idx{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:14px}
.plt-box-name{font-family:var(--serif);font-weight:400;font-size:clamp(40px,4.5vw,68px);line-height:.92;letter-spacing:-.025em;margin-bottom:24px}
.plt-box-desc{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink);line-height:1.5;max-width:48ch;margin-bottom:32px}

.plt-dims{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);margin-bottom:32px}
.plt-dims-2{grid-template-columns:1fr 1fr}
.plt-dim{padding:16px 18px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.plt-dim:last-child{border-right:0}
.plt-dim-v{font-family:var(--serif);font-size:24px;letter-spacing:-.02em;line-height:1}
.plt-dim-l{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--dim)}

.plt-feats{margin-bottom:32px}
.plt-feats h4{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--dim);margin-bottom:12px}
.plt-feats ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.plt-feats li{font-family:var(--sans);font-size:13px;color:var(--ink);padding:6px 0 6px 16px;border-bottom:1px dashed var(--line);position:relative;line-height:1.5}
.plt-feats li::before{content:"—";position:absolute;left:0;color:var(--accent);font-size:11px;top:7px}

.plt-loc{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--dim);margin-top:auto;padding-top:24px;border-top:1px solid var(--line)}
.plt-loc a{color:var(--accent)}
.plt-loc a:hover{color:var(--ink)}
.plt-loc-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:pulse 2.4s infinite}

.plt-extras{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--line)}
.plt-extra{padding:48px 28px;border-right:1px solid var(--line);display:flex;flex-direction:column}
.plt-extra:last-child{border-right:0}
.plt-extra-area{font-family:var(--serif);font-weight:400;font-size:clamp(32px,3.4vw,52px);letter-spacing:-.025em;line-height:.9;margin-bottom:20px}
.plt-extra-desc{font-family:var(--sans);font-size:13px;color:var(--dim);line-height:1.65;margin-bottom:16px}
.plt-extra .plt-dims{margin-bottom:18px}

.plt-upcoming{opacity:.85;min-height:380px}
.plt-upcoming .plt-box-info{padding-top:60px;padding-bottom:60px}

/* ESTUDIO — sedes + equipo + manifiesto */
.in-st-mani{padding:90px 28px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.in-st-mani q{quotes:none;display:block;font-family:var(--serif);font-size:clamp(44px,5.6vw,98px);line-height:1.04;letter-spacing:-.025em;max-width:1500px}
.in-st-mani q em{font-style:italic;color:var(--accent)}
.in-st-mani .in-sig{margin-top:48px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--dim);text-transform:uppercase}

.in-st-stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.in-st-stat{padding:48px 28px;border-right:1px solid var(--line)}
.in-st-stat:last-child{border-right:0}
.in-st-stat-n{font-family:var(--serif);font-size:clamp(64px,7vw,108px);line-height:.9;letter-spacing:-.03em}
.in-st-stat-n em{font-style:italic;color:var(--accent)}
.in-st-stat-l{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--dim);margin-top:14px}

.in-st-sedes{padding:80px 28px 0;border-bottom:1px solid var(--line)}
.in-st-sedes-head{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:end;margin-bottom:48px}
.in-st-sedes-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(56px,8vw,140px);line-height:.88;letter-spacing:-.03em}
.in-st-sedes-head h2 em{font-style:italic;color:var(--accent)}
.in-st-sedes-head p{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--dim);max-width:540px;justify-self:end}
.in-st-sedes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-strong);padding-bottom:32px}
.in-sede{padding:32px 24px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:14px}
.in-sede:last-child{border-right:0}
.in-sede-n{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.16em}
.in-sede h3{font-family:var(--serif);font-size:42px;font-weight:400;letter-spacing:-.01em;line-height:1}
.in-sede p{font-family:var(--mono);font-size:11.5px;line-height:1.7;color:var(--dim);letter-spacing:.04em}
.in-sede .in-sede-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:16px;border-top:1px dashed var(--line)}
.in-sede .in-sede-tags span{padding:4px 9px;border:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink);text-transform:uppercase}

/* CONTACTO — full form */
.in-ct{padding:80px 28px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start}
.in-ct-l h2{font-family:var(--serif);font-weight:400;font-size:clamp(56px,7.5vw,128px);line-height:.92;letter-spacing:-.03em;margin-bottom:24px}
.in-ct-l h2 em{font-style:italic;color:var(--accent)}
.in-ct-l p{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.45;color:var(--dim);margin-bottom:48px;max-width:540px}
.in-ct-info{display:grid;grid-template-columns:1fr 1fr;gap:32px;border-top:1px solid var(--line);padding-top:32px}
.in-ct-info h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}
.in-ct-info a{font-family:var(--serif);font-size:22px;color:var(--ink);font-style:italic;display:block;margin-bottom:6px}
.in-ct-info a:hover{color:var(--accent)}
.in-ct-info p{font-family:var(--mono);font-size:12px;color:var(--ink);line-height:1.6;letter-spacing:.04em;font-style:normal;margin:0}

.in-ct-form{background:var(--bg-2);padding:40px;border:1px solid var(--line)}
.in-ct-form h3{font-family:var(--serif);font-size:36px;font-weight:400;letter-spacing:-.015em;margin-bottom:8px}
.in-ct-form > p{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--dim);margin-bottom:32px;text-transform:uppercase;letter-spacing:.12em}
.in-ct-field{margin-bottom:18px;display:flex;flex-direction:column;gap:6px}
.in-ct-field label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.in-ct-field input,.in-ct-field select,.in-ct-field textarea{background:transparent;border:0;border-bottom:1px solid var(--line-strong);color:var(--ink);font-family:var(--sans);font-size:15px;padding:8px 0;outline:none;transition:border-color .2s}
.in-ct-field input:focus,.in-ct-field select:focus,.in-ct-field textarea:focus{border-bottom-color:var(--accent)}
.in-ct-field textarea{min-height:90px;resize:vertical;font-family:inherit}
.in-ct-field select{appearance:none;-webkit-appearance:none;color:var(--ink);background:transparent;cursor:pointer}
.in-ct-field select option{background:var(--bg);color:var(--ink)}
.in-ct-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.in-ct-submit{margin-top:24px;width:100%;background:var(--accent);color:#0a0a0a;padding:16px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;border:0;cursor:pointer;transition:opacity .2s}
.in-ct-submit:hover{opacity:.9}
.in-ct-note{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:.06em;margin-top:14px;text-align:center}

.in-ct-success{padding:48px;text-align:center;border:1px solid var(--accent);background:rgba(230,163,90,.05)}
.in-ct-success-i{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#0a0a0a;display:grid;place-items:center;margin:0 auto 18px;font-size:22px}
.in-ct-success h3{font-family:var(--serif);font-size:32px;margin-bottom:12px}
.in-ct-success p{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--dim)}

/* LEGAL */
.in-lg{padding:80px 28px;border-bottom:1px solid var(--line);max-width:920px;margin:0 auto;display:block}
.in-lg h2{font-family:var(--serif);font-weight:400;font-size:48px;line-height:1;margin:48px 0 16px;letter-spacing:-.02em}
.in-lg h2:first-of-type{margin-top:0}
.in-lg h2 em{font-style:italic;color:var(--accent)}
.in-lg h3{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin:32px 0 10px}
.in-lg p{font-size:15px;line-height:1.7;color:var(--ink);margin-bottom:14px;max-width:780px}
.in-lg p strong{color:var(--accent)}
.in-lg ul{list-style:none;margin:14px 0 24px}
.in-lg ul li{padding:8px 0 8px 18px;border-bottom:1px dashed var(--line);font-size:14px;color:var(--dim);position:relative}
.in-lg ul li::before{content:"›";position:absolute;left:0;color:var(--accent)}
.in-lg .in-lg-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);padding-bottom:32px;border-bottom:1px solid var(--line);margin-bottom:48px}
.in-lg-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);max-width:920px;margin:0 auto;padding:0 28px}
.in-lg-tab{padding:18px 28px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);border-bottom:2px solid transparent;cursor:pointer;transition:color .2s,border-color .2s;background:transparent}
.in-lg-tab.on{color:var(--ink);border-bottom-color:var(--accent)}
.in-lg-tab:hover{color:var(--ink)}

@media (max-width:900px){
  .in-svc-block{grid-template-columns:1fr;gap:24px}
  .in-svc-num{padding-top:0}
  .in-svc-r ul,.in-svc-r .in-deliverables{grid-template-columns:1fr}
  .plt-hero-grid,.plt-box,.plt-extras,.in-ct,.in-st-sedes-head,.in-ct-2,.in-ct-info{grid-template-columns:1fr;gap:24px}
  .plt-box.rev{direction:ltr}
  .plt-extra{border-right:0;border-bottom:1px solid var(--line)}
  .plt-feats ul{grid-template-columns:1fr}
  .plt-dims{grid-template-columns:repeat(2,1fr)}
  .plt-dim:nth-child(2){border-right:0}
  .plt-dim:nth-child(3){border-top:1px solid var(--line)}
  .in-st-stats,.in-st-sedes-grid{grid-template-columns:repeat(2,1fr)}
  .in-sede{border-bottom:1px solid var(--line)}
  .ci-page-foot,.in-hero{padding-left:18px;padding-right:18px}
  .ci-nav-inner{padding:14px 18px}
  .ci-nav-inner .ci-menu{display:none}
  .in-hero{padding-top:48px;padding-bottom:36px}
  .in-h1{font-size:64px}
}


/* ═══════════════════════════════════════════════════════════════════
   PROYECTOS — listado completo · editorial silencioso
   ═══════════════════════════════════════════════════════════════════ */

.pj-head{padding:80px 28px 28px;border-bottom:1px solid var(--line);position:relative}
.pj-head .in-crumbs{position:static;display:block;margin-bottom:24px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.pj-head .in-crumbs em{color:var(--accent);font-style:normal;margin-left:8px}
.pj-meta{display:flex;flex-wrap:wrap;gap:24px 40px;align-items:baseline;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.pj-meta .ci-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle;animation:pulse 2s infinite}
.pj-count b{color:var(--ink);font-weight:500}
.pj-view{margin-left:auto;display:inline-flex;gap:0;border:1px solid var(--line);border-radius:0;overflow:hidden}
.pj-view-lbl{padding:8px 14px;color:var(--dim);border-right:1px solid var(--line);background:rgba(255,255,255,.02)}
.pj-view button{padding:8px 14px;background:transparent;border:0;border-right:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);cursor:pointer;transition:color .2s,background .2s}
.pj-view button:last-child{border-right:0}
.pj-view button:hover{color:var(--ink)}
.pj-view button.on{background:var(--ink);color:var(--bg)}

/* ─── Filter bar ────────────────────────────────────────────── */
.pj-filters{padding:24px 28px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:14px;background:var(--bg-2)}
.pj-search{display:flex;align-items:center;gap:10px;border:1px solid var(--line);padding:10px 14px;max-width:480px;color:var(--dim)}
.pj-search input{flex:1;background:transparent;border:0;outline:0;font-family:var(--mono);font-size:13px;color:var(--ink);letter-spacing:.02em}
.pj-search input::placeholder{color:var(--dim);text-transform:none;letter-spacing:.02em}
.pj-search-x{background:transparent;border:0;color:var(--dim);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}
.pj-search-x:hover{color:var(--accent)}

.pj-filter-grp{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.pj-filter-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);min-width:88px;padding-right:8px}
.pj-filter-grp button{padding:5px 10px;background:transparent;border:1px solid transparent;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);cursor:pointer;transition:color .2s,border-color .2s,background .2s;white-space:nowrap}
.pj-filter-grp button:hover{color:var(--ink);border-color:var(--line)}
.pj-filter-grp button.on{color:var(--bg);background:var(--ink);border-color:var(--ink)}
.pj-clear{align-self:flex-start;margin-top:4px;background:transparent;border:0;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);cursor:pointer;padding:4px 0}
.pj-clear:hover{color:var(--ink)}

.pj-empty{padding:120px 28px;text-align:center;font-family:var(--serif);font-style:italic;font-size:24px;color:var(--dim)}

/* ═══ LEDGER — tabla filmográfica ═══════════════════════════ */
.pj-ledger{padding:0 28px}
.pj-led-head{display:grid;grid-template-columns:80px 1.6fr 140px 1.4fr 1.6fr;gap:32px;padding:32px 0 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);position:sticky;top:0;background:var(--bg);z-index:5}
.pj-led-row{display:grid;grid-template-columns:80px 1.6fr 140px 1.4fr 1.6fr;gap:32px;padding:18px 0;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:13px;color:var(--ink);transition:background .2s;align-items:baseline}
.pj-led-row:hover{background:rgba(255,255,255,.02)}
.pj-led-y{font-variant-numeric:tabular-nums;color:var(--dim);font-size:12px}
.pj-led-t{font-family:var(--serif);font-size:18px;letter-spacing:-.01em;color:var(--ink);position:relative;padding-left:0}
.pj-led-dot{color:var(--accent);font-size:9px;margin-right:10px;vertical-align:middle;position:relative;top:-2px}
.pj-led-cat em{font-style:italic;font-family:var(--serif);font-size:14px;color:var(--accent)}
.pj-led-c{color:var(--dim);font-size:11px;letter-spacing:.04em}
.pj-led-r{color:var(--ink);font-size:10px;letter-spacing:.06em;text-transform:uppercase;opacity:.75}

/* ═══ INDEX — lista tipográfica grande ═════════════════════ */
.pj-index{padding:0 28px}
.pj-idx-row{display:grid;grid-template-columns:60px 1fr auto 80px;gap:32px;padding:24px 0;border-bottom:1px solid var(--line);align-items:baseline;transition:background .2s,padding .3s}
.pj-idx-row:hover{background:rgba(230,163,90,.03);padding-left:12px}
.pj-idx-num{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--dim);font-variant-numeric:tabular-nums;padding-top:8px}
.pj-idx-t{font-family:var(--serif);font-size:clamp(28px,3vw,48px);font-weight:400;letter-spacing:-.025em;line-height:1;color:var(--ink)}
.pj-idx-t em.pj-idx-cat{display:inline-block;font-family:var(--mono);font-style:normal;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-left:14px;vertical-align:middle;opacity:.7}
.pj-idx-meta{display:flex;flex-direction:column;gap:4px;text-align:right;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--dim);text-transform:uppercase;padding-top:14px}
.pj-idx-meta span:last-child{font-size:9px;opacity:.7;letter-spacing:.08em}
.pj-idx-y{font-family:var(--mono);font-size:14px;font-variant-numeric:tabular-nums;color:var(--dim);text-align:right;padding-top:14px;letter-spacing:.04em}

/* ═══ ARCHIVE — agrupado por año ═══════════════════════════ */
.pj-archive{padding:0 28px 0}
.pj-arc-group{padding:48px 0 24px;border-bottom:1px solid var(--line)}
.pj-arc-y{display:flex;align-items:baseline;gap:24px;margin-bottom:32px;font-family:var(--serif);font-style:italic;color:var(--accent)}
.pj-arc-y > span:first-child{font-size:clamp(56px,7vw,96px);line-height:.9;letter-spacing:-.025em}
.pj-arc-y i{flex:1;height:1px;background:var(--line);font-style:normal}
.pj-arc-count{font-family:var(--mono);font-style:normal;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.pj-arc-count::before{content:"·\00a0"}
.pj-arc-items{display:flex;flex-direction:column;gap:0}
.pj-arc-row{display:grid;grid-template-columns:140px 1.8fr 1.4fr 1.6fr;gap:32px;padding:14px 0;border-top:1px solid var(--line);align-items:baseline;font-family:var(--mono);font-size:12px;color:var(--ink)}
.pj-arc-row:first-child{border-top:0}
.pj-arc-cat em{font-style:italic;font-family:var(--serif);font-size:13px;color:var(--dim)}
.pj-arc-t{font-family:var(--serif);font-size:20px;letter-spacing:-.01em;line-height:1.1}
.pj-arc-c{color:var(--dim);font-size:11px}
.pj-arc-r{color:var(--ink);font-size:10px;letter-spacing:.06em;text-transform:uppercase;opacity:.7}

/* ─── Responsive ───────────────────────────────────────── */
@media (max-width:900px){
  .pj-led-head,.pj-led-row{grid-template-columns:60px 1fr 90px;gap:16px}
  .pj-led-c,.pj-led-r,.pj-led-head .pj-led-c,.pj-led-head .pj-led-r{display:none}
  .pj-idx-row{grid-template-columns:40px 1fr 60px;gap:16px}
  .pj-idx-meta{display:none}
  .pj-idx-t{font-size:clamp(22px,5vw,32px)}
  .pj-arc-row{grid-template-columns:100px 1fr;gap:14px}
  .pj-arc-c,.pj-arc-r{display:none}
  .pj-view{margin-left:0;width:100%}
  .pj-meta{flex-direction:column;align-items:flex-start;gap:14px}
}


/* ═══ GRID — galería visual ════════════════════════════════ */
.pj-grid{padding:32px 28px 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.pj-grid-card{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg-2);cursor:default;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.pj-grid-card:hover{transform:translateY(-4px)}
.pj-grid-img{position:absolute;inset:0;overflow:hidden}
.pj-grid-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.05);transition:transform .8s cubic-bezier(.2,.8,.2,1),filter .4s}
.pj-grid-card:hover .pj-grid-img img{transform:scale(1.04);filter:saturate(1) contrast(1)}
.pj-grid-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.55) 35%,rgba(10,10,10,0) 60%);pointer-events:none}

/* Placeholder para proyectos sin still — composición tipográfica */
.pj-grid-ph{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-start;padding:24px;background:linear-gradient(135deg,rgba(230,163,90,.04) 0%,rgba(10,10,10,.95) 70%);overflow:hidden}
.pj-grid-ph::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(230,163,90,.08),transparent 60%);pointer-events:none}
.pj-grid-ph-y{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);opacity:.6;text-transform:uppercase}
.pj-grid-ph-t{font-family:var(--serif);font-style:italic;font-size:clamp(36px,4vw,56px);line-height:.95;letter-spacing:-.02em;color:rgba(255,255,255,.18);margin-top:auto;margin-bottom:auto;font-weight:400;text-wrap:balance;padding-right:30%}

.pj-grid-num{position:absolute;top:16px;right:18px;font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:rgba(255,255,255,.55);font-variant-numeric:tabular-nums;text-transform:uppercase;z-index:3}
.pj-grid-cat{position:absolute;top:16px;left:18px;font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--accent);text-transform:uppercase;z-index:3;padding:3px 8px;border:1px solid rgba(230,163,90,.4);background:rgba(10,10,10,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.pj-grid-meta{position:absolute;bottom:0;left:0;right:0;padding:20px 18px 18px;color:#fff;z-index:3}
.pj-grid-t{font-family:var(--serif);font-size:22px;line-height:1.05;letter-spacing:-.015em;color:#fff;margin-bottom:10px;text-wrap:balance;font-weight:400}
.pj-grid-d{display:flex;flex-direction:column;gap:3px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.pj-grid-d b{color:var(--accent);font-weight:500;letter-spacing:.1em}
.pj-grid-d span{opacity:.85}

@media (max-width:600px){
  .pj-grid{grid-template-columns:1fr;gap:16px}
}
