.bank-category-label{padding:6px 14px;font-size:.72rem;font-weight:800;color:var(--accent-orange);background:var(--accent-orange-pale);border-radius:var(--radius-sm);margin:8px 0 4px;letter-spacing:.05em;text-transform:uppercase}.exclude-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:.65rem;font-weight:800;color:#666;background:#eee;border-radius:var(--radius-full);margin-left:6px;vertical-align:middle;border:1px solid #ddd}:root.dark-theme .exclude-badge{background:#334155;color:#94a3b8;border-color:#475569}.bank-sort-handle{position:absolute;top:10px;right:46px;font-size:1.1rem;color:var(--text-muted);cursor:grab;padding:4px 6px;border-radius:var(--radius-sm);transition:all .2s;line-height:1;user-select:none;-webkit-user-select:none}.bank-sort-handle:hover{color:var(--accent-orange);background:var(--accent-orange-pale)}.bank-sort-handle:active{cursor:grabbing}.bank-card{position:relative}.bank-sort-placeholder{border-radius:var(--radius-lg);background:#ffa30d12;border:2px dashed rgba(255,163,13,.35);flex-shrink:0;pointer-events:none}.bank-sort-ghost{opacity:.3;background:var(--accent-orange-pale);border:2px dashed var(--accent-orange);border-radius:var(--radius-md)}.bank-sort-chosen{opacity:1!important;transform:scale(.95);box-shadow:var(--shadow-md)!important;border-color:var(--accent-orange)!important;z-index:998}.bank-sort-drag{opacity:.95!important;transform:scale(.9);box-shadow:var(--shadow-lg)!important;border:4px solid var(--accent-orange)!important;cursor:grabbing!important;z-index:999}:root{--bg-primary: #f5f6fa;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #fff8f0;--bg-modal: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #222222;--text-secondary: #555555;--text-muted: #999999;--text-accent: #e8870a;--accent-orange: #FFA30D;--accent-orange-light: #FFB84D;--accent-orange-pale: #FFF3DC;--accent-orange-glow: rgba(255, 163, 13, .2);--accent-blue: #4A86E8;--accent-blue-light: #6DA0FF;--accent-blue-pale: #EBF1FC;--accent-blue-glow: rgba(74, 134, 232, .2);--accent-green: #27ae60;--accent-green-pale: #e8f8ef;--accent-green-glow: rgba(39, 174, 96, .2);--accent-red: #e74c3c;--accent-red-pale: #fdf0ef;--gradient-primary: linear-gradient(135deg, #FFA30D, #FF6B35);--gradient-blue: linear-gradient(135deg, #4A86E8, #5B9BFF);--gradient-card: linear-gradient(160deg, #ffffff, #fafbff);--gradient-hero: linear-gradient(135deg, #FFF8EC 0%, #FFF3DC 100%);--border-color: #e8eaed;--border-active: #FFA30D;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-orange: 0 4px 16px rgba(255, 163, 13, .25);--shadow-blue: 0 4px 16px rgba(74, 134, 232, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--font-sans: "Noto Sans JP", "Inter", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;--z-dropdown: 100;--z-modal: 200;--z-toast: 300;--z-drag: 400}:root.dark-theme{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-card-hover: #334155;--bg-modal: #1e293b;--bg-overlay: rgba(0, 0, 0, .8);--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-accent: #fbbf24;--accent-orange-pale: rgba(251, 191, 36, .1);--accent-orange-glow: rgba(251, 191, 36, .15);--accent-blue-pale: rgba(59, 130, 246, .1);--accent-blue-glow: rgba(59, 130, 246, .15);--accent-green-pale: rgba(16, 185, 129, .1);--accent-green-glow: rgba(16, 185, 129, .15);--accent-red-pale: rgba(239, 68, 68, .1);--gradient-card: linear-gradient(160deg, #1e293b, #0f172a);--gradient-hero: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);--border-color: #334155;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5)}body,.app-header,.bank-card,.bank-detail-header,.unallocated-bar,.purpose-card,.modal-content,.login-screen,.header-icon-btn,.add-bank-btn,.add-purpose-btn{transition:background .3s ease,background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}#app{min-height:100vh;min-height:100dvh;position:relative}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:2rem;background:var(--gradient-hero);position:relative;overflow:hidden}:root.dark-theme .login-screen{background:linear-gradient(160deg,#0f172a,#1e293b)}.login-screen:before{content:"";position:absolute;top:-60px;right:-60px;width:260px;height:260px;background:radial-gradient(circle,rgba(255,163,13,.15) 0%,transparent 70%);border-radius:50%}.login-screen:after{content:"";position:absolute;bottom:-80px;left:-60px;width:300px;height:300px;background:radial-gradient(circle,rgba(74,134,232,.1) 0%,transparent 70%);border-radius:50%}.login-logo{width:90px;height:90px;margin-bottom:1.5rem;animation:logoFloat 3s ease-in-out infinite;filter:drop-shadow(0 8px 16px rgba(255,163,13,.3));position:relative;z-index:1}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.login-title{font-size:clamp(1.6rem,7vw,2.2rem);font-weight:800;color:var(--accent-orange);margin-bottom:.5rem;position:relative;z-index:1;letter-spacing:-.02em;word-break:keep-all}.login-subtitle{color:var(--text-secondary);font-size:1rem;margin-bottom:2.5rem;text-align:center;line-height:1.8;position:relative;z-index:1;font-weight:500}.login-features{display:flex;gap:16px;margin-bottom:2rem;position:relative;z-index:1;flex-wrap:wrap;justify-content:center}.login-feature-item{display:flex;align-items:center;gap:6px;padding:6px 14px;background:var(--bg-secondary);border-radius:var(--radius-full);font-size:.82rem;font-weight:600;color:var(--text-secondary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.login-feature-item .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-orange)}.login-btn{display:flex;align-items:center;gap:12px;padding:15px 36px;border-radius:var(--radius-full);border:none;background:var(--gradient-primary);color:#fff;font-size:1rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-orange);position:relative;z-index:1}.login-btn:hover{box-shadow:0 6px 24px #ffa30d66;transform:translateY(-2px)}.login-btn:active{transform:scale(.98)}.login-btn svg{width:22px;height:22px}.login-demo-btn{margin-top:1rem;padding:12px 24px;border-radius:var(--radius-full);border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all .3s;position:relative;z-index:1}.login-demo-btn:hover{border-color:var(--accent-orange);color:var(--accent-orange);background:var(--accent-orange-pale)}.app-header{position:sticky;top:0;z-index:50;background:var(--bg-secondary);border-bottom:2px solid var(--accent-orange);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #ffa30d1a;gap:8px}.header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.header-logo{width:24px;height:24px;color:var(--accent-orange);display:flex;align-items:center;justify-content:center}.header-logo svg{width:100%;height:100%}.header-title{font-size:1rem;font-weight:800;color:var(--accent-orange);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:480px){.header-logo{width:28px;height:28px}.header-title{font-size:1.15rem;max-width:none}}.header-right{display:flex;align-items:center;gap:4px;flex-shrink:0}.header-icon-btn{background:none;border:none;color:var(--text-secondary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--bg-primary);flex-shrink:0}.header-icon-btn:hover{color:var(--accent-orange);background:var(--accent-orange-pale)}.header-user{width:36px;height:36px;border-radius:50%;flex-shrink:0;margin-left:2px;border:2px solid var(--accent-orange);cursor:pointer;overflow:hidden;transition:all .3s;box-shadow:var(--shadow-sm)}.header-user:hover{box-shadow:var(--shadow-orange);transform:scale(1.05)}.header-user img{width:100%;height:100%;object-fit:cover}.header-back-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-full);transition:all .2s}.header-back-btn:hover{border-color:var(--accent-orange);color:var(--accent-orange);background:var(--accent-orange-pale)}.bank-list-page{padding:24px 16px 100px;max-width:800px;margin:0 auto}.page-title{font-size:1.6rem;font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.02em}.page-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:20px;font-weight:500}.total-balance-card{background:var(--gradient-primary);border-radius:var(--radius-xl);padding:24px 22px;margin-bottom:24px;position:relative;overflow:hidden;box-shadow:var(--shadow-orange)}.total-balance-card:before{content:"";position:absolute;right:-10px;top:50%;transform:translateY(-50%);width:100px;height:100px;background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'><path d='M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z'></path><polyline points='3.27 6.96 12 12.01 20.73 6.96'></polyline><line x1='12' y1='22.08' x2='12' y2='12'></line><line x1='16.5' y1='9.4' x2='7.5' y2='4.21'></line></svg>");background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.15}.total-balance-label{font-size:.8rem;color:#ffffffd9;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}.total-balance-amount{font-size:2.4rem;font-weight:900;color:#fff;letter-spacing:-.03em;line-height:1}.total-balance-amount .currency{font-size:1.1rem;font-weight:600;opacity:.85;margin-left:4px}.total-balance-info{margin-top:16px;display:flex;gap:20px}.balance-info-item{display:flex;flex-direction:column;gap:2px}.balance-info-item .label{font-size:.72rem;color:#ffffffb3;font-weight:600}.balance-info-item .value{font-size:1rem;font-weight:700;color:#fffffff7}.bank-grid{display:grid;grid-template-columns:1fr;gap:12px}.bank-grid.multiple{grid-template-columns:repeat(2,1fr);gap:10px}@media(min-width:600px){.bank-grid{grid-template-columns:repeat(2,1fr);gap:16px}}.bank-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;transition:scale .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,border-color .2s ease;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.bank-card:after{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--gradient-primary);opacity:0;transition:opacity .25s}@media(hover:hover){.bank-card:hover{transform:translateY(-3px);border-color:var(--accent-orange);box-shadow:var(--shadow-orange);background:var(--bg-card-hover)}.bank-card:hover:after{opacity:1}}.bank-card:active{transform:scale(.98);border-color:var(--accent-orange)}.bank-card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.bank-name{font-size:.9rem;font-weight:700;color:var(--text-primary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bank-account-count{font-size:.75rem;color:var(--text-muted);margin-top:2px;font-weight:500}.bank-card-balance{display:flex;flex-direction:column;align-items:flex-start;margin-top:auto}.bank-balance-label{font-size:.72rem;color:var(--text-muted);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.bank-balance-amount{font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.bank-balance-amount .currency{font-size:.85rem;color:var(--text-muted);margin-left:2px}.bank-arrow{color:var(--accent-orange);transition:transform .3s;opacity:.6}.bank-card:hover .bank-arrow{transform:translate(4px);opacity:1}.add-bank-btn{background:var(--bg-secondary);border:2px dashed var(--accent-orange);border-radius:var(--radius-lg);padding:28px 20px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--accent-orange);font-family:var(--font-sans);font-size:.95rem;font-weight:700;transition:all .25s;width:100%;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.add-bank-btn *{pointer-events:none}.add-bank-btn:hover{background:var(--accent-orange-pale);box-shadow:var(--shadow-orange);transform:translateY(-2px)}.add-bank-btn:active{transform:scale(.98)}.add-bank-btn .icon{width:48px;height:48px;border-radius:50%;background:var(--accent-orange-pale);border:2px solid rgba(255,163,13,.3);display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all .25s}.add-bank-btn:hover .icon{background:var(--bg-card);transform:scale(1.1) rotate(10deg)}.bank-detail-page{padding:20px 16px 100px;max-width:800px;margin:0 auto}.bank-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding:16px 18px;background:var(--bg-card);border-radius:var(--radius-lg);border:2px solid var(--border-color);box-shadow:var(--shadow-sm)}.bank-detail-info h2{font-size:1.25rem;font-weight:800;color:var(--text-primary)}.bank-detail-balance{font-size:.85rem;color:var(--text-muted);margin-top:3px;font-weight:500}.bank-detail-balance span{color:var(--accent-orange);font-weight:700}.unallocated-bar{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);cursor:grab;transition:all .25s;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.unallocated-bar:hover{border-color:var(--accent-orange);box-shadow:var(--shadow-orange)}.unallocated-bar.drop-target{border-color:var(--accent-green);box-shadow:0 0 0 3px #27ae6033;background:var(--accent-green-pale)}.unallocated-label{font-size:.875rem;color:var(--text-secondary);font-weight:600;display:flex;align-items:center;gap:6px}.unallocated-label:before{content:"📦";font-size:1.1rem}.unallocated-amount{font-size:1.4rem;font-weight:800;color:var(--accent-green);letter-spacing:-.02em}.unallocated-amount .currency{font-size:.8rem;margin-left:2px}.purpose-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:600px){.purpose-grid{grid-template-columns:repeat(2,1fr)}}.purpose-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:18px;position:relative;transition:all .25s;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-sm)}.purpose-card:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-blue);transform:translateY(-2px)}.purpose-card.dragging{opacity:.5;transform:scale(.95);cursor:grabbing}.purpose-card.drop-target{border-color:var(--accent-blue);box-shadow:0 0 0 3px #4a86e840;background:var(--accent-blue-pale);transform:scale(1.02)}.purpose-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.purpose-card-left{display:flex;align-items:center;gap:10px}.purpose-emoji{font-size:1.6rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid rgba(0,0,0,.06)}.purpose-name{font-size:.95rem;font-weight:700;color:var(--text-primary)}.purpose-card-menu{padding:4px 8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);font-size:1rem;transition:all .2s}.purpose-card-menu:hover{background:var(--accent-orange-pale);border-color:var(--accent-orange);color:var(--accent-orange)}.purpose-balance{font-size:1.6rem;font-weight:800;margin-bottom:10px;color:var(--text-primary);letter-spacing:-.02em}.purpose-balance .currency{font-size:.85rem;color:var(--text-muted);margin-left:2px}.purpose-bar{height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden;border:1px solid var(--border-color)}.purpose-bar-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}.drag-hint{text-align:center;font-size:.78rem;color:var(--text-muted);margin-bottom:12px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px}.add-purpose-btn{background:var(--bg-secondary);border:2px dashed var(--accent-blue);border-radius:var(--radius-lg);padding:22px 20px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--accent-blue);font-family:var(--font-sans);font-size:.9rem;font-weight:700;transition:all .25s;width:100%}.add-purpose-btn:hover{background:var(--accent-blue-pale);box-shadow:var(--shadow-blue);transform:translateY(-2px)}.drag-ghost{position:fixed;z-index:var(--z-drag);pointer-events:none;transform:scale(.7);transform-origin:center;transition:none!important;animation:ghostAppear .15s cubic-bezier(.34,1.56,.64,1);opacity:.95;box-shadow:var(--shadow-lg)!important;border:4px solid var(--accent-orange)!important;border-radius:var(--radius-md)!important;margin:0}@keyframes ghostAppear{0%{transform:scale(1);opacity:.6}to{transform:scale(.7);opacity:.95}}.modal-overlay{position:fixed;inset:0;z-index:var(--z-modal);background:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:overlayIn .2s ease}@media(min-width:600px){.modal-overlay{align-items:center}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-modal);border:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px 24px max(24px,env(safe-area-inset-bottom));width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 32px #0000001f;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.modal-content.is-opening{pointer-events:none!important}@media(min-width:600px){.modal-content{border-radius:var(--radius-xl);animation:modalScaleIn .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes modalScaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-handle{width:36px;height:4px;background:var(--border-color);border-radius:2px;margin:0 auto 16px}@media(min-width:600px){.modal-handle{display:none}}.modal-title{font-size:1.2rem;font-weight:800;margin-bottom:20px;text-align:center;color:var(--text-primary)}.transfer-info{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:clamp(10px,3vh,20px);padding:clamp(8px,2vh,14px);background:var(--accent-orange-pale);border-radius:var(--radius-md);border:1px solid rgba(255,163,13,.2)}.transfer-account{text-align:center}.transfer-account .emoji{font-size:1.6rem;margin-bottom:4px}.transfer-account .name{font-size:.78rem;color:var(--text-secondary);font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transfer-arrow{color:var(--accent-orange);font-size:1.3rem;flex-shrink:0}.amount-input-area{margin-bottom:20px}.amount-display{font-size:clamp(2rem,8vw,2.6rem);font-weight:900;text-align:center;padding:12px;color:var(--text-primary);min-height:76px;display:flex;align-items:center;justify-content:center;letter-spacing:-.03em;user-select:none;-webkit-user-select:none}.amount-display .currency{font-size:1.2rem;color:var(--text-muted);margin-left:4px;font-weight:600}.amount-display .placeholder{color:var(--text-muted);font-weight:500;font-size:1.3rem}.available-balance{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:-8px;margin-bottom:16px;font-weight:600}.available-balance span{color:var(--accent-green)}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.numpad-btn{padding:clamp(10px,2.5vh,16px);border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:1.4rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.numpad-btn:hover{background:var(--accent-orange-pale);border-color:var(--accent-orange);color:var(--accent-orange)}.numpad-btn:active{transform:scale(.94);background:var(--accent-orange);color:#fff;border-color:var(--accent-orange)}.numpad-btn.backspace{font-size:1.2rem;color:var(--text-muted)}.numpad-btn.clear{font-size:.9rem;font-weight:700;color:var(--accent-red);border-color:#e74c3c33}.modal-actions{display:flex;gap:10px}.modal-btn{flex:1;padding:14px 20px;border-radius:var(--radius-md);border:none;font-size:1rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all .2s}.modal-btn-cancel{background:var(--bg-primary);color:var(--text-secondary);border:2px solid var(--border-color)}.modal-btn-cancel:hover{background:var(--border-color)}.modal-btn-confirm{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-orange)}.modal-btn-confirm:hover{box-shadow:0 6px 20px #ffa30d66;transform:translateY(-1px)}.modal-btn-confirm:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.bank-search-input{width:100%;padding:13px 16px 13px 44px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:var(--font-sans);outline:none;transition:all .2s;font-weight:500}.bank-search-input:focus{border-color:var(--accent-orange);background:var(--bg-secondary);box-shadow:0 0 0 3px #ffa30d26}.bank-search-input::placeholder{color:var(--text-muted)}.bank-search-wrap{position:relative;margin-bottom:14px}.bank-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.bank-list-results{max-height:300px;overflow-y:auto;margin-bottom:14px}.bank-list-results::-webkit-scrollbar{width:4px}.bank-list-results::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.bank-result-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;border:1px solid transparent}@media(hover:hover){.bank-result-item:hover{background:var(--accent-orange-pale);border-color:#ffa30d33}}.bank-result-item:active{background:var(--accent-orange-pale)}.bank-result-item .icon{font-size:1.3rem;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--accent-orange-pale);border-radius:var(--radius-sm);flex-shrink:0;border:1px solid rgba(255,163,13,.15)}.bank-result-item .name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.bank-custom-create{display:flex;align-items:center;gap:10px;padding:13px;border:2px dashed var(--accent-blue);border-radius:var(--radius-md);cursor:pointer;color:var(--accent-blue);font-size:.9rem;font-weight:700;transition:all .2s;margin-bottom:8px}.bank-custom-create:hover{background:var(--accent-blue-pale)}.custom-bank-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.82rem;color:var(--text-secondary);font-weight:700;letter-spacing:.02em}.form-input{padding:12px 14px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:var(--font-sans);outline:none;transition:all .2s;font-weight:500}.form-input:focus{border-color:var(--accent-orange);background:var(--bg-secondary);box-shadow:0 0 0 3px #ffa30d26}.emoji-picker{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.emoji-pick-btn{width:46px;height:46px;border:2px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);font-size:1.4rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-pick-btn:hover{background:var(--accent-orange-pale);border-color:#ffa30d4d;transform:scale(1.1)}.emoji-pick-btn.selected{border-color:var(--accent-orange);background:var(--accent-orange-pale);box-shadow:0 0 0 2px #ffa30d4d}.color-picker{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.color-pick-btn{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.color-pick-btn:hover{transform:scale(1.15)}.color-pick-btn.selected{border-color:var(--text-primary);box-shadow:0 0 0 3px #fff,0 0 0 5px currentColor}.toast-container{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:16px;right:16px;z-index:var(--z-toast);display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}.toast{pointer-events:auto;padding:12px 20px;background:var(--bg-card);border:2px solid var(--accent-orange);border-radius:var(--radius-xl);color:var(--text-primary);font-size:.9rem;font-weight:700;text-align:center;max-width:100%;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;box-shadow:var(--shadow-lg);word-break:break-all}.toast.success{border-color:var(--accent-green);box-shadow:0 4px 16px #27ae6033}.toast.error{border-color:var(--accent-red);box-shadow:0 4px 16px #e74c3c33}@keyframes toastIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.context-menu{position:fixed;z-index:var(--z-dropdown);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px;min-width:170px;box-shadow:var(--shadow-lg);animation:menuIn .15s ease}@keyframes menuIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.context-menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-sm);width:100%;transition:all .15s}.context-menu-item:hover{background:var(--accent-orange-pale);color:var(--accent-orange)}.context-menu-item.danger{color:var(--accent-red)}.context-menu-item.danger:hover{background:var(--accent-red-pale);color:var(--accent-red)}.confirm-text{text-align:center;color:var(--text-secondary);font-size:.95rem;line-height:1.7;margin-bottom:24px;font-weight:500;white-space:pre-wrap}.confirm-text strong{color:var(--text-primary);font-weight:700}.page-enter{animation:pageEnter .3s cubic-bezier(.4,0,.2,1)}@keyframes pageEnter{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.user-menu{position:fixed;top:58px;right:16px;z-index:var(--z-dropdown);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;min-width:200px;box-shadow:var(--shadow-lg);animation:menuIn .15s ease}.user-menu-header{padding:12px 14px;border-bottom:1px solid var(--border-color);margin-bottom:4px}.user-menu-name{font-size:.9rem;font-weight:700;color:var(--text-primary)}.user-menu-email{font-size:.75rem;color:var(--text-muted);margin-top:2px}.user-menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-sm);width:100%;transition:all .15s}.user-menu-item:hover{background:var(--accent-orange-pale);color:var(--accent-orange)}.user-menu-item.danger{color:var(--accent-red)}.user-menu-item.danger:hover{background:var(--accent-red-pale)}.balance-edit-input{width:100%;padding:14px 16px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:1.6rem;font-weight:800;font-family:var(--font-sans);outline:none;text-align:center;transition:all .2s}.balance-edit-input:focus{border-color:var(--accent-orange);background:var(--bg-card);box-shadow:0 0 0 3px #ffa30d26}@media(min-width:1024px){.bank-list-page,.bank-detail-page{padding:32px 40px;max-width:960px}.bank-grid,.purpose-grid{grid-template-columns:repeat(3,1fr)}.total-balance-amount{font-size:2.8rem}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted);background:var(--bg-card);border-radius:var(--radius-lg);border:2px dashed var(--border-color)}.empty-state .icon{font-size:3rem;margin-bottom:16px}.empty-state .title{font-size:1.05rem;font-weight:700;color:var(--text-secondary);margin-bottom:8px}.empty-state .desc{font-size:.85rem;line-height:1.7;font-weight:500}.info-banner{background:var(--accent-blue-pale);border:1px solid rgba(74,134,232,.2);border-radius:var(--radius-md);padding:12px 16px;font-size:.82rem;color:var(--accent-blue);font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;z-index:99999;transition:opacity .5s ease-out,visibility .5s}@media(min-width:769px){.splash-screen{display:none!important}}.splash-logo{width:100px;height:100px;border-radius:20%;animation:splashPulse 1.5s infinite ease-in-out}@keyframes splashPulse{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}to{transform:scale(1);opacity:.8}}.splash-fade-out{opacity:0;visibility:hidden}
