/* =====================================================================
   MOSAIC — Maryam Iftikhar · pinned-corkboard personal site
   ===================================================================== */
: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.7rem,3.4vw,2.5rem);
  --t-body:1.06rem; --t-sm:.9rem; --t-xs:.74rem;

  --radius:14px; --line:rgba(38,49,46,.12);
  /* layered shadows = real depth */
  --sh-s:0 1px 3px rgba(47,74,74,.1),0 8px 18px -12px rgba(47,74,74,.4);
  --sh-m:0 2px 6px rgba(47,74,74,.12),0 20px 42px -22px rgba(47,74,74,.46);
  --sh-l:0 3px 10px rgba(47,74,74,.16),0 34px 64px -30px rgba(47,74,74,.52);
  --tape:rgba(93,135,140,.34);
  --label:{}
}
*{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);
  background-image:radial-gradient(rgba(38,49,46,.05) 1.1px,transparent 1.1px);background-size:24px 24px;
  -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(20px);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.65rem;color:var(--rosewood);display:inline-block}
.label{font-family:var(--body);font-weight:600;font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-60)}

/* ---------- tape, pins, stickers ---------- */
.tape{position:absolute;width:92px;height:27px;background:var(--tape);border:1px solid rgba(255,255,255,.3);
  top:-13px;left:50%;transform:translateX(-50%) rotate(-4deg);z-index:5;box-shadow:0 2px 6px rgba(0,0,0,.09)}
.tape::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.4),transparent 42%)}
.tape.peel{clip-path:polygon(0 0,100% 0,100% 66%,86% 100%,0 80%)}
.tape.t-clay{background:rgba(207,162,157,.62)} .tape.t-rose{background:rgba(173,97,89,.42)}
.tape.t-gold{background:rgba(198,154,99,.5)} .tape.t-teal{background:var(--tape)}
.tape.right{left:auto;right:14px;transform:rotate(7deg)}
.pin{position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:19px;height:19px;border-radius:50%;z-index:6;
  background:radial-gradient(circle at 34% 30%,#e89a92,var(--rosewood));box-shadow:0 4px 9px rgba(0,0,0,.3)}
.pin.p-teal{background:radial-gradient(circle at 34% 30%,#8fb6ba,var(--teal))}

.sticker{position:absolute;z-index:1;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,.85);backdrop-filter:blur(9px);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:.06em;
  text-transform:uppercase;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:6px 12px;color:var(--ink-60);white-space:nowrap}
.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{padding:var(--s7) 0 var(--s6);position:relative}
.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.16rem;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:42px;height:42px;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--sh-s);transition:transform .25s ease,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-m);display:inline-block}
.polaroid img{width:100%;border-radius:2px;aspect-ratio:4/5;object-fit:cover;background:var(--blush)}
.polaroid .cap{display:block;text-align:center;font-family:var(--hand);font-size:1.3rem;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:12px;width:74px;color:var(--kraft);transform:rotate(10deg)}

/* ---------- hats ---------- */
.hats{padding:var(--s5) 0 var(--s6)}
.hats-head{text-align:center;margin-bottom:var(--s5)}
.hats-head h2{font-size:var(--t-h2);margin-top:4px}
.hats-head p{color:var(--ink-60);margin-top:6px}
.hats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
.hat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s5);box-shadow:var(--sh-s);
  transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s}
.hat:hover{transform:translateY(-5px);box-shadow:var(--sh-m)}
.hat .ic{width:48px;height:48px;border-radius:13px;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.24rem;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,.14);color:var(--rosewood)}
.hat:nth-child(2) .ic{background:rgba(93,135,140,.17);color:var(--teal)}
.hat:nth-child(3) .ic{background:rgba(47,74,74,.13);color:var(--emerald)}

/* ---------- the board (hub) ---------- */
.board{padding:var(--s6) 0 var(--s7);position:relative}
.board-head{text-align:center;margin-bottom:var(--s6)}
.board-head h2{font-size:var(--t-h2);margin-top:4px}
.board-head p{color:var(--ink-60);margin-top:6px}
.pinboard{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--s6) var(--s4);align-items:start;justify-items:center;perspective:900px}
.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 22px 26px rgba(47,74,74,.3))}
.artifact:focus-visible{z-index:6}
.artifact .a-tag{display:block;text-align:center;margin-top:14px}
.artifact .a-tag b{font-family:var(--display);font-size:1.14rem;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.28rem;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)}

/* ---------- now / currently ---------- */
.now-wrap{display:flex;justify-content:center;padding:var(--s4) 0 var(--s7)}
.now{max-width:560px;width:100%;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(-1deg)}
.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);display:inline-block}
.now dl{display:grid;grid-template-columns:auto 1fr;gap:11px 18px;margin:0}
.now dt{font-family:var(--hand);font-size:1.4rem;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:var(--emerald);color:#f3ede4;padding:var(--s6) 0;margin-top:var(--s5);position:relative}
.foot-in{display:flex;flex-direction:column;align-items:center;gap:var(--s3);text-align:center}
.foot-in .brand b{color:#f3ede4}
.foot-tag{font-family:var(--hand);font-size:1.55rem;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(243,237,228,.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(243,237,228,.62)}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:var(--s5)} .hero-photo{order:-1}
  .hats-grid{grid-template-columns:1fr}
  .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}
  .pinboard{grid-template-columns:1fr;gap:var(--s7)} .sticker{display:none}
}

/* =====================================================================
   INNER PAGES — shared components
   ===================================================================== */
.page-hero{padding:var(--s7) 0 var(--s5);position:relative}
.page-hero .kicker{margin-bottom:2px}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin:2px 0 var(--s3)}
.page-hero .lead{font-size:1.14rem;max-width:60ch;color:#3a453f}
.section{padding:var(--s5) 0}
.section-head{margin-bottom:var(--s5)}
.section-head h2{font-size:var(--t-h2)}
.section-head p{color:var(--ink-60);margin-top:4px}

/* stat "receipts" */
.stats{display:flex;flex-wrap:wrap;gap:var(--s3);margin-top:var(--s4)}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;box-shadow:var(--sh-s);position:relative;transform:rotate(-1deg)}
.stat:nth-child(even){transform:rotate(1.5deg)}
.stat b{font-family:var(--display);font-size:1.7rem;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)}

/* chips */
.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,.13);color:#894139;border-color:rgba(173,97,89,.32)}
.chip.design{background:rgba(93,135,140,.15);color:#3a5a5f;border-color:rgba(93,135,140,.34)}
.chip.media{background:rgba(47,74,74,.12);color:#2b4544;border-color:rgba(47,74,74,.3)}
.chip.data{background:rgba(140,85,105,.15);color:#774356;border-color:rgba(140,85,105,.32)}
.chip.strategy{background:rgba(198,154,99,.18);color:#8a5f27;border-color:rgba(198,154,99,.4)}
.chip.film{background:rgba(207,162,157,.24);color:#8a544d;border-color:rgba(207,162,157,.5)}

/* filter bar */
.filter{display:flex;flex-wrap:wrap;gap:8px;margin:var(--s4) 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}
.filter button:hover{color:var(--ink)}
.filter button[aria-pressed="true"]{background:var(--emerald);color:var(--paper);border-color:var(--emerald)}

/* project cards */
.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-m)}
.p-card .thumb{aspect-ratio:16/10;display:grid;place-items:center;position:relative}
.p-card .thumb svg{width:38px;height:38px;color:rgba(255,255,255,.7)}
.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}

/* timeline (resume) */
.two-col{display:grid;grid-template-columns:1.4fr .9fr;gap:var(--s6)}
.timeline{position:relative;padding-left:26px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl{position:relative;margin-bottom:var(--s5)}
.tl::before{content:"";position:absolute;left:-26px;top:5px;width:14px;height:14px;border-radius:50%;background:var(--rosewood);box-shadow:0 0 0 4px var(--paper)}
.tl .when{font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-60)}
.tl h3{font-size:1.16rem;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-s);margin-bottom:var(--s4)}
.side-card h3{font-size:1.16rem;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}
.btn:hover{background:#96504a;transform:translateY(-2px) rotate(-1.5deg)}
.btn svg{width:18px;height:18px}

/* pub cards (research) */
.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(4px);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}
.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 rows */
.c-rows{display:flex;flex-direction:column;gap:var(--s3);max-width:600px}
.c-row{display:flex;align-items:center;gap:var(--s4);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s4) var(--s5);box-shadow:var(--sh-s);text-decoration:none;color:var(--ink);transition:transform .25s,box-shadow .25s}
.c-row:hover{transform:translateY(-3px) translateX(3px);box-shadow:var(--sh-m)}
.c-row .ci{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--blush);color:var(--emerald);flex-shrink:0}
.c-row .ci svg{width:22px;height:22px}
.c-row b{display:block} .c-row span{font-size:.92rem;color:var(--ink-60)}
.c-row .go{margin-left:auto;color:var(--ink-60)}
.copy-note{font-size:.82rem;color:var(--teal);margin-left:10px}

@media(max-width:920px){.grid{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr;gap:var(--s5)}}
@media(max-width:640px){.grid{grid-template-columns:1fr}}

/* contact row: prevent long-email overflow on mobile */
.c-row{flex-wrap:wrap}
.c-row>span:not(.ci){flex:1 1 auto;min-width:0}
.c-row span span{overflow-wrap:anywhere}
