/* ===========================================================
   HARLEY WARD — PORTFOLIO
   Bold & color-forward. Design system + components.
   =========================================================== */

:root{
  --ink:#08080f; --ink-2:#0d0d1a; --ink-3:#13132300; --panel:#10101e;
  --paper:#f4f1e9; --paper-ink:#13131f;
  --blue:#2b4ff0; --blue-bright:#3d5aff;
  --magenta:#ff2d8e; --pink:#ff5da2;
  --violet:#7a3df5; --gold:#ffc24b; --cyan:#16d0ff; --orange:#ff7a1a;
  --text:#f3f1ea; --muted:#9c9cb6; --faint:#6a6a82;
  --line:rgba(255,255,255,.12); --line-2:rgba(255,255,255,.07);
  --accent:#3d5aff;                     /* overridden per-project */
  --maxw:1340px;
  --f-display:'Anton',Impact,sans-serif;
  --f-head:'Space Grotesk',sans-serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);color:var(--text);font-family:var(--f-body);
  line-height:1.6;overflow-x:hidden;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--magenta);color:#fff}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}

/* ---------- scroll progress + nav ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--magenta),var(--violet),var(--blue),var(--cyan));}
nav.site{position:fixed;top:0;left:0;right:0;z-index:110;display:flex;align-items:center;
  justify-content:space-between;padding:18px clamp(18px,4vw,46px);transition:.4s var(--ease);}
nav.site.scrolled{background:rgba(8,8,15,.78);backdrop-filter:blur(16px);
  padding-top:12px;padding-bottom:12px;border-bottom:1px solid var(--line-2);}
.brand{font-family:var(--f-display);font-size:22px;letter-spacing:.06em;line-height:1;display:flex;align-items:center;gap:10px;text-transform:uppercase}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--magenta);
  box-shadow:0 0 0 4px rgba(255,45,142,.25);animation:pulse 2.6s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 9px rgba(255,45,142,0)}}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-family:var(--f-head);font-size:13px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);position:relative;padding:4px 0;transition:.25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--accent);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{padding:10px 18px;border:1.5px solid var(--text);border-radius:40px;color:var(--text)!important;
  font-size:12px!important;transition:.25s}
.nav-cta:hover{background:var(--text);color:var(--ink)!important}
.nav-cta::after{display:none}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:6px}
.burger span{width:26px;height:2px;background:var(--text);transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:120px clamp(18px,5vw,70px) 60px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg video{width:100%;height:100%;object-fit:cover;opacity:.30;filter:saturate(1.2)}
.hero-bg .mesh{position:absolute;inset:-20%;z-index:1;opacity:.8;mix-blend-mode:screen;
  background:
    radial-gradient(40% 50% at 18% 28%,rgba(255,45,142,.55),transparent 60%),
    radial-gradient(45% 55% at 82% 22%,rgba(61,90,255,.55),transparent 60%),
    radial-gradient(50% 50% at 70% 82%,rgba(122,61,245,.5),transparent 60%),
    radial-gradient(40% 45% at 25% 85%,rgba(22,208,255,.32),transparent 60%);
  animation:mesh 18s ease-in-out infinite alternate}
@keyframes mesh{50%{transform:translate3d(3%,2%,0) scale(1.08)}100%{transform:translate3d(-3%,-2%,0) scale(1.04)}}
.hero-bg .scrim{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(8,8,15,.55),rgba(8,8,15,.35) 40%,var(--ink) 96%)}
.hero-bg .grain{position:absolute;inset:0;z-index:3;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-inner{position:relative;z-index:5;max-width:var(--maxw);margin:0 auto;width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-head);font-weight:600;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--text);
  padding:8px 16px;border:1px solid var(--line);border-radius:40px;background:rgba(255,255,255,.04);margin-bottom:26px}
.eyebrow b{color:var(--gold);font-weight:700}
h1.hero-title{font-family:var(--f-display);font-weight:400;line-height:.92;letter-spacing:.005em;
  font-size:clamp(46px,9vw,148px);text-transform:uppercase;margin-bottom:8px}
h1.hero-title .swap{color:var(--magenta);transition:color .5s}
.hero-sub{font-family:var(--f-head);font-size:clamp(17px,2.1vw,25px);font-weight:400;color:#d9d8e6;
  max-width:760px;margin:22px 0 36px;line-height:1.45}
.hero-sub b{color:#fff;font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{font-family:var(--f-head);font-weight:600;font-size:15px;letter-spacing:.01em;cursor:pointer;
  border:0;border-radius:44px;padding:16px 28px;display:inline-flex;align-items:center;gap:11px;transition:.28s var(--ease)}
.btn-primary{background:var(--text);color:var(--ink)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(255,255,255,.18)}
.btn-ghost{background:rgba(255,255,255,.05);border:1.5px solid var(--line);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
.btn .play{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--magenta);color:#fff;font-size:11px}
.hero-stats{display:flex;flex-wrap:wrap;gap:34px;margin-top:54px;padding-top:30px;border-top:1px solid var(--line-2)}
.hero-stats .st b{font-family:var(--f-display);font-size:clamp(28px,3.6vw,46px);line-height:1;display:block;
  background:linear-gradient(120deg,#fff,#b9b8d0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-stats .st span{font-family:var(--f-head);font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:5;
  font-family:var(--f-head);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);
  display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint .line{width:1px;height:34px;background:linear-gradient(var(--faint),transparent);animation:drop 2s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- awards marquee ---------- */
.awards{padding:30px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  background:linear-gradient(180deg,#0b0b16,#08080f);overflow:hidden;position:relative}
.marquee{display:flex;gap:0;width:max-content;animation:slide 40s linear infinite}
.awards:hover .marquee{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.aw{display:flex;align-items:center;gap:16px;padding:0 38px;border-right:1px solid var(--line-2);white-space:nowrap}
.aw .trophy{font-size:22px;filter:saturate(1.4)}
.aw b{font-family:var(--f-display);font-size:21px;letter-spacing:.03em;text-transform:uppercase;color:var(--awc,#fff)}
.aw span{display:block;font-size:12px;color:var(--muted)}
.aw em{font-style:normal;font-family:var(--f-head);font-size:12px;color:var(--faint)}

/* ---------- section frame ---------- */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,9vw,130px) clamp(18px,5vw,46px)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:46px;flex-wrap:wrap}
.sec-kicker{font-family:var(--f-head);font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:16px}
.sec-kicker::before{content:"";width:34px;height:2px;background:var(--accent)}
h2.sec-title{font-family:var(--f-display);font-weight:400;text-transform:uppercase;line-height:.95;
  font-size:clamp(34px,5.4vw,74px);letter-spacing:.01em}
.sec-note{color:var(--muted);max-width:440px;font-size:15.5px}

/* ---------- work / filters ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:38px;position:sticky;top:64px;z-index:40;
  padding:14px;background:rgba(8,8,15,.7);backdrop-filter:blur(12px);border:1px solid var(--line-2);border-radius:18px}
.filter{font-family:var(--f-head);font-weight:600;font-size:13.5px;letter-spacing:.02em;cursor:pointer;
  border:1px solid var(--line);background:transparent;color:var(--muted);padding:10px 18px;border-radius:40px;
  transition:.22s;display:inline-flex;align-items:center;gap:8px}
.filter .ct{font-size:11px;opacity:.7;font-variant-numeric:tabular-nums}
.filter:hover{color:var(--text);border-color:var(--text)}
.filter.active{background:var(--text);color:var(--ink);border-color:var(--text)}
.filter.award.active{background:linear-gradient(120deg,var(--gold),var(--orange));border:0;color:#1a1206}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.4vw,20px)}
.card{grid-column:span 4;position:relative;border-radius:18px;overflow:hidden;cursor:pointer;
  aspect-ratio:4/5;background:#15151f;border:1px solid var(--line-2);
  transition:transform .5s var(--ease),opacity .4s,box-shadow .4s;will-change:transform}
.card.feat{grid-column:span 6;aspect-ratio:16/11}
.card.wide{grid-column:span 8;aspect-ratio:16/9}
.card.hide{display:none}
.card.enter{animation:cardin .55s var(--ease) both}
@keyframes cardin{from{opacity:0;transform:translateY(26px) scale(.98)}}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .5s;filter:saturate(1.02)}
.card:hover{transform:translateY(-7px);box-shadow:0 26px 60px rgba(0,0,0,.6),0 0 0 1px var(--accent)}
.card:hover img{transform:scale(1.07)}
.card .veil{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(8,8,15,.05) 30%,rgba(8,8,15,.5) 64%,rgba(8,8,15,.95));transition:.4s}
.card:hover .veil{background:linear-gradient(180deg,rgba(8,8,15,.15) 10%,rgba(8,8,15,.55) 50%,rgba(8,8,15,.97))}
.card .accent-bar{position:absolute;left:0;top:0;height:5px;width:0;z-index:4;background:var(--accent);transition:width .5s var(--ease)}
.card:hover .accent-bar{width:100%}
.card .meta{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:20px 22px}
.card .ip{font-family:var(--f-head);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.card h3{font-family:var(--f-display);font-weight:400;text-transform:uppercase;line-height:.96;
  font-size:clamp(19px,2vw,30px);letter-spacing:.01em;margin-bottom:10px}
.card .tags{display:flex;flex-wrap:wrap;gap:6px;opacity:0;max-height:0;transition:.4s;overflow:hidden}
.card:hover .tags{opacity:1;max-height:60px}
.tag{font-family:var(--f-head);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:#dcdcea;
  border:1px solid var(--line);border-radius:30px;padding:4px 10px;background:rgba(255,255,255,.05)}
.badge{position:absolute;top:14px;right:14px;z-index:4;display:flex;align-items:center;gap:7px;
  font-family:var(--f-head);font-weight:700;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;
  padding:7px 13px;border-radius:30px;background:rgba(8,8,15,.6);backdrop-filter:blur(8px);border:1px solid var(--line);color:#fff}
.badge .star{color:var(--gold)}
.card .openhint{position:absolute;top:14px;left:14px;z-index:4;width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;background:rgba(8,8,15,.55);border:1px solid var(--line);opacity:0;transform:scale(.6);transition:.35s}
.card:hover .openhint{opacity:1;transform:scale(1)}
.has-video .openhint{background:var(--accent);border-color:transparent}

/* ---------- case study modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:none}
.modal.open{display:block}
.modal-scrim{position:absolute;inset:0;background:rgba(4,4,9,.9);backdrop-filter:blur(6px);animation:fade .3s}
@keyframes fade{from{opacity:0}}
.modal-panel{position:absolute;inset:0;overflow-y:auto;animation:rise .45s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(30px)}}
.cs{max-width:1140px;margin:0 auto;padding:0 clamp(16px,4vw,40px) 80px}
.cs-top{position:sticky;top:0;z-index:6;display:flex;justify-content:space-between;align-items:center;
  padding:16px 0;background:linear-gradient(180deg,var(--ink),rgba(8,8,15,.85),transparent)}
.cs-close{background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;border-radius:40px;
  padding:10px 18px;font-family:var(--f-head);font-weight:600;font-size:13px;cursor:pointer;transition:.25s;display:flex;gap:8px;align-items:center}
.cs-close:hover{background:#fff;color:var(--ink)}
.cs-nav{display:flex;gap:8px}
.cs-nav button{background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:16px;transition:.25s}
.cs-nav button:hover{background:var(--accent);border-color:transparent}
.cs-hero{position:relative;border-radius:20px;overflow:hidden;margin-top:6px;aspect-ratio:16/9;background:#15151f;border:1px solid var(--line-2)}
.cs-hero img,.cs-hero video{width:100%;height:100%;object-fit:cover}
.cs-hero .ph{position:absolute;left:0;bottom:0;right:0;padding:30px;z-index:3;
  background:linear-gradient(180deg,transparent,rgba(8,8,15,.92))}
.cs-hero .accent-line{position:absolute;top:0;left:0;height:6px;width:100%;background:var(--accent);z-index:4}
.cs-ip{font-family:var(--f-head);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#e7e7f2;margin-bottom:10px}
.cs h2.cs-title{font-family:var(--f-display);font-weight:400;text-transform:uppercase;line-height:.94;
  font-size:clamp(30px,5vw,62px);letter-spacing:.01em}
.cs-meta{display:flex;flex-wrap:wrap;gap:10px 26px;margin:22px 0 8px;padding-bottom:24px;border-bottom:1px solid var(--line-2)}
.cs-meta div{font-size:13.5px}
.cs-meta .k{font-family:var(--f-head);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:3px}
.cs-meta .v{color:#ece9e0}
.cs-award{display:inline-flex;align-items:center;gap:10px;margin:22px 0;padding:12px 20px;border-radius:14px;
  background:linear-gradient(120deg,rgba(255,194,75,.16),rgba(255,122,26,.08));border:1px solid rgba(255,194,75,.4)}
.cs-award .t{font-family:var(--f-display);font-size:18px;text-transform:uppercase;color:var(--gold);letter-spacing:.03em}
.cs-award .d{font-size:13px;color:#d9d3c4}
.cs-body{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;margin-top:34px}
@media(max-width:780px){.cs-body{grid-template-columns:1fr;gap:26px}}
.cs-story h4{font-family:var(--f-head);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin:26px 0 10px}
.cs-story h4:first-child{margin-top:0}
.cs-story p{color:#cfcfdd;font-size:16px;line-height:1.72}
.cs-side .metrics{display:grid;gap:12px;margin-bottom:26px}
.metric{padding:18px 20px;border-radius:14px;background:rgba(255,255,255,.035);border:1px solid var(--line-2);border-left:3px solid var(--accent)}
.metric b{font-family:var(--f-display);font-size:26px;letter-spacing:.02em;display:block;color:#fff;line-height:1}
.metric span{font-family:var(--f-head);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.cs-press{margin-top:6px}
.cs-press .lbl{font-family:var(--f-head);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.cs-press a{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;border:1px solid var(--line-2);
  margin-bottom:8px;font-size:13.5px;color:#dcdce8;transition:.25s;background:rgba(255,255,255,.02)}
.cs-press a:hover{border-color:var(--accent);background:rgba(255,255,255,.05);transform:translateX(4px)}
.cs-press a .arr{margin-left:auto;color:var(--accent)}
.cs-gallery-h{font-family:var(--f-head);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin:46px 0 16px}
.cs-gallery{columns:3;column-gap:14px}
@media(max-width:780px){.cs-gallery{columns:2}}
.cs-gallery figure{break-inside:avoid;margin:0 0 14px;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;background:#15151f;border:1px solid var(--line-2)}
.cs-gallery img{width:100%;transition:transform .6s var(--ease),filter .4s;filter:saturate(1.02)}
.cs-gallery figure:hover img{transform:scale(1.06)}
.cs-gallery figure::after{content:"⤢";position:absolute;top:10px;right:12px;color:#fff;opacity:0;transition:.3s;font-size:15px;text-shadow:0 2px 8px #000}
.cs-gallery figure:hover::after{opacity:1}

/* ---------- case-study clip strip ---------- */
.cs-clips{display:flex;gap:12px;margin:20px 0 4px;flex-wrap:wrap}
.cs-clip{position:relative;width:210px;height:120px;border-radius:12px;overflow:hidden;cursor:pointer;border:1px solid var(--line-2);background-size:cover;background-position:center;color:#fff;flex:0 0 auto;transition:.25s}
.cs-clip:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.5)}
.cs-clip .cp{position:absolute;inset:0;margin:auto;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--accent);font-size:13px;transition:.25s}
.cs-clip:hover .cp{transform:scale(1.14)}
.cs-clip em{position:absolute;left:0;right:0;bottom:0;padding:18px 10px 8px;font-style:normal;font-family:var(--f-head);font-size:12px;font-weight:600;letter-spacing:.02em;background:linear-gradient(transparent,rgba(8,8,15,.92));text-align:left}

/* ---------- lightbox ---------- */
.lbx{position:fixed;inset:0;z-index:300;display:none;background:rgba(3,3,7,.96);backdrop-filter:blur(4px)}
.lbx.open{display:grid;place-items:center}
.lbx-stage{max-width:92vw;max-height:84vh;position:relative;animation:fade .25s}
.lbx-stage img,.lbx-stage video{max-width:92vw;max-height:84vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lbx-cap{position:absolute;bottom:-34px;left:0;right:0;text-align:center;font-family:var(--f-head);font-size:13px;color:var(--muted)}
.lbx button{position:fixed;background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;cursor:pointer;transition:.25s}
.lbx button:hover{background:var(--accent);border-color:transparent}
.lbx .x{top:22px;right:22px;width:48px;height:48px;border-radius:50%;font-size:18px}
.lbx .pv,.lbx .nx{top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;font-size:22px;display:grid;place-items:center}
.lbx .pv{left:18px}.lbx .nx{right:18px}
.lbx .ct{position:fixed;top:30px;left:28px;font-family:var(--f-head);font-size:13px;letter-spacing:.1em;color:var(--muted);background:none;border:0}

/* ---------- platform / my toibox ---------- */
.platform{background:
  radial-gradient(60% 80% at 80% 10%,rgba(122,61,245,.18),transparent 60%),
  radial-gradient(50% 60% at 10% 90%,rgba(43,79,240,.16),transparent 60%),#0a0a14}
.mtb{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
@media(max-width:880px){.mtb{grid-template-columns:1fr;gap:34px}}
.mtb .lead{font-family:var(--f-display);text-transform:uppercase;line-height:.96;font-size:clamp(30px,4.4vw,58px);margin:14px 0 18px}
.mtb .lead .g{background:linear-gradient(110deg,var(--violet),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.mtb p{color:#cdccdd;font-size:16.5px;margin-bottom:18px;max-width:560px}
.mtb-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mtb-card{padding:22px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line-2);transition:.3s}
.mtb-card:hover{transform:translateY(-5px);border-color:var(--violet)}
.mtb-card b{font-family:var(--f-display);font-size:34px;display:block;line-height:1;
  background:linear-gradient(120deg,#fff,#b9b8d0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.mtb-card span{font-family:var(--f-head);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.mtb-card.full{grid-column:1/-1;display:flex;align-items:center;gap:14px}
.mtb-card.full b{font-size:20px;-webkit-text-fill-color:#fff;background:none}

/* ---------- about ---------- */
.about{background:linear-gradient(180deg,#08080f,#0b0b16)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:30px}}
.about-lead{font-family:var(--f-head);font-size:clamp(20px,2.4vw,30px);font-weight:500;line-height:1.42;color:#eceaf3}
.about-lead b{color:#fff}
.about-lead .hl{background:linear-gradient(120deg,var(--magenta),var(--violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}
.about p.body{color:#c2c1d2;font-size:15.5px;margin-top:18px}
.timeline{border-left:2px solid var(--line);padding-left:26px;margin-top:8px}
.tl{position:relative;padding:0 0 26px}
.tl::before{content:"";position:absolute;left:-33px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(61,90,255,.18)}
.tl .yr{font-family:var(--f-head);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.tl b{font-family:var(--f-head);font-size:17px;display:block;margin:3px 0;color:#fff}
.tl span{color:var(--muted);font-size:14px}
.skills{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
.skill{font-family:var(--f-head);font-size:12.5px;letter-spacing:.03em;color:#dcdce8;
  border:1px solid var(--line);border-radius:30px;padding:8px 15px;background:rgba(255,255,255,.03)}

/* ---------- contact ---------- */
.contact{background:radial-gradient(70% 90% at 50% 0%,rgba(255,45,142,.12),transparent 60%),#08080f;text-align:center}
.contact h2{font-family:var(--f-display);text-transform:uppercase;line-height:.95;font-size:clamp(40px,8vw,108px);margin-bottom:10px}
.contact .sub{color:var(--muted);font-size:18px;max-width:560px;margin:0 auto 40px}
.contact-links{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.clink{display:flex;align-items:center;gap:11px;padding:16px 24px;border-radius:44px;border:1px solid var(--line);
  font-family:var(--f-head);font-weight:600;font-size:15px;transition:.28s var(--ease);background:rgba(255,255,255,.03)}
.clink:hover{transform:translateY(-4px);border-color:var(--text);background:rgba(255,255,255,.08)}
.clink.solid{background:var(--text);color:var(--ink);border-color:var(--text)}
.clink.solid:hover{box-shadow:0 14px 40px rgba(255,255,255,.18)}

footer.site{border-top:1px solid var(--line-2);padding:34px clamp(18px,5vw,46px);
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
footer .brand{font-size:18px}
footer small{color:var(--faint);font-size:12.5px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,330px);flex-direction:column;justify-content:center;
    gap:26px;background:rgba(8,8,15,.97);backdrop-filter:blur(20px);transform:translateX(100%);transition:.4s var(--ease);padding:40px;border-left:1px solid var(--line)}
  .nav-links.show{transform:none}
  .nav-links a{font-size:18px}
  .burger{display:flex;z-index:130}
  .burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:760px){
  .card,.card.feat,.card.wide{grid-column:span 6;aspect-ratio:4/5}
  .grid{gap:12px}
  .filterbar{top:58px}
  .hero-stats{gap:22px}
  .cs-gallery{columns:2}
}
@media(max-width:480px){
  .card,.card.feat,.card.wide{grid-column:span 12;aspect-ratio:16/12}
  .nav-cta{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.1ms!important}
  .hero-bg .mesh,.marquee{animation:none}
}
