:root{
  --bg:#f6f8fb;
  --card:#ffffff;
  --text:#111827;
  --muted:#5f6b7a;
  --border:#dbe3ee;
  --accent:#2563eb;
  --accent-2:#14b8a6;
  --soft:#eef5ff;
  --shadow:0 16px 40px rgba(15,23,42,.08);
}
[data-theme="dark"]{
  --bg:#0b1120;
  --card:#111827;
  --text:#eef2ff;
  --muted:#a6b3c5;
  --border:#273449;
  --accent:#60a5fa;
  --accent-2:#2dd4bf;
  --soft:#172033;
  --shadow:0 16px 40px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
[hidden]{display:none!important}
img,svg,canvas,video{max-width:100%;height:auto}
input,textarea,select,button,.btn{max-width:100%}
h1,h2,h3,h4,p,li,a,span,strong,small,em,label,.result,.card,.tool-workspace{overflow-wrap:anywhere}
.container,.grid,.card,.tool-workspace,.result,.secret-panel,.secret-shell{min-width:0}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Arial,sans-serif}
a{color:inherit}
.container{max-width:1120px;margin:0 auto;padding:18px}
.site-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}
.brand img{width:52px;height:52px;border-radius:12px}
.brand strong{display:block;font-size:1.25rem}
.brand small{display:block;color:var(--muted);font-size:.85rem}
.nav{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px}
.nav a{padding:9px 12px;border-radius:9px;text-decoration:none;color:var(--muted);transition:.2s ease}
.nav a:hover{background:var(--soft);color:var(--text)}
.theme-toggle{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:999px;padding:9px 13px;display:flex;align-items:center;gap:8px;cursor:pointer;box-shadow:var(--shadow);transition:.2s ease}
.theme-toggle:hover{transform:translateY(-1px);border-color:var(--accent)}
.home-hero,.page-title,.tool-intro{padding:24px 0}
.home-hero h1,.page-title h1,.tool-intro h1{font-size:clamp(2rem,4vw,3.4rem);line-height:1.08;margin:0 0 12px;letter-spacing:0}
.home-hero p,.page-title p,.tool-intro p,.seo-content p,.faq-item p,.card p{color:var(--muted);line-height:1.7}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin:18px 0}
.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:18px;box-shadow:var(--shadow);transition:.2s ease}
.card:hover{transform:translateY(-3px);border-color:var(--accent)}
.card h2,.card h3{margin-top:0}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;padding:10px 14px;text-decoration:none;font-weight:750;cursor:pointer;transition:.2s ease;min-height:42px}
.btn:hover{transform:translateY(-2px);filter:saturate(1.08)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}
.btn-secondary{background:var(--soft);color:var(--text);border:1px solid var(--border)}
.btn-share{background:#111827;color:#fff}
[data-theme="dark"] .btn-share{background:#e5e7eb;color:#111827}
.btn-click{min-width:140px;min-height:72px;font-size:1.15rem}
.button-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0}
.button-row.center{justify-content:center}
.breadcrumb{color:var(--muted);font-size:.95rem;margin:8px 0 16px}
.breadcrumb a{text-decoration:none;color:var(--accent)}
.search{margin:4px 0 20px}
.search input,.input,textarea,select{width:100%;border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;padding:11px 12px;font:inherit}
label{display:block;color:var(--text);font-weight:700;margin:8px 0}
label input,label textarea,label select{margin-top:7px}
.input-hint{display:block;margin-top:6px;color:var(--muted);font-size:.9rem;font-weight:700}
.field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.field-grid.single{grid-template-columns:minmax(0,420px)}
.field-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.large-text{min-height:160px;resize:vertical}
.tool-workspace{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px;box-shadow:var(--shadow);margin-bottom:14px}
.tool-heading h2{margin:0}
.tool-heading p{margin-top:6px;color:var(--muted)}
.result{background:var(--soft);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:12px;min-height:46px;line-height:1.6}
.share-row{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 26px}
.seo-content,.related-section,.faq-section{margin-top:30px}
.seo-content h2,.related-section h2,.faq-section h2{margin-top:22px}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:14px;margin:12px 0}
.faq-item h3{margin:0 0 8px}
.footer{margin:34px 0 10px;padding:18px;text-align:center;color:#0f172a;border-radius:12px;background:linear-gradient(135deg,#7ee8fa,#80ff72);font-weight:800}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.split-tool{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.split-tool.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.preview-image{display:none;max-width:100%;border:1px solid var(--border);border-radius:10px;margin-top:12px}
.preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px}
.preview-box,.mini-preview{min-height:170px;border:1px dashed var(--border);border-radius:10px;background:var(--soft);display:flex;align-items:center;justify-content:center;padding:12px;color:var(--muted)}
.preview-box img,.mini-preview img{max-width:100%;border-radius:8px}
.qr-preview{text-align:center;margin-top:14px}
.qr-preview img{display:none;max-width:100%;border:1px solid var(--border);border-radius:10px;padding:10px;background:#fff}
.palette-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:12px}
.color-tile{min-height:110px;border-radius:10px;display:flex;align-items:end;padding:10px;font-weight:800;cursor:pointer}
.dice-visual{
  text-align:center;
  margin:18px 0;
}
.dice-empty{
  display:inline-flex;
  min-height:72px;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-weight:800;
}
.dice-board{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:14px;
  padding:16px;
  border:1px solid rgba(14,165,233,.18);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(20,184,166,.10));
}
.dice-face{
  position:relative;
  width:76px;
  aspect-ratio:1;
  display:block;
  border-radius:18px;
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.72),transparent 20%),
    linear-gradient(145deg,#ffffff,#e8f0ff);
  border:1px solid rgba(37,99,235,.18);
  box-shadow:0 14px 28px rgba(15,23,42,.14),inset 0 -8px 18px rgba(37,99,235,.10);
  animation:dice-pop .32s ease both;
}
.dice-pip{
  position:absolute;
  width:12px;
  height:12px;
  border-radius:999px;
  background:#0f172a;
  box-shadow:inset 0 -2px 3px rgba(255,255,255,.22);
}
.dice-pip-top-left{top:18px;left:18px}
.dice-pip-top-right{top:18px;right:18px}
.dice-pip-middle-left{top:50%;left:18px;transform:translateY(-50%)}
.dice-pip-middle-right{top:50%;right:18px;transform:translateY(-50%)}
.dice-pip-center{top:50%;left:50%;transform:translate(-50%,-50%)}
.dice-pip-bottom-left{bottom:18px;left:18px}
.dice-pip-bottom-right{bottom:18px;right:18px}
[data-theme="dark"] .dice-face{
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.22),transparent 20%),
    linear-gradient(145deg,#1e293b,#0f172a);
  border-color:rgba(125,211,252,.24);
}
[data-theme="dark"] .dice-pip{background:#e0f2fe}
@keyframes dice-pop{
  from{transform:translateY(10px) rotate(-8deg) scale(.72);opacity:.25}
  to{transform:translateY(0) rotate(0deg) scale(1);opacity:1}
}
.wheel-wrap{position:relative;text-align:center;margin:18px auto;max-width:320px}
#wheel_canvas{max-width:100%;border-radius:50%;box-shadow:var(--shadow)}
.wheel-pointer{position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:22px solid var(--accent)}
.ttt-board{display:grid;grid-template-columns:repeat(3,88px);gap:8px;justify-content:center}
.ttt-cell{height:88px;border:1px solid var(--border);border-radius:10px;background:var(--soft);color:var(--text);font-size:2rem;font-weight:900;cursor:pointer}
.score-board,.stats-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:14px 0}
.score-board span,.stats-grid .result{min-width:120px;text-align:center}
.game-final-result{margin:16px auto 0;max-width:760px}
.game-result-card{
  display:grid;
  gap:10px;
  padding:16px;
  border:1px solid rgba(14,165,233,.24);
  border-radius:14px;
  background:linear-gradient(135deg,rgba(37,99,235,.10),rgba(20,184,166,.10));
  box-shadow:0 12px 26px rgba(15,23,42,.08);
}
.game-result-card strong{
  font-size:clamp(1.2rem,3vw,1.55rem);
  color:#0f766e;
}
.game-result-card span{color:var(--text);line-height:1.55}
.game-challenge-line{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  justify-content:space-between;
  padding-top:8px;
  border-top:1px solid rgba(148,163,184,.28);
}
.game-challenge-line span{flex:1 1 260px;color:var(--muted);font-weight:700}
[data-theme="dark"] .game-result-card{
  background:linear-gradient(135deg,rgba(96,165,250,.16),rgba(45,212,191,.12));
  border-color:rgba(125,211,252,.28);
}
[data-theme="dark"] .game-result-card strong{color:#5eead4}
.typing-prompt{
  margin:14px 0;
  padding:16px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--soft);
  color:var(--text);
  font-weight:800;
  line-height:1.75;
  white-space:pre-wrap;
}
.typing-input{
  min-height:150px;
  font-size:1rem;
  line-height:1.7;
}
.typing-workspace .stats-grid .result{
  display:grid;
  gap:4px;
}
.typing-workspace .stats-grid .result span{
  color:var(--muted);
  font-size:.86rem;
  font-weight:800;
}
.memory-board{display:grid;grid-template-columns:repeat(4,74px);gap:8px;justify-content:center;margin:14px 0}
.mem-card{width:74px;height:74px;border-radius:10px;background:var(--soft);display:flex;align-items:center;justify-content:center;font-size:2rem;cursor:pointer;position:relative;transform-style:preserve-3d;transition:transform .45s ease}
.mem-card.flipped{transform:rotateY(180deg)}
.mem-card.matched{background:#16a34a;color:#fff}
.mem-card-back,.mem-card-front{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border-radius:10px;backface-visibility:hidden}
.mem-card-front{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;transform:rotateY(180deg)}
.keyboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(38px,1fr));gap:6px;margin:16px 0}
.btn-small{min-height:36px;padding:8px;border-radius:9px}
.hangman-art{background:var(--soft);border-radius:10px;padding:14px;overflow:auto;min-height:150px}
.word-display{text-align:center;font-size:2rem;letter-spacing:8px;font-weight:900;margin:16px 0}
.muted{color:var(--muted)}
.notification{position:fixed;top:18px;right:18px;padding:12px 16px;border-radius:10px;color:#fff;font-weight:800;z-index:9999;box-shadow:var(--shadow)}
@media (max-width:760px){
  .site-header{align-items:flex-start}.nav{gap:6px}.nav a{font-size:.92rem;padding:8px 9px}
  .split-tool,.split-tool.three,.preview-grid,.field-grid.two{grid-template-columns:1fr}
  .ttt-board{grid-template-columns:repeat(3,72px)}.ttt-cell{height:72px}
  .memory-board{grid-template-columns:repeat(4,1fr)}.mem-card{width:100%;height:auto;aspect-ratio:1}
  .button-row .btn,.share-row .btn{width:100%}
}


/* Validation, wheel, and word-game improvements */
.field-error{
  margin:7px 0 0;
  color:#dc2626;
  font-weight:800;
  font-size:.92rem;
}
[aria-invalid="true"]{
  border-color:#dc2626 !important;
  box-shadow:0 0 0 3px rgba(220,38,38,.12);
}
.tool-workspace > .field-error{
  margin:10px 0;
}
.wheel-wrap::after{
  content:"";
  position:absolute;
  top:-2px;
  left:50%;
  transform:translateX(-50%);
  width:18px;
  height:18px;
  border-radius:999px;
  background:var(--card);
  border:3px solid var(--accent);
}
.hangman-layout{
  display:grid;
  grid-template-columns:minmax(210px,320px) 1fr;
  gap:18px;
  align-items:start;
}
.word-game .hangman-art{
  font-size:16px;
  line-height:1.25;
  color:var(--text);
  min-height:210px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.word-panel{
  background:var(--soft);
  border:1px solid var(--border);
  border-radius:10px;
  padding:16px;
}
.keyboard button:disabled{
  opacity:.45;
  cursor:not-allowed;
  transform:none;
}
@media (max-width:760px){
  .hangman-layout{grid-template-columns:1fr}
  .word-display{font-size:1.45rem;letter-spacing:5px}
}


/* Word and memory game repairs */
.memory-board{
  grid-template-columns:repeat(4,minmax(64px,86px));
  align-items:center;
}
.mem-card{
  border:0;
  box-shadow:0 10px 20px rgba(15,23,42,.12);
  font:inherit;
}
.mem-card-back{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
  font-weight:900;
}
.mem-card-front{
  background:linear-gradient(135deg,#fff7ed,#dbeafe);
  color:#111827;
}
[data-theme="dark"] .mem-card-front{
  background:linear-gradient(135deg,#1f2937,#0f172a);
  color:#f8fafc;
}
.mem-card.matched .mem-card-front{
  background:linear-gradient(135deg,#16a34a,#0f766e);
  color:#fff;
}
.mem-icon{
  display:block;
  font-size:2.1rem;
  line-height:1;
  transform:translateY(1px);
}
.word-game .keyboard{
  grid-template-columns:repeat(auto-fit,minmax(40px,1fr));
}
.word-game .result{
  font-weight:700;
}
@media (max-width:520px){
  .memory-board{grid-template-columns:repeat(4,minmax(56px,1fr))}
  .mem-icon{font-size:1.75rem}
}


/* Expanded creator, card, developer, and AI tools */
.tool-icon{
  width:46px;
  height:46px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--soft);
  border:1px solid var(--border);
  font-size:1.45rem;
  margin-bottom:10px;
  font-weight:900;
}
.expanded-tool .button-row{align-items:center}
.generated-list{
  display:grid;
  gap:10px;
}
.generated-list div{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  padding:10px 12px;
}
.card-preview{
  min-height:360px;
  border-radius:14px;
  padding:26px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card-preview-inner{
  width:min(100%,680px);
  min-width:0;
  border:1px solid rgba(255,255,255,.45);
  background:rgba(255,255,255,.16);
  backdrop-filter:blur(6px);
  border-radius:14px;
  padding:30px;
  display:grid;
  gap:12px;
}
.card-preview small{font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.card-preview h3{font-size:clamp(1.8rem,5vw,3rem);margin:0}
.card-preview p{font-size:clamp(1rem,2.7vw,1.35rem);line-height:1.55;color:#fff}
.card-preview small,
.card-preview h3,
.card-preview p,
.card-preview strong,
.card-preview span{
  overflow-wrap:anywhere;
  word-break:break-word;
  max-width:100%;
}
.card-theme-sunset{background:linear-gradient(135deg,#fb7185,#f59e0b)}
.card-theme-ocean{background:linear-gradient(135deg,#0ea5e9,#14b8a6)}
.card-theme-rose{background:linear-gradient(135deg,#be123c,#f9a8d4)}
.card-theme-emerald{background:linear-gradient(135deg,#047857,#84cc16)}
.card-theme-midnight{background:linear-gradient(135deg,#111827,#4f46e5)}
.markdown-preview h1,.markdown-preview h2,.markdown-preview h3{margin-top:8px}
.markdown-preview p{margin:8px 0;color:var(--text)}
@media (max-width:760px){
  .card-preview{min-height:300px;padding:16px}
  .card-preview-inner{padding:20px}
}


/* TODO viral, AI API, anonymous, proposal, and card upgrades */
.big-percent{
  font-size:clamp(3rem,12vw,6rem);
  font-weight:900;
  line-height:1;
  background:linear-gradient(135deg,#e11d48,#f59e0b);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.viral-result{
  position:relative;
  overflow:hidden;
  text-align:center;
}
.heart-burst{
  position:absolute;
  inset:auto 0 10px;
  display:flex;
  justify-content:center;
  gap:8px;
  color:#e11d48;
  animation:heartFloat 1.4s ease forwards;
  pointer-events:none;
}
@keyframes heartFloat{
  from{opacity:0;transform:translateY(20px) scale(.9)}
  30%{opacity:1}
  to{opacity:0;transform:translateY(-80px) scale(1.1)}
}
.card-orientation-vertical{max-width:430px;min-height:720px;margin-inline:auto}
.card-orientation-square{max-width:620px;aspect-ratio:1;margin-inline:auto}
.card-orientation-horizontal{aspect-ratio:16/9}
.card-theme-romantic{background:linear-gradient(135deg,#be123c,#fb7185)}
.card-theme-elegant{background:linear-gradient(135deg,#334155,#94a3b8)}
.card-theme-islamic{background:linear-gradient(135deg,#065f46,#d97706)}
.card-theme-birthday{background:linear-gradient(135deg,#7c3aed,#f59e0b)}
.card-theme-wedding{background:linear-gradient(135deg,#831843,#f9a8d4)}
.card-theme-cute{background:linear-gradient(135deg,#f472b6,#38bdf8)}
.card-theme-dark-neon{background:linear-gradient(135deg,#020617,#7c3aed)}
.card-theme-floral{background:linear-gradient(135deg,#16a34a,#f0abfc)}
.card-theme-minimal{background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:#111827}
.card-theme-minimal p{color:#111827}
.card-theme-gold-luxury{background:linear-gradient(135deg,#111827,#f59e0b)}
.proposal-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
  margin-top:18px;
}
.runaway-btn{transition:transform .18s ease}
.proposal-response{
  min-height:36px;
  margin-top:14px;
  font-weight:900;
}
.anon-message{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  padding:12px;
  margin:10px 0;
}
@media (max-width:760px){
  .card-orientation-vertical{min-height:560px}
  .card-orientation-horizontal{aspect-ratio:auto;min-height:310px}
}


/* Anonymous message UI */
.secret-shell{
  display:grid;
  gap:18px;
}
.secret-panel{
  position:relative;
  overflow:hidden;
  box-sizing:border-box;
  width:100%;
  max-width:100%;
  border:1px solid rgba(255,255,255,.28);
  border-radius:18px;
  padding:24px;
  background:
    radial-gradient(circle at 10% 0%,rgba(255,255,255,.26),transparent 30%),
    linear-gradient(135deg,#7c3aed,#db2777 52%,#2563eb);
  color:#fff;
  box-shadow:0 20px 60px rgba(99,102,241,.24);
}
.secret-panel label,
.secret-panel .secret-check{
  color:#fff;
}
.secret-panel .input{
  background:rgba(255,255,255,.94);
  color:#111827;
  border-color:rgba(255,255,255,.4);
}
.secret-panel .btn-secondary{
  background:rgba(255,255,255,.18);
  color:#fff;
  border-color:rgba(255,255,255,.32);
}
.secret-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.18);
  color:#fff;
  border-radius:999px;
  padding:8px 13px;
  font-weight:900;
  margin-bottom:12px;
}
.secret-badge::before{
  content:"✦";
}
.secret-panel h3{
  font-size:clamp(1.6rem,4vw,2.4rem);
  margin:4px 0 8px;
}
.secret-muted{
  color:rgba(255,255,255,.88);
  line-height:1.7;
}
.secret-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-weight:800;
}
.secret-check input{
  width:18px;
  height:18px;
  margin-top:2px;
}
.secret-status{
  min-height:28px;
  font-weight:800;
  color:#fff;
  margin-top:8px;
}
.secret-link-box{
  min-height:76px;
}
.secret-success{
  background:
    radial-gradient(circle at 90% 10%,rgba(255,255,255,.24),transparent 28%),
    linear-gradient(135deg,#8b5cf6,#ec4899 48%,#06b6d4);
}
.secret-preview-card,
.reply-card-preview{
  box-sizing:border-box;
  width:100%;
  max-width:100%;
  margin-top:16px;
  min-height:360px;
  border-radius:22px;
  padding:26px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
  text-align:center;
  background:linear-gradient(135deg,#6d28d9,#db2777 50%,#0ea5e9);
  color:#fff;
  border:1px solid rgba(255,255,255,.34);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.16);
}
.secret-preview-card strong{
  font-size:clamp(1.55rem,4.5vw,2.6rem);
  line-height:1.08;
  overflow-wrap:anywhere;
}
.secret-preview-card span,
.reply-card-preview p{
  font-size:1.08rem;
  line-height:1.42;
  overflow-wrap:anywhere;
}
.secret-preview-card em,
.reply-card-preview em{
  display:block;
  max-width:100%;
  font-style:normal;
  font-weight:900;
  opacity:.9;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.secret-preview-card em{
  width:max-content;
  max-width:min(100%,420px);
  margin:0 auto;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  font-size:clamp(.86rem,3.8vw,1rem);
  line-height:1.35;
}
.secret-sender-panel textarea{
  min-height:190px;
}
.secret-empty{
  border:1px dashed var(--border);
  border-radius:14px;
  padding:22px;
  text-align:center;
  background:var(--soft);
}
.secret-message-list{
  display:grid;
  gap:14px;
  margin-top:14px;
  min-width:0;
  width:100%;
}
.anon-message-card{
  box-sizing:border-box;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;
  background:var(--card);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  box-shadow:var(--shadow);
}
.anon-message-card .secret-badge{
  background:linear-gradient(135deg,#7c3aed,#db2777);
  border:0;
}
.anon-message-card p{
  font-size:1.06rem;
  line-height:1.7;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.anon-message-card small{
  color:var(--muted);
}
.reply-composer{
  border-top:1px solid var(--border);
  margin-top:14px;
  padding-top:14px;
}
.reply-card-preview{
  min-height:460px;
}
.anon-message-card .button-row{
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.secret-panel .anon-message-card .btn,
.secret-panel .anon-message-card .btn-secondary,
.secret-panel .anon-message-card .btn-share{
  border:0;
  color:#fff;
  min-width:96px;
  min-height:42px;
  box-shadow:0 10px 24px rgba(15,23,42,.16);
}
.secret-panel .anon-message-card .anon-reply-btn,
.secret-panel .anon-message-card .anon_preview_reply{
  background:linear-gradient(135deg,#2563eb,#14b8a6);
}
.secret-panel .anon-message-card .anon-delete-btn{
  background:linear-gradient(135deg,#ef4444,#db2777);
}
.secret-panel .anon-message-card .anon_download_reply{
  background:linear-gradient(135deg,#7c3aed,#2563eb);
}
.secret-panel .anon-message-card .anon_share_reply{
  background:linear-gradient(135deg,#111827,#374151);
}
.secret-panel .anon-message-card .btn:hover{
  transform:translateY(-2px);
  filter:saturate(1.1);
}
.twf-loading-card{
  display:flex;
  align-items:center;
  gap:16px;
  width:100%;
  max-width:720px;
  margin:12px 0;
  padding:18px;
  border:1px solid rgba(37,99,235,.18);
  border-radius:18px;
  background:
    radial-gradient(circle at 0% 0%,rgba(14,165,233,.16),transparent 32%),
    linear-gradient(135deg,rgba(239,246,255,.96),rgba(224,242,254,.94));
  color:#0f172a;
  box-shadow:0 16px 42px rgba(37,99,235,.16);
}
.secret-status .twf-loading-card{
  margin-top:0;
}
.twf-loading-card.short-link-loading,
.twf-loading-card.link-redirect-loading{
  min-height:190px;
  color:#fff;
  border-color:rgba(255,255,255,.26);
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.24),transparent 25%),
    radial-gradient(circle at 82% 20%,rgba(56,189,248,.34),transparent 30%),
    linear-gradient(135deg,#0ea5e9,#2563eb 56%,#1d4ed8);
  box-shadow:0 22px 60px rgba(37,99,235,.26);
}
.short-link-waiting{
  background:
    radial-gradient(circle at top left,rgba(191,219,254,.55),transparent 28%),
    linear-gradient(135deg,#eff6ff,#dbeafe 45%,#bae6fd) !important;
}
[data-theme="dark"] .short-link-waiting,
[data-theme="dark"].short-link-waiting{
  background:linear-gradient(135deg,#0f172a,#0f3b74 52%,#075985) !important;
}
.twf-loading-orbit{
  position:relative;
  flex:0 0 auto;
  width:58px;
  height:58px;
  border-radius:50%;
  border:4px solid rgba(37,99,235,.18);
  border-top-color:#0ea5e9;
  animation:twfSpin 1s linear infinite;
}
.twf-loading-card.short-link-loading .twf-loading-orbit,
.twf-loading-card.link-redirect-loading .twf-loading-orbit{
  border-color:rgba(255,255,255,.28);
  border-top-color:#fff;
}
.twf-loading-orbit::before,
.twf-loading-orbit::after{
  content:"";
  position:absolute;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#14b8a6;
  box-shadow:0 0 18px rgba(20,184,166,.72);
}
.twf-loading-orbit::before{
  top:3px;
  right:4px;
}
.twf-loading-orbit::after{
  left:5px;
  bottom:6px;
  background:#f472b6;
  box-shadow:0 0 18px rgba(244,114,182,.72);
}
.twf-loading-copy{
  display:grid;
  gap:6px;
  min-width:0;
}
.twf-loading-title{
  display:block;
  font-size:1.06rem;
  font-weight:900;
}
.twf-loading-sub{
  color:inherit;
  opacity:.82;
  font-weight:700;
  line-height:1.45;
}
.twf-progress-track{
  width:min(320px,100%);
  height:8px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(15,23,42,.12);
}
.twf-loading-card.short-link-loading .twf-progress-track,
.twf-loading-card.link-redirect-loading .twf-progress-track{
  background:rgba(255,255,255,.22);
}
.twf-progress-bar{
  display:block;
  width:42%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#14b8a6,#38bdf8,#f472b6);
  animation:twfProgress 1.15s ease-in-out infinite;
}
@keyframes twfSpin{
  to{transform:rotate(360deg)}
}
@keyframes twfProgress{
  0%{transform:translateX(-110%)}
  50%{transform:translateX(90%)}
  100%{transform:translateX(260%)}
}
@media (max-width:560px){
  .twf-loading-card{
    align-items:flex-start;
    padding:15px;
  }
  .twf-loading-orbit{
    width:48px;
    height:48px;
  }
  .secret-panel .anon-message-card .btn,
  .secret-panel .anon-message-card .btn-secondary,
  .secret-panel .anon-message-card .btn-share{
    flex:1 1 100%;
    width:100%;
  }
  .secret-panel{padding:15px}
  .secret-panel h3{font-size:clamp(1.32rem,7vw,1.82rem)}
  .secret-preview-card{
    padding:22px 16px;
    gap:12px;
    min-height:300px;
  }
  .secret-preview-card strong{
    font-size:clamp(1.65rem,9vw,2.5rem);
  }
  .anon-message-card{
    padding:16px 14px;
    border-radius:18px;
  }
  .anon-message-card p{
    font-size:clamp(1rem,5vw,1.18rem);
    line-height:1.72;
  }
}
.reply-card-square{
  aspect-ratio:1;
  min-height:auto;
}
.reply-card-vertical{
  max-width:420px;
  min-height:650px;
  margin-inline:auto;
}
[data-theme="dark"] .secret-empty{
  background:#172033;
}
@media (max-width:760px){
  .secret-panel{padding:18px;border-radius:15px}
  .secret-preview-card{min-height:310px}
  .reply-card-vertical{min-height:560px}
}


/* Anonymous sender CTA and status states */
.secret-cta-card{
  display:grid;
  gap:6px;
  margin:16px 0 6px;
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.36);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.08));
  color:#fff;
  text-decoration:none;
  box-shadow:0 14px 30px rgba(15,23,42,.18);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.secret-cta-card:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.62);
  box-shadow:0 18px 42px rgba(15,23,42,.24);
}
.secret-cta-card span{
  width:max-content;
  max-width:100%;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.secret-cta-card strong{
  font-size:clamp(1.08rem,3.4vw,1.35rem);
  line-height:1.25;
}
.secret-cta-card small{
  color:rgba(255,255,255,.88);
  font-weight:700;
}
.secret-cta-strong{
  background:linear-gradient(135deg,#7c3aed,#db2777 55%,#2563eb);
}
.secret-status-loading{color:#fff8dc}
.secret-status-success{color:#dcfce7}
.secret-status-error{color:#fee2e2}
[data-theme="dark"] .secret-cta-card{
  box-shadow:0 14px 34px rgba(0,0,0,.28);
}

/* Anonymous message mobile app redesign */
.anon-simple-shell{
  max-width:620px;
  margin:0 auto;
}
.anon-create-card{
  padding:22px;
}
.anon-create-card .field-grid.single{
  display:grid;
  gap:12px;
}
.anon-mini-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin:16px 0;
}
.anon-mini-steps span{
  display:grid;
  gap:4px;
  min-width:0;
  padding:10px 8px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:14px;
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:.82rem;
  font-weight:900;
  text-align:center;
  line-height:1.2;
}
.anon-mini-steps strong{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  margin:0 auto;
  border-radius:50%;
  background:#fff;
  color:#db2777;
}
.anon-big-action{
  width:100%;
  min-height:54px;
  border-radius:18px;
  font-size:1.02rem;
}
body.anon-app-mode{
  background:#ffffff;
}
.anon-app-mode .site-header,
.anon-app-mode .nav,
.anon-app-mode .breadcrumb,
.anon-app-mode .tool-intro,
.anon-app-mode .tool-heading,
.anon-app-mode .share-row,
.anon-app-mode .seo-content,
.anon-app-mode .related-section,
.anon-app-mode .faq-section,
.anon-app-mode .footer{
  display:none;
}
.anon-app-mode .container{
  width:100%;
  max-width:none;
  padding:0;
}
.anon-app-mode main{
  margin:0;
}
.anon-app-mode .tool-workspace.expanded-tool{
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.anon-mobile-board{
  max-width:460px;
  min-height:100vh;
  margin:0 auto;
  padding:22px 0 34px;
  background:#fff;
  color:#0f172a;
}
.anon-board-top{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:12px;
  padding:0 18px;
}
.anon-board-tabs{
  display:flex;
  align-items:baseline;
  gap:22px;
}
.anon-board-tab{
  border:0;
  background:transparent;
  color:#d1d5db;
  font-size:clamp(2rem,10vw,3rem);
  font-weight:1000;
  line-height:1;
  cursor:pointer;
}
.anon-board-tab.active{
  color:#000;
}
.anon-board-delete{
  border:0;
  border-radius:999px;
  padding:10px 12px;
  background:#f3f4f6;
  color:#111827;
  font-weight:900;
  cursor:pointer;
}
.anon-board-username{
  margin:14px 18px 22px;
  color:#6b7280;
  font-weight:900;
}
.anon-play-title{
  display:grid;
  gap:3px;
  padding:0 18px 8px;
}
.anon-play-title strong{
  font-size:1.28rem;
  font-weight:1000;
  color:#111827;
}
.anon-play-title span{
  color:#6b7280;
  font-weight:800;
  line-height:1.35;
}
.anon-prompt-rail{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(268px,82%);
  gap:18px;
  overflow-x:auto;
  overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;
  padding:12px 18px 18px;
  scrollbar-width:none;
}
.anon-prompt-rail::-webkit-scrollbar{display:none}
.anon-play-card{
  position:relative;
  display:grid;
  grid-template-rows:1fr auto auto;
  align-items:start;
  min-height:250px;
  overflow:hidden;
  border:0;
  border-radius:34px;
  padding:26px 24px 72px;
  color:#fff;
  text-align:left;
  scroll-snap-align:center;
  box-shadow:0 18px 42px rgba(15,23,42,.18);
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease;
}
.anon-play-card::after{
  content:"";
  position:absolute;
  right:-36px;
  top:-28px;
  width:118px;
  height:118px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
.anon-play-card span{
  display:block;
  font-weight:900;
  opacity:.9;
}
.anon-play-card strong{
  align-self:start;
  max-width:100%;
  margin-top:auto;
  padding-right:88px;
  font-size:clamp(1.75rem,3vw,2.5rem);
  line-height:1.08;
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
  text-wrap:balance;
  text-shadow:0 4px 12px rgba(0,0,0,.28);
}
.anon-play-card small{
  margin-top:12px;
  font-weight:1000;
  opacity:.86;
  max-width:72%;
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
  text-wrap:balance;
}
.anon-play-card.active{
  transform:translateY(-4px);
  box-shadow:0 24px 52px rgba(236,72,153,.24);
}
.anon-play-pink{background:linear-gradient(135deg,#ec4899,#fb7185 55%,#f97316)}
.anon-play-red{background:linear-gradient(135deg,#e11d48,#ef4444 58%,#f59e0b)}
.anon-play-blue{background:linear-gradient(135deg,#2563eb,#38bdf8)}
.anon-play-purple{background:linear-gradient(135deg,#581c87,#7c3aed 55%,#db2777)}
.anon-play-orange{background:linear-gradient(135deg,#f97316,#ec4899)}
.anon-play-green{background:linear-gradient(135deg,#059669,#14b8a6)}
.anon-play-dark{background:linear-gradient(135deg,#111827,#334155)}
.anon-dots{
  display:flex;
  justify-content:center;
  gap:7px;
  margin:2px 0 18px;
}
.anon-dots span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#d1d5db;
}
.anon-dots span.active{
  width:18px;
  border-radius:999px;
  background:#0ea5e9;
}
.anon-step-card{
  margin:18px;
  padding:28px 20px;
  border-radius:24px;
  background:#f3f4f6;
  text-align:center;
}
.anon-step-card h3{
  margin:0 0 14px;
  font-size:clamp(1.55rem,7vw,2.2rem);
  color:#000;
}
.anon-step-card p{
  margin:0 0 12px;
  color:#6b7280;
  font-weight:1000;
  text-transform:uppercase;
}
.anon-step-card small{
  display:block;
  margin-top:12px;
  color:#6b7280;
  font-weight:800;
  line-height:1.35;
}
.anon-step-card .input{
  text-align:center;
  font-weight:900;
  border-radius:14px;
}
.anon-pill-btn{
  margin-top:12px;
  min-width:190px;
  border-radius:999px;
  border:3px solid #f43f5e;
  background:#fff !important;
  color:#f43f5e !important;
  font-size:1.1rem;
}
.anon-share-main,
.anon-whatsapp-btn{
  width:100%;
  min-height:62px;
  border-radius:999px;
  font-size:1.45rem;
  justify-content:center;
}
.anon-inbox-section{
  padding:18px;
}
.anon-inbox-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.anon-inbox-head h3{
  margin:4px 0 0;
  font-size:2rem;
}
.anon-mobile-board .secret-status{
  color:#111827;
}
.anon-message-prompt{
  display:inline-flex;
  max-width:100%;
  margin:0 0 8px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(236,72,153,.12);
  color:#be123c;
  font-weight:900;
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
  text-wrap:balance;
}
.anon-play-username{
  position:absolute;
  right:18px;
  bottom:16px;
  margin:0;
  font-size:.78rem;
  color:rgba(255,255,255,.88);
  font-weight:900;
  opacity:.92;
  max-width:45%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.anon-inbox-section .anon-message-card .btn{
  color:#fff;
  border:0;
}
.anon-inbox-section .anon-message-card .anon-reply-btn,
.anon-inbox-section .anon-message-card .anon_preview_reply{
  background:linear-gradient(135deg,#2563eb,#14b8a6);
}
.anon-inbox-section .anon-message-card .anon-delete-btn{
  background:linear-gradient(135deg,#ef4444,#db2777);
}
.anon-inbox-section .anon-message-card .anon_download_reply{
  background:linear-gradient(135deg,#7c3aed,#2563eb);
}
.anon-inbox-section .anon-message-card .anon_share_reply{
  background:linear-gradient(135deg,#111827,#374151);
}
body.anon-sender-mode{
  background:
    radial-gradient(circle at 18% 14%,rgba(34,211,238,.18),transparent 23%),
    radial-gradient(circle at 82% 8%,rgba(163,230,53,.18),transparent 20%),
    linear-gradient(145deg,#0f172a,#4c1d95 54%,#0f766e);
}
.anon-sender-app{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:38px 18px;
  color:#fff;
  background:
    radial-gradient(circle at 22% 14%,rgba(255,255,255,.10),transparent 24%),
    linear-gradient(145deg,#111827,#5b21b6 54%,#0f766e);
}
.anon-sender-card{
  position:relative;
  width:min(100%,560px);
  overflow:hidden;
  border-radius:32px;
  background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));
  color:#f8fafc;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 24px 58px rgba(15,23,42,.30);
  backdrop-filter:blur(14px);
}
.anon-sender-head{
  display:flex;
  align-items:center;
  gap:14px;
  padding:24px;
}
.anon-sender-head-copy{
  min-width:0;
  display:grid;
  gap:4px;
}
.anon-sender-head strong,
.anon-sender-head span{
  display:block;
  font-weight:1000;
  line-height:1.15;
}
.anon-sender-head strong{
  font-size:1.25rem;
}
.anon-sender-head span{
  font-size:1.12rem;
  color:#dbeafe;
}
.anon-avatar{
  width:58px;
  height:58px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#f3f4f6,#d1d5db);
  color:#6b7280;
  font-weight:1000;
}
.anon-sender-textarea{
  width:100%;
  min-height:240px;
  border:0;
  resize:none;
  padding:24px 22px;
  background:linear-gradient(145deg,rgba(15,23,42,.92),rgba(15,118,110,.72));
  color:#f8fafc;
  font-size:clamp(1.25rem,5.8vw,1.9rem);
  font-weight:900;
  line-height:1.18;
  outline:none;
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.12);
}
.anon-sender-textarea::placeholder{
  color:rgba(248,250,252,.45);
}
.anon-dice-btn{
  position:relative;
  width:max-content;
  min-height:44px;
  padding:10px 16px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  color:#f8fafc;
  font-weight:1000;
  box-shadow:0 12px 24px rgba(0,0,0,.12);
  cursor:pointer;
}
.anon-sender-compose{
  position:relative;
  display:grid;
  gap:12px;
  padding:0 24px 24px;
}
.anon-lock-line{
  margin:0;
  font-size:1.05rem;
  font-weight:900;
  text-align:center;
  text-shadow:0 3px 10px rgba(0,0,0,.16);
}
.anon-viral-line{
  width:min(100%,520px);
  margin:0;
  text-align:center;
  font-size:1.05rem;
  font-weight:900;
  text-shadow:0 3px 10px rgba(0,0,0,.16);
}
.anon-send-btn,
.anon-get-own,
.anon-send-another{
  width:min(100%,520px);
  min-height:68px;
  border:0;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#000;
  color:#fff;
  text-decoration:none;
  font-size:clamp(1.35rem,6vw,2rem);
  font-weight:1000;
  box-shadow:0 16px 34px rgba(0,0,0,.24);
  cursor:pointer;
}
.anon-get-own{
  margin-top:22px;
}
.anon-send-status{
  color:#fff;
  text-align:center;
}
.anon-sent-screen{
  width:min(100%,520px);
  display:grid;
  justify-items:center;
  gap:18px;
  text-align:center;
}
.anon-sent-check{
  width:140px;
  height:140px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#fff;
  color:#f43f5e;
  font-size:5rem;
  font-weight:1000;
}
.anon-sent-screen h3{
  margin:0;
  font-size:clamp(3rem,14vw,5rem);
  line-height:1;
}
.anon-sent-screen p{
  margin:0;
  font-size:1.25rem;
  font-weight:900;
}
.anon-send-another{
  min-height:auto;
  background:transparent;
  box-shadow:none;
  border-radius:0;
  text-decoration:underline;
  font-size:1.3rem;
}
@media (max-width:430px){
  .anon-mobile-board{max-width:none}
  .anon-board-top{padding-inline:14px}
  .anon-board-tabs{gap:16px}
  .anon-board-delete{font-size:.76rem;padding:8px 10px}
  .anon-mini-steps{grid-template-columns:1fr}
  .anon-prompt-rail{grid-auto-columns:82%;gap:14px;padding-inline:14px}
  .anon-play-card{min-height:238px;border-radius:28px}
  .anon-step-card{margin-inline:14px}
  .anon-sender-app{justify-content:flex-start;padding-top:58px}
  .anon-sender-card{border-radius:24px}
  .anon-sender-compose{padding-inline:18px 18px 18px}
  .anon-sender-textarea{min-height:210px}
}


.proposal-feature-highlight{
  margin:14px 0;
  padding:16px 18px;
  border:1px solid rgba(236,72,153,.35);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(236,72,153,.13),rgba(124,58,237,.13));
  box-shadow:0 12px 28px rgba(124,58,237,.12);
}
.proposal-link-main{
  display:grid;
  gap:12px;
  padding:20px;
  border-color:rgba(236,72,153,.52);
  background:
    radial-gradient(circle at 12% 18%,rgba(255,255,255,.42),transparent 18%),
    linear-gradient(135deg,rgba(236,72,153,.18),rgba(124,58,237,.18),rgba(14,165,233,.12));
}
.proposal-feature-badge{
  width:max-content;
  max-width:100%;
  padding:6px 11px;
  border-radius:999px;
  background:linear-gradient(135deg,#db2777,#7c3aed);
  color:#ffffff !important;
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  text-shadow:0 1px 2px rgba(15,23,42,.38);
}
.proposal-feature-highlight strong{
  display:block;
  font-size:1.1rem;
  color:var(--text);
}
.proposal-feature-highlight span{
  display:block;
  color:var(--muted);
  margin-top:4px;
}
.proposal-link-hero-btn{
  width:max-content;
  min-height:52px;
  padding:14px 22px;
  font-size:1rem;
  box-shadow:0 16px 30px rgba(37,99,235,.22);
}
.proposal-link-main .link-copy-field{
  margin-top:0;
}
.proposal-link-note{
  margin:0;
  color:var(--muted);
  font-weight:800;
  line-height:1.45;
}
.proposal-unlock-note{
  margin:12px auto 0;
  padding:8px 12px;
  width:max-content;
  max-width:100%;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:#fff;
  font-weight:900;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.22);
}
.card-theme-minimal .proposal-unlock-note{
  color:#111827;
  background:rgba(15,23,42,.08);
}
.proposal-actions{
  min-height:120px;
}
.proposal-actions .btn{
  transition:transform .22s ease,box-shadow .22s ease;
}
.proposal-response{
  min-height:34px;
  font-weight:800;
  margin-top:12px;
}
.link-copy-field{
  cursor:pointer;
  font-weight:700;
}


/* Proposal receiver button polish */
.proposal-experience{
  width:100%;
}
.proposal-card-inner{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.proposal-card-inner .proposal-message{
  max-width:760px;
  margin:0 auto;
  text-wrap:balance;
}
.proposal-actions{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:nowrap;
  gap:14px;
  width:min(100%,520px);
  min-height:118px;
  margin:18px auto 0;
  padding:8px 14px;
  isolation:isolate;
}
.proposal-actions .btn{
  min-width:112px;
  min-height:50px;
  padding:12px 18px;
  border-radius:16px;
  font-size:1rem;
  line-height:1.1;
  white-space:nowrap;
  transform-origin:center;
  transition:transform .22s ease,box-shadow .22s ease,min-width .22s ease,min-height .22s ease,font-size .22s ease,opacity .2s ease;
}
.proposal-accept-btn{
  z-index:2;
  box-shadow:0 14px 28px rgba(14,165,233,.24);
}
.proposal-reject-btn{
  z-index:1;
  will-change:transform;
}
.proposal-reject-muted{
  opacity:.48;
  cursor:not-allowed;
}
.runaway-btn{
  transition:transform .24s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease,opacity .2s ease;
}
.proposal-response{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  margin-top:4px;
  padding:0 12px;
  font-size:clamp(.95rem,2vw,1.08rem);
  line-height:1.35;
  font-weight:900;
  text-wrap:balance;
}
.proposal-accepted-shell{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  display:grid;
  gap:14px;
}
.proposal-accepted-shell > *:not(.proposal-confetti){
  position:relative;
  z-index:1;
}
.proposal-confetti{
  z-index:2;
  pointer-events:none;
}
.proposal-accepted-card{
  min-height:520px;
  box-shadow:0 22px 48px rgba(15,23,42,.18);
  position:relative;
  z-index:1;
  background:linear-gradient(135deg,rgba(88,28,135,.74),rgba(190,24,93,.70),rgba(17,24,39,.62));
}
.proposal-accepted-inner{
  gap:18px;
  min-height:inherit;
  padding-bottom:40px;
  background:rgba(15,23,42,.34);
  border-color:rgba(255,255,255,.22);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 16px 34px rgba(15,23,42,.12);
}
.proposal-accepted-inner small{
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.20);
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.proposal-accepted-inner h3{
  font-size:clamp(2rem,5.8vw,4rem);
  line-height:1.05;
  margin:0;
  text-shadow:0 3px 12px rgba(0,0,0,.28);
}
.proposal-accepted-inner strong{
  display:block;
  max-width:720px;
  margin:0 auto;
  font-size:clamp(.98rem,1.9vw,1.2rem);
  line-height:1.38;
  text-wrap:balance;
  text-shadow:0 2px 10px rgba(0,0,0,.28);
}
.proposal-accepted-inner span{
  margin-top:auto;
  font-weight:900;
  opacity:.96;
  text-shadow:0 2px 10px rgba(0,0,0,.22);
}
.proposal-accepted-actions{
  justify-content:center;
}
@media (max-width:560px){
  .proposal-actions{
    gap:10px;
    min-height:108px;
    padding-inline:6px;
  }
  .proposal-actions .btn{
    min-width:96px;
    padding-inline:14px;
  }
  .proposal-card-inner{
    padding-inline:16px;
  }
  .proposal-accepted-card{
    min-height:460px;
  }
}



/* Anonymous reply story cards */
.reply-card-preview{
  position:relative;
  overflow:hidden;
  justify-content:flex-start;
  padding:30px 24px 22px;
  background:
    radial-gradient(circle at 18% 12%,rgba(255,255,255,.22),transparent 18%),
    radial-gradient(circle at 82% 18%,rgba(255,255,255,.18),transparent 16%),
    linear-gradient(135deg,#5b21b6,#db2777 48%,#0284c7);
}
.reply-story-badge{
  align-self:center;
  width:auto;
  max-width:calc(100% - 18px);
  padding:7px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.34);
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-top:4px;
  text-align:center;
  white-space:normal;
  line-height:1.25;
}
.reply-story-message{
  margin:12px auto 0;
  max-width:min(92%,680px);
  font-weight:800;
  line-height:1.15;
  overflow:hidden;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
}
.reply-story-label{
  width:max-content;
  align-self:center;
  margin-top:clamp(20px,6vw,44px);
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.2);
}
.reply-story-reply{
  margin:0 auto;
  max-width:min(92%,680px);
  font-weight:950;
  line-height:1.12;
  overflow:hidden;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:8;
}
.reply-story-footer{
  margin-top:auto;
  align-self:center;
  padding:12px 0 0;
  font-size:clamp(1rem,4.5vw,1.25rem);
  letter-spacing:.01em;
}
.reply-card-square .reply-story-message{
  -webkit-line-clamp:3;
}
.reply-card-square .reply-story-reply{
  -webkit-line-clamp:5;
}

/* Birthday Surprise Link */
.birthday-tool{
  display:grid;
  gap:18px;
}
.birthday-mini-hero,
.birthday-success-card,
.birthday-error-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(236,72,153,.26);
  border-radius:18px;
  padding:20px;
  background:
    radial-gradient(circle at 12% 15%,rgba(255,255,255,.55),transparent 22%),
    linear-gradient(135deg,rgba(236,72,153,.16),rgba(124,58,237,.16),rgba(14,165,233,.12));
}
.birthday-mini-hero h3,
.birthday-success-card h3,
.birthday-error-card h3{
  margin:10px 0 6px;
  font-size:clamp(1.55rem,4vw,2.25rem);
}
.birthday-mini-hero p,
.birthday-success-card p,
.birthday-error-card p{
  color:var(--muted);
  line-height:1.7;
}
.birthday-pill{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  padding:8px 13px;
  border-radius:999px;
  background:linear-gradient(135deg,#ec4899,#7c3aed);
  color:#fff;
  font-weight:950;
  box-shadow:0 12px 26px rgba(124,58,237,.22);
}
.birthday-main-btn{
  min-height:54px;
  padding-inline:20px;
  font-size:1.02rem;
}
.birthday-status{
  min-height:30px;
  color:var(--text);
  font-weight:850;
}
.birthday-status-success{color:#059669}
.birthday-status-error{color:#dc2626}
.birthday-success-card{
  background:
    radial-gradient(circle at 88% 10%,rgba(255,255,255,.32),transparent 26%),
    linear-gradient(135deg,#fb7185,#a855f7 48%,#06b6d4);
  color:#fff;
}
.birthday-success-card label,
.birthday-success-card h3{
  color:#fff;
}
.birthday-success-card .input{
  background:rgba(255,255,255,.92);
  color:#111827;
}
.birthday-loading-screen,
.birthday-surprise-page{
  position:relative;
  overflow:hidden;
  min-height:620px;
  border-radius:24px;
  padding:28px;
  color:#fff;
  isolation:isolate;
  background:linear-gradient(135deg,#7c3aed,#ec4899 52%,#0ea5e9);
  box-shadow:0 24px 70px rgba(15,23,42,.18);
}
.birthday-loading-screen{
  display:grid;
  place-items:center;
  align-content:center;
  text-align:center;
  gap:16px;
}
.birthday-loading-screen h3{
  margin:8px 0 0;
  font-size:clamp(1.75rem,6vw,3.1rem);
  line-height:1.1;
}
.birthday-loading-screen p{
  max-width:620px;
  margin:0 auto;
  color:rgba(255,255,255,.9);
  font-weight:800;
}
.birthday-progress{
  width:min(420px,88%);
  height:12px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.25);
}
.birthday-progress span{
  display:block;
  width:45%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#fef08a,#f472b6,#67e8f9);
  animation:birthdayProgress 1.15s ease-in-out infinite;
}
.birthday-gift-loader{
  position:relative;
  width:108px;
  height:98px;
  border-radius:18px;
  background:linear-gradient(135deg,#facc15,#fb7185);
  box-shadow:0 22px 50px rgba(15,23,42,.28);
  animation:birthdayGift 1.1s ease-in-out infinite;
}
.birthday-gift-loader:before,
.birthday-gift-loader:after{
  content:"";
  position:absolute;
  background:#fff;
  opacity:.9;
}
.birthday-gift-loader:before{
  width:18px;
  height:100%;
  left:45px;
}
.birthday-gift-loader:after{
  height:18px;
  width:100%;
  top:39px;
  left:0;
}
.birthday-gift-loader span{
  position:absolute;
  left:-10px;
  right:-10px;
  top:-22px;
  height:28px;
  border-radius:14px;
  background:linear-gradient(135deg,#f472b6,#7c3aed);
  transform-origin:center bottom;
  animation:birthdayLid 1.1s ease-in-out infinite;
}
.birthday-confetti,
.birthday-balloon-field,
.birthday-star-field{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-1;
}
.confetti-piece{
  position:absolute;
  top:-24px;
  left:var(--x);
  width:10px;
  height:18px;
  border-radius:4px;
  background:hsl(calc(var(--i) * 47),88%,65%);
  animation:birthdayFall calc(4s + var(--d) * .35s) linear infinite;
  animation-delay:calc(var(--i) * -.17s);
}
.birthday-balloon{
  position:absolute;
  bottom:-90px;
  left:var(--x);
  width:44px;
  height:58px;
  border-radius:50% 50% 44% 44%;
  background:hsl(calc(var(--i) * 39),86%,64%);
  box-shadow:inset -9px -12px 0 rgba(0,0,0,.12);
  animation:birthdayBalloonRise calc(7s + var(--d) * .6s) ease-in infinite;
  animation-delay:calc(var(--i) * -.4s);
}
.birthday-balloon:after{
  content:"";
  position:absolute;
  left:21px;
  top:58px;
  width:1px;
  height:64px;
  background:rgba(255,255,255,.65);
}
.birthday-star{
  position:absolute;
  left:var(--x);
  top:calc((var(--i) * 29) % 90 * 1%);
  width:8px;
  height:8px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 18px #fff;
  animation:birthdayTwinkle calc(1.2s + var(--d) * .2s) ease-in-out infinite;
}
.birthday-reveal-card{
  position:relative;
  z-index:1;
  width:min(100%,900px);
  min-height:620px;
  margin:0 auto;
  padding:26px;
  border:1px solid rgba(255,255,255,.36);
  border-radius:28px;
  text-align:center;
  background:rgba(255,255,255,.17);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.13),0 26px 70px rgba(15,23,42,.20);
  backdrop-filter:blur(10px);
  animation:birthdayReveal .72s ease both;
}
.birthday-card-top{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  min-height:150px;
  padding-top:8px;
  padding-bottom:8px;
}
.cake-wrap{
  position:relative;
  flex-shrink:0;
  width:90px;
  height:90px;
}
.birthday-reveal-top{display:contents}
.birthday-reveal-body{
  display:grid;
  gap:18px;
  min-width:0;
}
.birthday-orientation-vertical{
  max-width:560px;
  min-height:760px;
}
.birthday-orientation-square{
  max-width:720px;
  aspect-ratio:1;
}
.birthday-orientation-horizontal{
  max-width:980px;
  min-height:540px;
}
.birthday-reveal-card h2{
  margin:0 auto 10px;
  max-width:900px;
  font-size:clamp(32px,6vw,72px);
  line-height:1.02;
  text-wrap:balance;
  word-break:normal;
  overflow-wrap:normal;
  hyphens:none;
}
.birthday-title{
  display:grid;
  justify-items:center;
  gap:2px;
  margin:0 auto 8px;
  max-width:min(100%,880px);
  color:#fff;
  text-align:center;
}
.birthday-title-line,
.birthday-title-name{
  display:block;
  width:100%;
  max-width:100%;
  overflow-wrap:normal;
  word-break:normal;
  text-wrap:balance;
}
.birthday-title-line{
  font-size:inherit;
  line-height:1.02;
}
.birthday-title-name{
  font-size:inherit;
  line-height:1.04;
}
.birthday-auto-wish,
.birthday-reveal-card blockquote{
  max-width:820px;
  margin:14px auto;
  color:rgba(255,255,255,.94);
  font-weight:800;
  line-height:1.65;
  overflow-wrap:anywhere;
}
.birthday-reveal-card blockquote{
  margin-top:4px;
  padding:16px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.28);
  font-size:clamp(1.05rem,3vw,1.35rem);
}
.birthday-message-box{
  position:relative;
  z-index:1;
}
.birthday-from{
  margin:8px 0 18px;
  font-weight:950;
  overflow-wrap:anywhere;
}
.birthday-age-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:20px auto;
}
.birthday-age-grid div{
  min-width:0;
  padding:14px 12px;
  border-radius:18px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.25);
}
.birthday-age-grid span{
  display:block;
  color:rgba(255,255,255,.78);
  font-weight:800;
  font-size:.88rem;
  overflow-wrap:anywhere;
}
.birthday-age-grid strong{
  display:block;
  margin-top:6px;
  color:#fff;
  line-height:1.3;
  overflow-wrap:anywhere;
}
.birthday-cake{
  position:relative;
  width:100%;
  height:100%;
  margin:0 auto;
  animation:birthdayCakeGlow 1.6s ease-in-out infinite;
}
.birthday-cake i,
.birthday-cake b,
.birthday-cake span{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
}
.birthday-cake i{
  bottom:0;
  width:100%;
  height:52%;
  border-radius:16px 16px 10px 10px;
  background:linear-gradient(135deg,#f9a8d4,#fb7185);
}
.birthday-cake b{
  bottom:40%;
  width:78%;
  height:34%;
  border-radius:15px 15px 8px 8px;
  background:linear-gradient(135deg,#fef3c7,#f59e0b);
}
.birthday-cake span{
  bottom:72%;
  width:12%;
  height:32%;
  border-radius:999px;
  background:#fff;
}
.birthday-cake span:before{
  content:"";
  position:absolute;
  top:-44%;
  left:-33%;
  width:175%;
  height:58%;
  border-radius:50% 50% 50% 0;
  background:#fde047;
  transform:rotate(-45deg);
  box-shadow:0 0 22px #fde047;
}
.birthday-theme-neon-birthday,
.birthday-theme-dark-celebration{
  background:linear-gradient(135deg,#020617,#312e81 48%,#db2777);
}
.birthday-theme-golden-luxury{
  background:linear-gradient(135deg,#111827,#92400e 52%,#f59e0b);
}
.birthday-theme-islamic-simple{
  background:linear-gradient(135deg,#064e3b,#0f766e 54%,#d97706);
}
.birthday-theme-pink-party,
.birthday-theme-romantic-birthday{
  background:linear-gradient(135deg,#be123c,#ec4899 50%,#a855f7);
}
.birthday-theme-kids-fun{
  background:linear-gradient(135deg,#22c55e,#06b6d4 48%,#f97316);
}
@keyframes birthdayProgress{
  0%{transform:translateX(-120%)}
  50%{transform:translateX(90%)}
  100%{transform:translateX(250%)}
}
@keyframes birthdayGift{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-10px) rotate(2deg)}
}
@keyframes birthdayLid{
  0%,100%{transform:rotate(0)}
  50%{transform:translateY(-7px) rotate(-8deg)}
}
@keyframes birthdayFall{
  to{transform:translateY(760px) rotate(360deg)}
}
@keyframes birthdayBalloonRise{
  to{transform:translateY(-860px) translateX(24px)}
}
@keyframes birthdayTwinkle{
  0%,100%{opacity:.25;transform:scale(.7)}
  50%{opacity:1;transform:scale(1.35)}
}
@keyframes birthdayReveal{
  from{opacity:0;transform:translateY(24px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes birthdayStepEnter{
  from{opacity:0;transform:translateY(18px) scale(.95)}
  60%{opacity:1;transform:translateY(-2px) scale(1.01)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes birthdayCakeGlow{
  0%,100%{filter:drop-shadow(0 0 8px rgba(253,224,71,.45))}
  50%{filter:drop-shadow(0 0 24px rgba(253,224,71,.95))}
}
.birthday-stage-enter{
  animation:birthdayStepEnter .62s cubic-bezier(.2,.8,.2,1) both;
}
.birthday-stage-enter.is-active .surprise-step-count,
.birthday-stage-enter.is-active .surprise-open-label,
.birthday-stage-enter.is-active .surprise-next-button,
.birthday-stage-enter.is-active .birthday-title,
.birthday-stage-enter.is-active .birthday-reveal-body{
  animation:birthdayStepEnter .62s cubic-bezier(.2,.8,.2,1) both;
}
@media (max-width:720px){
  .birthday-loading-screen,
  .birthday-surprise-page{
    min-height:560px;
    padding:18px;
    border-radius:18px;
  }
  .birthday-reveal-card{
    padding:18px 14px;
    border-radius:22px;
    min-height:600px;
  }
  .birthday-reveal-top{
    gap:18px;
    min-height:initial;
    padding-bottom:0;
  }
  .birthday-age-grid{
    grid-template-columns:1fr;
  }
  .birthday-reveal-card .button-row .btn{
    width:100%;
  }
  .birthday-cake{
    width:100%;
    height:100%;
  }
  .cake-wrap{
    width:72px;
    height:72px;
  }
  .birthday-card-top{min-height:150px}
}
@media (max-width:430px){
  .birthday-card-top{
    gap:18px;
    min-height:138px;
  }
  .cake-wrap{
    width:60px;
    height:60px;
  }
  .birthday-cake{
    width:100%;
    height:100%;
  }
  .birthday-reveal-card h2{
    margin-bottom:8px;
  }
  .birthday-title-line{
    font-size:clamp(34px,11vw,56px);
  }
  .birthday-title-name{
    font-size:clamp(34px,11vw,56px);
  }
  .birthday-reveal-card blockquote{
    padding:14px 14px;
  }
}

/* Friendship Anniversary Surprise Link */
.friendship-mini-hero{
  border-color:rgba(251,191,36,.34);
  background:
    radial-gradient(circle at 14% 12%,rgba(255,255,255,.56),transparent 20%),
    linear-gradient(135deg,rgba(250,204,21,.17),rgba(236,72,153,.14),rgba(37,99,235,.14));
}
.friendship-success-card{
  background:
    radial-gradient(circle at 86% 14%,rgba(255,255,255,.32),transparent 26%),
    linear-gradient(135deg,#f59e0b,#ec4899 48%,#2563eb);
}
.friendship-loading-screen,
.friendship-surprise-page{
  background:linear-gradient(135deg,#f59e0b,#ec4899 50%,#2563eb);
}
.friendship-reveal-card h2{
  font-size:clamp(2rem,7vw,4.2rem);
}
.friendship-emoji-field,
.friendship-bracelet-field{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-1;
}
.friendship-emoji{
  position:absolute;
  left:var(--x);
  bottom:-48px;
  font-size:clamp(1.2rem,3vw,2rem);
  filter:drop-shadow(0 8px 16px rgba(15,23,42,.18));
  animation:friendshipEmojiRise calc(6s + var(--d) * .45s) ease-in infinite;
  animation-delay:calc(var(--i) * -.32s);
}
.friendship-bracelet,
.friendship-bracelet-loader{
  position:absolute;
}
.friendship-bracelet{
  left:var(--x);
  bottom:-72px;
  width:64px;
  height:64px;
  border-radius:50%;
  border:8px dotted rgba(255,255,255,.84);
  box-shadow:0 0 0 5px rgba(250,204,21,.35),0 16px 34px rgba(15,23,42,.22);
  animation:friendshipBraceletFloat calc(7s + var(--d) * .55s) ease-in infinite;
  animation-delay:calc(var(--i) * -.44s);
}
.friendship-bracelet-loader{
  position:relative;
  width:120px;
  height:80px;
  margin:0 auto 6px;
}
.friendship-bracelet-loader span{
  position:absolute;
  top:12px;
  width:70px;
  height:70px;
  border-radius:50%;
  border:8px dotted rgba(255,255,255,.9);
  box-shadow:0 12px 28px rgba(15,23,42,.22);
  animation:friendshipBraceletPulse 1.2s ease-in-out infinite;
}
.friendship-bracelet-loader span:first-child{
  left:10px;
  background:rgba(251,191,36,.22);
}
.friendship-bracelet-loader span:last-child{
  right:10px;
  background:rgba(236,72,153,.22);
  animation-delay:.18s;
}
.friendship-card-bracelet{
  position:relative;
  height:90px;
}
.friendship-theme-neon{
  background:linear-gradient(135deg,#020617,#6d28d9 48%,#06b6d4);
}
.friendship-theme-best-friends{
  background:linear-gradient(135deg,#7c3aed,#ec4899 50%,#f59e0b);
}
.friendship-theme-polaroid-style,
.friendship-theme-minimal{
  background:linear-gradient(135deg,#334155,#64748b 54%,#e2e8f0);
}
.friendship-theme-colorful,
.friendship-theme-fun{
  background:linear-gradient(135deg,#22c55e,#06b6d4 45%,#f97316);
}
@keyframes friendshipEmojiRise{
  to{transform:translateY(-820px) rotate(18deg)}
}
@keyframes friendshipBraceletFloat{
  to{transform:translateY(-860px) rotate(220deg)}
}
@keyframes friendshipBraceletPulse{
  0%,100%{transform:scale(.94) rotate(-4deg)}
  50%{transform:scale(1.08) rotate(4deg)}
}


.secret-username-box{
  display:inline-flex;
  align-items:center;
  gap:8px;
  max-width:100%;
  margin:8px 0 14px;
  padding:9px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.34);
  color:#fff;
  font-weight:800;
}
.secret-username-box strong{
  overflow-wrap:anywhere;
}

.tool-loading-slot{
  margin:10px 0 0;
}
.tool-status-note{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 12px;
  background:var(--soft);
  color:var(--muted);
  font-weight:800;
  line-height:1.35;
}
.tool-status-success{
  border-color:rgba(20,184,166,.28);
  color:#0f766e;
  background:rgba(20,184,166,.1);
}
.tool-status-warning{
  border-color:rgba(245,158,11,.32);
  color:#92400e;
  background:rgba(245,158,11,.12);
}
.tool-status-error{
  border-color:rgba(239,68,68,.35);
  color:#991b1b;
  background:rgba(254,226,226,.82);
}
[data-theme="dark"] .tool-status-success{
  color:#5eead4;
}
[data-theme="dark"] .tool-status-warning{
  color:#fbbf24;
}
[data-theme="dark"] .tool-status-error{
  color:#fecaca;
  border-color:#7f1d1d;
  background:rgba(127,29,29,.28);
}

.tool-icon svg{
  width:25px;
  height:25px;
}
.tool-icon.icon-purple{background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:0}
.tool-icon.icon-rose{background:linear-gradient(135deg,#be123c,#fb7185);color:#fff;border:0}
.tool-icon.icon-blue{background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;border:0}
.tool-icon.icon-teal{background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff;border:0}
.tool-icon.icon-amber{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border:0}
.tool-icon.icon-pink{background:linear-gradient(135deg,#ec4899,#8b5cf6);color:#fff;border:0}
.tool-icon.icon-slate{background:linear-gradient(135deg,#111827,#475569);color:#fff;border:0}
.tool-icon.icon-indigo{background:linear-gradient(135deg,#4f46e5,#0ea5e9);color:#fff;border:0}
.game-workspace{
  overflow:hidden;
}
.reaction-pad{
  width:100%;
  min-height:210px;
  border:0;
  border-radius:18px;
  display:grid;
  place-items:center;
  gap:8px;
  padding:24px;
  text-align:center;
  color:#fff;
  background:linear-gradient(135deg,#334155,#0f172a);
  box-shadow:0 18px 42px rgba(15,23,42,.18);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease;
}
.reaction-pad strong{display:block;font-size:clamp(1.35rem,4vw,2.3rem)}
.reaction-pad span{font-weight:800;opacity:.88}
.reaction-pad.waiting{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.reaction-pad.ready{background:linear-gradient(135deg,#16a34a,#14b8a6);transform:scale(1.01)}
.reaction-pad.early{background:linear-gradient(135deg,#dc2626,#7f1d1d)}
.reaction-pad.done{background:linear-gradient(135deg,#2563eb,#7c3aed)}
.color-match-panel{
  border:1px solid var(--border);
  border-radius:16px;
  padding:22px;
  text-align:center;
  background:var(--soft);
}
.color-match-word{
  font-size:clamp(2.5rem,9vw,5rem);
  font-weight:1000;
  line-height:1.05;
  letter-spacing:0;
  margin-top:8px;
}
.math-question{
  text-align:center;
  font-size:clamp(2rem,7vw,4rem);
  font-weight:1000;
  padding:24px;
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(37,99,235,.1),rgba(20,184,166,.1));
  margin:14px 0;
}
@media (max-width:560px){
  .reaction-pad{min-height:180px}
}

.emoji-arena{
  position:relative;
  min-height:300px;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 20%,rgba(20,184,166,.2),transparent 28%),
    radial-gradient(circle at 80% 10%,rgba(236,72,153,.16),transparent 24%),
    linear-gradient(135deg,rgba(37,99,235,.08),rgba(20,184,166,.08));
}
.emoji-target{
  position:absolute;
  left:50%;
  top:50%;
  width:52px;
  height:52px;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,#f59e0b,#ec4899);
  color:#fff;
  font-size:1.6rem;
  font-weight:900;
  box-shadow:0 14px 30px rgba(236,72,153,.26);
  cursor:pointer;
  transform:translate(-50%,-50%);
  transition:left .12s ease, top .12s ease, transform .12s ease;
}
.emoji-target:active{
  transform:translate(-50%,-50%) scale(.92);
}
.pattern-board{
  display:grid;
  grid-template-columns:repeat(2,minmax(110px,170px));
  gap:12px;
  justify-content:center;
  margin:18px 0;
}
.pattern-pad{
  min-height:128px;
  border:0;
  border-radius:20px;
  box-shadow:0 12px 24px rgba(15,23,42,.14);
  cursor:pointer;
  opacity:.78;
  transition:transform .14s ease, opacity .14s ease, filter .14s ease;
}
.pattern-pad.active,
.pattern-pad:active{
  opacity:1;
  transform:scale(1.05);
  filter:brightness(1.25);
}
.pad-red{background:#ef4444}
.pad-blue{background:#2563eb}
.pad-green{background:#16a34a}
.pad-yellow{background:#f59e0b}
@media (max-width:560px){
  .emoji-arena{min-height:240px}
  .pattern-board{grid-template-columns:repeat(2,minmax(96px,1fr))}
  .pattern-pad{min-height:110px}
}

.secret-panel .secret-empty{
  background:rgba(255,255,255,.94);
  color:#0f172a;
  border-color:rgba(255,255,255,.48);
}
.secret-panel .secret-empty strong{
  color:#111827;
}
.secret-panel .secret-empty p{
  color:#334155;
}
.secret-panel .secret-empty a{
  color:#2563eb;
  font-weight:900;
}
[data-theme="dark"] .secret-panel .secret-empty{
  background:rgba(15,23,42,.88);
  color:#f8fafc;
  border-color:rgba(255,255,255,.18);
}
[data-theme="dark"] .secret-panel .secret-empty strong{
  color:#fff;
}
[data-theme="dark"] .secret-panel .secret-empty p{
  color:#cbd5e1;
}


.short-link-waiting{
  min-height:100vh;
  overflow:hidden;
  background:
    radial-gradient(circle at 16% 12%,rgba(125,211,252,.9),transparent 26%),
    radial-gradient(circle at 84% 18%,rgba(96,165,250,.7),transparent 28%),
    linear-gradient(135deg,#0ea5e9,#2563eb 52%,#1d4ed8) !important;
}
.short-link-waiting .container{
  filter:blur(8px);
  transform:scale(.985);
  opacity:.38;
  pointer-events:none;
  user-select:none;
  transition:filter .25s ease,opacity .25s ease,transform .25s ease;
}
.short-redirect-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:22px;
  background:
    radial-gradient(circle at 20% 18%,rgba(255,255,255,.18),transparent 24%),
    radial-gradient(circle at 82% 22%,rgba(20,184,166,.22),transparent 26%),
    linear-gradient(135deg,rgba(14,165,233,.92),rgba(37,99,235,.94) 54%,rgba(29,78,216,.96));
  color:#fff;
}
.short-redirect-panel{
  width:min(520px,100%);
  padding:34px 26px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:28px;
  text-align:center;
  background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.08));
  box-shadow:0 30px 90px rgba(15,23,42,.34);
  backdrop-filter:blur(16px);
}
.short-redirect-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.26);
  font-weight:900;
  letter-spacing:.02em;
}
.short-redirect-loader{
  position:relative;
  width:104px;
  height:104px;
  margin:24px auto 18px;
  border-radius:50%;
  background:conic-gradient(from 0deg,#fff,#38bdf8,#14b8a6,#f472b6,#fff);
  animation:twfSpin 1.05s linear infinite;
  box-shadow:0 0 44px rgba(255,255,255,.26);
}
.short-redirect-loader::before{
  content:"";
  position:absolute;
  inset:11px;
  border-radius:50%;
  background:linear-gradient(135deg,#2563eb,#0ea5e9);
}
.short-redirect-loader span{
  position:absolute;
  inset:31px;
  z-index:1;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(255,255,255,.96);
  color:#2563eb;
  font-size:1.5rem;
  font-weight:900;
}
.short-redirect-loader span::before{
  content:"";
  width:18px;
  height:18px;
  border-top:4px solid currentColor;
  border-right:4px solid currentColor;
  transform:rotate(45deg);
  margin-left:-5px;
}
.short-redirect-panel h1{
  margin:0;
  color:#fff;
  font-size:clamp(2rem,5vw,3rem);
  line-height:1.08;
}
.short-redirect-panel p{
  margin:12px auto 0;
  max-width:36rem;
  color:rgba(255,255,255,.88);
  font-size:1.02rem;
  font-weight:800;
  line-height:1.5;
}
.short-redirect-host{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  max-width:100%;
  margin:18px 0 4px;
  padding:10px 14px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(15,23,42,.24);
  color:#fff;
  font-weight:900;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.short-redirect-host.muted{
  color:rgba(255,255,255,.82);
}
.short-redirect-progress{
  width:min(320px,100%);
  height:10px;
  margin:22px auto 12px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(255,255,255,.22);
}
.short-redirect-progress span{
  display:block;
  width:45%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#fff,#bfdbfe,#14b8a6);
  animation:twfProgress 1.15s ease-in-out infinite;
}
.short-redirect-panel small{
  display:block;
  color:rgba(255,255,255,.76);
  font-weight:800;
}
@media (max-width:560px){
  .short-redirect-panel{
    padding:28px 18px;
    border-radius:22px;
  }
  .short-redirect-loader{
    width:88px;
    height:88px;
  }
  .short-redirect-loader span{
    inset:27px;
  }
}


.short-redirect-panel{
  width:min(560px,100%);
}
.short-redirect-loader{
  width:min(260px,72vw);
  height:112px;
  margin:22px auto 18px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.24);
  background:
    linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,.08)),
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.28),transparent 28%);
  box-shadow:0 24px 60px rgba(15,23,42,.2), inset 0 1px 0 rgba(255,255,255,.22);
  overflow:hidden;
  animation:shortLoaderFloat 2.9s ease-in-out infinite;
}
.short-redirect-loader::before{
  content:"";
  position:absolute;
  inset:-65% -35%;
  border-radius:0;
  background:conic-gradient(from 90deg,transparent,rgba(255,255,255,.46),transparent 38%);
  opacity:.9;
  animation:shortLoaderSweep 2.4s linear infinite;
}
.short-redirect-loader::after{
  content:"";
  position:absolute;
  inset:11px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(37,99,235,.72),rgba(14,165,233,.58));
  border:1px solid rgba(255,255,255,.18);
}
.short-redirect-loader span{
  position:absolute;
  display:block;
  z-index:2;
  inset:auto;
  border:0;
  margin:0;
  color:inherit;
  font-size:initial;
  font-weight:normal;
  background:transparent;
}
.short-redirect-loader span::before{
  content:none;
}
.short-redirect-loader .short-link-node{
  top:35px;
  width:44px;
  height:44px;
  border-radius:16px;
  background:rgba(255,255,255,.95);
  box-shadow:0 14px 32px rgba(15,23,42,.24), inset 0 0 0 1px rgba(37,99,235,.12);
  animation:shortNodeBounce 1.7s ease-in-out infinite;
}
.short-redirect-loader .short-link-node-left{
  left:42px;
}
.short-redirect-loader .short-link-node-right{
  right:42px;
  animation-delay:.18s;
}
.short-redirect-loader .short-link-node::before,
.short-redirect-loader .short-link-node::after{
  content:"";
  position:absolute;
  left:11px;
  top:16px;
  width:20px;
  height:12px;
  border:4px solid #2563eb;
  border-radius:999px;
  transform:rotate(-28deg);
}
.short-redirect-loader .short-link-node::after{
  left:15px;
  border-color:#14b8a6;
  transform:rotate(-28deg) translateX(7px);
}
.short-redirect-loader .short-link-beam{
  left:86px;
  right:86px;
  top:52px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.24);
  overflow:hidden;
}
.short-redirect-loader .short-link-beam::before{
  content:"";
  position:absolute;
  inset:0;
  width:55%;
  border-radius:inherit;
  background:linear-gradient(90deg,#fff,#67e8f9,#86efac);
  box-shadow:0 0 22px rgba(255,255,255,.72);
  animation:shortBeamMove 1.15s ease-in-out infinite;
}
.short-redirect-loader .short-link-spark{
  top:49px;
  width:14px;
  height:14px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 20px rgba(255,255,255,.9);
  animation:shortSparkMove 1.55s ease-in-out infinite;
}
.short-redirect-loader .spark-one{
  left:92px;
}
.short-redirect-loader .spark-two{
  left:120px;
  width:10px;
  height:10px;
  animation-delay:.32s;
  opacity:.85;
}
.short-redirect-panel h1{
  font-size:clamp(1.9rem,4.5vw,2.75rem);
}
.short-redirect-progress{
  height:9px;
}
@keyframes shortLoaderFloat{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-7px) scale(1.015)}
}
@keyframes shortLoaderSweep{
  to{transform:rotate(360deg)}
}
@keyframes shortNodeBounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
@keyframes shortBeamMove{
  0%{transform:translateX(-115%)}
  55%{transform:translateX(78%)}
  100%{transform:translateX(210%)}
}
@keyframes shortSparkMove{
  0%{transform:translateX(-22px) scale(.65);opacity:0}
  25%{opacity:1}
  70%{opacity:1}
  100%{transform:translateX(78px) scale(1.15);opacity:0}
}
@media (max-width:560px){
  .short-redirect-loader{
    width:min(230px,78vw);
    height:98px;
  }
  .short-redirect-loader .short-link-node{
    top:29px;
  }
  .short-redirect-loader .short-link-node-left{
    left:28px;
  }
  .short-redirect-loader .short-link-node-right{
    right:28px;
  }
  .short-redirect-loader .short-link-beam{
    left:72px;
    right:72px;
    top:46px;
  }
}

/* Creator template library tools */
.creator-library-workspace{overflow:hidden}
.creator-library-tool{display:grid;gap:18px}
.creator-filter-panel,.creator-builder-panel{
  display:grid;
  gap:14px;
  padding:16px;
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(20,184,166,.08));
}
.creator-filter-panel{grid-template-columns:repeat(3,minmax(0,1fr))}
.creator-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:end}
.creator-count-line{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  color:var(--muted);
  font-weight:800;
}
.creator-count-line strong{
  color:var(--text);
  padding:7px 11px;
  border-radius:999px;
  background:var(--soft);
}
.creator-results-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:14px;
}
.creator-result-card{
  display:grid;
  gap:12px;
  min-width:0;
  padding:16px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  box-shadow:var(--shadow);
}
.creator-card-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}
.creator-card-top span{
  font-weight:900;
  color:#0f766e;
}
.creator-fav-btn{
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--soft);
  color:var(--text);
  padding:6px 9px;
  font-weight:800;
  cursor:pointer;
}
.creator-result-card p{
  margin:0;
  color:var(--text);
  font-weight:800;
  line-height:1.45;
  overflow-wrap:anywhere;
}
.creator-result-card small{color:var(--muted);font-weight:700}
.creator-memory-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.creator-mini-list{
  display:grid;
  gap:8px;
}
.creator-mini-copy{
  text-align:left;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--soft);
  color:var(--text);
  padding:10px;
  font-weight:800;
  cursor:pointer;
}
.creator-special-output{display:grid;gap:14px}
.creator-random-pick,.creator-checklist,.creator-structure{
  padding:16px;
  border:1px solid rgba(37,99,235,.22);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(37,99,235,.10),rgba(20,184,166,.10));
}
.creator-random-pick p{
  white-space:pre-wrap;
  font-size:1.08rem;
  font-weight:900;
  overflow-wrap:anywhere;
}
.creator-plan-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:12px;
}
.creator-plan-grid article,.creator-structure article{
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--card);
  padding:13px;
}
.creator-plan-grid strong,.creator-structure strong{display:block;color:var(--text)}
.creator-plan-grid span{display:inline-flex;margin:6px 0;color:#0f766e;font-weight:900}
.creator-plan-grid p,.creator-structure p{margin:0;color:var(--muted)}
.creator-checklist{display:grid;gap:9px}
.creator-checklist label{
  display:flex;
  align-items:flex-start;
  gap:9px;
  padding:9px;
  border-radius:10px;
  background:var(--card);
  font-weight:800;
}
.creator-checklist input{margin-top:4px}
@media (max-width:760px){
  .creator-filter-panel{grid-template-columns:1fr}
  .creator-memory-grid{grid-template-columns:1fr}
  .creator-actions .btn{width:100%;justify-content:center}
}

/* Friendship Quiz Challenge */
.friendship-quiz-intro{
  position:relative;
  overflow:hidden;
}
.quiz-kicker{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  align-items:center;
  gap:6px;
  padding:7px 12px;
  border-radius:999px;
  color:#fff;
  font-size:.82rem;
  font-weight:900;
  background:linear-gradient(135deg,#7c3aed,#ec4899,#f97316);
  box-shadow:0 10px 24px rgba(236,72,153,.26);
}
.friendship-quiz-workspace{
  overflow:hidden;
  background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(236,72,153,.08),rgba(20,184,166,.08));
}
.friendship-quiz-shell{
  position:relative;
  display:grid;
  gap:18px;
  min-width:0;
}
.friendship-quiz-hero,
.friendship-quiz-form,
.quiz-question-card,
.friendship-quiz-success,
.friendship-quiz-result-card,
.friendship-leaderboard{
  border:1px solid rgba(124,58,237,.18);
  border-radius:20px;
  background:var(--card);
  box-shadow:var(--shadow);
  padding:18px;
}
.friendship-quiz-hero{
  color:#fff;
  background:
    radial-gradient(circle at 20% 18%,rgba(255,255,255,.22),transparent 24%),
    linear-gradient(135deg,#7c3aed,#ec4899 52%,#f97316);
}
.friendship-quiz-hero h3{
  margin:.5rem 0 .35rem;
  font-size:clamp(1.55rem,4vw,2.4rem);
  color:#fff;
  letter-spacing:0;
}
.friendship-quiz-hero p{
  margin:0;
  max-width:720px;
  color:rgba(255,255,255,.9);
  font-weight:700;
}
.friendship-quiz-hero .quiz-kicker{
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.34);
}
.friendship-quiz-form{
  display:grid;
  gap:14px;
}
.quiz-main-btn{
  font-size:1rem;
  padding:13px 18px;
  border-radius:14px;
}
.quiz-topline{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-weight:900;
}
.quiz-topline span{
  padding:7px 11px;
  border-radius:999px;
  color:#7c2d12;
  background:#ffedd5;
}
[data-theme="dark"] .quiz-topline span{
  color:#fed7aa;
  background:rgba(249,115,22,.18);
}
.quiz-progress{
  height:11px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(148,163,184,.25);
}
.quiz-progress span{
  display:block;
  height:100%;
  width:0;
  border-radius:inherit;
  background:linear-gradient(90deg,#2563eb,#14b8a6,#ec4899);
  transition:width .28s ease;
}
.quiz-question-card{
  animation:quizSlideIn .24s ease both;
}
.quiz-question-card h3{
  margin-top:0;
  font-size:clamp(1.35rem,3vw,2rem);
  line-height:1.25;
}
.quiz-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.quiz-option{
  min-height:58px;
  padding:14px;
  border:2px solid transparent;
  border-radius:16px;
  color:var(--text);
  background:linear-gradient(var(--card),var(--card)) padding-box,linear-gradient(135deg,#60a5fa,#e879f9,#2dd4bf) border-box;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
  font-weight:900;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.quiz-option:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 26px rgba(15,23,42,.13);
}
.quiz-option.selected{
  color:#fff;
  background:linear-gradient(135deg,#2563eb,#7c3aed,#ec4899);
}
.player-quiz-option{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  min-width:0;
  min-height:68px;
  text-align:left;
}
.player-quiz-option:disabled{
  opacity:1;
  cursor:default;
}
.player-quiz-option:disabled:hover{
  transform:none;
}
.player-quiz-option.is-correct{
  border-color:#bbf7d0;
  background:#15803d;
  color:#fff;
  box-shadow:0 12px 28px rgba(21,128,61,.26);
}
.player-quiz-option.is-wrong{
  border-color:#fecaca;
  background:#dc2626;
  color:#fff;
  box-shadow:0 12px 28px rgba(220,38,38,.24);
}
.player-quiz-option.is-locked{
  border-color:var(--border);
  background:var(--soft);
  color:var(--muted);
  box-shadow:none;
}
.quiz-option-label{
  min-width:0;
  overflow-wrap:anywhere;
}
.quiz-option-feedback{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  max-width:100%;
  padding:5px 8px;
  border:1px solid rgba(255,255,255,.42);
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:#fff;
  font-size:.78rem;
  font-weight:950;
  line-height:1.2;
  text-align:center;
}
.quiz-answer-feedback{
  min-height:48px;
  display:flex;
  align-items:center;
  margin:14px 0 0;
  padding:11px 13px;
  border:1px solid var(--border);
  border-radius:13px;
  background:var(--soft);
  color:var(--muted);
  font-weight:850;
  line-height:1.45;
}
.quiz-answer-feedback.is-correct{
  border-color:#86efac;
  background:#dcfce7;
  color:#14532d;
}
.quiz-answer-feedback.is-wrong{
  border-color:#fca5a5;
  background:#fee2e2;
  color:#7f1d1d;
}
[data-theme="dark"] .quiz-answer-feedback.is-correct{
  border-color:#22c55e;
  background:rgba(21,128,61,.24);
  color:#bbf7d0;
}
[data-theme="dark"] .quiz-answer-feedback.is-wrong{
  border-color:#ef4444;
  background:rgba(185,28,28,.24);
  color:#fecaca;
}
#fq_player_next:disabled{
  opacity:.52;
  cursor:not-allowed;
  transform:none;
}
.quiz-action-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.quiz-review-list{
  display:grid;
  gap:10px;
}
.quiz-review-list article{
  min-width:0;
  padding:13px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
}
.quiz-review-list span{
  display:block;
  color:#0f766e;
  font-weight:900;
}
.quiz-review-list strong,
.quiz-review-list p{
  overflow-wrap:anywhere;
}
.friendship-quiz-success{
  color:#fff;
  background:linear-gradient(135deg,#7c3aed,#ec4899,#06b6d4);
}
.friendship-quiz-success .input{
  color:#071226;
  background:#fff;
}
.friendship-quiz-loading{
  min-height:320px;
  display:grid;
  place-items:center;
  text-align:center;
  padding:30px;
  border-radius:24px;
  color:#fff;
  background:linear-gradient(135deg,#2563eb,#7c3aed,#ec4899);
}
.quiz-loader-ring{
  width:84px;
  height:84px;
  border-radius:50%;
  border:10px solid rgba(255,255,255,.28);
  border-top-color:#fff;
  animation:quizSpin 1s linear infinite;
}
.friendship-quiz-result-card{
  position:relative;
  overflow:hidden;
  text-align:center;
  color:#fff;
  background:linear-gradient(135deg,#7c3aed,#ec4899 55%,#06b6d4);
}
.friendship-quiz-result-card h3{
  margin:.55rem 0 1rem;
  color:#fff;
  font-size:clamp(1.9rem,6vw,3rem);
}
.friendship-quiz-result-card p{
  margin:1rem auto 0;
  max-width:620px;
  color:#fff;
  font-size:1.15rem;
  font-weight:900;
}
.quiz-score-circle{
  width:min(230px,70vw);
  height:min(230px,70vw);
  margin:0 auto;
  display:grid;
  place-items:center;
  align-content:center;
  gap:5px;
  border-radius:50%;
  background:rgba(255,255,255,.16);
  border:2px solid rgba(255,255,255,.35);
  box-shadow:inset 0 0 50px rgba(255,255,255,.12);
}
.quiz-score-circle strong{
  display:block;
  font-size:clamp(2.4rem,8vw,4.5rem);
}
.quiz-score-circle span{
  font-weight:800;
}
.friendship-leaderboard h3{
  margin-top:0;
}
.leaderboard-list{
  display:grid;
  gap:10px;
}
.leaderboard-list article{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--soft);
}
.leaderboard-list strong,
.leaderboard-list span{
  overflow-wrap:anywhere;
  min-width:0;
}
.quiz-confetti{
  pointer-events:none;
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:1;
}
.quiz-confetti span{
  position:absolute;
  left:var(--x);
  top:-16px;
  width:10px;
  height:18px;
  border-radius:3px;
  background:hsl(calc(var(--i) * 37),90%,62%);
  animation:quizConfettiFall calc(2.1s + var(--d) * .2s) linear infinite;
  animation-delay:calc(var(--i) * -.08s);
}
.result-shell > *:not(.quiz-confetti){
  position:relative;
  z-index:2;
}
@keyframes quizSlideIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes quizSpin{
  to{transform:rotate(360deg)}
}
@keyframes quizConfettiFall{
  to{transform:translateY(720px) rotate(540deg);opacity:.15}
}
@media (max-width:700px){
  .friendship-quiz-hero,
  .friendship-quiz-form,
  .quiz-question-card,
  .friendship-quiz-success,
  .friendship-quiz-result-card,
  .friendship-leaderboard{
    padding:15px;
    border-radius:18px;
  }
  .quiz-options{
    grid-template-columns:1fr;
  }
  .quiz-action-row .btn,
  .friendship-quiz-success .btn{
    width:100%;
    justify-content:center;
  }
  .leaderboard-list article{
    align-items:flex-start;
    flex-direction:column;
  }
}
@media (max-width:480px){
  .player-quiz-option{
    grid-template-columns:1fr;
    gap:8px;
    min-height:72px;
    padding:14px 15px;
  }
  .quiz-option-feedback{
    justify-self:start;
  }
  .quiz-answer-feedback{
    min-height:54px;
  }
}

/* Rewarded ads and reward games */
.btn-reward{background:linear-gradient(135deg,#7c3aed,#ec4899,#f97316);color:#fff;border:0;box-shadow:0 12px 24px rgba(236,72,153,.24)}
.reward-modal-backdrop{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:18px;background:rgba(15,23,42,.58);backdrop-filter:blur(8px)}
.reward-modal{width:min(430px,100%);display:grid;gap:13px;padding:20px;border:1px solid rgba(255,255,255,.28);border-radius:20px;background:var(--card);box-shadow:0 30px 90px rgba(15,23,42,.35)}
.reward-pill{width:max-content;padding:6px 10px;border-radius:999px;color:#fff;font-weight:900;background:linear-gradient(135deg,#2563eb,#14b8a6)}
.reward-progress{height:9px;overflow:hidden;border-radius:999px;background:var(--soft)}
.reward-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,#7c3aed,#ec4899,#f97316)}
.reward-modal-backdrop.is-loading .reward-progress span{animation:rewardLoad 1.7s ease forwards}
@keyframes rewardLoad{to{width:100%}}
.game-rank-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.btn-small{padding:8px 10px;font-size:.86rem}
.reward-game-workspace{overflow:hidden;background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(236,72,153,.08))}
.treasure-board{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.treasure-box,.spot-cell{min-height:58px;border:1px solid var(--border);border-radius:14px;background:var(--card);font-size:1.5rem;cursor:pointer;box-shadow:var(--shadow)}
.treasure-box.safe{background:linear-gradient(135deg,#dcfce7,#86efac)}
.treasure-box.trap{background:linear-gradient(135deg,#fee2e2,#fca5a5)}
.escape-room{text-align:center;border:1px solid var(--border);border-radius:16px;background:var(--soft);padding:18px}
.escape-room-art{font-size:3rem}
.spot-board{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.spot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;padding:12px;border:1px solid var(--border);border-radius:16px;background:var(--soft)}
.spot-cell.hinted{outline:4px solid #f59e0b;transform:scale(1.06)}
.word-puzzle-box{display:grid;gap:12px;text-align:center;border:1px solid var(--border);border-radius:16px;background:var(--soft);padding:18px}
.word-puzzle-mask{font-size:2rem;font-weight:900;letter-spacing:.14em;color:#7c3aed}
@media (max-width:620px){.spot-board{grid-template-columns:1fr}.treasure-board{gap:7px}.treasure-box,.spot-cell{min-height:50px}.game-rank-actions .btn{width:100%;justify-content:center}}


.ai-quota-card{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  padding:13px;
  border:1px solid rgba(124,58,237,.22);
  border-radius:14px;
  background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(236,72,153,.08));
}
.ai-quota-card strong{color:var(--text)}
.ai-quota-card span{color:var(--muted);font-weight:700}
@media (max-width:620px){.ai-quota-card .btn{width:100%;justify-content:center}}

/* Cross-page overflow safety */
html,
body{
  max-width:100%;
  overflow-x:clip;
}
main,
section,
article,
.grid > *,
.field-grid > *,
.button-row > *,
.tool-heading,
.card-preview-inner{
  min-width:0;
}
.card,
.tool-workspace,
.result,
.faq-item,
.card-preview,
.reply-composer{
  overflow-wrap:anywhere;
}
img,
svg,
canvas,
video,
iframe{
  max-width:100%;
}
.button-row{
  align-items:stretch;
}
@media (max-width:520px){
  .tool-workspace .button-row:not(.proposal-actions) > .btn,
  .tool-workspace .button-row:not(.proposal-actions) > a.btn,
  .share-row > .btn{
    flex:1 1 100%;
    width:100%;
  }
}

/* Anonymous Message board: responsive desktop and swipe layout */
body.anon-board-mode{
  background:#f4f6fb;
}
.anon-mobile-board{
  width:min(100%,1040px);
  max-width:1040px;
  min-height:100vh;
  padding:28px;
  border-inline:1px solid #e5e7eb;
  box-shadow:0 24px 70px rgba(15,23,42,.08);
}
.anon-board-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:0;
}
.anon-board-tabs{
  flex:0 0 auto;
  align-items:center;
  gap:24px;
  min-width:max-content;
}
.anon-board-tab{
  flex:0 0 auto;
  min-width:max-content;
  white-space:nowrap;
  word-break:normal;
  overflow-wrap:normal;
  font-size:clamp(1.9rem,4vw,2.75rem);
}
.anon-board-delete{
  flex:0 0 auto;
  white-space:nowrap;
}
.anon-board-username{
  margin:12px 0 24px;
}
.anon-play-title{
  padding:0 0 10px;
}
.anon-prompt-rail{
  grid-auto-columns:minmax(270px,calc((100% - 36px)/3));
  gap:18px;
  padding:12px 4px 22px;
  scroll-padding-inline:4px;
}
.anon-play-card{
  width:100%;
  min-width:0;
  min-height:270px;
}
.anon-play-card strong{
  font-size:clamp(1.65rem,3vw,2.35rem);
  overflow-wrap:normal;
  word-break:normal;
}
.anon-dots{
  margin:4px 0 24px;
}
.anon-play-steps{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.anon-step-card{
  min-width:0;
  margin:0;
  padding:26px 22px;
}
.anon-step-card h3{
  font-size:clamp(1.45rem,3vw,2rem);
}
.anon-social-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:12px;
  margin-top:16px;
}
.anon-social-btn{
  width:52px;
  height:52px;
  flex:0 0 52px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:50%;
  color:#fff;
  cursor:pointer;
  box-shadow:0 12px 24px rgba(15,23,42,.16);
  transition:transform .2s ease,box-shadow .2s ease;
}
.anon-social-btn:hover,
.anon-social-btn:focus-visible{
  transform:translateY(-3px);
  box-shadow:0 16px 30px rgba(15,23,42,.22);
}
.anon-social-btn svg{
  width:25px;
  height:25px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.anon-social-whatsapp{background:#16a34a}
.anon-social-facebook{background:#2563eb}
.anon-social-instagram{background:linear-gradient(135deg,#7c3aed,#db2777,#f97316)}
.anon-social-x{background:#111827}
.anon-inbox-section{
  padding:18px 0;
}
.anon-inbox-section .secret-message-list{
  display:grid;
  gap:18px;
}
.anon-message-card{
  min-width:0;
}
[data-theme="dark"] body.anon-board-mode,
[data-theme="dark"] .anon-mobile-board{
  background:#0f172a;
  color:#f8fafc;
  border-color:#273449;
}
[data-theme="dark"] .anon-board-tab.active,
[data-theme="dark"] .anon-play-title strong,
[data-theme="dark"] .anon-inbox-head h3{
  color:#f8fafc;
}
@media (max-width:760px){
  .anon-mobile-board{
    width:min(100%,540px);
    padding:22px 16px 34px;
    border:0;
    box-shadow:none;
  }
  .anon-prompt-rail{
    grid-auto-columns:minmax(250px,84%);
    gap:14px;
    margin-inline:-16px;
    padding-inline:16px;
    scroll-padding-inline:16px;
  }
  .anon-play-steps{
    grid-template-columns:1fr;
    gap:16px;
  }
  .anon-step-card{
    padding:24px 18px;
  }
}
@media (max-width:430px){
  .anon-board-top{
    gap:10px;
  }
  .anon-board-tabs{
    gap:14px;
  }
  .anon-board-tab{
    font-size:1.8rem;
  }
  .anon-board-delete{
    padding:8px 10px;
    font-size:.74rem;
  }
  .anon-prompt-rail{
    grid-auto-columns:86%;
  }
  .anon-play-card{
    min-height:238px;
    padding:24px 18px 66px;
  }
  .anon-play-card strong{
    font-size:clamp(1.4rem,7vw,2rem);
    padding-right:76px;
  }
  .anon-play-card small{
    max-width:78%;
  }
  .anon-play-username{
    right:14px;
    bottom:14px;
    font-size:.72rem;
    max-width:48%;
  }
  .anon-share-main{
    min-height:58px;
    font-size:1.2rem;
  }
}

/* Proposal shared-page polish */
.proposal-experience{
  min-height:620px;
}
.proposal-card-inner{
  width:min(100%,900px);
  min-height:560px;
  margin:auto;
  padding:42px 28px;
  gap:16px;
}
.proposal-kicker{
  display:inline-flex;
  max-width:100%;
  padding:7px 13px;
  border:1px solid rgba(255,255,255,.34);
  border-radius:999px;
  background:rgba(255,255,255,.16);
  font-weight:900;
  text-transform:uppercase;
  text-align:center;
}
.proposal-card-inner h3{
  max-width:780px;
  margin:4px auto;
  font-size:clamp(2.25rem,6vw,4.65rem);
  line-height:1.04;
  text-wrap:balance;
}
.proposal-card-inner .proposal-message{
  font-size:clamp(1.08rem,2.4vw,1.45rem);
  line-height:1.55;
}
.proposal-unlock-note{
  margin:4px auto 0;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  font-weight:850;
}
.proposal-actions{
  margin-top:auto;
}
.proposal-response{
  min-height:54px;
}
@media (max-width:560px){
  .proposal-experience{
    min-height:560px;
  }
  .proposal-card-inner{
    min-height:540px;
    padding:28px 16px;
  }
  .proposal-card-inner h3{
    font-size:clamp(2rem,11vw,3.25rem);
  }
}

/* Multi-step surprise reveal */
.surprise-stage{
  position:relative;
  min-height:620px;
  overflow:hidden;
  display:grid;
  place-items:center;
  padding:28px;
  border-radius:24px;
  color:#fff;
  isolation:isolate;
  background:linear-gradient(135deg,#7c3aed,#ec4899 52%,#0ea5e9);
  box-shadow:0 24px 70px rgba(15,23,42,.18);
}
.surprise-stage-friendship{
  background:linear-gradient(135deg,#f59e0b,#ec4899 50%,#2563eb);
}
.surprise-stage-marriage{
  background:linear-gradient(135deg,#7f1d1d,#be123c 46%,#b45309);
}
.surprise-stage-inner{
  position:relative;
  z-index:2;
  width:min(100%,660px);
  display:grid;
  justify-items:center;
  gap:16px;
  text-align:center;
  animation:birthdayReveal .62s ease both;
}
.surprise-step-count{
  display:inline-flex;
  padding:7px 12px;
  border:1px solid rgba(255,255,255,.34);
  border-radius:999px;
  background:rgba(255,255,255,.15);
  font-weight:900;
}
.surprise-stage h2,
.surprise-stage h3{
  max-width:620px;
  margin:0;
  font-size:clamp(2rem,6vw,3.6rem);
  line-height:1.06;
  text-wrap:balance;
}
.surprise-stage p{
  max-width:610px;
  margin:0;
  color:rgba(255,255,255,.92);
  font-size:clamp(1rem,2.5vw,1.25rem);
  font-weight:750;
  line-height:1.65;
}
.surprise-open-button{
  display:grid;
  justify-items:center;
  gap:22px;
  max-width:100%;
  border:0;
  background:transparent;
  color:#fff;
  cursor:pointer;
}
.surprise-open-label,
.surprise-next-button{
  min-height:54px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 22px;
  border:1px solid rgba(255,255,255,.35);
  border-radius:999px;
  background:#fff;
  color:#111827;
  font-size:1.05rem;
  font-weight:950;
  box-shadow:0 16px 34px rgba(15,23,42,.22);
}
.surprise-next-button{
  cursor:pointer;
}
.surprise-open-button:hover .birthday-gift-loader,
.surprise-open-button:focus-visible .birthday-gift-loader{
  transform:translateY(-8px) rotate(3deg) scale(1.05);
}
.surprise-stage .birthday-confetti,
.surprise-stage .birthday-star-field,
.surprise-stage .friendship-emoji-field,
.surprise-stage .marriage-heart-field{
  z-index:0;
}
.marriage-ring-loader{
  position:relative;
  width:138px;
  height:92px;
  margin:0 auto;
}
.marriage-ring-loader span{
  position:absolute;
  top:8px;
  width:74px;
  height:74px;
  border:10px solid #fde68a;
  border-radius:50%;
  box-shadow:0 0 0 3px rgba(255,255,255,.32),0 18px 34px rgba(15,23,42,.25);
  animation:marriageRingGlow 1.35s ease-in-out infinite;
}
.marriage-ring-loader span:first-child{left:8px;transform:rotate(-12deg)}
.marriage-ring-loader span:last-child{right:8px;transform:rotate(12deg);animation-delay:.18s}
.marriage-surprise-page{
  background:linear-gradient(135deg,#7f1d1d,#be123c 46%,#b45309);
}
.marriage-mini-hero{
  border-color:rgba(190,24,93,.32);
  background:linear-gradient(135deg,rgba(190,24,93,.16),rgba(217,119,6,.15),rgba(124,58,237,.12));
}
.marriage-success-card,
.marriage-loading-screen{
  background:linear-gradient(135deg,#7f1d1d,#be123c 46%,#b45309);
}
.marriage-theme-midnight{
  background:linear-gradient(135deg,#020617,#312e81 50%,#be123c);
}
.marriage-theme-soft-pink,
.marriage-theme-rose-celebration{
  background:linear-gradient(135deg,#9f1239,#ec4899 50%,#7c3aed);
}
.marriage-theme-elegant{
  background:linear-gradient(135deg,#312e81,#7c2d12 54%,#d97706);
}
.marriage-reveal-card h2{
  font-size:clamp(2.1rem,7vw,4.35rem);
}
.marriage-heart-field{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-1;
}
.marriage-heart{
  position:absolute;
  left:var(--x);
  bottom:-48px;
  color:#fecdd3;
  font-size:clamp(1.25rem,3vw,2rem);
  text-shadow:0 8px 18px rgba(15,23,42,.24);
  animation:marriageHeartRise calc(6s + var(--d) * .45s) ease-in infinite;
  animation-delay:calc(var(--i) * -.34s);
}
@keyframes marriageRingGlow{
  0%,100%{filter:drop-shadow(0 0 5px rgba(253,230,138,.5))}
  50%{filter:drop-shadow(0 0 20px rgba(253,230,138,1))}
}
@keyframes marriageHeartRise{
  to{transform:translateY(-840px) rotate(22deg);opacity:.18}
}
@media (max-width:720px){
  .surprise-stage{
    min-height:560px;
    padding:20px 16px;
    border-radius:18px;
  }
  .surprise-open-label,
  .surprise-next-button{
    width:100%;
  }
}
@media (prefers-reduced-motion:reduce){
  .surprise-stage *,
  .birthday-surprise-page *,
  .proposal-experience *{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
  }
}

/* Savage AI Roast Chat */
body[data-expanded-tool="ai-roast-generator"] .tool-workspace{
  overflow:visible;
  padding:12px;
}
body[data-expanded-tool="ai-roast-generator"] main{
  overflow:visible;
}
.roast-chat-app{
  display:grid;
  grid-template-columns:245px minmax(0,1fr);
  align-items:stretch;
  overflow:visible;
  border:1px solid var(--border);
  border-radius:20px;
  background:var(--card);
  box-shadow:0 22px 56px rgba(15,23,42,.12);
}
.roast-chat-sidebar{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-self:stretch;
  gap:14px;
  overflow:visible;
  padding:18px;
  color:#fff;
  background:linear-gradient(165deg,#111827 0%,#312e81 52%,#831843 100%);
}
.roast-sidebar-heading{
  display:flex;
  align-items:center;
  gap:10px;
}
.roast-sidebar-heading > div{
  min-width:0;
  display:grid;
  gap:2px;
}
.roast-sidebar-heading strong{font-size:1.05rem}
.roast-sidebar-heading span{color:#cbd5e1;font-size:.78rem;font-weight:700}
.roast-brand-mark,
.roast-message-avatar,
.roast-empty-icon{
  flex:0 0 auto;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,#f43f5e,#a855f7 58%,#06b6d4);
  box-shadow:0 10px 22px rgba(168,85,247,.28);
  font-weight:950;
}
.roast-brand-mark{width:38px;height:38px;border-radius:11px}
.roast-new-chat{
  width:100%;
  color:#111827;
  background:linear-gradient(135deg,#fda4af,#fde68a 55%,#5eead4);
}
.roast-chat-list{
  flex:0 0 auto;
  display:grid;
  align-content:start;
  gap:7px;
  overflow:visible;
  padding-right:2px;
}
.roast-history-item{
  width:100%;
  min-width:0;
  display:grid;
  gap:3px;
  padding:10px 11px;
  border:1px solid transparent;
  border-radius:10px;
  color:#e2e8f0;
  background:transparent;
  text-align:left;
  cursor:pointer;
}
.roast-history-item:hover,
.roast-history-item.active{
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);
}
.roast-history-item span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  overflow-wrap:normal;
  font-weight:850;
}
.roast-history-item small{color:#a5b4fc;font-weight:700}
.roast-sidebar-actions{
  display:grid;
  gap:8px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.16);
}
.roast-sidebar-actions .btn{width:100%}
.roast-clear-all{
  min-height:36px;
  border:0;
  color:#fecdd3;
  background:transparent;
  text-decoration:underline;
  font:inherit;
  font-weight:800;
  cursor:pointer;
}
.roast-chat-main{
  min-width:0;
  display:grid;
  grid-template-rows:auto auto auto auto auto;
  align-content:start;
  overflow:visible;
  background:
    linear-gradient(135deg,rgba(168,85,247,.06),transparent 42%),
    var(--card);
}
.roast-chat-header,
.roast-chat-status,
.roast-composer,
.roast-disclaimer{
  min-width:0;
}
.roast-chat-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 20px;
  border-bottom:1px solid var(--border);
}
.roast-chat-header > div{min-width:0}
.roast-chat-header h3{margin:5px 0 3px;font-size:1.35rem}
.roast-chat-header p{margin:0;color:var(--muted);font-size:.9rem}
.roast-online{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:#0f766e;
  font-size:.78rem;
  font-weight:850;
}
.roast-online i{width:8px;height:8px;border-radius:50%;background:#14b8a6;box-shadow:0 0 0 4px rgba(20,184,166,.14)}
[data-theme="dark"] .roast-online{color:#5eead4}
.roast-tone-label{
  width:180px;
  flex:0 0 180px;
  margin:0;
  font-size:.78rem;
}
.roast-tone-label select{margin-top:4px;padding:8px 10px}
.roast-chat-messages{
  min-width:0;
  height:clamp(500px,60vh,650px);
  max-height:60vh;
  overflow-y:auto;
  overscroll-behavior:contain;
  padding:24px clamp(14px,3vw,30px);
  scroll-behavior:smooth;
}
.roast-empty-state{
  min-height:100%;
  display:grid;
  place-content:center;
  justify-items:center;
  gap:10px;
  padding:24px;
  text-align:center;
}
.roast-empty-icon{width:68px;height:68px;border-radius:20px;font-size:1.8rem;transform:rotate(-4deg)}
.roast-empty-state h3{max-width:520px;margin:4px 0 0;font-size:clamp(1.35rem,3vw,1.8rem)}
.roast-empty-state p{margin:0;color:var(--muted);line-height:1.6}
.roast-suggestions{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-top:8px;
}
.roast-suggestions button,
.roast-reply-actions button{
  min-height:34px;
  border:1px solid var(--border);
  border-radius:999px;
  padding:7px 11px;
  color:var(--text);
  background:var(--card);
  font:inherit;
  font-size:.82rem;
  font-weight:800;
  cursor:pointer;
}
.roast-suggestions button:hover,
.roast-reply-actions button:hover{border-color:#a855f7;color:#7e22ce}
[data-theme="dark"] .roast-suggestions button:hover,
[data-theme="dark"] .roast-reply-actions button:hover{color:#e9d5ff}
.roast-message{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:0 0 18px;
  animation:roastMessageIn .25s ease both;
}
.roast-message-user{flex-direction:row-reverse}
.roast-message-avatar{
  width:38px;
  height:38px;
  border-radius:12px;
  font-size:.76rem;
}
.roast-message-user .roast-message-avatar{
  color:#334155;
  background:linear-gradient(135deg,#bae6fd,#99f6e4);
  box-shadow:none;
}
.roast-message-content{
  min-width:0;
  max-width:min(78%,680px);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:5px;
}
.roast-message-user .roast-message-content{align-items:flex-end}
.roast-message-name{color:var(--muted);font-size:.76rem;font-weight:850}
.roast-bubble{
  max-width:100%;
  padding:11px 14px;
  border:1px solid var(--border);
  border-radius:6px 17px 17px 17px;
  color:var(--text);
  background:var(--soft);
  line-height:1.6;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
.roast-message-user .roast-bubble{
  border:0;
  border-radius:17px 6px 17px 17px;
  color:#fff;
  background:linear-gradient(135deg,#7c3aed,#db2777);
}
.roast-reply-actions{display:flex;flex-wrap:wrap;gap:6px}
.roast-reply-actions button{min-height:30px;padding:5px 10px;background:transparent}
.roast-typing{display:flex;align-items:center;gap:5px;min-width:64px;min-height:42px}
.roast-typing i{width:8px;height:8px;border-radius:50%;background:#a855f7;animation:roastTyping 1s ease-in-out infinite}
.roast-typing i:nth-child(2){animation-delay:.15s}
.roast-typing i:nth-child(3){animation-delay:.3s}
.roast-chat-status{
  margin:0 20px 12px;
  padding:11px 13px;
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text);
  background:var(--soft);
  font-weight:800;
  line-height:1.45;
}
.roast-chat-status.is-error{color:#991b1b;border-color:#fca5a5;background:#fef2f2}
.roast-chat-status.is-success{color:#0f766e;border-color:#5eead4;background:#ecfdf5}
[data-theme="dark"] .roast-chat-status.is-error{color:#fecaca;border-color:#7f1d1d;background:rgba(127,29,29,.3)}
[data-theme="dark"] .roast-chat-status.is-success{color:#99f6e4;border-color:#115e59;background:rgba(6,78,59,.3)}
.roast-composer{
  margin:0 20px;
  overflow:visible;
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--card);
  box-shadow:0 12px 30px rgba(15,23,42,.09);
}
.roast-composer textarea{
  min-height:80px;
  max-height:180px;
  resize:vertical;
  border:0;
  border-radius:0;
  background:transparent;
  line-height:1.55;
}
.roast-composer textarea:focus{outline:2px solid transparent}
.roast-composer:focus-within{border-color:#a855f7;box-shadow:0 0 0 3px rgba(168,85,247,.12)}
.roast-composer-footer{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-top:1px solid var(--border);
}
.roast-composer-footer > span{color:var(--muted);font-size:.75rem;font-weight:750}
.roast-enter-hint{flex:1 1 auto;text-align:right}
.roast-send{min-width:88px;min-height:38px;padding:8px 14px}
.tool-heading-icon{
  display:inline-grid;
  place-items:center;
  width:1.25em;
  height:1.25em;
  margin-inline-end:.35em;
  vertical-align:-0.18em;
}
.tool-heading-icon svg{
  width:100%;
  height:100%;
}
.roast-disclaimer{
  margin:10px 20px 16px;
  color:var(--muted);
  text-align:center;
  font-size:.78rem;
  line-height:1.45;
}
.roast-chat-app button:disabled,
.roast-chat-app textarea:disabled,
.roast-chat-app select:disabled{cursor:not-allowed;opacity:.62}
@keyframes roastMessageIn{
  from{opacity:0;transform:translateY(7px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes roastTyping{
  0%,60%,100%{transform:translateY(0);opacity:.45}
  30%{transform:translateY(-5px);opacity:1}
}
@media (max-width:760px){
  .roast-chat-app{
    grid-template-columns:1fr;
  }
  .roast-chat-sidebar{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    padding:13px;
    border-bottom:1px solid rgba(255,255,255,.18);
  }
  .roast-sidebar-heading{grid-column:1}
  .roast-new-chat{grid-column:2;grid-row:1;width:auto;white-space:nowrap}
  .roast-chat-list{
    grid-column:1/-1;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    overflow:visible;
    padding:2px 0;
  }
  .roast-history-item{width:100%}
  .roast-sidebar-actions{
    grid-column:1/-1;
    grid-template-columns:1fr 1fr;
    padding-top:8px;
  }
  .roast-chat-main{grid-template-rows:auto auto auto auto auto}
  .roast-chat-messages{height:60vh;max-height:60vh}
}
@media (max-width:520px){
  body[data-expanded-tool="ai-roast-generator"] .container{padding-inline:10px}
  body[data-expanded-tool="ai-roast-generator"] .tool-workspace{padding:6px}
  .roast-chat-app{
    border-radius:16px;
  }
  .roast-chat-header{align-items:stretch;flex-direction:column;padding:14px}
  .roast-tone-label{width:100%;flex-basis:auto}
  .roast-chat-messages{padding:18px 12px}
  .roast-message-content{max-width:84%}
  .roast-message-avatar{width:34px;height:34px;border-radius:10px}
  .roast-chat-status,.roast-composer{margin-inline:12px}
  .roast-composer-footer{flex-wrap:wrap}
  .roast-enter-hint{display:none}
  .roast-send{margin-left:auto}
  .roast-disclaimer{margin-inline:12px}
  .roast-sidebar-actions{grid-template-columns:1fr}
  .roast-chat-list{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .roast-message,
  .roast-typing i{animation:none!important}
  .roast-chat-messages{scroll-behavior:auto}
}
