:root{--cute-bg: #FFF9F5;--cute-white: #FFFFFF;--cute-pink: #FFB7C5;--cute-pink-dark: #FF9AA2;--cute-mint: #E0F7FA;--cute-mint-dark: #B2EBF2;--cute-yellow: #FFF9C4;--cute-blue: #D1EAFF;--cute-line: #F3E5DC;--cute-text: #5D40 brown;--cute-text-primary: #5D4037;--cute-text-soft: #8D6E63;--cute-shadow: 0 10px 30px rgba(215, 184, 166, .25);--cute-radius: 24px}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;background:var(--cute-bg);font-family:Rounded system fonts,SF Pro Text,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--cute-text-primary);-webkit-font-smoothing:antialiased;overflow:hidden;line-height:1.5}.page{max-width:600px;margin:0 auto;padding:0;height:100vh;display:flex;flex-direction:column;background:var(--cute-bg);position:relative}.main-content{flex:1;overflow-y:auto;padding:16px 16px 100px;-webkit-overflow-scrolling:touch;background:var(--cute-bg);position:relative}.page:before{content:"✨";position:absolute;top:15%;left:5%;font-size:20px;opacity:.4;animation:floatCute 6s infinite ease-in-out;pointer-events:none}.page:after{content:"🍓";position:absolute;bottom:15%;right:5%;font-size:24px;opacity:.3;animation:floatCute 8s infinite ease-in-out;pointer-events:none}@keyframes floatCute{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(15deg)}}.page-header{display:flex;flex-direction:column;gap:12px;padding:16px 20px 12px;background:rgba(255,249,245,.85);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border-bottom:2px solid var(--cute-line);position:sticky;top:0;z-index:100;transition:all .3s ease}@media (max-width: 600px){.page-header{padding:10px 16px 8px;gap:8px}}.header-grid-wrapper{display:grid;grid-template-columns:80px 1fr 80px;align-items:center;width:100%}.header-center-title{display:flex;justify-content:center;align-items:center;min-width:0}.cute-title-container{display:flex;align-items:center;gap:8px;position:relative;cursor:pointer}.cute-sticker{font-size:18px;animation:bounceCute 2s infinite ease-in-out}@keyframes bounceCute{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.title-mirror{visibility:hidden;white-space:pre;font-size:18px;font-weight:700;padding:0 4px}.title-input-minimal{position:absolute;left:28px;right:28px;width:calc(100% - 56px);border:none;background:transparent;text-align:center;font-size:18px;font-weight:700;color:var(--cute-text-primary);outline:none}.header-bottom-cute{display:flex;flex-direction:column;align-items:center;gap:12px;padding-top:4px}.month-pill-nav{display:flex;align-items:center;background:var(--cute-white);border:2px solid var(--cute-line);border-radius:50px;padding:4px 12px;box-shadow:0 4px 10px #00000005}.pill-arrow{background:transparent;border:none;font-size:20px;color:var(--cute-text-soft);padding:0 8px;cursor:pointer}.pill-text{font-weight:700;font-size:15px;color:var(--cute-text-primary)}.ai-hint-box{display:flex;align-items:center;gap:6px;background:var(--cute-yellow);padding:6px 14px;border-radius:12px;font-size:12px;transform:rotate(-.5deg);box-shadow:0 4px 8px #d7b8a633}.summary-section-cute{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.summary-grid-cute{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cute-card{background:var(--cute-white);border-radius:20px;padding:12px 14px;display:flex;align-items:center;gap:10px;border:2px solid var(--cute-line);box-shadow:var(--cute-shadow)}.stat-pink{background:#FFF5F7}.stat-mint{background:#F0FDFA}.stat-mint-light{background:#F5FFFA}.stat-pink-light{background:#FFF9F9}.card-icon{font-size:20px;background:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;box-shadow:0 2px 6px #0000000d}.card-label{font-size:11px;color:var(--cute-text-soft);font-weight:500}.card-value{font-size:15px;font-weight:800}.cute-budget-container{background:var(--cute-white);padding:14px 16px;border-radius:20px;border:2px solid var(--cute-line);box-shadow:var(--cute-shadow)}.budget-status-text{font-size:12px;font-weight:700;text-align:right;margin-bottom:6px}.cute-progress-bg{height:18px;background:#F3E5DC;border-radius:20px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000000d}.cute-progress-fill{height:100%;border-radius:20px;transition:width .6s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:6px;color:#fff;font-size:10px;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.2)}.cute-progress-fill.status-safe{background:linear-gradient(90deg,#A8E6CF,#10B981)}.cute-progress-fill.status-warning{background:linear-gradient(90deg,#FFD3B6,#FF8C42)}.cute-progress-fill.status-danger{background:repeating-linear-gradient(45deg,#FF9A9E,#FF9A9E 10px,#FF6B6B 10px,#FF6B6B 20px);background-size:28px 28px;animation:stripeMove 1s linear infinite;box-shadow:0 0 10px #ff6b6b66}@keyframes stripeMove{0%{background-position:0 0}to{background-position:28px 0}}.ai-analysis-row-cute{display:flex;gap:10px;margin-top:4px}.cute-ai-btn{flex:1;background:#fff;border:2px solid var(--cute-line);padding:10px;border-radius:12px;font-weight:700;font-size:13px;color:var(--cute-text-primary);box-shadow:3px 3px 0 var(--cute-line)}.cute-ai-btn.primary{background:var(--cute-pink);border-color:#ff9aa2;color:#fff;box-shadow:3px 3px #ff9aa2}.cute-card-form{background:var(--cute-white);padding:20px;border-radius:24px;border:2px solid var(--cute-line);margin-bottom:20px;box-shadow:var(--cute-shadow)}.pill-switch-cute{display:flex;background:#F5F5F5;padding:3px;border-radius:40px;margin-bottom:16px}.pill-switch-cute.full{width:100%}.pill-switch-cute .pill{flex:1;border:none;background:transparent;padding:8px;border-radius:40px;font-size:13px;font-weight:700;color:#888;cursor:pointer}.pill-switch-cute .pill.active{background:#fff;color:var(--cute-text-primary);box-shadow:0 4px 10px #0000000d}.form-grid-cute{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.form-item label{display:block;font-size:11px;font-weight:700;margin-bottom:4px;margin-left:4px}.input-cute{width:100%;background:#F9F9F9;border:2px solid transparent;border-radius:12px;padding:10px 12px;font-size:14px;outline:none;transition:all .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none}.input-cute:focus{background:#fff;border-color:var(--cute-pink)}.cute-btn-save{background:var(--cute-blue);border:none;padding:14px;width:100%;border-radius:16px;font-weight:800;color:var(--cute-text-primary);box-shadow:0 5px #b2d8f7;cursor:pointer}.cute-btn-save:active{transform:translateY(3px);box-shadow:0 2px #b2d8f7}.ai-top-module{margin-bottom:12px!important;margin-top:-4px}.hero-row-cute{display:flex;flex-direction:column;gap:12px}.smart-input-container{position:relative}.hero-input{width:100%;background:#F0F4F8;border:2px solid transparent;border-radius:14px;padding:12px 14px;font-size:14px;outline:none}.hero-preview-cute{position:absolute;top:100%;left:0;right:0;background:var(--cute-white);border:2px solid var(--cute-pink);border-radius:14px;margin-top:8px;display:flex;align-items:center;padding:8px 12px;z-index:1100;gap:8px}.date-pills-cute{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-ms-overflow-style:none;scrollbar-width:none}.date-pills-cute::-webkit-scrollbar{display:none}.date-pills-cute button{background:#fff;border:2px solid var(--cute-line);padding:6px 14px;border-radius:50px;font-size:12px;font-weight:700;white-space:nowrap}.date-pills-cute button.active{background:var(--cute-pink);border-color:#ff9aa2;color:#fff}.profile-pill{background:#F9F9F9;padding:12px 16px;border-radius:16px;display:flex;align-items:center;gap:12px;margin-bottom:16px}.profile-pill .avatar{width:44px;height:44px;background:#333;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}.profile-pill .name{font-weight:800;font-size:15px}.profile-pill .edit-btn{margin-left:auto;background:#fff;border:1px solid #ddd;padding:4px 10px;border-radius:8px;font-size:12px}.cute-btn-logout{width:100%;background:#FFF0F0;border:1px solid #FFD1D1;color:#c0392b;padding:12px;border-radius:12px;font-weight:700;margin-top:20px}.cute-tabbar{position:fixed;bottom:0;left:0;right:0;height:72px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--cute-line);z-index:1500}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:transparent}.tab-item.active{color:var(--cute-pink)}.tab-item .icon{font-size:20px}.tab-item .label{font-size:10px;font-weight:700}.list-group-cute{margin-bottom:20px}.list-date-header{position:sticky;top:0;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px 16px;font-size:13px;font-weight:700;color:var(--cute-text-primary);display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.05);z-index:10}.list-item-cute{display:flex;align-items:center;padding:12px 16px;background:#fff;border-bottom:1px solid #f9f9f9;cursor:pointer;transition:background .2s}.list-item-cute:active{background:#f5f5f5}.item-icon-circle{width:42px;height:42px;background:#F8F8F8;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin-right:12px;border:1px solid #EEE}.item-main-info{flex:1;display:flex;flex-direction:column;gap:2px}.item-cat-name{font-size:15px;font-weight:600;color:var(--cute-text-primary)}.item-note-text{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.item-right-info{text-align:right;display:flex;flex-direction:column;align-items:flex-end}.item-amount-text{font-size:16px;font-weight:700}.item-amount-text.income{color:#10b981}.item-amount-text.expense{color:var(--cute-text-primary)}.item-actions-row{display:flex;gap:8px;margin-top:4px;opacity:0;transform:translate(10px);transition:all .2s}.list-item-cute:hover .item-actions-row{opacity:1;transform:translate(0)}.action-btn-mini{background:transparent;border:1px solid #ddd;border-radius:6px;font-size:10px;padding:2px 6px;cursor:pointer;color:#666}.modal-overlay-cute{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:flex-end}.modal-content-cute{background:#fff;width:100%;border-radius:24px 24px 0 0;padding:24px}.loading-box{background:var(--cute-white);padding:24px;border-radius:20px;text-align:center;margin:auto;box-shadow:var(--cute-shadow)}.auto-grow-title:focus-within{transform:translateY(-1px)}.auto-grow-title:focus-within .signature-line{height:2px;background:rgba(26,32,44,.15)}.mini-search-minimal{display:flex;align-items:center;background:rgba(0,0,0,.04);padding:4px 10px;border-radius:12px;max-width:80px;overflow:hidden;transition:max-width .3s ease}.mini-search-minimal:focus-within{max-width:155px;background:rgba(0,0,0,.06)}.mini-search-minimal input{border:none;background:transparent;padding-left:6px;font-size:13px;width:100%;outline:none}@keyframes titlePop{0%{transform:scale(.8) translate(-50%,10px);opacity:0}to{transform:scale(1) translate(-50%,-50%);opacity:1}}@media (max-width: 480px){.title-input{max-width:110px;font-size:17px}}.title-input:focus{transform:scale(1.05)}.title-input::placeholder{color:#ccc;font-weight:400}.edit-icon{font-size:14px;opacity:.3;transition:opacity .2s;flex-shrink:0}.editable-header:hover .edit-icon{opacity:1}.mini-search{display:flex;align-items:center;background:#fff;border:1px solid #ddd;padding:6px 10px;border-radius:16px;width:140px;transition:width .2s}.mini-search:focus-within{width:180px;border-color:#999}.mini-search input{border:none;background:transparent;outline:none;font-size:12px;width:100%}.search-icon{font-size:14px;opacity:.5;margin-right:8px}.user-meta-group{display:flex;align-items:center;gap:8px}.user-badge{font-size:12px;color:#666;background:#e0e0e0;padding:2px 8px;border-radius:6px}.ghost-btn{background:none;border:1px solid #ccc;border-radius:6px;padding:3px 8px;font-size:11px;cursor:pointer;color:#666}.book-tabs{background:#e0e0e0;padding:2px;border-radius:6px;display:flex}.book-tab{border:none;background:none;padding:4px 10px;font-size:11px;border-radius:4px;cursor:pointer;color:#666}.book-tab.active{background:#fff;color:#000;font-weight:600}.smart-input-container{flex:1;position:relative}.hero-input{width:100%;border:none;padding:12px 16px;font-size:15px;background:transparent;outline:none}.hero-preview{position:absolute;top:110%;left:0;background:#333;color:#fff;padding:8px 12px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:0 10px 20px #0003;z-index:100;animation:fadeIn .2s ease-out}.date-pills-scroll{overflow-x:auto;padding:4px 0}.date-pills{display:flex;background:#f3f4f6;padding:3px;border-radius:12px;white-space:nowrap}.date-pills button{border:none;background:transparent;padding:6px 12px;font-size:12px;border-radius:8px;cursor:pointer;color:#666}.date-pills button.active{background:#fff;color:#111;font-weight:600;box-shadow:0 2px 4px #0000000d}.card{background:white;border:1px solid #eef0f4;box-shadow:0 1px 3px #00000005;padding:24px;border-radius:20px;margin-bottom:20px}.summary-card{padding:20px}.summary-row-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.stat-block-small{background:#f8f9fa;border-radius:12px;padding:16px}.summary-label{font-size:11px;color:#888;text-transform:uppercase;margin-bottom:4px;font-weight:600}.summary-value{font-size:22px;font-weight:700}.trend-text{font-size:10px;margin-top:4px;font-weight:500}.balance-big-card{display:flex;justify-content:space-between;align-items:center;padding:24px;border-radius:16px;margin-bottom:16px;color:#fff;box-shadow:0 8px 20px #00000014;transition:transform .1s}.balance-big-card.bg-green{background:linear-gradient(135deg,#10B981,#059669)}.balance-big-card.bg-red{background:linear-gradient(135deg,#EF4444,#B91C1C)}.balance-label-big{font-size:14px;opacity:.9;margin-bottom:4px}.balance-amount-big{font-size:32px;font-weight:700;line-height:1}.budget-row-clean{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid #f0f0f0;padding:12px 16px;border-radius:12px}.budget-left{min-width:80px;cursor:pointer}.budget-edit-wrapper{display:flex;align-items:center;gap:2px}.budget-input-clean{width:50px;border:none;font-size:16px;font-weight:700;color:#333;outline:none;background:transparent;padding:0}.budget-input-clean:focus{border-bottom:1px solid #333}.edit-icon-small{font-size:10px;opacity:.3}.budget-right-bar{flex:1}.budget-info-text-right{text-align:right;font-size:11px;color:#999;margin-bottom:4px}.budget-progress-bg{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.gradient-bar{height:100%;background:linear-gradient(90deg,#4ade80,#facc15,#ef4444);border-radius:3px;transition:width .8s}.positive{color:#10b981}.negative{color:#1f1f1f}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.col{display:flex;flex-direction:column;gap:20px}.full-width{grid-column:1 / -1}.card h2{font-size:16px;margin:0 0 16px;color:#111;font-weight:700}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;row-gap:16px;margin-bottom:20px}.form-item{display:flex;flex-direction:column;gap:6px}.form-item label{font-size:11px;color:#666;font-weight:600}.input{border:1px solid #e1e1e1;border-radius:8px;padding:10px;font-size:14px;background:#f9f9f9;width:100%;height:42px;box-shadow:none;transition:all .2s}.input:focus{background:#fff;border-color:#333;outline:none}.input.large-input{font-size:16px;font-weight:600}.pill-switch{display:inline-flex;background:#f3f4f6;padding:3px;border-radius:8px;margin-bottom:16px}.pill{background:none;border:none;padding:6px 14px;border-radius:6px;cursor:pointer;color:#666;font-size:13px;font-weight:500;transition:all .2s}.pill.active{background:#fff;color:#111;box-shadow:0 1px 2px #0000000d}.btn{border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:opacity .2s}.btn:active{opacity:.8}.primary-btn{background:#111;color:#fff;padding:12px;font-size:14px}.full-btn{width:100%}.small-btn{background:#e5e7eb;padding:6px 10px;color:#333;font-size:12px}.input-loading{background-image:linear-gradient(45deg,#f3f4f6 25%,#ffffff 50%,#f3f4f6 75%);background-size:200% 100%;animation:loadingShimmer 1.5s infinite;cursor:wait}@keyframes loadingShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.enter-hint{margin-left:auto;font-size:11px;color:#bbb;font-weight:400!important}.divider{display:flex;align-items:center;text-align:center;margin:16px 0;color:#ccc;font-size:12px}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #eee}.divider span{padding:0 10px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.export-btn{border-color:#10b981;color:#10b981}.export-btn:hover{background:#f0fdf4}.list-controls{display:flex;align-items:center;gap:10px}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;padding:10px;color:#888;border-bottom:1px solid #eee;font-weight:600;-webkit-user-select:none;user-select:none;transition:color .2s}.table th[onClick]:hover{color:#333;cursor:pointer}.table td{padding:12px 10px;border-bottom:1px solid #f5f5f5;vertical-align:middle}.table tr:hover{background:#fafafa}.badge{padding:3px 6px;border-radius:4px;font-size:10px;font-weight:600}.badge.expense{background:#fee2e2;color:#b91c1c}.badge.income{background:#dcfce7;color:#15803d}.amount-cell{font-family:monospace;text-align:right;font-weight:600}.delete-link{background:none;border:none;color:#999;cursor:pointer;font-size:11px;padding:4px}.delete-link:hover{color:#e54a4a;text-decoration:underline}.list-expand-btn{text-align:center;padding:12px 0;color:#666;font-size:13px;cursor:pointer;border-top:1px solid #f5f5f5;margin-top:4px;transition:color .2s}.list-expand-btn:hover{color:#111;background:#fafafa}.add-recurring-box{display:flex;gap:8px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.input.mini{padding:6px 8px;font-size:12px;height:32px}.recurring-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.recurring-item{display:flex;justify-content:space-between;background:#f9f9f9;padding:10px;border-radius:8px;font-size:12px;border:1px solid #eee}.rec-info{display:flex;align-items:center;gap:8px}.rec-day{background:#333;color:#fff;font-size:10px;padding:2px 4px;border-radius:4px;font-weight:600}.icon-btn{background:none;border:none;cursor:pointer;opacity:.5}.icon-btn:hover{opacity:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease-out}.modal-content{background:white;width:90%;max-width:400px;border-radius:16px;overflow:hidden;box-shadow:0 20px 50px #0003}.modal-header{padding:14px 18px;background:#f9f9f9;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.modal-body{max-height:60vh;overflow-y:auto}.close-btn{background:none;border:none;font-size:20px;color:#999;cursor:pointer}.empty,.empty-text{text-align:center;color:#999;padding:20px;font-size:12px}.chart-wrapper{height:220px;width:100%}.footer{text-align:center;padding:30px 0 20px;color:#ccc;font-size:11px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.bubble-group{cursor:pointer}.bubble-group:hover .bubble-circle{filter:brightness(1.15);stroke:#fff;stroke-width:2px;opacity:.95}.bubble-group text{pointer-events:none;-webkit-user-select:none;user-select:none;font-family:SF Pro Display,-apple-system,sans-serif}@keyframes floatBubble{0%{transform:translate(0)}50%{transform:translateY(-5px)}to{transform:translate(0)}}@media (max-width: 800px){.header-top-row{flex-direction:column;align-items:flex-start;gap:12px}.header-utilities{width:100%;justify-content:space-between}.header-hero-row{flex-direction:column;align-items:stretch;padding:12px}.smart-input-container{width:100%}.date-pills-scroll{width:100%;overflow-x:auto}.mini-search{width:auto;flex:1;max-width:150px}.list-controls .search-box{width:120px!important}.two-col{grid-template-columns:1fr}.budget-row-clean{flex-direction:column;align-items:stretch;gap:8px}.budget-left{display:flex;justify-content:space-between;width:100%}.card{padding:16px;border-radius:16px}.balance-amount-big{font-size:28px}.form-grid{grid-template-columns:1fr!important;gap:12px}}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f3f4f6 0%,#e5e7eb 100%);padding:20px}.login-card{background:white;width:100%;max-width:400px;padding:40px;border-radius:24px;box-shadow:0 20px 60px -10px #0000001a;text-align:center}.login-header h1{font-size:24px;margin:10px 0}.login-btn{margin-top:24px;height:44px;width:100%;background:#111;color:#fff;border-radius:12px;font-weight:600;cursor:pointer;border:none}@media (min-width: 769px){.tabbar{display:none}}.tabbar{position:fixed;bottom:0;left:0;right:0;height:65px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid #f0f0f0;display:flex;justify-content:space-around;align-items:center;z-index:1000;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 10px #00000008}.tab-item{display:flex;flex-direction:column;align-items:center;font-size:11px;color:#888;cursor:pointer;transition:all .2s;flex:1;padding:8px 0}.tab-item span{font-size:20px;margin-bottom:2px;transition:transform .2s}.tab-item.active{color:#111;font-weight:700}.tab-item.active span{transform:translateY(-2px)}.hero-preview-editable{position:absolute;top:110%;left:0;right:0;background:white;border:1px solid #e5e7eb;padding:8px;border-radius:12px;display:flex;align-items:center;gap:8px;box-shadow:0 10px 25px #0000001a;z-index:100;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.preview-select{border:none;background:#f3f4f6;padding:6px 8px;border-radius:8px;font-size:12px;outline:none;max-width:80px}.preview-amount-wrapper{display:flex;align-items:center;background:#f3f4f6;padding:6px 8px;border-radius:8px;width:70px}.preview-amount-wrapper span{font-size:12px;color:#666;margin-right:2px}.preview-input-amount{border:none;background:transparent;width:100%;font-weight:700;font-size:13px;outline:none;padding:0}.preview-input-note{flex:1;border:none;border-bottom:1px dashed #ccc;padding:6px 4px;font-size:12px;outline:none;min-width:50px}.preview-input-note:focus{border-bottom-color:#333}.preview-save-btn{background:#111;color:#fff;border:none;border-radius:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px}.preview-save-btn:hover{opacity:.9}@media (max-width: 600px){.hero-preview-editable{flex-wrap:wrap}.preview-input-note{width:100%;order:3}.preview-save-btn{margin-left:auto;order:2}}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:0}input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.preview-amount-wrapper{display:flex;align-items:center;background:#f3f4f6;padding:6px 10px;border-radius:8px;width:auto;min-width:80px}.preview-amount-wrapper span{font-size:14px;color:#666;margin-right:4px;flex-shrink:0}.preview-input-amount{border:none;background:transparent;width:100%;font-weight:700;font-size:14px;outline:none;padding:0;color:#111}.preview-amount-wrapper{flex:0 0 auto;min-width:100px!important;max-width:140px}.preview-input-amount{width:100%!important;min-width:0;text-align:left}.cute-card-plain{background:var(--cute-white);border-radius:var(--cute-radius);padding:20px;border:2px solid var(--cute-line);box-shadow:var(--cute-shadow);margin-bottom:20px}.cute-card-plain.full-width{width:100%}.cute-card-plain h3{margin-top:0;margin-bottom:20px;font-size:16px;color:var(--cute-text-primary);display:flex;align-items:center;gap:8px}.add-recurring-pill-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.form-item-row-cute{display:flex;gap:8px;align-items:center}.recurring-list-cute{display:flex;flex-direction:column;gap:10px}.rec-item-cute{display:flex;align-items:center;justify-content:space-between;background:var(--cute-bg);padding:12px 16px;border-radius:12px;border:1px solid var(--cute-line)}.rec-btns{display:flex;gap:8px}.rec-btns button{background:var(--cute-white);border:1px solid var(--cute-line);width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}.profile-pill{background:var(--cute-white);padding:12px 16px;border-radius:16px;display:flex;align-items:center;gap:12px;margin-bottom:16px;border:2px solid var(--cute-line);box-shadow:var(--cute-shadow)}.avatar{width:44px;height:44px;background:var(--cute-text-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;border:2px solid var(--cute-white);box-shadow:0 4px 8px #0000001a}.user-info .name{font-weight:800;font-size:15px;color:var(--cute-text-primary)}.profile-pill .edit-btn{background:var(--cute-white);border:2px solid var(--cute-line);padding:4px 12px;border-radius:10px;font-size:12px;font-weight:700;color:var(--cute-text-primary);box-shadow:2px 2px 0 var(--cute-line);cursor:pointer;margin-left:auto}.profile-pill .edit-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--cute-line)}.card-header-cute{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-controls-cute{display:flex;gap:10px;align-items:center}.search-box-cute{background:var(--cute-bg);padding:6px 12px;border-radius:30px;display:flex;align-items:center;gap:6px;font-size:13px;border:1px solid var(--cute-line)}.search-box-cute input{border:none;background:transparent;outline:none;width:80px;font-size:13px}.export-btn{padding:6px;border-radius:8px;background:var(--cute-white);border:1px solid var(--cute-line);cursor:pointer}.empty{padding:40px;text-align:center;color:var(--cute-text-soft);font-size:14px;font-style:italic}.modal-header{margin-bottom:20px}.modal-header h3{margin:0;font-size:18px;font-weight:800}.cute-btn-logout{width:100%;background:#FFF0F0;border:2px solid #FFD1D1;color:#c0392b;padding:12px;border-radius:12px;font-weight:700;margin-top:20px;cursor:pointer;transition:all .2s}.cute-btn-logout:active{transform:scale(.98);background:#FFE5E5}@media (max-width: 600px){.header-grid-wrapper{grid-template-columns:40px 1fr 40px}.tab-view{padding-bottom:100px}.cute-card-plain{padding:16px}.form-grid-cute{grid-template-columns:1fr}}.fab-chat-btn{position:fixed;z-index:9999;width:56px;height:56px;border-radius:50%;background:#111;color:#fff;border:none;box-shadow:0 4px 15px #0003;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;user-select:none;-webkit-user-select:none;touch-action:none}.fab-chat-btn:active{transform:scale(.95);box-shadow:0 2px 8px #0003}.fab-icon{font-size:22px;line-height:1;margin-bottom:2px}.fab-badge{font-size:9px;font-weight:800;text-transform:uppercase;opacity:.9}.ai-report{background:#fff;border-top:5px solid #FFB7C5}.report-container{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.report-section{display:flex;gap:12px;padding:12px;border-radius:16px;position:relative;overflow:hidden}.section-icon{font-size:24px;background:rgba(255,255,255,.6);width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.section-content{flex:1}.report-label{font-size:10px;opacity:.6;font-weight:700;text-transform:uppercase;margin-bottom:4px;letter-spacing:1px}.roast-box{background:#FFF0F3;border:1px solid #FFCCD5}.roast-text-highlight{color:#c0392b;font-weight:700;font-size:14px;line-height:1.5}.blackhole-box{background:#34495E;color:#fff}.blackhole-box .section-icon{background:rgba(255,255,255,.1)}.blackhole-box .report-label{color:#bdc3c7;opacity:1}.blackhole-text{font-size:15px;font-weight:800;color:#f1c40f}.suspects-box{background:#F9F9F9;border:2px dashed #E0E0E0;flex-direction:column;gap:8px;padding:14px}.report-label-row{font-size:12px;font-weight:700;color:#7f8c8d;margin-bottom:4px}.suspect-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #eee}.suspect-item:last-child{border-bottom:none}.suspect-info{font-size:13px;font-weight:600;color:#2c3e50}.suspect-comment{font-size:12px;color:#e74c3c;font-style:italic;max-width:60%;text-align:right}.advice-box{background:#E8F8F5;border:1px solid #D1F2EB}.advice-text{font-size:13px;color:#16a085;line-height:1.4}.promise-zone{margin-bottom:16px}.promise-input{width:100%;height:80px;padding:12px;border-radius:12px;border:2px solid #EEE;background:#FAFAFA;font-size:14px;resize:none;transition:all .2s}.promise-input:focus{background:#fff;border-color:#ffb7c5;outline:none}.roast-text-fallback{white-space:pre-wrap;background:#f8f9fa;padding:16px;border-radius:12px;font-size:14px;color:#333;margin-bottom:20px}.home-book-switch-container{display:flex;justify-content:center;margin-bottom:16px;margin-top:4px}.book-switch-capsule{position:relative;display:flex;background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px;border-radius:40px;border:2px solid var(--cute-line);box-shadow:0 4px 10px #00000008}.switch-item{position:relative;z-index:2;border:none;background:transparent;padding:6px 24px;font-size:14px;font-weight:700;color:#999;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .3s;min-width:90px;justify-content:center}.switch-item.active{color:var(--cute-text-primary)}.switch-icon{font-size:16px}.switch-slider{position:absolute;top:4px;bottom:4px;width:calc(50% - 4px);background:#fff;border-radius:30px;box-shadow:0 2px 6px #0000001a;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1}.switch-slider.left{transform:translate(0)}.switch-slider.right{transform:translate(100%)}.budget-edit-wrapper-cute{display:flex;align-items:baseline;gap:2px}.budget-symbol{font-size:14px;font-weight:700;color:var(--cute-text-primary)}.budget-input-cute{background:transparent;border:none;border-bottom:2px dashed transparent;width:70px;font-size:15px;font-weight:800;color:var(--cute-text-primary);padding:0;outline:none;transition:all .2s;font-family:inherit}.budget-input-cute:focus{border-bottom-color:var(--cute-pink)}.card-content:hover .budget-input-cute{border-bottom-color:#0000001a}.theme-blue{--cute-bg: #E3F2FD;--cute-white: #FFFFFF;--cute-pink: #64B5F6;--cute-pink-dark: #42A5F5;--cute-mint: #E8EAF6;--cute-mint-dark: #C5CAE9;--cute-yellow: #E1F5FE;--cute-line: #BBDEFB;--cute-text-primary: #1565C0;--cute-text-soft: #5C6BC0;--cute-shadow: 0 10px 30px rgba(33, 150, 243, .15)}.theme-forest{--cute-bg: #F1F8E9;--cute-white: #FFFFFF;--cute-pink: #81C784;--cute-pink-dark: #66BB6A;--cute-mint: #F9FBE7;--cute-mint-dark: #DCEDC8;--cute-yellow: #FFFDE7;--cute-line: #DCEDC8;--cute-text-primary: #33691E;--cute-text-soft: #558B2F;--cute-shadow: 0 10px 30px rgba(76, 175, 80, .15)}.theme-dark{--cute-bg: #121212;--cute-white: #1E1E1E;--cute-pink: #BB86FC;--cute-pink-dark: #9955FF;--cute-mint: #2C2C2C;--cute-mint-dark: #383838;--cute-yellow: #2A2A2A;--cute-blue: #333333;--cute-line: #333333;--cute-text-primary: #E0E0E0;--cute-text-soft: #A0A0A0;--cute-shadow: 0 10px 30px rgba(0, 0, 0, .5)}.theme-dark .cute-title-container input{color:#fff}.theme-dark .summary-grid-cute .cute-card{background:#1E1E1E;border-color:#333}.theme-dark .stat-pink,.theme-dark .stat-mint,.theme-dark .stat-mint-light,.theme-dark .stat-pink-light{background:#252525}.theme-dark .input-cute,.theme-dark .hero-input{background:#2C2C2C;color:#fff}.theme-dark .pill-switch-cute{background:#333}.theme-dark .pill-switch-cute .pill.active{background:#555;color:#fff}.theme-dark .search-box-cute input{color:#fff}.theme-dark .table-cute th,.theme-dark .table-cute tr:hover{background:#252525}.theme-dark .modal-content-cute{background:#1E1E1E}.theme-dark .cute-tabbar{background:rgba(30,30,30,.95);border-top-color:#333}.theme-dark .tab-item{color:#888}.theme-dark .tab-item.active{color:#bb86fc}.theme-selector-row{display:flex;gap:12px;overflow-x:auto;padding:4px 2px}.theme-option-btn{display:flex;flex-direction:column;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;min-width:60px}.theme-preview-circle{width:40px;height:40px;border-radius:50%;box-shadow:0 4px 10px #0000001a;border:2px solid transparent;transition:all .2s;position:relative}.theme-option-btn.active .theme-preview-circle{transform:scale(1.1);border-color:var(--cute-text-primary)}.theme-option-btn.active .theme-preview-circle:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.theme-name{font-size:11px;font-weight:700;color:var(--cute-text-soft)}.ai-analysis-row-cute{display:flex;flex-direction:column;gap:12px;margin-top:16px}.tone-selector{display:flex;justify-content:center;align-items:center;gap:8px;background:var(--cute-surface);padding:8px;border-radius:20px}.tone-label{font-size:13px;font-weight:600;color:var(--cute-text-soft);margin-right:4px}.tone-btn{border:1px solid var(--cute-border);background:transparent;padding:6px 12px;border-radius:16px;font-size:13px;cursor:pointer;transition:all .2s;color:var(--cute-text-soft)}.tone-btn.active{background:var(--cute-primary);color:#fff;border-color:var(--cute-primary);font-weight:600}.theme-dark .tone-btn.active{color:#333}.analysis-btns{display:flex;gap:12px}.report-container{display:flex;flex-direction:column;gap:16px;padding-bottom:20px}.report-section{background:var(--cute-bg-soft);border-radius:16px;padding:16px;position:relative;border:1px solid rgba(0,0,0,.02)}.report-label{font-size:12px;font-weight:700;color:var(--cute-text-soft);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.report-text,.advice-text{font-size:15px;line-height:1.6;color:var(--cute-text-primary)}.roast-box.tone-toxic{background:#FFE5E5;border:1px solid #FFCDCD}.theme-dark .roast-box.tone-toxic{background:#4a2c2c;border-color:#5c3a3a}.roast-box.tone-warm{background:#FFF8E1;border:1px solid #FFE082}.theme-dark .roast-box.tone-warm{background:#4a422c;border-color:#5c533a}.roast-box.tone-neutral{background:#E3F2FD;border:1px solid #BBDEFB}.theme-dark .roast-box.tone-neutral{background:#2c3a4a;border-color:#3a4a5c}.roast-text-highlight{font-size:16px;font-weight:500;color:var(--cute-text-primary)}.section-icon{position:absolute;top:-10px;right:-5px;font-size:32px;transform:rotate(10deg);opacity:.2}.report-grid-row{display:flex;gap:12px}.report-section.half{flex:1}.good-box{background:#E8F5E9}.theme-dark .good-box{background:#2c4a3a}.bad-box{background:#FFEBEE}.theme-dark .bad-box{background:#4a2c2c}.report-list{padding-left:16px;margin:0;font-size:13px;color:var(--cute-text-primary)}.blackhole-text{font-weight:700;color:#d32f2f;font-size:15px;text-align:center;padding:10px 0}.theme-dark .blackhole-text{color:#ffcdcd}.habit-tag{display:inline-block;background:rgba(0,0,0,.05);padding:4px 8px;border-radius:8px;font-size:12px;margin-right:6px;margin-bottom:6px;color:var(--cute-text-soft)}.theme-dark .habit-tag{background:rgba(255,255,255,.1)}.status-row{display:flex;flex-direction:column;gap:6px;margin-top:10px;font-size:13px;color:var(--cute-text-soft)}.suspects-list{display:flex;flex-direction:column;gap:10px}.suspect-item{background:rgba(255,255,255,.5);padding:10px;border-radius:10px;font-size:13px}.theme-dark .suspect-item{background:rgba(0,0,0,.2)}.suspect-info{font-weight:600;margin-bottom:4px}.suspect-comment{color:#e91e63;font-style:italic}.warning-box{background:#FFF3CD;color:#856404;display:flex;align-items:center;gap:12px}.chat-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3000;display:flex;justify-content:center;align-items:center;animation:fadeIn .2s forwards;padding:20px;overscroll-behavior:contain;touch-action:none}.chat-container{width:100%;max-width:480px;height:80vh;max-height:700px;background:#f9f9f9;border-radius:24px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d;transform:scale(.95);animation:popIn .3s cubic-bezier(.16,1,.3,1) forwards}.chat-header{background:white;padding:16px 20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.chat-header h3{margin:0;font-size:16px;font-weight:700;color:#111}.clear-btn,.close-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;color:#666;transition:color .2s}.clear-btn:hover,.close-btn:hover{color:#111}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:#f5f6fa;-webkit-overflow-scrolling:touch}.message{display:flex;max-width:88%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.bubble{padding:12px 16px;border-radius:18px;font-size:15px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message.user .bubble{background:#111;color:#fff;border-bottom-right-radius:4px}.message.assistant .bubble{background:white;color:#333;box-shadow:0 2px 8px #0000000d;border-bottom-left-radius:4px}.typing{color:#999;font-style:italic;font-size:13px}.chat-input-box{background:white;padding:12px 16px;border-top:1px solid #eee;display:flex;gap:10px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.chat-input-box input{flex:1;padding:12px 16px;border:1px solid #e5e7eb;border-radius:24px;font-size:15px;outline:none;background:#f9f9f9;transition:all .2s}.chat-input-box input:focus{background:white;border-color:#333;box-shadow:0 0 0 2px #0000000d}.send-btn{background:#111;color:#fff;border:none;padding:0 20px;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;flex-shrink:0}.send-btn:disabled{opacity:.5}@keyframes fadeIn{to{opacity:1}}@keyframes popIn{to{transform:scale(1)}}.bubble-wrapper{display:flex;flex-direction:column;gap:8px}.action-card{background:white;border:1px solid #e5e7eb;border-radius:14px;padding:14px;margin-top:4px;box-shadow:0 4px 12px #0000000d;display:flex;justify-content:space-between;align-items:center;min-width:260px;gap:12px;animation:slideUp .3s ease-out}.action-card.create{border-left:4px solid #10b981}.action-card.update{border-left:4px solid #f59e0b;background:#fffbeb}.action-card.done{opacity:.6;filter:grayscale(1)}.action-info{flex:1}.action-title{font-size:11px;font-weight:700;color:#666;text-transform:uppercase;margin-bottom:2px}.action-title.warning{color:#b45309}.action-detail{font-size:15px;font-weight:700;color:#111}.action-desc{font-size:12px;color:#666;margin-top:2px}.action-confirm-btn{background:#111;color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.action-done-badge{font-size:12px;color:#15803d;font-weight:600;background:#dcfce7;padding:4px 8px;border-radius:6px}.system-tip{font-size:12px;color:#ef4444;margin-top:4px;background:#fef2f2;padding:6px 10px;border-radius:8px}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 600px){.chat-overlay{align-items:flex-end;padding:0}.chat-container{width:100%;max-width:100%;height:92vh;max-height:none;border-radius:24px 24px 0 0;transform:translateY(100%);animation:slideUpSheet .3s cubic-bezier(.32,.72,0,1) forwards;margin-bottom:0}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.chat-input-box input{font-size:16px}.chat-input-box{padding-bottom:calc(12px + env(safe-area-inset-bottom))}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Source Sans Pro,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
