/* ─────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:Inter,system-ui,sans-serif;
  background:#faf9f7;color:#1a1816;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;font-size:15px;line-height:1.6;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;background:none;border:none;padding:0}

/* ── Custom pencil cursor ── */
*{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24'%3E%3Cpath d='M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25z' fill='%23d44a2a'/%3E%3Cpath d='M20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z' fill='%231a1816'/%3E%3C/svg%3E") 4 28, crosshair!important}

/* ─────────────────────────────────────────
   TOKENS
───────────────────────────────────────── */
:root{
  --red:    #d44a2a;
  --red2:   #b83820;
  --redl:   #f9ecea;
  --dark:   #17150f;
  --ink:    #1a1816;
  --ink2:   #4a4540;
  --mute:   #9a9490;
  --rule:   #e8e4dc;
  --bg:     #faf9f7;
  --bg2:    #f3f0ea;
  --mono:   'Syne Mono', monospace;
  --serif:  'DM Serif Display', serif;
  --script: 'Sacramento', cursive;
}

/* ─────────────────────────────────────────
   ANNOUNCE BAR
───────────────────────────────────────── */
.bar{
  background:var(--red);
  text-align:center;padding:8px 20px;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.8);
}
.bar strong{color:#fff;font-weight:600}

/* ─────────────────────────────────────────
   NAV
───────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:300;
  height:56px;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(250,249,247,.95);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--rule);
  transition:box-shadow .2s;
}
.nav.shadow{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.nav-logo{
  display:flex;flex-direction:column;gap:3px;line-height:1;text-decoration:none;
}
.nav-logo-name{
  font-family:'Cinzel',serif;font-weight:400;font-size:14px;
  letter-spacing:.3em;text-transform:uppercase;
  background:linear-gradient(135deg,#8a4e2c 0%,#c4825a 30%,#e8b48a 55%,#d4956a 75%,#a06040 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-logo-sub{
  font-family:'Cinzel',serif;font-weight:300;font-size:7.5px;
  letter-spacing:.5em;text-transform:uppercase;
  background:linear-gradient(135deg,#8a4e2c 0%,#c4825a 40%,#e8b48a 70%,#a06040 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--mute);padding:7px 14px;transition:color .15s;
}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;background:var(--red);padding:8px 18px;
  transition:background .15s;
}
.nav-cta:hover{background:var(--red2)}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.hero{
  min-height:100vh;position:relative;
  display:flex;flex-direction:column;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;background:#0e0b09;overflow:hidden}
.orb{position:absolute;border-radius:50%;pointer-events:none}
.orb1{width:75vw;height:75vw;top:-20%;right:-14%;opacity:.52;
  background:radial-gradient(circle at 38% 38%,#9a1a08,#5a0a04 48%,transparent 70%);
  filter:blur(88px);animation:o1 15s ease-in-out infinite}
.orb2{width:50vw;height:50vw;bottom:-10%;left:6%;opacity:.28;
  background:radial-gradient(circle at 50% 50%,#c83828,#801810 52%,transparent 72%);
  filter:blur(78px);animation:o2 19s ease-in-out infinite}
.orb3{width:28vw;height:28vw;top:30%;left:30%;opacity:.16;
  background:radial-gradient(circle at 50% 50%,#e85030,#a02010 55%,transparent 74%);
  filter:blur(58px);animation:o3 12s ease-in-out infinite}
@keyframes o1{0%,100%{transform:translate(0,0) scale(1)}35%{transform:translate(-3%,5%) scale(1.06)}70%{transform:translate(4%,-3%) scale(.95)}}
@keyframes o2{0%,100%{transform:translate(0,0)}50%{transform:translate(5%,-6%)}}
@keyframes o3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5%,4%) scale(1.1)}}
.hero-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.055) 1px, transparent 1px);
  background-size:50px 50px;
}
.hero-grain{
  position:absolute;inset:0;opacity:.4;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.07'/%3E%3C/svg%3E");
}
.hero-art{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.hero-inner{
  position:relative;z-index:2;
  flex:1;display:flex;flex-direction:column;justify-content:flex-end;
  padding:120px 56px 88px;
}
.hero-eyebrow{
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.22);margin-bottom:20px;display:block;
}
.hero-name-wrap{position:relative;display:block;margin-bottom:18px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.juven-svg{
  display:block;
  width:clamp(300px,52vw,740px);
  height:auto;
  overflow:visible;
  filter:drop-shadow(0 0 28px rgba(212,74,42,.52)) drop-shadow(0 0 10px rgba(255,220,180,.22));
}
.js-stroke{stroke-dasharray:9999;stroke-dashoffset:9999}
.hero-desc{
  font-size:16px;color:rgba(255,255,255,.4);
  font-style:italic;line-height:1.7;
  max-width:460px;margin-bottom:36px;
}
.hero-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:40px}
.hero-pill{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.1);
  padding:5px 12px;transition:all .2s;
}
.hero-pill:hover{color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.3)}
.ai-pill{color:rgba(212,149,106,.6);border-color:rgba(212,149,106,.25)}
.ai-pill:hover{color:rgba(232,180,138,.9);border-color:rgba(232,180,138,.5)}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn-red{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  background:var(--red);color:#fff;padding:13px 28px;font-weight:600;
  transition:background .15s;display:inline-block;
}
.btn-red:hover{background:var(--red2)}
.btn-ghost{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  background:transparent;color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.16);padding:13px 28px;
  transition:all .2s;display:inline-block;
}
.btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,.45)}
.hero-badge{
  position:absolute;top:76px;right:44px;z-index:2;
  font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.35);border:1px solid rgba(255,255,255,.14);
  padding:7px 16px;transition:all .2s;
}
.hero-badge:hover{color:var(--red);border-color:var(--red)}
.hero-scroll{
  position:absolute;bottom:36px;right:44px;z-index:2;
  writing-mode:vertical-rl;
  font-family:var(--mono);font-size:8px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.15);
  display:flex;align-items:center;gap:10px;
}
.scroll-ln{width:1px;height:48px;background:rgba(255,255,255,.1);position:relative;overflow:hidden}
.scroll-ln::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;
  background:rgba(255,255,255,.35);animation:slnMove 2s ease-in-out infinite}
@keyframes slnMove{0%{top:-100%}100%{top:100%}}
.pa-drift {animation:paDrift 22s ease-in-out infinite}
.pa-drift-r{animation:paDrift 28s ease-in-out infinite 8s reverse}
@keyframes paDrift{
  0%,100%{opacity:1}
  45%{opacity:.7}
  80%{opacity:.92}
}

/* ─────────────────────────────────────────
   SECTION ATOMS
───────────────────────────────────────── */
.s-eyebrow{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);margin-bottom:12px;display:block;
}
.s-title{
  font-family:var(--serif);font-size:clamp(32px,4vw,52px);
  font-style:italic;line-height:1.05;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:0;
}
.s-title strong{font-style:normal;font-weight:400}
.text-link{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  border-bottom:1.5px solid currentColor;padding-bottom:1px;
  display:inline-flex;align-items:center;gap:5px;
  transition:opacity .15s;
}
.text-link:hover{opacity:.5}

/* ─────────────────────────────────────────
   WORK SECTION
───────────────────────────────────────── */
#work{padding:80px 40px;background:var(--bg)}
.work-top{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--rule);
  flex-wrap:wrap;gap:16px;
}
.work-count{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute)}
.filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:36px}
.filt{
  font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid var(--rule);color:var(--mute);padding:6px 16px;
  transition:all .15s;cursor:pointer;background:none;
}
.filt.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.filt:hover:not(.on){border-color:var(--ink);color:var(--ink)}
.work-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;grid-auto-flow:row dense;
}
.wc{
  display:block;background:transparent;
  text-decoration:none;color:inherit;cursor:pointer;
}
.wc[data-h]{display:none}
.wc-img{
  width:100%;aspect-ratio:3/2;overflow:hidden;position:relative;
  background:var(--bg2);
}
.wc-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.6);
  transition:opacity .3s, filter .4s;
}
.wc:hover .wc-img img{filter:saturate(1)}
.wc-img video{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity .35s;
  pointer-events:none;
}
.wc-img video.playing{opacity:1}
.wc-over{
  position:absolute;inset:0;
  background:rgba(14,11,9,.18);
  opacity:0;transition:opacity .25s;
}
.wc:hover .wc-over{opacity:1}
.wc-label{padding:9px 0 2px}
.wc-cat{
  font-family:var(--mono);font-size:7.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mute);display:block;margin-bottom:3px;
}
.wc-name{
  font-size:12.5px;font-weight:600;color:var(--ink);letter-spacing:-.01em;
  display:block;line-height:1.3;
}

/* ─────────────────────────────────────────
   FYP FEATURE BLOCK
───────────────────────────────────────── */
#fyp{
  display:grid;grid-template-columns:280px 1fr;
  height:280px;
  border-top:1px solid var(--rule);
}
.fyp-visual{
  position:relative;overflow:hidden;
  background:var(--dark);
  border-right:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:center;
}
.fyp-visual img{
  width:100%;height:100%;object-fit:contain;
  filter:saturate(.8) contrast(1.05);
  transition:transform .9s cubic-bezier(.4,0,.2,1);
}
#fyp:hover .fyp-visual img{transform:scale(1.04)}
.fyp-stamp{
  position:absolute;bottom:24px;left:24px;
  font-family:var(--script);font-size:28px;color:var(--red);
  letter-spacing:.02em;line-height:1;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.fyp-content{
  background:var(--dark);color:#fff;
  padding:20px 36px;
  display:flex;flex-direction:column;justify-content:center;
}
.fyp-eyebrow{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);margin-bottom:8px;
  display:flex;align-items:center;gap:12px;
}
.fyp-eyebrow::after{content:'';width:32px;height:1px;background:var(--red);opacity:.5}
.fyp-title{
  font-family:var(--serif);
  font-size:clamp(24px,3vw,40px);
  font-style:italic;line-height:.95;
  letter-spacing:-.02em;margin-bottom:8px;
}
.fyp-sub{
  font-family:var(--mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.2);margin-bottom:10px;
}
.fyp-desc{
  font-size:12.5px;color:rgba(255,255,255,.4);line-height:1.7;
  max-width:400px;margin-bottom:14px;font-style:italic;
}
.fyp-meta{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid rgba(255,255,255,.06);
  margin-bottom:14px;gap:0;
}
.fyp-row{padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.fyp-row:nth-child(odd){padding-right:20px;border-right:1px solid rgba(255,255,255,.05)}
.fyp-row:nth-child(even){padding-left:20px}
.fyp-label{font-family:var(--mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:3px}
.fyp-val{font-size:13px;color:rgba(255,255,255,.5)}
.btn-outline-w{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.45);
  padding:12px 24px;display:inline-block;transition:all .2s;width:fit-content;
}
.btn-outline-w:hover{background:var(--red);border-color:var(--red);color:#fff}

/* ─────────────────────────────────────────
   ABOUT
───────────────────────────────────────── */
#about{
  display:grid;grid-template-columns:400px 1fr;
  min-height:70vh;border-top:1px solid var(--rule);
}
.about-l{
  padding:0;
  background:var(--bg2);border-right:1px solid var(--rule);
  overflow:hidden;
}
.about-portrait{
  width:100%;height:100%;overflow:hidden;
  background:var(--rule);
}
.about-portrait img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.7) contrast(1.08)}
.about-r{
  padding:72px 56px;display:flex;flex-direction:column;justify-content:center;
}
.about-eyebrow{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.about-name{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(36px,4vw,56px);
  line-height:.95;letter-spacing:-.01em;margin-bottom:6px;
}
.about-name span{display:block;font-style:normal;color:var(--mute);letter-spacing:.04em;font-family:var(--mono);text-transform:uppercase;font-size:9.5px;margin-top:8px;margin-bottom:0}
.about-role{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-bottom:32px;margin-top:12px}
.about-body{font-size:14.5px;color:var(--ink2);line-height:1.88;margin-bottom:12px}
.about-body em{font-style:italic;color:var(--red)}
.about-tags{display:flex;flex-wrap:wrap;gap:4px;margin:24px 0 32px}
.tag{
  font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--rule);color:var(--mute);padding:5px 10px;
  transition:all .15s;
}
.tag:hover{border-color:var(--ink);color:var(--ink)}
.skills-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:32px}
.skill{
  font-family:var(--mono);font-size:8px;letter-spacing:.08em;text-transform:uppercase;
  background:var(--redl);color:var(--red);padding:5px 10px;
}
.ai-skill{background:#1a1410;color:#c4825a;border:1px solid rgba(196,130,90,.25)}
.about-links{display:flex;gap:0;flex-wrap:wrap;border-top:1px solid var(--rule)}
.alink{
  font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mute);padding:12px 16px 12px 0;margin-right:14px;
  border-bottom:1.5px solid transparent;transition:color .15s,border-color .15s;
}
.alink:hover{color:var(--red);border-bottom-color:var(--red)}

/* ─────────────────────────────────────────
   CONTACT
───────────────────────────────────────── */
#contact{
  background:var(--dark);color:#fff;
  display:grid;grid-template-columns:1fr 1fr;
  border-top:3px solid var(--red);
}
.contact-l{
  padding:80px 52px;
  border-right:1px solid rgba(255,255,255,.05);
  display:flex;flex-direction:column;justify-content:space-between;
}
.contact-eyebrow{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:20px}
.contact-heading{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(40px,5.5vw,68px);
  line-height:.92;letter-spacing:-.02em;color:#fff;
}
.contact-script{
  font-family:var(--script);font-size:clamp(44px,5.5vw,70px);
  color:rgba(255,255,255,.18);display:block;margin-top:4px;line-height:1;
}
.contact-note{font-size:13.5px;color:rgba(255,255,255,.28);line-height:1.82;margin-top:24px;max-width:300px}
.contact-details{margin-top:48px}
.cd{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.cd dt{font-family:var(--mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.18);margin-bottom:4px}
.cd dd a{font-size:13px;color:rgba(255,255,255,.35);transition:color .15s}
.cd dd a:hover{color:var(--red)}
.cd dd a.icon-link{display:inline-flex;align-items:center;color:rgba(255,255,255,.35);transition:color .15s}
.cd dd a.icon-link:hover{color:#0a66c2}
.cd dd a.icon-link svg{width:22px;height:22px;fill:currentColor}
.contact-r{padding:80px 52px}
.cf-label{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:8px;display:block}
.cf-field{margin-bottom:28px}
.cf-field input,.cf-field select,.cf-field textarea{
  font-family:Inter,sans-serif;font-size:14px;background:transparent;border:none;
  border-bottom:1px solid rgba(255,255,255,.1);color:#fff;
  padding:9px 0;width:100%;outline:none;transition:border-color .2s;letter-spacing:-.01em;
}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-bottom-color:var(--red)}
.cf-field input::placeholder,.cf-field textarea::placeholder{color:rgba(255,255,255,.12)}
.cf-field select{cursor:pointer}.cf-field select option{background:var(--dark)}
.cf-field textarea{resize:none}
.cf-row2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cf-submit{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  background:var(--red);color:#fff;padding:13px 32px;
  transition:background .15s;font-weight:600;margin-top:8px;
}
.cf-submit:hover{background:var(--red2)}
.cf-ok{display:none;font-family:var(--script);font-size:40px;color:rgba(255,255,255,.3);padding:48px 0}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer{
  background:var(--dark);border-top:1px solid rgba(255,255,255,.05);
  padding:40px 44px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
}
.f-brand{display:flex;flex-direction:column;gap:3px;line-height:1}
.f-brand .nav-logo-name{font-size:30px}
.f-brand .nav-logo-sub{font-size:7.5px}
.f-copy{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.15)}
.f-links{display:flex;gap:20px}
.f-links a{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.2);transition:color .15s}
.f-links a:hover{color:rgba(255,255,255,.6)}

/* ─────────────────────────────────────────
   MODAL
───────────────────────────────────────── */
.mbg{
  position:fixed;inset:0;z-index:600;
  background:rgba(10,8,6,.92);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;pointer-events:none;transition:opacity .22s;
}
.mbg.open{opacity:1;pointer-events:all}
.md{
  background:var(--bg);max-width:680px;width:100%;
  max-height:92vh;overflow-y:auto;
  padding:40px;position:relative;
  transform:translateY(18px);transition:transform .28s cubic-bezier(.4,0,.2,1);
}
.mbg.open .md{transform:none}
.mx{
  position:absolute;top:14px;right:14px;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--mute);
  border:1px solid var(--rule);
  transition:all .15s;cursor:pointer;
  background:var(--bg);
  line-height:1;
}
.mx:hover{color:#fff;background:var(--red);border-color:var(--red)}
.m-cat{font-family:var(--mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.m-title{font-family:var(--serif);font-style:italic;font-size:30px;letter-spacing:-.01em;margin-bottom:16px}
.m-video{
  width:100%;aspect-ratio:16/9;background:#0e0b09;overflow:hidden;margin-bottom:18px;
}
.m-video video{width:100%;height:100%;object-fit:contain;display:block;background:#0e0b09}
.m-desc{font-size:14px;color:var(--ink2);line-height:1.8}

/* ─────────────────────────────────────────
   REVEAL ANIMATIONS
───────────────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* ─────────────────────────────────────────
   RESPONSIVE — TABLET (≤1024px)
───────────────────────────────────────── */
@media(max-width:1024px){
  .nav{padding:0 24px}
  .nav-logo-name{font-size:13px}
  .nav-links a{font-size:9px;padding:7px 10px}
  .hero-inner{padding:80px 36px 60px}
  .hero-eyebrow{font-size:10px}
  .hero-desc{font-size:16px}
  .hero-badge{top:68px;right:24px}
  .hero-scroll{right:24px}
  #work{padding:60px 24px}
  .work-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  #fyp{grid-template-columns:200px 1fr;height:250px}
  .fyp-content{padding:20px 28px}
  .fyp-title{font-size:clamp(20px,2.8vw,34px)}
  .fyp-desc{display:none}
  #about{grid-template-columns:280px 1fr}
  .about-r{padding:52px 36px}
  .contact-l,.contact-r{padding:56px 36px}
  .cf-row2{grid-template-columns:1fr}
}

/* ─────────────────────────────────────────
   RESPONSIVE — MOBILE (≤768px)
───────────────────────────────────────── */
@media(max-width:768px){
  .nav{padding:0 20px;height:56px}
  .nav-links{display:none}
  .nav-logo-name{font-size:13px;letter-spacing:.22em}
  .nav-logo-sub{font-size:6.5px}
  .nav-cta{padding:7px 14px;font-size:9px}
  .bar{font-size:10px;letter-spacing:.08em;padding:8px 16px}
  .hero-inner{padding:60px 24px 52px}
  .hero-badge{display:none}
  .hero-scroll{display:none}
  .hero-eyebrow{font-size:10px;letter-spacing:.13em}
  .juven-svg{width:clamp(220px,80vw,420px)}
  .hero-desc{font-size:15px;max-width:100%;margin-bottom:24px}
  .hero-tags{margin-bottom:28px;gap:6px}
  .hero-pill{font-size:9.5px;padding:5px 11px}
  .hero-btns{flex-direction:column;gap:10px;align-items:flex-start}
  .btn-red,.btn-ghost{font-size:10px;padding:13px 28px}
  #fyp{grid-template-columns:1fr;height:auto}
  .fyp-visual{height:200px;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .fyp-content{padding:28px 24px}
  .fyp-meta{display:none}
  .fyp-desc{display:none}
  .fyp-title{font-size:clamp(22px,6vw,34px)}
  .fyp-eyebrow{font-size:9px}
  .btn-outline-w{font-size:9px;padding:10px 20px}
  #work{padding:48px 16px}
  .work-top{margin-bottom:20px;padding-bottom:14px;flex-direction:column;align-items:flex-start;gap:8px}
  .work-count{display:none}
  .s-title{font-size:clamp(26px,6vw,40px)}
  .work-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .wc-name{font-size:12px}
  .wc-cat{font-size:7.5px}
  .wc-label{padding:8px 0 2px}
  .filters{gap:4px;margin-bottom:24px}
  .filt{padding:6px 12px;font-size:9.5px}
  #about{grid-template-columns:1fr;min-height:auto}
  .about-l{border-right:none;border-bottom:1px solid var(--rule)}
  .about-portrait{height:300px;width:100%}
  .about-r{padding:36px 24px}
  .about-eyebrow{font-size:9px}
  .about-name{font-size:clamp(30px,8vw,44px)}
  .about-role{font-size:8.5px;margin-bottom:20px}
  .about-body{font-size:14px}
  .about-tags{margin:16px 0 20px}
  .skills-row{margin-bottom:20px}
  .tag,.skill{font-size:8px}
  #contact{grid-template-columns:1fr}
  .contact-l{border-right:none;border-bottom:1px solid rgba(255,255,255,.06);padding:44px 24px 32px}
  .contact-r{padding:32px 24px 44px}
  .contact-eyebrow{font-size:10px}
  .contact-note{font-size:14px;max-width:100%}
  .cf-row2{grid-template-columns:1fr}
  .contact-details{margin-top:24px}
  .cd dt{font-size:9px}
  .cd dd a{font-size:13px}
  .cf-label{font-size:10px}
  .cf-field input,.cf-field select,.cf-field textarea{font-size:16px}
  .cf-submit{font-size:11px;padding:13px 28px}
  footer{padding:28px 20px;flex-direction:column;align-items:flex-start;gap:12px}
  .f-links{gap:14px}
  .f-brand .nav-logo-name{font-size:24px}
  .f-copy{font-size:10px}
  .f-links a{font-size:10px}
  .mbg{padding:12px}
  .md{padding:24px 20px;max-width:100%}
  .m-title{font-size:22px}
  .m-desc{font-size:13px}
  .bc{width:92vw;aspect-ratio:1.55/1;padding:5% 7% 4%}
  .bc-jq{width:min(110px,24vw)}
  .bc-name{font-size:clamp(11px,3.8vw,18px)}
  .bc-sub{font-size:clamp(7px,2vw,10px)}
  .bc-bot{font-size:clamp(7px,2vw,9px);gap:10px;flex-wrap:wrap;justify-content:center}
}

/* ─────────────────────────────────────────
   RESPONSIVE — SMALL MOBILE (≤480px)
───────────────────────────────────────── */
@media(max-width:480px){
  .hero-inner{padding:48px 18px 44px}
  .hero-eyebrow{font-size:9px}
  .hero-desc{font-size:14px}
  .juven-svg{width:clamp(200px,85vw,320px)}
  .hero-pill{font-size:9px;padding:5px 10px}
  .work-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .wc-name{font-size:11px}
  .filt{padding:5px 10px;font-size:9px}
  .bar{font-size:10px;padding:7px 12px}
  .about-portrait{height:260px}
  .contact-heading{font-size:clamp(32px,9vw,52px)}
  .contact-script{font-size:clamp(36px,9vw,54px)}
  .f-brand .nav-logo-name{font-size:22px}
  .bc{aspect-ratio:1.35/1;padding:5% 6% 4%}
  .bc-jq{width:min(90px,23vw)}
  .bc-name{font-size:clamp(10px,4.5vw,15px)}
  .bc-sub{font-size:clamp(6.5px,2.2vw,9px)}
  .bc-bot{flex-direction:column;align-items:center;gap:6px}
  .bc-sep{display:none}
  .bc-ci{font-size:clamp(6px,2.5vw,8.5px)}
}
