/* ============================================================
   POSTER.CSS — Khushvi Bamrolia · vintage Indian bazaar showcase
   Bottle green · cream · brick red · turmeric · terracotta
   ============================================================ */

/* ---------- TOKENS ---------- */
:root {
  --cream:   #f1e4c3;
  --cream-2: #e9d8af;
  --cream-hi:#fbf4df;
  --green:   #1c6b43;
  --green-d: #0d472b;
  --green-ink:#0a3a22;
  --red:     #c5392a;
  --red-d:   #9e2b20;
  --turmeric:#e3a52e;
  --terra:   #c4673a;
  --ink:     #2a1c10;
  --ink-soft:#5b4226;
  --paper-line: rgba(42,28,16,0.16);

  --accent: var(--red);

  --fat:    "Anton", Impact, sans-serif;        /* fat condensed latin */
  --deva:   "Yatra One", system-ui, sans-serif; /* fat devanagari      */
  --disp:   "Rozha One", Georgia, serif;        /* high-contrast both   */
  --script: "Pinyon Script", cursive;           /* elegant accent       */
  --body:   "Spectral", Georgia, serif;
  --mono:   "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1180px;
  --pad: clamp(18px, 4.5vw, 60px);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--body);
  font-size: 18px;
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body.loading { overflow: hidden; height: 100vh; }
::selection { background: var(--red); color: var(--cream-hi); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ---------- GLOBAL PAPER TEXTURE ---------- */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: multiply; opacity: var(--grain, 0.06);
}
body.no-marquee .marquee .track { animation: none !important; transform: none !important; }
body.no-spin .hero-medallion .ring { animation: none !important; }
/* warm grain vignette */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 9998; pointer-events: none;
  background: radial-gradient(120% 100% at 50% 30%, transparent 60%, rgba(60,30,10,0.10) 100%);
}

body.flat-shadows .product, body.flat-shadows .postcard, body.flat-shadows .poster { box-shadow: none; }
body.flat-shadows .stat { box-shadow: 2px 2px 0 var(--green); }
body.flat-shadows .mf-sticker { box-shadow: 2px 2px 0 var(--green-d); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }

/* reusable halftone helper (set --dot color) */
.halftone {
  background-image: radial-gradient(var(--dot, rgba(42,28,16,0.5)) 1.4px, transparent 1.5px);
  background-size: 8px 8px;
}

/* ornament SVG sprite hidden */
.svg-defs { position: absolute; width: 0; height: 0; overflow: hidden; }
.orn { fill: currentColor; display: inline-block; vertical-align: middle; }

/* ---------- REVEAL ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.2,.8,.3,1), transform .8s cubic-bezier(.2,.8,.3,1); }
.reveal.show { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1 !important; transform: none !important; } }

/* ============================================================
   LOADER — stamp-framed Devanglish hello
   ============================================================ */
#loader {
  position: fixed; inset: 0; z-index: 1000; background: var(--green);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .8s ease, visibility .8s ease;
}
#loader.done { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-stamp {
  position: relative; width: min(86vw, 440px); aspect-ratio: 3/3.5;
  background: var(--cream);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
  padding: 30px;
  /* perforated stamp edge */
  --p: 11px;
  -webkit-mask:
    radial-gradient(circle var(--p) at 0 50%, transparent 99%, #000) ,
    radial-gradient(circle var(--p) at 100% 50%, transparent 99%, #000);
  box-shadow: 0 30px 70px -20px rgba(0,0,0,.5);
}
.loader-stamp::before {
  content: ""; position: absolute; inset: 14px; border: 2.5px solid var(--green);
  outline: 1px solid var(--green); outline-offset: 3px;
}
.loader-perf {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(circle 8px at 50% 0, var(--green) 96%, transparent 0) 0 0/26px 26px repeat-x,
    radial-gradient(circle 8px at 50% 100%, var(--green) 96%, transparent 0) 0 100%/26px 26px repeat-x,
    radial-gradient(circle 8px at 0 50%, var(--green) 96%, transparent 0) 0 0/26px 26px repeat-y,
    radial-gradient(circle 8px at 100% 50%, var(--green) 96%, transparent 0) 100% 0/26px 26px repeat-y;
  -webkit-mask: linear-gradient(#000,#000);
  mix-blend-mode: normal;
}
.loader-mark { font-family: var(--mono); font-size: 11px; letter-spacing: .25em; color: var(--green); text-transform: uppercase; position: relative; z-index: 2; }
.loader-eyebrow { font-family: var(--mono); font-size: 10px; letter-spacing: .3em; color: var(--terra); text-transform: uppercase; margin-bottom: 8px; position: relative; z-index: 2; }
#loader-word {
  font-family: var(--disp); font-size: clamp(46px, 13vw, 80px); line-height: .95; color: var(--red);
  position: relative; z-index: 2; text-align: center; min-height: 1.1em;
}
#loader-word.flick { animation: flick .26s ease; }
@keyframes flick { 0% { opacity: 0; transform: translateY(8px) rotate(-2deg); } 45% { opacity: 1; transform: none; } }
#loader-lang { font-family: var(--mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); position: relative; z-index: 2; margin-top: 4px; }
.loader-track { position: relative; z-index: 2; width: 150px; height: 5px; background: var(--cream-2); border: 1px solid var(--green); margin-top: 26px; }
#loader-bar { height: 100%; background: var(--turmeric); transform: scaleX(0); transform-origin: left; transition: transform .26s ease; }
.loader-leaf { position: absolute; color: var(--green); z-index: 2; width: 34px; }
.loader-leaf.tl { top: 26px; left: 26px; transform: rotate(0deg); }
.loader-leaf.tr { top: 26px; right: 26px; transform: scaleX(-1); }
.loader-leaf.bl { bottom: 26px; left: 26px; transform: scaleY(-1); }
.loader-leaf.br { bottom: 26px; right: 26px; transform: scale(-1,-1); }

/* ============================================================
   NAV
   ============================================================ */
header.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 14px var(--pad) 0; color: var(--cream);
  transition: transform .4s ease; pointer-events: none;
}
header.nav .nav-inner {
  pointer-events: auto; display: flex; align-items: center; justify-content: space-between;
  max-width: var(--maxw); margin: 0 auto; height: 56px;
  padding: 0 10px 0 20px;
  background: var(--green); border: 2px solid var(--turmeric); border-radius: 16px;
  box-shadow: 0 16px 40px -18px rgba(13,71,43,.75);
}
.brand { font-family: var(--disp); font-size: 22px; letter-spacing: .01em; display: flex; align-items: center; gap: 9px; color: var(--cream-hi); }
.brand .seal { width: 22px; height: 22px; color: var(--turmeric); }
.nav-links { display: flex; gap: 26px; align-items: center; }
.nav-links a { font-family: var(--mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--cream-2); transition: color .2s; }
.nav-links a:hover { color: var(--turmeric); }
.nav-links a.cta { color: var(--green); background: var(--turmeric); padding: 6px 12px; border-radius: 2px; font-weight: 600; }
.nav-links a.cta:hover { background: var(--cream-hi); }
@media (max-width: 720px) { .nav-links a:not(.cta) { display: none; } }

/* ============================================================
   HERO POSTER
   ============================================================ */
.hero { padding: 96px var(--pad) 40px; display: flex; justify-content: center; }
.poster {
  position: relative; width: min(100%, 1000px); background: var(--cream);
  border: 3px solid var(--green); outline: 2px solid var(--green); outline-offset: 6px;
  padding: clamp(22px, 4vw, 48px) clamp(20px, 4vw, 56px) clamp(28px, 4vw, 44px);
  box-shadow: 0 40px 90px -40px rgba(20,60,30,.6);
  overflow: hidden;
}
.poster.green-bg { background: var(--green); color: var(--cream); border-color: var(--turmeric); outline-color: var(--turmeric); }
/* corner ornaments */
.poster-corner { position: absolute; width: 56px; height: 56px; color: var(--terra); }
.poster-corner.tl { top: 10px; left: 10px; }
.poster-corner.tr { top: 10px; right: 10px; transform: scaleX(-1); }
.poster-corner.bl { bottom: 10px; left: 10px; transform: scaleY(-1); }
.poster-corner.br { bottom: 10px; right: 10px; transform: scale(-1,-1); }

.hero-eyebrow {
  text-align: center; font-family: var(--mono); font-size: clamp(10px, 1.4vw, 13px);
  letter-spacing: .34em; text-transform: uppercase; color: var(--green);
  display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 6px;
}
.hero-eyebrow .ln { height: 1px; width: clamp(20px, 6vw, 60px); background: currentColor; }

/* the big arch headline */
.hero-arch { text-align: center; position: relative; }
.hero-pre { font-family: var(--script); font-size: clamp(28px, 6vw, 58px); color: var(--terra); line-height: .8; transform: rotate(-3deg); display: inline-block; margin-bottom: 2px; }
.hero-name {
  font-family: var(--disp); font-weight: 400;
  font-size: clamp(58px, 15vw, 168px); line-height: .86; color: var(--red);
  letter-spacing: -.01em; text-transform: uppercase;
  text-shadow: 3px 3px 0 var(--turmeric);
}
.hero-name .deva { font-family: var(--deva); text-transform: none; text-shadow: 3px 3px 0 var(--green); }
.hero-name .last { display: block; color: var(--green); text-shadow: 3px 3px 0 var(--terra); }
.hero-q { color: var(--turmeric); -webkit-text-stroke: 2px var(--green); }

.hero-sub {
  max-width: 60ch; margin: 22px auto 0; text-align: center; font-size: clamp(15px, 1.7vw, 20px);
  color: var(--ink-soft); line-height: 1.5;
}
.hero-sub strong { color: var(--red); font-weight: 600; }

.hero-banner {
  margin: 26px auto 0; max-width: 720px; background: var(--red); color: var(--cream-hi);
  font-family: var(--mono); font-size: clamp(10px, 1.4vw, 13px); letter-spacing: .12em; text-transform: uppercase;
  text-align: center; padding: 9px 16px; display: flex; flex-wrap: wrap; gap: 8px 22px; justify-content: center;
  position: relative;
}
.hero-banner b { color: var(--turmeric); }

.hero-photo-row { display: flex; align-items: center; justify-content: center; gap: clamp(16px, 4vw, 50px); margin-top: 30px; flex-wrap: wrap; }
.hero-medallion {
  position: relative; width: clamp(150px, 26vw, 230px); aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.hero-medallion image-slot { width: 76%; height: 76%; border-radius: 50%; }
.hero-medallion .hero-portrait { width: 78%; height: 78%; border-radius: 50%; object-fit: cover; object-position: 50% 30%; border: 3px solid var(--green); box-shadow: 0 8px 24px -8px rgba(20,60,30,.55); }
.hero-medallion .ring { position: absolute; inset: 0; color: var(--green); animation: spin 60s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.hero-tags { display: flex; flex-direction: column; gap: 12px; }
.price-tag {
  font-family: var(--mono); font-size: 13px; color: var(--ink); background: var(--turmeric);
  padding: 8px 14px 8px 26px; position: relative; clip-path: polygon(12px 0, 100% 0, 100% 100%, 12px 100%, 0 50%);
  letter-spacing: .04em; box-shadow: 3px 3px 0 rgba(42,28,16,.25);
}
.price-tag b { color: var(--red); }

.scroll-cue { text-align: center; margin-top: 26px; font-family: var(--mono); font-size: 11px; letter-spacing: .25em; text-transform: uppercase; color: var(--green); }
.scroll-cue .arr { display: block; margin: 6px auto 0; width: 1px; height: 30px; background: var(--green); animation: drop 1.8s infinite; }
@keyframes drop { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section.band { padding: clamp(54px, 8vw, 96px) 0; position: relative; }
.band.green { background: var(--green); color: var(--cream); }
.band.red { background: var(--red); color: var(--cream-hi); }
.band.turmeric { background: var(--turmeric); color: var(--ink); }

.band-rule { height: 14px; background-repeat: repeat-x; }
.rule-zig { background-image: linear-gradient(135deg, var(--green) 25%, transparent 25%), linear-gradient(225deg, var(--green) 25%, transparent 25%); background-size: 18px 14px; background-position: 0 0; }

.sec-head { display: flex; align-items: flex-end; gap: 16px; margin-bottom: 40px; flex-wrap: wrap; }
.sec-kicker {
  font-family: var(--deva); font-size: clamp(34px, 6vw, 64px); line-height: .9; color: var(--red);
}
.band.green .sec-kicker, .band.red .sec-kicker { color: var(--turmeric); }
.sec-en { font-family: var(--mono); font-size: 12px; letter-spacing: .3em; text-transform: uppercase; color: var(--green); padding-bottom: 8px; }
.band.green .sec-en, .band.red .sec-en { color: var(--cream-2); }
.sec-no { margin-left: auto; font-family: var(--mono); font-size: 12px; color: var(--ink-soft); padding-bottom: 8px; }
.band.green .sec-no, .band.red .sec-no { color: var(--cream-2); }

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto { text-align: center; }
.mf-kicker { font-family: var(--mono); font-size: clamp(11px, 1.5vw, 13px); letter-spacing: .26em; text-transform: uppercase; color: var(--turmeric); margin-bottom: 18px; }
.manifesto .mf-line {
  font-family: var(--disp); font-size: clamp(30px, 6vw, 78px); line-height: 1.02; color: var(--cream-hi);
  max-width: 18ch; margin: 0 auto;
}
.manifesto .mf-line .hi { color: var(--turmeric); }
.manifesto .mf-line .deva { font-family: var(--deva); }
.manifesto .mf-en { margin-top: 22px; font-family: var(--mono); font-size: clamp(12px, 1.6vw, 15px); letter-spacing: .08em; color: var(--cream-2); text-transform: uppercase; }
.mf-sticker {
  display: inline-block; background: var(--cream-hi); color: var(--red); font-family: var(--fat); text-transform: uppercase;
  padding: 4px 14px; transform: rotate(-2deg); box-shadow: 4px 4px 0 var(--green-d);
}

/* ============================================================
   STAT STAMPS (brag bar)
   ============================================================ */
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(12px, 2vw, 22px); }
@media (max-width: 720px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
.stat {
  position: relative; background: var(--cream); border: 2px solid var(--green); padding: 22px 16px; text-align: center;
  box-shadow: 4px 4px 0 var(--green);
}
.band.green .stat { background: var(--cream); }
.stat .num { font-family: var(--fat); font-size: clamp(36px, 6vw, 60px); color: var(--red); line-height: .9; }
.stat .num .u { font-size: .5em; color: var(--terra); }
.stat .lbl { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-top: 8px; }
.stat .stamp-no { position: absolute; top: 6px; right: 8px; font-family: var(--mono); font-size: 9px; color: var(--green); opacity: .6; }

/* ============================================================
   WORK — product posters
   ============================================================ */
.work-stack { display: flex; flex-direction: column; gap: clamp(28px, 5vw, 56px); }
.product {
  display: grid; grid-template-columns: 1fr; gap: 0; border: 3px solid var(--green); background: var(--cream);
  box-shadow: 0 30px 70px -40px rgba(20,60,30,.5); overflow: hidden;
}
@media (min-width: 860px) { .product { grid-template-columns: 0.95fr 1.25fr; } }
.product-art {
  position: relative; background: var(--green); color: var(--cream); padding: 34px; min-height: 260px;
  display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 14px;
  border-right: 3px solid var(--green);
}
.product-art .can {
  position: relative; width: 130px; min-height: 180px; background: var(--cream-hi); border: 3px solid var(--turmeric);
  border-radius: 10px / 14px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 16px 10px;
  box-shadow: inset 0 0 0 3px var(--green), 6px 8px 0 rgba(0,0,0,.25);
}
.product-art .can .can-name { font-family: var(--disp); font-size: 28px; color: var(--red); line-height: .9; }
.product-art .can .can-sub { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--green); text-transform: uppercase; }
.product-art .can .can-steam { position: absolute; top: -34px; font-size: 26px; color: var(--cream); opacity: .5; }
.product-art .art-cap { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--turmeric); }
.product-art .halo { position: absolute; inset: 0; background: radial-gradient(circle at 50% 42%, rgba(227,165,46,.28), transparent 60%); }

.product-body { padding: clamp(24px, 3vw, 38px); }
.product-idx { font-family: var(--mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--terra); }
.product-name { font-family: var(--disp); font-size: clamp(34px, 5vw, 56px); line-height: .92; color: var(--green); margin: 4px 0 2px; }
.product-tag { font-family: var(--script); font-size: clamp(22px, 3vw, 32px); color: var(--red); line-height: 1; }
.product-body p { margin-top: 16px; font-size: 16.5px; color: var(--ink-soft); max-width: 56ch; }
.syntax {
  display: inline-block; margin: 18px 0 4px; font-family: var(--mono); font-size: 14px; background: var(--ink); color: var(--cream-hi);
  padding: 12px 16px; border-radius: 4px; letter-spacing: .02em;
}
.syntax .k { color: var(--turmeric); }
.syntax .p { color: #9ec5a8; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.chip-m { font-family: var(--mono); font-size: 12px; color: var(--green); border: 1.5px solid var(--green); padding: 6px 11px; background: var(--cream-hi); }
.chip-m b { color: var(--red); }
.links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
.lk { font-family: var(--mono); font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--cream); background: var(--green); padding: 8px 13px; transition: background .2s, transform .15s; }
.lk:hover { background: var(--red); transform: translateY(-2px); }

/* ============================================================
   WHAT I CAN DO — topic cards
   ============================================================ */
.do-grid { display: grid; grid-template-columns: 1fr; gap: clamp(14px, 2vw, 22px); }
@media (min-width: 680px) { .do-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .do-grid { grid-template-columns: repeat(3, 1fr); } }
.do-card {
  position: relative; background: var(--cream); border: 2px solid var(--turmeric); border-radius: 12px;
  padding: 26px 22px 24px; box-shadow: 5px 6px 0 var(--green-d);
  transition: transform .2s ease, box-shadow .2s ease;
}
.do-card:hover { transform: translate(-2px, -2px); box-shadow: 8px 9px 0 var(--green-d); }
.do-card .do-no {
  position: absolute; top: 14px; right: 16px; font-family: var(--disp); font-size: 26px;
  color: var(--turmeric); line-height: 1; text-transform: uppercase; letter-spacing: .02em;
}
.do-card .do-name { font-family: var(--disp); font-size: clamp(21px, 2.4vw, 27px); line-height: 1.08; color: var(--red); padding-right: 40px; }
.do-card .do-desc { margin-top: 14px; font-size: 15.5px; line-height: 1.5; color: var(--ink-soft); }

.do-invite {
  margin-top: clamp(28px, 4vw, 44px); text-align: center; background: var(--cream); border: 2px dashed var(--turmeric);
  border-radius: 14px; padding: clamp(22px, 3vw, 34px);
}
.do-invite .di-text { font-family: var(--disp); font-size: clamp(20px, 2.8vw, 30px); color: var(--green); line-height: 1.1; }
.do-invite .di-actions { margin-top: 18px; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.do-invite .di-quiet { font-family: var(--mono); font-size: 12px; letter-spacing: .04em; color: var(--ink-soft); }
.do-invite .di-quiet:hover { color: var(--red); }

/* ============================================================
   EXPERIENCE — ledger
   ============================================================ */
.xp { border-top: 2px solid var(--paper-line); }
.xp-row { display: grid; grid-template-columns: 1fr; gap: 8px 30px; padding: 26px 0; border-bottom: 2px solid var(--paper-line); }
@media (min-width: 820px) { .xp-row { grid-template-columns: 1fr; } }
.xp-when { font-family: var(--mono); font-size: 12.5px; color: var(--terra); letter-spacing: .04em; }
.xp-role { font-family: var(--disp); font-size: clamp(22px, 2.6vw, 32px); line-height: 1; color: var(--green); }
.xp-role .co { color: var(--red); }
.xp-pts { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.xp-pts li { list-style: none; position: relative; padding-left: 24px; color: var(--ink-soft); font-size: 16px; line-height: 1.5; max-width: 64ch; }
.xp-pts li::before { content: "✦"; position: absolute; left: 2px; top: 1px; color: var(--turmeric); font-size: 13px; }

/* ============================================================
   SKILLS — menu card
   ============================================================ */
.menu { background: var(--cream); border: 3px double var(--green); padding: clamp(24px, 4vw, 44px); position: relative; }
.menu-title { text-align: center; font-family: var(--script); font-size: clamp(30px, 5vw, 46px); color: var(--red); line-height: .9; }
.menu-sub { text-align: center; font-family: var(--mono); font-size: 11px; letter-spacing: .3em; text-transform: uppercase; color: var(--green); margin-top: 4px; margin-bottom: 26px; }
.menu-grid { display: grid; grid-template-columns: 1fr; gap: 6px 50px; }
@media (min-width: 760px) { .menu-grid { grid-template-columns: 1fr 1fr; } }
.menu-item { display: grid; grid-template-columns: auto 1fr auto; align-items: baseline; gap: 10px; padding: 11px 0; border-bottom: 1.5px dotted var(--paper-line); }
.menu-item .mi-name { font-family: var(--disp); font-size: 19px; color: var(--green); white-space: nowrap; }
.menu-item .mi-dots { border-bottom: 1.5px dotted var(--paper-line); transform: translateY(-4px); }
.menu-item .mi-list { font-family: var(--mono); font-size: 11.5px; color: var(--ink-soft); text-align: right; letter-spacing: .02em; }

.edu { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 30px; }
@media (min-width: 720px) { .edu { grid-template-columns: 1fr 1fr; } }
.edu-stamp { position: relative; background: var(--cream); border: 2px dashed var(--green); padding: 18px 20px; box-shadow: 3px 3px 0 var(--turmeric); }
.edu-stamp .deg { font-family: var(--disp); font-size: 21px; color: var(--green); line-height: 1; }
.edu-stamp .school { font-size: 15px; color: var(--ink-soft); margin-top: 4px; }
.edu-stamp .cgpa { font-family: var(--mono); font-size: 12px; color: var(--red); margin-top: 6px; letter-spacing: .04em; }

/* ============================================================
   CONTACT — postcard
   ============================================================ */
.postcard { background: var(--cream); border: 3px solid var(--green); display: grid; grid-template-columns: 1fr; box-shadow: 0 30px 70px -40px rgba(20,60,30,.5); overflow: hidden; }
@media (min-width: 820px) { .postcard { grid-template-columns: 1.3fr 1fr; } }
.pc-left { padding: clamp(26px, 4vw, 46px); border-right: 2px dashed var(--green); }
.pc-hello { font-family: var(--script); font-size: clamp(32px, 5vw, 52px); color: var(--red); line-height: .9; }
.pc-head { font-family: var(--disp); font-size: clamp(30px, 5vw, 52px); color: var(--green); line-height: .95; margin-top: 4px; }
.pc-head .deva { font-family: var(--deva); }
.pc-mail { display: inline-block; margin-top: 22px; font-family: var(--mono); font-size: clamp(15px, 2.4vw, 22px); color: var(--ink); border-bottom: 3px solid var(--turmeric); padding-bottom: 3px; }
.pc-mail:hover { color: var(--red); }
.pc-links { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 26px; }
.pc-right { padding: clamp(22px, 3vw, 34px); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; background: var(--green); color: var(--cream); }
.pc-postmark { width: 120px; height: 120px; border-radius: 50%; border: 2px solid var(--turmeric); color: var(--turmeric); display: flex; align-items: center; justify-content: center; text-align: center; font-family: var(--mono); font-size: 10px; letter-spacing: .15em; text-transform: uppercase; line-height: 1.5; transform: rotate(-8deg); }
.qr { width: 92px; height: 92px; background: var(--cream-hi); padding: 7px; }
.qr svg { width: 100%; height: 100%; }

/* footer */
.footer { background: var(--green-d); color: var(--cream-2); padding: 30px var(--pad); text-align: center; }
.footer .line { font-family: var(--disp); font-size: clamp(20px, 3vw, 30px); color: var(--turmeric); }
.footer .sub { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-top: 8px; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee { overflow: hidden; white-space: nowrap; border-top: 3px solid var(--turmeric); border-bottom: 3px solid var(--turmeric); background: var(--red); }
.marquee .track { display: inline-flex; gap: 36px; padding: 12px 18px; animation: scrollx 26s linear infinite; }
.marquee .track span { font-family: var(--disp); font-size: 22px; color: var(--cream-hi); letter-spacing: .02em; }
.marquee .track span .star { color: var(--turmeric); margin-left: 36px; }
@keyframes scrollx { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee .track, .hero-medallion .ring { animation: none; } }
