/* ============================================================
   Venny Violetta — interactive enhancements (motion, live, theme)
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.18s}
.reveal.d4{transition-delay:.24s}.reveal.d5{transition-delay:.3s}.reveal.d6{transition-delay:.36s}

/* ---------- hero aurora background ---------- */
.p1{position:relative}
.p1 .p1l,.p1 .p1r{position:relative;z-index:1}
.hero-aurora{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-aurora span{position:absolute;border-radius:50%;filter:blur(64px);opacity:.5;mix-blend-mode:multiply;animation:auroraFloat 20s ease-in-out infinite}
.hero-aurora span:nth-child(1){width:430px;height:430px;left:-90px;top:-70px;background:radial-gradient(circle,rgba(184,133,26,.55),transparent 70%)}
.hero-aurora span:nth-child(2){width:390px;height:390px;right:-70px;top:22%;background:radial-gradient(circle,rgba(20,112,106,.4),transparent 70%);animation-delay:-7s}
.hero-aurora span:nth-child(3){width:360px;height:360px;left:32%;bottom:-90px;background:radial-gradient(circle,rgba(212,168,67,.5),transparent 70%);animation-delay:-13s}
@keyframes auroraFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(44px,32px) scale(1.12)}66%{transform:translate(-32px,22px) scale(.9)}}

/* ---------- typewriter roles ---------- */
.p1-roles{font-family:var(--cond);font-size:18px;font-weight:600;letter-spacing:.4px;margin-bottom:1.25rem;min-height:1.6em}
.p1-roles .pr-lead{color:var(--ink3);font-weight:500}
.vv-typer{color:var(--gold2)}
.vv-caret{color:var(--gold);font-weight:400;margin-left:1px;animation:caretBlink 1s steps(1) infinite}
@keyframes caretBlink{50%{opacity:0}}

/* ---------- live strip (clock + role timer) ---------- */
.live-strip{display:flex;flex-wrap:wrap;gap:.45rem 1.35rem;margin:0 0 1rem;font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--ink3);text-transform:uppercase}
.live-item{display:inline-flex;align-items:center;gap:.45rem}
.live-item b{color:var(--gold2);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.5px}
.live-dot{width:7px;height:7px;border-radius:50%;background:#2ec16b;animation:livePulse 1.7s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(46,193,107,.55)}70%{box-shadow:0 0 0 8px rgba(46,193,107,0)}100%{box-shadow:0 0 0 0 rgba(46,193,107,0)}}

/* ---------- animated counters / skill bars use JS; ensure smooth fill ---------- */
.sk-fill{transition:width 1.3s cubic-bezier(.2,.7,.2,1)}

/* ---------- project filters + tilt ---------- */
.proj-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.15rem}
.pf-btn{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:.45rem .95rem;border-radius:100px;border:1px solid var(--goldborder);background:transparent;color:var(--ink3);cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.pf-btn:hover{border-color:var(--gold);color:var(--gold2)}
.pf-btn.active{background:var(--ink);color:var(--c0);border-color:var(--ink)}
.bento{perspective:1200px}
.bc{transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,border-color .25s,opacity .45s,filter .3s;transform-style:preserve-3d}
.bc.filtered-out{opacity:.12;filter:grayscale(1);pointer-events:none}
.bc.tilt{will-change:transform}

/* ---------- nav actions (game + theme) ---------- */
.nav-actions{display:flex;align-items:center;gap:.55rem;flex:0 0 auto}
.game-btn{font-family:var(--mono);font-size:9.5px;letter-spacing:1px;text-transform:uppercase;color:#F5EDD8;background:rgba(255,255,255,.06);border:1px solid rgba(212,168,67,.4);padding:.42rem .7rem;border-radius:100px;cursor:pointer;transition:border-color .2s,color .2s,background .2s;display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}
.game-btn:hover{border-color:var(--gold3);color:var(--gold3);background:rgba(212,168,67,.12)}
.game-btn .gp-star{color:var(--gold3);font-size:11px}

/* ---------- theme toggle ---------- */
.theme-toggle{background:transparent;border:1px solid rgba(255,255,255,.28);color:#F5EDD8;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s,transform .3s;margin-left:1.1rem;flex:0 0 auto}
.theme-toggle:hover{border-color:var(--gold3);color:var(--gold3);transform:rotate(20deg)}

/* ---------- easter-egg puzzle ---------- */
.vv-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(10,7,2,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.vv-modal.open{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.vv-game{background:var(--c2);border:1px solid var(--goldborder);border-radius:18px;padding:1.6rem;max-width:340px;width:92%;box-shadow:0 30px 80px rgba(0,0,0,.45);text-align:center;position:relative}
.vv-game h3{font-family:var(--cond);font-size:24px;font-weight:800;color:var(--ink);margin-bottom:.2rem}
.vv-game .g-sub{font-size:11px;color:var(--ink3);letter-spacing:.5px;margin-bottom:1rem}
.vv-close{position:absolute;top:.7rem;right:.9rem;background:none;border:none;font-size:20px;color:var(--ink3);cursor:pointer;line-height:1}
.puzzle{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:216px;height:216px;margin:0 auto 1rem}
.puztile{border:none;border-radius:10px;background:linear-gradient(135deg,var(--gold3),var(--gold));color:#1a1208;font-family:var(--cond);font-size:28px;font-weight:800;cursor:pointer;transition:transform .1s,filter .15s;display:flex;align-items:center;justify-content:center}
.puztile:hover{filter:brightness(1.06)}
.puztile:active{transform:scale(.95)}
.puztile.blank{background:transparent;cursor:default}
.g-status{color:var(--teal);font-weight:700;font-size:13px;min-height:1.3em;margin-bottom:.7rem;font-family:var(--cond);letter-spacing:.3px}
.g-actions{display:flex;gap:.5rem;justify-content:center}
.vv-btn{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:.55rem 1.05rem;border-radius:100px;border:1px solid var(--goldborder);background:transparent;color:var(--ink2);cursor:pointer;transition:background .2s,color .2s}
.vv-btn.primary{background:var(--ink);color:var(--c0);border-color:var(--ink)}

/* ---------- photo gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem;margin-top:1.5rem}
.gal-item{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--goldborder);aspect-ratio:4/3;cursor:pointer;background:var(--c1)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.gal-item:hover img{transform:scale(1.07)}
.gal-item::after{content:'⤢';position:absolute;right:10px;bottom:8px;color:#fff;font-size:14px;opacity:0;transition:opacity .3s;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.gal-item:hover::after{opacity:1}
.gal-empty{margin-top:1.5rem;padding:2.5rem;border:1px dashed var(--goldborder);border-radius:14px;text-align:center;color:var(--ink3);font-size:13px}
.lightbox{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;background:rgba(8,6,2,.9);backdrop-filter:blur(4px);cursor:zoom-out}
.lightbox.open{display:flex;animation:fadeIn .25s ease}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.6)}

/* ---------- DARK THEME = the mobile-CV look (near-black · silver · minimal) ----------
   Cool silver-on-black. Accents (the "gold" vars) become platinum/silver.
   This is the DEFAULT theme (html[data-theme=dark]); light/gold is the toggle. */
[data-theme=dark]{
  --c0:#0a0a0c;--c1:#0d0d11;--c2:#0b0b0e;--c3:#101015;--c4:#08080a;
  --ink:#f5f6fb;--ink2:#e2e4ee;--ink3:#c2c5d1;
  --gold:#c9ccd6;--gold2:#9a9daa;--gold3:#f2f4fb;
  --goldfaint:rgba(198,204,224,.05);--goldborder:rgba(198,204,224,.16);
  --teal:#8c8e99;--coral:#ff8a80;
}
[data-theme=dark] body{background:var(--c0);color:var(--ink3)}
[data-theme=dark] .contact-panel,[data-theme=dark] .p2-aside,[data-theme=dark] .edu-box,[data-theme=dark] .p1r{background:rgba(255,255,255,.035)}
[data-theme=dark] .bc,[data-theme=dark] .cert-c,[data-theme=dark] .pub-c,[data-theme=dark] .sp-item{background:rgba(255,255,255,.035);border-color:rgba(198,204,224,.13)}
[data-theme=dark] .bc:hover,[data-theme=dark] .gs-col:hover{box-shadow:0 16px 44px rgba(0,0,0,.5)}
[data-theme=dark] .gs-col{background:rgba(255,255,255,.04)}
[data-theme=dark] .tl-logo,[data-theme=dark] .tl-logo-sm{background:#f4f5fa}
[data-theme=dark] .pf-btn.active{background:#f2f4fb;color:#0a0a0c;border-color:#f2f4fb}
[data-theme=dark] .tl-co-name{color:#9a9daa}
[data-theme=dark] .bc-num{color:rgba(245,246,251,.28)}
[data-theme=dark] .nav{background:rgba(8,8,11,.92)}
[data-theme=dark] .nav-brand{color:#f5f6fb}
[data-theme=dark] .theme-toggle,[data-theme=dark] .game-btn{color:#e2e4ee;border-color:rgba(198,204,224,.3)}
[data-theme=dark] .award-card{filter:none}
[data-theme=dark] .gs-core{background:radial-gradient(circle at 30% 30%,#f2f4fb,#9a9daa);color:#0a0a0c;box-shadow:0 0 0 8px rgba(198,204,224,.06)}
[data-theme=dark] .map-wrap{background:radial-gradient(circle at 50% 44%,#101015,#050507)}
[data-theme=dark] .puztile{background:linear-gradient(135deg,#f2f4fb,#c9ccd6);color:#0a0a0c}
[data-theme=dark] .vv-game{background:#111116}
[data-theme=dark] .g-status{color:var(--coral)}
[data-theme=dark] .sk-fill{filter:grayscale(1) brightness(1.4)}
/* minimal: no aurora blobs, no gold rain in dark — just faint starfield sparkles */
[data-theme=dark] .hero-aurora{display:none}
[data-theme=dark] #goldrain{display:none}
[data-theme=dark] .spark{background:radial-gradient(circle,#fff,#c2c5d1 55%,transparent 74%)}
[data-theme=dark] .spark.lg{box-shadow:0 0 8px 1px rgba(226,228,238,.6)}
/* cool silver shimmer on the name + titles (override the warm gold gradient) */
[data-theme=dark] .p1-name,[data-theme=dark] .p1-name-line2,[data-theme=dark] .sec-title,
[data-theme=dark] .p3-title,[data-theme=dark] .p5-title,[data-theme=dark] .p6-title,
[data-theme=dark] .gs-title,[data-theme=dark] .map-title,[data-theme=dark] .aside-title,
[data-theme=dark] .cp-headline,[data-theme=dark] .p3-title em,[data-theme=dark] .p5-title em,
[data-theme=dark] .p6-title em,[data-theme=dark] .sec-title em,[data-theme=dark] .gs-title em,
[data-theme=dark] .map-title em,[data-theme=dark] .aside-title em,[data-theme=dark] .gs-x{
  background:linear-gradient(100deg,#9a9daa 0%,#e2e4ee 42%,#ffffff 50%,#e2e4ee 58%,#9a9daa 100%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
[data-theme=dark] .p1-name,[data-theme=dark] .p1-name-line2{filter:drop-shadow(0 2px 14px rgba(226,228,238,.25))}

/* ================= INTERACTIVE VISUAL TOOLS ================= */

/* ----- Generalist × Specialist ----- */
.gs-band{grid-column:1/-1;margin-bottom:2.5rem}
.gs-head{margin-bottom:1.15rem}
.gs-title{font-family:var(--cond);font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:800;color:var(--ink);line-height:1;letter-spacing:-1px;margin:.15rem 0 .85rem}
.gs-title em{font-style:italic;font-weight:500;color:var(--gold2);font-size:.6em}
.gs-x{color:var(--gold);font-family:var(--serif);font-style:italic}
.gs-lens{display:inline-flex;gap:.3rem;background:var(--goldfaint);padding:.25rem;border-radius:100px;border:1px solid var(--goldborder)}
.gs-lbtn{font-family:var(--mono);font-size:9.5px;letter-spacing:1px;text-transform:uppercase;padding:.4rem .85rem;border:none;background:transparent;color:var(--ink3);border-radius:100px;cursor:pointer;transition:background .25s,color .25s}
.gs-lbtn.active{background:var(--ink);color:var(--c0)}
.gs-wrap{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}
.gs-col{background:#fff;border:1px solid var(--goldborder);border-radius:16px;padding:1.35rem 1.5rem;transition:transform .3s,box-shadow .3s,opacity .35s,filter .35s}
.gs-col:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(184,133,26,.14)}
.gs-col.gen{border-top:3px solid var(--phase-corp)}
.gs-col.spec{border-top:3px solid var(--gold)}
.gs-col-h{font-family:var(--cond);font-size:20px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:.5rem;margin-bottom:.45rem}
.gs-ic{color:var(--gold)}
.gs-tag{font-family:var(--mono);font-size:8px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold2);background:var(--goldfaint);padding:2px 7px;border-radius:100px;font-weight:500}
.gs-lead{font-size:12.5px;color:var(--ink3);line-height:1.55;margin-bottom:.85rem}
.gs-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.35rem .8rem}
.gs-list li{font-size:12px;color:var(--ink2);font-weight:500;display:flex;align-items:center;gap:.4rem}
.gs-list li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);flex:0 0 auto}
.gs-core{width:90px;height:90px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--gold3),var(--gold2));color:#1a1208;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 0 0 8px var(--goldfaint);animation:corePulse 3s ease-in-out infinite;flex:0 0 auto}
.gs-core span{font-family:var(--cond);font-weight:800;font-size:18px;letter-spacing:.5px}
.gs-core small{font-family:var(--mono);font-size:7px;letter-spacing:1px;text-transform:uppercase;opacity:.85}
@keyframes corePulse{0%,100%{box-shadow:0 0 0 8px var(--goldfaint)}50%{box-shadow:0 0 0 14px rgba(184,133,26,.05)}}
.gs-wrap.mode-gen .spec,.gs-wrap.mode-spec .gen{opacity:.4;filter:grayscale(.6)}
.gs-wrap.mode-gen .gen,.gs-wrap.mode-spec .spec{transform:scale(1.02)}
@media(max-width:820px){.gs-wrap{grid-template-columns:1fr;gap:.8rem}.gs-core{margin:0 auto}}

/* ----- Milestone timeline ----- */
.mstone{margin:0 0 1.4rem;overflow-x:auto;padding-bottom:.4rem}
.ms-track{display:flex;min-width:660px;position:relative;padding:.4rem 0}
.ms-track::before{content:'';position:absolute;left:5%;right:5%;top:15px;height:2px;background:linear-gradient(90deg,var(--goldborder),var(--gold),var(--goldborder))}
.ms-node{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;padding:0 .3rem;background:none;border:none}
.ms-dot{width:12px;height:12px;border-radius:50%;background:var(--c4);border:2px solid var(--gold);z-index:1;transition:transform .2s,background .2s}
.ms-node:hover .ms-dot,.ms-node.active .ms-dot{background:var(--gold);transform:scale(1.35)}
.ms-yr{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--gold2);margin-top:.4rem}
.ms-lbl{font-family:var(--cond);font-size:11px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.3px;margin-top:.1rem;line-height:1.2;max-width:92px}
.ms-node:hover .ms-lbl,.ms-node.active .ms-lbl{color:var(--ink)}
.bc.ms-flash{box-shadow:0 0 0 3px var(--gold),0 12px 32px rgba(184,133,26,.22)!important}

/* ----- Footprint map ----- */
.map-band{grid-column:1/-1;margin-bottom:2rem}
.map-title{font-family:var(--cond);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--ink);letter-spacing:-1px;margin:.1rem 0 1rem}
.map-title em{font-style:italic;font-weight:500;color:var(--gold2)}
.map-wrap{position:relative;width:100%;aspect-ratio:16/7;min-height:230px;background:radial-gradient(circle at 50% 44%,#15110a,#070503);border:1px solid var(--goldborder);border-radius:18px;overflow:hidden}
.map-geo{position:absolute;inset:0;width:100%;height:100%;object-fit:fill;opacity:1;pointer-events:none;z-index:0}
.map-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
.map-lines path{fill:none;stroke:var(--gold);stroke-width:.3;stroke-dasharray:2 2;opacity:.45;animation:dashMove 22s linear infinite}
@keyframes dashMove{to{stroke-dashoffset:-40}}
.map-pin{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;z-index:2}
.map-pin span{width:12px;height:12px;border-radius:50%;background:var(--gold3);box-shadow:0 0 0 4px rgba(212,168,67,.18);transition:transform .2s,box-shadow .2s}
.map-pin em{font-family:var(--mono);font-size:8.5px;letter-spacing:.5px;font-style:normal;text-transform:uppercase;color:rgba(237,224,196,.72);white-space:nowrap;transition:color .2s}
.map-pin.hub span{width:16px;height:16px;background:var(--gold);animation:livePulse 1.9s infinite}
.map-pin:hover span,.map-pin.active span{transform:scale(1.3);box-shadow:0 0 0 6px rgba(212,168,67,.3)}
.map-pin:hover em,.map-pin.active em{color:var(--gold3)}
.map-cap{margin-top:.8rem;font-size:12.5px;color:var(--ink3);line-height:1.5;min-height:2.2em}
.map-cap b{color:var(--ink2);font-family:var(--cond);font-size:14px}
.map-cap .mc-place{color:var(--gold2);font-weight:700}

/* ================= GOLD SHINE · SPARKLE · GLOSS ================= */
/* shimmering metallic gold on accent text */
.p3-title em,.p5-title em,.p6-title em,.sec-title em,.gs-title em,.map-title em,
.aside-title em,.cp-headline em,.p1-name-line2,.p6-title em,.gs-x{
  background:linear-gradient(100deg,var(--gold2) 0%,var(--gold) 28%,var(--gold3) 44%,#fff7db 50%,var(--gold3) 56%,var(--gold) 72%,var(--gold2) 100%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shineMove 7s linear infinite}
@keyframes shineMove{to{background-position:-220% center}}
@media (prefers-reduced-motion:reduce){.p1-name-line2,.gs-x{-webkit-text-fill-color:var(--gold2)}}

/* soft gold glow on accents */
.sec-eyebrow,.press-eyebrow,.bc-co,.map-title,.gs-tag{text-shadow:0 0 14px rgba(212,168,67,.22)}
.stn{text-shadow:0 0 20px rgba(212,168,67,.4)}
.map-pin span,.live-dot{box-shadow:0 0 10px 2px rgba(212,168,67,.45)}
.map-pin.hub span{box-shadow:0 0 14px 3px rgba(212,168,67,.6)}

/* metallic pills */
.pill{background:linear-gradient(135deg,rgba(212,168,67,.18),rgba(184,133,26,.05));border:1px solid var(--goldborder)}

/* signature constant sheen on the "BOTH" medallion + Play button */
.gs-core,.game-btn,.pill,.pf-btn,.bc,.gs-col,.tl-item,.award-card,.theme-toggle{overflow:hidden}
.gs-core::after,.game-btn::after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,247,219,.55),transparent);transform:skewX(-18deg);
  pointer-events:none;animation:sweep 6s ease-in-out infinite}
.game-btn{position:relative}
@keyframes sweep{0%,55%{left:-75%}78%,100%{left:135%}}

/* gloss sheen sweep on hover for cards & pills */
.bc::after,.gs-col::after,.pill::after,.pf-btn::after{content:"";position:absolute;top:0;left:-60%;width:42%;height:130%;
  background:linear-gradient(100deg,transparent,rgba(255,247,219,.28),transparent);transform:skewX(-16deg);opacity:0;pointer-events:none}
.bc:hover::after,.gs-col:hover::after,.pill:hover::after,.pf-btn:hover::after{animation:sheen .9s ease}
@keyframes sheen{0%{left:-60%;opacity:1}100%{left:135%;opacity:0}}

/* ambient sparkles (JS-injected) */
#sparkles{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.spark{position:absolute;width:3px;height:3px;border-radius:50%;
  background:radial-gradient(circle,#fff7db,var(--gold3) 55%,transparent 74%);
  opacity:0;animation:twinkle var(--dur) ease-in-out var(--dly) infinite}
.spark.lg{width:5px;height:5px;box-shadow:0 0 7px 1px rgba(212,168,67,.5)}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.3)}50%{opacity:.82;transform:scale(1)}}
[data-theme=dark] .spark{background:radial-gradient(circle,#fff,var(--gold3) 55%,transparent 74%)}

/* ================= MAXIMUM GOLD: rain · gold fonts · glitter ================= */
/* the whole name shimmers gold, unified serif */
.p1-name,.p1-name-line2{
  background:linear-gradient(100deg,var(--gold2) 0%,var(--gold) 26%,var(--gold3) 42%,#fff7db 50%,var(--gold3) 58%,var(--gold) 74%,var(--gold2) 100%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  filter:drop-shadow(0 2px 10px rgba(184,133,26,.35));
  animation:shineMove 6.5s linear infinite}
@media (prefers-reduced-motion:reduce){.p1-name,.p1-name-line2{-webkit-text-fill-color:var(--gold2)}}

/* section titles rendered in rich gold */
.sec-title,.p3-title,.p5-title,.p6-title,.gs-title,.map-title,.aside-title,.p6-hd .p6-title,.cp-headline{
  background:linear-gradient(96deg,var(--gold2),var(--gold3) 45%,var(--gold) 70%,var(--gold2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
/* keep the italic <em> accents on their brighter animated shimmer (already defined) */

/* GOLD RAIN — falling flecks across every page */
#goldrain{position:fixed;inset:0;pointer-events:none;z-index:59;overflow:hidden}
.grdrop{position:absolute;top:-8%;width:2px;height:12px;border-radius:2px;
  background:linear-gradient(180deg,rgba(255,247,219,0),#ffe9a8,var(--gold3));opacity:0;
  animation:grfall var(--gd) linear var(--gdl) infinite}
.grdrop.fleck{width:4px;height:4px;border-radius:50%;background:radial-gradient(circle,#fff7db,var(--gold3) 60%,transparent 74%);box-shadow:0 0 6px 1px rgba(212,168,67,.55)}
@keyframes grfall{0%{transform:translateY(-12vh) rotate(6deg)}8%{opacity:.9}90%{opacity:.65}100%{transform:translateY(114vh) rotate(6deg);opacity:0}}

/* brighter ambient sparkles */
.spark{width:4px;height:4px}
.spark.lg{width:7px;height:7px;box-shadow:0 0 10px 2px rgba(212,168,67,.65)}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.15)}}

/* golden glow lift on the hero name area */
.p1-name-line2{filter:drop-shadow(0 3px 14px rgba(212,168,67,.4))}

/* map land goes monochrome in the dark CV theme */
[data-theme=dark] .map-geo{filter:grayscale(.9) brightness(1.15)}

/* CV nav chip */
.nav-cv{border:1px solid var(--goldborder);border-radius:100px;padding:.28rem .72rem;margin-left:.4rem;color:var(--gold3)!important}
.nav-cv:hover{border-color:var(--gold3);background:rgba(198,204,224,.08)}
.nav-cv::after{display:none!important}

/* keep the radar chart & warm SVG accents monochrome in the dark CV theme */
[data-theme=dark] .radar-container svg{filter:grayscale(1) brightness(1.5)}
[data-theme=dark] .map-pin span{box-shadow:0 0 10px 2px rgba(226,228,238,.5)}
