/* =========================
   Convicts-inspired portfolio (v2)
   Adds:
   1) Intro black screen type burst (3–5s)
   2) Cursor interaction upgrades
   3) Key color tone-and-manner system
   4) Multi-page structure + case study template
   ========================= */

:root{
  /* Tone & manner */
  --bg: #ffffff;
  --fg: #000000;
  --muted: rgba(15,15,16,.58);
  --hair: rgba(15,15,16,.12);
  --soft: rgba(15,15,16,.06);

  /* Key color: set this once to theme the whole site */
  --accent: #39FF14; /* change to your key color */
  --accent2: rgba(57,255,20,.18);

  --radius: 22px;
  --radius2: 30px;

  --wrap: min(1180px, calc(100vw - 80px));

  --h1: clamp(40px, 6.6vw, 118px);
  --h2: clamp(26px, 3.1vw, 56px);
  --h3: 22px;

  --ls-tight: -0.058em;
  --ls-mid: -0.03em;
  --ls-wide: 0.14em;

  --ease: cubic-bezier(.2,.8,.2,1);
  --ease2: cubic-bezier(.14,.9,.16,1);

  --shadow: 0 18px 60px rgba(0,0,0,.08);
}

*{ box-sizing:border-box; }

html,body{ height:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
a{ color:inherit; }
button{ font:inherit; color:inherit; }

.wrap{ width: var(--wrap); margin:0 auto; }
.accent{ color: var(--accent); }

/* intro */
.intro{
 z-index : 9999;
 position:fixed;inset:0;
 background:#000;color:#fff;
 display:flex;flex-direction:column;
 justify-content:center;align-items:center;
 animation:fadeOut 0.9s ease 1.1s forwards;
}
.intro-line{
 font-size:12px;
 letter-spacing:.3em;
 margin:6px 0;
 animation:flicker .2s infinite;
 text-shadow:
 0 0 12px rgba(57,255,20,.25),
 0 0 48px rgba(57,255,20,.2),
 0 0 120px rgba(57,255,20,.15);
}
@keyframes flicker{
 0%{opacity:.2}50%{opacity:1}100%{opacity:.6}
}
@keyframes fadeOut{to{opacity:0;pointer-events:none}}


/* smoother transition into page */
.intro.is-off{
  opacity: 0;
}

/* page comes in gently after intro */
body.intro-running .wrap,
body.intro-running .top{
  opacity: 0;
  transform: translateY(6px);
}
body.intro-done .wrap,
body.intro-done .top{
  opacity: 1;
  transform: translateY(0);
}

/* ensure intro sits above everything cleanly */
.intro{ transform: translateZ(0); }

/* ===== Top bar ===== */
.top{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  padding: 22px 40px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  pointer-events:none;
}
.top > *{ pointer-events:auto; }

.top__right{
  display:flex;
  align-items:center;
  gap: 16px;
}

.brand{
  text-decoration:none;
  font-family:"Inter Tight","Inter",system-ui;
  font-weight:800;
  letter-spacing: var(--ls-mid);
}

.menuBtn{
  display:flex;
  align-items:center;
  gap:12px;
  background: transparent;
  border: 1px solid var(--hair);
  padding: 10px 14px;
  border-radius: 999px;
  cursor:pointer;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.menuBtn:hover{
  transform: translateY(-1px);
  background: rgba(15,15,16,.03);
  border-color: rgba(15,15,16,.20);
}
.menuBtn__text{ font-weight:700; }
.menuBtn__icon{
  width:16px; height:2px; background:var(--fg);
  position:relative;
}
.menuBtn__icon:before{
  content:""; position:absolute; left:0; top:-6px;
  width:16px; height:2px; background:var(--fg);
}

/* ===== Hero ===== */
.hero{ padding: 140px 0 40px; }
.hero__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 56px;
  align-items:end;
}
.h1{
  font-family:"Inter Tight","Inter",system-ui;
  font-size: var(--h1);
  line-height:.92;
  font-weight: 800;
  letter-spacing: var(--ls-tight);
  margin:0;
}
.h2{
  margin:0;
  font-family:"Inter Tight","Inter",system-ui;
  font-size: var(--h2);
  line-height: 1.03;
  font-weight: 750;
  letter-spacing: var(--ls-mid);
}
.h3{
  margin:0 0 10px;
  font-family:"Inter Tight","Inter",system-ui;
  letter-spacing: var(--ls-mid);
  font-size: var(--h3);
  font-weight: 750;
}
.lead{
  font-size: 16px;
  color: var(--muted);
  margin:0;
  max-width: 52ch;
}

.hero__copy{
  align-self:stretch;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:18px;
}

.ctaRow{ display:flex; gap: 12px; flex-wrap:wrap; }
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight: 750;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,15,16,.20);
  background: var(--fg);
  color: #fff;
  box-shadow: var(--shadow);
  transition: transform .25s var(--ease), filter .25s var(--ease);
}
.cta:hover{ transform: translateY(-1px); filter: brightness(1.05); }
.cta--ghost{
  background: transparent;
  color: var(--fg);
  box-shadow: none;
  border-color: rgba(15,15,16,.18);
}
.cta--ghost:hover{ background: rgba(15,15,16,.03); }

/* Poster / media button */
.hero__media{ justify-self:end; width: min(460px, 100%); }
.poster{
  width:100%;
  aspect-ratio: 4/3;
  border: 1px solid var(--hair);
  border-radius: var(--radius2);
  background:
    radial-gradient(1200px 600px at 20% 20%, rgba(15,15,16,.14), transparent 55%),
    radial-gradient(900px 500px at 80% 70%, rgba(15,15,16,.10), transparent 60%),
    linear-gradient(180deg, rgba(15,15,16,.06), rgba(15,15,16,.02));
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition: transform .45s var(--ease2), border-color .35s var(--ease);
}
.poster:hover{
  transform: translateY(-4px);
  border-color: rgba(15,15,16,.24);
}

/* Poster used as a static image (no video / no player) */
.poster--image{ cursor: default; }
.poster--image:hover{ transform: none; }
.poster--image:before{ display:none; }
.poster--image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.poster:before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(135deg, rgba(255,255,255,.18), transparent 55%),
    radial-gradient(800px 400px at 20% 10%, rgba(255,255,255,.35), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.poster__ui{
  position:absolute; inset:auto 18px 18px 18px;
  display:flex; align-items:center; justify-content:space-between;
  gap:14px;
}
.poster__badge{
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(15,15,16,.85);
  color:#fff;
  font-weight:800;
  letter-spacing: var(--ls-wide);
  font-size: 12px;
}
.poster__hint{
  color: rgba(255,255,255,.85);
  font-weight:650;
  font-size: 13px;
  mix-blend-mode: difference;
}

/* ===== Index chips ===== */
.index{ padding: 44px 0 24px; border-top: 1px solid var(--hair); }
.sectionHead{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 18px;
  padding-bottom: 14px;
}
.sub{ margin:0; color: var(--muted); font-weight: 600; }
.index__row{ display:flex; flex-wrap:wrap; gap: 12px; padding: 16px 0; }
.chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  border: 1px solid var(--hair);
  padding: 12px 14px;
  border-radius: 999px;
  font-weight: 700;
  background: #fff;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.chip:hover{
  transform: translateY(-1px);
  background: rgba(15,15,16,.03);
  border-color: rgba(15,15,16,.20);
}
.chip__tag{
  font-size: 12px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--muted);
}

/* ===== Slider ===== */
.sliderSection{ padding: 70px 0 40px; }
.sliderHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 22px;
}
.sliderCtrls{ display:flex; gap: 10px; }
.iconBtn{
  border: 1px solid var(--hair);
  background: #fff;
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.iconBtn:hover{ transform: translateY(-1px); background: rgba(15,15,16,.03); border-color: rgba(15,15,16,.22); }

.slider{
  position:relative;
  border-radius: var(--radius2);
  overflow:hidden;
  border: 1px solid var(--hair);
  background: #fff;
}
.slides{ position:relative; height: clamp(360px, 60vh, 620px); }
.slide{
  position:absolute; inset:0;
  opacity:0;
  transform: scale(1.01);
  transition: opacity .7s var(--ease), transform 1.0s var(--ease);
  display:grid;
  grid-template-rows: 1fr auto;
}
.slide.is-active{ opacity:1; transform: scale(1); }
.slide__media{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}
.slide__media img,
.slide__media video{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transform: scale(1.02);
}
.slide__mediaBtn{
  border:0;
  padding:0;
  background: transparent;
  cursor:pointer;
  text-align:left;
}
.slide__play{
  position:absolute;
  inset:auto 18px 18px auto;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(15,15,16,.85);
  color: #fff;
  font-weight:800;
  letter-spacing: var(--ls-wide);
  font-size: 12px;
}
.slide__cap{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
  padding: 16px 18px;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  border-top: 1px solid var(--hair);
}
/* 사용하지 않는 태그
.slide__title{ font-weight: 800; }*/
.slide__meta{ color: var(--muted); font-weight: 650; }


.dots{
  position:absolute;
  left: 18px;
  bottom: 18px;
  display:flex;
  gap:10px;
  z-index:2;
}
.dot{
  width: 9px; height: 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(15,15,16,.18);
  cursor:pointer;
}
.dot.is-active{ background: var(--accent); border-color: rgba(15,15,16,.0); }

/* ===== Lists (Agency / Originals) ===== */
.pageHero{ padding: 140px 0 22px; }
.pageHero__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:end;
  gap: 18px;
}
.list{ padding: 26px 0 70px; border-top: 1px solid var(--hair); }
.list__head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 18px;
  padding: 14px 0 18px;
}
.rows{ display:grid; }
.row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
  padding: 18px 0;
  text-decoration:none;
  border-top: 1px solid var(--hair);
  font-weight: 750;
}
.row:last-child{ border-bottom: 1px solid var(--hair); }
.row__right{ color: var(--muted); font-weight: 650; }
.row:hover .row__left{ color: var(--accent); }
.row:hover{ border-top-color: rgba(15,15,16,.20); }

/* ===== Project detail ===== */
.caseHero{ padding: 140px 0 24px; }
.caseHero__top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--hair);
}
.caseMeta .kicker{ margin-bottom: 10px; }
.caseTitle{
  font-family:"Inter Tight","Inter",system-ui;
  font-weight: 850;
  letter-spacing: var(--ls-mid);
  font-size: clamp(22px, 3vw, 44px);
}
.caseAside{
  display:flex;
  gap: 18px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.caseStat{
  border: 1px solid var(--hair);
  border-radius: 16px;
  padding: 10px 12px;
  background: rgba(15,15,16,.02);
  min-width: 150px;
}
.caseStat__k{
  font-size: 12px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 800;
}
.caseStat__v{ margin-top: 6px; font-weight: 750; }

.casePoster{
  width:100%;
  margin-top: 20px;
  aspect-ratio: 16/9;
  border-radius: var(--radius2);
  border: 1px solid var(--hair);
  background:
    radial-gradient(1200px 600px at 20% 20%, rgba(15,15,16,.18), transparent 55%),
    radial-gradient(900px 500px at 80% 70%, rgba(15,15,16,.12), transparent 60%),
    linear-gradient(180deg, rgba(15,15,16,.08), rgba(15,15,16,.02));
  overflow:hidden;
  cursor:pointer;
  position:relative;
  transition: transform .45s var(--ease2);
}
.casePoster:hover{ transform: translateY(-4px); }

/* Case poster used as a static image */
.casePoster--image{ cursor: default; }
.casePoster--image:hover{ transform:none; }
.casePoster--image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.casePoster__ui{
  position:absolute; inset:auto 18px 18px 18px;
  display:flex; align-items:center; justify-content:space-between;
  gap:14px;
}
.casePoster__hint{
  color: rgba(255,255,255,.86);
  font-weight:650;
  mix-blend-mode:difference;
}

.caseBody{ padding: 26px 0 80px; border-top: 1px solid var(--hair); }
.caseGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 56px;
  padding-top: 20px;
}
.p{ margin: 10px 0 0; color: rgba(15,15,16,.78); max-width: 72ch; }
.credits{ margin-top: 12px; display:grid; gap: 10px; }
.credit{
  display:flex; justify-content:space-between; gap: 16px;
  padding: 12px 14px;
  border: 1px solid var(--hair);
  border-radius: 14px;
  background: rgba(15,15,16,.02);
  font-weight: 650;
  color: rgba(15,15,16,.78);
}
.credit span:last-child{ color: var(--fg); font-weight: 750; }

.stills{
  margin-top: 34px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.still{
  margin:0;
  border: 1px solid var(--hair);
  border-radius: var(--radius2);
  overflow:hidden;
  background:#fff;
}
.still img{ width:100%; height: 360px; object-fit: cover; display:block; }
.still figcaption{
  padding: 12px 14px;
  border-top: 1px solid var(--hair);
  color: var(--muted);
  font-weight: 650;
}
.next{
  margin-top: 26px;
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
}

/* ===== Footer ===== */
.footer{
  padding: 70px 0 90px;
  border-top: 1px solid var(--hair);
}
.footer--tight{ padding: 60px 0 70px; }
.footer__row{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.footer__big{
  font-family:"Inter Tight","Inter",system-ui;
  font-size: clamp(22px, 3vw, 44px);
  font-weight: 850;
  letter-spacing: var(--ls-mid);
  text-decoration:none;
}
.footer__small{
  margin-top: 12px;
  color: var(--muted);
  font-weight: 650;
}

/* ===== Overlay menu ===== */
.menu{
  position: fixed;
  inset: 0;
  z-index: 80;
  display:none;
}
.menu.is-open{ display:block; }
.menu__bg{
  position:absolute; inset:0;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
}
.menu__inner{
  position:relative;
  height:100%;
  padding: 28px 40px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.menu__marquee{
  overflow:hidden;
  border-bottom: 1px solid var(--hair);
  padding-bottom: 16px;
}
.menu__marqueeTrack{
  display:flex;
  gap: 18px;
  font-family:"Inter Tight","Inter",system-ui;
  font-weight: 900;
  letter-spacing: var(--ls-tight);
  font-size: clamp(28px, 4vw, 56px);
  white-space: nowrap;
  animation: marquee 14s linear infinite;
}
@keyframes marquee{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-50%); }
}

.menu__nav{
  display:flex;
  gap: 22px;
  margin-top: 26px;
  flex-wrap:wrap;
}
.menu__nav a{
  text-decoration:none;
  font-family:"Inter Tight","Inter",system-ui;
  font-weight: 900;
  letter-spacing: var(--ls-mid);
  font-size: clamp(22px, 2.4vw, 34px);
}
.menu__meta{
  margin-top: 34px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.kicker{
  color: var(--muted);
  font-weight: 850;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-size: 12px;
  margin-bottom: 10px;
}
.metaLink{ text-decoration:none; font-weight: 750; }
.metaRow{ display:flex; gap: 14px; flex-wrap:wrap; }

.menu__close{
  align-self:flex-end;
  border: 1px solid var(--hair);
  background: #fff;
  padding: 10px 14px;
  border-radius: 999px;
  cursor:pointer;
}

/* ===== Fullscreen player ===== */
.player{
  position: fixed;
  inset: 0;
  z-index: 90;
  display:none;
}
.player.is-open{ display:block; }
.player__backdrop{
  position:absolute; inset:0;
  background: rgba(15,15,16,.82);
}
.player__panel{
  position:absolute;
  inset: 22px;
  border-radius: var(--radius2);
  overflow:hidden;
  background: #000;
  border: 1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  box-shadow: 0 40px 120px rgba(0,0,0,.35);
}
.player__bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(0,0,0,.55);
  color: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.player__title{
  font-weight: 850;
  letter-spacing: var(--ls-mid);
  font-family:"Inter Tight","Inter",system-ui;
}
.player__actions{ display:flex; gap: 10px; }
.player__btn{
  border: 1px solid rgba(255,255,255,.18);
  background: transparent;
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 750;
}
.player__video, .player__frame{
  width:100%;
  height: 100%;
  border:0;
  display:none;
  background:#000;
}

/* ===== Reveal animations ===== */
.reveal{
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}
.border-underline {
  margin-bottom: -200px;
  border-bottom: 60px solid rgba(57,255,20,.45);
}

/* ===== Cursor (upgraded) ===== */
.cursor{
  position: fixed;
  left:0; top:0;
  width: 0; height: 0;
  pointer-events:none;
  z-index: 100;
  mix-blend-mode: difference;
  transform: translate3d(0,0,0);
}
.cursor__dot{
  position:absolute;
  width: 6px; height:6px;
  border-radius: 999px;
  background: #fff;
  transform: translate(-50%,-50%);
}
.cursor__ring{position:absolute;width:46px;height:46px;border-radius:999px;border:1px solid rgba(255,255,255,.9);transform:translate(-50%,-50%);opacity:.9;}
.cursor__label{
  position:absolute;
  transform: translate(10px, 10px);
  color:#fff;
  font-size: 11px;
  letter-spacing: .18em;
  font-weight: 900;
  opacity: .92;
  text-transform: uppercase;
  transition: opacity .18s var(--ease);
}

body.cursor--down .cursor__ring{ width: 34px; height:34px; opacity: 1; }
body.cursor--hide .cursor{ display:none; }

/* Hover states driven by JS adding body classes */
body.cursor--hover .cursor__ring{ width:46px; height:46px; opacity:.9; }
body.cursor--hover .cursor__ring{ width:46px; height:46px; opacity:.9; }

body.cursor--play .cursor__ring{ width:46px; height:46px; }
body.cursor--drag .cursor__ring{ width:46px; height:46px; }
body.cursor--drag .cursor__ring{ width:46px; height:46px; }

/* ===== Responsive ===== */
@media (max-width: 980px){
  :root{ --wrap: min(1180px, calc(100vw - 40px)); }
  .top{ padding: 18px 20px; }
  .hero__grid{ grid-template-columns: 1fr; gap: 26px; }
  .hero__media{ justify-self: start; width: min(520px, 100%); }
  .pageHero__grid{ grid-template-columns: 1fr; }
  .caseHero__top{ flex-direction:column; align-items:flex-start; }
  .caseAside{ justify-content:flex-start; }
  .caseGrid{ grid-template-columns: 1fr; gap: 22px; }
  .stills{ grid-template-columns: 1fr; }
  .player__panel{ inset: 12px; border-radius: 18px; }
  .menu__inner{ padding: 20px; }
}

@media (hover: none){
  .cursor{ display:none; }
}



/* --- Accent expansion --- */
::selection{ background: var(--accent2); }

a:focus-visible,
button:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 10px;
}

.toplink:hover{
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
}

.menuBtn:hover{
  border-color: color-mix(in srgb, var(--accent) 55%, rgba(15,15,16,.20));
}

.chip__tag{ color: color-mix(in srgb, var(--accent) 55%, var(--muted)); }

.chip:hover{
  border-color: color-mix(in srgb, var(--accent) 55%, rgba(15,15,16,.20));
}

.iconBtn:hover{
  border-color: color-mix(in srgb, var(--accent) 55%, rgba(15,15,16,.22));
}

.row:hover{
  border-top-color: color-mix(in srgb, var(--accent) 38%, rgba(15,15,16,.20));
}

.poster__badge,
.slide__play{
  background: color-mix(in srgb, var(--accent) 70%, rgba(15,15,16,.85));
}

.dot.is-active{
  background: var(--accent);
}

.footer__big:hover{
  color: var(--accent);
}

/* subtle accent hairlines in key section heads */
.sliderHead,
.list__head,
.sectionHead,
.caseHero__top{
  border-bottom-color: color-mix(in srgb, var(--accent) 18%, var(--hair));
}

/* accent pills optional */
.pill{
  border-color: color-mix(in srgb, var(--accent) 22%, var(--hair));
}



/* --- Neon glitch tone --- */
.intro.is-glitch .intro__line{
  text-shadow:
    0 0 6px rgba(57,255,20,.45),
    0 0 18px rgba(57,255,20,.25);
}

.poster__badge,
.slide__play{
  box-shadow:
    0 0 0 1px rgba(57,255,20,.9),
    0 0 12px rgba(57,255,20,.6),
    inset 0 0 12px rgba(57,255,20,.25);
}

a:hover,
.row:hover .row__left{
  text-shadow: 0 0 8px rgba(57,255,20,.45);
}


/* --- Landing keyword line --- */
.pillRow--single{
  display:flex;
  gap:18px;
  flex-wrap:nowrap;
  font-size:14px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.pillRow--single .pill{
  background:none;
  border:none;
  padding:0;
  font-weight:800;
  color:#000;
}


/* Neon text highlight (soft fluorescent wash) */
.neonHL{
  position: relative;
  padding: 0 .14em;
  border-radius: .22em;
  background: rgba(0,255,170,.16);
  box-shadow: 0 0 0 1px rgba(0,255,170,.10) inset, 0 0 22px rgba(0,255,170,.12);
}

/* Resume layout */
.resume{ padding-top: 64px; padding-bottom: 80px; }
.resumeHero{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap: 28px;
  align-items:start;
  margin: 18px 0 40px;
}
.resumeName{
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 6px 0 10px;
}
.resumeTitle{
  font-weight: 600;
  opacity: .86;
  margin: 0 0 14px;
}
.resumeSummary{
  line-height: 1.65;
  max-width: 62ch;
  opacity: .9;
}
.resumeCard{
  border: 1px solid rgba(15,15,16,.14);
  background: rgba(255,255,255,.65);
  border-radius: 18px;
  padding: 18px 18px;
  backdrop-filter: blur(10px);
}
.resumeCard__row{
  display:flex;
  justify-content: space-between;
  gap: 14px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(15,15,16,.08);
}
.resumeCard__row:last-child{ border-bottom: 0; }
.resumeCard__k{ font-size: 12px; opacity: .65; text-transform: uppercase; letter-spacing: .08em; }
.resumeCard__v{ font-size: 14px; }
.resumeCard a.link{ text-decoration: underline; text-underline-offset: 3px; }

.resumeSection{ margin: 36px 0; }
.resumeH2{
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .10em;
  opacity: .78;
  margin: 0 0 14px;
}
.resumeH2--mt{ margin-top: 22px; }
.resumeText{ line-height: 1.65; max-width: 70ch; opacity: .9; }

.resumeItem{
  padding: 16px 0 18px;
  border-top: 1px solid rgba(15,15,16,.10);
}
.resumeItem:first-of-type{ border-top: 0; }
.resumeItem__head{
  display:flex;
  justify-content: space-between;
  gap: 16px;
  align-items: baseline;
}
.resumeItem__role{ font-weight: 700; letter-spacing: -0.01em; }
.resumeItem__meta{ font-size: 13px; opacity: .68; white-space: nowrap; }
.resumeItem__org{ margin: 6px 0 10px; opacity: .8; }
.resumeList{
  margin: 0;
  padding-left: 18px;
  line-height: 1.7;
}
.resumeList li{ margin: 6px 0; }

.resumeGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.resumeTile{
  border: 1px solid rgba(15,15,16,.14);
  border-radius: 16px;
  padding: 14px 14px;
  background: rgba(255,255,255,.5);
  transition: transform .18s ease, border-color .18s ease;
}
.resumeTile:hover{ transform: translateY(-3px); border-color: rgba(15,15,16,.24); }
.resumeTile__t{ font-weight: 700; }
.resumeTile__s{ margin-top: 6px; font-size: 13px; opacity: .72; line-height: 1.4; }

.resumeSection--split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items:start;
}
.tagCloud{ display:flex; flex-wrap: wrap; gap: 8px; }
.tag{
  font-size: 12px;
  padding: 8px 10px;
  border: 1px solid rgba(15,15,16,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  opacity: .92;
}

/* Responsive */
@media (max-width: 900px){
  .resumeHero{ grid-template-columns: 1fr; }
  .resumeSection--split{ grid-template-columns: 1fr; }
  .resumeGrid{ grid-template-columns: 1fr; }
  .resumeItem__meta{ white-space: normal; }
}

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; }
  .reveal{ transition: none !important; }
  .resumeTile{ transition: none !important; }
}
