/* ============================================================
   MARYAM IFTIKHAR — SITE STYLES
   One file controls the whole site's look.

   TO RESTYLE EVERYTHING, edit the values in :root below.
   (Change a color or font here once → every page updates.)
   ============================================================ */

:root{
  /* --- BRAND COLORS (change these to recolor the site) --- */
  --ad:#AD6159;       /* rosewood  — headings, buttons, links   */
  --cfa:#CFA29D;      /* clay pink — soft accents, tiles         */
  --teal:#5D878C;     /* teal      — secondary accent            */
  --emerald:#2F4A4A;  /* emerald   — body text / ink             */
  --pale:#EAD3D3;     /* pale pink — tints, sticky notes         */
  --paper:#FAF4F3;    /* page background                          */
  --card:#FFFDF8;     /* cards & raised surfaces                  */
  --ink:#2F4A4A;      /* default text color                       */
  --muted:#6E807C;    /* secondary text                           */

  /* --- FONTS --- */
  --serif:'Fraunces',Georgia,serif;          /* headings & accents */
  --sans:'Hanken Grotesk',system-ui,sans-serif; /* body & UI       */

  /* --- LAYOUT --- */
  --maxw:1000px;      /* page content width */
}

/* ---------- base ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:radial-gradient(60% 50% at 85% 0%,rgba(173,97,89,.08),transparent 60%),
             radial-gradient(55% 45% at 5% 100%,rgba(93,135,140,.09),transparent 60%);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:1;}
a{color:inherit;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;margin:0;}
img{max-width:100%;display:block;}

/* progress bar (top of page) */
#prog{position:fixed;top:0;left:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--ad),var(--teal));z-index:60;}

/* ---------- navigation ---------- */
nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:rgba(250,244,243,.82);border-bottom:1px solid rgba(47,74,74,.08);}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px;}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);
  font-weight:600;font-size:19px;text-decoration:none;color:var(--ink);}
.brand-mark{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;width:22px;height:22px;}
.brand-mark i{border-radius:2px;}
.brand-mark i:nth-child(1){background:var(--ad)}.brand-mark i:nth-child(2){background:var(--cfa)}
.brand-mark i:nth-child(3){background:var(--teal)}.brand-mark i:nth-child(4){background:var(--pale)}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0;}
.nav-links a{text-decoration:none;font-size:14.5px;color:var(--ink);position:relative;padding:4px 0;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--ad);transition:width .25s ease;}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--ad);}
.nav-cta{background:var(--emerald);color:#fff !important;padding:9px 18px;border-radius:100px;font-size:14px;}
.nav-cta::after{display:none;}
@media(max-width:760px){.nav-links{display:none;}}

/* ---------- buttons ---------- */
.btn-shine{position:relative;overflow:hidden;display:inline-block;background:var(--ad);color:#fff;
  border:none;border-radius:100px;padding:13px 30px;text-decoration:none;font-family:var(--serif);
  font-size:16px;cursor:pointer;}
.btn-shine::after{content:"";position:absolute;top:0;left:-70%;width:45%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-20deg);transition:left .6s ease;}
.btn-shine:hover::after{left:130%;}
.btn-outline{display:inline-flex;align-items:center;gap:9px;background:none;border:2px solid var(--emerald);
  color:var(--emerald);border-radius:100px;padding:11px 24px;font-family:var(--serif);font-size:16px;
  text-decoration:none;cursor:pointer;transition:gap .25s,background .25s,color .25s;}
.btn-outline .a{transition:transform .25s;}
.btn-outline:hover{background:var(--emerald);color:#fff;gap:14px;}
.btn-outline:hover .a{transform:translateX(3px);}
.lnk{text-decoration:none;border:1px solid rgba(47,74,74,.2);border-radius:100px;padding:10px 20px;
  font-size:14px;color:var(--emerald);transition:.2s;display:inline-block;}
.lnk:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);}

/* ---------- mosaic divider (between sections) ---------- */
.mdiv{display:flex;justify-content:center;gap:6px;padding:48px 0;}
.mdiv i{width:11px;height:11px;border-radius:3px;}
.mdiv i:nth-child(1){background:var(--ad)}.mdiv i:nth-child(2){background:var(--cfa)}
.mdiv i:nth-child(3){background:var(--teal)}.mdiv i:nth-child(4){background:var(--emerald)}
.mdiv i:nth-child(5){background:var(--pale)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

/* ---------- section headings ---------- */
.kicker{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ad);font-weight:600;}
.sec{padding:30px 0;scroll-margin-top:80px;}
.sec h2{font-size:clamp(28px,4.5vw,46px);font-weight:600;margin:10px 0 0;letter-spacing:-.01em;}
.sec .sub{color:var(--muted);font-size:16px;margin:14px 0 0;max-width:40em;}

/* ---------- hero ---------- */
.hero{padding:80px 0 56px;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;}}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);
  background:rgba(93,135,140,.1);border:1px solid rgba(93,135,140,.32);border-radius:100px;padding:7px 15px;}
.eyebrow i{position:relative;width:8px;height:8px;border-radius:50%;background:var(--teal);}
.eyebrow i::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--teal);
  animation:pulse 1.9s ease-out infinite;}
@keyframes pulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(3.4);opacity:0}}
.hero h1{font-size:clamp(44px,8vw,84px);font-weight:600;letter-spacing:-.015em;margin:22px 0 14px;}
.hero h1 .em{font-style:italic;color:var(--ad);}
.hero .roles{font-family:var(--serif);font-size:clamp(18px,2.6vw,23px);}
.hero .roles .sep{color:var(--cfa);margin:0 8px;}
.hero .rot{color:var(--teal);font-style:italic;}
.hero .lead{max-width:30em;font-size:18px;color:var(--muted);margin:22px 0 30px;}
.hero .lead b{color:var(--ad);font-weight:600;font-family:var(--serif);font-style:italic;}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero-azadi{margin-top:34px;font-family:var(--serif);font-style:italic;color:var(--muted);font-size:15px;}
.hero-azadi b{color:var(--ad);}
.hero-photo{border-radius:18px;width:100%;aspect-ratio:4/5;object-fit:cover;
  box-shadow:0 26px 54px -30px rgba(47,74,74,.55);}

/* ---------- pull quote ---------- */
.pquote{font-family:var(--serif);font-size:clamp(24px,3.6vw,34px);font-weight:500;line-height:1.34;
  color:var(--ink);border-left:4px solid var(--ad);padding:6px 0 6px 26px;margin:40px auto;max-width:26em;}
.pquote em{color:var(--ad);font-style:italic;}

/* ---------- disciplines marquee ---------- */
.marquee{overflow:hidden;margin:34px 0;
  -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee-t{display:flex;gap:14px;width:max-content;animation:marq 26s linear infinite;}
.marquee-t span{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--emerald);white-space:nowrap;}
.marquee-t span::after{content:"·";margin-left:14px;color:var(--cfa);}
@keyframes marq{to{transform:translateX(-50%);}}

/* ---------- term tooltip ---------- */
.term{position:relative;border-bottom:2px dotted var(--ad);color:var(--ad);cursor:help;text-decoration:none;}
.term .tip{position:absolute;left:0;bottom:160%;width:260px;background:var(--card);
  border:1px solid rgba(47,74,74,.14);border-radius:11px;padding:12px 14px;font-size:13.5px;line-height:1.5;
  color:var(--ink);box-shadow:0 14px 34px -16px rgba(47,74,74,.5);opacity:0;pointer-events:none;
  transition:.2s;z-index:6;font-family:var(--sans);}
.term .tip b{color:var(--teal);}
.term:hover .tip,.term:focus .tip{opacity:1;}

/* ---------- interest tags ---------- */
.tags{display:flex;flex-wrap:wrap;gap:11px;margin-top:24px;}
.tag{background:var(--card);border:1px solid rgba(47,74,74,.14);border-radius:100px;padding:9px 18px;
  font-size:14.5px;color:var(--ink);transition:transform .2s,border-color .2s,color .2s;}
.tag:hover{transform:translateY(-3px);border-color:var(--ad);color:var(--ad);}

/* ---------- stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px;}
.stat{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:16px;padding:22px 20px;}
.stat .n{font-family:var(--serif);font-weight:600;font-size:clamp(32px,4.4vw,46px);color:var(--ad);line-height:1;}
.stat .l{color:var(--muted);font-size:13px;margin-top:8px;}
.stat .o{color:var(--teal);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;margin-top:6px;}
.stat .spark{width:100%;height:24px;margin-top:12px;}
.stat .spark polyline{fill:none;stroke:var(--teal);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:200;stroke-dashoffset:200;}
.stat.in .spark polyline{transition:stroke-dashoffset 1.5s ease;stroke-dashoffset:0;}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);}}

/* ---------- mosaic underline heading ---------- */
.mosaic-h{display:inline-block;}
.mosaic-h .row{display:flex;gap:5px;margin-top:10px;}
.mosaic-h .row i{width:16px;height:16px;border-radius:4px;background:var(--pale);transition:background .3s,transform .3s;}
.mosaic-h:hover .row i{background:var(--ad);transform:translateY(-2px);}
.mosaic-h:hover .row i:nth-child(2){transition-delay:.06s;background:var(--cfa)}
.mosaic-h:hover .row i:nth-child(3){transition-delay:.12s;background:var(--teal)}
.mosaic-h:hover .row i:nth-child(4){transition-delay:.18s}
.mosaic-h:hover .row i:nth-child(5){transition-delay:.24s;background:var(--cfa)}
.mosaic-h:hover .row i:nth-child(6){transition-delay:.3s;background:var(--teal)}

/* ---------- hero mosaic art ---------- */
.mosaic-art{position:relative;aspect-ratio:1;max-width:330px;margin-left:auto;display:grid;
  grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);gap:7px;}
.mosaic-art i{border-radius:6px;opacity:0;transform:scale(.4);}
.mosaic-art.in i{opacity:1;transform:none;transition:opacity .5s ease,transform .55s cubic-bezier(.3,.9,.3,1.2);}
@media(max-width:820px){.mosaic-art{margin:8px auto 0;}}

/* ---------- timeline ---------- */
.tl{position:relative;padding:14px 0 10px 46px;margin-top:30px;max-width:760px;}
.tl-track,.tl-fill{position:absolute;left:15px;top:30px;bottom:30px;width:2px;}
.tl-track{background:rgba(47,74,74,.14);}
.tl-fill{background:var(--ad);height:0;transition:height .15s linear;}
.tl-item{position:relative;padding:18px 0;opacity:.5;transition:opacity .4s;}
.tl-item.active{opacity:1;}
.tl-dot{position:absolute;left:-38px;top:24px;width:15px;height:15px;border-radius:50%;
  background:var(--paper);border:2px solid rgba(47,74,74,.3);transition:.3s;}
.tl-item.active .tl-dot{background:var(--ad);border-color:var(--ad);transform:scale(1.22);}
.tl-item .role{font-family:var(--serif);font-size:21px;}
.tl-item .org{color:var(--ad);font-size:14.5px;margin:2px 0;}
.tl-item .when{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;}
.tl-item ul{margin:0;padding-left:18px;color:var(--ink);font-size:15px;}
.tl-item li{margin-bottom:6px;}
.tl-item li::marker{color:var(--cfa);}

/* ---------- org marquee ---------- */
.orgs{overflow:hidden;margin-top:44px;
  -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.orgs-t{display:flex;gap:40px;width:max-content;animation:marq 30s linear infinite;align-items:center;}
.orgs-t span{font-family:var(--serif);font-size:18px;color:var(--muted);white-space:nowrap;}

/* ---------- blog scrapbook cards ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;}
@media(max-width:820px){.posts{grid-template-columns:1fr;max-width:360px;margin-inline:auto;}}
.post{position:relative;text-decoration:none;color:inherit;}
.post .photo{height:200px;border-radius:10px;object-fit:cover;width:100%;
  box-shadow:0 14px 30px -18px rgba(47,74,74,.55);transition:transform .3s;}
.post:hover .photo{transform:translateY(-4px);}
.post .note{position:absolute;right:-10px;top:-14px;background:var(--pale);padding:8px 12px;
  font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink);
  box-shadow:0 8px 16px -9px rgba(47,74,74,.5);transform:rotate(4deg);transition:transform .3s;}
.post:hover .note{transform:rotate(0) translateY(-3px);}
.post .date{font-size:12.5px;color:var(--ad);text-transform:uppercase;letter-spacing:.08em;margin-top:16px;}
.post h3{font-size:21px;margin:6px 0 0;}
.post .read{display:inline-flex;align-items:center;gap:6px;color:var(--teal);font-size:14px;margin-top:10px;}
.post .read .a{transition:transform .2s;}
.post:hover .read .a{transform:translateX(3px);}
.sub-cta{margin-top:46px;background:var(--card);border:1px solid rgba(47,74,74,.12);border-radius:18px;
  padding:30px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.sub-cta h3{font-size:24px;}.sub-cta p{margin:6px 0 0;color:var(--muted);}

/* ---------- research: area cards ---------- */
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px;}
@media(max-width:820px){.areas{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.areas{grid-template-columns:1fr;}}
.area{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:16px;padding:22px 22px 24px;
  transition:transform .25s ease,box-shadow .25s ease;}
.area:hover{transform:translateY(-5px);box-shadow:0 20px 40px -26px rgba(47,74,74,.5);}
.area .tiles{display:flex;gap:4px;margin-bottom:14px;}
.area .tiles i{width:12px;height:12px;border-radius:3px;transition:transform .25s ease;}
.area:hover .tiles i{transform:translateY(-2px);}
.area .tiles i:nth-child(1){background:var(--ad)}.area .tiles i:nth-child(2){background:var(--cfa)}
.area .tiles i:nth-child(3){background:var(--teal)}.area .tiles i:nth-child(4){background:var(--pale)}
.area h3{font-size:19px;font-weight:600;margin-bottom:7px;}
.area p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55;}

/* ---------- research: projects ---------- */
.proj{display:flex;align-items:flex-start;gap:18px;padding:18px 0;border-bottom:1px solid rgba(47,74,74,.1);}
.proj .ptype{flex:none;width:120px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--teal);font-weight:600;padding-top:3px;}
.proj .pmain{flex:1;}
.proj .pmain p{margin:0 0 6px;font-family:var(--serif);font-size:18px;color:var(--ink);}
.proj .plink{display:inline-flex;align-items:center;gap:7px;text-decoration:none;color:var(--ad);font-size:14px;}
.proj .plink .a{transition:transform .2s;}.proj:hover .plink .a{transform:translateX(4px);}
@media(max-width:560px){.proj{flex-direction:column;gap:6px;}.proj .ptype{width:auto;}}

/* ---------- tabs ---------- */
.tabs-nav{display:flex;gap:8px;margin-top:30px;flex-wrap:wrap;}
.tab-btn{background:none;border:1px solid rgba(47,74,74,.2);border-radius:100px;padding:9px 20px;
  font-family:var(--serif);font-size:15px;color:var(--ink);cursor:pointer;transition:.2s;}
.tab-btn:hover{border-color:var(--ad);}
.tab-btn.active{background:var(--emerald);color:#fff;border-color:var(--emerald);}
.tab-panel{display:none;margin-top:24px;}
.tab-panel.active{display:block;animation:fade .4s ease;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.edu{position:relative;padding-left:26px;margin-bottom:20px;}
.edu::before{content:"";position:absolute;left:0;top:7px;width:11px;height:11px;border-radius:50%;background:var(--ad);}
.edu h4{font-size:19px;font-weight:600;}
.edu .when{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.07em;margin:2px 0 5px;}
.edu p{margin:0;color:var(--ink);font-size:15px;}
.awgroup,.exgroup{margin-bottom:24px;}
.awgroup h4,.exgroup h4{font-size:17px;color:var(--ad);margin-bottom:10px;}
.awgroup ul,.exgroup ul{margin:0;padding-left:18px;color:var(--ink);font-size:15px;}
.awgroup li,.exgroup li{margin-bottom:7px;}
.awgroup li em,.exgroup li em{color:var(--muted);font-style:italic;}

/* ---------- portfolio: work cards ---------- */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px;}
.chip{text-decoration:none;border:1px solid rgba(47,74,74,.2);border-radius:100px;padding:9px 18px;
  font-size:14px;color:var(--emerald);transition:.2s;display:inline-flex;align-items:center;gap:8px;}
.chip i{width:9px;height:9px;border-radius:2px;}
.chip:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:28px;}
@media(max-width:680px){.grid{grid-template-columns:1fr;}}
.work{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:16px;padding:24px;
  transition:transform .25s ease,box-shadow .25s ease;display:flex;flex-direction:column;}
.work:hover{transform:translateY(-5px);box-shadow:0 22px 44px -28px rgba(47,74,74,.5);}
.work .type{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:600;}
.work h3{font-size:21px;font-weight:600;margin:8px 0 8px;}
.work p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55;}
.work .meta{margin-top:14px;font-size:12.5px;color:var(--ink);}
.work .meta b{color:var(--ad);font-family:var(--serif);}
.work .link{margin-top:16px;display:inline-flex;align-items:center;gap:7px;text-decoration:none;
  color:var(--ad);font-size:14px;font-family:var(--serif);}
.work .link .a{transition:transform .2s;}.work:hover .link .a{transform:translateX(4px);}
.work.text{border-left:4px solid var(--ad);}
.work.media,.work.video{padding:0;overflow:hidden;}
.work.media .photo,.work.video .thumb{position:relative;height:180px;object-fit:cover;width:100%;display:block;}
.work.media .tape{position:absolute;top:10px;left:18px;width:54px;height:18px;background:rgba(93,135,140,.32);transform:rotate(-5deg);}
.work .body{padding:20px 22px 24px;}
.work.data .viz{display:flex;align-items:flex-end;gap:5px;height:40px;margin-bottom:14px;}
.work.data .viz span{width:12px;border-radius:3px 3px 0 0;background:var(--cfa);}
.work.data .viz span:nth-child(odd){background:var(--teal);}
.work.video .thumb-wrap{position:relative;display:block;}
.work.video .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;
  border-radius:50%;background:rgba(255,253,248,.92);display:flex;align-items:center;justify-content:center;transition:transform .25s ease;}
.work.video:hover .play{transform:translate(-50%,-50%) scale(1.12);}
.work.video .play::after{content:"";border-style:solid;border-width:9px 0 9px 15px;
  border-color:transparent transparent transparent var(--ad);margin-left:4px;}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;margin-top:42px;align-items:start;}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr;gap:30px;}}
.about-h{font-family:var(--serif);font-size:15px;color:var(--ad);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;}
.prompts{list-style:none;margin:0 0 30px;padding:0;}
.prompts li{display:flex;gap:11px;align-items:flex-start;padding:7px 0;font-size:16px;color:var(--ink);}
.prompts li .t{flex:none;width:11px;height:11px;border-radius:3px;margin-top:7px;}
.prompts li:nth-child(1) .t{background:var(--ad)}.prompts li:nth-child(2) .t{background:var(--teal)}.prompts li:nth-child(3) .t{background:var(--cfa)}
.copy{display:inline-flex;align-items:center;gap:11px;background:var(--card);border:1px solid rgba(47,74,74,.16);
  border-radius:100px;padding:11px 9px 11px 18px;font-size:15px;color:var(--ink);cursor:pointer;}
.copy:hover{border-color:var(--ad);}
.copy .ic{background:var(--ad);color:#fff;border-radius:100px;padding:6px 14px;font-size:12.5px;}
.copy.done .ic{background:var(--teal);}
.socials{display:flex;gap:11px;flex-wrap:wrap;margin-top:18px;}
.socials a{text-decoration:none;color:var(--emerald);border:1px solid rgba(47,74,74,.2);border-radius:100px;padding:9px 18px;font-size:14px;transition:.2s;}
.socials a:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);}
.formcard{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:18px;padding:28px;
  box-shadow:0 22px 50px -34px rgba(47,74,74,.45);}
.formcard h3{font-size:22px;margin-bottom:6px;}
.formcard .fnote{color:var(--muted);font-size:13.5px;margin-bottom:20px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:12.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;}
.field input,.field textarea{width:100%;background:var(--paper);border:1px solid rgba(47,74,74,.18);border-radius:10px;
  padding:12px 14px;font-family:var(--sans);font-size:15px;color:var(--ink);transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ad);box-shadow:0 0 0 3px rgba(173,97,89,.15);}
.field textarea{resize:vertical;min-height:110px;}
.signoff{text-align:center;padding:20px 0 0;}
.signoff .sg{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:16px;}
.sig{display:inline-block;text-align:center;margin-top:4px;}
.sig-n{font-family:var(--serif);font-style:italic;font-weight:500;font-size:38px;color:var(--ink);}
.sig-fl{display:block;width:170px;height:20px;margin:-2px auto 0;overflow:visible;}
.sig-fl path{stroke-dasharray:300;stroke-dashoffset:300;animation:sigdraw 1.3s ease .3s forwards;}
@keyframes sigdraw{to{stroke-dashoffset:0;}}

/* ---------- footer ---------- */
footer{margin-top:80px;border-top:1px solid rgba(47,74,74,.1);padding:40px 0;}
.foot-in{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.foot-in .azadi{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;}
.foot-in .azadi b{color:var(--ad);}
.foot-in small{color:var(--muted);font-size:13px;}

/* ---------- back to top ---------- */
#top{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;background:var(--emerald);
  color:#fff;border:none;cursor:pointer;font-size:20px;opacity:0;transform:translateY(12px);transition:.3s;z-index:40;}
#top.show{opacity:1;transform:none;}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;}
  .reveal{opacity:1;transform:none;}
  .mosaic-art i{opacity:1;transform:none;}
  .tl-fill{height:100% !important;}.tl-item{opacity:1;}
  .stat .spark polyline{stroke-dashoffset:0;}
  .sig-fl path{stroke-dashoffset:0;}
}

/* ---------- two-photo strip (homepage) ---------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px;}
@media(max-width:680px){.duo{grid-template-columns:1fr;}}
.duo figure{margin:0;}
.duo img{border-radius:14px;width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:0 16px 32px -22px rgba(47,74,74,.5);}
.duo figcaption{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;margin-top:10px;}

/* ====================================================
   v2 — pushed aesthetic, icons, embeds, timeline reframe
   ==================================================== */

/* numbered, editorial section kickers */
.kicker .num{color:var(--cfa);margin-right:10px;font-family:var(--serif);font-style:italic;
  font-weight:600;letter-spacing:0;text-transform:none;font-size:15px;}

/* longer editorial body copy + drop cap */
.body-copy{max-width:42em;font-size:17px;color:var(--ink);}
.body-copy p{margin:0 0 16px;}
.body-copy a{color:var(--ad);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}
.dropcap::first-letter{font-family:var(--serif);font-weight:600;color:var(--ad);
  font-size:3.6em;line-height:.8;float:left;margin:10px 13px -2px 0;}

/* bigger pull quote with decorative mark */
.pquote{position:relative;}
.pquote.xl{font-size:clamp(27px,4.4vw,42px);max-width:16em;margin-top:54px;}
.pquote .qmark{position:absolute;left:-8px;top:-52px;font-family:var(--serif);font-size:110px;
  color:var(--pale);line-height:1;pointer-events:none;z-index:-1;}

/* hero refinements */
.hero .meta-line{display:flex;flex-wrap:wrap;gap:8px 22px;margin-top:20px;font-size:14px;color:var(--muted);}
.hero .meta-line .mi{display:inline-flex;align-items:center;gap:7px;}
.hero .meta-line .mi b{font-family:var(--serif);font-weight:600;color:var(--emerald);font-style:normal;}
.hero .meta-line .mi i{width:7px;height:7px;border-radius:2px;background:var(--cfa);}
.photo-frame{position:relative;display:inline-block;}
.photo-frame .t{position:absolute;width:38px;height:38px;border-radius:8px;z-index:0;}
.photo-frame .t1{background:var(--cfa);top:-18px;left:-18px;}
.photo-frame .t2{background:var(--teal);bottom:-16px;right:-16px;}
.photo-frame .t3{background:var(--pale);bottom:40px;left:-24px;}
.photo-frame img{position:relative;z-index:1;}

/* ---- icons ---- */
.ic-svg{width:20px;height:20px;display:block;}
.iconrow{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(47,74,74,.2);color:var(--emerald);text-decoration:none;transition:.22s;
  font-family:var(--serif);font-size:21px;line-height:1;}
.iconbtn:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);transform:translateY(-3px);}
.ilink{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink);
  padding:13px 0;border-bottom:1px solid rgba(47,74,74,.1);transition:padding .2s;}
.ilink:hover{padding-left:6px;}
.ilink .ib{flex:none;width:46px;height:46px;border-radius:13px;background:var(--card);
  border:1px solid rgba(47,74,74,.14);display:flex;align-items:center;justify-content:center;
  color:var(--ad);transition:.22s;font-family:var(--serif);font-size:19px;}
.ilink:hover .ib{background:var(--ad);color:#fff;border-color:var(--ad);}
.ilink .lab b{display:block;font-family:var(--serif);font-size:16px;color:var(--ink);font-weight:500;}
.ilink .lab span{font-size:13px;color:var(--muted);}
.ilink .go{margin-left:auto;color:var(--cfa);transition:transform .2s;}
.ilink:hover .go{transform:translateX(4px);color:var(--ad);}

/* ---- responsive video embeds ---- */
.embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  box-shadow:0 22px 48px -28px rgba(47,74,74,.6);background:var(--emerald);}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.embed-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:28px;}
@media(max-width:760px){.embed-grid{grid-template-columns:1fr;}}
.embed-cap{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;margin-top:11px;}

/* ---- timeline reframe (most-recent-first, made explicit) ---- */
.tl-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:14px;margin-top:8px;}
.tl-head .pill{background:var(--ad);color:#fff;border-radius:100px;padding:4px 14px;font-family:var(--serif);font-size:13px;}
.tl .dur{display:inline-block;background:rgba(93,135,140,.13);color:var(--teal);border-radius:100px;
  padding:2px 11px;font-size:11px;margin-left:9px;vertical-align:middle;letter-spacing:0;text-transform:none;}
.tl-end{position:relative;padding:18px 0 4px;}
.tl-end .tl-dot{position:absolute;left:-38px;top:22px;width:15px;height:15px;border-radius:50%;
  background:var(--cfa);border:2px solid var(--cfa);}
.tl-end .role{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--muted);}

/* link list (projects, writing) */
.linklist{margin-top:26px;}
.linkrow{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid rgba(47,74,74,.1);
  text-decoration:none;color:inherit;transition:padding .2s;}
.linkrow:hover{padding-left:6px;}
.linkrow .lr-type{flex:none;width:120px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--teal);font-weight:600;}
.linkrow .lr-main{flex:1;font-family:var(--serif);font-size:18px;color:var(--ink);}
.linkrow .lr-main em{display:block;font-family:var(--sans);font-style:normal;font-size:13.5px;color:var(--muted);margin-top:3px;}
.linkrow .lr-go{color:var(--ad);transition:transform .2s;}
.linkrow:hover .lr-go{transform:translateX(4px);}
@media(max-width:560px){.linkrow{flex-wrap:wrap;gap:4px;}.linkrow .lr-type{width:100%;}}

/* ====================================================
   v3 — accessibility, dark mode, responsive
   ==================================================== */

/* contrast bumps for readability (override earlier tokens) */
:root{ --muted:#586A66; --teal:#4F757A; }

/* visible keyboard focus everywhere */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:3px solid var(--ad);outline-offset:2px;border-radius:6px;}

/* fluid side gutters — never pressed to the edge, never too wide */
.wrap{padding:0 clamp(20px,5vw,44px);}

/* nav tools (theme toggle + mobile menu button, injected by JS) */
.nav-right{display:flex;align-items:center;gap:18px;}
.theme-toggle,.nav-toggle{width:42px;height:42px;border:1px solid rgba(47,74,74,.2);
  background:none;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.theme-toggle{border-radius:50%;}
.nav-toggle{border-radius:12px;flex-direction:column;gap:4px;display:none;}
.theme-toggle:hover,.nav-toggle:hover{border-color:var(--ad);color:var(--ad);}
.theme-toggle svg{width:20px;height:20px;}
.nav-toggle span{display:block;width:18px;height:2px;background:currentColor;border-radius:2px;}

/* tablet */
@media(max-width:900px){ .hero-grid{grid-template-columns:1fr;gap:34px;} }

/* phone */
@media(max-width:760px){
  .nav-toggle{display:inline-flex;}
  .nav-links{position:absolute;top:66px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid rgba(47,74,74,.12);padding:6px 24px 16px;display:none;
    box-shadow:0 22px 34px -24px rgba(0,0,0,.35);}
  nav.open .nav-links{display:flex;}
  .nav-links li{width:100%;}
  .nav-links a{display:block;padding:13px 0;font-size:16px;}
  .nav-links a::after{display:none;}
  .nav-cta{display:inline-block;width:auto;margin-top:8px;}
  .hero{padding:46px 0 38px;}
  .sec{padding:24px 0;}
  .mdiv{padding:34px 0;}
  .contact-grid{gap:26px;}
  .stats{gap:12px;}
}
@media(max-width:430px){
  .stats{grid-template-columns:1fr;}
  .areas{grid-template-columns:1fr;}
  .iconrow{gap:10px;}
}

/* ===== DARK MODE ===== */
html[data-theme="dark"]{
  --paper:#172221; --card:#202d2b; --ink:#ECE3DF; --muted:#A2B2AE;
  --ad:#DD8E84; --teal:#86B6BB;
}
html[data-theme="dark"] body::before{opacity:.3;}
html[data-theme="dark"] nav{background:rgba(23,34,33,.85);border-bottom-color:rgba(236,227,223,.1);}
html[data-theme="dark"] .nav-links{background:var(--paper);}
html[data-theme="dark"] .stat,html[data-theme="dark"] .area,html[data-theme="dark"] .work,
html[data-theme="dark"] .formcard,html[data-theme="dark"] .copy,html[data-theme="dark"] .tag,
html[data-theme="dark"] .term .tip,html[data-theme="dark"] .sub-cta,
html[data-theme="dark"] .ilink .ib{border-color:rgba(236,227,223,.14);}
html[data-theme="dark"] .btn-outline,html[data-theme="dark"] .chip,html[data-theme="dark"] .socials a,
html[data-theme="dark"] .iconbtn,html[data-theme="dark"] .lnk,html[data-theme="dark"] .tab-btn,
html[data-theme="dark"] .theme-toggle,html[data-theme="dark"] .nav-toggle{color:var(--ink);border-color:rgba(236,227,223,.28);}
html[data-theme="dark"] .ilink,html[data-theme="dark"] .linkrow,html[data-theme="dark"] .proj,
html[data-theme="dark"] footer,html[data-theme="dark"] .field input,html[data-theme="dark"] .field textarea{
  border-color:rgba(236,227,223,.12);}
html[data-theme="dark"] .field input,html[data-theme="dark"] .field textarea{background:#172221;color:var(--ink);}
html[data-theme="dark"] .tl-track{background:rgba(236,227,223,.16);}
html[data-theme="dark"] .tl-dot{background:var(--card);}

/* ====================================================
   v4 — layout fixes + static experience + skills
   ==================================================== */
html,body{overflow-x:hidden;max-width:100%;}
.wrap{max-width:1080px;padding-inline:clamp(22px,6vw,56px);}
.tl-fill{display:none;} /* retired the scroll-fill timeline */

/* static experience list */
.xp{margin-top:30px;border-left:2px solid rgba(47,74,74,.14);}
html[data-theme="dark"] .xp{border-left-color:rgba(236,227,223,.16);}
.xp-item{position:relative;padding:0 0 36px 30px;}
.xp-item::before{content:"";position:absolute;left:-8px;top:8px;width:14px;height:14px;border-radius:50%;
  background:var(--ad);box-shadow:0 0 0 4px var(--paper);}
.xp-item:last-child{padding-bottom:4px;}
.xp-role{font-family:var(--serif);font-size:22px;font-weight:600;line-height:1.2;}
.xp-org{color:var(--ad);font-size:15.5px;font-weight:600;margin-top:3px;}
.xp-meta{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;margin:5px 0 12px;}
.xp-meta .dot{margin:0 8px;color:var(--cfa);}
.xp-desc{color:var(--ink);font-size:15.5px;max-width:48em;margin:0 0 12px;}
.xp-item ul{margin:0 0 14px;padding-left:18px;color:var(--ink);font-size:15px;max-width:48em;}
.xp-item li{margin-bottom:7px;}
.xp-item li::marker{color:var(--cfa);}
.xp-item li b{color:var(--ad);font-family:var(--serif);}
.xp-skills{display:flex;flex-wrap:wrap;gap:7px;}
.xp-skills span{font-size:12px;background:rgba(93,135,140,.12);color:var(--teal);border-radius:100px;padding:3px 12px;}
html[data-theme="dark"] .xp-skills span{background:rgba(134,182,185,.16);}

/* skills section */
.skills{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:30px;}
@media(max-width:680px){.skills{grid-template-columns:1fr;}}
.skillgroup{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:16px;padding:22px 24px;}
html[data-theme="dark"] .skillgroup{border-color:rgba(236,227,223,.14);}
.skillgroup h3{font-size:14.5px;color:var(--ad);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-family:var(--serif);}
.skillgroup ul{list-style:none;margin:0;padding:0;}
.skillgroup li{padding:7px 0;border-bottom:1px solid rgba(47,74,74,.07);font-size:15px;color:var(--ink);}
html[data-theme="dark"] .skillgroup li{border-bottom-color:rgba(236,227,223,.08);}
.skillgroup li:last-child{border-bottom:none;}

/* compact education */
.edu-c{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:26px;}
@media(max-width:760px){.edu-c{grid-template-columns:1fr;}}
.edu-c .e{background:var(--card);border:1px solid rgba(47,74,74,.1);border-radius:14px;padding:18px 20px;}
html[data-theme="dark"] .edu-c .e{border-color:rgba(236,227,223,.14);}
.edu-c .e h4{font-size:16px;font-weight:600;}
.edu-c .e .w{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em;margin:4px 0 7px;}
.edu-c .e p{margin:0;font-size:14px;color:var(--ink);}

/* ====================================================
   v5 — scrapbook, handwriting, alive, consistent buttons
   ==================================================== */
:root{ --hand:'Caveat', 'Bradley Hand', cursive; }

/* consistent button system (fixes uneven button sizes) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:50px;
  padding:13px 28px;border-radius:100px;font-family:var(--serif);font-size:16px;font-weight:500;
  text-decoration:none;cursor:pointer;border:2px solid transparent;line-height:1;
  transition:transform .2s ease,background .2s,color .2s,border-color .2s,box-shadow .2s;}
.btn .a{transition:transform .2s;}
.btn:hover .a{transform:translateX(4px);}
.btn-primary{background:var(--ad);color:#fff;box-shadow:0 10px 22px -12px rgba(173,97,89,.7);}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{background:none;border-color:var(--emerald);color:var(--ink);}
html[data-theme="dark"] .btn-ghost{border-color:rgba(236,227,223,.4);}
.btn-ghost:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);}

/* gentle life */
.float{animation:floaty 6.5s ease-in-out infinite;}
.float2{animation:floaty 7.5s ease-in-out infinite .8s;}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--rot,0deg));}50%{transform:translateY(-10px) rotate(var(--rot,0deg));}}
.reveal-rot{opacity:0;transform:translateY(26px) rotate(-2deg);transition:opacity .7s ease,transform .7s ease;}
.reveal-rot.in{opacity:1;transform:none;}

/* polaroid */
.polaroid{position:relative;background:#fffdf9;padding:13px 13px 0;border-radius:3px;
  box-shadow:0 16px 34px -16px rgba(47,74,74,.55);display:inline-block;max-width:100%;
  transform:rotate(var(--rot,-2deg));transition:transform .35s ease,box-shadow .35s ease;}
.polaroid img{display:block;width:100%;border-radius:1px;background:var(--pale);}
.polaroid .cap{font-family:var(--hand);font-size:23px;color:#4a4340;text-align:center;padding:9px 6px 15px;line-height:1.1;}
.polaroid:hover{transform:rotate(0) translateY(-4px) scale(1.015);box-shadow:0 24px 44px -18px rgba(47,74,74,.6);}

/* washi tape + pins (placed INSIDE relative parents so they never clip the page) */
.tape{position:absolute;width:84px;height:24px;background:rgba(207,162,157,.6);
  box-shadow:0 2px 5px rgba(0,0,0,.07);left:50%;top:-11px;transform:translateX(-50%) rotate(-4deg);}
.tape.t-teal{background:rgba(93,135,140,.5);}
.pin{position:absolute;width:16px;height:16px;border-radius:50%;left:50%;top:-7px;transform:translateX(-50%);
  background:radial-gradient(circle at 34% 30%,#e2a39b,#A1564E 62%);box-shadow:0 3px 7px rgba(0,0,0,.35);z-index:3;}

/* sticky note */
.stickynote{position:relative;display:inline-block;background:var(--pale);color:#4a3f3d;
  font-family:var(--hand);font-size:22px;line-height:1.25;padding:18px 22px;max-width:260px;
  box-shadow:0 12px 24px -14px rgba(47,74,74,.5);transform:rotate(-2.5deg);}
.stickynote::before{content:"";position:absolute;left:50%;top:-9px;transform:translateX(-50%) rotate(6deg);
  width:70px;height:20px;background:rgba(255,255,255,.45);}

/* scrapbook collage grid */
.collage{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px;margin-top:34px;align-items:start;}
.collage .polaroid{width:100%;}
.collage > div:nth-child(1){--rot:-3deg;}
.collage > div:nth-child(2){--rot:2deg;margin-top:22px;}
.collage > div:nth-child(3){--rot:-1.5deg;}
@media(max-width:760px){.collage{grid-template-columns:1fr 1fr;gap:24px 18px;}}
@media(max-width:480px){.collage{grid-template-columns:1fr;max-width:300px;margin-inline:auto;}.collage > div{--rot:-2deg !important;margin-top:0 !important;}}

/* fun-fact scratch cards */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:30px;}
@media(max-width:560px){.facts{grid-template-columns:1fr;}}
.fact{position:relative;border-radius:16px;min-height:118px;overflow:hidden;
  border:1px solid rgba(47,74,74,.12);background:var(--card);}
html[data-theme="dark"] .fact{border-color:rgba(236,227,223,.14);}
.fact .answer{padding:22px 24px;font-family:var(--serif);font-size:16.5px;color:var(--ink);line-height:1.4;height:100%;display:flex;align-items:center;}
.fact .answer b{color:var(--ad);}
.fact .cover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;color:#fff;font-family:var(--hand);font-size:24px;
  background:repeating-linear-gradient(45deg,#5D878C,#5D878C 9px,#54797e 9px,#54797e 18px);
  transition:opacity .5s ease,transform .5s ease;}
.fact .cover::after{content:"✺";font-size:18px;opacity:.9;}
.fact.revealed .cover{opacity:0;transform:scale(.97);pointer-events:none;}

/* a touch more air between stacked scrapbook bits on mobile */
@media(max-width:760px){ .stickynote{font-size:20px;} }

/* ====================================================
   v6 — quieter azadi, deeper scrapbook, more alive
   ==================================================== */
/* faintest paper-fiber texture — adds depth, stays out of the way */
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.08;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='220'%20height='220'%3E%3Cfilter%20id='p'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.85'%20numOctaves='2'%20stitchTiles='stitch'/%3E%3CfeColorMatrix%20type='saturate'%20values='0'/%3E%3C/filter%3E%3Crect%20width='100%25'%20height='100%25'%20filter='url(%23p)'/%3E%3C/svg%3E");
  background-size:220px 220px;}
html[data-theme="dark"] body::after{mix-blend-mode:screen;opacity:.06;}

/* gently animated mosaic dividers */
@media (prefers-reduced-motion: no-preference){
  .mdiv i{animation:tilebob 3.4s ease-in-out infinite;}
  .mdiv i:nth-child(1){animation-delay:0s}
  .mdiv i:nth-child(2){animation-delay:.12s}
  .mdiv i:nth-child(3){animation-delay:.24s}
  .mdiv i:nth-child(4){animation-delay:.36s}
  .mdiv i:nth-child(5){animation-delay:.48s}
  @keyframes tilebob{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(9deg)}}
}

/* real scratch-off cards */
.scratch-canvas{position:absolute;inset:0;cursor:grab;touch-action:none;border-radius:16px;}
.scratch-canvas:active{cursor:grabbing;}
.fact.done .scratch-canvas{transition:opacity .45s ease;opacity:0;pointer-events:none;}
.cover-simple{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:#5D878C;color:#fff;font-family:var(--hand);font-size:22px;cursor:pointer;}

/* ====================================================
   v7 — draggable polaroids + "currently" desk corner
   ==================================================== */
.polaroid.grabbing{cursor:grabbing;box-shadow:0 32px 54px -20px rgba(47,74,74,.62);z-index:5;}
.currently{display:flex;flex-wrap:wrap;gap:20px;margin-top:30px;}
.notecard{position:relative;background:var(--card);border:1px solid rgba(47,74,74,.12);border-radius:10px;
  padding:20px 22px;max-width:240px;box-shadow:0 14px 28px -18px rgba(47,74,74,.5);transform:rotate(var(--rot,-1.5deg));}
html[data-theme="dark"] .notecard{border-color:rgba(236,227,223,.14);}
.notecard .pin{top:-7px;}
.notecard .lab{font-family:var(--serif);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ad);}
.notecard .val{font-family:var(--hand);font-size:23px;color:var(--ink);line-height:1.2;margin-top:6px;}
.currently > div:nth-child(1){--rot:-2deg}
.currently > div:nth-child(2){--rot:1.5deg}
.currently > div:nth-child(3){--rot:-1deg}
@media(max-width:560px){.currently > div{--rot:-1.5deg!important;}}

/* v8 — keep handwriting to the genuinely hand-made bits (post-its, photo captions) */
.notecard .val{font-family:var(--serif);font-style:italic;font-size:19px;font-weight:500;}
/* connective "what's next" hand-off */
.whatsnext{text-align:center;}
.whatsnext .sub{margin-inline:auto;}

/* ====================================================
   v9 — hover definitions, click delight, deeper scrapbook
   ==================================================== */
/* hover / tap definitions */
.term{position:relative;border-bottom:1.6px dotted var(--ad);cursor:help;font-weight:500;color:inherit;}
.term::after{content:attr(data-def);position:absolute;left:50%;bottom:calc(100% + 12px);
  transform:translateX(-50%) translateY(6px) scale(.97);width:max-content;max-width:230px;
  background:var(--ink);color:var(--paper);padding:10px 13px;border-radius:11px;
  font:400 13.5px/1.5 var(--sans);text-align:left;box-shadow:0 16px 32px -12px rgba(0,0,0,.45);
  opacity:0;visibility:hidden;transition:.18s ease;z-index:70;pointer-events:none;white-space:normal;}
.term::before{content:"";position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%);
  border:7px solid transparent;border-top-color:var(--ink);opacity:0;visibility:hidden;transition:.18s ease;z-index:70;}
.term:hover::after,.term:focus-visible::after,.term.open::after{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0) scale(1);}
.term:hover::before,.term:focus-visible::before,.term.open::before{opacity:1;visibility:visible;}

/* click ripple */
.btn{position:relative;overflow:hidden;}
.ripple{position:absolute;border-radius:50%;background:currentColor;opacity:.26;transform:scale(0);
  animation:rip .6s ease-out;pointer-events:none;}
@keyframes rip{to{transform:scale(2.6);opacity:0;}}
.confit{position:fixed;width:10px;height:10px;border-radius:2px;z-index:999;pointer-events:none;}

/* "many hats" facets — diversity of self */
.facets{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:26px;}
.facet{position:relative;background:var(--card);border:1px solid rgba(47,74,74,.10);border-radius:14px;
  padding:22px 22px 20px;box-shadow:0 16px 34px -22px rgba(47,74,74,.55);transform:rotate(var(--rot,0deg));
  transition:transform .25s ease, box-shadow .25s ease;}
.facet:hover{transform:rotate(0) translateY(-3px);box-shadow:0 24px 46px -22px rgba(47,74,74,.6);}
.facet:nth-child(1){--rot:-1.3deg}.facet:nth-child(2){--rot:1deg}
.facet:nth-child(3){--rot:1.2deg}.facet:nth-child(4){--rot:-1deg}
.facet .tiles{display:flex;gap:4px;margin-bottom:12px}
.facet .tiles i{width:11px;height:11px;border-radius:2px}
.facet .tiles i:nth-child(1){background:var(--ad)}.facet .tiles i:nth-child(2){background:var(--cfa)}
.facet .tiles i:nth-child(3){background:var(--teal)}.facet .tiles i:nth-child(4){background:var(--pale)}
.facet h3{font-size:20px;margin-bottom:7px}
.facet p{margin:0;color:var(--muted);font-size:15px;line-height:1.55}
.facet .imp{display:inline-block;margin-top:11px;font-family:var(--serif);font-style:italic;color:var(--ad);font-size:15px}
@media(max-width:640px){.facets{grid-template-columns:1fr}.facet{--rot:0deg!important}}
@media (prefers-reduced-motion: reduce){.ripple{display:none}}

/* --- homepage v2 additions --- */
.flink{display:inline-block;margin-top:12px;font-family:var(--sans);font-weight:600;font-size:.92rem;color:var(--ad);text-decoration:none}
.flink .a{display:inline-block;transition:transform .2s}
.flink:hover{color:var(--emerald)}
.flink:hover .a{transform:translateX(3px)}
.now{font-family:var(--sans);color:var(--muted);font-size:1rem}
.now .rot{color:var(--ad);font-weight:600}

/* --- Drunken Hour display accent (self-hosted; add fonts/drunken-hour.otf) --- */
@font-face{
  font-family:'Drunken Hour';
  src:url('../fonts/drunken-hour.woff2') format('woff2'),
      url('../fonts/drunken-hour.otf') format('opentype');
  font-display:swap;
}
.mosaic-type{font-family:'Drunken Hour','Fraunces',Georgia,serif;font-weight:400;letter-spacing:.01em;}
