/* ═══════════════════════════════════════════════════
   PICKY EATERS — style.css
   Instrument Serif + Inter · Clean startup aesthetic
═══════════════════════════════════════════════════ */

:root {
  --bg:        #0c0c10;
  --surface:   #141418;
  --card:      #1c1c22;
  --card-h:    #22222a;
  --border:    rgba(255,255,255,0.08);
  --text:      #f0f0f5;
  --muted:     rgba(240,240,245,0.45);
  --accent:    #6c63ff;
  --accent2:   #a78bfa;
  --glow:      0 0 32px rgba(108,99,255,0.25);
  --radius:    16px;
  --radius-sm: 10px;
  --max-w:     440px;
  --fd:        'Playfair Display', Georgia, serif;
  --fb:        'Inter', sans-serif;
}
/* MORNING — bright warm sunrise */
body.theme-morning {
  --bg:#fff8f0;--surface:#fff3e6;--card:#ffffff;--card-h:#fdf6ed;
  --border:rgba(180,100,20,0.1);--text:#1c1008;--muted:rgba(28,16,8,0.45);
  --accent:#d4600a;--accent2:#f0882a;--glow:0 0 40px rgba(212,96,10,0.2);
}
/* AFTERNOON — slightly dimmed cool blue-white */
body.theme-afternoon {
  --bg:#f0f2fa;--surface:#e8eaf6;--card:#ffffff;--card-h:#eceefa;
  --border:rgba(60,80,180,0.1);--text:#0f1525;--muted:rgba(15,21,37,0.45);
  --accent:#3730a3;--accent2:#4f46e5;--glow:0 0 40px rgba(55,48,163,0.15);
}
/* EVENING — warm purple dusk */
body.theme-evening {
  --bg:#130a1a;--surface:#1c1025;--card:#22152e;--card-h:#2a1a38;
  --border:rgba(200,130,255,0.12);--text:#f0e8ff;--muted:rgba(240,232,255,0.4);
  --accent:#b06ef3;--accent2:#d946ef;--glow:0 0 40px rgba(176,110,243,0.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--fb);-webkit-font-smoothing:antialiased;overflow:hidden;transition:background 0.6s}

/* AMBIENT */
.ambient-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(100px)}
.orb-1{width:55vw;height:55vw;top:-20%;left:-15%;background:rgba(108,99,255,0.15);animation:drift1 20s ease-in-out infinite alternate}
.orb-2{width:45vw;height:45vw;bottom:-15%;right:-10%;background:rgba(167,139,250,0.1);animation:drift2 25s ease-in-out infinite alternate}
@keyframes drift1{to{transform:translate(8%,14%)}}
@keyframes drift2{to{transform:translate(-10%,-8%)}}

/* NAV */
.top-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;pointer-events:none;opacity:0;transition:opacity 0.3s}
.top-nav.visible{opacity:1;pointer-events:all}
.nav-logo{font-family:var(--fb);font-size:16px;color:var(--text)}
.nav-actions{display:flex;gap:8px}
.nav-btn{padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:99px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--fb);transition:all 0.2s;letter-spacing:0.2px}
.nav-btn:hover{color:var(--text);border-color:var(--accent)}
.nav-btn-avatar{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-color:transparent;font-family:var(--fb);font-style:normal;font-weight:600}

/* SCREENS */
.screen{display:none;position:fixed;inset:0;z-index:10;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}
.screen.active{display:flex;animation:screenIn 0.3s ease}
@keyframes screenIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
#picksScreen,#foodScreen,#historyScreen,#profileScreen,#authScreen{justify-content:flex-start;padding-top:68px;padding-bottom:40px}
#questionScreen{justify-content:flex-start;padding:56px 20px 40px;align-items:center}

/* SHARED */
.hidden{display:none!important}
.btn-primary{width:100%;padding:17px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:var(--radius);font-family:var(--fb);font-size:16px;font-weight:600;cursor:pointer;letter-spacing:0.2px;box-shadow:var(--glow);transition:transform 0.15s,opacity 0.15s}
.btn-primary:hover{transform:translateY(-1px);opacity:0.92}
.btn-primary:active{transform:scale(0.98)}
.btn-ghost{background:none;border:1px solid var(--border);color:var(--muted);padding:12px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;font-family:var(--fb);transition:all 0.2s}
.btn-ghost:hover{border-color:var(--accent);color:var(--text)}
.btn-back{background:none;border:none;color:var(--muted);font-size:14px;font-weight:500;cursor:pointer;padding:8px 0;margin-bottom:12px;align-self:flex-start;font-family:var(--fb);transition:color 0.2s}
.btn-back:hover{color:var(--text)}
.btn-text-sm{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;font-family:var(--fb);padding:8px;transition:color 0.2s}
.btn-text-sm:hover{color:var(--text)}
.btn-danger{width:100%;padding:15px;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.25);color:#f87171;border-radius:var(--radius-sm);font-family:var(--fb);font-size:14px;cursor:pointer;transition:all 0.2s}
.btn-danger:hover{background:rgba(239,68,68,0.18)}
.page-inner{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;gap:14px;padding-bottom:40px}
.page-title{font-family:var(--fd);font-size:28px;font-weight:700;margin-bottom:4px}
.empty-state{color:var(--muted);font-size:14px;text-align:center;padding:32px 0}

/* PROGRESS */
.progress-track{width:100%;height:3px;background:rgba(255,255,255,0.12);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:99px;width:0%;transition:width 0.5s cubic-bezier(0.4,0,0.2,1)}

/* SPLASH */
.splash-inner{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}
.time-badge{font-size:13px;font-weight:500;color:var(--muted);letter-spacing:0.3px}
.splash-title{font-family:var(--fd);font-size:clamp(46px,13vw,68px);font-weight:900;line-height:0.95;letter-spacing:-2px;color:var(--text)}
.splash-accent{color:var(--accent);font-weight:900}
.splash-sub{font-size:16px;color:var(--muted);line-height:1.5;font-weight:400}
.auth-row{display:flex;align-items:center;gap:10px}
.auth-sep{color:var(--border)}

/* AUTH */
.auth-inner{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;gap:16px}
.auth-toggle{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px;gap:4px}
.auth-tab{flex:1;padding:11px;border:none;background:none;border-radius:calc(var(--radius) - 4px);font-family:var(--fb);font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;transition:all 0.2s}
.auth-tab.active{background:var(--accent);color:#fff}
.auth-form{display:flex;flex-direction:column;gap:13px}
.field-group{display:flex;flex-direction:column;gap:5px}
.field-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--muted)}
.field-group input{width:100%;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--fb);font-size:15px;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.field-group input:focus{border-color:var(--accent)}
.field-group input::placeholder{color:var(--muted)}
.auth-error{color:#f87171;font-size:13px;min-height:16px}
.auth-note{font-size:12px;color:var(--muted);text-align:center}

/* LOCATION */
.loc-inner{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;gap:16px;padding-bottom:40px}
.screen-step{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}
.screen-title{font-family:var(--fd);font-size:clamp(26px,7vw,34px);font-weight:700;line-height:1.05;letter-spacing:-0.5px}
.screen-sub{font-size:15px;color:var(--muted)}
.loc-method{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.loc-method-btn{padding:18px 14px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--fb);cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:4px;transition:all 0.2s}
.loc-method-btn.active{border-color:var(--accent);background:var(--card-h)}
.loc-method-btn:hover:not(.active){border-color:rgba(108,99,255,0.4)}
.lmb-title{font-size:14px;font-weight:600}
.lmb-sub{font-size:12px;color:var(--muted)}
.zip-input{display:flex;flex-direction:column;gap:6px}
.zip-input input{width:100%;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:18px;text-align:center;letter-spacing:4px;outline:none;-webkit-appearance:none;font-family:var(--fb);transition:border-color 0.2s}
.zip-input input:focus{border-color:var(--accent)}
.zip-status{font-size:13px;color:var(--muted);text-align:center;min-height:16px}
.distance-section{display:flex;flex-direction:column;gap:10px}
.distance-label{font-size:14px;color:var(--muted)}
.distance-label strong{color:var(--text);font-weight:600}
.distance-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:99px;outline:none;cursor:pointer}
.distance-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px rgba(108,99,255,0.4);cursor:pointer}
.slider-ticks{display:flex;justify-content:space-between}
.slider-ticks span{font-size:10px;color:var(--muted);font-weight:500}
.map-preview{width:100%;height:180px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);position:relative;background:var(--card)}
.map-fake{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:28px 28px;opacity:0.5}
.map-radius-ring{position:absolute;border-radius:50%;border:1.5px solid var(--accent);background:rgba(108,99,255,0.08);transition:all 0.4s ease;width:80px;height:80px}
.map-pin{position:absolute;font-size:14px;color:var(--accent);z-index:2}
.map-label{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--border);padding:4px 12px;border-radius:99px;font-size:11px;color:var(--muted);white-space:nowrap;font-weight:600}

/* QUESTIONS */
.q-wrap{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;gap:0;margin:0 auto}
.q-header{position:sticky;top:0;background:transparent;padding:16px 0 12px;z-index:20;width:100%;max-width:440px;align-self:center}
.q-header-row{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.q-counter{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.q-body{width:100%;max-width:440px;display:flex;flex-direction:column;padding:32px 0 60px;gap:24px}
.q-body.slide-in{animation:slideIn 0.3s ease}
.q-body.slide-out{animation:slideOut 0.22s ease forwards}
@keyframes slideIn{from{transform:translateX(32px);opacity:0}to{transform:none;opacity:1}}
@keyframes slideOut{from{transform:none;opacity:1}to{transform:translateX(-32px);opacity:0}}
.q-question{font-family:var(--fd);font-size:clamp(24px,6.5vw,30px);font-weight:700;line-height:1.15;letter-spacing:-0.5px}
.q-options{display:flex;flex-direction:column;gap:10px}
.q-option{width:100%;padding:17px 20px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--fb);font-size:15px;font-weight:500;cursor:pointer;text-align:left;transition:all 0.15s;position:relative;overflow:hidden}
.q-option:hover{border-color:var(--accent);background:var(--card-h)}
.q-option.selected{border-color:var(--accent);background:var(--accent);color:#fff}
.q-option:active{transform:scale(0.99)}

/* THINKING / LOTTERY */
.thinking-inner{display:flex;flex-direction:column;align-items:center;gap:28px}
.lottery-spinner{width:120px;height:80px;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;position:relative;background:var(--card)}
.lottery-spinner::before,.lottery-spinner::after{content:'';position:absolute;left:0;right:0;height:28px;z-index:2}
.lottery-spinner::before{top:0;background:linear-gradient(to bottom,var(--bg),transparent)}
.lottery-spinner::after{bottom:0;background:linear-gradient(to top,var(--bg),transparent)}
.lottery-reel{display:flex;flex-direction:column;align-items:center;animation:reelSpin 0.08s linear infinite;will-change:transform}
.lottery-reel div{font-size:22px;height:40px;display:flex;align-items:center;justify-content:center;width:100%;flex-shrink:0}
.thinking-label{font-size:15px;font-weight:500;color:var(--muted);text-align:center}

/* PICKS SCREEN */
.picks-inner{width:100%;max-width:var(--max-w);display:flex;flex-direction:column;align-items:center;gap:16px;padding-bottom:40px}
.picks-header{text-align:center}
.picks-title{font-family:var(--fd);font-size:clamp(26px,7vw,32px);font-weight:700;margin-bottom:6px;letter-spacing:-0.5px}
.picks-sub{font-size:14px;color:var(--muted)}
.picks-list{width:100%;display:flex;flex-direction:column;gap:10px}
.pick-card{width:100%;padding:20px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all 0.2s;animation:pickIn 0.35s cubic-bezier(0.34,1.56,0.64,1) both}
.pick-card:nth-child(1){animation-delay:0s}
.pick-card:nth-child(2){animation-delay:0.06s}
.pick-card:nth-child(3){animation-delay:0.12s}
.pick-card:nth-child(4){animation-delay:0.18s}
.pick-card:nth-child(5){animation-delay:0.24s}
@keyframes pickIn{from{opacity:0;transform:scale(0.92) translateY(10px)}to{opacity:1;transform:none}}
.pick-card:hover{border-color:var(--accent);transform:translateX(4px)}
.pick-card:active{transform:scale(0.99)}
.pick-left{display:flex;flex-direction:column;gap:4px}
.pick-label{font-family:var(--fd);font-size:20px;font-weight:700}
.pick-tag{font-size:12px;color:var(--muted)}
.pick-arrow{font-size:16px;color:var(--muted);transition:transform 0.2s,color 0.2s}
.pick-card:hover .pick-arrow{transform:translateX(4px);color:var(--accent)}
.btn-respin{width:100%;margin-top:4px}

/* RESTAURANT SCREEN */
.rest-screen-header{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:4px}
.rest-screen-food{font-family:var(--fd);font-size:24px;font-weight:400;margin-bottom:4px}
.rest-screen-tag{font-size:13px;color:var(--muted)}
.rest-count{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:4px 0}
.rest-actions{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:8px}

/* FILTER BAR */
.filter-bar{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:14px}
.filter-row{display:flex;flex-direction:column;gap:8px}
.filter-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--muted)}
.filter-label strong{color:var(--text)}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap}
.filter-chip{padding:6px 14px;background:var(--surface);border:1px solid var(--border);border-radius:99px;font-size:12px;font-weight:600;font-family:var(--fb);color:var(--muted);cursor:pointer;transition:all 0.2s}
.filter-chip:hover{border-color:var(--accent);color:var(--text)}
.filter-chip.active{background:var(--accent);border-color:transparent;color:#fff}

/* RESTAURANT CARDS */
.restaurants{width:100%;display:flex;flex-direction:column;gap:10px}
.rest-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;align-items:stretch;transition:transform 0.2s,border-color 0.2s;animation:fadeUp 0.35s ease both}
.rest-card:hover{transform:translateY(-2px);border-color:rgba(108,99,255,0.35)}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.rest-img{width:80px;flex-shrink:0;background:var(--surface);font-size:30px;display:flex;align-items:center;justify-content:center}
.rest-info{flex:1;padding:13px 14px;display:flex;flex-direction:column;gap:3px}
.rest-name{font-size:15px;font-weight:600;line-height:1.2}
.rest-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-top:1px}
.rest-rating{font-size:12px;font-weight:600;color:var(--accent2)}
.rest-distance,.rest-price,.rest-cuisine{font-size:12px;color:var(--muted)}
.rest-sep{color:var(--border);font-size:10px}
.rest-address{font-size:11px;color:var(--muted);margin-top:2px}
.rest-bottom{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}
.rest-dir{display:inline-flex;align-items:center;padding:6px 12px;background:var(--accent);color:#fff;border-radius:8px;font-size:11px;font-weight:600;font-family:var(--fb);cursor:pointer;border:none;text-decoration:none;transition:opacity 0.15s}
.rest-dir:hover{opacity:0.85}
.rest-yelp{background:#d32323}
.rest-badge{font-size:10px;padding:3px 8px;border-radius:99px;font-weight:600}
.rest-badge.in-range{background:rgba(52,211,153,0.12);color:#34d399}
.rest-badge.out-range{background:rgba(248,113,113,0.12);color:#f87171}
.btn-load-more{width:100%;padding:13px;background:var(--card);border:1px dashed var(--border);color:var(--muted);border-radius:var(--radius);font-family:var(--fb);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;margin-top:4px}
.btn-load-more:hover{border-color:var(--accent);color:var(--text)}
.fallback-notice{width:100%;background:rgba(211,35,35,0.07);border:1px solid rgba(211,35,35,0.2);border-left:3px solid #d32323;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--text);font-weight:500}

/* HISTORY */
.history-list{display:flex;flex-direction:column;gap:10px}
.history-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all 0.2s}
.history-card:hover{border-color:rgba(108,99,255,0.4);transform:translateX(3px)}
.history-emoji{font-size:30px;flex-shrink:0}
.history-info{flex:1;min-width:0}
.history-food{font-size:16px;font-weight:600}
.history-meta{font-size:12px;color:var(--muted);margin-top:2px}
.history-rating-btns{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.rate-btn{padding:5px 12px;background:var(--surface);border:1px solid var(--border);border-radius:99px;font-size:11px;font-weight:600;cursor:pointer;color:var(--muted);font-family:var(--fb);transition:all 0.2s}
.rate-btn:hover{border-color:var(--accent)}
.rate-btn.rated-bad{background:rgba(248,113,113,0.1);border-color:rgba(248,113,113,0.3);color:#f87171}
.rate-btn.rated-good{background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.3);color:#34d399}
.rate-btn.rated-amazing{background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.3);color:#fbbf24}
.history-arrow{font-size:14px;color:var(--muted);flex-shrink:0;transition:all 0.2s}
.history-card:hover .history-arrow{color:var(--accent);transform:translateX(3px)}
.history-detail-header{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:14px}
.detail-header-emoji{font-size:36px;flex-shrink:0}
.detail-header-food{font-family:var(--fd);font-size:20px;font-weight:400}
.detail-header-meta{font-size:12px;color:var(--muted);margin-top:2px}

/* PROFILE */
.profile-header{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.profile-avatar{width:52px;height:52px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fb);font-size:22px;color:#fff;flex-shrink:0}
.profile-name{font-size:18px;font-weight:600}
.profile-email{font-size:12px;color:var(--muted);margin-top:2px}
.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center}
.stat-num{font-family:var(--fb);font-size:30px;font-weight:400;color:var(--accent)}
.stat-label{font-size:11px;color:var(--muted);margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.profile-prefs{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}
.pref-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--muted);margin-bottom:2px}
.pref-row{display:flex;align-items:center;justify-content:space-between;font-size:14px}
.pref-food{font-weight:500}
.pref-score{font-size:12px;color:var(--muted)}

/* RATING TOAST */
.rating-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);z-index:200;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;width:calc(100% - 40px);max-width:var(--max-w);box-shadow:0 8px 40px rgba(0,0,0,0.4);transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1)}
.rating-toast.visible{transform:translateX(-50%) translateY(0)}
.rating-q{font-size:14px;font-weight:600;margin-bottom:10px;text-align:center}
.rating-btns{display:flex;gap:8px}
.rating-btn{flex:1;padding:11px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all 0.2s}
.rating-btn:hover{border-color:var(--accent)}

/* AI LOADING */
.ai-loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 0}
.ai-dots{display:flex;gap:8px}
.ai-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dot 1.2s ease-in-out infinite}
.ai-dots span:nth-child(2){animation-delay:0.2s;background:var(--accent2)}
.ai-dots span:nth-child(3){animation-delay:0.4s}
@keyframes dot{0%,80%,100%{transform:scale(0.5);opacity:0.3}40%{transform:scale(1.2);opacity:1}}
.ai-dots-label{font-size:14px;color:var(--muted)}

::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ── PICKS ACTIONS ROW ── */
.picks-actions {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.btn-refine {
  color: var(--accent);
  border-color: var(--accent);
}
.btn-refine:hover {
  background: rgba(108,99,255,0.08);
}

/* ── PICK RANK BADGES ── */
.pick-rank {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 3px 8px;
  border-radius: 99px;
  margin-bottom: 6px;
  font-family: var(--fb);
}
.pick-rank-0 { background: var(--accent); color: #fff; }
.pick-rank-1 { background: rgba(108,99,255,0.15); color: var(--accent); }
.pick-rank-2 { background: var(--surface); color: var(--muted); border: 1px solid var(--border); }
.pick-rank-3 { background: var(--surface); color: var(--muted); border: 1px solid var(--border); }
.pick-rank-4 { background: var(--surface); color: var(--muted); border: 1px solid var(--border); opacity: 0.7; }

.pick-card-best {
  border-color: rgba(108,99,255,0.4);
  background: var(--card-h);
}

/* ── PICKS LOCATION ROW ── */
.picks-location-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}
.picks-location-text {
  font-size: 13px;
  color: var(--muted);
}
.picks-change-loc {
  font-size: 12px;
  color: var(--accent);
  padding: 4px 8px;
  text-decoration: underline;
}

/* ── RESTAURANT COLOR CODING ── */
.rest-card-excellent { border-left: 3px solid #34d399; }
.rest-card-good      { border-left: 3px solid #6c63ff; }
.rest-card-ok        { border-left: 3px solid rgba(255,255,255,0.15); }
.rest-badge.best-pick {
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  color: #1a1400;
  font-weight: 700;
}

/* ── INLINE RATING PROMPT ── */
.inline-rating {
  width: 100%;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  animation: fadeUp 0.35s ease;
}
.inline-rating-q {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 12px;
  color: var(--text);
}
.inline-rating-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.inline-rate-btn {
  flex: 1;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  font-family: var(--fb);
  transition: all 0.2s;
  white-space: nowrap;
}
.inline-rate-btn:hover { border-color: var(--accent); background: var(--card); }
.inline-rating-done {
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  text-align: center;
  padding: 4px 0;
}

/* ── SCREEN OVERFLOW FIX ── */
.screen { overflow-x: hidden; }
#questionScreen { overflow-y: auto; }
body { overflow: hidden; }

/* ── AI SUMMARY ── */
.ai-summary {
  width: 100%;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(108,99,255,0.1), rgba(167,139,250,0.08));
  border: 1px solid rgba(108,99,255,0.25);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.5;
  animation: fadeUp 0.4s ease;
}

/* ── LOCATION PILL (restaurant screen) ── */
.location-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 10px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 99px;
  cursor: pointer;
  font-family: var(--fb);
  font-size: 13px;
  color: var(--text);
  transition: all 0.2s;
  text-align: left;
}
.location-pill:hover {
  border-color: var(--accent);
  background: var(--card-h);
}
.location-pill-icon { font-size: 14px; flex-shrink: 0; }
.location-pill-change {
  margin-left: auto;
  font-size: 12px;
  color: var(--accent);
  font-weight: 600;
}

/* ── EDIT NAME ROW ── */
.edit-name-row {
  display: flex;
  gap: 8px;
  width: 100%;
  align-items: center;
  margin-top: 4px;
}
.edit-name-input {
  flex: 1;
  padding: 9px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--fb);
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s;
  -webkit-appearance: none;
  min-width: 0;
}
.edit-name-input:focus { border-color: var(--accent); }
.btn-save-name {
  padding: 9px 14px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--fb);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.2s;
  flex-shrink: 0;
}
.btn-save-name:hover { opacity: 0.88; }

/* ── DELETE ACCOUNT ── */
.btn-delete-account {
  width: 100%;
  padding: 14px;
  background: none;
  border: 1px solid rgba(239,68,68,0.2);
  color: rgba(239,68,68,0.6);
  border-radius: var(--radius-sm);
  font-family: var(--fb);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-delete-account:hover {
  background: rgba(239,68,68,0.08);
  border-color: rgba(239,68,68,0.5);
  color: #f87171;
}

/* ── AUTH SUCCESS MESSAGE ── */
.auth-success {
  color: #34d399;
  font-size: 13px;
  text-align: center;
  padding: 4px 0;
}

/* ── PROFILE NAME ROW ── */
.profile-name-row { flex: 1; display: flex; flex-direction: column; gap: 2px; }
#profileNameDisplay { display: flex; align-items: center; gap: 8px; }
.btn-pencil {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 15px;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  transition: color 0.2s, background 0.2s;
  line-height: 1;
}
.btn-pencil:hover { color: var(--accent); background: rgba(108,99,255,0.1); }
.btn-cancel-name {
  padding: 13px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--muted);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}
.btn-cancel-name:hover { color: var(--text); }

/* ── SPLASH WELCOME (logged in) ── */
.splash-welcome {
  font-size: 14px;
  color: var(--muted);
  font-weight: 500;
}

/* ── RATING SELECTED STATE (yellow) ── */
.rate-btn-selected,
.inline-rate-btn.rate-selected {
  background: rgba(251,191,36,0.18) !important;
  border-color: rgba(251,191,36,0.6) !important;
  color: #d97706 !important;
  font-weight: 700 !important;
}
body.theme-afternoon .rate-btn-selected,
body.theme-afternoon .inline-rate-btn.rate-selected {
  color: #92400e !important;
}

/* ── LOCATION CHANGE MODAL ── */
.loc-modal {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0 0 env(safe-area-inset-bottom, 0);
  opacity: 0;
  transition: opacity 0.25s ease;
  backdrop-filter: blur(4px);
}
.loc-modal.modal-visible { opacity: 1; }
.loc-modal.hidden { display: none; }
.loc-modal-inner {
  width: 100%;
  max-width: 480px;
  background: var(--bg);
  border-radius: 24px 24px 0 0;
  padding: 20px 20px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transform: translateY(20px);
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1);
}
.loc-modal.modal-visible .loc-modal-inner { transform: translateY(0); }
.loc-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.loc-modal-title {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 700;
}
.loc-modal-close {
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--muted);
  width: 32px; height: 32px;
  border-radius: 50%;
  font-size: 13px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.loc-modal-close:hover { color: var(--text); }

/* ── THEME AMBIENT ELEMENTS ── */

/* Morning sun */
.theme-sun {
  display: none;
  position: absolute;
  width: 200px; height: 200px;
  border-radius: 50%;
  top: -80px; right: -60px;
  background: radial-gradient(circle, rgba(255,200,80,0.55) 0%, rgba(255,160,40,0.2) 50%, transparent 70%);
  filter: blur(20px);
  animation: sunPulse 6s ease-in-out infinite alternate;
}
@keyframes sunPulse { from { transform: scale(1); opacity: 0.8; } to { transform: scale(1.12); opacity: 1; } }
body.theme-morning .theme-sun { display: block; }

/* Afternoon — softer orbs, slightly dim */
body.theme-afternoon .orb-1 { background: rgba(55,48,163,0.1); }
body.theme-afternoon .orb-2 { background: rgba(99,102,241,0.08); }

/* Evening moon glow */
body.theme-evening .orb-1 {
  background: rgba(176,110,243,0.18);
  width: 40vw; height: 40vw;
  top: -10%; right: -10%;
}
body.theme-evening .orb-2 {
  background: rgba(217,70,239,0.12);
}

/* Night stars */
.theme-stars {
  display: none;
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.theme-stars::before,
.theme-stars::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(255,255,255,0.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 25% 40%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 10%, rgba(255,255,255,0.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 60% 25%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 8%, rgba(255,255,255,0.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 35%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 92% 18%, rgba(255,255,255,0.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 15% 28%, rgba(255,255,255,0.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 5%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 68% 42%, rgba(255,255,255,0.4) 0%, transparent 100%);
  animation: starTwinkle 0.9s ease-in-out infinite alternate;
}
.theme-stars::after {
  background-image:
    radial-gradient(1px 1px at 20% 55%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 35% 70%, rgba(255,255,255,0.3) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 60%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 78% 65%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 75%, rgba(255,255,255,0.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 5% 80%, rgba(255,255,255,0.3) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 88%, rgba(255,255,255,0.4) 0%, transparent 100%);
  animation-delay: 2s;
}
@keyframes starTwinkle { from { opacity: 0.6; } to { opacity: 1; } }

/* Night theme gets stars */
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .theme-stars { display: block; }

/* Morning orbs warmer */
body.theme-morning .orb-1 {
  background: rgba(240,130,40,0.15);
  width: 50vw; height: 50vw;
}
body.theme-morning .orb-2 {
  background: rgba(255,180,60,0.1);
}

/* ── HISTORY LOGIN PROMPT ── */
.history-login-prompt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 48px 24px;
  text-align: center;
}
.history-login-msg {
  font-size: 16px;
  color: var(--muted);
  line-height: 1.5;
  max-width: 280px;
}
.history-login-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 280px;
}

/* ── FOOD HERO ── */
.food-hero {
  width: 100%;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.food-hero-emoji { font-size: 64px; line-height: 1; }
.food-hero-name  { font-family: var(--fd); font-size: 32px; font-weight: 900; letter-spacing: -1px; }
.food-hero-desc  { font-size: 15px; color: var(--muted); max-width: 260px; line-height: 1.5; }

/* ── YELP BUTTON ── */
.yelp-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px;
  background: #d32323;
  color: #fff;
  border-radius: var(--radius);
  font-family: var(--fb);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: opacity 0.2s;
}
.yelp-search-btn:hover { opacity: 0.88; }

/* ── CITY INPUT ── */
.city-input-wrap { width: 100%; }
.city-input {
  width: 100%;
  padding: 12px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--muted);
  font-family: var(--fb);
  font-size: 14px;
  outline: none;
  -webkit-appearance: none;
  transition: border-color 0.2s;
}
.city-input:focus { border-color: var(--accent); color: var(--text); }

/* ── SIMILAR OPTIONS ── */
.similar-section { width: 100%; }
.similar-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
  margin-bottom: 10px;
}
.similar-list { display: flex; flex-wrap: wrap; gap: 8px; }
.similar-chip {
  padding: 8px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 99px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  font-family: var(--fb);
  transition: all 0.2s;
}
.similar-chip:hover { border-color: var(--accent); background: var(--card-h); }

/* ── FOOD ACTIONS ── */
.food-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}

/* ── QUERY BOX ── */
.query-box {
  width: 100%;
  display: flex;
  gap: 8px;
  align-items: center;
}
.query-input {
  flex: 1;
  padding: 12px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--fb);
  font-size: 14px;
  outline: none;
  -webkit-appearance: none;
  transition: border-color 0.2s;
}
.query-input:focus { border-color: var(--accent); }
.query-input::placeholder { color: var(--muted); }
.btn-query {
  padding: 12px 16px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  flex-shrink: 0;
  transition: opacity 0.2s;
}
.btn-query:hover { opacity: 0.85; }

/* ── 0-10 RATING SCALE ── */
.rating-scale {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
  width: 100%;
}
.rate-num {
  flex: 1;
  padding: 8px 2px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  min-width: 0;
  text-align: center;
}
.inline-rate-btn.rate-num {
  flex: 1;
  padding: 10px 2px;
  font-size: 13px;
  font-weight: 700;
  min-width: 0;
}
.rating-scale-labels {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--muted);
  font-weight: 500;
  padding: 0 2px;
  margin-top: 2px;
}
.history-rating-btns.rating-scale {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 2px;
}
.history-rating-btns.rating-scale::-webkit-scrollbar { display: none; }

/* ── WIDE RESPIN BUTTON ── */
.btn-respin-wide {
  width: 100%;
  background: var(--card) !important;
  color: var(--text) !important;
  border: 1.5px solid var(--border) !important;
  box-shadow: none !important;
}
.btn-respin-wide:hover {
  border-color: var(--accent) !important;
  background: var(--card-h) !important;
}

/* ── LOGIN NUDGE ── */
.login-nudge {
  width: 100%;
  background: rgba(108,99,255,0.08);
  border: 1px solid rgba(108,99,255,0.25);
  border-radius: var(--radius);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  text-align: center;
}
.login-nudge p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}

/* ══════════════════════════════════════════════
   ENHANCED TIME-OF-DAY THEMING
══════════════════════════════════════════════ */

/* MORNING — bright, warm, energetic */
body.theme-morning { --bg:#fff9f2; --surface:#fff4e8; --card:#ffffff; --card-h:#fdf6ed; --border:rgba(200,100,20,0.12); --text:#1c0e06; --muted:rgba(28,14,6,0.45); --accent:#d4600a; --accent2:#f07820; --glow:0 0 48px rgba(212,96,10,0.25); }
body.theme-morning .orb-1 { width:70vw;height:70vw;background:rgba(255,160,40,0.22);top:-25%;left:-20%;filter:blur(80px); }
body.theme-morning .orb-2 { width:50vw;height:50vw;background:rgba(255,200,80,0.15);bottom:-15%;right:-10%;filter:blur(90px); }
body.theme-morning .theme-sun { display:block;width:300px;height:300px;top:-120px;right:-80px;background:radial-gradient(circle,rgba(255,210,80,0.7) 0%,rgba(255,160,40,0.3) 40%,transparent 70%);filter:blur(30px);animation:sunPulse 5s ease-in-out infinite alternate; }

/* AFTERNOON — cool, slightly muted blue-white */
body.theme-afternoon { --bg:#f0f3fc; --surface:#e8ecf8; --card:#ffffff; --card-h:#eceffe; --border:rgba(60,80,200,0.1); --text:#0d1528; --muted:rgba(13,21,40,0.45); --accent:#3730a3; --accent2:#4f46e5; --glow:0 0 40px rgba(55,48,163,0.18); }
body.theme-afternoon .orb-1 { background:rgba(55,48,163,0.12);filter:blur(110px); }
body.theme-afternoon .orb-2 { background:rgba(99,102,241,0.1);filter:blur(120px); }

/* EVENING — rich purple dusk with moon */
body.theme-evening { --bg:#0e0814; --surface:#160c1e; --card:#1e1028; --card-h:#261638; --border:rgba(200,130,255,0.14); --text:#f2eaff; --muted:rgba(242,234,255,0.42); --accent:#b06ef3; --accent2:#d946ef; --glow:0 0 48px rgba(176,110,243,0.35); }
body.theme-evening .orb-1 { width:65vw;height:65vw;background:rgba(176,110,243,0.22);top:-18%;right:-15%;filter:blur(80px); }
body.theme-evening .orb-2 { width:50vw;height:50vw;background:rgba(217,70,239,0.14);bottom:-10%;left:-10%;filter:blur(90px); }
body.theme-evening .theme-sun { display:block;width:180px;height:180px;top:-60px;right:-40px;background:radial-gradient(circle,rgba(230,200,255,0.5) 0%,rgba(176,110,243,0.25) 50%,transparent 70%);filter:blur(25px);border-radius:50%;box-shadow:0 0 60px rgba(176,110,243,0.4);animation:sunPulse 7s ease-in-out infinite alternate; }

/* NIGHT — deep dark with dense stars */
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .orb-1 { background:rgba(108,99,255,0.12);filter:blur(100px); }
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .orb-2 { background:rgba(167,139,250,0.08);filter:blur(120px); }
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .theme-stars { display:block; }

/* Dense star field for night */
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .theme-stars::before {
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 5% 8%, rgba(255,255,255,0.9) 0%,transparent 100%),
    radial-gradient(1px 1px at 12% 20%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(2px 2px at 20% 5%, rgba(255,255,255,0.8) 0%,transparent 100%),
    radial-gradient(1px 1px at 28% 32%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 35% 12%, rgba(255,255,255,0.7) 0%,transparent 100%),
    radial-gradient(1px 1px at 42% 25%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(2px 2px at 50% 7%, rgba(255,255,255,0.9) 0%,transparent 100%),
    radial-gradient(1px 1px at 58% 18%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 65% 3%, rgba(255,255,255,0.8) 0%,transparent 100%),
    radial-gradient(1px 1px at 72% 28%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(2px 2px at 80% 10%, rgba(255,255,255,0.9) 0%,transparent 100%),
    radial-gradient(1px 1px at 88% 22%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 94% 6%, rgba(255,255,255,0.7) 0%,transparent 100%),
    radial-gradient(1px 1px at 15% 45%, rgba(255,255,255,0.4) 0%,transparent 100%),
    radial-gradient(1px 1px at 33% 52%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 40%, rgba(255,255,255,0.7) 0%,transparent 100%),
    radial-gradient(1px 1px at 75% 48%, rgba(255,255,255,0.4) 0%,transparent 100%),
    radial-gradient(1px 1px at 92% 38%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(2px 2px at 8% 65%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1px 1px at 45% 70%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 62%, rgba(255,255,255,0.8) 0%,transparent 100%);
  animation:starTwinkle 0.8s ease-in-out infinite alternate;
}
body:not(.theme-morning):not(.theme-afternoon):not(.theme-evening) .theme-stars::after {
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 18% 78%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 38% 85%, rgba(255,255,255,0.7) 0%,transparent 100%),
    radial-gradient(1px 1px at 62% 80%, rgba(255,255,255,0.4) 0%,transparent 100%),
    radial-gradient(2px 2px at 78% 90%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 95% 75%, rgba(255,255,255,0.8) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 25% 92%, rgba(255,255,255,0.5) 0%,transparent 100%),
    radial-gradient(1px 1px at 50% 88%, rgba(255,255,255,0.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 70% 72%, rgba(255,255,255,0.4) 0%,transparent 100%),
    radial-gradient(2px 2px at 90% 82%, rgba(255,255,255,0.7) 0%,transparent 100%);
  animation:starTwinkle 1.2s ease-in-out infinite alternate-reverse;
}

/* ── WHY THIS BUTTON ── */
.btn-why {
  width: 100%;
  padding: 13px;
  background: none;
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  color: var(--muted);
  font-family: var(--fb);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
}
.btn-why:hover { border-color: var(--accent); color: var(--accent); }
.btn-why:disabled { opacity: 0.5; cursor: default; }

/* ── PICK RANK LABELS ── */
.pick-rank {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 3px 8px;
  border-radius: 99px;
  display: inline-block;
  margin-bottom: 4px;
}
.pick-rank-0 { background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; }
.pick-rank-1 { background: rgba(108,99,255,0.15); color: var(--accent); }
.pick-rank-2 { background: rgba(108,99,255,0.08); color: var(--muted); }
.pick-rank-3 { background: rgba(108,99,255,0.05); color: var(--muted); }
.pick-rank-4 { background: rgba(108,99,255,0.05); color: var(--muted); }

/* ── PERFORMANCE: Reduce animations on mobile ── */
@media (max-width: 600px) {
  .orb { filter: blur(60px) !important; animation-duration: 30s !important; }
  .theme-sun { filter: blur(40px) !important; }
  .theme-stars::before, .theme-stars::after { animation-duration: 2s !important; }
  .pick-card { animation: none !important; }
  .rest-card { animation: none !important; }
  @keyframes drift1 { to { transform: none; } }
  @keyframes drift2 { to { transform: none; } }
}
