:root{--black: #000;--black-card: rgba(8, 8, 8, .92);--gold-mid: #d4af37;--gold-l: #f0d875;--gold-pale: #f5e6a8;--gold-glow: rgba(212, 175, 55, .35);--text: #f5f0e6;--text-muted: #8a8278;--border: rgba(201, 162, 39, .28);--border-soft: rgba(201, 162, 39, .12);--danger: #fca5a5;--success: #6ee7b7;--warn: #fcd34d;--font-serif: "Cormorant Garamond", "Noto Serif TC", serif;--font-sans: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--black);color:var(--text);min-height:100vh;padding-bottom:78px;position:relative;overflow-x:hidden}.bg-decor{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.bg-decor:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(1px 1px at 12% 18%,rgba(240,216,117,.55) 0%,transparent 100%),radial-gradient(1px 1px at 78% 12%,rgba(212,175,55,.45) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 45% 35%,rgba(245,230,168,.35) 0%,transparent 100%)}.ribbon{position:absolute;border-radius:50%;background:linear-gradient(135deg,#a0781e8c,#d4af37bf,#f5e6a880);opacity:.55}.ribbon-tr{width:280px;height:120px;top:-30px;right:-80px;transform:rotate(-25deg)}.ribbon-bl{width:240px;height:100px;bottom:60px;left:-70px;transform:rotate(20deg);opacity:.4}.app-header,.page,.bottom-nav,.login-screen{position:relative;z-index:1}.app-header{background:linear-gradient(180deg,#000000fa,#000000d9);padding:20px 20px 18px;border-bottom:1px solid var(--border-soft);position:sticky;top:0;z-index:100}.app-header:after{content:"";display:block;height:1px;margin-top:16px;background:linear-gradient(90deg,transparent,var(--gold-mid),transparent)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:14px}.header-left{display:flex;align-items:center;gap:14px;min-width:0}.header-badge{font-family:var(--font-serif);font-size:.62rem;font-weight:600;letter-spacing:.18em;color:var(--black);background:linear-gradient(135deg,var(--gold-l),var(--gold-mid),#a8862a);padding:6px 12px;border-radius:999px;flex-shrink:0}.app-header h1{font-family:var(--font-serif);font-size:1.45rem;font-weight:700;background:linear-gradient(180deg,var(--gold-pale),var(--gold-mid),#a8862a);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-subtitle{font-family:var(--font-serif);font-style:italic;font-size:.78rem;color:#f5f0e68c;margin-top:2px}.btn-logout{flex-shrink:0;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.68rem;padding:6px 10px;border-radius:999px;cursor:pointer}.btn-logout:hover{color:var(--gold-l);border-color:var(--gold-mid)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#000000f5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border-soft);display:flex;z-index:200}.nav-btn{flex:1;border:none;background:transparent;padding:9px 2px 7px;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;font-size:.58rem;color:var(--text-muted)}.nav-btn.active{color:var(--gold-l)}.nav-btn svg{width:21px;height:21px}.nav-btn.active svg path,.nav-btn.active svg circle,.nav-btn.active svg rect{stroke:var(--gold-l)}.page{display:none;padding:16px;max-width:640px;margin:0 auto}.page.active{display:block}.card{background:var(--black-card);border:1px solid var(--border);border-radius:4px;padding:22px 20px;margin-bottom:14px}.card-title{font-family:var(--font-serif);font-size:.85rem;font-weight:600;letter-spacing:.14em;color:var(--gold-mid);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border-soft)}.hero-card{background:var(--black);border:1px solid var(--border);border-radius:4px;padding:28px 22px 22px;margin-bottom:14px;text-align:center}.hero-label{font-family:var(--font-serif);font-size:.68rem;letter-spacing:.2em;color:var(--text-muted)}.hero-script{font-family:var(--font-serif);font-style:italic;font-size:1rem;color:#f5f0e6b3;margin:4px 0}.hero-amount{font-family:var(--font-serif);font-size:2.6rem;font-weight:700;margin:8px 0 20px;background:linear-gradient(180deg,var(--gold-pale),var(--gold-mid),#a8862a);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.summary-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.summary-item{background:#0009;border:1px solid var(--border-soft);border-radius:2px;padding:12px 6px;text-align:center}.summary-num{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;color:var(--gold-l)}.summary-lbl{font-size:.62rem;color:var(--text-muted);margin-top:4px}.form-group{margin-bottom:16px}label{display:block;font-size:.72rem;color:var(--text-muted);margin-bottom:7px}input,select,textarea{width:100%;border:1px solid var(--border-soft);border-radius:2px;padding:11px 14px;font-size:.9rem;color:var(--text);font-family:var(--font-sans);background:#00000080;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--gold-mid);box-shadow:0 0 0 1px var(--gold-mid)}textarea{resize:vertical;min-height:72px}input[type=date]{cursor:pointer;position:relative;color-scheme:dark;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(78%) sepia(38%) saturate(560%) hue-rotate(2deg) brightness(102%);opacity:.9}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.cat-pills{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}.cat-pill{border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:.8rem;cursor:pointer;background:#0009;color:var(--text-muted)}.cat-pill.active{color:var(--black);border-color:transparent;background:linear-gradient(135deg,var(--gold-l),var(--gold-mid),#a8862a);font-weight:700}.subcat-section{overflow:hidden;max-height:0;opacity:0;transition:all .3s;margin-bottom:0}.subcat-section.show{max-height:520px;opacity:1;margin-bottom:14px}.subcat-label{font-family:var(--font-serif);font-size:.78rem;font-weight:600;margin-bottom:8px;color:var(--gold-mid)}.subcat-pill{border:1px solid var(--border-soft);border-radius:999px;padding:5px 12px;font-size:.76rem;cursor:pointer;background:#00000080;color:var(--text-muted)}.subcat-pill.active{color:var(--black);background:linear-gradient(135deg,var(--gold-pale),var(--gold-mid))}.subcat-custom{margin-top:10px;margin-bottom:0!important}.subcat-tag{display:inline-block;background:#c9a22726;color:var(--gold-l);border-radius:2px;padding:1px 7px;font-size:.66rem;margin-right:4px}.btn{width:100%;padding:14px;border:none;border-radius:999px;font-family:var(--font-serif);font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.12em}.btn-primary{background:linear-gradient(135deg,var(--gold-l),var(--gold-mid),#a8862a);color:var(--black);box-shadow:0 4px 20px #c9a22759}.btn-danger{background:transparent;color:var(--danger);font-size:.72rem;padding:4px 10px;width:auto;border-radius:2px;border:1px solid rgba(252,165,165,.3)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-inline{width:auto;padding:8px 14px;font-size:.82rem;letter-spacing:.06em}#toast{position:fixed;bottom:88px;left:50%;transform:translate(-50%) translateY(20px);background:#000000eb;color:var(--gold-l);border:1px solid var(--border);padding:10px 24px;border-radius:999px;font-family:var(--font-serif);opacity:0;transition:all .3s;pointer-events:none;z-index:999}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}#loading{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;pointer-events:none;transition:opacity .2s}#loading.show{opacity:1;pointer-events:all}.spinner{width:42px;height:42px;border:2px solid var(--border-soft);border-top-color:var(--gold-mid);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.expense-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border-soft)}.expense-item:last-child{border-bottom:none}.cat-badge{width:38px;height:38px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-weight:700;flex-shrink:0;border:1px solid var(--border);background:#000c}.cat-badge.食{color:#e8a090}.cat-badge.衣{color:#c9a0cc}.cat-badge.住{color:#90bce8}.cat-badge.行{color:#80cfc0}.cat-badge.娛樂{color:#e890b0}.cat-badge.其他{color:#e8c080}.expense-info{flex:1;min-width:0}.expense-notes{font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-date{font-size:.68rem;color:var(--text-muted);opacity:.6;margin-top:3px}.expense-amount{font-family:var(--font-serif);font-size:1.05rem;font-weight:700;color:var(--gold-l)}.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.filter-row select{flex:1}.badge-count{background:#c9a22726;color:var(--gold-l);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-family:var(--font-serif);font-size:.72rem}.empty-hint{text-align:center;color:var(--text-muted);padding:28px 0;font-family:var(--font-serif);font-style:italic}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 20px 40px}.login-box{width:100%;max-width:400px;text-align:center;background:var(--black-card);border:1px solid var(--border);border-radius:4px;padding:36px 28px}.login-box h1{font-family:var(--font-serif);font-size:2rem;font-weight:700;margin-bottom:8px;background:linear-gradient(180deg,var(--gold-pale),var(--gold-mid));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-box .tagline{font-family:var(--font-serif);font-style:italic;color:var(--text-muted);margin-bottom:28px}.login-box p{font-size:.85rem;color:var(--text-muted);line-height:1.65;margin-bottom:24px}.setup-error{color:#f87171;font-size:.82rem;line-height:1.6;text-align:left}.otp-hint{font-size:.82rem;color:var(--muted);margin-bottom:16px;line-height:1.5}.otp-hint strong{color:var(--gold-l);font-weight:500}.btn-link{display:block;width:100%;margin-top:14px;border:none;background:none;color:var(--gold-l);font-size:.82rem;cursor:pointer;text-decoration:underline}.btn-link:hover{color:var(--gold-pale)}.login-tabs{display:flex;gap:6px;margin-bottom:22px;border:1px solid var(--border-soft);border-radius:999px;padding:4px}.login-tab{flex:1;border:none;background:transparent;cursor:pointer;padding:9px 8px;border-radius:999px;font-size:.82rem;color:var(--text-muted);font-family:var(--font-sans)}.login-tab.active{color:var(--black);font-weight:700;background:linear-gradient(135deg,var(--gold-l),var(--gold-mid),#a8862a)}.login-switch-hint{font-size:.78rem;color:var(--text-muted);margin-top:16px;margin-bottom:0}.btn-link-inline{border:none;background:none;cursor:pointer;padding:0;color:var(--gold-l);font-size:.78rem;text-decoration:underline;font-family:var(--font-sans)}.btn-link-inline:hover{color:var(--gold-pale)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#000000c7;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px 20px}.modal-box{width:100%;max-width:400px;background:var(--black-card);border:1px solid var(--border);border-radius:6px;padding:26px 22px}.modal-box .btn-link{margin-top:8px}.hidden{display:none!important}.budget-row{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border-soft)}.budget-row:last-child{border-bottom:none}.budget-cat{width:36px;height:36px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:.82rem;font-weight:700;color:var(--gold-l);flex-shrink:0;border:1px solid var(--border);background:#0009}.budget-info{flex:1;min-width:0}.budget-name{font-size:.82rem;font-weight:500;color:var(--text)}.budget-input{width:100%;max-width:130px;padding:7px 10px;font-size:.85rem;text-align:right}.budget-progress-wrap{margin-top:8px}.budget-bar-bg{height:4px;border-radius:0;background:#c9a2271a;overflow:hidden}.budget-bar-fill{height:100%;transition:width .4s ease;background:linear-gradient(90deg,#a8862a,var(--gold-mid),var(--gold-l));box-shadow:0 0 8px var(--gold-glow)}.budget-bar-fill.over{background:linear-gradient(90deg,#991b1b,var(--danger));box-shadow:0 0 8px #fca5a54d}.budget-bar-fill.warn{background:linear-gradient(90deg,#92400e,var(--warn),var(--gold-l))}.budget-meta{display:flex;justify-content:space-between;font-size:.66rem;color:var(--text-muted);margin-top:5px}.budget-boom{margin-left:6px;display:inline-block;animation:boom-pulse 1s ease-in-out infinite}.budget-row.is-over .budget-name{color:var(--danger)}@keyframes boom-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.35) rotate(-8deg)}}.chart-wrap{position:relative;height:240px}.chart-wrap-sm{position:relative;height:200px}.compare-table,.subcat-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:14px}.compare-table th,.compare-table td,.subcat-table th,.subcat-table td{padding:9px 10px;text-align:right;border-bottom:1px solid var(--border-soft)}.compare-table th:first-child,.compare-table td:first-child,.subcat-table th:first-child,.subcat-table td:first-child{text-align:left}.compare-table th,.subcat-table th{font-family:var(--font-serif);font-weight:600;color:var(--gold-mid);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--border)}.compare-table tr:last-child td{font-family:var(--font-serif);font-weight:700;border-top:1px solid var(--border);color:var(--gold-l)}.period-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.period-row select{flex:1;min-width:110px}.hint-text{font-size:.72rem;color:var(--text-muted);margin-bottom:12px;line-height:1.6}
