/* =========================================================
   LTN / PROJECTS — CASEFILES (data-page="projects")
   Skin standalone para /public/skins/projects.css
   Scope: body[data-page="projects"] ...
========================================================= */

body[data-page="projects"]{
  --bg: #050506;
  --ink: rgba(255,255,255,.88);
  --muted: rgba(255,255,255,.62);

  --paper: #b9b7b0;
  --paper2: #a9a59c;
  --paperInk: rgba(8,8,10,.92);

  --crimson: #8b0f18;
  --crimson2: #b11221;
  --glitch: rgba(80, 255, 145, .55);

  --line: rgba(255,255,255,.14);

  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;

  background: var(--bg);
  color: var(--ink);
}

body[data-page="projects"] main{
  position: relative;
  min-height: 100vh;
  overflow: clip;
}

/* overlays */
body[data-page="projects"] main::before,
body[data-page="projects"] main::after{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  z-index:0;
}

body[data-page="projects"] main::before{
  opacity:.22;
  mix-blend-mode: overlay;
  background:
    radial-gradient(1200px 800px at 22% 18%, rgba(255,255,255,.08), transparent 55%),
    radial-gradient(900px 700px at 78% 34%, rgba(177,18,33,.10), transparent 60%),
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.05) 0px,
      rgba(255,255,255,.05) 1px,
      transparent 2px,
      transparent 4px
    );
  filter: contrast(110%) saturate(110%);
  animation: ltnScan 7.5s linear infinite;
}

body[data-page="projects"] main::after{
  opacity:.16;
  mix-blend-mode: soft-light;
  background:
    repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,.03) 0 1px, transparent 1px 3px),
    linear-gradient(90deg, rgba(80,255,145,.06), transparent 28%, rgba(177,18,33,.05) 70%, transparent);
  filter: blur(.4px);
  animation: ltnFlicker 5.2s ease-in-out infinite;
}

@keyframes ltnScan{ 0%{transform:translateY(0)} 100%{transform:translateY(18px)} }
@keyframes ltnFlicker{ 0%,100%{opacity:.14} 50%{opacity:.20} }

body[data-page="projects"] .ltn-projects{
  position: relative;
  z-index: 1;
  padding: clamp(22px, 4vw, 56px) clamp(16px, 4vw, 56px) 96px;
  max-width: 1240px;
  margin: 0 auto;
}

body[data-page="projects"] .ltn-projects__top{
  position: relative;
  padding: 20px 0 18px;
  border-bottom: 1px solid var(--line);
}

body[data-page="projects"] .ltn-projects__kicker{
  display:flex; align-items:center; gap:10px;
  font-family: var(--mono);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 12px;
  color: var(--muted);
}

body[data-page="projects"] .ltn-projects__kicker .dot{
  width:8px;height:8px;border-radius:999px;
  background: var(--crimson2);
  box-shadow: 0 0 0 3px rgba(177,18,33,.18), 0 0 18px rgba(177,18,33,.28);
}

body[data-page="projects"] .ltn-projects__title{
  margin: 10px 0 6px;
  font-family: var(--serif);
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.05;
  font-size: clamp(34px, 4.6vw, 64px);
}

body[data-page="projects"] .ltn-projects__subtitle{
  margin:0;
  max-width: 66ch;
  color: rgba(255,255,255,.70);
  font-size: 15px;
  line-height: 1.7;
}

body[data-page="projects"] .ltn-projects__meta{
  margin-top: 14px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  font-family: var(--mono);
  font-size: 12px;
  color: rgba(255,255,255,.66);
}

/* Badge “archivo” para projects (sin tocar el global .badge) */
body[data-page="projects"] .badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
  text-transform: uppercase;
  letter-spacing: .14em;
  border-radius: 0;
}
body[data-page="projects"] .badge b{ color: rgba(255,255,255,.86); font-weight: 600; letter-spacing:.12em; }
body[data-page="projects"] .badge i{
  width:6px;height:6px;border-radius:999px;
  background: rgba(80,255,145,.45);
  box-shadow: 0 0 12px rgba(80,255,145,.25);
}

body[data-page="projects"] .ltn-projects__grid{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap: 26px;
  margin-top: 26px;
}
@media (max-width: 980px){
  body[data-page="projects"] .ltn-projects__grid { grid-template-columns: 1fr; }
}

/* CONTENTS (índice editorial) */
body[data-page="projects"] .contents{
  position: sticky;
  top: 22px;
  align-self: start;

  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 14px;
  border-radius: 0;
}
@media (max-width: 980px){
  body[data-page="projects"] .contents { position: relative; top: 0; }
}

body[data-page="projects"] .contents__label{
  font-family: var(--mono);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 11px;
  color: rgba(255,255,255,.60);
  margin: 0 0 10px;
}

body[data-page="projects"] .contents__list{
  list-style: none;
  padding: 0;
  margin: 0;
  display:flex;
  flex-direction: column;
  gap: 8px;
}

body[data-page="projects"] .contents__item{ margin:0; }

body[data-page="projects"] .contents__link{
  display:block;
  text-decoration: none;
  color: rgba(255,255,255,.76);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 12px 12px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
  border-radius: 0;
}

body[data-page="projects"] .contents__link::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent, rgba(80,255,145,.10), transparent),
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px);
  opacity: 0;
  transform: translateX(-18%);
  transition: opacity .2s ease, transform .2s ease;
}

body[data-page="projects"] .contents__link:hover{
  border-color: rgba(177,18,33,.40);
  color: rgba(255,255,255,.92);
}
body[data-page="projects"] .contents__link:hover::before{
  opacity: 1;
  transform: translateX(0);
}

body[data-page="projects"] .contents__row{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

body[data-page="projects"] .contents__id{
  font-family: var(--mono);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.70);
}

body[data-page="projects"] .contents__name{
  font-family: var(--mono);
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,.88);
  flex: 1;
  text-align: right;
}

body[data-page="projects"] .contents__sub{
  display:block;
  margin-top: 6px;
  color: rgba(255,255,255,.55);
  letter-spacing: .14em;
  text-transform: uppercase;
}

/* CASEFILE */
body[data-page="projects"] .casefile{ display:flex; flex-direction: column; gap: 18px; }

/* CHAPTER paper */
body[data-page="projects"] .chapter{
  position: relative;
  background: linear-gradient(180deg, var(--paper), var(--paper2));
  color: var(--paperInk);
  border: 1px solid rgba(0,0,0,.35);
  box-shadow: 0 24px 80px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.25);
  padding: 20px 18px 18px;
  overflow: hidden;
  border-radius: 0;
}

body[data-page="projects"] .chapter::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(18px 10px at 18px 12px, rgba(0,0,0,.22), transparent 70%),
    radial-gradient(18px 10px at calc(100% - 18px) 14px, rgba(0,0,0,.22), transparent 70%),
    radial-gradient(22px 14px at 22px calc(100% - 14px), rgba(0,0,0,.28), transparent 70%),
    radial-gradient(22px 14px at calc(100% - 22px) calc(100% - 14px), rgba(0,0,0,.28), transparent 70%);
  pointer-events:none;
  opacity:.75;
  mix-blend-mode: multiply;
}

body[data-page="projects"] .chapter::after{
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  background:
    radial-gradient(500px 220px at 20% 10%, rgba(0,0,0,.12), transparent 70%),
    radial-gradient(420px 220px at 80% 30%, rgba(139,15,24,.10), transparent 70%),
    repeating-linear-gradient(0deg, rgba(0,0,0,.05) 0 1px, transparent 1px 5px);
  opacity:.85;
  mix-blend-mode: multiply;
}

/* tape */
body[data-page="projects"] .chapter__tape{
  position:absolute;
  width: 84px;
  height: 24px;
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(0,0,0,.18);
  transform: rotate(-8deg);
  top: 10px;
  left: 14px;
  z-index: 2;
  opacity: .85;
}
body[data-page="projects"] .chapter__tape--b{
  transform: rotate(10deg);
  top: 12px;
  left: auto;
  right: 14px;
  width: 64px;
}

/* head */
body[data-page="projects"] .chapter__head{
  position: relative;
  z-index: 2;
  display:flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  border-bottom: 1px solid rgba(0,0,0,.28);
  padding-bottom: 12px;
  margin-bottom: 14px;
}

body[data-page="projects"] .chapter__id{
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 11px;
  color: rgba(0,0,0,.68);
}

body[data-page="projects"] .chapter__title{
  margin: 8px 0 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1.05;
  font-size: clamp(22px, 2.3vw, 30px);
}

body[data-page="projects"] .chapter__logline{
  margin: 8px 0 0;
  color: rgba(0,0,0,.76);
  line-height: 1.7;
  font-size: 14px;
  max-width: 70ch;
}

body[data-page="projects"] .stamps{
  display:flex;
  flex-direction: column;
  align-items:flex-end;
  gap: 10px;
  min-width: 210px;
}
@media (max-width: 560px){
  body[data-page="projects"] .chapter__head{ flex-direction: column; }
  body[data-page="projects"] .stamps{ align-items:flex-start; min-width: unset; }
}

body[data-page="projects"] .stamp{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  border: 2px solid rgba(139,15,24,.70);
  color: rgba(90,10,16,.92);
  background: rgba(139,15,24,.06);
  transform: rotate(-2deg);
  border-radius: 0;
}
body[data-page="projects"] .stamp--danger{ border-color: rgba(139,15,24,.82); box-shadow: 0 10px 26px rgba(139,15,24,.18); }
body[data-page="projects"] .stamp--status{
  border-color: rgba(0,0,0,.35);
  background: rgba(0,0,0,.04);
  color: rgba(0,0,0,.72);
  transform: rotate(1deg);
}

/* body grid */
body[data-page="projects"] .chapter__body{
  position: relative;
  z-index: 2;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
}
@media (max-width: 980px){
  body[data-page="projects"] .chapter__body{ grid-template-columns: 1fr; }
}

/* evidence */
body[data-page="projects"] .evidence{
  border: 1px dashed rgba(0,0,0,.35);
  padding: 14px;
  background: rgba(255,255,255,.16);
  position: relative;
  overflow: hidden;
}

body[data-page="projects"] .evidence__label{
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  color: rgba(0,0,0,.68);
  margin: 0 0 10px;
}

body[data-page="projects"] .evidence__grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 560px){
  body[data-page="projects"] .evidence__grid{ grid-template-columns: 1fr; }
}

body[data-page="projects"] .still{
  position: relative;
  aspect-ratio: 16/9;
  border: 1px solid rgba(0,0,0,.55);
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.32)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px);
  overflow: hidden;
  border-radius: 0;
}
body[data-page="projects"] .still img{
  width:100%;
  height:100%;
  object-fit: cover;
  filter: contrast(110%) saturate(90%);
  opacity: .92;
  transform: scale(1.02);
}
body[data-page="projects"] .still::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(80,255,145,.08), transparent 35%, rgba(177,18,33,.07) 72%, transparent),
    radial-gradient(220px 140px at 30% 20%, rgba(255,255,255,.07), transparent 70%);
  mix-blend-mode: overlay;
  opacity: .70;
}
body[data-page="projects"] .still__cap{
  position:absolute;
  left:10px;
  bottom:10px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.86);
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.14);
  padding: 6px 8px;
  border-radius: 0;
}

/* notes */
body[data-page="projects"] .notes{
  border: 1px solid rgba(0,0,0,.35);
  background: rgba(0,0,0,.03);
  padding: 14px;
  border-radius: 0;
}
body[data-page="projects"] .notes__label{
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  color: rgba(0,0,0,.68);
  margin: 0 0 10px;
}
body[data-page="projects"] .notes__list{
  margin: 0;
  padding-left: 14px;
  color: rgba(0,0,0,.78);
  line-height: 1.7;
  font-size: 13px;
}
body[data-page="projects"] .notes__list li{ margin: 6px 0; }

/* tags */
body[data-page="projects"] .tags{ display:flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
body[data-page="projects"] .tag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 7px 8px;
  border: 1px solid rgba(0,0,0,.35);
  background: rgba(255,255,255,.12);
  color: rgba(0,0,0,.78);
  border-radius: 0;
}

/* foot */
body[data-page="projects"] .chapter__foot{
  position: relative;
  z-index: 2;
  margin-top: 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(0,0,0,.28);
}

body[data-page="projects"] .links{ display:flex; flex-wrap: wrap; gap: 10px; }
body[data-page="projects"] .link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  text-decoration: none;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 11px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.55);
  color: rgba(0,0,0,.86);
  background: rgba(255,255,255,.14);
  position: relative;
  overflow: hidden;
  border-radius: 0;
}
body[data-page="projects"] .link::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, transparent, rgba(139,15,24,.10), transparent);
  opacity:0;
  transform: translateX(-18%);
  transition: opacity .18s ease, transform .18s ease;
}
body[data-page="projects"] .link:hover{ border-color: rgba(139,15,24,.65); }
body[data-page="projects"] .link:hover::before{ opacity:1; transform: translateX(0); }

body[data-page="projects"] .readout{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(0,0,0,.68);
  display:flex;
  align-items:center;
  gap: 10px;
}
body[data-page="projects"] .readout .sig{
  width:10px;height:10px;
  background: rgba(80,255,145,.30);
  border: 1px solid rgba(0,0,0,.35);
  box-shadow: 0 0 14px rgba(80,255,145,.18);
}

/* divider */
body[data-page="projects"] .chapter-divider{
  height: 18px;
  background:
    linear-gradient(90deg, transparent, rgba(177,18,33,.32), transparent),
    repeating-linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px 10px);
  opacity: .55;
  filter: blur(.1px);
}

/* ---------------------------------------------------------
   Cinematic opening (video feed)
--------------------------------------------------------- */
body[data-page="projects"] .projects-open{
  margin-top: 18px;
}

body[data-page="projects"] .projects-open__frame{
  position: relative;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  overflow: hidden;
  box-shadow: 0 24px 90px rgba(0,0,0,.55);
  border-radius: 0;
}

body[data-page="projects"] .projects-open__video{
  width: 100%;
  height: clamp(220px, 34vw, 420px);
  object-fit: cover;
  filter: contrast(112%) saturate(90%);
  opacity: .92;
  transform: scale(1.02);
}

body[data-page="projects"] .projects-open__mask{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(900px 420px at 22% 18%, rgba(255,255,255,.08), transparent 55%),
    linear-gradient(90deg, rgba(80,255,145,.08), transparent 35%, rgba(177,18,33,.08) 72%, transparent),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 4px);
  mix-blend-mode: overlay;
  opacity: .75;
}

body[data-page="projects"] .projects-open__hud{
  position:absolute;
  left: 14px;
  bottom: 14px;
  display:flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 10px;
  color: rgba(255,255,255,.88);
}

body[data-page="projects"] .hud__chip{
  align-self: flex-start;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(0,0,0,.55);
  border-radius: 0;
}

body[data-page="projects"] .hud__line{
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.42);
  width: fit-content;
  border-radius: 0;
}

/* =========================================================
   PROJECTS — POLISH PASS (elegante + cinematográfico)
========================================================= */

/* quitar radius dentro del bloque projects (editorial “corte”) */
body[data-page="projects"] .ltn-projects *,
body[data-page="projects"] .ltn-projects *::before,
body[data-page="projects"] .ltn-projects *::after{
  border-radius: 0 !important;
}

/* HERO */
body[data-page="projects"] .projects-hero{
  margin-top: 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.30);
  box-shadow: 0 26px 110px rgba(0,0,0,.62);
  overflow: hidden;
  position: relative;
  border-radius: 0;
}

body[data-page="projects"] .projects-hero__media{
  position: relative;
  height: clamp(320px, 38vw, 520px);
}

body[data-page="projects"] .projects-hero__video{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.03);
  opacity: .90;
  filter: contrast(112%) saturate(92%);
  display:block;
}

/* forzar ocultar controles overlay */
body[data-page="projects"] .projects-hero__video::-webkit-media-controls{ display:none !important; }
body[data-page="projects"] .projects-hero__video::-webkit-media-controls-enclosure{ display:none !important; }
body[data-page="projects"] .projects-hero__video::-webkit-media-controls-panel{ display:none !important; }

body[data-page="projects"] .projects-hero__mask{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(1200px 520px at 20% 20%, rgba(255,255,255,.08), transparent 58%),
    radial-gradient(900px 520px at 75% 25%, rgba(177,18,33,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.55), transparent 30%, rgba(0,0,0,.65)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 4px),
    linear-gradient(90deg, rgba(80,255,145,.07), transparent 32%, rgba(177,18,33,.06) 72%, transparent);
  mix-blend-mode: overlay;
  opacity: .80;
}

body[data-page="projects"] .projects-hero__grain{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,.03) 0 1px, transparent 1px 3px);
  opacity: .14;
  mix-blend-mode: soft-light;
}

body[data-page="projects"] .projects-hero__overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(18px, 3vw, 34px);
  gap: 14px;
}

/* HUD top */
body[data-page="projects"] .projects-hero__hud{
  position:absolute;
  left: 18px;
  top: 14px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 10px;
  color: rgba(255,255,255,.86);
  opacity: .82;
}
body[data-page="projects"] .hud__sep{ opacity: .45; }

/* header sobre el video */
body[data-page="projects"] .ltn-projects__top{
  border-bottom: none;
  padding: 0;
  max-width: 980px;
}

body[data-page="projects"] .ltn-projects__title{
  text-shadow: 0 18px 60px rgba(0,0,0,.85);
}

body[data-page="projects"] .ltn-projects__subtitle{
  color: rgba(255,255,255,.78);
}

@media (prefers-reduced-motion: reduce){
  body[data-page="projects"] main::before,
  body[data-page="projects"] main::after{
    animation: none !important;
  }
}
/* =========================================================
   PROJECTS HUB — Archive folders + sliding casefile paper
========================================================= */

body[data-page="projects"] .proj-hub{
  position: relative;
  z-index: 1;
  max-width: 1240px;
  margin: 0 auto;
  padding: clamp(22px, 4vw, 56px) clamp(16px, 4vw, 56px) 96px;
}

body[data-page="projects"] .proj-hub__top{
  padding: 20px 0 18px;
  border-bottom: 1px solid var(--line);
}

body[data-page="projects"] .proj-hub__kicker{
  display:flex; align-items:center; gap:10px;
  font-family: var(--mono);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 12px;
  color: var(--muted);
}
body[data-page="projects"] .proj-hub__kicker .dot{
  width:8px;height:8px;border-radius:999px;
  background: var(--crimson2);
  box-shadow: 0 0 0 3px rgba(177,18,33,.18), 0 0 18px rgba(177,18,33,.28);
}

body[data-page="projects"] .proj-hub__title{
  margin: 10px 0 6px;
  font-family: var(--serif);
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.05;
  font-size: clamp(34px, 4.6vw, 64px);
}

body[data-page="projects"] .proj-hub__sub{
  margin:0;
  max-width: 70ch;
  color: rgba(255,255,255,.74);
  font-size: 15px;
  line-height: 1.7;
}

body[data-page="projects"] .proj-hub__meta{
  margin-top: 14px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  font-family: var(--mono);
  font-size: 12px;
  color: rgba(255,255,255,.66);
}

body[data-page="projects"] .hub-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
  text-transform: uppercase;
  letter-spacing: .14em;
}
body[data-page="projects"] .hub-badge b{ color: rgba(255,255,255,.86); font-weight: 600; letter-spacing:.12em; }
body[data-page="projects"] .hub-badge .sep{ opacity:.45; }

/* archive stack */
body[data-page="projects"] .archive{
  margin-top: 22px;
  display:flex;
  flex-direction: column;
  gap: 18px;
}

/* folder shell */
body[data-page="projects"] .folder{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  box-shadow: 0 18px 70px rgba(0,0,0,.55);
  position: relative;
  overflow: hidden;
}

/* folder “tab” header */
body[data-page="projects"] .folder__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 14px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(90deg, rgba(80,255,145,.05), transparent 35%, rgba(177,18,33,.06) 72%, transparent),
    rgba(0,0,0,.25);
}

body[data-page="projects"] .folder__tab{
  width: 72px;
  height: 18px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  box-shadow: 0 0 0 1px rgba(0,0,0,.35) inset;
  transform: skewX(-14deg);
}

body[data-page="projects"] .folder__title{
  font-family: var(--mono);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.86);
  flex: 1;
}

body[data-page="projects"] .folder__count{
  font-family: var(--mono);
  letter-spacing: .22em;
  font-size: 12px;
  color: rgba(255,255,255,.60);
}

body[data-page="projects"] .folder__body{
  padding: 14px;
}

body[data-page="projects"] .folder__empty{
  font-family: var(--mono);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 11px;
  color: rgba(255,255,255,.60);
  padding: 18px 2px;
}

/* grid of cases */
body[data-page="projects"] .casegrid{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}

@media (max-width: 980px){
  body[data-page="projects"] .casegrid{ gap: 10px; }
}

/* each case: spine + sliding paper */
body[data-page="projects"] .case{
  grid-column: span 6;
  min-height: 156px;
  position: relative;
}

@media (max-width: 980px){
  body[data-page="projects"] .case{ grid-column: span 12; }
}

body[data-page="projects"] .case__hit{
  display:block;
  position: relative;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  min-height: 156px;
  text-decoration:none;
  outline: none;
}

/* spine (carpeta / lomo) */
body[data-page="projects"] .case__spine{
  position:absolute;
  left:0; top:0; bottom:0;
  width: 62px;
  border-right: 1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    rgba(0,0,0,.20);
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content: center;
  gap: 10px;
}

body[data-page="projects"] .case__id{
  font-family: var(--mono);
  letter-spacing: .22em;
  font-size: 12px;
  color: rgba(255,255,255,.75);
}

body[data-page="projects"] .case__stamp{
  font-family: var(--mono);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(255,255,255,.65);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}

/* the “paper” that slides out */
body[data-page="projects"] .case__paper{
  position:absolute;
  left: 62px;
  top: 10px;
  bottom: 10px;
  width: calc(100% - 72px);
  background:
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(220,214,202,.92));
  border: 1px solid rgba(0,0,0,.28);
  box-shadow:
    0 20px 70px rgba(0,0,0,.55),
    0 1px 0 rgba(255,255,255,.35) inset;
  transform: translateX(-72%);
  transition: transform .28s ease;
}

/* paper “print” */
body[data-page="projects"] .case__paper::before{
  content:"";
  position:absolute; inset:0;
  opacity:.55;
  background:
    radial-gradient(420px 240px at 30% 18%, rgba(0,0,0,.08), transparent 70%),
    radial-gradient(520px 280px at 80% 70%, rgba(139,15,24,.06), transparent 72%),
    repeating-linear-gradient(0deg, rgba(0,0,0,.06) 0 1px, transparent 1px 6px);
  mix-blend-mode: multiply;
  pointer-events:none;
}

/* content sits above paper, masked by paper slide */
body[data-page="projects"] .case__content{
  position: relative;
  display:block;
  padding: 16px 16px 14px 78px;
  min-height: 156px;
}

/* preview background (subtle) */
body[data-page="projects"] .case__content::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.68), rgba(0,0,0,.20)),
    var(--case-bg);
  background-size: cover;
  background-position: center;
  opacity: .0;
  transition: opacity .28s ease;
  pointer-events:none;
}

/* text */
body[data-page="projects"] .case__topline{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  position: relative;
  z-index: 2;
}

body[data-page="projects"] .case__title{
  font-family: var(--serif);
  font-size: 22px;
  color: rgba(0,0,0,.88);
  letter-spacing: .02em;
}

body[data-page="projects"] .case__year{
  font-family: var(--mono);
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(0,0,0,.65);
}

body[data-page="projects"] .case__logline{
  display:block;
  margin-top: 8px;
  max-width: 70ch;
  line-height: 1.6;
  color: rgba(0,0,0,.72);
  position: relative;
  z-index: 2;
  font-size: 14px;
}

body[data-page="projects"] .case__tags{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  position: relative;
  z-index: 2;
}

body[data-page="projects"] .ctag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 7px 8px;
  border: 1px solid rgba(0,0,0,.32);
  background: rgba(255,255,255,.18);
  color: rgba(0,0,0,.72);
}

/* CTA */
body[data-page="projects"] .case__cta{
  display:block;
  margin-top: 12px;
  position: relative;
  z-index: 2;
}

body[data-page="projects"] .cta{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-family: var(--mono);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 11px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.42);
  background: rgba(255,255,255,.58);
  color: rgba(0,0,0,.86);
}

body[data-page="projects"] .cta__arrow{
  width:26px;height:2px;
  background: rgba(140,0,20,.95);
  position:relative;
}
body[data-page="projects"] .cta__arrow::after{
  content:"";
  position:absolute;
  right:-1px; top:-4px;
  width:10px; height:10px;
  border-right:2px solid rgba(140,0,20,.95);
  border-top:2px solid rgba(140,0,20,.95);
  transform: rotate(45deg);
}

/* Interaction: hover/focus opens paper + reveal preview */
body[data-page="projects"] .case__hit:hover .case__paper,
body[data-page="projects"] .case__hit:focus-visible .case__paper{
  transform: translateX(0%);
}

body[data-page="projects"] .case__hit:hover .case__content::before,
body[data-page="projects"] .case__hit:focus-visible .case__content::before{
  opacity: .20;
}

/* Add subtle jitter/glow on hover */
body[data-page="projects"] .case__hit:hover{
  border-color: rgba(177,18,33,.40);
  box-shadow: 0 18px 80px rgba(0,0,0,.55);
  transform: translateY(-1px);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

@media (prefers-reduced-motion: reduce){
  body[data-page="projects"] .case__paper,
  body[data-page="projects"] .case__content::before{
    transition: none !important;
  }
}