.planner-app{--bg: #f7f8fb;--surface: #ffffff;--surface-2: #f4f6fa;--surface-3: #eaeef5;--border: #e4e8ef;--border-strong: #cdd3dd;--text: #0f1729;--text-2: #525a6b;--text-3: #8a93a4;--accent: #2563eb;--accent-2: #4f8bff;--accent-bg: #eff5ff;--accent-text: #0b3a99;--accent-grad: linear-gradient(135deg, #2563eb 0%, #4f8bff 100%);--coral: #f97356;--coral-bg: #fff1ed;--coral-text: #9a2e16;--gold: #f0b429;--gold-bg: #fff8e1;--gold-text: #7a5a00;--teal: #0a9b7a;--teal-bg: #e3f7f0;--teal-text: #064e3d;--teal-grad: linear-gradient(135deg, #0a9b7a 0%, #14b896 100%);--purple: #6d5cf0;--purple-bg: #eeecfd;--purple-text: #2e2683;--warn-bg: #fff4d6;--warn-text: #7a5a00;--warn-border: #f0d27a;--danger: #b42318;--danger-bg: #fde8e6;--radius: 14px;--radius-sm: 8px;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(15,23,42,.04);--shadow-sm: 0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.03);--shadow-md: 0 6px 18px -8px rgba(15,23,42,.1), 0 3px 6px rgba(15,23,42,.04);--shadow-lg: 0 16px 40px -12px rgba(15,23,42,.16), 0 6px 14px rgba(15,23,42,.06);--font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;font-family:var(--font-body);background:var(--bg);color:var(--text);padding:2rem 1.25rem 4rem;min-height:100vh;font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.planner-app *{box-sizing:border-box}@keyframes pl-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes pl-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}@keyframes pl-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pl-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.planner-app .anim-fade{animation:pl-fade-in .35s ease-out both}.planner-app .anim-pop{animation:pl-pop .25s ease-out both}.planner-app .anim-slide{animation:pl-slide-down .3s ease-out both}.planner-app .topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:14px;flex-wrap:wrap}.planner-app .ttl{font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1.1}.planner-app .sub{font-size:13px;color:var(--text-2);margin-top:6px}.planner-app .month-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:1.75rem}.planner-app .mchip{padding:11px 4px;text-align:center;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12.5px;color:var(--text-2);background:var(--surface);-webkit-user-select:none;user-select:none;transition:all .18s cubic-bezier(.4,0,.2,1);font-weight:500;position:relative}.planner-app .mchip:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.planner-app .mchip.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text);box-shadow:0 0 0 3px #2563eb14}.planner-app .mchip.hot:before{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 2px var(--surface)}.planner-app .mdots{display:flex;justify-content:center;gap:3px;margin-top:5px;min-height:6px}.planner-app .mdot{width:5px;height:5px;border-radius:50%}.planner-app .season-empty{text-align:center;padding:1.75rem;font-size:13px;color:var(--text-2);border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface)}.planner-app .season-events{display:flex;flex-direction:column;gap:10px;margin-bottom:1rem}.planner-app .moment-card{border-radius:var(--radius);padding:18px 20px;border:1px solid;display:flex;flex-direction:column;gap:12px;transition:transform .2s,box-shadow .2s;animation:pl-fade-in .35s ease-out both}.planner-app .moment-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.planner-app .moment-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.planner-app .moment-title{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.015em;line-height:1.2}.planner-app .moment-sub{font-size:13px;opacity:.85;margin-top:3px}.planner-app .moment-urgency{font-size:11px;font-weight:700;padding:5px 12px;border-radius:var(--radius-pill);white-space:nowrap;letter-spacing:.02em}.planner-app .moment-cats{display:flex;flex-wrap:wrap;gap:6px}.planner-app .moment-pill{font-size:11.5px;padding:4px 11px;border-radius:var(--radius-pill);font-weight:600;border:1px solid;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}.planner-app .moment-hint{font-size:11.5px;font-weight:600;margin:2px 0 4px;letter-spacing:.01em;display:flex;align-items:center;gap:6px}button.moment-pill{font-family:inherit;cursor:pointer;border-style:solid;border-width:1px;transition:transform .12s ease,box-shadow .12s ease,background .15s ease}button.moment-pill:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000014}button.moment-pill:active{transform:translateY(0)}.planner-app .sticky-bar{position:sticky;top:0;z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:14px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:14px;flex-wrap:wrap;-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);background:#ffffffeb}.planner-app .sb-month{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;padding-right:14px;border-right:1px solid var(--border)}.planner-app .sb-stat{display:flex;align-items:baseline;gap:5px;font-size:12px;color:var(--text-2)}.planner-app .sb-stat strong{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.planner-app .sb-spacer{flex:1}.planner-app .sb-price{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--teal-text);letter-spacing:-.01em}.planner-app .sb-price.muted{color:var(--text-3);font-weight:600}.planner-app .go-btn{width:100%;padding:14px;font-size:14px;cursor:pointer;background:var(--accent-grad);color:#fff;border:none;border-radius:var(--radius-sm);margin-top:6px;font-weight:600;letter-spacing:.01em;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 6px 18px -6px #2563eb73;transition:transform .12s,box-shadow .12s;font-family:var(--font-body)}.planner-app .go-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px -6px #2563eb8c}.planner-app .go-btn:active{transform:translateY(0)}.planner-app .genbtn{width:100%;padding:12px;font-size:13.5px;cursor:pointer;margin-top:8px;background:var(--surface);border:1.5px solid var(--accent);color:var(--accent-text);border-radius:var(--radius-sm);font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:all .15s;font-family:var(--font-body)}.planner-app .genbtn:hover{background:var(--accent-bg)}.reset-btn{background:#fff;border:1px solid var(--border);color:var(--text-2);font-size:12px;font-weight:500;padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-body)}.reset-btn:hover{background:var(--danger-bg);border-color:#fbb;color:var(--danger)}.back-btn{background:transparent;border:1px solid var(--border);color:var(--text-2);font-size:12.5px;font-weight:500;padding:7px 13px;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:14px;transition:all .15s;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body)}.back-btn:hover{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.planner-app .cfg-link{font-size:12px;color:var(--text-2);cursor:pointer;margin-bottom:1rem;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-weight:500;transition:all .15s;font-family:var(--font-body)}.planner-app .cfg-link:hover{border-color:var(--border-strong);color:var(--text)}.planner-app .cfgpanel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:1.25rem;box-shadow:var(--shadow-sm);animation:pl-slide-down .25s ease-out both}.planner-app .cfgrow{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:13px;color:var(--text-2)}.planner-app .cfgrow:last-child{margin-bottom:0}.planner-app .cfglbl{flex:1}.planner-app .cfgrow input[type=number]{width:80px;text-align:right;padding:6px 9px;border:1px solid var(--border);border-radius:6px;background:var(--surface);font-size:13px;font-family:var(--font-body)}.planner-app .cfgrow input[type=number]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.planner-app .cfg-divider{border-top:1px solid var(--border);margin:14px 0 10px}.planner-app .cfg-section{font-size:10px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.planner-app .cfg-note{font-size:11px;color:var(--text-3);margin-bottom:8px;line-height:1.5}.planner-app .slbl{font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;margin:0 0 12px;display:flex;align-items:center;gap:6px}.planner-app .chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-bottom:1.75rem}.planner-app .chip{display:flex;align-items:center;gap:8px;padding:11px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;background:var(--surface);-webkit-user-select:none;user-select:none;transition:all .15s cubic-bezier(.4,0,.2,1);font-weight:500}.planner-app .chip:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.planner-app .chip.on{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text);box-shadow:0 0 0 3px #2563eb14}.planner-app .chip.season-hint{box-shadow:inset 3px 0 0 var(--coral)}.planner-app .chip.season-hint.on{box-shadow:inset 3px 0 0 var(--coral),0 0 0 3px #2563eb14}.planner-app .dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.55}.planner-app .cards{display:flex;flex-direction:column;gap:16px;margin-bottom:1.5rem}.planner-app .empty{text-align:center;padding:3rem 1rem;font-size:13.5px;color:var(--text-2);border:1.5px dashed var(--border-strong);border-radius:var(--radius);margin-bottom:1.5rem;background:var(--surface);display:flex;flex-direction:column;align-items:center;gap:14px}.planner-app .empty-icon{width:54px;height:54px;border-radius:50%;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center}.planner-app .ccard{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm);transition:box-shadow .2s;animation:pl-fade-in .3s ease-out both}.planner-app .ccard:hover{box-shadow:var(--shadow-md)}.planner-app .chead{padding:16px 20px;color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;background:linear-gradient(135deg,var(--cat-from, #1A2942) 0%,var(--cat-to, #2c3e60) 100%);position:relative;overflow:hidden}.planner-app .chead:after{content:"";position:absolute;top:0;right:0;width:120px;height:120px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.planner-app .cname{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.01em;color:#fff;position:relative;display:flex;align-items:center;gap:8px}.planner-app .cbadges{display:flex;gap:6px;align-items:center;flex-wrap:wrap;position:relative}.planner-app .badge{font-size:11px;padding:4px 10px;border-radius:var(--radius-pill);font-weight:600;background:#ffffff2e;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.22)}.planner-app .b-blue{background:#ffffff38;color:#fff}.planner-app .b-teal{background:#14b896d9;color:#fff;border-color:transparent}.planner-app .b-gray{background:#ffffff1f;color:#fff}.planner-app .cbody{display:flex;flex-direction:column}.planner-app .csec{padding:18px 20px;border-bottom:1px solid var(--border)}.planner-app .csec:last-child{border-bottom:none}.planner-app .cbody.bf-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}.planner-app .cbody.bf-grid .csec{border-bottom:none;border-right:1px solid var(--border)}.planner-app .cbody.bf-grid .csec:last-child{border-right:none}.planner-app .sectitle{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:9px}.planner-app .sectitle:before{content:"";width:4px;height:14px;background:var(--accent);border-radius:2px}.planner-app .csec.brandformance .sectitle:before{background:var(--purple)}.planner-app .csec.videos-section .sectitle:before{background:var(--teal)}.planner-app .csec.brandformance{background:linear-gradient(180deg,#faf9ff 0%,var(--surface) 100%)}.planner-app .sf-note{font-size:11.5px;color:var(--text-2);background:var(--surface-2);border-left:3px solid var(--accent);padding:8px 11px;border-radius:0 6px 6px 0;margin-bottom:10px;line-height:1.45}.planner-app .sf-note strong{color:var(--text);font-weight:700}.planner-app .atable{width:100%;border-collapse:collapse;font-size:13px}.planner-app .atable th{font-size:10px;font-weight:700;color:var(--text-3);text-align:left;padding:7px 4px;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em}.planner-app .atable td{padding:8px 4px;border-bottom:1px solid var(--border);vertical-align:middle}.planner-app .atable tr:last-child td{border-bottom:none}.planner-app .atable tbody tr:hover{background:var(--surface-2)}.planner-app .td-name{color:var(--text);font-size:13px}.planner-app .td-name.off{color:var(--text-3)}.planner-app .fp{font-size:10px;padding:2px 7px;border-radius:var(--radius-pill);white-space:nowrap;background:var(--accent-bg);color:var(--accent-text);font-weight:600}.planner-app .td-total{text-align:right;font-weight:700;font-size:13px;font-family:var(--font-display)}.planner-app .td-total.off{color:var(--text-3);font-weight:500}.planner-app .tfoot-row td{border-top:1px solid var(--border-strong)!important;padding-top:10px!important;font-weight:700;font-size:13px;background:var(--surface-2)}.planner-app input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.planner-app .vsublabel{font-size:10.5px;font-weight:700;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;padding:14px 0 8px;display:block;margin-top:8px;border-top:1px dashed var(--border)}.planner-app .vsublabel:first-child{border-top:none;padding-top:0;margin-top:0}.planner-app .item-card{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:7px;overflow:hidden;background:var(--surface);transition:border-color .15s}.planner-app .item-card:hover{border-color:var(--border-strong)}.planner-app .item-head{display:flex;align-items:center;gap:9px;padding:9px 11px;background:var(--surface-2)}.planner-app .item-head input[type=text]{flex:1;font-size:13px;padding:5px 8px;border:1px solid var(--border);border-radius:5px;background:var(--surface);font-family:var(--font-body)}.planner-app .item-head input[type=text]:focus{outline:none;border-color:var(--accent)}.planner-app .item-chk{width:15px;height:15px;cursor:pointer;flex-shrink:0}.planner-app .item-del{font-size:14px;color:var(--text-3);cursor:pointer;background:none;border:none;line-height:1;padding:3px 6px;border-radius:5px;display:inline-flex;align-items:center}.planner-app .item-del:hover{background:var(--danger-bg);color:var(--danger)}.planner-app .item-vid{font-size:11px;color:var(--text-2);white-space:nowrap;font-weight:600;font-family:var(--font-display)}.planner-app .prod-styles{padding:10px 11px;display:flex;flex-direction:column;gap:6px}.planner-app .style-row{display:flex;align-items:center;gap:8px}.planner-app .style-row input[type=checkbox]{width:15px;height:15px;cursor:pointer;flex-shrink:0}.planner-app .style-lbl{flex:1;font-size:13px;cursor:pointer}.planner-app .style-lbl.off{color:var(--text-3)}.planner-app .rec-badge{font-size:9.5px;padding:2px 8px;border-radius:var(--radius-pill);background:var(--coral-bg);color:var(--coral-text);border:1px solid #fbcdb8;white-space:nowrap;font-weight:700;display:inline-flex;align-items:center;gap:3px}.planner-app .add-item-btn{font-size:12.5px;padding:8px 12px;cursor:pointer;border:1px dashed var(--border-strong);border-radius:var(--radius-sm);background:none;color:var(--text-2);width:100%;text-align:center;margin-top:6px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;font-family:var(--font-body)}.planner-app .add-item-btn:hover{border-color:var(--accent);color:var(--accent-text);background:var(--accent-bg);border-style:solid}.planner-app .vtot{display:flex;justify-content:space-between;font-size:13.5px;font-weight:700;border-top:1px solid var(--border-strong);padding-top:10px;margin-top:10px;font-family:var(--font-display)}.planner-app .vdest-note{font-size:10.5px;color:var(--text-3);margin-top:8px;font-style:italic}.planner-app .prod-client-name{font-size:13px;font-weight:600}.planner-app .bf-pill-cell{display:inline-flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:600;padding:4px 9px;border-radius:var(--radius-pill);border:1px solid var(--border);color:var(--text-3);cursor:pointer;background:var(--surface);transition:all .15s;-webkit-user-select:none;user-select:none;white-space:nowrap;font-family:var(--font-body)}.planner-app .bf-pill-cell:hover{border-color:var(--purple);color:var(--purple-text)}.planner-app .bf-pill-cell.on{background:var(--purple-bg);border-color:var(--purple);color:var(--purple-text);font-weight:700}.planner-app .vstep{display:inline-flex;align-items:center;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:2px;font-family:var(--font-body)}.planner-app .vstep-btn{width:18px;height:18px;border:none;background:transparent;color:var(--text-3);border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background .12s,color .12s}.planner-app .vstep-btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}.planner-app .vstep-btn:disabled{opacity:.35;cursor:not-allowed}.planner-app .vstep-num{font-size:11px;font-weight:600;color:var(--text-2);min-width:22px;text-align:center;display:inline-flex;align-items:center;justify-content:center}.planner-app .vstep-num.on{color:var(--accent-text);font-weight:700}.planner-app .video-note{margin:0 20px 14px;padding:11px 14px;border-radius:var(--radius-sm);font-size:12.5px;line-height:1.5;display:flex;align-items:flex-start;gap:9px;animation:pl-fade-in .3s ease-out both}.planner-app .video-note svg{flex-shrink:0;margin-top:1px}.planner-app .video-note.v-info{background:var(--accent-bg);color:var(--accent-text);border:1px solid #c7dcff}.planner-app .video-note.v-good{background:var(--teal-bg);color:var(--teal-text);border:1px solid #b6ead8}.planner-app .video-note.v-great{background:linear-gradient(135deg,#fff8e1,#fff1ed);color:var(--coral-text);border:1px solid #fbcdb8}.planner-app .upsell-box{margin-top:14px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-sm);padding:12px 14px;background:var(--surface-2);transition:all .18s ease}.planner-app .upsell-box.on{border-style:solid;border-color:var(--coral);background:var(--coral-bg)}.planner-app .upsell-head{display:flex;gap:11px;align-items:flex-start;cursor:pointer}.planner-app .upsell-head input[type=checkbox]{margin-top:3px;width:15px;height:15px;cursor:pointer;accent-color:var(--coral);flex-shrink:0}.planner-app .upsell-text{flex:1}.planner-app .upsell-title{font-family:var(--font-display);font-size:13.5px;font-weight:700;color:var(--text);letter-spacing:-.005em;margin-bottom:3px;display:flex;align-items:center;gap:6px}.planner-app .upsell-box.on .upsell-title{color:var(--coral-text)}.planner-app .upsell-sub{font-size:12px;color:var(--text-2);line-height:1.45}.planner-app .upsell-box.on .upsell-sub{color:var(--coral-text);opacity:.85}.planner-app .upsell-qty{display:flex;align-items:center;gap:12px;margin-top:11px;padding-top:11px;border-top:1px dashed #fbcdb8;flex-wrap:wrap}.planner-app .upsell-qty-lbl{font-size:12px;font-weight:600;color:var(--coral-text)}.planner-app .upsell-out{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--coral-text);margin-left:auto}.planner-app .cat-cost-box{background:var(--surface-2);border-top:1px solid var(--border);padding:14px 20px}.planner-app .cat-cost-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);padding:3px 0}.planner-app .cat-cost-total{display:flex;justify-content:space-between;font-size:13.5px;font-weight:700;border-top:1px solid var(--border-strong);padding-top:8px;margin-top:6px;color:var(--text);font-family:var(--font-display)}.planner-app .andromeda-alert{background:var(--warn-bg);border:1px solid var(--warn-border);border-radius:var(--radius-sm);padding:11px 15px;margin-bottom:14px;font-size:12.5px;color:var(--warn-text);display:flex;align-items:center;gap:9px;animation:pl-slide-down .25s ease-out both}.planner-app .reason-note{font-size:11.5px;color:var(--coral-text);background:var(--coral-bg);border:1px solid #fbcdb8;border-radius:6px;padding:7px 11px;margin-bottom:12px;display:flex;align-items:center;gap:7px;font-weight:500}.planner-app .scard{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px;background:var(--surface);box-shadow:var(--shadow-md);position:relative}.planner-app .scard:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-grad)}.planner-app .scard-head{padding:18px 20px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px dashed var(--border)}.planner-app .scard-title{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}.planner-app .scard-stamp{font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:var(--radius-pill);background:var(--teal-bg);color:var(--teal-text);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:5px}.planner-app .scard-stamp.warn{background:var(--warn-bg);color:var(--warn-text)}.planner-app .metgrid{display:grid;grid-template-columns:repeat(4,1fr)}.planner-app .met{padding:16px;border-right:1px solid var(--border);text-align:center}.planner-app .met:last-child{border-right:none}.planner-app .mlbl{font-size:10.5px;color:var(--text-3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.planner-app .mval{font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1}.planner-app .msub{font-size:11px;color:var(--text-3);margin-top:4px}.planner-app .met-includes{text-align:left;display:flex;flex-direction:column;justify-content:center}.planner-app .met-includes .mlbl{text-align:left}.planner-app .mincl{font-size:12px;color:var(--text-2);line-height:1.45}.planner-app .global-cost-box{padding:16px 20px;border-top:1px dashed var(--border);background:var(--surface-2)}.planner-app .global-cost-title{font-size:10.5px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:flex;align-items:center;gap:6px}.planner-app .global-cost-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);padding:4px 0;border-bottom:1px dotted var(--border)}.planner-app .global-cost-row:last-child{border-bottom:none}.planner-app .global-cost-row.fee{color:var(--teal-text);font-weight:600;font-size:13px}.planner-app .pbar{border-top:1px dashed var(--border-strong);padding:18px 20px;display:flex;justify-content:space-between;align-items:center;background:var(--surface)}.planner-app .plbl{font-size:13.5px;color:var(--text-2);font-weight:600}.planner-app .pval{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:-.025em}.planner-app .pval.green{color:var(--teal-text)}.planner-app .wdist{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px;background:var(--surface);box-shadow:var(--shadow-sm)}.planner-app .wdhead{padding:13px 18px;background:var(--surface-2);font-size:13.5px;font-weight:700;border-bottom:1px solid var(--border);font-family:var(--font-display);display:flex;align-items:center;gap:8px}.planner-app .wdgrid{display:grid;grid-template-columns:repeat(4,1fr)}.planner-app .wdwk{padding:14px;border-right:1px solid var(--border);min-height:90px}.planner-app .wdwk:last-child{border-right:none}.planner-app .wdnum{font-size:10.5px;font-weight:700;color:var(--text-3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}.planner-app .wdcat{font-size:12.5px;padding:5px 10px;margin-bottom:5px;border-radius:6px;font-weight:500;display:flex;align-items:center;gap:5px}.planner-app .wdcat:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cat-color, var(--accent))}.planner-app .login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--surface-2)}.planner-app .login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.planner-app .login-card h1{font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.planner-app .login-card p{font-size:13px;color:var(--text-2);margin-bottom:22px}.planner-app .login-card label{display:block;font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;margin-top:14px;font-weight:700}.planner-app .login-card input{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);font-family:var(--font-body)}.planner-app .login-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.planner-app .login-card button{width:100%;margin-top:22px;padding:13px;background:var(--accent-grad);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;font-weight:600;font-family:var(--font-body);box-shadow:0 6px 18px -6px #2563eb73;transition:transform .12s}.planner-app .login-card button:hover{transform:translateY(-1px)}.planner-app .login-err{font-size:12.5px;color:var(--danger);margin-top:12px}.planner-app .skel{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:pl-shimmer 1.4s linear infinite;border-radius:6px}.planner-app .skel-line{height:14px;margin:6px 0}.planner-app .skel-block{height:80px}@media(max-width:760px){.planner-app .cbody.bf-grid{grid-template-columns:1fr}.planner-app .cbody.bf-grid .csec{border-right:none;border-bottom:1px solid var(--border)}.planner-app .cbody.bf-grid .csec:last-child{border-bottom:none}}@media(max-width:720px){.planner-app{padding:1.25rem .9rem 3rem}.planner-app .ttl{font-size:24px}.planner-app .month-grid{grid-template-columns:repeat(4,1fr)}.planner-app .metgrid{grid-template-columns:repeat(2,1fr)}.planner-app .met:nth-child(2){border-right:none}.planner-app .met:nth-child(-n+2){border-bottom:1px solid var(--border)}.planner-app .wdgrid{grid-template-columns:repeat(2,1fr)}.planner-app .wdwk:nth-child(2){border-right:none}.planner-app .wdwk:nth-child(-n+2){border-bottom:1px solid var(--border)}.planner-app .sticky-bar{font-size:12px}.planner-app .sb-month{padding-right:10px}.planner-app .sb-stat strong{font-size:16px}.planner-app .pval{font-size:26px}.planner-app .scard-head{flex-direction:column;align-items:flex-start;gap:8px}}@media(max-width:480px){.planner-app{padding:1rem .75rem 2.5rem}.planner-app .ttl{font-size:21px}.planner-app .sub{font-size:12px}.planner-app .topbar{margin-bottom:1.1rem}.planner-app .reset-btn{font-size:11px;padding:5px 9px}.planner-app .month-grid{grid-template-columns:repeat(3,1fr);gap:6px}.planner-app .mchip{padding:9px 3px;font-size:12px}.planner-app .chips{grid-template-columns:1fr 1fr;gap:6px}.planner-app .chip{padding:10px 11px;font-size:12.5px}.planner-app .moment-card{padding:14px 15px;border-radius:12px}.planner-app .moment-title{font-size:15px}.planner-app .moment-sub{font-size:12px}.planner-app .moment-urgency{font-size:10px;padding:3px 9px}.planner-app .go-btn{padding:13px;font-size:13px}.planner-app .sticky-bar{padding:8px 11px;gap:9px}.planner-app .sb-month{font-size:12.5px;padding-right:8px;gap:4px}.planner-app .sb-stat{font-size:11px;gap:3px}.planner-app .sb-stat strong{font-size:14px}.planner-app .sb-price{font-size:15px}.planner-app .chead{padding:13px 15px}.planner-app .cname{font-size:15px}.planner-app .csec{padding:14px 15px}.planner-app .badge{font-size:10px;padding:3px 8px}.planner-app .atable{font-size:12px}.planner-app .atable th{font-size:9.5px;padding:6px 3px}.planner-app .atable td{padding:7px 3px}.planner-app .scard-head{padding:14px 15px 11px}.planner-app .scard-title{font-size:15px}.planner-app .met{padding:12px 8px}.planner-app .mval{font-size:21px}.planner-app .mlbl{font-size:9.5px}.planner-app .pbar{padding:14px 15px}.planner-app .pval{font-size:22px}.planner-app .plbl{font-size:12.5px}.planner-app .global-cost-box{padding:13px 15px}.planner-app .wdhead{padding:11px 14px;font-size:12.5px}.planner-app .wdwk{padding:11px 10px;min-height:75px}.planner-app .wdcat{font-size:11.5px;padding:4px 8px}.planner-app .empty{padding:2.2rem .8rem}.planner-app .empty-icon{width:46px;height:46px}}.planner-app .vmodal-backdrop{position:fixed;inset:0;background:#0f141e8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:vfadein .15s ease}@keyframes vfadein{0%{opacity:0}to{opacity:1}}.planner-app .vmodal{background:var(--surface);border-radius:14px;max-width:440px;width:100%;padding:26px 26px 22px;position:relative;box-shadow:0 20px 60px #00000040;animation:vslidein .2s ease}@keyframes vslidein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.planner-app .vmodal-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:var(--text-3);padding:6px;border-radius:6px;display:flex}.planner-app .vmodal-close:hover{background:var(--surface-2);color:var(--text)}.planner-app .vmodal-icon{width:42px;height:42px;border-radius:10px;background:var(--coral-bg,var(--surface-2));color:var(--coral,var(--accent));display:flex;align-items:center;justify-content:center;margin-bottom:12px}.planner-app .vmodal-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);margin:0 0 10px;letter-spacing:-.01em}.planner-app .vmodal-text{font-size:13.5px;color:var(--text-2);line-height:1.55;margin:0 0 10px}.planner-app .vmodal-text strong{color:var(--text);font-weight:700}.planner-app .vmodal-list{font-size:13px;color:var(--text-2);line-height:1.6;margin:0 0 4px;padding-left:18px}.planner-app .vmodal-list li{margin-bottom:3px}.planner-app .vmodal-ok{margin-top:16px;width:100%;background:var(--text);color:var(--surface);border:none;padding:10px 16px;border-radius:8px;font-weight:600;font-size:13.5px;cursor:pointer;font-family:var(--font-display)}.planner-app .vmodal-ok:hover{opacity:.9}.planner-app .basefee-card{margin-top:14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:14px 16px}.planner-app .basefee-head{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:13.5px;color:var(--text);margin-bottom:6px;letter-spacing:-.005em}.planner-app .basefee-amount{margin-left:auto;font-size:16px;color:var(--text);font-weight:700}.planner-app .basefee-desc{font-size:12.5px;color:var(--text-2);line-height:1.55}.planner-app .basefee-desc strong{color:var(--text);font-weight:600}
