#welcomeOverlay{position:fixed;inset:0;background:rgba(6,18,33,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:300;display:none;align-items:center;justify-content:center;padding:24px;animation:wFade .3s cubic-bezier(.4,0,.2,1);}
#welcomeOverlay.on{display:flex;}
@keyframes wFade{from{opacity:0;}to{opacity:1;}}
.welcome-card{background:var(--surface,var(--card));border:1px solid var(--border);border-radius:20px;padding:32px;max-width:720px;width:100%;box-shadow:0 24px 60px rgba(0,0,0,.25);animation:wPop .4s cubic-bezier(.4,0,.2,1);}
@keyframes wPop{from{opacity:0;transform:translateY(12px) scale(.98);}to{opacity:1;transform:translateY(0) scale(1);}}
.welcome-head{text-align:center;margin-bottom:24px;}
.welcome-logo{display:flex;justify-content:center;margin-bottom:10px;}
.welcome-logo-img{height:54px;width:auto;display:block;}
:root.dark .welcome-logo-img{filter:invert(1) hue-rotate(180deg);}
.welcome-sub{font-size:14px;color:var(--txt2);line-height:1.5;}
.welcome-choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;}
.welcome-choice{background:var(--surface-2,var(--card2));border:1.5px solid var(--border);border-radius:14px;padding:22px 20px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left;font-family:inherit;color:inherit;}
.welcome-choice:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 10px 24px rgba(37,99,235,.12);}
.welcome-choice-ico{width:40px;height:40px;border-radius:10px;background:var(--abg);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.welcome-choice-ttl{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:4px;}
.welcome-choice-sub{font-size:12px;color:var(--txt3);line-height:1.45;}
.welcome-choice-sub b{color:var(--txt2);font-weight:600;}
.welcome-tertiary{margin-top:14px;text-align:center;}
.welcome-tertiary button{font-size:12px;color:var(--txt3);background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:6px;transition:color .15s;font-family:inherit;}
.welcome-tertiary button:hover{color:var(--accent);}
.welcome-saved-list{margin-top:14px;max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;background:var(--surface,var(--card));}
.welcome-saved-list .wsrow{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;transition:background .15s;}
.welcome-saved-list .wsrow:last-child{border-bottom:none;}
.welcome-saved-list .wsrow:hover{background:var(--surface-2,var(--card2));}
.welcome-saved-name{font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.welcome-saved-meta{font-size:11px;color:var(--txt3);margin-top:2px;}
.welcome-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--txt3);padding:8px;border-radius:8px;transition:all .15s;}
.welcome-close:hover{background:var(--surface-2,var(--card2));color:var(--txt);}
@media (max-width:600px){
  .welcome-card{padding:24px 20px;}
  .welcome-choices{grid-template-columns:1fr;}
  .welcome-logo-img{height:42px;}
}

/* ══════════════════ PLANNER REDESIGN ══════════════════ */
.plan-hero{display:grid;grid-template-columns:minmax(280px,1fr) 2fr;gap:12px;margin-bottom:16px;}
@media (max-width:900px){.plan-hero{grid-template-columns:1fr;}}

.plan-hero-budget{background:linear-gradient(135deg,var(--surface,var(--card)) 0%,var(--surface-2,var(--card2)) 100%);border:1px solid var(--border);border-radius:var(--r-lg,14px);padding:22px 24px;box-shadow:0 1px 2px rgba(15,23,42,.04);position:relative;overflow:hidden;}
.plan-hero-budget::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--accent),#0891b2);}
.ph-lbl{font-size:10.5px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;}
.ph-big-input-wrap{position:relative;margin-bottom:14px;}
.ph-big-input-wrap::before{content:"$";position:absolute;left:2px;top:50%;transform:translateY(-50%);font-size:26px;font-weight:700;color:var(--txt2);line-height:1;}
.ph-big-input{width:100%;background:transparent;border:none;outline:none;font-size:32px;font-weight:700;color:var(--txt);padding:4px 0 4px 22px;font-family:'DM Sans',sans-serif;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;}
.ph-big-input::placeholder{color:var(--txt4,#94a3b8);}
.ph-fee-row{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--border);}
.ph-fee-inp-wrap{position:relative;}
.ph-fee-inp{width:70px;background:var(--surface-2,var(--card2));border:1px solid var(--border);border-radius:6px;padding:6px 24px 6px 10px;font-size:13px;font-weight:600;color:var(--txt);outline:none;font-family:'DM Mono',monospace;}
.ph-fee-inp:focus{border-color:var(--accent);}
.ph-fee-inp-wrap::after{content:"%";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--txt3);}
.ph-fee-label{font-size:11.5px;color:var(--txt2);flex:1;}
.ph-global-cb{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--txt3);cursor:pointer;}
.ph-global-cb input{accent-color:var(--accent);}

.plan-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
@media (max-width:700px){.plan-stats{grid-template-columns:repeat(2,1fr);}}
.plan-stat{background:var(--surface,var(--card));border:1px solid var(--border);border-radius:var(--r-lg,14px);padding:16px 14px;box-shadow:0 1px 2px rgba(15,23,42,.04);transition:transform .18s cubic-bezier(.4,0,.2,1),box-shadow .18s cubic-bezier(.4,0,.2,1),border-color .18s cubic-bezier(.4,0,.2,1);}
.plan-stat:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(15,23,42,.08);border-color:var(--border-2,var(--border2));}
.plan-stat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.plan-stat-lbl{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em;}
.plan-stat-val{font-size:20px;font-weight:700;color:var(--txt);letter-spacing:-0.02em;font-variant-numeric:tabular-nums;line-height:1.1;}
.plan-stat-sub{font-size:10.5px;color:var(--txt3);margin-top:4px;}
.plan-stat.ok .plan-stat-val{color:var(--green,#16a34a);}
.plan-stat.warn .plan-stat-val{color:var(--amber,#d97706);}
.plan-stat.danger .plan-stat-val{color:var(--red,#dc2626);}

.plan-alloc{background:var(--surface,var(--card));border:1px solid var(--border);border-radius:var(--r-lg,14px);padding:18px 20px;margin-bottom:16px;box-shadow:0 1px 2px rgba(15,23,42,.04);}
.plan-alloc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px;flex-wrap:wrap;}
.plan-alloc-ttl{font-size:13px;font-weight:700;color:var(--txt);}
.plan-alloc-sub{font-size:11px;color:var(--txt3);}
.plan-alloc-bar{height:36px;width:100%;background:var(--surface-3,var(--bg));border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;position:relative;}
.plan-alloc-seg{height:100%;position:relative;transition:width .7s cubic-bezier(.4,0,.2,1);min-width:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.55), 0 0 2px rgba(0,0,0,.35);cursor:pointer;}
.plan-alloc-seg > *{position:relative;z-index:1;}
.plan-alloc-seg:first-child{border-radius:10px 0 0 10px;}
.plan-alloc-seg:last-child{border-radius:0 10px 10px 0;}
.plan-alloc-seg:only-child{border-radius:10px;}
.plan-alloc-seg:hover{filter:brightness(1.08);}
.plan-alloc-seg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 55%);pointer-events:none;z-index:0;}
.plan-alloc-empty{color:var(--txt3);font-size:12px;text-align:center;padding:8px 0;flex:1;align-self:center;}
.plan-alloc-legend{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:12px;}
.plan-alloc-dot{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--txt2);white-space:nowrap;}
.plan-alloc-dot b{color:var(--txt);font-weight:600;}
.plan-alloc-dot .pad-swatch{width:9px;height:9px;border-radius:50%;flex-shrink:0;display:inline-block;}
.plan-alloc-dot .pad-pct{color:var(--txt3);font-variant-numeric:tabular-nums;}

@media (max-width:640px){
  /* On mobile, hide the in-bar labels entirely — the legend below shows the numbers. */
  .plan-alloc-seg{font-size:0;}
  .plan-alloc-legend{gap:6px 12px;}
  .plan-alloc-dot{font-size:11px;}
  .plan-alloc-bar{height:30px;}
  .ph-big-input{font-size:26px;}
  .ph-big-input-wrap::before{font-size:22px;}
}

/* Platform card redesign */
.plat-plan-card{position:relative;padding-left:4px;}
.plat-plan-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--plat-color,var(--accent));border-radius:10px 0 0 10px;}
.plat-plan-card{background:var(--surface,var(--card));border:1px solid var(--border);border-radius:var(--r-lg,14px);overflow:hidden;margin-bottom:10px;box-shadow:0 1px 2px rgba(15,23,42,.04);transition:box-shadow .18s cubic-bezier(.4,0,.2,1);}
.plat-plan-card:hover{box-shadow:0 4px 14px rgba(15,23,42,.08);}
.plat-plan-hdr{padding:14px 18px 12px;background:transparent;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.plat-logo-sq{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0;}
.plat-mini-bar{width:100%;height:4px;background:var(--surface-3,var(--bg));border-radius:2px;overflow:hidden;margin-top:8px;}
.plat-mini-bar-fill{height:100%;border-radius:2px;width:0;transition:width .7s cubic-bezier(.4,0,.2,1);}

/* Quick add row */
.plan-quick-add{background:linear-gradient(135deg,var(--surface,var(--card)) 0%,var(--surface-2,var(--card2)) 100%);border:1.5px dashed var(--border-2,var(--border2));border-radius:var(--r-lg,14px);padding:16px 18px;margin-top:12px;}
.plan-quick-ttl{font-size:12px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;text-align:center;}
.plan-quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;}
.plan-quick-btn{background:var(--surface,var(--card));border:1px solid var(--border);border-radius:10px;padding:12px 8px;cursor:pointer;font-family:inherit;font-size:12px;color:var(--txt);transition:all .18s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:6px;}
.plan-quick-btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 14px rgba(37,99,235,.12);}
.plan-quick-btn .plat-logo-sq{width:32px;height:32px;border-radius:8px;font-size:14px;}
.plan-quick-btn-lbl{font-weight:600;font-size:11.5px;}

/* Sticky allocation footer */
.plan-footer-indicator{position:sticky;bottom:0;margin-top:14px;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:10px;padding:10px 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;box-shadow:0 -4px 16px rgba(0,0,0,.06);z-index:2;}
:root.dark .plan-footer-indicator{background:rgba(15,30,48,.96);}
.pfi-stat{font-size:12px;color:var(--txt2);}
.pfi-stat b{color:var(--txt);font-weight:700;font-variant-numeric:tabular-nums;}
.pfi-badge{margin-left:auto;font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;}
.pfi-badge.ok{background:var(--green-soft,rgba(22,163,74,.1));color:var(--green,#16a34a);}
.pfi-badge.warn{background:var(--amber-soft,rgba(217,119,6,.1));color:var(--amber,#d97706);}
.pfi-badge.danger{background:var(--red-soft,rgba(220,38,38,.1));color:var(--red,#dc2626);}
}
