:root {
  --bg:#080810; --surface:#111118; --surface2:#1a1a26; --surface3:#22222f;
  --border:rgba(255,255,255,0.06); --border2:rgba(255,255,255,0.12);
  --accent:#f0e040; --accent-dim:rgba(240,224,64,0.12); --accent-mid:rgba(240,224,64,0.3);
  --bad:#ff5c5c; --good:#5cffb0; --text:#eeeef8;
  --muted:rgba(238,238,248,0.4); --muted2:rgba(238,238,248,0.2);
  --font-head:'Syne',sans-serif; --font-body:'DM Sans',sans-serif;
  --speed:#ff6b35; --trivia:#8b5cf6; --sil:#00d4ff; --don:#f0e040;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;}
body::before{content:'';position:fixed;top:-250px;left:50%;transform:translateX(-50%);width:700px;height:700px;background:radial-gradient(ellipse,rgba(240,224,64,0.07) 0%,transparent 65%);pointer-events:none;z-index:0;}

/* HEADER */
header{width:100%;max-width:500px;padding:26px 22px 0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:2;}
.logo{font-family:var(--font-head);font-size:20px;font-weight:800;letter-spacing:2px;}
.logo em{color:var(--accent);font-style:normal;}
.header-right{display:flex;align-items:center;gap:10px;}
.streak-pill{display:flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border2);border-radius:100px;padding:5px 13px;font-size:13px;font-weight:500;color:var(--accent);}
.score-pill{display:flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:100px;padding:5px 13px;font-size:13px;color:var(--muted);}
.score-pill strong{color:var(--text);font-weight:600;}

main{width:100%;max-width:500px;padding:18px 18px 48px;display:flex;flex-direction:column;gap:14px;position:relative;z-index:1;}
.date-line{text-align:center;font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted2);}

/* PUZZLE CARD */
.puzzle-card{background:var(--surface);border:1px solid var(--border);border-radius:26px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,0.5);}

/* IMAGE STAGE */
.image-stage{position:relative;width:100%;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--surface2);user-select:none;}
#portraitCanvas,#silCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;filter:brightness(0.82) contrast(0.9);transition:filter 0.9s cubic-bezier(0.16,1,0.3,1),transform 1.3s cubic-bezier(0.16,1,0.3,1);transform-origin:var(--ox,50%) var(--oy,38%);}
#silCanvas{display:none;}
.celeb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;display:block;opacity:0;filter:brightness(0.82) contrast(0.9);transition:opacity 0.5s,filter 0.9s cubic-bezier(0.16,1,0.3,1),transform 1.3s cubic-bezier(0.16,1,0.3,1);transform-origin:var(--ox,50%) var(--oy,38%);}
.celeb-img.loaded{opacity:1;}
#maskCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none;filter:none !important;}
.stage-ui{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:14px;pointer-events:none;}
.stage-top{display:flex;justify-content:space-between;align-items:flex-start;}
.cat-chip{background:rgba(0,0,0,0.5);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);border-radius:100px;padding:4px 12px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.6);}
.zoom-badge{background:rgba(0,0,0,0.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);border-radius:100px;padding:4px 12px;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;}
.stage-bottom{display:flex;flex-direction:column;gap:8px;}
.hint-bubble{align-self:flex-start;background:rgba(240,224,64,0.13);border:1px solid rgba(240,224,64,0.28);backdrop-filter:blur(8px);border-radius:100px;padding:5px 14px;font-size:12px;font-weight:500;color:var(--accent);opacity:0;transform:translateY(8px);transition:opacity 0.5s,transform 0.5s;max-width:90%;}
.hint-bubble.show{opacity:1;transform:translateY(0);}
.tap-nudge{align-self:center;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.3);animation:breathe 2.5s ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.3}50%{opacity:.65}}

/* POINTS BANNER */
.points-banner{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--surface2);}
.pts-label{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.pts-value{font-family:var(--font-head);font-size:24px;font-weight:800;color:var(--accent);transition:all 0.3s;}
.pts-value.drop{animation:ptsDrop 0.45s ease forwards;}
@keyframes ptsDrop{0%{transform:scale(1.35);color:var(--bad)}100%{transform:scale(1);color:var(--accent)}}

/* PROGRESS DOTS */
.progress-row{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;}
.pdot{width:9px;height:9px;border-radius:50%;background:var(--surface3);border:1px solid var(--border2);transition:all 0.35s cubic-bezier(0.16,1,0.3,1);}
.pdot.cur{background:var(--accent);border-color:var(--accent);transform:scale(1.3);box-shadow:0 0 8px rgba(240,224,64,.5);}
.pdot.past{background:var(--accent-mid);border-color:var(--accent-mid);}
.pdot.bad{background:rgba(255,92,92,.4);border-color:rgba(255,92,92,.4);}

/* CHOICE GRID */
.choice-label{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:0 18px 8px;}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 12px;}
.reveal-btn{display:block;width:calc(100% - 32px);margin:0 16px 18px;background:none;border:1.5px solid var(--border2);border-radius:14px;padding:13px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;letter-spacing:0.3px;transition:border-color 0.2s,color 0.2s;}
.reveal-btn:hover:not(:disabled){border-color:var(--accent-mid);color:var(--text);}
.reveal-btn:disabled{opacity:0.3;cursor:not-allowed;}
@keyframes popIn{from{opacity:0;transform:scale(.95) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ═══ BONUS ROUND OVERLAY ═══════════════════════════════════════════════════ */
.bonus-overlay{
  position:fixed;inset:0;z-index:150;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:0;
  opacity:0;pointer-events:none;transition:opacity 0.4s;
  overflow-y:auto;
}
.bonus-overlay.show{opacity:1;pointer-events:all;}

/* Bonus type themes */
.bonus-overlay.speed-theme{background:rgba(8,8,16,0.97);}
.bonus-overlay.trivia-theme{background:rgba(8,8,16,0.97);}
.bonus-overlay.sil-theme{background:rgba(8,8,16,0.97);}
.bonus-overlay.don-theme{background:rgba(8,8,16,0.97);}

.bonus-inner{
  width:100%;max-width:500px;
  display:flex;flex-direction:column;align-items:center;
  gap:0; padding:0 0 48px;
  transform:translateY(30px);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);
}
.bonus-overlay.show .bonus-inner{transform:translateY(0);}

/* BONUS HEADER BAR */
.bonus-header{
  width:100%;padding:20px 22px 16px;
  display:flex;align-items:center;justify-content:space-between;
}
.bonus-type-badge{
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;
}
.speed-badge{background:rgba(255,107,53,0.2);color:var(--speed);border:1px solid rgba(255,107,53,0.4);}
.trivia-badge{background:rgba(139,92,246,0.2);color:var(--trivia);border:1px solid rgba(139,92,246,0.4);}
.sil-badge{background:rgba(0,212,255,0.15);color:var(--sil);border:1px solid rgba(0,212,255,0.35);}
.don-badge{background:rgba(240,224,64,0.15);color:var(--don);border:1px solid rgba(240,224,64,0.35);}

.bonus-pts-live{
  font-family:var(--font-head);font-size:32px;font-weight:800;
  font-variant-numeric:tabular-nums;
  transition:color 0.3s;
}
.bonus-pts-live.hot{color:var(--good);}
.bonus-pts-live.warm{color:var(--accent);}
.bonus-pts-live.cold{color:var(--bad);}

/* BONUS IMAGE STAGE */
.bonus-stage{
  width:100%;aspect-ratio:1;
  position:relative;overflow:hidden;
  background:var(--surface2);
}
#bonusCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;filter:brightness(0.82) contrast(0.9);}
#bonusMaskCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none;filter:none !important;}

/* Speed round expanding ring indicator */
.speed-ring{
  position:absolute;inset:0;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
.speed-ring-inner{
  border:2px solid rgba(255,107,53,0.5);
  border-radius:50%;
  animation:ringPulse 1s ease-in-out infinite;
}
@keyframes ringPulse{0%,100%{opacity:0.5;transform:scale(1);}50%{opacity:1;transform:scale(1.05);}}

/* BONUS FOOTER */
.bonus-footer{
  width:100%;padding:16px 18px 0;
  display:flex;flex-direction:column;gap:12px;
}
.bonus-instruction{
  text-align:center;font-size:13px;color:var(--muted);
  letter-spacing:0.3px;line-height:1.5;
}
.bonus-instruction strong{color:var(--text);}

/* MULTIPLE CHOICE GRID */
.mc-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px;width:100%;
}
.mc-btn{
  background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:16px;padding:16px 12px;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  color:var(--text);cursor:pointer;
  text-align:center;line-height:1.3;
  transition:all 0.15s;
  -webkit-tap-highlight-color:transparent;
}
.mc-btn:hover{background:var(--surface3);border-color:var(--accent-mid);}
.mc-btn:active{transform:scale(0.96);}
.mc-btn.correct{background:rgba(92,255,176,0.15);border-color:var(--good);color:var(--good);}
.mc-btn.wrong{background:rgba(255,92,92,0.12);border-color:var(--bad);color:var(--bad);}
.mc-btn.reveal{background:rgba(92,255,176,0.08);border-color:rgba(92,255,176,0.3);}
.mc-btn:disabled{opacity:0.5;cursor:not-allowed;}

/* TRIVIA QUESTION */
.trivia-q{
  font-family:var(--font-head);font-size:20px;font-weight:700;
  text-align:center;line-height:1.4;
  padding:16px 20px;
  white-space:normal;word-wrap:break-word;overflow:visible;width:100%;
}
.trivia-progress{
  display:flex;gap:6px;justify-content:center;
}
.tprog-dot{
  width:28px;height:4px;border-radius:2px;
  background:var(--surface3);transition:background 0.3s;
}
.tprog-dot.done{background:var(--good);}
.tprog-dot.active{background:var(--accent);}
.tprog-dot.miss{background:var(--bad);}

/* SILHOUETTE label */
.sil-label{
  font-family:var(--font-head);font-size:22px;font-weight:800;
  text-align:center;color:var(--sil);letter-spacing:1px;
}
.sil-sub{font-size:12px;color:var(--muted);text-align:center;letter-spacing:1px;text-transform:uppercase;}

/* DON — double or nothing */
.don-stakes{
  text-align:center;
  font-family:var(--font-head);font-size:14px;font-weight:600;
  color:var(--muted);letter-spacing:0.5px;
}
.don-stakes b{color:var(--accent);}
.don-stakes s{color:var(--bad);}

/* BONUS RESULT */
.bonus-result-card{
  background:var(--surface);border:1px solid var(--border2);
  border-radius:24px;padding:28px 24px;
  width:calc(100% - 36px);margin:16px 18px 0;
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;
  animation:popIn 0.4s cubic-bezier(0.16,1,0.3,1);
}
.bonus-result-icon{font-size:48px;line-height:1;}
.bonus-result-title{font-family:var(--font-head);font-size:26px;font-weight:800;}
.bonus-result-title.win{color:var(--good);}
.bonus-result-title.lose{color:var(--bad);}
.bonus-result-pts{font-size:15px;color:var(--muted);}
.bonus-result-pts b{color:var(--accent);}
.bonus-continue-btn{
  width:100%;background:var(--accent);color:#080810;
  border:none;border-radius:14px;padding:15px;
  font-family:var(--font-head);font-size:16px;font-weight:700;
  cursor:pointer;transition:transform 0.15s,box-shadow 0.2s;
}
.bonus-continue-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(240,224,64,.3);}

/* BONUS TRIGGER TOAST */
.bonus-trigger{
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0.8);
  background:var(--surface);border:2px solid var(--accent);
  border-radius:24px;padding:28px 32px;
  text-align:center;z-index:200;
  opacity:0;pointer-events:none;
  transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 0 60px rgba(240,224,64,0.3);
}
.bonus-trigger.pop{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:all;}
.bt-icon{font-size:52px;line-height:1;margin-bottom:8px;}
.bt-title{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--accent);margin-bottom:4px;}
.bt-sub{font-size:13px;color:var(--muted);}
.bt-start{
  margin-top:16px;width:100%;
  background:var(--accent);color:#080810;
  border:none;border-radius:12px;padding:14px;
  font-family:var(--font-head);font-size:15px;font-weight:700;cursor:pointer;
}
.bt-dismiss{
  margin-top:8px;width:100%;
  background:none;color:var(--muted);
  border:none;font-family:var(--font-body);font-size:13px;cursor:pointer;padding:8px;
}

/* RESULT OVERLAY */
.result-overlay{position:fixed;inset:0;background:rgba(8,8,16,.88);backdrop-filter:blur(16px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.45s;}
.result-overlay.session-mode{align-items:flex-start;overflow-y:auto;padding-top:20px;}
.result-overlay.show{opacity:1;pointer-events:all;}
.result-card{background:var(--surface);border:1px solid var(--border2);border-radius:28px;padding:34px 28px 28px;width:100%;max-width:380px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px;transform:scale(0.9) translateY(24px);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);box-shadow:0 40px 80px rgba(0,0,0,.6);}
.result-overlay.show .result-card{transform:scale(1) translateY(0);}
.result-icon{font-size:54px;line-height:1;}
.result-head{font-family:var(--font-head);font-size:30px;font-weight:800;letter-spacing:-.5px;line-height:1.1;}
.result-head.win{color:var(--good);}
.result-head.lose{color:var(--bad);}
.result-sub{font-size:15px;color:var(--muted);line-height:1.55;max-width:280px;}
.result-sub strong{color:var(--text);}
.result-sub b{color:var(--accent);}
.result-stats{display:flex;gap:1px;background:var(--border);border-radius:16px;overflow:hidden;width:100%;}
.rstat{flex:1;background:var(--surface2);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:3px;}
.rstat .v{font-family:var(--font-head);font-size:24px;font-weight:800;}
.rstat .l{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.share-btn{width:100%;background:var(--accent);color:#080810;border:none;border-radius:14px;padding:16px;font-family:var(--font-head);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform 0.15s,box-shadow 0.2s;}
.share-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(240,224,64,.32);}
.next-up{font-size:12px;color:var(--muted2);}
.next-up .cd{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums;}

/* CONFETTI */
.confetti-stage{position:fixed;inset:0;pointer-events:none;z-index:200;overflow:hidden;}
.cp{position:absolute;top:-14px;border-radius:2px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(110vh) rotate(800deg);opacity:0;}}

/* TOAST */
.toast{position:fixed;top:22px;left:50%;transform:translateX(-50%) translateY(-70px);background:var(--text);color:var(--bg);border-radius:100px;padding:9px 22px;font-size:13px;font-weight:600;z-index:300;white-space:nowrap;transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);box-shadow:0 4px 20px rgba(0,0,0,.3);}
.toast.show{transform:translateX(-50%) translateY(0);}

/* LOADER */
.loader{position:fixed;inset:0;background:var(--bg);z-index:400;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity 0.7s;}
.loader.out{opacity:0;pointer-events:none;}
.loader-logo{font-family:var(--font-head);font-size:38px;font-weight:800;letter-spacing:2px;}
.loader-logo em{color:var(--accent);font-style:normal;}
.loader-sub{font-size:11px;color:var(--muted);letter-spacing:2.5px;text-transform:uppercase;}
.loader-track{width:100px;height:2px;background:var(--surface2);border-radius:10px;overflow:hidden;}
.loader-fill{height:100%;background:var(--accent);border-radius:10px;animation:lfill 1.4s cubic-bezier(0.16,1,0.3,1) forwards;}
@keyframes lfill{from{width:0}to{width:100%}}

/* ═══ SESSION DOTS (puzzle 1/2/3 indicator) ═══════════════════════════════ */
.session-dots{
  display:flex;align-items:center;justify-content:center;
  gap:10px;padding:6px 0 2px;
}
.sdot{
  width:10px;height:10px;border-radius:50%;
  background:var(--surface3);border:1px solid var(--border2);
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
}
.sdot-cur{
  background:var(--accent);border-color:var(--accent);
  transform:scale(1.25);box-shadow:0 0 8px rgba(240,224,64,0.4);
}
.sdot-won{background:var(--good);border-color:var(--good);}
.sdot-lost{background:rgba(255,92,92,0.5);border-color:rgba(255,92,92,0.5);}

/* ═══ NEXT PUZZLE BUTTON ═════════════════════════════════════════════════ */
.next-puzzle-btn{
  background:var(--accent);color:#080810;
  border:none;border-radius:12px;padding:13px 28px;
  font-family:var(--font-head);font-size:15px;font-weight:700;
  cursor:pointer;transition:transform 0.15s,box-shadow 0.2s;
}
.next-puzzle-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(240,224,64,0.3);
}

/* ═══ SESSION SUMMARY ════════════════════════════════════════════════════ */
.ss-list{
  width:100%;display:flex;flex-direction:column;gap:6px;text-align:left;
}
.ssrow{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;padding:9px 13px;
  background:var(--surface2);border-radius:10px;
  color:var(--muted);
}
.ssrow span:first-child{color:var(--text);}
.sspts{color:var(--accent);font-weight:600;font-family:var(--font-head);font-size:14px;}

/* ═══ SHARE SHEET ════════════════════════════════════════════════════════ */
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.share-backdrop{position:fixed;inset:0;z-index:499;background:rgba(0,0,0,0.7);}
.share-sheet{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:500px;
  background:var(--surface);border-radius:24px 24px 0 0;
  padding:24px;z-index:500;
  animation:slideUp 0.35s cubic-bezier(0.16,1,0.3,1);
}
.share-sheet-inner{display:flex;flex-direction:column;gap:12px;}
.share-sheet-header{display:flex;align-items:center;justify-content:flex-end;margin-bottom:4px;}
.share-sheet-title{font-family:var(--font-head);font-size:18px;font-weight:700;margin-bottom:4px;}
.share-sheet-close{background:var(--surface2);border:none;color:var(--muted);border-radius:50%;width:32px;height:32px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.share-canvas-wrap{width:100%;display:flex;justify-content:center;}
.share-canvas-wrap canvas{width:100%;border-radius:14px;border:1px solid var(--border);filter:none !important;}
#shareCanvas,#shareCanvasEl{filter:none !important;}
.share-icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.share-icon-grid-2{grid-template-columns:repeat(2,1fr);}
.share-icon-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 12px;background:var(--surface2);border:1px solid var(--border2);border-radius:14px;cursor:pointer;transition:background 0.15s;}
.share-icon-btn:hover{background:var(--surface3);}
.sib-emoji{font-size:18px;line-height:1;}
.sib-label{font-family:var(--font-body);font-size:12px;color:var(--muted);}
.share-full-btn{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:14px 20px;font-family:var(--font-body);font-size:15px;color:var(--text);display:flex;align-items:center;gap:12px;cursor:pointer;transition:background 0.15s;}
.share-full-btn:hover{background:var(--surface3);}
.save-image-btn{
  width:100%;background:transparent;border:1px solid var(--accent-mid);
  border-radius:14px;padding:14px 20px;
  font-family:var(--font-body);font-size:15px;color:var(--accent);
  display:flex;align-items:center;gap:12px;
  cursor:pointer;transition:background 0.15s;margin-top:4px;
}
.save-image-btn:hover{background:var(--accent-dim);}

/* ═══ UPSELL CARDS ═══════════════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.upsell-cards{display:flex;flex-direction:column;gap:12px;margin-top:20px;width:100%;}
.upsell-card{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) both;}
.upsell-card:nth-child(1){animation-delay:0.05s;border-color:var(--accent-mid);}
.upsell-card:nth-child(2){animation-delay:0.12s;}
.upsell-card:nth-child(3){animation-delay:0.19s;border:2px solid var(--accent);}
.upsell-card-emoji{font-size:40px;line-height:1;}
.upsell-card-title{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--text);}
.upsell-card-title.upsell-accent{color:var(--accent);font-size:18px;}
.upsell-card-sub{font-size:13px;color:var(--muted);line-height:1.5;}
.upsell-card--arcade{background:linear-gradient(135deg,var(--surface2) 0%,color-mix(in srgb,var(--accent) 5%,var(--surface2)) 100%);}
.pack-thumb-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;width:100%;}
.pack-thumb-wrap{position:relative;aspect-ratio:1;}
.pack-thumb{width:100%;height:100%;border-radius:12px;object-fit:cover;opacity:0.7;display:block;}
.pack-thumb-lock{position:absolute;bottom:5px;right:6px;font-size:14px;line-height:1;}
.upsell-cta-btn{width:100%;background:transparent;border:1.5px solid var(--accent);border-radius:12px;padding:11px 24px;font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--accent);cursor:pointer;transition:background 0.15s;}
.upsell-cta-btn:hover{background:var(--accent-dim);}
.upsell-email-input{width:100%;background:var(--surface3);border:1px solid var(--border2);border-radius:10px;padding:12px 16px;font-family:var(--font-body);font-size:15px;color:var(--text);outline:none;transition:border-color 0.2s;}
.upsell-email-input::placeholder{color:var(--muted);}
.upsell-email-input:focus{border-color:var(--accent-mid);}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.upsell-email-input.shake{animation:shake 0.4s;}
.upsell-notify-btn{width:100%;background:var(--accent);color:#080810;border:none;border-radius:12px;padding:14px;font-family:var(--font-head);font-size:15px;font-weight:700;cursor:pointer;transition:transform 0.15s,box-shadow 0.2s;}
.upsell-notify-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(240,224,64,0.3);}
.upsell-thanks{display:flex;flex-direction:column;align-items:center;gap:8px;}
.upsell-thanks-title{color:var(--good);font-family:var(--font-head);font-size:20px;font-weight:700;}
.upsell-thanks-sub{font-size:13px;color:var(--muted);line-height:1.5;text-align:center;}
