/* ============================================================= *
 *  MEHAK JAIN — portfolio                                        *
 *  Design language: editorial · lilac · grain · motion          *
 *  Palette + type live in :root — tweak there to rebrand.       *
 * ============================================================= */

:root{
  /* --- lilac system --- */
  --paper:      #F3EEF8;   /* pale warm-lilac canvas */
  --paper-2:    #EAE0F3;   /* slightly deeper panel  */
  --ink:        #1B121F;   /* near-black plum (text) */
  --ink-soft:   #6A5874;   /* muted plum             */
  --lilac:      #B79CE0;   /* primary lilac          */
  --lilac-600:  #9C7AD6;   /* saturated lilac        */
  --lilac-200:  #E0D2F2;   /* tint                   */
  --plum:       #3A1F4E;   /* deep plum (dark bg)    */
  --plum-900:   #1F1029;   /* darkest plum           */
  --acid:       #D6E84F;   /* unexpected acid accent */
  --line:       rgba(27,18,31,.14);
  --line-light: rgba(243,238,248,.18);

  /* --- type --- */
  --serif: "Fraunces", Georgia, serif;
  --sans:  "Space Grotesk", system-ui, sans-serif;
  --mono:  "Space Mono", ui-monospace, monospace;

  /* --- rhythm --- */
  --pad: clamp(1.25rem, 5vw, 6rem);
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ============================ RESET ============================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
em{ font-style:italic; }
sup{ font-size:.5em; vertical-align:super; }
::selection{ background:var(--acid); color:var(--ink); }

/* Hide native cursor on capable pointers (custom cursor takes over) */
@media (hover:hover) and (pointer:fine){
  .js body{ cursor:none; }
  .js a, .js button{ cursor:none; }
}

/* ====================== TEXTURE / OVERLAYS ====================== */
.grain{
  position:fixed; inset:-50%; z-index:9000; pointer-events:none;
  opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)}
  40%{transform:translate(3%,-5%)} 60%{transform:translate(-2%,4%)}
  80%{transform:translate(5%,2%)} 100%{transform:translate(0,0)}
}
/* soft moving lilac aura behind everything */
.aura{
  position:fixed; z-index:-1; width:60vw; height:60vw; top:-10vw; right:-10vw;
  background:radial-gradient(circle at 50% 50%, rgba(156,122,214,.45), transparent 60%);
  filter:blur(40px); pointer-events:none;
  transition:transform .6s var(--ease);
}

.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:2px; z-index:8000; pointer-events:none;
}
.scroll-progress span{
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg,var(--lilac-600),var(--acid));
  transform-origin:left;
}

/* ====================== CUSTOM CURSOR ====================== */
.cursor{ position:fixed; top:0; left:0; z-index:9500; pointer-events:none;
  mix-blend-mode:difference; display:none; }
@media (hover:hover) and (pointer:fine){ .js .cursor{ display:block; } }
.cursor__ring{
  position:absolute; width:42px; height:42px; border:1px solid #fff; border-radius:50%;
  transform:translate(-50%,-50%); transition:width .3s var(--ease), height .3s var(--ease), opacity .3s;
}
.cursor__dot{
  position:absolute; width:6px; height:6px; background:#fff; border-radius:50%;
  transform:translate(-50%,-50%);
}
.cursor__label{
  position:absolute; transform:translate(-50%,-50%);
  font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink); opacity:0; white-space:nowrap;
}
.cursor.is-hover .cursor__ring{ width:64px; height:64px; }
.cursor.is-view .cursor__ring{
  width:88px; height:88px; background:var(--acid); border-color:var(--acid); mix-blend-mode:normal;
}
.cursor.is-view{ mix-blend-mode:normal; }
.cursor.is-view .cursor__dot{ opacity:0; }
.cursor.is-view .cursor__label{ opacity:1; }

/* ====================== PRELOADER ====================== */
.loader{
  position:fixed; inset:0; z-index:9700; background:var(--plum-900); color:var(--paper);
  display:flex; flex-direction:column; justify-content:flex-end; padding:var(--pad);
}
.loader__inner{
  display:flex; justify-content:space-between; align-items:flex-end; gap:1rem;
  border-bottom:1px solid var(--line-light); padding-bottom:1.2rem;
}
.loader__name{ font-family:var(--serif); font-size:clamp(1.4rem,4vw,2.4rem); font-weight:300; }
.loader__count{ font-family:var(--mono); font-size:clamp(3rem,18vw,12rem); line-height:.8; color:var(--lilac); }
.loader__bar{ height:2px; background:var(--line-light); margin-top:1.2rem; }
.loader__bar span{ display:block; height:100%; width:0%; background:var(--acid); }
.loader.is-done{ transform:translateY(-100%); transition:transform 1s var(--ease); }

/* ====================== NAV ====================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:7000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--pad);
  mix-blend-mode:difference; color:#fff;
}
.nav__logo{ display:flex; align-items:center; gap:.5rem; font-weight:600; }
.nav__logo-mark{ font-size:1.1rem; color:var(--lilac); animation:spin 14s linear infinite; display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.nav__logo-text{ font-family:var(--serif); font-size:1.05rem; letter-spacing:.01em; }
.nav__logo-text sup{ font-family:var(--mono); }
.nav__menu{ display:flex; gap:1.6rem; font-size:.82rem; }
.nav__menu a{ position:relative; overflow:hidden; }
.nav__menu a span{ display:inline-block; transition:transform .4s var(--ease); }
.nav__menu a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease);
}
.nav__menu a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav__meta{ display:flex; align-items:center; gap:1.2rem; }
.btn-pill{
  border:1px solid currentColor; border-radius:100px; padding:.45rem 1rem; font-size:.78rem;
  overflow:hidden; position:relative;
}
.btn-pill span{ position:relative; z-index:1; }
.btn-pill::before{
  content:""; position:absolute; inset:0; background:var(--acid); transform:translateY(101%);
  transition:transform .4s var(--ease);
}
.btn-pill:hover{ color:var(--ink); }
.btn-pill:hover::before{ transform:translateY(0); }

/* ====================== SHARED BITS ====================== */
.eyebrow{ font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.12em;
  color:var(--ink-soft); display:flex; align-items:center; gap:.5rem; }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--acid);
  box-shadow:0 0 0 4px rgba(214,232,79,.25); }
.eyebrow--right{ justify-content:flex-end; text-align:right; }
.status{ display:inline-flex; align-items:center; gap:.4rem; color:var(--lilac-600); }
.status i{ width:7px; height:7px; border-radius:50%; background:var(--lilac-600);
  animation:pulse 1.8s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{opacity:.4; transform:scale(.8)} 50%{opacity:1; transform:scale(1.3)} }

.section-label{ font-family:var(--mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.16em;
  display:flex; gap:1rem; color:var(--ink-soft); margin-bottom:2.5rem; }
.section-label span:first-child{ color:var(--lilac-600); }
.section-label--light{ color:rgba(243,238,248,.6); }
.section-label--light span:first-child{ color:var(--acid); }

/* reveal-from-bottom default (only when JS on) */
.js [data-reveal]{ opacity:0; transform:translateY(40px); }

/* ====================== HERO ====================== */
.hero{ min-height:100svh; display:flex; flex-direction:column; justify-content:space-between;
  padding:6.5rem var(--pad) 2.5rem; position:relative; overflow:hidden; }
/* interactive dot-field (injected by JS) sits behind the type */
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0;
  pointer-events:none; }
.hero__top, .hero__head, .hero__bottom{ position:relative; z-index:1; }
.hero__top{ display:flex; justify-content:space-between; gap:1rem; }
.hero__head{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(2.6rem, 9.5vw, 11rem); line-height:.96; letter-spacing:-.02em;
  margin:auto 0; padding:2rem 0;
}
/* padding+negative-margin gives descenders (g, y, p) room inside the
   overflow:hidden reveal mask without loosening the visual leading */
.hero__head .line{ display:block; overflow:hidden; padding-bottom:.14em; margin-bottom:-.14em; }
.hero__head .line__in{ display:block; }
.hero__head em{ color:var(--lilac-600); font-variation-settings:"opsz" 144; }
.hero__bottom{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; }
.hero__lede{ max-width:46ch; font-size:clamp(.95rem,1.4vw,1.15rem); color:var(--ink); }
.hero__lede strong{ font-weight:500; color:var(--lilac-600); }
.hero__scroll{ display:flex; flex-direction:column; align-items:center; gap:.7rem; flex-shrink:0; }
.hero__scroll-line{ width:1px; height:54px; background:var(--ink); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; inset:0; background:var(--acid);
  animation:scrolldrop 1.8s var(--ease) infinite; }
@keyframes scrolldrop{ 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(100%)} }
.hero__scroll-txt{ font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--ink-soft); writing-mode:vertical-rl; }

/* ====================== TAPE / MARQUEE ====================== */
.tape{ border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:1.1rem 0; overflow:hidden; }
.tape__track{ display:flex; align-items:center; gap:2.5rem; white-space:nowrap; width:max-content;
  font-family:var(--serif); font-size:clamp(1.4rem,3vw,2.6rem); font-weight:300; will-change:transform; }
.tape__track span{ display:inline-block; }
.tape__star{ color:var(--lilac-600); font-size:.6em; }
.tape--dark{ background:transparent; border-color:var(--line-light); margin-top:5rem; }
.tape--dark .tape__track{ font-family:var(--mono); font-size:clamp(.9rem,1.6vw,1.2rem);
  text-transform:uppercase; letter-spacing:.08em; color:rgba(243,238,248,.7); }
.tape--dark .tape__star{ color:var(--acid); }

/* ====================== ABOUT ====================== */
.about{ padding:7rem var(--pad); }
.about__statement{
  font-family:var(--serif); font-weight:300; letter-spacing:-.01em;
  font-size:clamp(1.6rem,4.4vw,3.6rem); line-height:1.15; max-width:18ch; margin:0 auto;
  text-align:left;
}
.about__statement .w{ color:var(--lilac-200); transition:color .1s linear; }
.about__statement .w.on{ color:var(--ink); }
.about__statement em{ color:var(--lilac-600); }
.about__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:5rem;
  border-top:1px solid var(--line); padding-top:2.5rem; }
.about__cell .num{ font-family:var(--serif); font-size:clamp(2.6rem,6vw,4.6rem); font-weight:300;
  line-height:1; display:block; }
.about__cell .num i{ color:var(--lilac-600); font-style:normal; }
.about__cell p{ font-family:var(--mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.08em;
  color:var(--ink-soft); margin-top:.6rem; }

/* ====================== WORK ====================== */
.work{ padding:4rem var(--pad) 7rem; position:relative; }
.work__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem;
  margin-bottom:3rem; flex-wrap:wrap; }
.work__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.4rem,7vw,6rem);
  line-height:.95; letter-spacing:-.02em; }
.work__title em{ color:var(--lilac-600); }

.projects{ border-top:1px solid var(--line); }
.project{ border-bottom:1px solid var(--line); }
.project__row{ display:grid; grid-template-columns:auto 1.4fr 2fr auto; align-items:center; gap:1.5rem;
  padding:1.7rem .4rem; position:relative; transition:padding .45s var(--ease); }
.project__idx{ font-family:var(--mono); font-size:.78rem; color:var(--ink-soft); }
.project__name{ font-family:var(--serif); font-size:clamp(1.6rem,4vw,3rem); font-weight:300;
  transition:transform .45s var(--ease), color .45s var(--ease); }
.project__cat{ font-size:.85rem; color:var(--ink-soft); }
.project__year{ font-family:var(--mono); font-size:.82rem; color:var(--ink-soft); }
/* hover: row breathes, name slides + colors, acid wash sweeps in */
.project__row::before{
  content:""; position:absolute; inset:0; background:var(--lilac-200); transform:scaleY(0);
  transform-origin:bottom; transition:transform .45s var(--ease); z-index:-1;
}
.project:hover .project__row{ padding-left:1.6rem; padding-right:1.6rem; }
.project:hover .project__row::before{ transform:scaleY(1); }
.project:hover .project__name{ color:var(--lilac-600); transform:translateX(8px); }

/* floating cursor-follow preview */
.preview{ position:fixed; top:0; left:0; width:300px; height:380px; z-index:6000; pointer-events:none;
  opacity:0; transform:translate(-50%,-50%) scale(.9); transition:opacity .35s var(--ease), transform .35s var(--ease);
  border-radius:6px; overflow:hidden; }
.preview.is-on{ opacity:1; }
.preview__media{ position:absolute; inset:0; opacity:0; transition:opacity .3s; }
.preview__media.is-active{ opacity:1; }
.preview__media::after{ content:attr(data-p); display:none; }
/* generated gradient "covers" so there are zero broken images */
.preview__media[data-p="p1"]{
  background-image: url('../img/docuchat_preview.png');
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}
.preview__media[data-p="p2"]{
  background-image: url('../img/maisonbleu_preview.png');
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}
.preview__media[data-p="p3"]{
  background-image: url('../img/ateliernoir_preview.png');
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}
.preview__media[data-p="p4"]{
  background-image: url('../img/nore_preview.png');
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}
.preview__media::before{
  content:""; position:absolute; inset:0; opacity:.25; mix-blend-mode:overlay;
  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='.8'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ====================== SKILLS (dark) ====================== */
.skills{ background:var(--plum-900); color:var(--paper); padding:7rem var(--pad); position:relative;
  border-radius:36px 36px 0 0; }
.skills::before{ /* subtle top glow */
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:60%; height:200px; background:radial-gradient(ellipse at top, rgba(156,122,214,.4), transparent 70%);
  pointer-events:none;
}
.skills__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.4rem,7vw,6rem);
  line-height:.95; letter-spacing:-.02em; margin-bottom:3.5rem; }
.skills__title em{ color:var(--lilac); }
.skills__cols{ display:grid; grid-template-columns:1fr auto 1fr; gap:clamp(2rem,6vw,6rem); }
.skills__col-head{ display:flex; align-items:baseline; gap:1rem; margin-bottom:2rem; }
.skills__num{ font-family:var(--mono); font-size:.9rem; color:var(--acid);
  border:1px solid var(--line-light); border-radius:50%; width:2.4rem; height:2.4rem;
  display:grid; place-items:center; flex-shrink:0; }
.skills__col-head h3{ font-family:var(--serif); font-weight:300; font-size:clamp(1.6rem,3.4vw,2.6rem);
  line-height:1; }
.skills__list li{ display:flex; gap:1rem; align-items:baseline; padding:1rem 0;
  border-top:1px solid var(--line-light); font-size:clamp(.95rem,1.4vw,1.15rem); }
.skills__list li span{ font-family:var(--mono); font-size:.74rem; color:var(--lilac); }
.skills__list li{ transition:color .3s, transform .3s var(--ease); }
.skills__list li:hover{ color:var(--acid); transform:translateX(6px); }
.skills__divider span{ display:block; width:1px; height:100%; background:var(--line-light); }

/* ====================== AI WIDGET (dark continues) ====================== */
.ai{ background:var(--plum-900); color:var(--paper); padding:2rem var(--pad) 7rem; }
.ai__wrap{ max-width:760px; margin:0 auto; border:1px solid var(--line-light); border-radius:18px;
  background:rgba(255,255,255,.03); backdrop-filter:blur(6px); overflow:hidden; }
.ai__head{ display:flex; align-items:center; gap:.8rem; padding:.9rem 1.2rem;
  border-bottom:1px solid var(--line-light); }
.ai__dots{ display:flex; gap:.4rem; }
.ai__dots i{ width:10px; height:10px; border-radius:50%; background:var(--line-light); }
.ai__dots i:first-child{ background:var(--lilac-600); }
.ai__dots i:nth-child(2){ background:var(--lilac); }
.ai__dots i:nth-child(3){ background:var(--acid); }
.ai__title{ font-family:var(--mono); font-size:.76rem; color:rgba(243,238,248,.6); letter-spacing:.04em; }
.ai__log{ padding:1.4rem; display:flex; flex-direction:column; gap:1.1rem; min-height:170px;
  max-height:340px; overflow-y:auto; }
.ai__msg{ display:flex; flex-direction:column; gap:.3rem; max-width:85%; }
.ai__msg--bot{ align-self:flex-start; }
.ai__msg--user{ align-self:flex-end; align-items:flex-end; }
.ai__role{ font-family:var(--mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--lilac); }
.ai__msg--user .ai__role{ color:var(--acid); }
.ai__msg p{ font-size:.98rem; line-height:1.55; padding:.7rem 1rem; border-radius:14px;
  background:rgba(255,255,255,.05); border:1px solid var(--line-light); }
.ai__msg--user p{ background:var(--lilac-600); border-color:transparent; color:#fff; }
.ai__caret{ display:inline-block; width:.5ch; background:var(--acid); animation:blink 1s steps(1) infinite;
  margin-left:1px; }
@keyframes blink{ 50%{opacity:0} }
.ai__chips{ display:flex; flex-wrap:wrap; gap:.6rem; padding:0 1.4rem 1rem; }
.ai__chips button{ font-family:var(--mono); font-size:.74rem; padding:.5rem .8rem;
  border:1px solid var(--line-light); border-radius:100px; color:rgba(243,238,248,.8);
  transition:background .3s,color .3s,border-color .3s; }
.ai__chips button:hover{ background:var(--acid); color:var(--ink); border-color:var(--acid); }
.ai__form{ display:flex; gap:.6rem; padding:1.1rem 1.4rem; border-top:1px solid var(--line-light); }
.ai__form input{ flex:1; background:rgba(255,255,255,.04); border:1px solid var(--line-light);
  border-radius:100px; padding:.7rem 1.1rem; color:var(--paper); font-family:var(--sans); font-size:.95rem;
  outline:none; transition:border-color .3s; }
.ai__form input:focus{ border-color:var(--lilac); }
.ai__form input::placeholder{ color:rgba(243,238,248,.4); }
.ai__form button{ width:2.9rem; height:2.9rem; border-radius:50%; background:var(--lilac-600); color:#fff;
  font-size:1.1rem; display:grid; place-items:center; transition:background .3s, transform .3s; flex-shrink:0; }
.ai__form button:hover{ background:var(--acid); color:var(--ink); }

/* ====================== CONTACT (dark) ====================== */
.contact{ background:var(--plum-900); color:var(--paper); padding:5rem var(--pad) 4rem; }
.contact__head{ font-family:var(--serif); font-weight:300; font-size:clamp(2.8rem,11vw,9rem);
  line-height:.96; letter-spacing:-.02em; margin:1rem 0 2.5rem; }
.contact__head .line{ display:block; overflow:hidden; padding-bottom:.14em; margin-bottom:-.14em; }
.contact__head .line__in{ display:block; }
.contact__head em{ color:var(--lilac); }
.contact__mail{ font-family:var(--serif); font-size:clamp(1.4rem,5vw,3.4rem); font-weight:300;
  display:inline-block; position:relative; padding-bottom:.2em; color:var(--paper); }
.contact__mail::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:2px;
  background:var(--acid); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.contact__mail:hover::after{ transform:scaleX(1); }
.contact__mail:hover{ color:var(--acid); }
.contact__rows{ display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap;
  margin-top:5rem; padding-top:2.5rem; border-top:1px solid var(--line-light); }
.contact__links{ display:flex; flex-wrap:wrap; gap:1.4rem; }
.contact__links a{ font-family:var(--mono); font-size:.85rem; text-transform:uppercase; letter-spacing:.06em;
  display:flex; align-items:center; gap:.3rem; color:rgba(243,238,248,.8); transition:color .3s; }
.contact__links a:hover{ color:var(--acid); }
.contact__links a i{ font-style:normal; transition:transform .3s var(--ease); }
.contact__links a:hover i{ transform:translate(2px,-2px); }
.contact__note{ font-family:var(--mono); font-size:.8rem; line-height:1.8; color:rgba(243,238,248,.6);
  text-align:right; }

/* ====================== FOOTER ====================== */
.footer{ background:var(--plum-900); color:var(--paper); padding-bottom:1.5rem; }
.footer__marquee{ border-top:1px solid var(--line-light); border-bottom:1px solid var(--line-light);
  padding:2.5rem 0; overflow:hidden; }
.footer__marquee .tape__track{ font-family:var(--serif); font-size:clamp(2.5rem,9vw,7rem);
  font-weight:300; color:var(--paper); }
.footer__marquee .tape__star{ color:var(--lilac); }
.footer__base{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  padding:1.5rem var(--pad) 0; font-family:var(--mono); font-size:.74rem; text-transform:uppercase;
  letter-spacing:.06em; color:rgba(243,238,248,.6); }
.footer__top:hover{ color:var(--acid); }

/* ====================== RESPONSIVE ====================== */
@media (max-width:880px){
  .nav__menu{ display:none; }
  .skills__cols{ grid-template-columns:1fr; gap:3rem; }
  .skills__divider{ display:none; }
  .about__statement{ max-width:none; }
  .about__grid{ grid-template-columns:1fr; gap:2.2rem; }
  .project__row{ grid-template-columns:auto 1fr; row-gap:.3rem; }
  .project__cat{ grid-column:2; }
  .project__year{ grid-column:2; }
  .contact__note{ text-align:left; }
  .hero__scroll{ display:none; }
  .preview{ display:none; }
}
@media (max-width:520px){
  .nav__meta .btn-pill{ display:none; }
  .hero__top{ flex-direction:column; gap:.5rem; }
  .eyebrow--right{ justify-content:flex-start; text-align:left; }
}

/* ====================== REDUCED MOTION ====================== */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
     transition-duration:.001ms !important; }
  .js [data-reveal]{ opacity:1 !important; transform:none !important; }
  .grain{ display:none; }
}

/* Fallback: if JS never boots, make sure nothing stays hidden */
.no-js [data-reveal]{ opacity:1; transform:none; }
