/* =====================================================================
   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}
}
