:root{
  --bg:#041C1C;--bg-2:#062828;--fg:#FFE6CB;--accent:#FFFF89;
  --mid:rgba(255,230,203,0.4);--mid-2:rgba(255,230,203,0.6);
  --border:rgba(255,230,203,0.15);--border-strong:rgba(255,230,203,0.35);
  --maxw:1280px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;border-radius:0;}
html,body{background:var(--bg);color:var(--fg);}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;font-weight:300;font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;position:relative;min-height:100vh;}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{background:none;border:none;color:inherit;font:inherit;cursor:pointer;}

/* ---------- External link confirm modal ---------- */
.ysn-external-modal{
  position:fixed;inset:0;
  display:none;
  z-index:999;
}
.ysn-external-modal[aria-hidden="false"]{display:block;}
.ysn-external-backdrop{
  position:absolute;inset:0;
  background:rgba(4,28,28,0.78);
  backdrop-filter:blur(8px);
}
.ysn-external-panel{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:min(720px, calc(100% - 48px));
  border:1px solid var(--border-strong);
  background:rgba(6,40,40,0.82);
  box-shadow:0 0 0 1px rgba(255,230,203,0.08) inset;
  padding:28px 24px 22px;
}
.ysn-external-eyebrow{color:var(--accent);margin-bottom:10px;}
.ysn-external-title{font-size:52px;line-height:0.95;margin-bottom:18px;}
.ysn-external-copy{display:flex;flex-direction:column;gap:10px;color:var(--mid-2);}
.ysn-external-name{color:var(--fg);}
.ysn-external-url{
  color:var(--mid);
  word-break:break-word;
}
.ysn-external-note{color:var(--mid-2);}
.ysn-external-actions{
  display:flex;gap:14px;justify-content:flex-end;
  margin-top:22px;flex-wrap:wrap;
}

/* Make frames feel clickable */
a.proj-frame{cursor:pointer;}
a.proj-frame:focus-visible{
  outline:1px solid var(--accent);
  outline-offset:4px;
}

/* Grey-out state on click */
.proj-frame.ysn-external-pending::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(4,28,28,0.55);
  pointer-events:none;
}
.proj-frame.ysn-external-pending img,
.proj-frame.ysn-external-pending{
  filter:grayscale(1) contrast(1.05) brightness(0.85);
}
.proj-frame.ysn-external-pending{border-color:var(--accent);}

.bebas{font-family:'Bebas Neue',sans-serif;font-weight:400;letter-spacing:0.01em;line-height:0.95;}
.mono{font-family:'Space Mono',monospace;text-transform:uppercase;letter-spacing:0.15em;font-size:11px;}
.mono-md{font-family:'Space Mono',monospace;text-transform:uppercase;letter-spacing:0.15em;font-size:13px;}
.mono-lower{font-family:'Space Mono',monospace;letter-spacing:0;font-size:13px;text-transform:none;}

.grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.05;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:overlay;}
.glow{position:fixed;top:-300px;left:-300px;width:1000px;height:1000px;background:radial-gradient(circle at center, rgba(255,189,56,0.18) 0%, rgba(255,189,56,0.08) 25%, rgba(255,189,56,0) 60%);pointer-events:none;z-index:1;mix-blend-mode:lighten;}
.scanline{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0.04;background:repeating-linear-gradient(0deg, transparent 0, transparent 2px, rgba(255,230,203,0.4) 2px, rgba(255,230,203,0.4) 3px);}

.shell{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 32px;}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(8px);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:20px 32px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:40px;}
.logo{display:flex;align-items:baseline;gap:10px;}
.logo .y{font-family:'Bebas Neue',sans-serif;font-size:30px;line-height:1;letter-spacing:0.02em;}
.logo .d{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.25em;color:var(--mid-2);}
.nav-links{display:flex;justify-content:center;gap:40px;list-style:none;}
.nav-links a{transition:color 0.15s ease;}
.nav-links a:hover{color:var(--accent);}
.nav-links a.active::before{content:"> ";color:var(--accent);}
.nav-cta{transition:color 0.15s ease;}
.nav-cta:hover{color:var(--accent);}
.hamburger{display:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:6px;align-items:flex-end;}
.hamburger span{display:block;height:1px;background:var(--fg);transition:all 0.2s ease;}
.hamburger span:nth-child(1){width:24px;}
.hamburger span:nth-child(2){width:18px;}
.hamburger.open span:nth-child(1){transform:translateY(3.5px) rotate(45deg);width:24px;}
.hamburger.open span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg);width:24px;}

/* HERO */
.page-hero{padding:96px 0 64px;border-bottom:1px solid var(--border);}
.page-hero .eyebrow{color:var(--accent);margin-bottom:24px;display:inline-block;}
.page-hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(72px, 13vw, 192px);line-height:0.92;margin-bottom:32px;}
.page-hero .sub{color:var(--mid-2);max-width:640px;font-size:18px;line-height:1.7;}

/* INDEX BAR */
.indexbar{
  display:grid;grid-template-columns:120px 1fr 1fr 1fr 100px;
  gap:24px;align-items:center;
  padding:18px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  font-family:'Space Mono',monospace;
  font-size:10px;text-transform:uppercase;letter-spacing:0.25em;
  color:var(--mid);
}

/* PROJECT */
.project{
  display:grid;grid-template-columns:120px 1fr;
  gap:48px;
  padding:96px 0;
  border-bottom:1px solid var(--border);
}
.project:last-of-type{border-bottom:none;}
.project .index-col{
  display:flex;flex-direction:column;gap:24px;
  font-family:'Space Mono',monospace;
}
.project .index-col .num{
  font-family:'Bebas Neue',sans-serif;
  font-size:80px;line-height:1;color:var(--accent);
}
.project .index-col .yr{font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--mid);}
.project .body-col{display:flex;flex-direction:column;gap:32px;}

.proj-frame{
  aspect-ratio:4/3;
  background:#0a2a2a;
  border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.proj-frame::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0, transparent 32px, rgba(255,230,203,0.025) 32px, rgba(255,230,203,0.025) 33px);
  pointer-events:none;
}
.proj-frame .corner{position:absolute;width:18px;height:18px;border:1px solid var(--border-strong);}
.proj-frame .corner.tl{top:18px;left:18px;border-right:none;border-bottom:none;}
.proj-frame .corner.tr{top:18px;right:18px;border-left:none;border-bottom:none;}
.proj-frame .corner.bl{bottom:18px;left:18px;border-right:none;border-top:none;}
.proj-frame .corner.br{bottom:18px;right:18px;border-left:none;border-top:none;}
.proj-frame .stamp{position:relative;z-index:1;text-align:center;padding:0 24px;}
.proj-frame .stamp .meta-top{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--mid);margin-bottom:16px;
}
.proj-frame .stamp .big{
  font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,6vw,84px);
  line-height:0.95;letter-spacing:0.02em;color:var(--fg);margin-bottom:14px;
}
.proj-frame .stamp .meta-bot{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--mid-2);
}
.proj-frame .pid{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:0.3em;color:var(--mid);
  text-align:center;
  max-width:calc(100% - 48px);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.proj-frame .ticks{
  position:absolute;top:0;left:0;right:0;height:24px;
  display:flex;justify-content:space-between;padding:0 24px;
  pointer-events:none;
}
.proj-frame .ticks span{display:block;width:1px;height:8px;background:var(--border-strong);}

.proj-info{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
}
.proj-info .col h3{
  font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:1;margin-bottom:8px;
}
.proj-info .col .type{color:var(--accent);margin-bottom:24px;display:block;}
.proj-info .col .desc{color:var(--mid-2);font-size:15px;text-wrap:pretty;}
.proj-info .meta-block{display:flex;flex-direction:column;gap:24px;}
.proj-info .meta-row{
  display:flex;flex-direction:column;gap:6px;
  padding-bottom:16px;border-bottom:1px solid var(--border);
}
.proj-info .meta-row .k{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--mid);
}
.proj-info .meta-row .v{font-family:'Space Mono',monospace;font-size:13px;color:var(--fg);}
.proj-info .tags{display:flex;flex-wrap:wrap;gap:8px;}
.proj-info .tags span{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  border:1px solid var(--border-strong);padding:8px 12px;color:var(--fg);
}

/* CTA */
.cta-band{border-top:1px solid var(--border-strong);border-bottom:1px solid var(--border-strong);padding:96px 0;position:relative;z-index:3;}
.cta-band-inner{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.cta-band h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,8vw,112px);line-height:0.95;max-width:1000px;}
.cta-band .sub{color:var(--mid-2);margin-top:20px;max-width:560px;}
.cta-band .label{color:var(--accent);display:inline-block;margin-bottom:24px;}
.btn{display:inline-flex;align-items:center;gap:14px;padding:18px 28px;border:1px solid var(--fg);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;transition:all 0.15s ease;cursor:pointer;}
.btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent);}

/* PROCESS STRIP */
.process{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.process-step{padding:40px 28px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:14px;}
.process-step:last-child{border-right:none;}
.process-step .n{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent);}
.process-step .t{font-family:'Bebas Neue',sans-serif;font-size:32px;line-height:1;}
.process-step .d{color:var(--mid-2);font-size:13px;line-height:1.6;}

/* FOOTER */
.footer{border-top:1px solid var(--border-strong);padding:80px 0 32px;position:relative;z-index:3;}
.footer-grid{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;}
.footer h4{font-family:'Space Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:0.25em;color:var(--mid);margin-bottom:20px;}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.footer ul a{color:var(--fg);transition:color 0.15s ease;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;}
.footer ul a:hover{color:var(--accent);}
.footer .tagline{color:var(--mid-2);max-width:300px;margin-top:16px;font-size:14px;}
.footer-bottom{max-width:var(--maxw);margin:64px auto 0;padding:24px 32px 0;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);}
.footer-bottom .star{color:var(--accent);margin:0 10px;}

.reveal{opacity:0;transform:translateY(16px);animation:rise 0.5s ease forwards;}
@keyframes rise{to{opacity:1;transform:translateY(0);}}
.r-1{animation-delay:0.05s;} .r-2{animation-delay:0.15s;} .r-3{animation-delay:0.25s;} .r-4{animation-delay:0.35s;}

@media (max-width:980px){
  .project{grid-template-columns:1fr;gap:32px;padding:64px 0;}
  .project .index-col{flex-direction:row;align-items:center;gap:20px;}
  .project .index-col .num{font-size:56px;}
  .proj-info{grid-template-columns:1fr;gap:32px;}
  .indexbar{grid-template-columns:1fr 1fr;gap:8px 16px;font-size:9px;}
  .indexbar > span:nth-child(n+3){display:none;}
  .process{grid-template-columns:repeat(2,1fr);}
  .process-step:nth-child(2){border-right:none;}
  .process-step:nth-child(1),.process-step:nth-child(2){border-bottom:1px solid var(--border);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .cta-band-inner{grid-template-columns:1fr;}
}
@media (max-width:768px){
  .shell,.nav-inner,.cta-band-inner,.footer-grid,.footer-bottom{padding-left:24px;padding-right:24px;}
  .nav-inner{grid-template-columns:1fr auto;gap:16px;}
  .logo{justify-self:start;}
  .hamburger{justify-self:end;}
  .nav-links{position:fixed;top:65px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border-strong);flex-direction:column;gap:0;padding:0;max-height:0;overflow:hidden;transition:max-height 0.3s ease;}
  .nav-links.open{max-height:400px;}
  .nav-links li{border-top:1px solid var(--border);list-style:none;}
  .nav-links li:first-child{border-top:none;}
  .nav-links a{display:block;padding:24px 32px;}
  .nav-cta{display:none;}
  .hamburger{display:flex;}
  .page-hero{padding:64px 0 48px;}
  .process{grid-template-columns:1fr;}
  .process-step{border-right:none;border-bottom:1px solid var(--border);}
  .process-step:last-child{border-bottom:none;}
  .footer-grid{grid-template-columns:1fr;gap:40px;}
  .footer-bottom{flex-direction:column;}
}

@media (max-width:520px){
  .project{padding:48px 0;}
  .project .index-col{gap:14px;flex-wrap:wrap;}
  .project .index-col .num{font-size:48px;}

  .proj-frame .stamp{padding:0 16px;}
  .proj-frame .ticks{padding:0 14px;}
  .proj-frame .corner{width:14px;height:14px;}
  .proj-frame .corner.tl{top:14px;left:14px;}
  .proj-frame .corner.tr{top:14px;right:14px;}
  .proj-frame .corner.bl{bottom:14px;left:14px;}
  .proj-frame .corner.br{bottom:14px;right:14px;}
  .proj-frame .pid{
    bottom:18px;
    max-width:calc(100% - 32px);
    letter-spacing:0.22em;
  }

  .proj-info .col h3{font-size:44px;}
}
