/* ==========================================
   styles.css — Theme Tokens & Layout
   mcjn_jazzy — Commission Hub
   ========================================== */

/* ----- LIGHT theme (default — readability-tuned) ----- */
:root {
  --bg-1:       #FFF7F2;
  --bg-2:       #FFE9EF;
  --card:       #FFFFFF;
  --panel:      #FFE9EF;
  --panel-2:    #FFD0DF;
  --ink:        #43281F;
  --ink-soft:   #6E4B3C;
  --berry:      #FF6F91;
  --berry-ink:  #D12E63;
  --star:       #E6A52B;
  --btn-bg:     #D12E63;
  --on-btn:     #FFFFFF;
  --border:     rgba(209, 46, 99, 0.10);

  --shadow-soft: 0 22px 48px -26px rgba(209, 46, 99, 0.40);
  --shadow-lift: 0 12px 26px -16px rgba(67, 40, 31, 0.34);

  --radius:   28px;
  --radius-s: 16px;

  --font-display: "Fredoka", system-ui, sans-serif;
  --font-body:    "Quicksand", system-ui, sans-serif;
  --font-hand:    "Caveat", cursive;
}

/* ----- DARK theme (warm "night diary") ----- */
[data-theme="dark"] {
  --bg-1:       #241820;
  --bg-2:       #3A2230;
  --card:       #312029;
  --panel:      #3E2A38;
  --panel-2:    #4E3344;
  --ink:        #FBE7EE;
  --ink-soft:   #C9A6B6;
  --berry:      #FF8FAB;
  --berry-ink:  #FFA9BF;
  --star:       #FFDD7A;
  --btn-bg:     #FF8FAB;
  --on-btn:     #3A1622;
  --border:     rgba(255,255,255,0.06);

  --shadow-soft: 0 22px 48px -26px rgba(0, 0, 0, 0.6);
  --shadow-lift: 0 12px 26px -16px rgba(0, 0, 0, 0.55);
}

/* ----- reset ----- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background:
    radial-gradient(1200px 720px at 50% -8%, var(--bg-2) 0%, transparent 62%),
    var(--bg-1);
  min-height: 100dvh;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  transition: background-color .4s ease, color .4s ease;
}

/* ==========================================
   Floating Background Doodles
   ========================================== */
.sky { position: fixed; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.doodle { position: absolute; opacity: 0.5; font-size: 1.6rem; will-change: transform; }
.d1 { top: 11%; left: 8%;  color: var(--star); }
.d2 { top: 26%; right: 9%;  font-size: 2.1rem; }
.d3 { top: 60%; left: 6%;  color: var(--berry); }
.d4 { top: 80%; right: 12%; font-size: 1.9rem; }
.d5 { top: 44%; right: 21%; color: var(--star); }
.d6 { top: 70%; left: 14%; font-size: 1.4rem; }

/* ==========================================
   Page Wrapper
   ========================================== */
.page {
  position: relative;
  z-index: 1;
  width: min(680px, 92vw);
  margin: 0 auto;
  padding: 26px 0 64px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

/* ==========================================
   Top Bar + Theme Toggle (pill switch)
   ========================================== */
.topbar { display: flex; justify-content: flex-end; }

.theme-toggle { background: none; border: none; padding: 0; cursor: pointer; }
.tt-track {
  position: relative;
  display: inline-flex; align-items: center;
  width: 66px; height: 34px;
  background: var(--panel);
  border: 2px solid var(--border);
  border-radius: 999px;
  box-shadow: var(--shadow-lift);
  transition: background .3s ease;
}
.tt-icon { position: absolute; font-size: 0.9rem; line-height: 1; }
.tt-sun  { left: 9px; }
.tt-moon { right: 9px; }
.tt-knob {
  position: absolute; top: 50%; left: 4px;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--berry);
  transform: translateY(-50%);
  transition: left .28s cubic-bezier(.5,.1,.3,1.4), background .3s ease;
  box-shadow: 0 4px 8px -2px rgba(0,0,0,0.25);
}
[data-theme="dark"] .tt-knob { left: 34px; }

/* ==========================================
   Card Base (cloud-floating panels)
   ========================================== */
.card {
  background: var(--card);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow-soft);
  border: 2px solid var(--border);
  transition: background-color .4s ease, box-shadow .4s ease, transform .25s ease;
}

.section-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.35rem;
  color: var(--berry-ink);
  display: flex; align-items: center; gap: 8px;
}
.section-title { cursor: default; }
.section-title span { color: var(--star); display: inline-block; transition: transform .2s ease; }
.section-title:hover span { animation: emojiWiggle .6s ease; }
@keyframes emojiWiggle {
  0%, 100% { transform: rotate(0) scale(1); }
  30%      { transform: rotate(-12deg) scale(1.2); }
  60%      { transform: rotate(10deg) scale(1.15); }
}

/* ==========================================
   ID Card
   ========================================== */
.idcard { position: relative; overflow: hidden; }
.ribbon {
  position: absolute; top: 0; left: 0; right: 0; height: 6px; z-index: 3;
  background: linear-gradient(90deg, var(--berry), var(--panel-2), var(--star), var(--berry));
  background-size: 300% 100%;
  animation: ribbonShift 8s linear infinite;
}
@keyframes ribbonShift { to { background-position: 300% 0; } }

/* cover banner — bleeds to the card edges, avatar overlaps it */
.cover { margin: -28px -28px 0; aspect-ratio: 1376 / 768; background: var(--panel); }
.cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

.idcard-top { display: flex; align-items: flex-end; gap: 18px; margin-top: -42px; position: relative; }

/* fallback when the banner image is missing */
.idcard.no-cover .cover { display: none; }
.idcard.no-cover .idcard-top { align-items: center; margin-top: 8px; }

.avatar {
  position: relative;
  width: 88px; height: 88px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--panel);
  display: grid; place-items: center;
  box-shadow: var(--shadow-lift);
  overflow: hidden;
  isolation: isolate;
}
.avatar::before {
  content: ""; position: absolute; inset: -4px; z-index: -1;
  border-radius: 50%;
  background: conic-gradient(from 0deg, var(--berry), var(--star), var(--panel-2), var(--berry));
  animation: spin 6s linear infinite;
}
.avatar::after { content: ""; position: absolute; inset: 3px; border-radius: 50%; background: var(--card); z-index: -1; }
.avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.avatar.no-img::after { content: "🍓"; font-size: 2.2rem; display: grid; place-items: center; inset: 3px; background: var(--panel); }
@keyframes spin { to { transform: rotate(360deg); } }

.eyebrow {
  font-family: var(--font-hand); font-size: 1.25rem; font-weight: 700; color: var(--berry-ink); line-height: 1;
  paint-order: stroke fill;
  -webkit-text-stroke: 3px var(--card);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.28);
}
.handle {
  font-family: var(--font-display); font-weight: 700; font-size: 1.7rem; color: var(--ink);
  paint-order: stroke fill;
  -webkit-text-stroke: 4px var(--card);
  text-shadow: 0 2px 5px rgba(0, 0, 0, 0.30);
}
.tagline { color: var(--ink-soft); font-weight: 600; }

/* intro line */
.intro { margin-top: 16px; color: var(--ink); font-weight: 500; }
.intro .hand { font-family: var(--font-hand); font-size: 1.3rem; font-weight: 700; color: var(--berry-ink); }

/* social stats */
.stats { display: flex; gap: 10px; margin-top: 16px; }
.stat {
  flex: 1; text-align: center;
  background: var(--panel);
  border-radius: var(--radius-s);
  padding: 12px 8px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.stat:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.stat b { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--ink); }
.stat span { font-size: 0.78rem; color: var(--ink-soft); font-weight: 700; letter-spacing: .02em; }

.traits-label {
  font-family: var(--font-hand);
  font-size: 1.45rem; font-weight: 700;
  color: var(--berry-ink);
  text-align: center;
  margin: 24px 0 2px;
}
.traits-label span { color: var(--star); }

.chips { list-style: none; display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: 10px; }
.chip {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: linear-gradient(135deg, var(--panel), var(--panel-2));
  color: var(--ink);
  padding: 9px 16px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.92rem;
  border: 1.5px solid var(--border);
  box-shadow: var(--shadow-lift), 0 0 16px -6px var(--berry);
  cursor: default;
  transition: transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease, filter .22s ease;
}
.chip strong { color: var(--berry-ink); }
.chip::after {
  content: ""; position: absolute; top: 0; left: -130%; z-index: 1;
  width: 55%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.55), transparent);
  transform: skewX(-18deg);
  pointer-events: none;
}
.chip:hover {
  transform: translateY(-4px) scale(1.05) rotate(-1.5deg);
  box-shadow: var(--shadow-lift), 0 0 22px -2px var(--berry-ink);
  filter: brightness(1.04);
}
.chip:hover::after { animation: chipShine .8s ease; }
@keyframes chipShine { to { left: 130%; } }

/* status sticker — the signature, gently bobbing */
.status-sticker {
  position: absolute; top: 18px; right: 18px; z-index: 4;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--berry);
  color: #fff;
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.82rem;
  box-shadow: 0 10px 18px -8px var(--berry-ink);
  animation: bob 3.4s ease-in-out infinite;
}
.status-dot {
  width: 9px; height: 9px; border-radius: 50%; background: #fff;
  box-shadow: 0 0 0 4px rgba(255,255,255,0.35);
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes bob   { 0%,100% { transform: translateY(0) rotate(-2deg); } 50% { transform: translateY(-6px) rotate(2deg); } }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ==========================================
   Link Bridges
   ========================================== */
.group-label { font-family: var(--font-hand); font-size: 1.3rem; font-weight: 700; color: var(--berry-ink); margin: 16px 0 8px; }
.link-row { display: flex; flex-wrap: wrap; gap: 12px; }

.link-pill {
  flex: 1 1 130px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--panel);
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
  padding: 14px;
  border-radius: var(--radius-s);
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.link-pill:hover { transform: translateY(-3px) rotate(-1deg); box-shadow: var(--shadow-lift); background: var(--panel-2); }
.link-pill:active { transform: translateY(-1px) scale(.98); }
.link-pill.folio { background: var(--btn-bg); color: var(--on-btn); }
.link-pill.folio:hover { filter: brightness(1.05); background: var(--btn-bg); }

/* ==========================================
   Recent Art Gallery
   ========================================== */
.art-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 14px; }
.art {
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-s);
  background: radial-gradient(circle at 50% 38%, var(--panel) 0%, var(--card) 100%);
  display: grid; place-items: center;
  padding: 10px;
  cursor: zoom-in;
  transition: transform .18s ease, box-shadow .18s ease;
}
.art img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 6px 10px rgba(0,0,0,0.14)); pointer-events: none; }
.art:hover { transform: translateY(-4px) rotate(-1.5deg); box-shadow: var(--shadow-lift); }

/* gentle hover lift on the interactive cards (idcard handled by JS tilt) */
.gallery, .links, .desk { will-change: transform; }
.gallery:hover, .links:hover, .desk:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-soft), var(--shadow-lift);
}

/* lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 50;
  display: none; place-items: center;
  padding: 24px;
  background: rgba(36, 24, 32, 0.74);
  backdrop-filter: blur(6px);
  cursor: zoom-out;
}
.lightbox.open { display: grid; animation: lbIn .25s ease; }
.lightbox img { max-width: min(92vw, 720px); max-height: 86vh; border-radius: var(--radius-s); box-shadow: var(--shadow-soft); }
@keyframes lbIn { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: none; } }

/* ==========================================
   Stitched Divider
   ========================================== */
.stitch { height: 0; border-top: 3px dashed var(--panel-2); margin: 4px 8px; opacity: 0.9; }

/* ==========================================
   Commission Form
   ========================================== */
.desk-note { color: var(--ink-soft); font-weight: 600; margin: 6px 0 18px; }
.form { display: flex; flex-direction: column; gap: 16px; }

.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-weight: 700; font-size: 0.95rem; color: var(--ink); }
.req { color: var(--berry-ink); }
.hint { font-family: var(--font-hand); font-size: 1.2rem; font-weight: 700; color: var(--ink-soft); }

input, select, textarea {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink);
  background: var(--bg-1);
  border: 2px solid var(--panel-2);
  border-radius: var(--radius-s);
  padding: 12px 14px;
  transition: border-color .15s ease, box-shadow .15s ease, background .4s ease;
}
input::placeholder, textarea::placeholder { color: var(--ink-soft); opacity: 0.85; }
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--berry);
  box-shadow: 0 0 0 4px rgba(255, 111, 145, 0.20);
}
textarea { resize: vertical; }

/* deadline chip picker */
.chip-pick { display: flex; flex-wrap: wrap; gap: 10px; }
.pick {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--ink);
  background: var(--panel);
  border: 2px solid transparent;
  border-radius: 999px;
  padding: 10px 16px;
  cursor: pointer;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.pick:hover { transform: translateY(-2px); background: var(--panel-2); }
.pick.is-active {
  background: var(--btn-bg);
  color: var(--on-btn);
  border-color: var(--berry-ink);
  box-shadow: var(--shadow-lift);
}
.deadline-date { margin-top: 12px; align-self: flex-start; }
.is-hidden { display: none !important; }

/* honeypot — hidden from real users */
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.submit {
  position: relative;
  overflow: hidden;
  margin-top: 6px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--on-btn);
  background: var(--btn-bg);
  border: none;
  border-radius: 999px;
  padding: 15px;
  cursor: pointer;
  box-shadow: 0 12px 22px -10px var(--berry-ink);
  transition: transform .15s ease, filter .15s ease;
}
.submit::after {
  content: ""; position: absolute; top: 0; left: -130%;
  width: 70%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.45), transparent);
  transform: skewX(-20deg);
}
.submit:hover:not(:disabled) { transform: translateY(-2px); filter: brightness(1.05); }
.submit:hover:not(:disabled)::after { animation: shine .7s ease; }
.submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
@keyframes shine { to { left: 130%; } }

.form-msg { font-weight: 700; text-align: center; min-height: 1.2em; }
.form-msg.ok  { color: #2e9e6b; }
.form-msg.err { color: var(--berry-ink); }

/* confetti burst on success */
.confetti {
  position: fixed; z-index: 60; pointer-events: none;
  font-size: 1.2rem; will-change: transform, opacity;
  animation: pop 1s ease-out forwards;
}
@keyframes pop {
  0%   { transform: translate(0,0) scale(.6) rotate(0deg); opacity: 1; }
  100% { transform: translate(var(--dx), var(--dy)) scale(1.1) rotate(var(--rot)); opacity: 0; }
}

/* ==========================================
   Footer
   ========================================== */
.foot { text-align: center; color: var(--ink-soft); font-weight: 600; font-size: 0.9rem; margin-top: 8px; }

/* ==========================================
   Responsive
   ========================================== */
@media (max-width: 460px) {
  .idcard-top { flex-direction: column; align-items: center; text-align: center; }
  .intro { text-align: center; }
  .chips { justify-content: center; }
  .link-pill { flex: 1 1 100%; }
  .status-sticker { top: 14px; right: 14px; }
}

/* ==========================================
   Motion — entrance (IntersectionObserver) + ambient
   ========================================== */
@media (prefers-reduced-motion: no-preference) {
  html.js .reveal {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity .6s cubic-bezier(.2,.7,.2,1), transform .6s cubic-bezier(.2,.7,.2,1);
  }
  html.js .reveal.is-visible { opacity: 1; transform: none; }
  .delay-1 { transition-delay: .05s; }
  .delay-2 { transition-delay: .12s; }
  .delay-3 { transition-delay: .19s; }
  .delay-4 { transition-delay: .26s; }
  .delay-5 { transition-delay: .33s; }
  .doodle  { animation: float 9s ease-in-out infinite; }
  .d2 { animation-delay: 1.5s; } .d3 { animation-delay: 3s; }
  .d4 { animation-delay: 2.2s; } .d5 { animation-delay: 4s; } .d6 { animation-delay: 0.8s; }

  html.js .idcard.is-visible .chip {
    animation: chipIn .55s cubic-bezier(.2,.8,.2,1) backwards;
    animation-delay: calc(.35s + var(--i, 0) * .07s);
  }
}
@keyframes float { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-14px) rotate(8deg); } }
@keyframes chipIn { from { opacity: 0; transform: translateY(14px) scale(.82); } to { opacity: 1; transform: none; } }

/* ==========================================
   Reduced Motion — kill ambient + entrance
   ========================================== */
@media (prefers-reduced-motion: reduce) {
  .doodle, .status-sticker, .status-dot, .ribbon, .avatar::before, .confetti { animation: none; }
}
