/* =====================================================================
   MOSAIC — Maryam Iftikhar · scrapbook site, banded & dimensional
   ===================================================================== */
:root{
  --rosewood:#AD6159; --rose:#CFA29D; --teal:#5D878C; --emerald:#2F4A4A;
  --blush:#EAD3D3; --kraft:#C69A63; --sun:#FBE7A8; --mint:#D7E8E3;
  --paper:#F7F1E8; --card:#FFFDF8; --ink:#26312E; --ink-60:#5c665f;
  --display:"Fraunces",Georgia,serif; --body:"Hanken Grotesk",system-ui,sans-serif; --hand:"Caveat",ui-rounded,cursive;
  --s1:.5rem; --s2:.75rem; --s3:1rem; --s4:1.5rem; --s5:2rem; --s6:3rem; --s7:4.5rem; --s8:6.5rem;
  --t-hero:clamp(2.7rem,6vw,4.4rem); --t-h2:clamp(1.8rem,3.5vw,2.6rem); --t-body:1.06rem; --t-sm:.9rem; --t-xs:.74rem;
  --radius:16px; --line:rgba(38,49,46,.1);
  --sh-s:0 1px 2px rgba(47,74,74,.08),0 6px 16px -10px rgba(47,74,74,.32);
  --sh-m:0 2px 5px rgba(47,74,74,.1),0 18px 38px -18px rgba(47,74,74,.4);
  --sh-l:0 4px 12px rgba(47,74,74,.14),0 34px 60px -26px rgba(47,74,74,.46);
}
*{box-sizing:border-box;margin:0}
html{overflow-x:clip;scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--body);color:var(--ink);line-height:1.65;font-size:var(--t-body);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--display);font-weight:540;line-height:1.08;letter-spacing:-.01em}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:4px}
.wrap{width:min(1120px,92vw);margin-inline:auto}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
.kicker{font-family:var(--hand);font-weight:600;font-size:1.7rem;color:var(--rosewood);display:inline-block}
.label{font-family:var(--body);font-weight:600;font-size:var(--t-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--ink-60)}

/* ---------- BANDS (distinct section backgrounds + stacked depth) ---------- */
.band{position:relative}
.band>.wrap{padding-block:var(--s7)}
.band::before{content:"";position:absolute;top:0;left:0;right:0;height:22px;background:linear-gradient(rgba(38,49,46,.05),transparent);pointer-events:none;z-index:1}
.b-paper{background:#F7F1E8;background-image:radial-gradient(rgba(38,49,46,.045) 1.1px,transparent 1.1px);background-size:24px 24px}
.b-blush{background:linear-gradient(180deg,#F5E7E3,#F0DBD5)}
.b-teal{background:linear-gradient(180deg,#E9F1F0,#DEEBE9)}
.b-sun{background:linear-gradient(180deg,#F8F0DC,#F3E7CB)}
.b-rose{background:linear-gradient(180deg,#F1DCD7,#EACFC9)}
.b-emerald{background:linear-gradient(165deg,#33534f,#26403c);color:#f1ece3}
.b-emerald h1,.b-emerald h2,.b-emerald h3{color:#fff}
.b-emerald .lead,.b-emerald p{color:rgba(241,236,227,.86)}
.b-emerald .kicker{color:var(--sun)}

.section-head{margin-bottom:var(--s5)}
.section-head.center{text-align:center}
.section-head h2{font-size:var(--t-h2);margin-top:3px}
.section-head p{color:var(--ink-60);margin-top:6px;max-width:56ch}
.section-head.center p{margin-inline:auto}

/* ---------- tape, pins, stickers (clean + correctly seated) ---------- */
.tape{position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(-3deg);width:86px;height:26px;z-index:5;
  background:linear-gradient(180deg,rgba(93,135,140,.5),rgba(93,135,140,.34));box-shadow:0 2px 6px rgba(0,0,0,.1)}
.tape::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(255,255,255,.35),transparent 45%)}
.tape.t-clay{background:linear-gradient(180deg,rgba(207,162,157,.72),rgba(207,162,157,.5))}
.tape.t-rose{background:linear-gradient(180deg,rgba(173,97,89,.5),rgba(173,97,89,.34))}
.tape.t-gold{background:linear-gradient(180deg,rgba(198,154,99,.6),rgba(198,154,99,.4))}
.tape.right{left:auto;right:16px;transform:rotate(6deg)}
.tape.left{left:22px;transform:rotate(-7deg)}
.pin{position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:18px;height:18px;border-radius:50%;z-index:6;
  background:radial-gradient(circle at 35% 30%,#ec9d95,var(--rosewood));box-shadow:0 3px 7px rgba(0,0,0,.32),inset 0 -2px 3px rgba(0,0,0,.2)}
.pin.p-teal{background:radial-gradient(circle at 35% 30%,#93bbbf,var(--teal))}
.sticker{position:absolute;z-index:2;pointer-events:none;animation:float 6.5s ease-in-out infinite}
.sticker.s2{animation-delay:-2.4s;animation-duration:7.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(prefers-reduced-motion:reduce){.sticker{animation:none}}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(247,241,232,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:var(--s4);padding:.7rem 0}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.brand svg{width:30px;height:30px}
.brand b{font-family:var(--display);font-weight:560;font-size:1.08rem;color:var(--ink);white-space:nowrap}
.nav-links{margin-left:auto;display:flex;gap:var(--s4);align-items:center;list-style:none;padding:0}
.nav-links a{text-decoration:none;font-weight:500;font-size:.98rem;position:relative;padding:.2rem 0}
.nav-links a:hover{color:var(--rosewood)}
.nav-links a[aria-current]{color:var(--rosewood)}
.nav-links a[aria-current]::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:6px;
  background:no-repeat center/100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 8' preserveAspectRatio='none'%3E%3Cpath d='M2 5 Q 12 1 22 5 T 42 5 T 62 5 T 82 5 T 98 5' fill='none' stroke='%23AD6159' stroke-width='2.4' stroke-linecap='round'/%3E%3C/svg%3E")}
.pill{margin-left:var(--s3);display:inline-flex;align-items:center;gap:7px;font-size:var(--t-xs);font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  background:var(--card);border:1px solid var(--line);border-radius:999px;padding:6px 12px;color:var(--ink-60);white-space:nowrap;box-shadow:var(--sh-s)}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(93,135,140,.2)}
.menu-btn{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:10px;padding:7px 9px;cursor:pointer}

/* ---------- hero ---------- */
.hero .wrap{padding-block:var(--s8) var(--s7)}
.hero-grid{display:grid;grid-template-columns:1.35fr .9fr;gap:var(--s6);align-items:center}
.hero h1{font-size:var(--t-hero);margin-bottom:var(--s3)}
.accent{position:relative;display:inline-block;color:var(--rosewood)}
.accent::after{content:"";position:absolute;left:0;bottom:-.14em;width:100%;height:.4em;
  background:no-repeat left center/100% 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M4 10 Q 19 2 34 10 T 64 10 T 94 10 T 124 10 T 154 10 T 184 10 T 198 10' fill='none' stroke='%235D878C' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E");animation:draw 1.1s ease .4s both}
@keyframes draw{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@media(prefers-reduced-motion:reduce){.accent::after{animation:none}}
.hero .lead{font-size:1.17rem;max-width:47ch;color:#3a453f}
.hero .lead strong{color:var(--ink);font-weight:640}
.socials{display:flex;gap:12px;margin-top:var(--s4)}
.socials a{width:44px;height:44px;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);border-radius:13px;box-shadow:var(--sh-s);transition:transform .25s,color .25s}
.socials a:hover{transform:translateY(-3px) rotate(-5deg);color:var(--rosewood)}
.socials svg{width:20px;height:20px}
.polaroid{position:relative;background:#fff;padding:12px 12px 16px;border-radius:4px;box-shadow:var(--sh-l);display:inline-block}
.polaroid img,.polaroid .ph{width:100%;border-radius:2px;aspect-ratio:4/5;object-fit:cover;background:linear-gradient(135deg,var(--teal),var(--emerald))}
.polaroid .cap{display:block;text-align:center;font-family:var(--hand);font-size:1.34rem;color:#5b6b67;margin-top:8px}
.hero-photo{display:flex;justify-content:center;position:relative}
.hero-photo .polaroid{max-width:280px;transform:rotate(2.2deg)}
.doodle-arrow{position:absolute;left:-30px;bottom:14px;width:72px;color:var(--kraft);transform:rotate(10deg)}

/* ---------- hats ---------- */
.hats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);margin-top:var(--s5)}
.hat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s5);box-shadow:var(--sh-m);
  transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s}
.hat:hover{transform:translateY(-6px);box-shadow:var(--sh-l)}
.hat .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:var(--s3);background:var(--blush);color:var(--emerald)}
.hat .ic svg{width:24px;height:24px}
.hat h3{font-size:1.26rem;margin-bottom:7px}
.hat p{color:var(--ink-60);font-size:.98rem;line-height:1.6}
.hat:nth-child(1) .ic{background:rgba(173,97,89,.15);color:var(--rosewood)}
.hat:nth-child(2) .ic{background:rgba(93,135,140,.18);color:var(--teal)}
.hat:nth-child(3) .ic{background:rgba(47,74,74,.14);color:var(--emerald)}

/* ---------- board (hub) ---------- */
.pinboard{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--s7) var(--s4);align-items:start;justify-items:center;perspective:1000px;margin-top:var(--s6)}
.artifact{--rot:0deg;--tiltX:0deg;--tiltY:0deg;--lift:0px;--sc:1;position:relative;text-decoration:none;color:var(--ink);display:block;
  transform:rotateX(var(--tiltX)) rotateY(var(--tiltY)) rotate(var(--rot)) translateY(var(--lift)) scale(var(--sc));
  transition:transform .3s cubic-bezier(.2,.7,.3,1);transform-style:preserve-3d}
.artifact .obj{transition:filter .3s ease}
.artifact:hover{--lift:-8px;--sc:1.03;z-index:6}
.artifact:hover .obj{filter:drop-shadow(0 24px 28px rgba(47,74,74,.34))}
.artifact .a-tag{display:block;text-align:center;margin-top:14px}
.artifact .a-tag b{font-family:var(--display);font-size:1.16rem;display:block}
.artifact .a-tag span{font-size:var(--t-sm);color:var(--ink-60)}
.artifact.a1{grid-column:1/3}.artifact.a2{grid-column:3/5}.artifact.a3{grid-column:5/7}
.artifact.a4{grid-column:2/4}.artifact.a5{grid-column:4/6}
.art-polaroid{background:#fff;padding:12px 12px 14px;border-radius:4px;box-shadow:var(--sh-m);width:200px;position:relative}
.art-polaroid .ph{aspect-ratio:1/1;border-radius:3px;background:linear-gradient(135deg,var(--teal),var(--emerald));display:grid;place-items:center}
.art-polaroid .ph svg{width:44px;height:44px;color:rgba(255,255,255,.72)}
.art-folder{width:210px;height:170px;position:relative}
.art-folder .tab{position:absolute;top:0;left:22px;width:84px;height:26px;background:#E7C88A;border-radius:9px 9px 0 0}
.art-folder .body{position:absolute;top:20px;inset-inline:0;bottom:0;background:linear-gradient(#EAD09A,#E1BE76);border-radius:6px 12px 12px 12px;padding:22px 20px;box-shadow:var(--sh-m)}
.art-folder .ln{height:9px;background:rgba(120,86,40,.26);border-radius:4px;margin-bottom:10px}
.art-folder .ln:nth-child(2){width:78%}.art-folder .ln:nth-child(3){width:56%}
.art-folder .stamp{position:absolute;right:16px;bottom:14px;font-weight:700;font-size:.56rem;letter-spacing:.1em;color:var(--rosewood);border:2px solid var(--rosewood);border-radius:5px;padding:3px 6px;transform:rotate(-7deg);opacity:.72}
.art-card{width:214px;min-height:152px;background:repeating-linear-gradient(var(--card) 0 26px,rgba(93,135,140,.15) 26px 27px);border:1px solid var(--line);border-radius:8px;box-shadow:var(--sh-m);padding:18px 20px 20px 34px;position:relative;overflow:hidden}
.art-card::before{content:"";position:absolute;left:30px;top:0;bottom:0;width:2px;background:rgba(173,97,89,.45)}
.art-card .rc-k{color:var(--rosewood);letter-spacing:.1em}
.art-card .rc-t{font-family:var(--display);font-size:1.55rem;line-height:1.14;margin-top:20px}
.art-cassette{width:216px;background:linear-gradient(#33403c,#26312e);border-radius:12px;box-shadow:var(--sh-l);padding:16px 14px 14px;position:relative}
.art-cassette .label{display:block;text-align:center;font-family:var(--hand);font-size:1.3rem;color:#f4ead2;margin-bottom:9px;line-height:1}
.art-cassette .win{height:60px;background:#f4ead2;border-radius:6px;display:flex;align-items:center;justify-content:space-around;padding:0 20px;border:2px solid #1c2421}
.art-cassette .reel{width:32px;height:32px;border-radius:50%;background:conic-gradient(#c9b48f 0 25%,#e7dcc2 0 50%,#c9b48f 0 75%,#e7dcc2 0);border:4px solid #6b5c3f;transition:transform .9s linear}
.art-cassette:hover .reel{transform:rotate(200deg)}
.art-cassette .strip{margin-top:11px;height:19px;background:var(--rosewood);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.56rem;letter-spacing:.13em}
.art-postcard{width:224px;min-height:150px;background:var(--card);border-radius:8px;box-shadow:var(--sh-m);padding:16px;position:relative;border:1px solid var(--line)}
.art-postcard .air{height:7px;border-radius:4px;margin-bottom:12px;background:repeating-linear-gradient(45deg,var(--rosewood) 0 9px,transparent 9px 18px,var(--teal) 18px 27px,transparent 27px 36px)}
.art-postcard .msg{font-family:var(--hand);font-size:1.7rem;color:var(--teal);line-height:1}
.art-postcard .to{margin-top:12px;max-width:130px}
.art-postcard .stamp{position:absolute;top:30px;right:18px;width:42px;height:50px;background:var(--blush);border:2px dashed var(--rosewood);border-radius:4px;display:grid;place-items:center;font-size:1.4rem;transform:rotate(4deg)}

/* ---------- interests collage (post-its + polaroids) ---------- */
.collage{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--s5) var(--s4);margin-top:var(--s5)}
.postit{position:relative;width:198px;min-height:150px;padding:32px 22px 22px;border-radius:2px;box-shadow:var(--sh-m);color:#3a3a2e;transform:rotate(-2deg)}
.postit:nth-child(4n+2){transform:rotate(2.3deg)}.postit:nth-child(4n+3){transform:rotate(-1.4deg)}.postit:nth-child(4n){transform:rotate(2deg)}
.postit .k{display:block;font-weight:700;font-size:.72rem;letter-spacing:.11em;text-transform:uppercase;color:rgba(58,58,46,.55);margin-bottom:9px}
.postit p{font-size:1.02rem;line-height:1.5;margin:0}
.postit.y{background:#FBE7A8}.postit.b{background:#F2D6D2}.postit.m{background:#D7E8E3}.postit.p{background:#F6E0C5}
.collage .polaroid{max-width:186px;transform:rotate(2.2deg)}
.collage .polaroid:nth-child(even){transform:rotate(-2.4deg)}
.collage .polaroid .ph{aspect-ratio:1/1}
.collage>*{transition:transform .3s cubic-bezier(.2,.7,.3,1)}
.collage>*:hover{transform:translateY(-6px) rotate(0deg);z-index:4}

/* ---------- now card ---------- */
.now{max-width:600px;width:100%;margin-inline:auto;background:repeating-linear-gradient(var(--card) 0 33px,rgba(93,135,140,.12) 33px 34px);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--sh-m);padding:var(--s5) var(--s5) var(--s5) calc(var(--s5) + 14px);position:relative;transform:rotate(-.8deg)}
.now::before{content:"";position:absolute;left:26px;top:0;bottom:0;width:2px;background:rgba(173,97,89,.4)}
.now h3{font-size:1.4rem;margin-bottom:var(--s3);display:flex;align-items:center;gap:8px}
.now h3 .badge{width:12px;height:12px;border-radius:3px;background:var(--rosewood)}
.now dl{display:grid;grid-template-columns:auto 1fr;gap:11px 18px;margin:0}
.now dt{font-family:var(--hand);font-size:1.42rem;color:var(--teal);line-height:1.1}
.now dd{margin:0;align-self:center}
.now .updated{margin-top:var(--s4);font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-60)}

/* ---------- footer ---------- */
.site-foot{background:linear-gradient(165deg,#33534f,#243d39);color:#f1ece3;padding:var(--s7) 0;position:relative}
.foot-in{display:flex;flex-direction:column;align-items:center;gap:var(--s3);text-align:center}
.foot-in .brand b{color:#f1ece3}
.foot-tag{font-family:var(--hand);font-size:1.6rem;color:var(--sun);max-width:34ch}
.foot-social{display:flex;gap:14px}
.foot-social a{color:#cfdcd6;transition:color .2s,transform .2s}.foot-social a:hover{color:#fff;transform:translateY(-2px)}
.foot-social svg{width:22px;height:22px}
.foot-count{display:inline-flex;gap:8px;align-items:center;font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:rgba(241,236,227,.72)}
.foot-count .digits{display:inline-flex;gap:3px}
.foot-count .d{font-weight:700;font-variant-numeric:tabular-nums;background:rgba(255,255,255,.1);color:var(--sun);padding:3px 6px;border-radius:4px;text-transform:none}
.foot-meta{font-size:var(--t-xs);letter-spacing:.06em;text-transform:uppercase;color:rgba(241,236,227,.6)}

/* ---------- inner pages ---------- */
.page-hero .wrap{padding-block:var(--s8) var(--s6)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin:3px 0 var(--s3)}
.page-hero .lead{font-size:1.16rem;max-width:60ch;color:#3a453f}
.stats{display:flex;flex-wrap:wrap;gap:var(--s3);margin-top:var(--s5)}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 20px;box-shadow:var(--sh-s);transform:rotate(-1.2deg)}
.stat:nth-child(even){transform:rotate(1.5deg)}
.stat b{font-family:var(--display);font-size:1.8rem;color:var(--rosewood);display:block;line-height:1}
.stat span{font-size:var(--t-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-60)}
.chip{display:inline-block;font-weight:600;font-size:.8rem;padding:5px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:var(--blush);color:#3a3a36;margin:0 5px 6px 0}
.chip.writing{background:rgba(173,97,89,.14);color:#894139;border-color:rgba(173,97,89,.3)}
.chip.design{background:rgba(93,135,140,.16);color:#3a5a5f;border-color:rgba(93,135,140,.32)}
.chip.media{background:rgba(47,74,74,.13);color:#2b4544;border-color:rgba(47,74,74,.3)}
.chip.data{background:rgba(140,85,105,.16);color:#774356;border-color:rgba(140,85,105,.3)}
.chip.strategy{background:rgba(198,154,99,.2);color:#8a5f27;border-color:rgba(198,154,99,.4)}
.chip.film{background:rgba(207,162,157,.26);color:#8a544d;border-color:rgba(207,162,157,.5)}
.filter{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 var(--s5)}
.filter button{font-family:var(--body);font-weight:600;font-size:.9rem;padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--ink-60);cursor:pointer;transition:all .2s;box-shadow:var(--sh-s)}
.filter button:hover{color:var(--ink)}
.filter button[aria-pressed="true"]{background:var(--emerald);color:var(--paper);border-color:var(--emerald)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
.p-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-s);display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s}
.p-card:hover{transform:translateY(-6px);box-shadow:var(--sh-l)}
.p-card .thumb{aspect-ratio:16/10;display:grid;place-items:center}
.p-card .thumb svg{width:36px;height:36px;color:rgba(255,255,255,.72)}
.p-card .thumb.g1{background:linear-gradient(135deg,var(--teal),var(--emerald))}.p-card .thumb.g2{background:linear-gradient(135deg,var(--rosewood),var(--rose))}
.p-card .thumb.g3{background:linear-gradient(135deg,var(--emerald),var(--teal))}.p-card .thumb.g4{background:linear-gradient(135deg,var(--rose),var(--blush))}
.p-card .thumb.g5{background:linear-gradient(135deg,#8c5569,var(--rosewood))}.p-card .thumb.g6{background:linear-gradient(135deg,var(--kraft),var(--rosewood))}
.p-card .pc-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.p-card .pc-meta{font-size:var(--t-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--rosewood);font-weight:600}
.p-card h3{font-size:1.16rem;margin:8px 0 6px}
.p-card p{color:var(--ink-60);font-size:.95rem;flex:1}
.p-card .tags{margin-top:12px}
.p-card[hidden]{display:none}
/* resume */
.two-col{display:grid;grid-template-columns:1.45fr .9fr;gap:var(--s6)}
.timeline{position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:2px;background:rgba(173,97,89,.3)}
.tl{position:relative;margin-bottom:var(--s5)}
.tl::before{content:"";position:absolute;left:-28px;top:5px;width:15px;height:15px;border-radius:50%;background:var(--rosewood);box-shadow:0 0 0 4px var(--card),0 2px 5px rgba(0,0,0,.2)}
.tl .when{font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-60)}
.tl h3{font-size:1.18rem;margin:3px 0 1px}
.tl .org{color:var(--teal);font-weight:600;font-size:.96rem;margin-bottom:6px}
.tl p{color:#3a453f;font-size:.97rem}
.side-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s5);box-shadow:var(--sh-m);margin-bottom:var(--s4)}
.side-card h3{font-size:1.2rem;margin-bottom:var(--s3)}
.side-card .row{display:block;margin-bottom:var(--s3)}
.side-card .row b{display:block}.side-card .row span{font-size:.9rem;color:var(--ink-60)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--rosewood);color:#fff;font-weight:600;text-decoration:none;padding:11px 22px;border-radius:999px;box-shadow:var(--sh-s);transition:transform .2s,background .2s;border:0;cursor:pointer;font-family:var(--body);font-size:1rem}
.btn:hover{background:#96504a;transform:translateY(-2px) rotate(-1.5deg)}
.btn svg{width:18px;height:18px}
.btn.ghost{background:var(--card);color:var(--rosewood);border:1px solid rgba(173,97,89,.3)}
.btn.ghost:hover{background:var(--blush)}
/* research pubs */
.pub{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s4) var(--s5);box-shadow:var(--sh-s);margin-bottom:var(--s3);display:flex;gap:var(--s4);align-items:flex-start;transition:transform .25s,box-shadow .25s}
.pub:hover{transform:translateX(5px);box-shadow:var(--sh-m)}
.pub .yr{font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--rosewood);font-weight:700;white-space:nowrap;padding-top:3px;min-width:42px}
.pub h3{font-size:1.14rem;margin-bottom:3px}.pub h3 a{text-decoration:none}.pub h3 a:hover{color:var(--rosewood)}
.pub .where{color:var(--ink-60);font-size:.94rem}
/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s5);align-items:start}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--sh-m);padding:var(--s6);position:relative}
.contact-card .air{height:8px;border-radius:5px;margin-bottom:var(--s4);background:repeating-linear-gradient(45deg,var(--rosewood) 0 10px,transparent 10px 20px,var(--teal) 20px 30px,transparent 30px 40px)}
.contact-card .big{font-family:var(--hand);font-size:2rem;color:var(--teal);margin-bottom:6px}
.contact-card .email{font-size:1.24rem;font-weight:600;word-break:break-word}
.contact-card .cc-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:var(--s4)}
.c-rows{display:flex;flex-direction:column;gap:var(--s3)}
.c-row{display:flex;align-items:center;gap:var(--s3);background:var(--card);border:1px solid var(--line);border-radius:14px;padding:var(--s3) var(--s4);box-shadow:var(--sh-s);text-decoration:none;color:var(--ink);transition:transform .25s,box-shadow .25s}
.c-row:hover{transform:translateX(4px);box-shadow:var(--sh-m)}
.c-row .ci{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--blush);color:var(--emerald);flex-shrink:0}
.c-row .ci svg{width:21px;height:21px}
.c-row>div{min-width:0}.c-row b{display:block}.c-row span{font-size:.9rem;color:var(--ink-60);overflow-wrap:anywhere}
.c-row .go{margin-left:auto;color:var(--ink-60);flex-shrink:0}

@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:var(--s5)}.hero-photo{order:-1}
  .hats-grid{grid-template-columns:1fr}.grid{grid-template-columns:repeat(2,1fr)}
  .two-col,.contact-grid{grid-template-columns:1fr;gap:var(--s5)}
  .pinboard{grid-template-columns:repeat(2,1fr);gap:var(--s7) var(--s4)}
  .artifact.a1,.artifact.a2,.artifact.a3,.artifact.a4,.artifact.a5{grid-column:auto}
}
@media(max-width:640px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);padding:var(--s3) 6vw;gap:var(--s2);margin-left:0}
  .nav-links.open{display:flex}.menu-btn{display:block}.pill{display:none}
  .grid{grid-template-columns:1fr}.pinboard{grid-template-columns:1fr;gap:var(--s7)}.sticker{display:none}
}

/* ---------- lightbox ---------- */
.p-card,.pub{cursor:pointer}
.lb{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:5vh 4vw}
.lb.open{display:flex}
.lb-backdrop{position:absolute;inset:0;background:rgba(38,49,46,.55);backdrop-filter:blur(3px)}
.lb-panel{position:relative;background:var(--card);border-radius:var(--radius);box-shadow:var(--sh-l);max-width:640px;width:100%;
  max-height:88vh;overflow:auto;animation:lbin .3s cubic-bezier(.2,.7,.3,1)}
@keyframes lbin{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.lb-panel{animation:none}}
.lb-thumb{aspect-ratio:16/9;display:grid;place-items:center;border-radius:var(--radius) var(--radius) 0 0}
.lb-thumb svg{width:52px;height:52px;color:rgba(255,255,255,.72)}
.lb-body{padding:var(--s5) var(--s6) var(--s6)}
.lb-body .pc-meta{font-size:var(--t-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--rosewood);font-weight:600}
.lb-body h3{font-family:var(--display);font-size:1.7rem;margin:10px 0 12px;line-height:1.15}
.lb-body p{color:#3a453f;font-size:1.02rem}
.lb-body .tags{margin-top:var(--s4)}
.lb-body .lb-actions{margin-top:var(--s4);display:flex;gap:10px;flex-wrap:wrap}
.lb-close{position:absolute;top:12px;right:12px;z-index:2;width:38px;height:38px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,253,248,.92);color:var(--ink);box-shadow:var(--sh-s);display:grid;place-items:center;transition:transform .2s}
.lb-close:hover{transform:rotate(90deg)}
body.lb-lock{overflow:hidden}
.lb-thumb.g1{background:linear-gradient(135deg,var(--teal),var(--emerald))}
.lb-thumb.g2{background:linear-gradient(135deg,var(--rosewood),var(--rose))}
.lb-thumb.g3{background:linear-gradient(135deg,var(--emerald),var(--teal))}
.lb-thumb.g4{background:linear-gradient(135deg,var(--rose),var(--blush))}
.lb-thumb.g5{background:linear-gradient(135deg,#8c5569,var(--rosewood))}
.lb-thumb.g6{background:linear-gradient(135deg,var(--kraft),var(--rosewood))}
