
:root {
  --bg: #0f172a;
  --bg-soft: #131d35;
  --surface: rgba(21, 31, 56, 0.9);
  --surface-2: rgba(31, 45, 79, 0.9);
  --text: #e5eefc;
  --muted: #9db1d3;
  --border: rgba(148, 163, 184, 0.16);
  --brand: #7c3aed;
  --brand-2: #9333ea;
  --good: #22c55e;
  --shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
}

:root[data-theme="light"] {
  --bg: #f8fafc;
  --bg-soft: #eef2ff;
  --surface: rgba(255, 255, 255, 0.94);
  --surface-2: rgba(255, 255, 255, 0.98);
  --text: #0f172a;
  --muted: #475569;
  --border: rgba(15, 23, 42, 0.09);
  --shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scrollbar-gutter: stable; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(124, 58, 237, 0.22), transparent 28%),
    radial-gradient(circle at top right, rgba(6, 182, 212, 0.18), transparent 30%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
  color: var(--text);
  min-height: 100vh;
}

body.modal-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, textarea { font: inherit; }

.container { width: min(1240px, calc(100% - 2rem)); margin: 0 auto; }
.narrow { width: min(820px, calc(100% - 2rem)); }
.section { padding: 56px 0; }
.muted-section { background: linear-gradient(180deg, transparent, rgba(255,255,255,0.02), transparent); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(18px);
  background: rgba(12, 19, 36, 0.52);
  border-bottom: 1px solid var(--border);
}
:root[data-theme="light"] .site-header { background: rgba(248,250,252,0.72); }
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 74px;
}
.brand-logo { height: 38px; }
.nav-links { display: flex; align-items: center; gap: .85rem; flex-wrap: wrap; justify-content: flex-end; }
.nav-links a { color: var(--muted); font-size: .98rem; }
.nav-links a:hover { color: var(--text); }
.theme-toggle, .icon-toggle {
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: 999px;
  width: 44px;
  height: 44px;
  cursor: pointer;
}

.hero { padding-top: 28px; }
.hero-grid { display: grid; gap: 1.2rem; grid-template-columns: minmax(320px, 430px) minmax(0, 1fr); align-items: start; }
.hero-copy { max-width: none; position: sticky; top: 96px; }
.hero-copy h1 { max-width: 16ch; }
.eyebrow {
  display: inline-block;
  padding: .45rem .8rem;
  border-radius: 999px;
  background: rgba(124, 58, 237, 0.18);
  color: #d8c6ff;
  font-size: .94rem;
}
:root[data-theme="light"] .eyebrow { color: #5b21b6; }
h1 {
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  line-height: 1.04;
  margin: 1rem 0 .9rem;
}
.lead {
  margin: 0;
  color: var(--muted);
  font-size: 1.08rem;
  max-width: 1000px;
}
.hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.25rem;
}
.hero-badges span {
  padding: .55rem .85rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--muted);
}

.tool-shell {
  margin-top: 0;
  display: grid;
  gap: 1.2rem;
  grid-template-columns: minmax(300px, 390px) minmax(0, 1fr);
  align-items: start;
}
.panel-card,
.wheel-card,
.info-card,
.faq-list details,
.support-card,
.modal-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 24px;
  box-shadow: var(--shadow);
}
.panel-card,
.wheel-card { padding: 1.15rem; position: relative; }
.panel-header,
.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}
.section-head { margin-bottom: 1.35rem; }
.section-head h2,
.panel-header h2,
.info-card h3,
.site-footer h3,
.site-footer h4,
.modal-card h2 { margin: 0; }
.section-head p,
.info-card p,
.site-footer p,
.faq-list p,
.support-card p,
.helper-text,
.modal-note { color: var(--muted); }
.helper-text { margin: .4rem 0 0; font-size: .95rem; }
textarea {
  width: 100%;
  margin-top: .95rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text);
  padding: 1rem;
  resize: vertical;
  min-height: 190px;
}

.option-list {
  display: grid;
  gap: .85rem;
  margin-top: 1rem;
  color: var(--muted);
}
.option-list label {
  display: flex;
  align-items: center;
  gap: .65rem;
}
.panel-actions {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}
.compact-actions { justify-content: space-between; }
.center-actions { justify-content: center; }
.btn {
  border: 0;
  border-radius: 14px;
  padding: .9rem 1.1rem;
  cursor: pointer;
  transition: transform .15s ease, opacity .2s ease, background .2s ease;
}
.btn:hover,
.theme-toggle:hover,
.icon-toggle:hover { transform: translateY(-1px); }
.spin-button:hover { transform: translate(-50%, calc(-50% - 1px)); }
.btn-primary,
.btn-secondary,
.btn-ghost { color: white; }
.btn-primary,
.spin-button {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
}
.btn-secondary {
  background: linear-gradient(135deg, #06b6d4, #3b82f6);
}
.btn-ghost {
  background: rgba(148, 163, 184, 0.12);
  border: 1px solid var(--border);
}

.history-card { margin-top: 1rem; max-height: min(30vh, 270px); overflow: auto; }
.howto-card { margin-top: 1rem; }
.history-list {
  margin: .9rem 0 0;
  padding-left: 1.35rem;
  display: grid;
  gap: .45rem;
}
.history-list li { line-height: 1.4; }

.wheel-toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: .2rem;
}
.wheel-stage {
  position: relative;
  display: grid;
  place-items: center;
  padding: 0 .25rem .25rem;
  min-height: clamp(360px, calc(100vh - 335px), 500px);
}
#wheelCanvas {
  width: min(100%, 56vh);
  max-width: 600px;
  min-width: 320px;
  height: auto;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.32));
}
.pointer {
  position: absolute;
  top: 0;
  width: 0;
  height: 0;
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 34px solid #f8fafc;
  z-index: 2;
}
:root[data-theme="light"] .pointer { border-top-color: #0f172a; }
.spin-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 112px;
  height: 112px;
  padding: 0 0 0 .05em;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-align: center;
  font-size: 1rem;
  border-radius: 999px;
  border: 8px solid rgba(255,255,255,.18);
  color: white;
  font-weight: 800;
  letter-spacing: .04em;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(124,58,237,.35);
}
.spin-button:disabled,
.btn:disabled { cursor: not-allowed; opacity: .5; }
.btn:disabled { transform: none; }
.spin-button:disabled { transform: translate(-50%, -50%); }
.result-card { text-align: center; padding-top: 0; margin-top: .35rem; }
.result-label {
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--muted);
  font-size: .8rem;
  margin: 0;
}
.result-value {
  font-size: clamp(1.35rem, 3vw, 2.15rem);
  margin: .55rem 0 0;
  font-weight: 800;
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.info-card {
  padding: 1.15rem;
  transition: transform .15s ease, border-color .2s ease;
}
.info-card:hover { transform: translateY(-3px); border-color: rgba(124, 58, 237, 0.45); }
.info-card p { margin-bottom: 0; }
.center-head { justify-content: center; }
.faq-list { display: grid; gap: 1rem; }
.faq-list details { padding: 1rem 1.1rem; }
.faq-list summary { cursor: pointer; font-weight: 700; }
.faq-list p { margin: .8rem 0 0; }

.site-footer { padding: 2rem 0 3rem; border-top: 1px solid var(--border); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.35fr .85fr 1fr .9fr;
  gap: 1.25rem;
}
.site-footer ul {
  list-style: none;
  padding: 0;
  margin: .8rem 0 0;
}

.site-footer li { margin-bottom: .65rem; }


.site-footer a { color: var(--muted); }
.site-footer a:hover { color: var(--text); }

.compact-actions-3 .btn { flex: 1 1 0; }
.pill { display:inline-flex; align-items:center; padding:.35rem .65rem; border-radius:999px; font-size:.78rem; background:rgba(124,58,237,.18); color:#d8c6ff; margin-bottom:.75rem; }
:root[data-theme="light"] .pill { color:#5b21b6; }
.coming-soon { opacity:.92; }
.support-section { padding-top: 0; }
.support-card { padding:1.6rem; }
.support-card h2 { margin-top:0; margin-bottom:.8rem; }
.support-card p { max-width: 780px; margin-top:0; margin-bottom:1.2rem; }

.modal {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 0;
  z-index: 30;
  pointer-events: none;
}
.modal.hidden { display: none; }
.modal::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(15,23,42,0.04), rgba(15,23,42,0.32));
  border-radius: 26px;
}
.modal-card { pointer-events: auto; position: relative; }
.modal-card {
  width: min(420px, calc(100% - 2rem));
  padding: 1.35rem;
  text-align: center;
  margin-top: 28px;
}
.modal-kicker {
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--muted);
  font-size: .8rem;
  margin: 0 0 .65rem;
}
.modal-card h2 { font-size: clamp(2rem, 5vw, 3rem); }
.modal-note { margin: .7rem auto 0; max-width: 32ch; }

@media (max-width: 1120px) {
  .hero-grid { display:block; }
  .hero-copy { max-width:none; }
}

@media (max-width: 980px) {
  .tool-shell { grid-template-columns: 1fr; }
  .card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .wheel-stage { min-height: auto; }
}

@media (max-width: 720px) {
  .section { padding: 58px 0; }
  .nav-wrap { min-height: 68px; }
  .nav-links { gap: .75rem; font-size: .95rem; }
  .panel-actions { flex-direction: column; }
  .panel-actions .btn { width: 100%; }
  .card-grid, .footer-grid { grid-template-columns: 1fr; }
  .spin-button { width: 92px; height: 92px; font-size: .92rem; }
  .hero-copy h1 { max-width: 10ch; }
}


.page-main .panel-card { max-width: 820px; margin: 0 auto; text-align: left; }
.page-main h1 { font-size: clamp(2.2rem, 7vw, 3.8rem); line-height: 1.05; max-width: none; }
.page-main .lead { max-width: none; }

.history-intro { margin-top: .85rem; font-weight: 600; }
.hidden { display: none !important; }


.tool-section { padding-top: 10px; padding-bottom: 28px; }
.tool-section .tool-shell { align-items: start; }
.tool-section .wheel-stage { min-height: clamp(360px, calc(100vh - 335px), 500px); }


@media (min-height: 900px) {
  .tool-section .wheel-stage { min-height: clamp(420px, calc(100vh - 360px), 560px); }
  #wheelCanvas { width: min(100%, 60vh); max-width: 640px; }
}

@media (max-width: 1200px) {
  #wheelCanvas { width: min(100%, 52vh); max-width: 560px; }
}

@media (max-width: 980px) {
  #wheelCanvas { width: min(100%, 82vw); min-width: 0; }
  .tool-section .wheel-stage { min-height: auto; }
  .history-card { max-height: none; }
}


@media (max-height: 820px) {
  .tool-shell { gap: 1rem; }
  .panel-card, .wheel-card { padding: 1rem; }
  textarea { min-height: 160px; }
  .result-value { margin-top: .35rem; }
}


/* V2_4 light theme button and control contrast fixes */
:root[data-theme="light"] .btn-primary {
  color: #ffffff;
}
:root[data-theme="light"] .btn-secondary {
  color: #ffffff;
}
:root[data-theme="light"] .btn-ghost {
  background: #f1f5f9;
  color: #111827;
  border: 1px solid #cbd5e1;
}
:root[data-theme="light"] .btn-ghost:hover,
:root[data-theme="light"] .theme-toggle:hover,
:root[data-theme="light"] .icon-toggle:hover {
  background: #e2e8f0;
}
:root[data-theme="light"] .btn:disabled,
:root[data-theme="light"] .spin-button:disabled {
  opacity: .68;
}
:root[data-theme="light"] textarea:disabled,
:root[data-theme="light"] input:disabled,
:root[data-theme="light"] button:disabled {
  color: #94a3b8;
}
:root[data-theme="light"] .option-list,
:root[data-theme="light"] .helper-text,
:root[data-theme="light"] .modal-note,
:root[data-theme="light"] .faq-list p,
:root[data-theme="light"] .support-card p,
:root[data-theme="light"] .site-footer a,
:root[data-theme="light"] .site-footer p,
:root[data-theme="light"] .history-intro,
:root[data-theme="light"] .result-label,
:root[data-theme="light"] .nav-links a {
  color: #475569;
}
:root[data-theme="light"] .nav-links a:hover,
:root[data-theme="light"] .site-footer a:hover {
  color: #0f172a;
}
:root[data-theme="light"] .theme-toggle,
:root[data-theme="light"] .icon-toggle {
  background: rgba(255,255,255,.98);
  color: #111827;
  border-color: #cbd5e1;
}
:root[data-theme="light"] .panel-card,
:root[data-theme="light"] .wheel-card,
:root[data-theme="light"] .info-card,
:root[data-theme="light"] .faq-list details,
:root[data-theme="light"] .support-card,
:root[data-theme="light"] .modal-card {
  background: rgba(255,255,255,.96);
}

/* V2_5 Coin Flip */
.coin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 390px);
  gap: 1.2rem;
  align-items: start;
}
.coin-panel { padding: 1.2rem; }
.coin-stage {
  min-height: 360px;
  display: grid;
  place-items: center;
  perspective: 1200px;
}
.coin-disc {
  position: relative;
  width: min(280px, 70vw);
  aspect-ratio: 1;
  transform-style: preserve-3d;
  transition: transform 1.2s cubic-bezier(.18,.85,.24,1);
}
.coin-face {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  font-weight: 800;
  backface-visibility: hidden;
  border: 8px solid rgba(255,255,255,.12);
  box-shadow: 0 20px 50px rgba(0,0,0,.2), inset 0 6px 20px rgba(255,255,255,.18);
}
.coin-front {
  background: linear-gradient(135deg, #f59e0b, #fcd34d);
  color: #1f2937;
}
.coin-back {
  background: linear-gradient(135deg, #60a5fa, #06b6d4);
  color: white;
  transform: rotateY(180deg);
}
.coin-result { margin-top: 0; }
.coin-history-card { max-height: none; }
.coin-head { align-items: start; }
:root[data-theme="light"] .coin-face { border-color: rgba(15,23,42,.08); }

@media (max-width: 980px) {
  .coin-grid { grid-template-columns: 1fr; }
  .coin-stage { min-height: 300px; }
}


/* V2_6 Random Name Picker */
.picker-grid {
  display: grid;
  gap: 1.2rem;
  grid-template-columns: minmax(300px, 390px) minmax(0, 1fr);
  align-items: start;
}
.picker-stage {
  min-height: 360px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 1rem;
}
.picker-result-box {
  width: min(100%, 560px);
  padding: 2rem 1.25rem;
  border-radius: 24px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(124,58,237,.14), rgba(6,182,212,.08));
}
.picker-result-box .result-value {
  font-size: clamp(2rem, 5vw, 3.3rem);
  word-break: break-word;
}
.picker-empty { color: var(--muted); font-size: 1rem; margin-top: .8rem; }
.picker-actions { margin-top: 1rem; }
.picker-history { margin-top: 1.35rem; max-height: min(30vh, 270px); overflow: auto; }
.picker-history .panel-header { align-items: start; gap: .8rem; }
.picker-history .panel-header .btn { flex-shrink: 0; }
:root[data-theme="light"] .picker-grid .btn-primary { color: #ffffff; box-shadow: 0 8px 20px rgba(109,74,255,.18); }
:root[data-theme="light"] .picker-grid .btn-secondary { color: #ffffff; box-shadow: 0 8px 20px rgba(59,130,246,.14); }
:root[data-theme="light"] .picker-grid .btn-primary:disabled,
:root[data-theme="light"] .picker-grid .btn-secondary:disabled { color: rgba(255,255,255,.85); opacity: .55; }
@media (max-width: 980px) { .picker-grid { grid-template-columns: 1fr; } .picker-stage{min-height:auto;} .picker-history{max-height:none;} }


/* V2_8 Random Name Picker spacing fix */
.picker-grid .compact-actions-3 { margin-bottom: 1.15rem; }
.picker-history { margin-top: 1.2rem !important; }

/* V2_8 Raffle Picker */
.upload-row { margin-top: 1rem; }
.file-help { margin: .45rem 0 0; color: var(--muted); font-size: .92rem; }
.file-input { display:block; width:100%; padding:.9rem 1rem; border-radius:16px; border:1px solid var(--border); background: var(--surface-2); color: var(--text); }
.file-input::file-selector-button { margin-right:.9rem; border:0; border-radius:10px; padding:.65rem .9rem; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; cursor:pointer; }
.raffle-note { margin-top:.8rem; color: var(--muted); font-size:.95rem; }
:root[data-theme="light"] .file-input { background:#fff; }
:root[data-theme="light"] .file-input::file-selector-button { color:#fff; }

.picker-status { color: var(--muted); font-size: .92rem; margin-top: .65rem; }
.name-reveal { animation: nameReveal .32s ease; }
@keyframes nameReveal { 0% { opacity: .2; transform: scale(.96); } 100% { opacity: 1; transform: scale(1); } }
.history-flash { animation: historyFlash .55s ease; }
@keyframes historyFlash { 0% { box-shadow: 0 0 0 0 rgba(34,197,94,.0); } 35% { box-shadow: 0 0 0 4px rgba(34,197,94,.18); } 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); } }
:root[data-theme="light"] .history-flash { animation-name: historyFlashLight; }
@keyframes historyFlashLight { 0% { box-shadow: 0 0 0 0 rgba(59,130,246,0); } 35% { box-shadow: 0 0 0 4px rgba(59,130,246,.16); } 100% { box-shadow: 0 0 0 0 rgba(59,130,246,0); } }


/* V3_0 tool-page and blog polish */
.tool-page-intro { padding: 18px 0 10px; }
.tool-page-intro .section-head { margin-bottom: 0; }
.tool-page-intro h1 { font-size: clamp(2rem, 5vw, 3.25rem); margin: 0 0 .35rem; }
.tool-page-intro .lead { max-width: 820px; }
.picker-history { margin-top: 1rem; }
.blog-cta { margin-top: 1.15rem; display: flex; gap: .75rem; flex-wrap: wrap; }
.blog-cta .btn { display: inline-flex; align-items: center; }
.tool-faq-section { padding-top: 10px; }
.raffle-note, .picker-empty, .picker-status { color: var(--muted); }


.tool-page-intro { padding: 22px 0 8px; }
.tool-page-intro .lead { max-width: 900px; }
.usecase-grid .info-card { display:block; }
.share-row {
  display:flex; flex-wrap:wrap; gap:.65rem; justify-content:center; margin-top: .9rem;
}
.share-btn {
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 110px; padding:.7rem 1rem; border-radius: 12px; border:1px solid var(--border);
  background: rgba(148,163,184,.12); color: var(--text); cursor:pointer;
}
.share-btn:hover { transform: translateY(-1px); background: rgba(148,163,184,.18); }
.share-row.hidden { display:none; }
.mini-confetti { position: absolute; inset: 0; pointer-events:none; overflow:hidden; }
.mini-confetti i { position:absolute; width:8px; height:12px; opacity:0; animation: miniBurst 1s ease-out forwards; }
@keyframes miniBurst { 0% { transform: translate(var(--x0), var(--y0)) rotate(0deg); opacity:1; } 100% { transform: translate(var(--x1), var(--y1)) rotate(420deg); opacity:0; } }
.history-flash { box-shadow: 0 0 0 1px rgba(124,58,237,.3), 0 0 0 8px rgba(124,58,237,.08), var(--shadow); }
.picker-status { margin: .5rem 0 0; color: var(--muted); }
.tool-page-links { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:.95rem; }
.blog-grid { display:grid; gap:1rem; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); }
.blog-card { display:block; }
.blog-cta { display:flex; flex-wrap:wrap; gap:.8rem; margin-top: 1.35rem; }
:root[data-theme="light"] .share-btn { background:#f8fafc; color:#0f172a; border-color: rgba(15,23,42,.14); }
:root[data-theme="light"] .share-btn:hover { background:#e2e8f0; }


/* V2_16 homepage quick tools + blog related tools */
.quick-tools-wrap { margin: 0 0 14px; }
.quick-tools-kicker { color: var(--muted); margin: 0 0 8px; font-size: .95rem; }
.quick-tools{ display:flex; gap:12px; flex-wrap:wrap; }
.quick-tool{ padding:10px 16px; border-radius:12px; background:#6c4cff; color:#fff; text-decoration:none; font-weight:600; }
.quick-tool:hover{ transform: translateY(-1px); }
.footer-contact a { color: var(--text); text-decoration: underline; text-underline-offset: 3px; }
.support-card-has-qr { display:grid; grid-template-columns:minmax(0,1fr) auto; align-items:center; gap:1.25rem; }
.support-card-has-qr h2, .support-card-has-qr > p, .support-card-has-qr > a { grid-column:1; }
.support-qr { grid-column:2; grid-row:1 / span 3; display:grid; justify-items:center; gap:.45rem; color:var(--muted); text-align:center; }
.support-qr img { width:104px; height:104px; border-radius:16px; background:#fff; padding:.35rem; border:1px solid var(--border); }
.support-qr p { margin:0; font-size:.88rem; }
.support-card a:not(.btn), .site-footer a[href="https://theprintlabchronicles.com"] { color:var(--text); text-decoration:underline; text-underline-offset:3px; }
@media (max-width:640px){ .support-card-has-qr{ grid-template-columns:1fr; } .support-card-has-qr h2, .support-card-has-qr > p, .support-card-has-qr > a, .support-qr{ grid-column:1; grid-row:auto; } .support-qr{ justify-items:start; text-align:left; } }
.blog-post-main pre { overflow:auto; padding:1rem; border-radius:16px; border:1px solid var(--border); background:rgba(15,23,42,.36); color:var(--text); }
.blog-post-main code { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; }
:root[data-theme="light"] .blog-post-main pre { background:#f8fafc; color:#0f172a; border-color:rgba(15,23,42,.14); }
.related-tools { margin-top: 1.35rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.related-tools h3 { margin: 0 0 .7rem; font-size: 1rem; }
.related-tools ul { display:flex; flex-wrap:wrap; gap:.7rem 1.25rem; padding:0; margin:0; list-style:none; }
.related-tools a { color: var(--text); text-decoration:none; }
.related-tools a:hover { text-decoration:underline; }
.blog-cta { margin-top: 1.35rem; display:flex; gap:.8rem; flex-wrap:wrap; }


/* V3_1 Truth or Dare */
.truth-dare-grid .panel-card:first-child { max-width: 390px; }
.filter-group { margin-bottom: 1rem; }
.chip-row { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: .35rem; }
.chip { padding: .65rem .95rem; border-radius: 999px; border: 1px solid var(--border); background: rgba(148,163,184,.12); color: var(--text); font-weight: 700; }
.chip-active { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #fff; }
.truth-dare-box .td-result { font-size: clamp(1.55rem, 3.4vw, 2.4rem); line-height: 1.2; }
.truth-links-card { margin-top: 1rem; }
.truth-links-card .btn { text-decoration: none; }
.related-tool-card { margin-top:1rem; background:linear-gradient(135deg, rgba(59,130,246,.14), rgba(16,185,129,.1)); }
.long-list { columns: 2; column-gap: 1.5rem; }
.long-list li { break-inside: avoid; margin: 0 0 .55rem; }
@media (max-width: 780px) { .long-list { columns: 1; } }
:root[data-theme="light"] .chip { background: #f8fafc; color: #0f172a; border-color: rgba(15,23,42,.14); }
:root[data-theme="light"] .chip-active { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; border-color: transparent; }


/* V3_1_2 Truth or Dare polish */
.td-result { transform-origin: center; }
.td-flip { animation: tdFlipReveal .42s ease; }
@keyframes tdFlipReveal { 0% { opacity: .15; transform: rotateX(-75deg) scale(.96); } 100% { opacity: 1; transform: rotateX(0) scale(1); } }

.wyr-or { font-weight: 800; letter-spacing: .12em; text-transform: uppercase; margin: .6rem 0; }
.truth-links-card .tool-page-links .btn { white-space: normal; }


/* V3_3 Team Generator */
.team-grid { display:grid; grid-template-columns: minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.team-chip-row { display:flex; flex-wrap:wrap; gap:.65rem; margin-top:.35rem; }
.team-output-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap:1rem; width:100%; }
.team-card { border:1px solid var(--border); border-radius:18px; padding:1rem; background: rgba(124,58,237,.08); }
.team-card h3 { margin:0 0 .7rem; font-size:1.05rem; }
.team-card ul { margin:0; padding-left:1.15rem; display:grid; gap:.35rem; }
.team-history-card { margin-top:1rem; }
.team-summary { color: var(--muted); margin-top:.5rem; }
@media (max-width: 980px) { .team-grid { grid-template-columns: 1fr; } }

.compact-actions-4 { display:grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap:.75rem; }
.team-card.reveal { animation: teamCardReveal .38s ease both; }
@keyframes teamCardReveal { 0% { opacity:0; transform: translateY(10px) scale(.98); } 100% { opacity:1; transform: translateY(0) scale(1); } }


/* V3_4 Yes / No Picker */
.yesno-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.yesno-box { min-height: 320px; display:grid; place-items:center; text-align:center; }
.yesno-answer { font-size: clamp(3rem, 9vw, 5.6rem); font-weight: 900; letter-spacing: .06em; }
.yesno-question { color: var(--muted); max-width: 46ch; margin: .35rem auto 0; }
.yesno-answer.yes { color: #22c55e; }
.yesno-answer.no { color: #ef4444; }
.yesno-answer.flip { animation: yesNoFlip .34s ease; }
@keyframes yesNoFlip { 0% { opacity:.15; transform: rotateX(90deg) scale(.92); } 100% { opacity:1; transform: rotateX(0) scale(1); } }
.sound-toggle-row { margin-top: .9rem; }
@media (max-width: 980px) { .yesno-grid { grid-template-columns: 1fr; } }


/* Release 4 V4_1 Lucky Stick Draw */
.quick-tool.more-tools { background: rgba(148,163,184,.12); border: 1px solid var(--border); }
:root[data-theme="light"] .quick-tool.more-tools { background: #f8fafc; color:#0f172a; border-color: rgba(15,23,42,.14); }
.lucky-grid { display:grid; grid-template-columns: minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.lucky-stage { position: relative; min-height: 420px; display:grid; place-items:center; overflow:hidden; }
.lucky-scene { position: relative; width:min(360px, 92%); height: 350px; display:grid; place-items:center; }
.bamboo-cylinder { position:absolute; bottom:22px; width: 200px; height: 225px; border-radius: 38px 38px 26px 26px; background: linear-gradient(180deg, #9a6b2f 0%, #b8863b 18%, #8a5f28 40%, #b8863b 68%, #7b5324 100%); box-shadow: inset 0 0 0 4px rgba(255,255,255,.08), inset 0 -14px 25px rgba(0,0,0,.22), 0 20px 50px rgba(0,0,0,.28); }
.bamboo-cylinder::before { content:''; position:absolute; inset: 14px 12px auto; height: 28px; border-radius: 999px; background: rgba(40,20,7,.5); box-shadow: inset 0 4px 10px rgba(255,255,255,.06); }
.bamboo-cylinder::after { content:''; position:absolute; left:50%; top:0; transform:translateX(-50%); width: 8px; height: 100%; background: rgba(255,255,255,.1); }
.lucky-scene.shake .bamboo-cylinder { animation: bambooShake .85s ease-in-out; }
@keyframes bambooShake { 0%,100%{ transform: translateX(0) rotate(0deg);} 15%{ transform: translateX(-8px) rotate(-3deg);} 30%{ transform: translateX(7px) rotate(2deg);} 45%{ transform: translateX(-6px) rotate(-2deg);} 60%{ transform: translateX(5px) rotate(2deg);} 75%{ transform: translateX(-3px) rotate(-1deg);} }
.stick-fan { position:absolute; bottom: 198px; width: 280px; height: 150px; pointer-events:none; }
.stick { position:absolute; left:50%; bottom:0; width: 18px; height: 165px; transform-origin: bottom center; border-radius: 14px 14px 6px 6px; background: linear-gradient(180deg, #f3dfb1 0%, #e9c98a 45%, #d5a75f 100%); box-shadow: inset 0 0 0 2px rgba(132,82,25,.16), 0 10px 18px rgba(0,0,0,.16); }
.stick::after { content:''; position:absolute; left:50%; top: 18px; transform:translateX(-50%); width: 36px; max-width:90%; text-align:center; font-weight: 800; color:#7b3f00; font-size: 1rem; }
.stick[data-num]::after { content: attr(data-num); }
.draw-stick { position:absolute; left:50%; bottom: 80px; transform: translateX(-50%) translateY(95px) scale(.9); width: 24px; height: 205px; opacity:0; border-radius: 14px 14px 6px 6px; background: linear-gradient(180deg, #f8e6bf 0%, #edcb8d 44%, #d39f4f 100%); box-shadow: inset 0 0 0 2px rgba(132,82,25,.16), 0 12px 24px rgba(0,0,0,.22); transition: transform .58s ease, opacity .28s ease; }
.draw-stick::after { content: attr(data-num); position:absolute; top: 20px; left:50%; transform:translateX(-50%); font-weight:900; color:#7b3f00; font-size: 1.15rem; }
.lucky-scene.reveal .draw-stick { opacity:1; transform: translateX(-50%) translateY(-42px) scale(1.02); }
.lucky-glow { position:absolute; inset:auto 0 0; margin:auto; width: 260px; height: 90px; border-radius: 50%; background: radial-gradient(circle, rgba(124,58,237,.26), transparent 70%); filter: blur(18px); }
.lucky-number-chip { display:inline-flex; align-items:center; justify-content:center; min-width:70px; padding:.5rem .9rem; border-radius:999px; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; font-weight:800; letter-spacing:.04em; }
@media (max-width: 980px) { .lucky-grid { grid-template-columns: 1fr; } .lucky-stage { min-height: 360px; } }

.pretty-number-wrap { display:flex; align-items:center; gap:.7rem; margin-top:.35rem; }
.pretty-number-input { width: 120px; height: 48px; border-radius: 14px; border: 1px solid var(--border); background: rgba(148,163,184,.08); color: var(--text); padding: 0 .95rem; font-size: 1.1rem; font-weight: 700; box-shadow: inset 0 0 0 1px rgba(255,255,255,.03); }
.pretty-number-input:focus { outline: none; border-color: rgba(99,102,241,.55); box-shadow: 0 0 0 3px rgba(99,102,241,.16); }
.pretty-number-badge { display:inline-flex; align-items:center; justify-content:center; height: 40px; padding: 0 .8rem; border-radius: 999px; background: rgba(124,58,237,.14); color: var(--text); font-weight: 700; }
.lucky-wheel-card { min-height: auto; }
:root[data-theme="light"] .pretty-number-input { background:#fff; color:#0f172a; border-color: rgba(15,23,42,.14); }


/* Lucky Stick Draw polish */
.lucky-intro { padding-top: 18px; padding-bottom: 8px; }
.lucky-intro .section-head { margin-bottom: 0; }
.lucky-intro h1 { margin-bottom: .35rem; }
.lucky-intro .lead { max-width: 52rem; }
.lucky-wheel-card { align-self: start; }
.lucky-stage { min-height: 320px; }
.lucky-scene { width:min(320px, 90%); height: 280px; overflow: visible; }
.bamboo-cylinder { bottom:16px; width: 176px; height: 196px; }
.bamboo-cylinder::before { inset: 12px 10px auto; height: 24px; }
.stick-fan { bottom: 166px; width: 240px; height: 122px; z-index: 2; }
.stick { width: 16px; height: 148px; }
.lucky-scene.shake .bamboo-cylinder, .lucky-scene.shake .stick-fan, .lucky-scene.shake .draw-stick { animation: bambooShake .85s ease-in-out; }
.draw-stick { z-index: 3; bottom: 70px; transform: translateX(-50%) translateY(78px) scale(.92); width: 22px; height: 182px; }
.draw-stick::after { top: 16px; font-size: 1.05rem; }
.lucky-scene.reveal .draw-stick { opacity:1; transform: translateX(-50%) translateY(18px) scale(1); }
.lucky-confetti { z-index: 5; overflow: visible; inset: -20px; }
.lucky-scene .lucky-glow { z-index: 1; }
.lucky-scene .bamboo-cylinder { z-index: 4; }
.pretty-number-wrap { display:flex; align-items:center; gap:.65rem; margin-top:.35rem; }
.pretty-number-input { width: 110px; padding: .8rem .9rem; border-radius: 14px; border:1px solid var(--border); background: rgba(255,255,255,.08); color: var(--text); font-weight: 700; font-size: 1rem; box-shadow: inset 0 1px 0 rgba(255,255,255,.04); }
.pretty-number-badge { display:inline-flex; align-items:center; justify-content:center; padding:.65rem .85rem; border-radius: 999px; background: rgba(124,58,237,.14); color: var(--muted); font-weight:700; }
:root[data-theme="light"] .pretty-number-input { background: #fff; border-color: rgba(15,23,42,.14); color:#0f172a; }
@media (max-width: 980px) { .lucky-stage { min-height: 290px; } .lucky-scene { height: 250px; width:min(290px, 90%); } }


/* V4_1_3 Lucky Stick layering fix */
.lucky-stage { min-height: 360px; overflow: visible; }
.lucky-wheel-card { overflow: visible; }
.lucky-scene { width:min(330px, 92%); height: 310px; overflow: visible; }
.stick-fan { bottom: 170px; height: 138px; z-index: 6; }
.stick { z-index: 6; }
.draw-stick { z-index: 7; bottom: 74px; }
.lucky-scene.reveal .draw-stick { opacity:1; transform: translateX(-50%) translateY(6px) scale(1); }
.lucky-scene .bamboo-cylinder { z-index: 4; }
.lucky-confetti { z-index: 8; }
.result-card, .result-card * { position: relative; z-index: 1; }
@media (max-width: 980px) {
  .lucky-stage { min-height: 330px; }
  .lucky-scene { height: 285px; width:min(300px, 92%); }
}


/* V4_2 Dice Roller */
.dice-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.dice-stage { min-height: 340px; display:grid; place-items:center; }
.dice-canvas { display:grid; gap:1rem; justify-items:center; width:100%; }
.dice-box { display:grid; grid-template-columns: repeat(auto-fit,minmax(120px,1fr)); gap:1rem; justify-items:center; align-items:center; }
.dice-box { width:min(520px,92%); min-height:220px; }
.die-card { width:min(160px,28vw); aspect-ratio:1; border-radius:28px; background:linear-gradient(135deg,#f8fafc,#dbeafe); border:1px solid rgba(15,23,42,.14); box-shadow:0 22px 40px rgba(15,23,42,.18); position:relative; display:grid; place-items:center; }
.die-card.roll { animation:diceRoll .55s ease; }
.die-card-number { font-size: clamp(2.3rem, 5vw, 3.4rem); font-weight:900; color:#0f172a; opacity:.94; }
.dice-box.roll { animation:diceRoll .45s ease; }
@keyframes diceRoll { 0% { transform:translateY(0) rotate(0) scale(1);} 25% { transform:translateY(-8px) rotate(12deg) scale(.96);} 55% { transform:translateY(3px) rotate(-11deg) scale(1.03);} 100% { transform:translateY(0) rotate(0) scale(1);} }
.pip { width:18px; height:18px; border-radius:999px; background:#0f172a; position:absolute; }
.dice-total { font-size: clamp(2.4rem, 6vw, 4rem); font-weight:900; }
.dice-meta { color: var(--muted); }
.dice-chip-row { display:flex; flex-wrap:wrap; gap:.65rem; margin-top:.35rem; }
@media (max-width:980px){ .dice-grid{ grid-template-columns:1fr; } }

.dice-box .pip { position:absolute; width:18px; height:18px; border-radius:999px; background:#0f172a; }


/* V4_3 Number Generator */
.number-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.number-input-row { display:grid; grid-template-columns: 1fr 1fr; gap:.8rem; }
.number-field label { display:block; color: var(--muted); margin-bottom:.35rem; }
.number-field input { width:100%; padding:.85rem 1rem; border-radius:16px; border:1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); font: inherit; }
.number-count-chips { display:flex; gap:.65rem; flex-wrap:wrap; margin-top:.35rem; }
.number-result-stack { display:grid; gap:1rem; width:100%; }
.number-pill-grid { display:flex; flex-wrap:wrap; gap:.85rem; justify-content:center; }
.number-pill { min-width:88px; min-height:88px; padding:1rem; display:grid; place-items:center; border-radius:22px; font-size:2rem; font-weight:900; background: linear-gradient(135deg, rgba(124,58,237,.24), rgba(59,130,246,.18)); border:1px solid var(--border); box-shadow: var(--shadow); }
.number-pill.reveal { animation:numberPop .36s ease both; }
@keyframes numberPop { 0% { opacity:.2; transform: scale(.86) translateY(6px); } 100% { opacity:1; transform: scale(1) translateY(0); } }
@media (max-width:980px){ .number-grid{ grid-template-columns:1fr; } }


/* V4_4 Tournament / Bracket Picker */
.bracket-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.bracket-board { width:100%; overflow:auto; padding:.5rem 0; }
.bracket-rounds { display:grid; grid-auto-flow:column; grid-auto-columns:minmax(190px,1fr); gap:1rem; align-items:start; }
.bracket-round { display:grid; gap:1rem; }
.bracket-round h3 { margin:0; font-size:1rem; }
.bracket-match { border:1px solid var(--border); border-radius:16px; background: rgba(148,163,184,.08); padding:.75rem .9rem; display:grid; gap:.45rem; min-height:74px; }
.bracket-player { font-weight:700; }
.bracket-vs { color:var(--muted); font-size:.9rem; }
.bracket-bye { color: var(--muted); font-style: italic; }
.bracket-summary { color:var(--muted); margin-top:.75rem; }
@media (max-width: 980px) { .bracket-grid { grid-template-columns: 1fr; } .bracket-rounds { grid-auto-flow: row; grid-auto-columns: unset; grid-template-columns:1fr; } }


/* V4_5 Group Assignment Generator */
.group-assignment-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.assignment-output-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap:1rem; width:100%; }
.assignment-card { border:1px solid var(--border); border-radius:18px; padding:1rem; background: rgba(16,185,129,.08); }
.assignment-card h3 { margin:0 0 .7rem; font-size:1.05rem; }
.assignment-card ul { margin:0; padding-left:1.15rem; display:grid; gap:.35rem; }
.assignment-card.reveal { animation: assignmentCardReveal .36s ease both; }
@keyframes assignmentCardReveal { 0% { opacity:0; transform: translateY(10px) scale(.98);} 100% { opacity:1; transform: translateY(0) scale(1);} }
@media (max-width:980px){ .group-assignment-grid{ grid-template-columns:1fr; } }


/* V5_7 Desk assignment tools */
.desk-tool-grid { display:grid; grid-template-columns:minmax(320px,460px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.desk-two-col { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.desk-field { display:block; margin-top:1rem; }
.desk-field span { display:block; color:var(--muted); font-size:.94rem; font-weight:700; margin-bottom:.4rem; }
.desk-field input { width:100%; min-height:46px; padding:.75rem .9rem; border-radius:14px; border:1px solid var(--border); background:var(--surface-2); color:var(--text); font:inherit; }
.desk-field textarea { margin-top:0; min-height:160px; }
.desk-small-textarea { min-height:86px !important; }
.desk-inline-tools { display:grid; grid-template-columns:1.3fr .75fr .75fr auto; gap:.75rem; align-items:end; margin-top:1rem; }
.desk-inline-tools .desk-field { margin-top:0; }
.privacy-strip { margin-top:1rem; padding:.8rem .95rem; border-radius:16px; border:1px solid rgba(34,197,94,.28); background:rgba(34,197,94,.09); color:var(--text); font-weight:700; font-size:.94rem; }
.day-toggle-row { display:flex; flex-wrap:wrap; gap:.65rem; margin-top:.45rem; }
.day-toggle-row label { display:flex; align-items:center; gap:.4rem; padding:.65rem .85rem; border:1px solid var(--border); border-radius:999px; background:rgba(148,163,184,.1); color:var(--text); font-weight:700; }
.desk-result-box { width:min(100%,760px); }
.desk-output { width:100%; display:grid; gap:1rem; margin-top:1rem; }
.desk-assignment-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:.85rem; width:100%; }
.desk-assignment-card { border:1px solid var(--border); border-radius:16px; padding:.85rem; background:rgba(59,130,246,.1); text-align:left; }
.desk-assignment-card h3 { margin:0 0 .4rem; font-size:1.05rem; }
.desk-assignment-card p { margin:0; color:var(--text); font-weight:800; overflow-wrap:anywhere; }
.desk-assignment-card.reveal, .desk-day-card.reveal { animation:assignmentCardReveal .36s ease both; }
.desk-warning, .desk-muted-list { display:grid; gap:.35rem; text-align:left; border:1px solid var(--border); border-radius:16px; padding:.85rem; }
.desk-warning { background:rgba(244,63,94,.12); }
.desk-muted-list { background:rgba(148,163,184,.1); color:var(--muted); }
.desk-warning span, .desk-muted-list span { color:var(--muted); overflow-wrap:anywhere; }
.desk-day-card { display:grid; gap:.65rem; border:1px solid var(--border); border-radius:18px; padding:1rem; background:rgba(16,185,129,.08); text-align:left; }
.desk-day-card h3 { margin:0; font-size:1.1rem; }
.desk-schedule-row { display:grid; grid-template-columns:minmax(70px,.7fr) minmax(120px,1.25fr) minmax(80px,1fr); gap:.65rem; align-items:center; padding:.65rem .7rem; border-radius:12px; background:rgba(148,163,184,.1); }
.desk-schedule-row span, .desk-schedule-row em { overflow-wrap:anywhere; }
.desk-schedule-row em { color:var(--muted); font-style:normal; font-size:.92rem; }
.howto-steps { margin:.95rem 0 0; padding-left:1.25rem; color:var(--muted); display:grid; gap:.65rem; }
.howto-steps li { line-height:1.5; }
.howto-steps strong { color:var(--text); }
:root[data-theme="light"] .desk-field input, :root[data-theme="light"] .desk-field textarea { background:#fff; color:#0f172a; border-color:rgba(15,23,42,.14); }
:root[data-theme="light"] .day-toggle-row label { background:#f8fafc; color:#0f172a; border-color:rgba(15,23,42,.14); }
:root[data-theme="light"] .privacy-strip { color:#14532d; background:#dcfce7; border-color:#86efac; }
@media (max-width:980px){ .desk-tool-grid{ grid-template-columns:1fr; } .desk-two-col{ grid-template-columns:1fr; } .desk-inline-tools{ grid-template-columns:1fr 1fr; } .desk-inline-tools .btn{ grid-column:1 / -1; } }
@media (max-width:620px){ .desk-schedule-row{ grid-template-columns:1fr; } .desk-inline-tools{ grid-template-columns:1fr; } }


/* V5_1 tools */
.generator-grid { display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
.generator-stage { min-height:340px; display:grid; place-items:center; }
@media (max-width:980px){ .generator-grid{ grid-template-columns:1fr; } .generator-stage{ min-height:auto; } }
.result-stack { display:grid; gap:1rem; width:min(680px,94%); justify-items:center; }
.result-boxes { display:flex; flex-wrap:wrap; gap:.85rem; justify-content:center; }
.letter-tile, .lottery-ball, .color-swatch, .food-pill { min-width:88px; min-height:88px; padding:1rem; display:grid; place-items:center; border-radius:22px; font-size:2rem; font-weight:900; background: linear-gradient(135deg, rgba(124,58,237,.24), rgba(59,130,246,.18)); border:1px solid var(--border); box-shadow: var(--shadow); }
.letter-tile.reveal, .lottery-ball.reveal, .color-swatch.reveal, .food-pill.reveal { animation:numberPop .36s ease both; }
.color-swatch { width:120px; height:120px; min-width:120px; min-height:120px; border-radius:24px; position:relative; overflow:hidden; }
.color-code { font-size:1rem; font-weight:800; background:rgba(15,23,42,.5); color:#fff; padding:.3rem .6rem; border-radius:999px; }
.food-pill { min-width:160px; min-height:70px; font-size:1.1rem; border-radius:18px; }
.lottery-ball { border-radius:999px; min-width:72px; min-height:72px; background:linear-gradient(135deg, #f8fafc, #cbd5e1); color:#0f172a; }
.bonus-ball { background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; }
.result-meta { color: var(--muted); text-align:center; }
.inline-range { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.error-note { color:#fca5a5; }
.preset-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.65rem; margin-top:.35rem; }
.preset-btn { text-align:left; padding:.75rem .9rem; border-radius:16px; border:1px solid var(--border); background:rgba(148,163,184,.12); color:var(--text); font-weight:700; }
.preset-btn.active { background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; }
@media (max-width:700px){ .preset-grid{ grid-template-columns:1fr; } .inline-range{ grid-template-columns:1fr; } }
:root[data-theme="light"] .preset-btn { background:#f8fafc; color:#0f172a; border-color:rgba(15,23,42,.14); }
:root[data-theme="light"] .preset-btn.active { background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#fff; border-color:transparent; }


/* V6 Movie / Activity / Animal */
.media-grid{ display:grid; grid-template-columns:minmax(300px,390px) minmax(0,1fr); gap:1.2rem; align-items:start; }
@media (max-width:980px){ .media-grid{ grid-template-columns:1fr; } }
.movie-card, .activity-card, .animal-card { width:min(620px,94%); display:grid; gap:1rem; justify-items:center; text-align:center; }
.poster-faux { width:min(220px,64vw); aspect-ratio: 2 / 3; border-radius: 22px; background: linear-gradient(135deg, rgba(124,58,237,.24), rgba(59,130,246,.18)); border:1px solid var(--border); box-shadow: var(--shadow); display:grid; place-items:center; padding:1rem; }
.poster-faux .poster-title { font-size: clamp(1.5rem, 4vw, 2.4rem); font-weight:900; line-height:1.1; }
.poster-faux .poster-year { color: var(--muted); font-weight:700; }
.movie-meta-list, .activity-meta-list, .animal-meta-list { display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; }
.meta-pill { padding:.55rem .8rem; border-radius:999px; background: rgba(124,58,237,.14); border:1px solid var(--border); color: var(--text); font-weight:700; }
.mono-code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.animal-emoji { font-size: clamp(4rem, 8vw, 6rem); line-height:1; min-height: 1em; display:grid; place-items:center; }
.activity-icon { font-size: clamp(3rem, 7vw, 4.5rem); line-height:1; }
.result-fact { max-width: 58ch; color: var(--muted); }


/* Release 6 final movie picker polish */
.media-grid{ grid-template-columns:minmax(420px,500px) minmax(0,1fr); }
.movie-picker-actions-top{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:.75rem; margin:.75rem 0 1rem; }
.movie-card{ width:min(620px,96%); position:relative; }
.poster-faux{
  width:min(245px,62vw);
  min-height:340px;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:1rem;
  padding:1.25rem 1rem;
}
.poster-faux::before{
  content:"";
  position:absolute;
  inset:auto 12% -8% 12%;
  height:28%;
  border-radius:999px;
  background:radial-gradient(circle, rgba(124,58,237,.28), rgba(59,130,246,.10) 55%, transparent 75%);
  filter:blur(18px);
  opacity:.55;
  transform:scale(.92);
  pointer-events:none;
}
.poster-faux::after{
  content:"";
  position:absolute;
  inset:-20%;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.16) 50%, transparent 70%);
  transform:translateX(-140%) rotate(12deg);
  pointer-events:none;
}
.poster-faux.reveal::after{ animation:posterSweep .78s ease; }
.poster-faux.reveal{ animation:moviePosterLift .46s ease; }
.poster-faux.reveal::before{ animation:posterGlow 1.1s ease; }
.poster-faux .poster-title{
  width:100%;
  max-width:100%;
  font-size:clamp(1.45rem, 3.4vw, 2.2rem);
  font-weight:900;
  line-height:1.12;
  text-align:center;
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
  hyphens:auto;
  padding:0 .25rem;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  overflow:hidden;
}
.poster-faux .poster-year{
  color: var(--muted);
  font-weight:700;
  margin-top:auto;
}
@keyframes posterSweep{0%{transform:translateX(-140%) rotate(12deg);}100%{transform:translateX(140%) rotate(12deg);}}
@keyframes moviePosterLift{0%{opacity:.12;transform:translateY(8px) scale(.97);}100%{opacity:1;transform:translateY(0) scale(1);}}
@keyframes posterGlow{0%{opacity:.2;transform:scale(.88);}45%{opacity:.8;transform:scale(1.02);}100%{opacity:.55;transform:scale(.92);}}
.footer-categories-list li + li{ margin-top:.5rem; }
@media (max-width:980px){ .media-grid{ grid-template-columns:1fr; } }


/* Final polish: tools/use-cases/blog spacing */
.tools-page-main-section { padding-top: 28px !important; }
.tools-page-intro-gap .section-head { margin-bottom: 18px; }
.blog-post-main .panel-card { margin-bottom: 32px; }
.blog-post-main .support-section { padding-top: 8px; }
.blog-post-main .support-card { margin-top: 12px; }
.use-cases-card-grid { margin-top: 16px; }


/* Final tools page spacing fix */
.tools-page-main-section{ padding-top:48px !important; }
.tools-page-main-section .panel-card:first-child{ margin-top:24px !important; }


/* Final tools layout alignment fix */
.tools-page-main-section .container{
  max-width: 1180px;
}
.tools-page-main-section .panel-card{
  width: 100%;
}
.tools-page-main-section{
  padding-top: 24px !important;
}


/* Final tools page spacing polish */
.tools-page-main-section{
  padding-top: 24px !important;
}
.tools-page-main-section .container{
  max-width: 1180px;
}
.tools-page-main-section .panel-card{
  width: 100%;
}
.tools-page-main-section .panel-card > h2{
  margin-bottom: .55rem;
}
.tools-page-main-section .panel-card > .helper-text{
  display: block;
  margin: 0 0 1.1rem 0 !important;
}
.tools-page-main-section .panel-card > .card-grid{
  margin-top: .25rem !important;
  align-items: stretch;
}
.tools-page-main-section .panel-card + .panel-card{
  margin-top: 1rem;
}
.tools-page-main-section .info-card h3{
  margin-bottom: .7rem;
}
.tools-page-main-section .info-card p{
  margin-top: 0;
}


/* Release 7 programmatic SEO pages */
.programmatic-hub-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1rem; margin-top:1rem; }
.programmatic-note{ color:var(--muted); margin-top:.9rem; }
.programmatic-list{ display:grid; gap:.9rem; margin-top:1rem; }
.programmatic-list a{ display:block; padding:.95rem 1rem; border:1px solid var(--border); border-radius:18px; background:var(--surface-2); }
.programmatic-list a strong{ display:block; margin-bottom:.35rem; }

/* Footer share actions */
.footer-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.footer-copy {
  margin: 0;
  color: var(--muted);
}

.share-spinrandomtool {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

.footer-share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: .65rem .9rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text);
  font-weight: 700;
  line-height: 1;
  transition: transform .15s ease, border-color .2s ease, background .2s ease;
}

.footer-share-btn:hover {
  transform: translateY(-2px);
  border-color: rgba(124, 58, 237, .45);
}

.footer-share-btn.copy {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  border-color: transparent;
}

@media (max-width: 700px) {
  .footer-meta {
    align-items: flex-start;
  }
}
