.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;gap:4px;height:100vh;overflow-y:auto;padding:24px 16px;position:sticky;top:0;width:260px}.sidebar-title{border-bottom:1px solid var(--border-light);font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:8px;padding:0 8px 16px}.sidebar-title em{color:var(--accent);font-style:italic}.sidebar-section{color:var(--text-light);font-size:.65rem;font-weight:600;letter-spacing:.08em;padding:12px 8px 6px;text-transform:uppercase}.sidebar-item{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;gap:10px;padding:9px 12px;text-align:left;transition:var(--transition);width:100%}.sidebar-item:hover{background:var(--bg-hover);color:var(--text)}.sidebar-item.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.sidebar-item .cat-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.sidebar-item .cat-count{background:var(--bg);border-radius:100px;color:var(--text-light);font-size:.72rem;padding:1px 7px}.sidebar-item.active .cat-count{background:#c4553a26;color:var(--accent)}.sidebar-item .cat-delete{opacity:0;transition:var(--transition)}.sidebar-item:hover .cat-delete{opacity:1}.cat-reorder-btn{color:var(--text-light);font-size:.6rem;height:22px;line-height:1;width:22px}.cat-reorder-btn:hover{background:var(--bg);color:var(--text-muted)}.cat-reorder-btn[aria-disabled=true]{opacity:.25;pointer-events:none}.sidebar-add-sub{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;font-family:inherit;font-size:.75rem;padding:4px 12px 4px 36px;text-align:left;transition:var(--transition);width:100%}.sidebar-add-sub:hover{color:var(--accent)}.sidebar-add{align-items:center;background:none;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;font-family:inherit;font-size:.82rem;gap:8px;margin-top:4px;padding:8px 12px;text-align:left;transition:var(--transition);width:100%}.sidebar-add:hover{border-color:var(--accent);color:var(--accent)}.sidebar-subcat{padding-left:4px}.subcat-indent{align-items:center;display:flex;flex-shrink:0;position:relative;width:16px}.subcat-indent:before{background:var(--border);content:"";height:1px;left:8px;position:absolute;top:50%;width:8px}.sidebar-recurring{align-items:center;cursor:default}.recurring-icon{align-items:center;color:var(--text-light);display:flex;flex-shrink:0}.sidebar-recurring-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0;text-align:left}.sidebar-recurring-title{color:var(--text-muted);font-size:.855rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-recurring-days{color:var(--text-light);font-size:.65rem;letter-spacing:.02em}@media (max-width:768px){.sidebar{height:100vh;left:-280px;position:fixed;top:0;transition:left .25s ease;width:270px;z-index:50}.sidebar.open{left:0}.sidebar-backdrop{background:#00000059;inset:0;position:fixed;z-index:49}.sidebar-item .cat-delete{opacity:1}}.rem-bell-wrap{align-items:center;display:inline-flex;position:relative}.rem-bell-btn{background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;font-size:1.1rem;line-height:1;padding:2px 4px;position:relative;transition:background .15s}.rem-bell-btn:hover{background:#00000012}.rem-bell-btn--active{animation:bell-ring .5s ease}@keyframes bell-ring{0%,to{transform:rotate(0)}20%{transform:rotate(-12deg)}40%{transform:rotate(12deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}}.rem-bell-badge{align-items:center;background:#e74c3c;border-radius:7px;color:#fff;display:flex;font-size:.6rem;font-weight:700;height:14px;justify-content:center;line-height:1;min-width:14px;padding:0 3px;position:absolute;right:-4px;top:-4px}.rem-bell-dropdown{background:#fff;background:var(--surface,#fff);border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:10px;box-shadow:0 8px 24px #0000001f;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:300px;z-index:200}.rem-bell-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border,#e0e0e0);display:flex;font-size:.85rem;font-weight:600;justify-content:space-between;padding:10px 14px}.rem-bell-manage{background:none;border:none;border-radius:4px;color:#4f46e5;color:var(--accent,#4f46e5);cursor:pointer;font-size:.8rem;padding:2px 6px}.rem-bell-manage:hover{background:#4f46e514}.rem-bell-empty{color:#888;color:var(--text-muted,#888);font-size:.85rem;padding:18px 14px;text-align:center}.rem-bell-list{list-style:none;margin:0;max-height:340px;overflow-y:auto;padding:0}.rem-bell-item{border-bottom:1px solid #f0f0f0;border-bottom:1px solid var(--border,#f0f0f0);padding:10px 14px}.rem-bell-item:last-child{border-bottom:none}.rem-bell-item-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:3px}.rem-bell-cat{color:#888;color:var(--text-muted,#888);font-size:.72rem}.rem-bell-days{color:#4f46e5;color:var(--accent,#4f46e5);font-size:.72rem;font-weight:600}.rem-bell-title{font-size:.9rem;font-weight:600;margin-bottom:2px}.rem-bell-date{color:#888;color:var(--text-muted,#888);font-size:.78rem;margin-bottom:6px}.rem-bell-dismiss{background:none;border:1px solid #ddd;border:1px solid var(--border,#ddd);border-radius:4px;color:#666;color:var(--text-muted,#666);cursor:pointer;font-size:.75rem;padding:2px 8px}.rem-bell-dismiss:hover{background:#f5f5f5;background:var(--surface-alt,#f5f5f5)}.header{padding:36px 0 24px}.header h2{font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:-.02em;line-height:1.1}.header h2 em{color:var(--accent);font-style:italic}.header-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.82rem;gap:16px;margin-top:8px}.header-meta .dot{background:var(--border);border-radius:50%;height:4px;width:4px}.stats{display:flex;gap:8px;margin-bottom:20px}.stat{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);flex:1 1;padding:12px 14px;text-align:center}.stat-number{font-family:var(--font-display);font-size:1.5rem;line-height:1}.stat-label{color:var(--text-muted);font-size:.65rem;letter-spacing:.08em;margin-top:3px;text-transform:uppercase}@media (max-width:768px){.header{padding:20px 0 16px}.header h2{font-size:1.6rem}.stats{gap:6px}.stat{padding:10px 8px}.stat-number{font-size:1.3rem}.header-admin,.header-logout,.header-user{display:none}}.header-user{font-size:.8rem}.header-logout,.header-user{color:#888;color:var(--text-muted,#888)}.header-logout{background:none;border:1px solid #e8e3dc;border:1px solid var(--border,#e8e3dc);border-radius:6px;cursor:pointer;font-size:.75rem;margin-left:4px;padding:3px 8px;transition:all .15s}.header-billing:hover{border-color:var(--accent)!important;color:var(--accent)!important}.header-logout:hover{border-color:#ef5350;color:#ef5350}.add-form{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:18px;transition:box-shadow var(--transition)}.add-form:focus-within{border-color:var(--border);box-shadow:var(--shadow-md)}.add-form-row{align-items:center;display:flex;gap:10px}.add-form input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;transition:var(--transition)}.add-form input[type=text]:focus{background:var(--bg-card);border-color:var(--accent)}.add-form input[type=text]::placeholder{color:var(--text-light)}.add-form-extras{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.add-form-extras input[type=text]{background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-family:var(--font-body);font-size:.82rem;min-width:120px;outline:none;padding:7px 10px;transition:var(--transition)}.add-form-extras input:focus{border-color:var(--accent)}.form-select{appearance:none;-webkit-appearance:none;background:var(--bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1 4 4 4-4' stroke='%237a7570' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.78rem;outline:none;padding:7px 26px 7px 10px}input[type=date].form-select,input[type=time].form-select{appearance:auto;-webkit-appearance:auto;background-image:none;cursor:text;padding:7px 10px}input[type=time].form-select:disabled{cursor:not-allowed;opacity:.4}.btn-add{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.82rem;font-weight:600;padding:9px 18px;transition:var(--transition);white-space:nowrap}.btn-add:hover{background:var(--accent-hover)}.btn-add:active{transform:scale(.97)}.form-date-label{display:flex;flex-direction:column;gap:2px}.form-date-hint{color:var(--text-light);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase}.free-tier-warning{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid #d4963a;border-radius:6px;color:var(--text-light);font-size:.8rem;margin-bottom:10px;padding:8px 12px}.free-tier-warning a{color:var(--accent);text-decoration:underline}.free-tier-warning-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.free-tier-note{color:var(--text-light);font-size:.72rem;margin-top:3px;opacity:.75}.task-usage-counter{background:var(--bg);border:1px solid var(--border-light);border-radius:20px;color:var(--text-muted);font-size:.78rem;font-weight:600;padding:2px 8px;white-space:nowrap}.task-usage-counter--warn{background:#d4963a11;border-color:#d4963a44;color:#d4963a}.task-usage-counter--full{background:#c0392b11;border-color:#c0392b44;color:#c0392b}@media (max-width:768px){.add-form-row{flex-direction:column}.add-form-row .btn-add,.add-form-row input[type=text]{width:100%}}.todo-item{align-items:flex-start;animation:slideIn .3s ease;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);display:flex;gap:12px;padding:14px 16px;transition:var(--transition)}.todo-item:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.todo-item.completed{opacity:.5}.todo-item.completed .todo-title{color:var(--text-muted);text-decoration:line-through}.todo-item.todo-item-selected{background:color-mix(in srgb,var(--accent) 6%,var(--bg-card));border-color:var(--accent)}.todo-item.todo-item-dragging{box-shadow:var(--shadow-md);z-index:99}.drag-handle{background:none;border:none;color:var(--text-light);cursor:grab;flex-shrink:0;font-size:1rem;margin-top:2px;opacity:0;padding:0 2px;touch-action:none;transition:opacity var(--transition)}.drag-handle:active{cursor:grabbing}.todo-item:hover .drag-handle{opacity:1}.todo-select-check{appearance:none;-webkit-appearance:none;background:#0000;border:2px solid var(--border);border-radius:50%;cursor:pointer;flex-shrink:0;height:16px;margin-top:4px;opacity:0;transition:opacity var(--transition),background var(--transition),border-color var(--transition);width:16px}.todo-select-check:checked{background:var(--accent);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 10 10' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m2 5 2.5 2.5L8 3' stroke='%23fff' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:10px;border-color:var(--accent)}.todo-item.todo-item-selected .todo-select-check,.todo-item:hover .todo-select-check{opacity:1}.reorder-arrows{display:flex;flex-direction:column;gap:1px;opacity:0;transition:opacity var(--transition)}.todo-item:hover .reorder-arrows{opacity:1}.btn-icon.arrow{font-size:.6rem;line-height:1;padding:2px 5px}.btn-icon.arrow:disabled{cursor:default;opacity:.2}@keyframes slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.todo-check{flex-shrink:0;height:20px;margin-top:2px;position:relative;width:20px}.todo-check input{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%;z-index:1}.todo-check .checkmark{align-items:center;border:2px solid var(--border);border-radius:5px;display:flex;height:20px;justify-content:center;transition:var(--transition);width:20px}.todo-check input:checked+.checkmark{background:var(--success);border-color:var(--success)}.todo-check .checkmark svg{opacity:0;transition:var(--transition)}.todo-check input:checked+.checkmark svg{opacity:1}.todo-content{flex:1 1;min-width:0}.todo-title{font-size:.9rem;font-weight:500;word-break:break-word}.todo-desc{color:var(--text-muted);font-size:.78rem;margin-top:2px;word-break:break-word}.todo-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}.priority-badge{border-radius:100px;font-size:.6rem;font-weight:600;letter-spacing:.05em;padding:2px 7px;text-transform:uppercase}.priority-badge.high{background:#fdf0ed;color:var(--priority-high)}.priority-badge.medium{background:#fdf6ed;color:var(--priority-medium)}.priority-badge.low{background:#eef6f1;color:var(--priority-low)}.cat-badge{border:1px solid var(--border-light);border-radius:100px;color:var(--text-muted)}.cat-badge,.recurring-badge{font-size:.6rem;font-weight:500;padding:2px 7px}.recurring-badge{align-items:center;background:#e8f4f8;border-radius:100px;color:#2a7b9b;display:inline-flex;gap:3px}.todo-date{color:var(--text-light);font-size:.68rem}.due-badge{background:#f0f4ff;border-radius:100px;color:#4a6fa5;font-size:.6rem;font-weight:500;padding:2px 7px}.due-badge.overdue{background:#fdf0ed;color:var(--accent)}.due-badge.today{background:#fff8e1;color:#b07d00}.due-badge.soon{background:#eef6f1;color:var(--priority-low)}.time-left-badge{animation:slideIn .2s ease;background:#eef3ff;border-radius:100px;color:#3a5fa8;font-size:.6rem;font-weight:600;padding:2px 7px}.time-left-badge.overdue{background:#fdf0ed;color:var(--priority-high)}.btn-icon.clock.active,.btn-icon.clock:hover{background:#eef3ff;color:#3a5fa8}.todo-item-editing{align-items:stretch}.edit-form{display:flex;flex:1 1;flex-direction:column;gap:8px}.edit-title{border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.edit-desc,.edit-title{background:var(--bg);color:var(--text);font-family:var(--font-body);outline:none;padding:6px 10px;width:100%}.edit-desc{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem}.edit-desc:focus{border-color:var(--accent)}.edit-row{display:flex;flex-wrap:wrap;gap:8px}.edit-row .form-select{flex:1 1;min-width:100px}.edit-row input[type=date].form-select,.edit-row input[type=time].form-select{appearance:auto;-webkit-appearance:auto;background-image:none;padding:7px 10px}.edit-row input[type=time].form-select:disabled{cursor:not-allowed;opacity:.4}.edit-actions{display:flex;gap:8px;justify-content:flex-end}.btn-cancel-edit,.btn-save-edit{border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:500;padding:5px 14px;transition:var(--transition)}.btn-cancel-edit{background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}.btn-cancel-edit:hover{border-color:var(--text-muted)}.btn-save-edit{background:var(--accent);border:none;color:#fff}.btn-save-edit:hover{filter:brightness(1.1)}.btn-icon.edit:hover{background:#e8f0ff;color:#4a6fa5}.btn-icon{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;height:30px;justify-content:center;transition:var(--transition);width:30px}.btn-icon:hover{background:var(--bg);color:var(--text-muted)}.btn-icon.delete:hover{background:var(--accent-soft);color:var(--accent)}@media (max-width:768px){.todo-item{gap:8px;padding:12px}.drag-handle,.reorder-arrows{display:none}.todo-select-check{opacity:1}.btn-icon{height:26px;width:26px}}.search-bar{margin-bottom:14px;position:relative}.search-bar input{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.82rem;outline:none;padding:9px 12px 9px 36px;transition:var(--transition);width:100%}.search-bar input:focus{border-color:var(--border);box-shadow:var(--shadow-sm)}.search-bar .search-icon{color:var(--text-light);left:11px;position:absolute;top:50%;transform:translateY(-50%)}.filters{-webkit-overflow-scrolling:touch;display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.filters::-webkit-scrollbar{display:none}.filter-btn{background:#0000;border:1px solid var(--border);border-radius:100px;color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.78rem;font-weight:500;padding:6px 12px;transition:var(--transition);white-space:nowrap}.filter-btn:hover{border-color:var(--text-muted);color:var(--text)}.filter-btn.active{background:var(--text);border-color:var(--text);color:var(--bg)}.list-actions-bar{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px;min-height:28px}.clear-completed{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.75rem;gap:6px;padding:5px 0;transition:var(--transition)}.clear-completed:hover{color:var(--accent)}.btn-select-all{background:none;border:none;color:var(--text-light);cursor:pointer;font-family:var(--font-body);font-size:.75rem;padding:5px 0;transition:var(--transition)}.btn-select-all:hover{color:var(--accent)}.bulk-toolbar{align-items:center;background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-sm);display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;padding:8px 12px}.bulk-count{color:var(--accent);font-size:.8rem;font-weight:600;margin-right:4px}.bulk-cat-select{appearance:none;-webkit-appearance:none;background:var(--bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1 4 4 4-4' stroke='%237a7570' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:5px 24px 5px 8px}.bulk-cat-select,.bulk-move-btn{cursor:pointer;font-family:var(--font-body);font-size:.8rem}.bulk-move-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:600;padding:5px 14px;transition:var(--transition)}.bulk-move-btn:hover{background:var(--accent-hover)}.bulk-cancel-btn{background:none;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.8rem;padding:5px 10px;transition:var(--transition)}.bulk-cancel-btn:hover{border-color:var(--border);color:var(--text)}.todo-list{display:flex;flex-direction:column;gap:5px;padding-bottom:80px}.empty-state{color:var(--text-muted);padding:50px 20px;text-align:center}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4}.empty-state h3{font-family:var(--font-display);font-size:1.2rem;font-weight:400;margin-bottom:4px}.empty-state p{font-size:.82rem}@media (max-width:768px){.bulk-toolbar{gap:6px;padding:8px}.bulk-cat-select{flex:1 1;min-width:0}.list-actions-bar{flex-wrap:wrap;gap:6px}}.modal-overlay{align-items:center;animation:fadeIn .15s ease;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-width:90vw;padding:24px;width:360px}.modal h3{font-size:1rem;font-weight:600;margin-bottom:4px}.modal-subtext{color:var(--text-light);font-size:.8rem;margin-bottom:16px}.modal-field{margin-bottom:12px}.modal-field label{color:var(--text-muted);display:block;font-size:.75rem;font-weight:500;margin-bottom:4px}.modal-field input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;width:100%}.modal-field input:focus{border-color:var(--accent)}.modal-field select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;width:100%}.modal-field select:focus{border-color:var(--accent)}.modal-colors{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}.modal-color{border:2px solid #0000;border-radius:6px;cursor:pointer;height:28px;transition:var(--transition);width:28px}.modal-color.active{border-color:var(--text);transform:scale(1.1)}.modal-actions{display:flex;gap:8px;margin-top:16px}.modal-actions button{border-radius:var(--radius-sm);cursor:pointer;flex:1 1;font-family:inherit;font-size:.85rem;font-weight:500;padding:9px 16px;transition:var(--transition)}.btn-cancel{background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}.btn-cancel:hover{border-color:var(--text-muted)}.btn-confirm{background:var(--accent);border:none;color:#fff}.btn-confirm:hover{filter:brightness(1.1)}.recurrence-modal{width:420px}.optional{color:var(--text-light);font-weight:400}.day-picker{display:flex;gap:5px}.day-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;flex:1 1;font-family:inherit;font-size:.72rem;font-weight:500;padding:7px 4px;transition:var(--transition)}.day-btn:hover{border-color:var(--accent);color:var(--accent)}.day-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.recurrence-selects{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.recurrence-modal select{appearance:none;background:var(--bg) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath d='m2 4 4 4 4-4' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-family:var(--font-body);font-size:.85rem;outline:none;padding:8px 28px 8px 10px;width:100%}.recurrence-modal select:focus{border-color:var(--accent)}@media (max-width:480px){.recurrence-modal{width:100%}.day-btn{font-size:.65rem;padding:6px 2px}.recurrence-selects{grid-template-columns:1fr}}.calendar-view{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.cal-nav{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 20px}.cal-month-label{font-family:var(--font-display);font-size:1.15rem;font-weight:400}.cal-month-label em{color:var(--text-muted);font-style:normal}.cal-nav-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:1.3rem;height:32px;justify-content:center;line-height:1;transition:var(--transition);width:32px}.cal-nav-btn:hover{background:var(--bg-hover);color:var(--text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-dow{color:var(--text-light);font-size:.62rem;font-weight:600;letter-spacing:.06em;padding:10px 4px 8px;text-align:center;text-transform:uppercase}.cal-cell,.cal-dow{border-bottom:1px solid var(--border-light)}.cal-cell{border-right:1px solid var(--border-light);cursor:pointer;display:flex;flex-direction:column;gap:5px;min-height:68px;padding:8px 8px 6px;transition:background var(--transition)}.cal-cell:nth-child(7n){border-right:none}.cal-cell:hover:not(.empty){background:var(--bg-hover)}.cal-cell.empty{background:var(--bg);border-right:1px solid var(--border-light);cursor:default}.cal-cell.empty:nth-child(7n){border-right:none}.cal-cell.selected{background:var(--accent-soft)}.cal-day-num{align-items:center;border-radius:50%;color:var(--text-muted);display:flex;flex-shrink:0;font-size:.78rem;font-weight:500;height:22px;justify-content:center;width:22px}.cal-cell.today .cal-day-num{background:var(--accent);color:#fff;font-weight:600}.cal-cell.selected:not(.today) .cal-day-num{color:var(--accent);font-weight:600}.cal-dots{display:flex;flex-wrap:wrap;gap:3px}.cal-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.cal-detail{border-top:2px solid var(--border-light);padding:20px}.cal-detail-header{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:14px}.cal-detail-empty{color:var(--text-light);font-size:.82rem;font-style:italic}.cal-detail-list{display:flex;flex-direction:column;gap:8px}.cal-detail-item{align-items:flex-start;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:10px;padding:10px 14px;transition:var(--transition)}.cal-detail-item:hover{border-color:var(--border)}.cal-detail-item.done{opacity:.5}.cal-detail-item.projected{border-style:dashed}.cal-detail-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:4px;width:8px}.cal-detail-text{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.cal-detail-title{color:var(--text);font-size:.875rem;font-weight:500}.cal-detail-item.done .cal-detail-title{color:var(--text-muted);text-decoration:line-through}.cal-detail-desc{color:var(--text-muted);font-size:.75rem}.cal-detail-tags{align-items:center;display:flex;flex-shrink:0;gap:5px}.cal-tag{border-radius:100px;font-size:.58rem;font-weight:600;letter-spacing:.04em;padding:2px 7px;text-transform:uppercase}.cat-tag{background:#0000;border:1px solid;opacity:.8}.rec-tag{background:#e8f4f8;color:#2a7b9b}.done-tag{background:#eef6f1;color:var(--priority-low)}@media (max-width:600px){.cal-cell{min-height:50px;padding:5px 4px 4px}.cal-dow{font-size:.55rem;padding:8px 2px 6px}.cal-day-num{font-size:.7rem;height:18px;width:18px}.cal-dot{height:5px;width:5px}.cal-detail{padding:14px}}.ext-cal-backdrop{background:#00000040;inset:0;position:fixed;z-index:59}.ext-cal-panel{background:var(--bg-card);border-left:1px solid var(--border);box-shadow:-4px 0 24px #00000014;display:flex;flex-direction:column;height:100vh;overflow:hidden;position:fixed;right:-340px;top:0;transition:right .28s cubic-bezier(.4,0,.2,1);width:320px;z-index:60}.ext-cal-panel.open{right:0}.ext-cal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 20px 16px}.ext-cal-title{color:var(--text);font-family:var(--font-display);font-size:1.15rem;font-weight:400}.ext-cal-close{color:var(--text-light)}.ext-cal-list{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:12px 16px}.ext-cal-empty{color:var(--text-light);font-size:.85rem;padding:32px 0;text-align:center}.ext-cal-item{align-items:center;border-radius:var(--radius-sm);display:flex;gap:6px;padding:2px 4px 2px 0;transition:var(--transition)}.ext-cal-item:hover{background:var(--bg-hover)}.ext-cal-link{align-items:center;border-radius:var(--radius-sm);color:var(--text-muted);display:flex;flex:1 1;gap:8px;min-width:0;padding:8px 10px;text-decoration:none;transition:var(--transition)}.ext-cal-link:hover{color:var(--accent)}.ext-cal-name{flex:1 1;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ext-cal-link-icon{align-items:center;display:flex;flex-shrink:0;opacity:0;transition:var(--transition)}.ext-cal-link:hover .ext-cal-link-icon{opacity:1}.ext-cal-action{flex-shrink:0;opacity:0;transition:var(--transition)}.ext-cal-item:hover .ext-cal-action{opacity:1}.ext-cal-item-editing{align-items:stretch;background:var(--bg-hover);border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:8px}.ext-cal-edit-fields{display:flex;flex-direction:column;gap:6px}.ext-cal-edit-actions{display:flex;gap:4px;justify-content:flex-end}.ext-cal-save{color:var(--success)}.ext-cal-save:hover{background:#4a8c6f1f!important;color:var(--success)!important}.ext-cal-form{background:var(--bg-sidebar);border-top:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;gap:8px;padding:16px}.ext-cal-form-title{color:var(--text-light);font-size:.72rem;font-weight:600;letter-spacing:.08em;margin-bottom:2px;text-transform:uppercase}.ext-cal-error{color:var(--priority-high);font-size:.8rem}.ext-cal-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.875rem;outline:none;padding:8px 12px;transition:var(--transition)}.ext-cal-input:focus{border-color:var(--accent)}.ext-cal-input::placeholder{color:var(--text-light)}.ext-cal-submit{align-self:flex-start;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:9px 16px;transition:var(--transition)}.ext-cal-submit:hover{background:var(--accent-hover)}@media (max-width:480px){.ext-cal-panel{right:-100vw;width:100vw}}.login-bg{align-items:center;background:var(--bg);color-scheme:light;display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:var(--bg-hover);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-sm);max-width:400px;padding:40px 36px;width:100%}.login-logo{gap:10px;margin-bottom:28px}.login-logo,.login-logo-icon{align-items:center;display:flex}.login-logo-icon{background:var(--accent);border-radius:10px;color:#fff;font-size:18px;font-weight:700;height:36px;justify-content:center;width:36px}.login-logo-text{color:var(--text);font-family:var(--font-display);font-size:1.3rem;font-weight:600}.login-title{color:var(--text);font-size:1.5rem;font-weight:700;margin:0 0 6px}.login-sub{color:var(--text-muted);font-size:.9rem;margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.login-label{color:var(--text-muted);font-size:.8rem;font-weight:600;letter-spacing:.05em;margin-top:10px;text-transform:uppercase}.login-input{appearance:none;background:#fff;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.95rem;outline:none;padding:10px 14px;transition:border-color .15s}.login-input::placeholder{color:var(--text-light);opacity:1}.login-input:focus{border-color:var(--accent)}.login-input-mono{font-family:monospace;font-size:.82rem;letter-spacing:.02em}.login-error{background:#fdecea;border:1px solid #f5b7b1;border-radius:8px;color:var(--priority-high)}.login-error,.login-info{font-size:.85rem;margin-top:6px;padding:9px 13px}.login-info{background:var(--accent-soft);border:1px solid #bfdbfe;border-radius:8px;color:var(--accent);word-break:break-all}.login-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:14px;padding:11px;transition:background .15s}.login-btn:hover{background:var(--accent-hover)}.login-btn:disabled{cursor:not-allowed;opacity:.5}.login-link{background:none;border:none;color:var(--text-muted);cursor:pointer;display:block;font-size:.85rem;margin-top:4px;padding:6px 0;text-align:center;text-decoration:underline;transition:color .15s;width:100%}.login-link:hover{color:var(--text)}.login-legal-links{border-top:1px solid var(--border-light);color:var(--text-light);font-size:.72rem;margin-top:24px;padding-top:16px;text-align:center}.login-legal-links a{color:var(--text-light);text-decoration:underline}.login-legal-links a:hover{color:var(--text-muted)}@media (max-width:480px){.login-bg{padding:16px}.login-card{padding:28px 22px}}.demo-app{background:var(--bg);color:var(--text);min-height:100vh}.demo-banner{background:var(--accent);box-shadow:0 1px 6px #00000014;color:#fff;position:sticky;top:0;z-index:60}.demo-banner-inner{align-items:center;display:flex;flex-wrap:wrap;gap:12px;max-width:100%;padding:10px 20px}.demo-banner-badge{background:#ffffff2e;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:3px 8px}.demo-banner-msg{flex:1 1;font-size:.9rem;min-width:200px}.demo-banner-actions{display:flex;gap:8px}.demo-banner-btn-pricing,.demo-banner-btn-primary,.demo-banner-btn-signin{border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.92rem;font-weight:600;line-height:1.2;padding:8px 14px;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.demo-banner-btn-primary{background:#fff;border:1px solid #fff;color:var(--accent)!important;font-weight:700}.demo-banner-btn-primary:hover{background:var(--bg)}.demo-banner-btn-pricing{background:#ffffff38;border:1.5px solid #ffffffbf;color:#fff!important}.demo-banner-btn-pricing:hover{background:#ffffff52;border-color:#fff}.demo-banner-btn-signin{background:#0000;border:1.5px solid #ffffff8c;color:#fff!important;font-weight:500}.demo-banner-btn-signin:hover{background:#ffffff1f;border-color:#fff}.demo-layout{display:flex;min-height:calc(100vh - 48px)}.demo-sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:2px;padding:20px 14px;width:240px}.demo-sidebar-title{border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font-display);font-size:1.35rem;font-weight:600;margin-bottom:12px;padding:0 8px 16px}.demo-sidebar-title em{color:var(--accent);font-style:italic}.demo-sidebar-section{color:var(--text-muted);font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:14px 8px 6px;text-transform:uppercase}.demo-sidebar-item{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;display:flex;font-size:.92rem;gap:10px;padding:8px 10px;text-align:left;transition:background .15s,color .15s;width:100%}.demo-sidebar-item:hover{background:var(--bg-hover)}.demo-sidebar-item--active{background:var(--accent-soft);color:var(--accent);font-weight:500}.demo-sidebar-item--cat{padding:7px 10px}.demo-sidebar-item--locked{color:var(--text-light);cursor:default;font-size:.88rem;font-style:italic}.demo-sidebar-item--locked:hover{background:#0000}.demo-cat-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.demo-cat-dot--all{background:#0000;border:1.5px solid var(--border)}.demo-sidebar-add-cat{background:#0000;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:block;font-size:.85rem;margin-top:4px;padding:6px 10px;text-align:left;transition:border-color .15s,color .15s,background .15s;width:100%}.demo-sidebar-add-cat:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.demo-sidebar-add-cat-form{margin-top:4px}.demo-sidebar-add-cat-input{font-size:.88rem;padding:6px 10px;width:100%}.demo-cat-name-side{flex:1 1}.demo-cat-count-side{background:var(--bg-hover);border-radius:10px;color:var(--text-muted);font-size:.78rem;padding:1px 7px}.demo-sidebar-upgrade{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-top:auto;padding:14px;text-align:center}.demo-sidebar-upgrade-title{font-size:.92rem;font-weight:600;margin-bottom:2px}.demo-sidebar-upgrade-sub{color:var(--text-muted);font-size:.78rem;margin-bottom:10px}.demo-sidebar-upgrade .demo-btn-primary{width:100%}.demo-sidebar-upgrade-link{background:#0000;border:none;color:var(--text-muted);cursor:pointer;display:block;font-size:.82rem;margin-top:8px;padding:4px;text-decoration:underline;transition:color .15s;width:100%}.demo-sidebar-upgrade-link:hover{color:var(--accent)}.demo-main{background:var(--bg);flex:1 1;min-width:0}.demo-page-header{align-items:center;display:flex;gap:12px;margin:0 auto;max-width:760px;padding:20px 24px 8px}.demo-nav-hint-group{align-items:center;display:flex;flex-direction:column;line-height:1}.demo-nav-hint{animation:demoPulse 1.4s ease-in-out infinite;color:var(--priority-high);display:none;font-size:.7rem;font-weight:700;letter-spacing:.02em;margin-bottom:1px}@keyframes demoPulse{0%,to{opacity:.65;transform:translateY(0)}50%{opacity:1;transform:translateY(-1px)}}.demo-sidebar-hint{animation:demoPulse 1.4s ease-in-out infinite;color:var(--priority-high);font-size:.7rem;font-weight:700;letter-spacing:.02em;margin-left:auto}.demo-mobile-nav-btn{background:#0000;border:none;color:var(--text);cursor:pointer;display:none;font-size:1.4rem;padding:4px 10px}.demo-page-title{color:var(--text);font-family:var(--font-display);font-size:1.8rem;font-weight:400;margin:0}.demo-main-inner{animation:demoFadeIn .2s ease-out;margin:0 auto;max-width:760px;padding:14px 24px 80px}@keyframes demoFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.demo-btn-primary{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 14px;transition:background .15s;white-space:nowrap}.demo-btn-primary:hover{background:var(--accent-hover)}.demo-btn-sm{font-size:.82rem;padding:6px 10px}.demo-btn-lg{font-size:1rem;padding:12px 22px}.demo-btn-ghost{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 14px;transition:background .15s}.demo-btn-ghost:hover{background:var(--bg-hover)}.demo-input,.demo-select{font-size:.95rem;padding:10px 12px}.demo-select{padding:9px 12px}.demo-select--full{margin-bottom:14px;width:100%}.demo-label{color:var(--text-muted);display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:12px 0 6px;text-transform:uppercase}.demo-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:16px;padding:18px 20px}.demo-card-title{color:var(--text);font-size:1rem;font-weight:600;margin:0}.demo-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.demo-task-add{display:flex;gap:8px;margin-bottom:16px}.demo-task-add .demo-input{flex:1 1}.demo-task-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.demo-task-empty{background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.9rem;padding:24px 16px;text-align:center}.demo-task{align-items:center;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:12px;padding:10px 14px;transition:background .15s}.demo-task:hover{background:var(--bg-hover)}.demo-task--done .demo-task-title{color:var(--text-muted);text-decoration:line-through}.demo-checkbox{align-items:center;background:#fff;border:1.5px solid var(--border);border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:22px;justify-content:center;padding:0;transition:background .15s,border-color .15s;width:22px}.demo-checkbox--on{background:var(--accent);border-color:var(--accent)}.demo-task-title{flex:1 1;font-size:.95rem}.demo-task-cat{border-radius:10px;font-size:.72rem;font-weight:600;padding:2px 8px;white-space:nowrap}.demo-task-pri{align-items:center;background:var(--priority-high);border-radius:50%;color:#fff;display:inline-flex;font-size:.7rem;font-weight:800;height:18px;justify-content:center;line-height:1;width:18px}.demo-task-due{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.demo-task-due--overdue{color:var(--priority-high);font-weight:600}.demo-summary-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.demo-summary-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:14px 18px}.demo-summary-label{color:var(--text-muted);font-size:.72rem;font-weight:600;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.demo-summary-num{color:var(--text);font-family:var(--font-display);font-size:1.6rem;font-weight:400}.demo-summary-card--income .demo-summary-num{color:var(--success)}.demo-summary-card--expense .demo-summary-num{color:var(--priority-high)}.demo-summary-card--net-pos .demo-summary-num{color:var(--success)}.demo-summary-card--net-neg .demo-summary-num{color:var(--priority-high)}.demo-cat-list{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.demo-cat-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:28px 1fr 100px auto}.demo-cat-icon{font-size:1.2rem}.demo-cat-name{font-size:.92rem}.demo-cat-bar{background:var(--bg-hover);border-radius:4px;height:8px;overflow:hidden}.demo-cat-bar-fill{border-radius:4px;height:100%;transition:width .3s}.demo-cat-amt{font-feature-settings:"tnum";font-size:.9rem;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.demo-tx-list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.demo-tx{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:12px;padding:10px 4px}.demo-tx:last-child{border-bottom:none}.demo-tx-icon{flex-shrink:0;font-size:1.1rem}.demo-tx-body{display:flex;flex:1 1;flex-direction:column;min-width:0}.demo-tx-desc{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.demo-tx-date{color:var(--text-muted);font-size:.75rem}.demo-tx-amt{font-feature-settings:"tnum";font-size:.92rem;font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.demo-tx-amt--pos{color:var(--success)}.demo-tx-amt--neg{color:var(--priority-high)}.demo-plan-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.demo-plan-dates{color:var(--text-muted);font-size:.85rem;margin-top:2px}.demo-plan-summary{display:flex;font-size:.92rem;gap:18px}.demo-plan-summary strong{font-family:var(--font-display);font-size:1.2rem;font-weight:400}.demo-plan-label{color:var(--text-muted);font-size:.78rem;margin-right:5px}.demo-plan-strip{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(7,1fr)}.demo-plan-day{background:var(--bg-hover);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;flex-direction:column;font-size:.8rem;gap:2px;padding:10px}.demo-plan-day--today{background:var(--accent-soft);border-color:var(--accent)}.demo-plan-day-date{color:var(--text-muted);font-size:.74rem;font-weight:700;margin-bottom:4px;text-transform:uppercase}.demo-plan-day-in{color:var(--success);font-weight:600}.demo-plan-day-out{color:var(--priority-high);font-weight:600}.demo-plan-day-bal{color:var(--text);font-family:var(--font-display);font-size:1.05rem;font-weight:400;margin-top:4px}.demo-plan-day-note{color:var(--text-muted);font-size:.7rem;line-height:1.3;margin-top:4px}.demo-plan-tip{background:var(--accent-soft);border:1px solid #bfdbfe;border-radius:var(--radius-sm);color:var(--text);font-size:.88rem;line-height:1.5;margin-top:20px;padding:12px 16px}.demo-plan-bal-btn{align-items:center;background:#0000;border:none;color:inherit;cursor:pointer;display:inline-flex;font:inherit;gap:4px;padding:0}.demo-plan-bal-btn:hover .demo-plan-bal-pencil{opacity:1}.demo-plan-bal-pencil{font-size:.7rem;opacity:.4;transition:opacity .15s}.demo-plan-bal-input{font-family:var(--font-display);font-size:1.2rem;padding:4px 8px;width:100px}.demo-plan-day-bal--neg,.demo-plan-end-neg{color:var(--priority-high)}.demo-plan-day-bal--neg{font-weight:600}.demo-plan-day--clickable{color:inherit;cursor:pointer;font:inherit;text-align:left;transition:background .15s,border-color .15s,transform .1s}.demo-plan-day--clickable:hover{border-color:var(--accent);transform:translateY(-1px)}.demo-plan-day--selected{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.demo-day-panel{animation:demoFadeIn .2s ease-out}.demo-day-panel-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:10px;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.demo-day-empty{color:var(--text-muted);font-size:.9rem;padding:20px 0;text-align:center}.demo-day-events{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.demo-day-event{align-items:center;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:12px;padding:10px 12px}.demo-day-ev-icon{flex-shrink:0;font-size:1.1rem}.demo-day-ev-body{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:8px;min-width:0}.demo-day-ev-label{font-size:.92rem;font-weight:500}.demo-day-ev-tag{border-radius:4px;font-size:.68rem;font-weight:600;letter-spacing:.05em;padding:2px 7px;text-transform:uppercase;white-space:nowrap}.demo-day-ev-tag--bill{background:#e8e3dc;color:#7a7570}.demo-day-ev-tag--subscription{background:#fef3c7;color:#92400e}.demo-day-ev-tag--income{background:#dcfce7;color:#166534}.demo-day-ev-tag--plan{background:var(--accent-soft);color:var(--accent)}.demo-day-ev-amt{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.demo-day-ev-del{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:4px 8px;transition:background .15s,color .15s}.demo-day-ev-del:hover{background:var(--priority-high);color:#fff}.demo-convert{max-width:440px;text-align:center}.demo-convert-headline{color:var(--text);font-family:var(--font-display);font-size:1.85rem;font-weight:400;margin-bottom:14px}.demo-convert-body{color:var(--text);font-size:.95rem;line-height:1.5;margin-bottom:20px}.demo-convert-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.demo-convert-fine{color:var(--text-light);font-size:.75rem}.demo-modal-type-toggle{display:flex;gap:6px;margin:6px 0 8px}.demo-toggle{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;flex:1 1;font-size:.88rem;padding:8px;transition:background .15s,color .15s,border-color .15s}.demo-toggle--on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.demo-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.demo-sidebar-close{background:var(--bg-card);border:1px solid var(--border);border-radius:50%;color:var(--text);cursor:pointer;display:none;font-size:1rem;height:36px;position:absolute;right:10px;top:10px;width:36px;z-index:1}.demo-sidebar-close:hover{background:var(--bg-hover)}.demo-sidebar-backdrop{animation:demoFadeIn .15s ease-out;background:#00000073;display:none;inset:0;position:fixed;z-index:69}@media (max-width:820px){.demo-sidebar{bottom:0;left:0;max-width:85vw;overflow-y:auto;padding:56px 14px 20px;position:fixed;top:0;transform:translateX(-100%);transition:transform .2s ease-out;width:280px;z-index:70}.demo-sidebar--open{box-shadow:4px 0 20px #0003;transform:translateX(0)}.demo-mobile-nav-btn,.demo-nav-hint,.demo-sidebar-backdrop,.demo-sidebar-close{display:block}.demo-main{width:100%}.demo-page-header{padding:16px 18px 6px}.demo-main-inner{padding:8px 18px 80px}.demo-summary-row{grid-template-columns:1fr}.demo-plan-strip{grid-template-columns:repeat(2,1fr)}.demo-banner-inner{gap:6px;padding:8px 12px}.demo-banner-badge{display:none}.demo-banner-msg{flex-basis:100%;font-size:.78rem;line-height:1.35;order:1}.demo-banner-actions{gap:6px;order:2;width:100%}.demo-banner-btn-pricing,.demo-banner-btn-primary,.demo-banner-btn-signin{flex:1 1;font-size:.82rem;min-width:0;padding:7px 6px}}.admin-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.admin-panel{background:#fff;background:var(--bg,#fff);border-radius:14px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:800px;overflow:hidden;width:100%}.admin-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;justify-content:space-between;padding:20px 24px 16px}.admin-header h2{font-size:1.2rem;font-weight:600;margin:0}.admin-close{background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;font-size:1.1rem;padding:4px 8px}.admin-close:hover{background:#f3f4f6;background:var(--hover,#f3f4f6)}.admin-tabs{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;gap:0;padding:0 24px}.admin-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:10px 16px}.admin-tab:hover{color:#1a1a1a;color:var(--text,#1a1a1a)}.admin-tab-active{border-bottom-color:#2563eb;color:#2563eb!important}.admin-storage{overflow-y:auto}.admin-storage-total{font-weight:600}.admin-stats{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;gap:0}.admin-stat{border-right:1px solid #e5e7eb;border-right:1px solid var(--border,#e5e7eb);flex:1 1;padding:16px 24px;text-align:center}.admin-stat:last-child{border-right:none}.admin-stat-num{color:#4f46e5;color:var(--accent,#4f46e5);font-size:1.8rem;font-weight:700}.admin-stat-label{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.75rem;letter-spacing:.05em;margin-top:2px;text-transform:uppercase}.admin-error,.admin-loading{color:#6b7280;color:var(--text-muted,#6b7280);padding:32px;text-align:center}.admin-error{color:#ef4444}.admin-table{border-collapse:collapse;display:block;overflow-y:auto;width:100%}.admin-table thead{background:#fff;background:var(--bg,#fff);position:sticky;top:0;z-index:1}.admin-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);color:#6b7280;color:var(--text-muted,#6b7280);font-size:.72rem;letter-spacing:.05em;padding:10px 16px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border,#f3f4f6);font-size:.9rem;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#f9fafb;background:var(--hover,#f9fafb)}.admin-email{font-weight:500}.admin-date{font-size:.82rem}.admin-date,.admin-num{color:#6b7280;color:var(--text-muted,#6b7280)}.admin-num{text-align:center}.admin-badge{background:none;border:1.5px solid #d1d5db;border:1.5px solid var(--border,#d1d5db);border-radius:20px;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;font-size:.75rem;font-weight:600;padding:3px 10px;transition:all .15s}.admin-badge-on{background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.admin-delete{background:none;border:1.5px solid #fecaca;border-radius:6px;color:#ef4444;cursor:pointer;font-size:.75rem;font-weight:500;padding:3px 10px;transition:all .15s}.admin-delete:hover{background:#fef2f2}.admin-actions{align-items:center;display:flex;gap:6px}.admin-comp{background:none;border:1.5px solid #bfdbfe;border-radius:6px;color:#2563eb;cursor:pointer;font-size:.75rem;font-weight:500;padding:3px 10px;transition:all .15s}.admin-comp:hover{background:#eff6ff}.admin-comp-backdrop{align-items:center;background:#00000059;border-radius:14px;display:flex;inset:0;justify-content:center;position:absolute;z-index:10}.admin-comp-modal{background:#fff;background:var(--bg,#fff);border-radius:12px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;gap:14px;max-width:360px;padding:24px;width:100%}.admin-comp-header{align-items:center;display:flex;justify-content:space-between}.admin-comp-header h3{font-size:.95rem;margin:0}.admin-comp-header h3,.admin-comp-label{color:#1a1a1a;color:var(--text,#1a1a1a);font-weight:600}.admin-comp-label{display:flex;flex-direction:column;font-size:.82rem;gap:5px}.admin-comp-input{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:7px;color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.9rem;outline:none;padding:8px 12px}.admin-comp-input:focus{border-color:#2563eb}.admin-comp-hint{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.75rem;font-weight:400}.admin-comp-submit{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px;transition:background .15s,opacity .15s}.admin-comp-submit:hover:not(:disabled){background:#1d4ed8}.admin-comp-submit:disabled{cursor:not-allowed;opacity:.6}.admin-comp-msg{border-radius:6px;font-size:.85rem;padding:8px 12px}.admin-comp-msg-ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.admin-comp-msg-err{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.header-admin{background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;cursor:pointer;font-size:.8rem;font-weight:600;margin-right:4px;padding:4px 10px}.header-admin:hover{background:#e0e7ff}.checkout-page{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:40px 20px}.checkout-inner{max-width:760px;width:100%}.checkout-back{color:var(--text-muted);display:inline-block;font-size:.875rem;margin-bottom:32px;text-decoration:none;transition:color var(--transition)}.checkout-back:hover{color:var(--text)}.checkout-header{margin-bottom:40px;text-align:center}.checkout-header h1{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:8px}.checkout-brand{color:var(--accent)}.checkout-header p{color:var(--text-muted);font-size:1rem}.checkout-error{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);color:var(--priority-high);font-size:.875rem;margin-bottom:24px;padding:12px 16px;text-align:center}.checkout-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}@media (max-width:560px){.checkout-cards{grid-template-columns:1fr}}.checkout-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:28px 24px;position:relative}.checkout-card-pro{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-md)}.checkout-card-badge{background:var(--accent);border-radius:99px;color:#fff;font-size:.75rem;font-weight:600;left:50%;padding:4px 12px;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.checkout-card-header{margin-bottom:20px}.checkout-tier{color:var(--text-muted);display:block;font-size:.8rem;font-weight:600;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.checkout-tier-sub{font-weight:400;letter-spacing:normal;margin-left:4px;opacity:.75;text-transform:none}.checkout-price{align-items:baseline;display:flex;gap:4px}.checkout-price-amount{font-family:var(--font-display);font-size:2.5rem;font-weight:400;line-height:1}.checkout-price-period{color:var(--text-muted);font-size:.875rem}.checkout-features{color:var(--text);display:flex;flex-direction:column;font-size:.9rem;gap:10px;list-style:none;margin-bottom:24px}.checkout-features li{color:var(--text)}.checkout-feature-no{color:var(--text-light)!important;opacity:.6}.checkout-current{color:var(--text-muted);font-size:.875rem;padding:10px 0;text-align:center}.checkout-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:13px 20px;transition:background var(--transition);width:100%}.checkout-btn:hover:not(:disabled){background:var(--accent-hover)}.checkout-btn:disabled{cursor:not-allowed;opacity:.6}.checkout-subscribed-actions{display:flex;flex-direction:column;gap:10px}.checkout-btn-portal{background:#0000;border:1.5px solid var(--accent);color:var(--accent)}.checkout-btn-portal:hover:not(:disabled){background:var(--accent);color:#fff}.checkout-btn-ghost{background:#0000;border:1.5px solid var(--border);color:var(--text)}.checkout-btn-ghost:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.checkout-footer{font-size:.8rem;margin-top:24px}.checkout-footer,.checkout-legal-links{color:var(--text-light);text-align:center}.checkout-legal-links{font-size:.75rem;margin-top:10px}.checkout-legal-links a{color:var(--text-light);text-decoration:underline}.checkout-legal-links a:hover{color:var(--text-muted)}.sub-result-page{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:40px 20px}.sub-result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-width:440px;padding:48px 40px;text-align:center;width:100%}.sub-result-icon{align-items:center;border-radius:50%;display:flex;font-size:1.5rem;font-weight:700;height:56px;justify-content:center;margin:0 auto 24px;width:56px}.sub-result-icon--success{background:#ecfdf5;color:var(--success)}.sub-result-icon--cancel{background:#fef2f2;color:var(--priority-high)}.sub-result-card h1{font-family:var(--font-display);font-size:1.6rem;font-weight:400;margin-bottom:12px}.sub-result-card p{color:var(--text-muted);font-size:.95rem;line-height:1.6;margin-bottom:32px}.sub-result-btn{background:var(--accent);border-radius:var(--radius-sm);color:#fff;display:inline-block;font-size:.95rem;font-weight:600;padding:12px 28px;text-decoration:none;transition:background var(--transition)}.sub-result-btn:hover{background:var(--accent-hover)}.sub-result-actions{align-items:center;display:flex;flex-direction:column;gap:12px}.sub-result-link{color:var(--text-muted);font-size:.875rem;text-decoration:none}.sub-result-link:hover{color:var(--text)}.gift-page{align-items:flex-start;background:#f8fafc;background:var(--bg,#f8fafc);display:flex;justify-content:center;min-height:100vh;padding:48px 16px}.gift-inner{max-width:480px;width:100%}.gift-back{color:#6b7280;color:var(--text-muted,#6b7280);display:inline-block;font-size:.875rem;margin-bottom:32px;text-decoration:none}.gift-back:hover{color:#1a1a1a;color:var(--text,#1a1a1a)}.gift-header{margin-bottom:28px;text-align:center}.gift-icon{font-size:2.5rem;margin-bottom:12px}.gift-header h1{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1.75rem;font-weight:700;margin:0 0 8px}.gift-header p{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.95rem;line-height:1.5;margin:0}.gift-price-badge{background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:#1d4ed8;display:inline-block;display:flex;font-size:.85rem;font-weight:600;justify-content:center;margin:0 auto 28px;padding:6px 16px}.gift-form{display:flex;flex-direction:column;gap:8px}.gift-label{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.875rem;font-weight:600}.gift-input-row{display:flex;gap:8px}.gift-input{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:8px;color:#1a1a1a;color:var(--text,#1a1a1a);flex:1 1;font-size:.95rem;outline:none;padding:10px 14px;transition:border-color .15s}.gift-input:focus{border-color:#2563eb}.gift-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 20px;transition:background .15s,opacity .15s;white-space:nowrap}.gift-btn:hover:not(:disabled){background:#1d4ed8}.gift-btn:disabled{cursor:not-allowed;opacity:.6}.gift-btn-outline{background:#0000;border:1px solid #2563eb;color:#2563eb}.gift-btn-outline:hover:not(:disabled){background:#eff6ff}.gift-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.875rem;padding:8px 12px}.gift-hint{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.8rem;margin:0}.gift-recipient-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:24px}.gift-recipient-info{align-items:center;display:flex;gap:12px}.gift-recipient-avatar{align-items:center;background:#2563eb;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:44px;justify-content:center;width:44px}.gift-recipient-email{color:#1a1a1a;color:var(--text,#1a1a1a);font-weight:600}.gift-recipient-warning{color:#d97706;font-size:.8rem;margin-top:2px}.gift-blocked{display:flex;flex-direction:column;gap:12px}.gift-blocked,.gift-recipient-desc{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.9rem}.gift-recipient-desc{line-height:1.5;margin:0}.gift-actions{display:flex;flex-direction:column;gap:8px}.gift-footer{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.8rem;line-height:1.5;margin-top:24px;text-align:center}@media (max-width:480px){.gift-page{padding:24px 16px}.gift-input-row{flex-direction:column}}.legal-page{background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:40px 20px 80px}.legal-inner{max-width:720px;width:100%}.legal-back{color:var(--text-muted);display:inline-block;font-size:.875rem;margin-bottom:32px;text-decoration:none;transition:color var(--transition)}.legal-back:hover{color:var(--text)}.legal-inner h1{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:6px}.legal-updated{color:var(--text-light);font-size:.8rem;margin-bottom:40px}.legal-inner section{margin-bottom:32px}.legal-inner h2{color:var(--text);font-family:var(--font-display);font-size:1.1rem;font-weight:500;margin-bottom:10px}.legal-inner h3{color:var(--text);font-size:.9rem;font-weight:600;margin-bottom:6px;margin-top:16px}.legal-inner p{color:var(--text-muted);font-size:.9rem;line-height:1.7;margin-bottom:8px}.legal-inner ul{margin:6px 0;padding-left:20px}.legal-inner li{color:var(--text-muted);font-size:.9rem;line-height:1.7;margin-bottom:4px}.legal-inner a{color:var(--accent);text-decoration:underline}@media (max-width:768px){.legal-inner h1{font-size:1.5rem}.legal-inner h2{font-size:1rem}}.settings-page{background:var(--bg);min-height:100vh;padding:40px 20px}.settings-inner{margin:0 auto;max-width:520px}.settings-back{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:inline-flex;font-size:.85rem;gap:4px;margin-bottom:28px;padding:0}.settings-back:hover{color:var(--text)}.settings-inner h1{color:var(--text);font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin:0 0 4px}.settings-current-email{color:var(--text-muted);font-size:.9rem;margin:0 0 32px}.settings-section{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;margin-bottom:16px;padding:24px}.settings-section h2{color:var(--text);font-size:.95rem;font-weight:600;margin:0 0 16px}.settings-field{margin-bottom:14px}.settings-field label{color:var(--text-muted);display:block;font-size:.8rem;font-weight:500;margin-bottom:5px}.settings-field input{background:var(--bg);border:1px solid var(--border-light);border-radius:6px;box-sizing:border-box;color:var(--text);font-size:.9rem;padding:8px 10px;width:100%}.settings-field input:focus{border-color:var(--accent);outline:none}.settings-btn{background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:4px;padding:8px 16px}.settings-btn:hover:not(:disabled){opacity:.88}.settings-btn:disabled{cursor:not-allowed;opacity:.5}.settings-btn-danger{background:#e53e3e}.settings-btn-cancel{background:none;border:1px solid var(--border-light);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.875rem;padding:8px 16px}.settings-btn-cancel:hover{border-color:var(--text-muted);color:var(--text)}.settings-actions{display:flex;gap:10px;margin-top:4px}.settings-hint{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:0 0 14px}.settings-success{color:var(--priority-low);font-size:.875rem;margin:0}.settings-error{color:var(--accent);font-size:.8rem;margin:0 0 10px}.settings-danger-zone{border-color:#e53e3e4d}.settings-danger-zone h2{color:#e53e3e}.doer-page{padding:0}.doer-header{margin-bottom:24px}.doer-header h1{color:var(--text);font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:0 0 4px}.doer-subtitle{color:var(--text-muted);font-size:.85rem;margin:0}.doer-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.doer-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:24px}.doer-card--coming-soon{opacity:.6}.doer-card-icon{font-size:1.8rem;line-height:1}.doer-card-body h2{color:var(--text);font-size:1rem;font-weight:600;margin:0 0 6px}.doer-card-body p{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:0}.doer-card-btn{align-self:flex-start;background:var(--accent);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:auto;padding:9px 16px}.doer-card-btn:hover:not(:disabled){opacity:.88}.doer-card-btn:disabled{cursor:not-allowed;opacity:.5}.doer-coming-soon-badge{align-self:flex-start;background:var(--border-light);border-radius:20px;color:var(--text-muted);display:inline-block;font-size:.75rem;font-weight:500;padding:4px 10px}.doer-usage{display:flex;flex-direction:column;gap:5px;margin-top:10px}.doer-usage-bar{background:var(--border-light);border-radius:99px;height:5px;overflow:hidden}.doer-usage-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .3s ease}.doer-usage-label{color:var(--text-muted);font-size:.75rem}.doer-pin-hint{color:var(--text-muted);font-size:.8rem;margin:4px 0 0}.doer-card-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between}.doer-pin-btn{background:var(--surface);border:1px solid var(--border-light);border-radius:20px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.72rem;font-weight:600;margin-top:2px;padding:4px 10px;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.doer-pin-btn:hover{background:#2563eb;background:var(--accent,#2563eb);border-color:#2563eb;border-color:var(--accent,#2563eb);color:#fff}.doer-pin-btn--pinned{background:#e8f4fd;border-color:#b8daf5;color:#1a6fa8}.doer-pin-btn--pinned:hover{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.doer-pin-remove{margin-left:4px;opacity:.7}.doer-replace-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.doer-replace-modal{background:#fff;background:var(--bg,#fff);border-radius:14px;box-shadow:0 16px 48px #00000038;display:flex;flex-direction:column;gap:14px;max-width:380px;padding:24px;width:100%}.doer-replace-title{color:var(--text);font-size:1rem;font-weight:700}.doer-replace-desc{color:var(--text-muted);font-size:.84rem;line-height:1.5}.doer-replace-options{display:flex;flex-direction:column;gap:8px}.doer-replace-opt{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;cursor:pointer;display:flex;font-size:.875rem;gap:12px;padding:12px 14px;text-align:left;transition:border-color .15s,background .15s}.doer-replace-opt:hover{background:#e8f4fd;border-color:#2563eb;border-color:var(--accent,#2563eb)}.doer-replace-opt-icon{flex-shrink:0;font-size:1.3rem}.doer-replace-opt-label{color:var(--text);flex:1 1;font-weight:500}.doer-replace-opt-swap{color:#2563eb;color:var(--accent,#2563eb);font-size:.75rem;font-weight:600}.doer-replace-cancel{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.84rem;padding:4px;text-align:center}.doer-replace-cancel:hover{color:var(--text);text-decoration:underline}.doer-loading{color:var(--text-muted);font-size:.9rem;padding:48px 0;text-align:center}.doer-card--locked{opacity:.72;position:relative}.doer-card--locked .doer-card-body h2,.doer-card--locked .doer-card-body p{color:var(--text-muted)}.doer-lock-badge{background:#fef3c7;border:1px solid #fcd34d;border-radius:20px;color:#92400e;display:inline-block;flex-shrink:0;font-size:.72rem;font-weight:600;margin-top:2px;padding:3px 8px;white-space:nowrap}.doer-card-btn--locked{background:#0000;border:1px solid var(--border-light);color:var(--text-muted);cursor:pointer}.doer-card-btn--locked:hover{background:#fef3c7;border-color:#fcd34d;color:#92400e}.doer-shared-section{border-top:1px solid var(--border-light);margin-top:32px;padding-top:24px}.doer-shared-title{color:var(--text-muted);font-size:.85rem;font-weight:700;letter-spacing:.04em;margin-bottom:12px;text-transform:uppercase}.doer-shared-grid{display:flex;flex-direction:column;gap:10px}.doer-shared-card{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:12px;display:flex;gap:12px;padding:14px 16px}.doer-shared-card-icon{flex-shrink:0;font-size:1.4rem}.doer-shared-card-body{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.doer-shared-card-owner{color:var(--text);font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doer-shared-card-meta{color:var(--text-muted);font-size:.76rem}.doer-shared-card-btn{flex-shrink:0;font-size:.85rem!important;padding:7px 18px!important}.preview-panel{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;flex-shrink:0;max-height:calc(100vh - 120px);position:sticky;top:20px;width:300px}.preview-panel-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 16px 8px}.preview-panel-header h3{color:var(--text);font-size:.9rem;font-weight:600;margin:0 0 2px}.preview-panel-count{color:var(--text-muted);font-size:.75rem;margin:0}.preview-revert-btn{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:2px 6px;white-space:nowrap}.preview-revert-btn:hover:not(:disabled){color:var(--accent)}.preview-panel-actions{border-bottom:1px solid var(--border-light);padding:8px 16px}.preview-select-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.78rem;padding:0}.preview-select-btn:hover{text-decoration:underline}.preview-suggestions{flex:1 1;overflow-y:auto;padding:8px}.preview-empty{color:var(--text-muted);font-size:.85rem;margin:0;padding:20px;text-align:center}.preview-suggestion{align-items:flex-start;border:1px solid #0000;border-radius:7px;cursor:pointer;display:flex;gap:10px;margin-bottom:4px;padding:8px}.preview-suggestion:hover{background:var(--bg)}.preview-suggestion.selected{background:color-mix(in srgb,var(--accent) 8%,#0000);border-color:color-mix(in srgb,var(--accent) 25%,#0000)}.preview-suggestion input[type=checkbox]{accent-color:var(--accent);flex-shrink:0;margin-top:3px}.preview-suggestion-body{display:flex;flex-direction:column;gap:4px;min-width:0}.preview-suggestion-title{color:var(--text);font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-suggestion-move{align-items:center;display:flex;font-size:.75rem;gap:5px}.preview-arrow,.preview-from{color:var(--text-muted)}.preview-to{align-items:center;color:var(--accent);display:flex;font-weight:500;gap:4px}.preview-new-badge{background:color-mix(in srgb,var(--accent) 15%,#0000);border-radius:4px;color:var(--accent);font-size:.65rem;font-weight:600;padding:1px 5px}.preview-panel-footer{border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:8px;padding:12px 16px}.preview-confirm-btn{background:var(--accent);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:9px;width:100%}.preview-confirm-btn:hover:not(:disabled){opacity:.88}.preview-confirm-btn:disabled{cursor:not-allowed;opacity:.4}.preview-revert-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:0;text-align:center}.preview-revert-link:hover:not(:disabled){color:var(--text)}@media (max-width:768px){.preview-panel{background:#fff;background:var(--bg-card,#fff);border-bottom:none;border-radius:16px 16px 0 0;bottom:0;box-shadow:0 -4px 20px #00000026;left:0;max-height:50vh;position:fixed;right:0;width:100%;z-index:200}}.rem-loading{color:#888;color:var(--text-muted,#888);padding:40px;text-align:center}.rem-page{margin:0 auto;max-width:700px;padding:8px 0 40px}.rem-page-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:24px}.rem-page-title{font-size:1.4rem;font-weight:700;margin:0 0 4px}.rem-page-sub{color:#888;color:var(--text-muted,#888);font-size:.88rem;margin:0}.rem-add-btn{background:#4f46e5;background:var(--accent,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.9rem;font-weight:600;padding:9px 16px;white-space:nowrap}.rem-add-btn:hover{opacity:.88}.rem-cats{display:flex;flex-direction:column;gap:10px}.rem-cat-card{background:#fff;background:var(--surface,#fff);border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:12px;overflow:hidden;transition:border-color .15s}.rem-cat-card--open{border-opacity:.4;border-color:#4f46e5;border-color:var(--accent,#4f46e5)}.rem-cat-header{align-items:center;background:none;border:none;color:#1a1a1a;color:var(--text,#1a1a1a);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:10px;padding:14px 16px;text-align:left;width:100%}.rem-cat-header:hover{background:#f8f8f8;background:var(--surface-alt,#f8f8f8)}.rem-cat-icon{flex-shrink:0;font-size:1.25rem;line-height:1}.rem-cat-name{flex:1 1;font-size:.97rem;font-weight:600}.rem-cat-count{background:#4f46e5;background:var(--accent,#4f46e5);border-radius:10px;color:#fff;flex-shrink:0;font-size:.72rem;font-weight:700;line-height:1.5;padding:2px 7px}.rem-cat-chevron{color:#aaa;color:var(--text-muted,#aaa);flex-shrink:0;font-size:1.3rem;line-height:1;transform:rotate(0deg);transition:transform .18s}.rem-cat-chevron--open{transform:rotate(90deg)}.rem-cat-body{border-top:1px solid #e0e0e0;border-top:1px solid var(--border,#e0e0e0);display:flex;flex-direction:column;gap:10px;padding:12px 16px 14px}.rem-cat-empty{color:#aaa;color:var(--text-muted,#aaa);font-size:.85rem;margin:0;padding:2px 0}.rem-item{background:#f9f9f9;background:var(--surface-alt,#f9f9f9);border:1px solid #ebebeb;border:1px solid var(--border,#ebebeb);border-radius:8px;padding:10px 12px}.rem-item-main{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.rem-item-title{flex:1 1;font-size:.93rem;font-weight:600}.rem-item-rec{color:#4f46e5;color:var(--accent,#4f46e5);font-size:.75rem;font-weight:600;white-space:nowrap}.rem-item-meta{color:#888;color:var(--text-muted,#888);display:flex;font-size:.78rem;gap:14px;margin-bottom:6px}.rem-item-notes{color:#666;color:var(--text-secondary,#666);font-size:.82rem;margin-bottom:6px;white-space:pre-wrap}.rem-item-actions{display:flex;gap:6px}.rem-item-del,.rem-item-edit{background:none;border:1px solid #ddd;border:1px solid var(--border,#ddd);border-radius:6px;color:#555;color:var(--text-secondary,#555);cursor:pointer;font-size:.8rem;padding:3px 10px}.rem-item-edit:hover{background:#fff;background:var(--surface,#fff)}.rem-item-del{border-color:#fccaca;color:#e74c3c}.rem-item-del:hover{background:#fff5f5}.rem-cat-templates{display:flex;flex-wrap:wrap;gap:6px}.rem-cat-template-btn{background:none;border:1px dashed #ccc;border:1px dashed var(--border,#ccc);border-radius:20px;color:#777;color:var(--text-muted,#777);cursor:pointer;font-size:.8rem;padding:4px 12px;transition:border-color .15s,color .15s,background .15s}.rem-cat-template-btn:hover{background:#4f46e50d;border-color:#4f46e5;border-color:var(--accent,#4f46e5);color:#4f46e5;color:var(--accent,#4f46e5)}.rem-cat-add-btn{background:none;border:none;color:#4f46e5;color:var(--accent,#4f46e5);cursor:pointer;font-size:.85rem;font-weight:600;padding:2px 0;text-align:left;width:fit-content}.rem-cat-add-btn:hover{opacity:.75}.rem-modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:300}.rem-modal{background:#fff;background:var(--surface,#fff);border-radius:12px;box-shadow:0 12px 40px #0000002e;max-height:90vh;max-width:460px;overflow-y:auto;padding:24px;width:100%}.rem-modal-title{font-size:1.15rem;font-weight:700;margin:0 0 16px}.rem-modal-error{background:#fff5f5;border:1px solid #fccaca;border-radius:6px;color:#c0392b;font-size:.85rem;margin-bottom:12px;padding:8px 12px}.rem-label{color:#555;color:var(--text-secondary,#555);display:flex;flex-direction:column;font-size:.82rem;font-weight:600;gap:4px;margin-bottom:12px}.rem-input{background:#fff;background:var(--surface,#fff);border:1px solid #ddd;border:1px solid var(--border,#ddd);border-radius:7px;box-sizing:border-box;color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.9rem;padding:8px 10px;width:100%}.rem-input:focus{border-color:#4f46e5;border-color:var(--accent,#4f46e5);outline:none}.rem-textarea{font-family:inherit;min-height:70px;resize:vertical}.rem-modal-actions{display:flex;gap:10px;margin-top:18px}.rem-modal-save{background:#4f46e5;background:var(--accent,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:9px 18px}.rem-modal-save:disabled{cursor:default;opacity:.6}.rem-modal-save:not(:disabled):hover{opacity:.88}.rem-modal-cancel{background:none;border:1px solid #ddd;border:1px solid var(--border,#ddd);border-radius:8px;color:#555;color:var(--text-secondary,#555);cursor:pointer;font-size:.9rem;padding:9px 16px}.rem-modal-cancel:hover{background:#f5f5f5;background:var(--surface-alt,#f5f5f5)}.budget-view{display:flex;flex-direction:column;gap:20px}.budget-month-nav{align-items:center;display:flex;gap:12px}.budget-month-btn{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;display:flex;font-size:1rem;height:30px;justify-content:center;width:30px}.budget-month-btn:hover:not(:disabled){background:var(--border-light)}.budget-month-btn:disabled{cursor:not-allowed;opacity:.4}.budget-month-label{color:var(--text);font-size:1rem;font-weight:600}.budget-range-toggle{background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.78rem;font-weight:500;margin-left:auto;padding:4px 10px;transition:background .15s,color .15s;white-space:nowrap}.budget-range-toggle:hover{background:var(--border-light);color:var(--text)}.budget-range-nav{display:flex;flex-direction:column;gap:8px}.budget-range-nav-top{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.budget-range-back{background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.8rem;padding:4px 0;white-space:nowrap}.budget-range-back:hover{color:var(--text)}.budget-range-chips{display:flex;flex-wrap:wrap;gap:4px}.budget-range-chip{background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.78rem;font-weight:500;padding:4px 10px;transition:background .12s,color .12s,border-color .12s}.budget-range-chip:hover{background:var(--border-light);color:var(--text)}.budget-range-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.budget-range-custom{align-items:center;display:flex;flex-wrap:wrap;gap:8px;padding:6px 0}.budget-range-date-input{background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;font-size:.82rem;padding:5px 8px}.budget-range-to-label{color:var(--text-muted);font-size:.8rem}.budget-range-apply{background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.82rem;font-weight:600;padding:5px 14px;transition:opacity .15s}.budget-range-apply:disabled{cursor:not-allowed;opacity:.45}.budget-range-label{align-items:center;color:var(--text);display:flex;font-size:.9rem;font-weight:600;gap:8px;padding:2px 0}.budget-range-months-badge{background:var(--accent);border-radius:10px;color:#fff;font-size:.72rem;font-weight:600;opacity:.85;padding:2px 7px}.budget-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.budget-summary-card{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;flex-direction:column;gap:4px;padding:16px}.budget-summary-card--over{background:#e74c3c08;border-color:#e74c3c44}.budget-summary-card--income,.budget-summary-card--positive{background:#2ecc7108;border-color:#2ecc7144}.budget-summary-card--income .budget-summary-value,.budget-summary-card--positive .budget-summary-value{color:#27ae60}.budget-summary-value{color:var(--text);font-size:1.15rem;font-weight:700}.budget-summary-label{color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.budget-summary-card--over .budget-summary-value{color:#e74c3c}.budget-summary-card--clickable{cursor:pointer;transition:filter .15s}.budget-summary-card--clickable:hover{filter:brightness(.96)}.budget-income-breakdown-toggle{color:#27ae60;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.01em;margin-top:6px}.budget-expense-breakdown-toggle{color:#e74c3c}.budget-expense-breakdown,.budget-expense-breakdown .budget-income-breakdown-total{border-color:#e74c3c30!important}.budget-income-breakdown{animation:fadeSlideDown .15s ease;background:var(--surface);border:1px solid #2ecc7130;border-radius:10px;display:flex;flex-direction:column;gap:0;padding:14px 16px}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.budget-income-breakdown-title{color:#27ae60;font-size:.72rem;font-weight:700;letter-spacing:.07em;margin-bottom:10px;text-transform:uppercase}.budget-income-breakdown-section{color:var(--text-muted);font-size:.7rem;font-weight:600;letter-spacing:.05em;margin:8px 0 4px;text-transform:uppercase}.budget-income-breakdown-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:8px;padding:5px 0}.budget-income-breakdown-row:last-of-type{border-bottom:none}.budget-income-breakdown-name{color:var(--text);flex:1 1;font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-income-breakdown-freq{color:var(--text-muted);font-size:.78rem;white-space:nowrap}.budget-income-breakdown-amt{color:#27ae60;font-size:.9rem;font-weight:600;white-space:nowrap}.budget-income-breakdown-subtotal{border-top:1px dashed var(--border-light);color:var(--text-muted);display:flex;font-size:.82rem;justify-content:space-between;margin-top:2px;padding:5px 0}.budget-income-breakdown-total{border-top:2px solid #2ecc7130;color:var(--text);display:flex;font-size:.92rem;font-weight:700;justify-content:space-between;margin-top:6px;padding:8px 0 2px}.budget-tabs-wrapper{align-items:stretch;display:flex;position:relative}.budget-tabs-arrow{background:var(--surface);border:none;border-bottom:1px solid var(--border-light);color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:1.1rem;padding:0 8px;transition:background .15s,color .15s,opacity .15s;z-index:1}.budget-tabs-arrow:hover:not(:disabled){background:var(--border-light);color:var(--text)}.budget-tabs-arrow--left{border-right:1px solid var(--border-light)}.budget-tabs-arrow--right{border-left:1px solid var(--border-light)}.budget-tabs{-ms-overflow-style:none;border-bottom:1px solid var(--border-light);display:flex;flex:1 1;gap:4px;min-width:0;overflow-x:auto;scrollbar-width:none}.budget-tabs::-webkit-scrollbar{display:none}.budget-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:8px 14px}.budget-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.budget-tab-content{display:flex;flex-direction:column;gap:12px}.budget-overview-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.budget-overview-title{color:var(--text-muted);font-size:.85rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.budget-edit-btn{background:none;border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;font-size:.8rem;padding:5px 12px}.budget-edit-btn:hover{background:var(--border-light)}.budget-edit-btn--save{background:var(--accent);border-color:var(--accent);color:#fff}.budget-edit-btn--save:hover{background:var(--accent);opacity:.88}.budget-category-row{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:14px 16px}.budget-category-row--child{background:var(--bg);border-left:3px solid var(--border-light);border-radius:0 10px 10px 0;margin-left:20px}.budget-category-child-indent{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.budget-cat-rollup-note{color:var(--text-muted);font-size:.7rem;font-weight:400;margin-left:2px}.budget-amount-input-row--child{padding-left:16px}.budget-category-row-header{align-items:center;display:flex;gap:10px}.budget-category-icon{font-size:1.2rem}.budget-category-name{color:var(--text);flex:1 1;font-size:.9rem;font-weight:600}.budget-category-amounts{color:var(--text);font-size:.875rem;font-weight:600}.budget-category-amounts.over{color:#e74c3c}.budget-category-of{color:var(--text-muted);font-weight:400}.budget-bar-wrap{align-items:center;display:flex;gap:8px}.budget-bar{background:var(--border-light);border-radius:99px;flex:1 1;height:6px;overflow:hidden}.budget-bar-fill{border-radius:99px;height:100%;transition:width .3s ease}.budget-bar-fill.over{background:#e74c3c!important}.budget-bar-pct{color:var(--text-muted);font-size:.75rem;min-width:32px;text-align:right}.budget-no-limit{color:var(--text-muted);font-size:.78rem;font-style:italic}.budget-amount-input-row{align-items:center;color:var(--text-muted);display:flex;font-size:.85rem;gap:6px}.budget-amount-input{background:var(--bg);border:1px solid var(--border-light);border-radius:6px;color:var(--text);font-size:.875rem;padding:4px 8px;width:100px}.budget-tx-header{display:flex;justify-content:flex-end}.budget-add-tx-btn{background:var(--accent);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px}.budget-add-tx-btn:hover{opacity:.88}.budget-import-btn{background:none;border:1px solid var(--border-light);border-radius:7px;color:var(--text);cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 14px}.budget-import-btn:hover{background:var(--border-light)}.budget-type-toggle{border:1px solid var(--border-light);border-radius:8px;display:flex;overflow:hidden}.budget-type-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:8px}.budget-type-btn.active-expense{background:#e74c3c;color:#fff}.budget-type-btn.active-income{background:#27ae60;color:#fff}.budget-tx-form{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;gap:12px;padding:16px}.budget-form-row,.budget-tx-form{display:flex;flex-direction:column}.budget-form-row{gap:4px}.budget-form-row label{color:var(--text-muted);font-size:.8rem;font-weight:500}.budget-form-row input,.budget-form-row select{background:var(--bg);border:1px solid var(--border-light);border-radius:7px;color:var(--text);font-size:.875rem;padding:8px 10px}.budget-form-actions{display:flex;gap:8px}.budget-save-btn{background:var(--accent);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 20px}.budget-save-btn:disabled{cursor:not-allowed;opacity:.6}.budget-cancel-btn{background:none;border:1px solid var(--border-light);border-radius:7px;color:var(--text);cursor:pointer;font-size:.875rem;padding:8px 16px}.budget-tx-list{display:flex;flex-direction:column;gap:8px}.budget-tx-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;gap:10px;padding:12px 14px}.budget-tx-icon{font-size:1.2rem}.budget-tx-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.budget-tx-note{color:var(--text);font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-tx-meta{color:var(--text-muted);font-size:.75rem}.budget-tx-amount{color:var(--text);font-size:.9rem;font-weight:600;white-space:nowrap}.budget-tx-amount--income{color:#27ae60}.budget-tx-row--income{background:#2ecc7106;border-color:#2ecc7130}.budget-tx-actions{display:flex;gap:4px}.budget-tx-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;opacity:.5;padding:4px}.budget-tx-btn:hover{background:var(--border-light);opacity:1}.budget-cat-list{display:flex;flex-direction:column;gap:8px}.budget-cat-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;gap:10px;padding:10px 14px}.budget-cat-row--child{background:var(--bg);border-left:3px solid var(--border-light);border-radius:0 8px 8px 0;margin-left:20px;padding:8px 12px}.budget-cat-child-indent{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.budget-cat-swatch{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:1rem;height:32px;justify-content:center;width:32px}.budget-cat-swatch--sm{font-size:.85rem;height:26px;width:26px}.budget-cat-name{color:var(--text);flex:1 1;font-size:.9rem;font-weight:500}.budget-tx-btn--add-sub{background:#0000;border:1px solid var(--accent);border-radius:5px;color:var(--accent);cursor:pointer;font-size:.68rem;font-weight:600;padding:2px 6px;white-space:nowrap}.budget-tx-btn--add-sub:hover{background:var(--accent);color:#fff}.budget-icon-picker{display:flex;flex-wrap:wrap;gap:6px}.budget-icon-opt{align-items:center;background:var(--bg);border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;width:36px}.budget-icon-opt.selected{background:var(--surface);border-color:var(--accent)}.budget-color-picker{display:flex;flex-wrap:wrap;gap:6px}.budget-color-opt{border:3px solid #0000;border-radius:50%;cursor:pointer;height:28px;outline:none;width:28px}.budget-color-opt.selected{border-color:var(--text)}.budget-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.budget-section-title{color:var(--text-muted);font-size:.85rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.budget-section-divider{border:none;border-top:1px solid var(--border-light);margin:8px 0}.budget-income-src-list{display:flex;flex-direction:column;gap:8px}.budget-income-src-row{align-items:center;background:var(--surface);border:1px solid #2ecc7130;border-radius:10px;display:flex;gap:10px;padding:12px 14px}.budget-income-src-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.budget-income-src-name{color:var(--text);font-size:.875rem;font-weight:500}.budget-income-src-freq{color:var(--text-muted);font-size:.75rem}.budget-income-src-monthly{color:#27ae60;font-size:.9rem;font-weight:600;white-space:nowrap}.budget-income-src-mo{color:var(--text-muted);font-size:.75rem;font-weight:400}.budget-income-src-badge{border-radius:10px;display:inline-block;font-size:.72rem;font-weight:600;padding:2px 7px}.budget-income-src-badge--variable{background:#fff3cd;color:#856404}.budget-income-src-monthly--variable{color:var(--text-muted);font-size:.78rem;font-style:italic;white-space:nowrap}.budget-income-src-block{border-bottom:1px solid var(--border-light)}.budget-income-src-block:last-of-type{border-bottom:none}.budget-income-src-right{align-items:center;display:flex;flex-shrink:0;gap:8px}.budget-income-src-match-chip{align-items:center;background:#e8f4fd;border:1px solid #b8daf5;border-radius:10px;color:#1a6fa8;cursor:pointer;display:inline-flex;font-size:.7rem;font-weight:500;gap:3px;padding:2px 8px;transition:background .15s;white-space:nowrap}.budget-income-src-match-chip.active,.budget-income-src-match-chip:hover{background:#c8e6fa}.budget-income-src-match-chip--none{background:var(--surface);border-color:var(--border-light);color:var(--text-muted);cursor:default;font-style:italic}.budget-income-src-matches{background:var(--surface);border-radius:0 0 8px 8px;margin-bottom:4px;padding:0 14px 8px}.budget-income-src-match-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;font-size:.82rem;gap:10px;padding:5px 0}.budget-income-src-match-row:last-of-type{border-bottom:none}.budget-income-src-match-date{color:var(--text-muted);font-size:.78rem;min-width:80px;white-space:nowrap}.budget-income-src-match-note{color:var(--text);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-income-src-match-amt{color:#27ae60;font-weight:600;white-space:nowrap}.budget-income-src-match-total{color:var(--text-muted);display:flex;font-size:.82rem;font-weight:600;justify-content:space-between;padding-top:6px}.budget-form-label-hint{color:var(--text-muted);font-size:.75rem;font-weight:400}.budget-form-hint{color:var(--text-muted);display:block;font-size:.75rem;margin-top:3px}.budget-income-variable-note{background:var(--surface);border:1px solid var(--border-light);border-radius:8px;color:var(--text-muted);font-size:.82rem;line-height:1.5;padding:10px 14px}.budget-income-total-row{align-items:center;border-top:1px solid var(--border-light);color:var(--text-muted);display:flex;font-size:.85rem;justify-content:space-between;margin-top:4px;padding:8px 14px}.budget-income-total-val{color:#27ae60;font-size:.95rem;font-weight:700}.budget-empty{color:var(--text-muted);font-size:.875rem;padding:32px 0;text-align:center}.budget-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.budget-upgrade-wall{align-items:center;display:flex;flex-direction:column;gap:12px;padding:60px 24px;text-align:center}.budget-upgrade-icon{font-size:2.5rem}.budget-upgrade-wall h2{font-family:var(--font-display);font-size:1.4rem;margin:0}.budget-upgrade-wall p{color:var(--text-muted);font-size:.9rem;margin:0;max-width:340px}.budget-upgrade-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:500;margin-top:8px;padding:10px 24px;text-decoration:none}.budget-loading{align-items:center;color:var(--text-muted);display:flex;gap:10px;padding:40px 0}.budget-tab{position:relative}.budget-tab-badge{align-items:center;background:#9b59b6;border-radius:10px;color:#fff;display:inline-flex;font-size:.65rem;font-weight:700;height:16px;justify-content:center;line-height:1;margin-left:5px;min-width:16px;padding:1px 5px;vertical-align:middle}.budget-sub-empty-icon{font-size:2rem;margin-bottom:8px}.budget-sub-list{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.budget-sub-row{background:var(--surface);border:1px solid var(--border-light);gap:12px;padding:12px 14px}.budget-sub-icon-wrap,.budget-sub-row{align-items:center;border-radius:10px;display:flex}.budget-sub-icon-wrap{flex-shrink:0;height:38px;justify-content:center;width:38px}.budget-sub-icon{font-size:1.15rem;line-height:1}.budget-sub-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.budget-sub-name{color:var(--text);font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-sub-meta{font-size:.75rem}.budget-sub-due,.budget-sub-meta{color:var(--text-muted)}.budget-sub-due--soon{color:#e67e22;font-weight:600}.budget-sub-amounts{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:2px}.budget-sub-price{color:var(--text);font-size:.9rem;font-weight:600;white-space:nowrap}.budget-sub-cycle{font-weight:400}.budget-sub-cycle,.budget-sub-monthly{color:var(--text-muted);font-size:.72rem}.budget-sub-total-row{align-items:center;background:#9b59b611;border:1px solid #9b59b633;border-radius:10px;display:flex;font-weight:600;justify-content:space-between;margin-top:8px;padding:12px 14px}.budget-sub-total-label{color:var(--text);font-size:.85rem}.budget-sub-total-val{color:#8e44ad;font-size:1rem;font-weight:700}.budget-sub-income-pct{color:var(--text-muted);font-size:.78rem;margin-top:6px;padding-bottom:4px;text-align:center}.budget-form-optional{color:var(--text-muted);font-size:.72rem;font-weight:400}.budget-tab-badge--bills{background:#e67e22}.budget-bills-list{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.budget-bill-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;gap:10px;padding:12px 14px;transition:opacity .15s}.budget-bill-row--paid{opacity:.6}.budget-bill-row--overdue{background:#e74c3c06;border-color:#e74c3c55}.budget-bill-check{align-items:center;background:#0000;border:2px solid var(--border-light);border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:26px;justify-content:center;transition:background .15s,border-color .15s;width:26px}.budget-bill-check:hover{border-color:#2ecc71}.budget-bill-check--paid{background:#2ecc71;border-color:#2ecc71}.budget-bill-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.budget-bill-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.budget-bill-name{color:var(--text);font-size:.9rem;font-weight:600}.budget-bill-autopay{background:#3498db22;color:#2980b9}.budget-bill-autopay,.budget-bill-paid-badge{border-radius:4px;font-size:.65rem;font-weight:600;letter-spacing:.04em;padding:1px 5px;text-transform:uppercase}.budget-bill-paid-badge{background:#2ecc7122;color:#27ae60}.budget-bill-daily-badge{background:#e67e2222;border-radius:4px;color:#d35400;font-size:.65rem;font-weight:600;letter-spacing:.04em;padding:1px 5px;text-transform:uppercase}.budget-bill-daily-icon{align-items:center;display:flex;flex-shrink:0;font-size:1rem;justify-content:center;width:28px}.budget-bill-per-day{color:var(--text-muted);font-size:.72rem;font-weight:400;margin-left:1px}.budget-bill-meta{font-size:.75rem}.budget-bill-due,.budget-bill-meta{color:var(--text-muted)}.budget-bill-due--urgent{color:#e67e22;font-weight:600}.budget-bill-due--overdue{color:#e74c3c;font-weight:600}.budget-bill-amount{color:var(--text);flex-shrink:0;font-size:.9rem;font-weight:600;white-space:nowrap}.budget-bill-amount--paid{color:var(--text-muted);text-decoration:line-through}.budget-bills-progress{display:flex;flex-direction:column;gap:4px;margin-top:8px}.budget-bills-progress-bar{background:var(--border-light);border-radius:99px;height:6px;overflow:hidden}.budget-bills-progress-fill{background:#2ecc71;border-radius:99px;height:100%;transition:width .3s ease}.budget-bills-progress-label{color:var(--text-muted);font-size:.75rem;text-align:right}.budget-bills-total-row{margin-top:4px}.budget-form-row--check{align-items:center;flex-direction:row;gap:8px}.budget-form-row--check label{align-items:center;color:var(--text);cursor:pointer;display:flex;font-size:.875rem;gap:8px}.budget-form-row--check input[type=checkbox]{accent-color:var(--accent);cursor:pointer;height:16px;width:16px}.budget-ov-cashflow{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;flex-direction:column;gap:6px;padding:14px}.budget-ov-cashflow-bar{background:var(--border-light);border-radius:99px;height:8px;overflow:hidden}.budget-ov-cashflow-fill{border-radius:99px;height:100%;transition:width .4s ease}.budget-ov-cashflow-labels{color:var(--text-muted);display:flex;font-size:.78rem;justify-content:space-between}.budget-ov-cashflow-spent{color:var(--text);font-weight:600}.budget-ov-savings-rate{font-size:.8rem;font-weight:600;text-align:right}.budget-ov-alerts{display:flex;flex-direction:column;gap:6px}.budget-ov-alert{align-items:center;border-radius:8px;display:flex;font-size:.82rem;gap:10px;justify-content:space-between;padding:9px 12px}.budget-ov-alert--over{background:#e74c3c0d;border:1px solid #e74c3c33;color:var(--text)}.budget-ov-alert--warn{background:#e67e220d;border:1px solid #e67e2233;color:var(--text)}.budget-ov-alert-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.78rem;font-weight:600;padding:0;white-space:nowrap}.budget-ov-section-title{color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.06em;padding-top:4px;text-transform:uppercase}.budget-ov-top-cats{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;flex-direction:column;gap:8px;padding:12px 14px}.budget-ov-cat-row{align-items:center;display:flex;gap:10px}.budget-ov-cat-icon{flex-shrink:0;font-size:1.1rem}.budget-ov-cat-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.budget-ov-cat-name-row{align-items:baseline;display:flex;justify-content:space-between}.budget-ov-cat-name{color:var(--text);font-size:.83rem;font-weight:500}.budget-ov-cat-amt{color:var(--text);font-size:.83rem;font-weight:700}.budget-ov-cat-bar-wrap{align-items:center;display:flex;gap:6px}.budget-ov-cat-bar{background:var(--border-light);border-radius:99px;flex:1 1;height:5px;overflow:hidden}.budget-ov-cat-bar-fill{border-radius:99px;height:100%;transition:width .3s ease}.budget-ov-cat-pct{font-size:.7rem;min-width:30px;text-align:right;white-space:nowrap}.budget-ov-atrisk{align-items:center;background:#e67e220a;border:1px solid #e67e2222;border-radius:8px;display:flex;flex-wrap:wrap;font-size:.78rem;gap:6px;padding:8px 12px}.budget-ov-atrisk-label{color:#e67e22;font-weight:600;white-space:nowrap}.budget-ov-atrisk-chip{background:#e67e2218;border-radius:5px;color:#c0392b;font-weight:500;padding:2px 7px}.budget-ov-recent{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;overflow:hidden}.budget-ov-tx-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:10px;padding:10px 14px}.budget-ov-tx-row:last-child{border-bottom:none}.budget-ov-tx-icon{flex-shrink:0;font-size:1.1rem}.budget-ov-tx-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.budget-ov-tx-note{color:var(--text);font-size:.83rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-ov-tx-meta{color:var(--text-muted);font-size:.72rem}.budget-ov-tx-amt{color:var(--text);flex-shrink:0;font-size:.85rem;font-weight:700;white-space:nowrap}.budget-ov-tx-amt--income{color:#27ae60}.budget-ov-view-all{background:none;border:none;border-top:1px solid var(--border-light);color:var(--accent);cursor:pointer;display:block;font-size:.78rem;font-weight:600;padding:9px 14px;text-align:left;width:100%}.budget-ov-view-all:hover{background:var(--border-light)}.budget-ov-donut-wrap{align-items:center;display:flex;flex-direction:row;gap:20px;padding:12px 0 8px}.budget-ov-donut-wrap svg{flex-shrink:0}.budget-ov-donut-legend{display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:0}.budget-ov-donut-row{align-items:center;border-radius:6px;cursor:default;display:flex;gap:7px;padding:3px 5px;transition:background .12s}.budget-ov-donut-row--hover{background:var(--border-light)}.budget-ov-donut-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.budget-ov-donut-name{color:var(--text);flex:1 1;font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-ov-donut-pct{color:var(--text-muted);font-size:.75rem;white-space:nowrap}.budget-ov-donut-amt{color:var(--text);font-size:.8rem;font-weight:600;min-width:48px;text-align:right;white-space:nowrap}@media (max-width:400px){.budget-ov-donut-wrap{align-items:center;flex-direction:column}.budget-ov-donut-legend{width:100%}}.budget-analyze-btn{background:linear-gradient(135deg,#9b59b6,#6c3483);border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;transition:opacity .15s;white-space:nowrap}.budget-analyze-btn:hover:not(:disabled){opacity:.88}.budget-analyze-btn:disabled{cursor:not-allowed;opacity:.55}.budget-analyze-error{align-items:center;background:#e74c3c12;border:1px solid #e74c3c44;border-radius:8px;color:#e74c3c;display:flex;font-size:.85rem;justify-content:space-between;padding:10px 14px}.budget-analyze-error button{background:none;border:none;color:#e74c3c;cursor:pointer;font-size:1rem;padding:0 4px}.budget-analyze-panel{background:var(--surface);border:1px solid #9b59b644;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:16px}.budget-analyze-panel-header{align-items:center;display:flex;justify-content:space-between}.budget-analyze-panel-title{color:var(--text);font-size:.95rem;font-weight:700}.budget-analyze-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:0 4px}.budget-analyze-hint{color:var(--text-muted);font-size:.78rem;margin:0}.budget-analyze-empty{color:var(--text-muted);font-size:.85rem;padding:8px 0;text-align:center}.budget-analyze-group{border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.7rem;font-weight:700;letter-spacing:.06em;margin-top:4px;padding:8px 0 4px;text-transform:uppercase}.budget-analyze-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:9px 10px;transition:background .1s}.budget-analyze-item:hover{background:var(--border-light)}.budget-analyze-item input[type=checkbox]{accent-color:#9b59b6;cursor:pointer;flex-shrink:0;height:16px;width:16px}.budget-analyze-item--tracked{cursor:default;opacity:.5}.budget-analyze-item--tracked:hover{background:#0000}.budget-analyze-item-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.budget-analyze-item-name{color:var(--text);font-size:.875rem;font-weight:600}.budget-analyze-item-reason{color:var(--text-muted);font-size:.73rem}.budget-analyze-item-right{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:3px}.budget-analyze-item-amount{color:var(--text);font-size:.875rem;font-weight:700;white-space:nowrap}.budget-analyze-tracked-badge{background:#2ecc7122;border-radius:4px;color:#27ae60;font-size:.65rem;font-weight:600;padding:1px 5px;white-space:nowrap}.budget-analyze-actions{border-top:1px solid var(--border-light);display:flex;gap:8px;margin-top:4px;padding-top:8px}.budget-bills-subs-group{border:1px solid var(--border-light);border-radius:10px;margin-top:4px;overflow:hidden}.budget-bills-subs-toggle{align-items:center;background:var(--surface);border:none;color:var(--text);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;justify-content:space-between;padding:12px 14px;text-align:left;width:100%}.budget-bills-subs-toggle:hover{background:var(--border-light)}.budget-bills-subs-toggle-right{align-items:center;display:flex;gap:10px}.budget-bills-subs-total{color:#9b59b6;font-size:.875rem;font-weight:700}.budget-bills-subs-chevron{color:var(--text-muted);font-size:.7rem}.budget-bills-subs-list{border-top:1px solid var(--border-light);padding:4px 0}.budget-bills-sub-row{align-items:center;display:flex;font-size:.83rem;gap:8px;padding:8px 14px}.budget-bills-sub-name{color:var(--text);flex:1 1;font-weight:500}.budget-bills-sub-cycle{color:var(--text-muted);font-size:.75rem}.budget-bills-sub-amt{color:var(--text);font-weight:600;white-space:nowrap}.budget-receipt-form-wrap{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;margin-bottom:20px;padding:18px}.budget-receipt-photo-area{margin-bottom:14px}.budget-receipt-upload-label{align-items:center;border:2px dashed var(--border-light);border-radius:10px;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;font-size:.9rem;gap:6px;justify-content:center;padding:32px 20px;text-align:center;transition:border-color .15s,background .15s}.budget-receipt-upload-label:hover{background:#f8f9fa;background:var(--surface-hover,#f8f9fa);border-color:#2563eb;border-color:var(--accent,#2563eb);color:var(--text)}.budget-receipt-upload-hint{color:var(--text-muted);font-size:.75rem}.budget-receipt-preview{display:inline-block;max-width:100%;position:relative}.budget-receipt-preview img{border:1px solid var(--border-light);border-radius:8px;display:block;max-height:320px;max-width:100%;object-fit:contain}.budget-receipt-remove-img{background:none;border:none;color:#e74c3c;cursor:pointer;display:block;font-size:.82rem;margin-top:8px;padding:0}.budget-receipt-remove-img:hover{text-decoration:underline}.budget-receipt-items-section{margin-bottom:14px}.budget-receipt-items-header{align-items:center;color:var(--text-muted);display:flex;font-size:.85rem;font-weight:500;justify-content:space-between;margin-bottom:8px}.budget-receipt-item-row{align-items:center;display:flex;gap:8px;margin-bottom:6px}.budget-receipt-item-row input[type=text]{flex:1 1}.budget-receipt-item-del{background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.85rem;padding:2px 4px}.budget-receipt-item-del:hover{color:#e74c3c}.budget-receipt-items-subtotal{color:var(--text-muted);font-size:.82rem;padding:4px 0;text-align:right}.budget-receipt-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.budget-receipt-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .15s,border-color .15s}.budget-receipt-card:hover{border-color:#2563eb;border-color:var(--accent,#2563eb);box-shadow:0 4px 16px #0000001a}.budget-receipt-card-thumb{background:#f0f0f0;height:120px;overflow:hidden;width:100%}.budget-receipt-card-thumb img{display:block;height:100%;object-fit:cover;width:100%}.budget-receipt-card-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:2.2rem;font-weight:700;height:100px;justify-content:center;width:100%}.budget-receipt-card-body{display:flex;flex:1 1;flex-direction:column;gap:3px;padding:10px 12px}.budget-receipt-card-store{color:var(--text);font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-receipt-card-date{color:var(--text-muted);font-size:.75rem}.budget-receipt-card-footer{align-items:center;display:flex;justify-content:space-between;margin-top:4px}.budget-receipt-card-total{color:#e74c3c;font-size:.85rem;font-weight:600}.budget-receipt-card-items{background:var(--surface);border:1px solid var(--border-light);border-radius:8px;color:var(--text-muted);font-size:.72rem;padding:2px 6px}.budget-receipt-modal-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.budget-receipt-modal{background:#fff;background:var(--bg,#fff);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:85vh;max-width:480px;overflow-y:auto;width:100%}.budget-receipt-modal-header{align-items:center;background:#fff;background:var(--bg,#fff);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 20px 12px;position:sticky;top:0;z-index:1}.budget-receipt-modal-title{color:var(--text);font-size:1rem;font-weight:700}.budget-receipt-modal-img{padding:16px 20px 0}.budget-receipt-modal-img img{border:1px solid var(--border-light);border-radius:8px;max-height:340px;object-fit:contain;width:100%}.budget-receipt-modal-meta{border-bottom:1px solid var(--border-light);color:var(--text-muted);display:flex;font-size:.875rem;gap:20px;padding:14px 20px}.budget-receipt-modal-section-title{color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.05em;padding:12px 20px 6px;text-transform:uppercase}.budget-receipt-modal-items{padding:0 20px 12px}.budget-receipt-modal-item-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;font-size:.875rem;gap:8px;padding:6px 0}.budget-receipt-modal-item-row:last-of-type{border-bottom:none}.budget-receipt-modal-item-name{color:var(--text);flex:1 1}.budget-receipt-modal-item-qty{color:var(--text-muted);font-size:.8rem}.budget-receipt-modal-item-price{color:var(--text);font-weight:600;white-space:nowrap}.budget-receipt-modal-items-total{border-top:1px solid var(--border-light);color:var(--text-muted);display:flex;font-size:.82rem;font-weight:600;justify-content:space-between;margin-top:4px;padding-top:8px}.budget-receipt-modal-notes{color:var(--text-muted);font-size:.875rem;line-height:1.5;padding:0 20px 20px}.budget-data-card{background:var(--surface);border:1px solid var(--border-light);border-radius:14px;display:flex;gap:16px;margin-bottom:16px;padding:20px}.budget-data-card-icon{flex-shrink:0;font-size:1.8rem;margin-top:2px}.budget-data-card-body{flex:1 1}.budget-data-card-title{color:var(--text);font-size:.975rem;font-weight:700;margin-bottom:6px}.budget-data-card-desc{color:var(--text-muted);font-size:.84rem;line-height:1.55}.budget-data-card-desc code{background:var(--border-light);border-radius:4px;font-family:monospace;font-size:.82rem;padding:1px 5px}.budget-data-import-warn{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:.8rem;margin-top:10px;padding:7px 12px}.budget-data-result{align-items:flex-start;background:#d4edda;border:1px solid #c3e6cb;border-radius:12px;display:flex;gap:12px;margin-top:4px;padding:16px}.budget-data-result--error{background:#f8d7da;border-color:#f5c6cb}.budget-data-result-icon{flex-shrink:0;font-size:1.3rem}.budget-data-result-summary{color:#155724;flex:1 1;font-size:.875rem}.budget-data-result--error .budget-data-result-summary{color:#721c24}.budget-data-result-grid{grid-gap:4px 20px;display:grid;gap:4px 20px;grid-template-columns:1fr 1fr;margin-top:10px}.budget-data-result-row{border-bottom:1px solid #0000000f;display:flex;font-size:.82rem;justify-content:space-between;padding:3px 0}.budget-data-result-row--skipped{color:#856404;font-style:italic}.budget-data-result-val{font-weight:700;margin-left:12px}.budget-data-result-close{background:none;border:none;color:#155724;cursor:pointer;flex-shrink:0;font-size:1rem;line-height:1;opacity:.6;padding:0}.budget-data-result-close:hover{opacity:1}@media (max-width:600px){.budget-summary{gap:8px;grid-template-columns:repeat(3,1fr)}.budget-summary-value{font-size:.95rem}.budget-receipt-grid{grid-template-columns:repeat(2,1fr)}}.budget-rec-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:300}.budget-rec-modal{background:#fff;background:var(--surface,#fff);border-radius:12px;box-shadow:0 12px 40px #0000002e;max-height:90vh;max-width:440px;overflow-y:auto;padding:22px 24px 24px;width:100%}.budget-rec-modal-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1.05rem;font-weight:700;margin:0 0 14px}.budget-rec-type-toggle{border:1px solid #ddd;border:1px solid var(--border,#ddd);border-radius:7px;display:flex;gap:0;margin-bottom:16px;overflow:hidden}.budget-rec-type-btn{background:none;border:none;color:#888;color:var(--text-muted,#888);cursor:pointer;flex:1 1;font-size:.88rem;font-weight:600;padding:8px 0;transition:background .15s,color .15s}.budget-rec-type-btn.active{background:#4f46e5;background:var(--accent,#4f46e5);color:#fff}.budget-rec-type-btn:not(.active):hover{background:#f5f5f5;background:var(--surface-alt,#f5f5f5)}.budget-monthly-hint{align-items:center;color:#4f46e5;color:var(--accent,#4f46e5);display:flex;font-size:.78rem;gap:6px;margin-top:4px}.budget-monthly-set-btn{background:none;border:1px solid #4f46e5;border:1px solid var(--accent,#4f46e5);border-radius:5px;color:#4f46e5;color:var(--accent,#4f46e5);cursor:pointer;font-size:.75rem;padding:2px 8px;white-space:nowrap}.budget-monthly-set-btn:hover{background:#4f46e5;background:var(--accent,#4f46e5);color:#fff}.budget-split-section{border-top:1px dashed var(--border-light);margin-top:10px;padding-top:10px}.budget-split-badge{background:#e8f4fd;border:1px solid #b8daf5;border-radius:20px;color:#1a6fa8;display:inline-block;font-size:.7rem;font-weight:600;margin-left:7px;padding:2px 7px;vertical-align:middle;white-space:nowrap}.bss-trigger-btn{background:var(--surface);border:1px dashed var(--border-light);border-radius:10px;color:var(--text-muted);cursor:pointer;display:block;font-size:.85rem;font-weight:500;margin:10px 0 0;padding:9px 16px;text-align:center;transition:background .15s,border-color .15s,color .15s;width:100%}.bss-trigger-btn:hover{background:#e8f4fd;border-color:#b8daf5;color:#1a6fa8}.bss-overlay{align-items:flex-start;background:#00000073;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:40px 20px 20px;position:fixed;z-index:1000}.bss-modal{background:#fff;background:var(--bg,#fff);border-radius:16px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-width:520px;overflow:hidden;width:100%}.bss-modal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:18px 20px 14px}.bss-modal-title{color:var(--text);font-size:1rem;font-weight:700}.bss-close{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:4px 6px}.bss-close:hover{background:var(--border-light);color:var(--text)}.bss-tabs{border-bottom:1px solid var(--border-light);display:flex;gap:0;overflow-x:auto;padding:0 20px;scrollbar-width:none}.bss-tabs::-webkit-scrollbar{display:none}.bss-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.875rem;font-weight:500;padding:10px 14px;transition:color .15s,border-color .15s;white-space:nowrap}.bss-tab:hover{color:var(--text)}.bss-tab--active{border-bottom-color:#2563eb;border-bottom-color:var(--accent,#2563eb);color:#2563eb;color:var(--accent,#2563eb);font-weight:600}.bss-tab-content{gap:16px;max-height:65vh;overflow-y:auto;padding:16px 20px 20px}.bss-section,.bss-tab-content{display:flex;flex-direction:column}.bss-section{gap:2px}.bss-section-title{color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.bss-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:8px;display:flex;gap:8px;padding:7px 10px}.bss-row-name{color:var(--text);flex:1 1;font-size:.875rem;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bss-row-meta{color:var(--text-muted);font-size:.75rem}.bss-row-amt,.bss-row-meta{flex-shrink:0;white-space:nowrap}.bss-row-amt{color:var(--text);font-size:.9rem;font-weight:600}.bss-row-cycle{color:var(--text-muted);font-size:.75rem;font-weight:400}.bss-empty{color:var(--text-muted);font-size:.85rem;padding:24px 0 8px;text-align:center}.bss-totals{border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:6px;padding-top:12px}.bss-total-row{color:var(--text-muted);display:flex;font-size:.85rem;justify-content:space-between}.bss-total-row--grand{color:var(--text);font-size:.95rem;font-weight:700;margin-top:4px}.budget-sharing-desc{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:0 0 16px}.budget-share-form-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;margin-bottom:20px;padding:16px}.budget-share-form-title{color:var(--text);font-size:.9rem;font-weight:600;margin-bottom:14px}.budget-share-mode-toggle{display:flex;gap:8px}.budget-share-mode-btn{background:var(--bg);border:1px solid var(--border-light);border-radius:8px;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:8px 12px;transition:all .15s}.budget-share-mode-btn.active{background:#2563eb;background:var(--accent,#2563eb);border-color:#2563eb;border-color:var(--accent,#2563eb);color:#fff}.budget-share-error{background:#fdecea;border-radius:8px;color:#c0392b;font-size:.83rem;margin-bottom:8px;padding:8px 12px}.budget-share-list{display:flex;flex-direction:column;gap:8px}.budget-share-list-title{color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.budget-share-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;gap:10px;padding:10px 14px}.budget-share-row-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.budget-share-row-email{color:var(--text);font-size:.875rem;font-weight:600}.budget-share-row-meta{color:var(--text-muted);font-size:.76rem}.budget-subtab-nav{border-bottom:1px solid var(--border-light);display:flex;gap:4px;margin-bottom:20px;padding-bottom:0}.budget-subtab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.82rem;font-weight:500;margin-bottom:-1px;padding:8px 14px;transition:var(--transition);white-space:nowrap}.budget-subtab:hover{color:var(--text)}.budget-subtab.active{border-bottom-color:var(--accent);color:var(--accent);font-weight:600}.budget-inline-link{background:none;border:none;color:var(--accent);cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:underline;text-underline-offset:2px}.budget-inline-link:hover{color:var(--accent-hover)}.catbank-wrap{display:flex;flex-direction:column;gap:24px}.catbank-hint{color:var(--text-muted);font-size:.82rem;line-height:1.5;margin-bottom:-8px}.catbank-group{display:flex;flex-direction:column;gap:10px}.catbank-group-title{color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.catbank-chips{display:flex;flex-wrap:wrap;gap:8px}.catbank-chip{align-items:center;background:var(--bg-card);border:1.5px solid var(--border);border-radius:100px;color:var(--text);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.82rem;gap:5px;padding:6px 12px;transition:var(--transition);white-space:nowrap}.catbank-chip:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.catbank-chip--owned{cursor:default;opacity:.5}.catbank-chip--adding{cursor:default;opacity:.6}.catbank-chip-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.catbank-chip-icon{font-size:.95em}.catbank-chip-name{font-size:.82rem}.catbank-chip-check{color:var(--success);font-size:.72rem;font-weight:700}.tpl-wrap{display:flex;flex-direction:column;gap:16px}.tpl-section-label{color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tpl-save-section{background:var(--bg-sidebar);border:1px dashed var(--border);border-radius:var(--radius-sm);padding:12px 16px}.tpl-save-trigger{background:none;border:none;color:var(--accent);cursor:pointer;font-family:var(--font-body);font-size:.85rem;padding:0;text-align:left}.tpl-save-trigger:hover{text-decoration:underline}.tpl-save-trigger:disabled{color:var(--text-muted);cursor:default;text-decoration:none}.tpl-save-form{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.tpl-save-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-family:var(--font-body);font-size:.875rem;min-width:160px;outline:none;padding:8px 12px}.tpl-save-input:focus{border-color:var(--accent)}.tpl-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.tpl-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;padding:16px}.tpl-card--system{border-top:3px solid var(--accent)}.tpl-card--user{border-top:3px solid var(--success)}.tpl-card-header{align-items:baseline;display:flex;gap:8px;justify-content:space-between}.tpl-card-name{color:var(--text);font-size:.9rem;font-weight:700}.tpl-card-count{color:var(--text-muted);flex-shrink:0;font-size:.72rem}.tpl-card-desc{color:var(--text-muted);font-size:.78rem;line-height:1.5;margin:0}.tpl-card-preview{display:flex;flex-wrap:wrap;gap:5px}.tpl-card-preview-chip{align-items:center;background:var(--bg);border:1px solid;border-radius:100px;color:var(--text);display:inline-flex;font-size:.72rem;gap:3px;padding:3px 8px}.tpl-card-preview-more{align-self:center;color:var(--text-muted);font-size:.72rem}.tpl-card-apply-btn{align-self:flex-start;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.82rem;font-weight:600;margin-top:auto;padding:8px 14px;transition:background .15s}.tpl-card-apply-btn:hover:not(:disabled){background:var(--accent-hover)}.tpl-card-apply-btn:disabled{cursor:default;opacity:.6}.tpl-card-actions{align-items:center;display:flex;gap:8px;margin-top:auto}.tpl-card-delete-btn{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;transition:var(--transition)}.tpl-card-delete-btn:hover{background:#fef2f2;color:#e74c3c}.debt-overview{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:0;margin-bottom:24px;overflow:hidden}.debt-overview-stat{border-right:1px solid var(--border-light);display:flex;flex:1 1;flex-direction:column;gap:3px;padding:14px 18px}.debt-overview-stat:last-child{border-right:none}.debt-overview-label{color:var(--text-muted);font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.debt-overview-value{color:var(--text);font-family:var(--font-display);font-size:1.2rem;font-weight:700}.debt-section{margin-bottom:28px}.debt-section-header{align-items:center;border-bottom:2px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:10px;padding:0 0 8px}.debt-section-title{color:var(--text-muted);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.debt-section-empty{color:var(--text-light);font-size:.82rem;font-style:italic;padding:12px 0}.debt-row{align-items:flex-start;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:10px;margin-bottom:8px;padding:12px 14px;transition:var(--transition)}.debt-row:hover{border-color:var(--border)}.debt-row--inactive{opacity:.6}.debt-row-main{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0}.debt-row-top{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.debt-row-name{color:var(--text);font-size:.875rem;font-weight:600}.debt-status-badge{border-radius:100px;color:#fff;flex-shrink:0;font-size:.67rem;font-weight:700;letter-spacing:.04em;padding:2px 7px;text-transform:uppercase}.debt-row-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.debt-type-badge{background:var(--bg-sidebar);border:1px solid var(--border-light);border-radius:100px;color:var(--text-muted);font-size:.7rem;font-weight:600;padding:2px 7px}.debt-row-creditor{color:var(--text-muted);font-size:.78rem}.debt-row-creditor:before{color:var(--text-light);content:"·";margin-right:6px}.debt-row-amount{color:var(--text);font-size:.875rem;font-weight:700}.debt-row-amount:before{color:var(--text-light);content:"·";margin-right:6px}.debt-row-rate{background:#fff3e0;border-radius:100px;color:var(--text-muted);font-size:.75rem;padding:1px 6px}.debt-row-payment{color:var(--accent);font-size:.78rem;font-weight:600}.debt-row-due{color:var(--text-muted);font-size:.75rem}.debt-row-dispute{color:#e67e22;font-size:.75rem;font-style:italic}.debt-row-notes{color:var(--text-muted);font-size:.76rem;line-height:1.4;margin-top:2px}.debt-form .budget-type-toggle{flex-wrap:wrap}@media (max-width:540px){.debt-overview{flex-direction:column}.debt-overview-stat{border-bottom:1px solid var(--border-light);border-right:none}.debt-overview-stat:last-child{border-bottom:none}}.csv-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:200}.csv-modal{background:var(--bg);border-radius:14px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.csv-modal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 20px 14px}.csv-modal-header h2{font-family:var(--font-display);font-size:1.1rem;margin:0}.csv-close{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px 8px}.csv-close:hover{background:var(--border-light)}.csv-error{background:#e74c3c18;border:1px solid #e74c3c44;border-radius:8px;color:#e74c3c;font-size:.875rem;margin:12px 20px 0;padding:10px 16px}.csv-upload-area{align-items:center;display:flex;flex-direction:column;gap:12px;padding:48px 24px}.csv-upload-icon{font-size:2.5rem}.csv-upload-hint{color:var(--text-muted);font-size:.9rem;margin:0;text-align:center}.csv-upload-hint--small{font-size:.78rem}.csv-upload-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:8px;padding:10px 28px}.csv-upload-btn:hover:not(:disabled){opacity:.88}.csv-upload-btn:disabled{cursor:not-allowed;opacity:.5}.csv-profile-bar{align-items:center;background:#2ecc7108;border-bottom:1px solid #2ecc7130;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;padding:8px 20px}.csv-profile-bank{align-items:center;color:var(--text);display:flex;font-size:.85rem;font-weight:600;gap:6px}.csv-profile-badge{background:#2ecc7120;border-radius:99px;color:#27ae60;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:2px 8px}.csv-profile-notes{flex:1 1;font-style:italic}.csv-profile-notes,.csv-reanalyze-btn{color:var(--text-muted);font-size:.78rem}.csv-reanalyze-btn{background:none;border:1px solid var(--border-light);border-radius:6px;cursor:pointer;margin-left:auto;padding:3px 10px}.csv-reanalyze-btn:hover:not(:disabled){background:var(--border-light);color:var(--text)}.csv-reanalyze-btn:disabled{cursor:not-allowed;opacity:.5}.csv-preview-bar{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 20px}.csv-preview-count{color:var(--text-muted);font-size:.85rem}.csv-toggle-all{background:none;border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;font-size:.8rem;padding:4px 12px}.csv-toggle-all:hover{background:var(--border-light)}.csv-table-wrap{flex:1 1;overflow-y:auto}.csv-table{border-collapse:collapse;font-size:.825rem;width:100%}.csv-table thead th{background:var(--bg);color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:8px 10px;position:sticky;text-align:left;text-transform:uppercase;top:0}.csv-table tbody td,.csv-table thead th{border-bottom:1px solid var(--border-light)}.csv-table tbody td{padding:7px 10px;vertical-align:middle}.csv-row--unchecked td{opacity:.4}.csv-td-date{color:var(--text-muted);white-space:nowrap}.csv-td-desc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.csv-td-amount{font-weight:500;white-space:nowrap}.csv-cat-select,.csv-type-select{background:var(--bg);border:1px solid var(--border-light);border-radius:5px;color:var(--text);cursor:pointer;font-size:.8rem;padding:4px 6px}.csv-type--income{border-color:#2ecc7160;color:#27ae60}.csv-type--expense{color:var(--text)}.csv-type--transfer{color:var(--text-muted)}.csv-footer{border-top:1px solid var(--border-light);display:flex;flex-shrink:0;gap:10px;padding:14px 20px}.csv-confirm-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:9px 22px}.csv-confirm-btn:hover:not(:disabled){opacity:.88}.csv-confirm-btn:disabled{cursor:not-allowed;opacity:.5}.csv-cancel-btn{background:none;border:1px solid var(--border-light);border-radius:8px;color:var(--text);cursor:pointer;font-size:.875rem;padding:9px 18px}.csv-done{align-items:center;display:flex;flex-direction:column;gap:14px;padding:40px 24px}.csv-done-icon{font-size:2.5rem}.csv-done p{color:var(--text);font-size:.95rem;margin:0;text-align:center}.csv-done-skipped{color:var(--text-muted)!important;font-size:.82rem!important}.csv-done-months{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;max-width:380px;padding:14px 18px;width:100%}.csv-done-months-label{color:var(--text-muted)!important;font-size:.78rem!important;font-weight:600;letter-spacing:.05em;margin-bottom:8px!important;text-transform:uppercase}.csv-done-months-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0 0 10px;padding:0}.csv-done-months-list li{color:var(--text);display:flex;font-size:.85rem;justify-content:space-between}.csv-done-nav-hint{color:var(--text-muted)!important;font-size:.78rem!important;font-style:italic}.bcal-wrap{padding:0 0 24px}.bcal-header{border-bottom:1px solid var(--border-light);flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:8px;padding:10px 0 14px;position:relative}.bcal-header,.bcal-month-nav{align-items:center;display:flex}.bcal-month-nav{gap:8px}.bcal-month-label{color:var(--text);font-size:.97rem;font-weight:700;min-width:148px;text-align:center}.bcal-loading-dot{color:var(--text-muted);font-size:.75rem}.bcal-nav-btn{background:none;border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;font-size:1.1rem;line-height:1.5;padding:2px 10px;transition:background .1s}.bcal-nav-btn:hover{background:var(--border-light)}.bcal-today-btn{background:none;border:1px solid var(--border-light);border-radius:6px;color:var(--accent);cursor:pointer;font-size:.77rem;font-weight:600;padding:2px 9px;transition:background .1s}.bcal-today-btn:hover{background:var(--border-light)}.bcal-header-right{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.bcal-persp{position:relative}.bcal-persp-btn{align-items:center;background:none;border:1px solid var(--border-light);border-radius:20px;color:var(--text);cursor:pointer;display:flex;font-size:.82rem;font-weight:600;gap:5px;padding:4px 10px;transition:border-color .1s,background .1s;white-space:nowrap}.bcal-persp-btn:hover{background:var(--border-light)}.bcal-persp-btn--person{background:color-mix(in srgb,var(--accent) 8%,#0000);border-color:var(--accent);color:var(--accent)}.bcal-persp-arrow{font-size:.65rem;opacity:.7}.bcal-persp-dropdown{background:var(--bg);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 4px 16px #0000001f;min-width:150px;overflow:hidden;position:absolute;right:0;top:calc(100% + 5px);z-index:50}.bcal-persp-opt{background:none;border:none;border-bottom:1px solid var(--border-light);color:var(--text);cursor:pointer;display:block;font-size:.83rem;padding:9px 14px;text-align:left;transition:background .1s;width:100%}.bcal-persp-opt:last-child{border-bottom:none}.bcal-persp-opt:hover{background:var(--border-light)}.bcal-persp-opt.active{background:color-mix(in srgb,var(--accent) 6%,#0000);color:var(--accent);font-weight:700}.bcal-persp-notice{color:var(--accent);font-size:.75rem;font-style:italic;white-space:nowrap}.bcal-startbal{align-items:center;display:flex;font-size:.8rem;gap:7px}.bcal-startbal-label{color:var(--text-muted);white-space:nowrap}.bcal-startbal-val{align-items:center;background:none;border:1px dashed var(--border-light);border-radius:5px;color:var(--text);cursor:pointer;display:flex;font-size:.82rem;font-weight:600;gap:4px;padding:3px 8px;transition:border-color .1s,color .1s}.bcal-startbal-val:hover{border-color:var(--accent);color:var(--accent)}.bcal-edit-icon{font-size:.68rem}.bcal-startbal-edit{align-items:center;display:flex;gap:4px}.bcal-startbal-input{background:var(--bg);border:1px solid var(--accent);border-radius:5px;color:var(--text);font-size:.82rem;outline:none;padding:3px 6px;width:92px}.bcal-startbal-ok,.bcal-startbal-x{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.88rem;padding:1px 5px}.bcal-startbal-ok{color:#27ae60}.bcal-startbal-x{color:#e74c3c}.bcal-legend{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.72rem;gap:12px;padding:6px 0 10px}.bcal-legend-item{align-items:center;display:flex;gap:4px}.bcal-dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.bcal-dot--income{background:#27ae60}.bcal-dot--expense{background:#e74c3c}.bcal-dot--proj-income{background:#27ae60;background-clip:padding-box;border:1.5px dashed #27ae60;opacity:.55}.bcal-dot--proj-expense{background:#e74c3c;background-clip:padding-box;border:1.5px dashed #e74c3c;opacity:.55}.bcal-grid{border:1px solid var(--border-light);border-radius:8px;display:grid;grid-template-columns:repeat(7,1fr);overflow:hidden}.bcal-col-header{background:#f7f8fa;background:var(--sidebar-bg,#f7f8fa);border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);color:var(--text-muted);font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:6px 2px;text-align:center;text-transform:uppercase}.bcal-col-header:last-child{border-right:none}.bcal-cell{align-items:flex-start;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);cursor:pointer;display:flex;flex-direction:column;gap:2px;min-height:62px;padding:5px 5px 4px;position:relative;transition:background .1s}.bcal-cell:nth-child(7n+8){border-right:none}.bcal-cell--blank{background:#f7f8fa;background:var(--sidebar-bg,#f7f8fa);cursor:default;opacity:.5;pointer-events:none}.bcal-cell--today{background:color-mix(in srgb,var(--accent) 8%,#0000)}.bcal-cell--today .bcal-cell-num{align-items:center;background:var(--accent);border-radius:50%;color:#fff!important;display:flex;font-weight:700;height:20px;justify-content:center;width:20px}.bcal-cell--future .bcal-cell-bal,.bcal-cell--future .bcal-cell-dots,.bcal-cell--future .bcal-cell-net{opacity:.7}.bcal-cell--selected{background:color-mix(in srgb,var(--accent) 13%,#0000)!important;outline:2px solid var(--accent);outline-offset:-2px}.bcal-cell:not(.bcal-cell--blank):hover:not(.bcal-cell--selected){background:var(--border-light)}.bcal-cell--today:hover:not(.bcal-cell--selected){background:color-mix(in srgb,var(--accent) 14%,#0000)}.bcal-cell-num{align-items:center;color:var(--text);display:flex;font-size:.75rem;font-weight:600;justify-content:center;line-height:1;min-height:18px;min-width:18px}.bcal-cell-dots{display:flex;flex-wrap:wrap;gap:2px}.bcal-cell-net{font-size:.62rem;font-weight:700;line-height:1;white-space:nowrap}.bcal-cell-net.pos{color:#27ae60}.bcal-cell-net.neg{color:#e74c3c}.bcal-cell-bal{font-size:.58rem;line-height:1;margin-top:1px;white-space:nowrap}.bcal-cell-bal.pos{color:#27ae60;opacity:.75}.bcal-cell-bal.neg{color:#e74c3c;opacity:.75}.bcal-detail{animation:bcal-fadein .15s ease;border:1px solid var(--border-light);border-radius:8px;margin-top:10px;overflow:hidden}@keyframes bcal-fadein{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.bcal-detail-header{align-items:center;background:#f7f8fa;background:var(--sidebar-bg,#f7f8fa);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:9px 14px}.bcal-detail-date{color:var(--text);font-size:.86rem;font-weight:700}.bcal-detail-close{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.88rem;padding:2px 7px}.bcal-detail-close:hover{background:var(--border-light)}.bcal-detail-stats{border-bottom:1px solid var(--border-light);display:grid;grid-template-columns:repeat(4,1fr)}.bcal-dstat{align-items:center;border-right:1px solid var(--border-light);display:flex;flex-direction:column;gap:3px;padding:10px 6px;text-align:center}.bcal-dstat:last-child{border-right:none}.bcal-dstat-lbl{color:var(--text-muted);font-size:.65rem;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.bcal-dstat-val{color:var(--text);font-size:.87rem;font-weight:700;white-space:nowrap}.bcal-dstat-val--income{color:#27ae60}.bcal-dstat-val--expense{color:#e74c3c}.bcal-dstat-val--pos{color:#27ae60}.bcal-dstat-val--neg{color:#e74c3c}.bcal-detail-empty{color:var(--text-muted);font-size:.82rem;padding:18px 14px;text-align:center}.bcal-detail-sec{border-bottom:1px solid var(--border-light)}.bcal-detail-sec:last-child{border-bottom:none}.bcal-detail-sec-title{border-bottom:1px solid var(--border-light);font-size:.68rem;font-weight:700;letter-spacing:.05em;padding:6px 14px;text-transform:uppercase}.bcal-detail-sec-title--income{color:#27ae60}.bcal-detail-sec-title--expense{color:#e74c3c}.bcal-ev{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:10px;padding:8px 14px}.bcal-ev:last-child{border-bottom:none}.bcal-ev-icon{flex-shrink:0;font-size:1rem}.bcal-ev-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.bcal-ev-name{color:var(--text);font-size:.83rem;font-weight:500}.bcal-ev-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.72rem;gap:5px}.bcal-badge{border-radius:4px;display:inline-block;font-size:.62rem;font-weight:700;letter-spacing:.04em;padding:1px 5px;text-transform:uppercase}.bcal-badge--proj{background:#fff3cd;color:#856404}.bcal-ev-amt-wrap{align-items:center;display:flex;flex-shrink:0;gap:4px}.bcal-ev-amt{font-size:.87rem;font-weight:700;white-space:nowrap}.bcal-ev-amt--income{color:#27ae60}.bcal-ev-amt--expense{color:#e74c3c}.bcal-ev-edit-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;line-height:1;opacity:0;padding:0 2px;transition:opacity .15s}.bcal-ev--daily:hover .bcal-ev-edit-btn,.bcal-ev-edit-btn:focus{opacity:1}.bcal-ev-edit-wrap{align-items:center;display:flex;flex-shrink:0;gap:4px}.bcal-ev-edit-input{background:var(--bg);border:1px solid var(--accent);border-radius:5px;color:var(--text);font-size:.82rem;outline:none;padding:3px 6px;width:72px}.bcal-ev-edit-ok,.bcal-ev-edit-reset,.bcal-ev-edit-x{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.82rem;line-height:1;padding:2px 4px}.bcal-ev-edit-ok{color:#27ae60}.bcal-ev-edit-x{color:#e74c3c}.bcal-ev-edit-reset{color:var(--text-muted);font-size:.9rem}.bcal-ev-edit-ok:hover{background:#27ae6018}.bcal-ev-edit-x:hover{background:#e74c3c18}.bcal-ev-edit-reset:hover{background:var(--hover)}.bcal-badge--daily{background:#fff3e0;color:#e65100}.bcal-badge--actual{background:#e8f5e9;color:#2e7d32}.bcal-weeks{border:1px solid var(--border-light);border-radius:8px;margin-top:16px;overflow:hidden}.bcal-weeks-title{background:#f7f8fa;background:var(--sidebar-bg,#f7f8fa);border-bottom:1px solid var(--border-light);color:var(--text);font-size:.73rem;font-weight:700;letter-spacing:.04em;padding:8px 14px;text-transform:uppercase}.bcal-weeks-head,.bcal-weeks-row{border-bottom:1px solid var(--border-light);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr}.bcal-weeks-head{background:#f7f8fa;background:var(--sidebar-bg,#f7f8fa);color:var(--text-muted);font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.bcal-weeks-head>span,.bcal-weeks-row>span{border-right:1px solid var(--border-light);overflow:hidden;padding:7px 10px;text-overflow:ellipsis;white-space:nowrap}.bcal-weeks-head>span:last-child,.bcal-weeks-row>span:last-child{border-right:none}.bcal-weeks-row{color:var(--text);font-size:.8rem}.bcal-weeks-row--current{background:color-mix(in srgb,var(--accent) 5%,#0000)}.bcal-weeks-row:last-child{border-bottom:none}.bcal-weeks-lbl{font-weight:500}.bcal-weeks-income{color:#27ae60;font-weight:600}.bcal-weeks-expense{color:#e74c3c;font-weight:600}.bcal-weeks-net.pos{color:#27ae60;font-weight:700}.bcal-weeks-net.neg{color:#e74c3c;font-weight:700}.bcal-weeks-bal-col{font-weight:700}.bcal-weeks-bal-col.pos{color:#27ae60}.bcal-weeks-bal-col.neg{color:#e74c3c}.bcal-weeks-note{border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.7rem;font-style:italic;padding:7px 14px}@media (max-width:560px){.bcal-header{align-items:flex-start;flex-direction:column;gap:8px}.bcal-month-label{font-size:.9rem;min-width:120px}.bcal-cell{min-height:48px;padding:4px 3px 3px}.bcal-cell-num{font-size:.7rem}.bcal-cell-net{font-size:.58rem}.bcal-cell-bal{display:none}.bcal-detail-stats{grid-template-columns:1fr 1fr}.bcal-dstat:nth-child(2){border-right:none}.bcal-dstat:nth-child(3),.bcal-dstat:nth-child(4){border-top:1px solid var(--border-light)}.bcal-weeks-head,.bcal-weeks-row{grid-template-columns:1.2fr 1fr 1fr 1fr}.bcal-weeks-bal-col{display:none}}@media (max-width:380px){.bcal-col-header{font-size:.6rem;padding:5px 1px}.bcal-cell{gap:1px;min-height:42px;padding:3px 2px}.bcal-dot{height:5px;width:5px}.bcal-cell-net{font-size:.54rem}}.wplan-wrap{padding:0 0 80px}.wplan-green{color:#27ae60}.wplan-red{color:#e74c3c}.wplan-list-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px}.wplan-page-title{color:var(--text);font-size:1.3rem;font-weight:700;margin:0 0 4px}.wplan-page-sub{color:var(--text-muted);font-size:.85rem;margin:0}.wplan-new-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.9rem;font-weight:600;padding:8px 16px;white-space:nowrap}.wplan-new-btn:hover{filter:brightness(.9)}.wplan-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;padding:20px}.wplan-form-title{color:var(--text);font-size:1rem;font-weight:700;margin:0 0 16px}.wplan-label{color:var(--text-muted);display:block;font-size:.82rem;font-weight:600;letter-spacing:.03em;margin:12px 0 4px;text-transform:uppercase}.wplan-label-hint{color:var(--text-muted);font-size:.8rem;font-weight:400;letter-spacing:0;text-transform:none}.wplan-input{background:var(--input-bg);border:1px solid var(--border);border-radius:8px;box-sizing:border-box;color:var(--text);display:block;font-size:.9rem;margin-bottom:4px;padding:8px 10px;width:100%}.wplan-input:focus{border-color:var(--accent);outline:none}.wplan-textarea{min-height:60px;resize:vertical}.wplan-days-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.wplan-day-chip{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:5px 12px;transition:all .15s}.wplan-day-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.wplan-day-chip:hover:not(.active){border-color:var(--accent);color:var(--accent)}.wplan-range-hint{color:var(--text-muted);font-size:.82rem;margin-bottom:10px}.wplan-bal-mode-row{display:flex;gap:6px;margin-bottom:8px}.wplan-mode-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:5px 14px;transition:all .15s}.wplan-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.wplan-mode-btn:hover:not(.active){border-color:var(--accent);color:var(--accent)}.wplan-breakdown{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:4px;padding:12px}.wplan-breakdown-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.wplan-breakdown-row:last-of-type{margin-bottom:0}.wplan-breakdown-row label{color:var(--text-muted);flex-shrink:0;font-size:.85rem;min-width:110px}.wplan-breakdown-row input{background:var(--input-bg);border:1px solid var(--border);border-radius:6px;color:var(--text);flex:1 1;font-size:.9rem;padding:6px 8px}.wplan-breakdown-row input:focus{border-color:var(--accent);outline:none}.wplan-breakdown-total{border-top:1px solid var(--border);color:var(--text);font-size:.9rem;font-weight:700;margin-top:10px;padding-top:8px;text-align:right}.wplan-check-label{align-items:flex-start;color:var(--text);cursor:pointer;display:flex;font-size:.88rem;gap:8px;line-height:1.4;margin:14px 0 4px}.wplan-check-label input{flex-shrink:0;margin-top:2px}.wplan-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.wplan-cancel-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:.88rem;padding:7px 16px}.wplan-cancel-btn:hover{background:var(--hover)}.wplan-submit-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:7px 18px}.wplan-submit-btn:hover:not(:disabled){filter:brightness(.9)}.wplan-submit-btn:disabled{cursor:default;opacity:.55}.wplan-loading{padding:32px}.wplan-empty,.wplan-loading{color:var(--text-muted);text-align:center}.wplan-empty{padding:40px 16px}.wplan-empty-icon{font-size:2.5rem;margin-bottom:12px}.wplan-empty p{font-size:.95rem;margin:0 0 16px}.wplan-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.wplan-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;cursor:pointer;padding:16px;text-align:left;transition:border-color .15s,box-shadow .15s}.wplan-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #00000014}.wplan-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.wplan-card-name{color:var(--text);font-size:1rem;font-weight:700}.wplan-card-del{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.95rem;opacity:.5;padding:2px 4px}.wplan-card-del:hover{background:var(--hover);opacity:1}.wplan-card-dates{color:var(--text-muted);font-size:.82rem;margin-bottom:6px}.wplan-card-days{font-weight:600}.wplan-card-balance{color:var(--text);font-size:.88rem;margin-bottom:4px}.wplan-card-breakdown{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.78rem;gap:8px;margin-bottom:6px}.wplan-card-breakdown span{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1px 8px}.wplan-card-import-badge{background:#e8f5e9;border-radius:10px;color:#2e7d32;display:inline-block;font-size:.75rem;margin-bottom:6px;padding:1px 8px}[data-theme=dark] .wplan-card-import-badge{background:#2e7d3233;color:#81c784}.wplan-card-cta{color:var(--accent);font-size:.82rem;font-weight:600;margin-top:8px}.wplan-detail-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.wplan-back-btn{background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.85rem;padding:5px 12px;white-space:nowrap}.wplan-back-btn:hover{background:var(--hover);color:var(--text)}.wplan-detail-meta{flex:1 1;min-width:0}.wplan-detail-name{color:var(--text);font-size:1.1rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wplan-detail-range{color:var(--text-muted);font-size:.82rem}.wplan-detail-days{font-weight:600}.wplan-detail-actions{display:flex;flex-shrink:0;gap:8px}.wplan-edit-btn{background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:.83rem;padding:5px 12px}.wplan-edit-btn:hover{background:var(--hover);color:var(--text)}.wplan-del-btn{background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:5px 10px}.wplan-del-btn:hover{background:#fdf2f2;border-color:#e74c3c;color:#e74c3c}.wplan-summary-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;display:flex;gap:0;margin-bottom:16px;overflow:hidden}.wplan-stat{align-items:center;border-right:1px solid var(--border);display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0;padding:12px 8px}.wplan-stat:last-child{border-right:none}.wplan-stat-label{color:var(--text-muted);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.wplan-stat-val{color:var(--text);font-size:.95rem;font-weight:700;white-space:nowrap}.wplan-strip-wrap{-webkit-overflow-scrolling:touch;border-radius:12px;margin-bottom:16px;overflow-x:auto}.wplan-strip{border:1px solid var(--border);border-radius:12px;gap:0;min-width:max-content;overflow:hidden}.wplan-day-col,.wplan-strip{background:var(--bg-card);display:flex}.wplan-day-col{align-items:center;border:none;border-right:1px solid var(--border);cursor:pointer;flex:1 1;flex-direction:column;gap:2px;min-width:90px;padding:12px 8px;transition:background .15s}.wplan-day-col:last-child{border-right:none}.wplan-day-col:hover{background:var(--hover)}.wplan-day-col.active{background:#4a90e21a;background:var(--accent-muted,rgba(var(--accent-rgb,74,144,226),.1));border-bottom:3px solid var(--accent)}.wplan-day-col.today .wplan-day-name{color:var(--accent);font-weight:700}.wplan-day-col--neg{background:#e74c3c0d}.wplan-day-name{color:var(--text-muted);font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.wplan-day-date{color:var(--text);font-size:1.2rem;font-weight:700;line-height:1}.wplan-day-income{color:#27ae60;font-size:.75rem;font-weight:600}.wplan-day-expense{color:#e74c3c;font-size:.75rem;font-weight:600}.wplan-day-quiet{color:var(--border);font-size:.75rem;line-height:1}.wplan-day-bal{color:var(--text-muted);font-size:.8rem;font-weight:700;margin-top:4px;white-space:nowrap}.wplan-day-bal--neg{color:#e74c3c}.wplan-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.wplan-modal{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-modal);max-height:90vh;max-width:420px;overflow-y:auto;padding:24px;width:100%}.wplan-day-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-top:4px;padding:16px}.wplan-day-panel-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:14px}.wplan-day-panel-date{color:var(--text);font-size:1rem;font-weight:700}.wplan-add-event-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:6px 14px;white-space:nowrap}.wplan-add-event-btn:hover{filter:brightness(.9)}.wplan-day-stats{background:var(--bg);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:12px}.wplan-day-stat{align-items:center;color:var(--text-muted);display:flex;font-size:.88rem;justify-content:space-between}.wplan-day-stat--income{color:#27ae60}.wplan-day-stat--expense{color:#e74c3c}.wplan-day-stat--net{font-weight:600}.wplan-day-stat--end{border-top:1px solid var(--border);color:var(--text);font-size:.92rem;font-weight:700;margin-top:2px;padding-top:6px}.wplan-day-empty{color:var(--text-muted);font-size:.85rem;font-style:italic;padding:12px;text-align:center}.wplan-events-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.wplan-event{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;display:flex;gap:8px;padding:8px 10px;transition:border-color .15s}.wplan-event--proj{border-style:dashed;opacity:.75}.wplan-event--entry{border-color:var(--accent);border-style:solid}.wplan-event--entry:hover{background:var(--hover)}.wplan-event-icon{flex-shrink:0;font-size:1rem}.wplan-event-body{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.wplan-event-name{color:var(--text);font-size:.88rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wplan-event-cat{color:var(--text-muted);font-size:.75rem}.wplan-event-tag{background:var(--border);border-radius:8px;color:var(--text-muted);display:inline-block;font-size:.7rem;padding:1px 6px;width:fit-content}.wplan-event-tag--tx{background:#27ae6026;color:#27ae60}.wplan-event-tag--entry{background:#4a90e226;background:rgba(var(--accent-rgb,74,144,226),.15);color:var(--accent)}.wplan-event-amt{flex-shrink:0;font-size:.9rem;font-weight:700;white-space:nowrap}.wplan-event-actions{display:flex;flex-shrink:0;gap:4px}.wplan-event-actions button{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:3px 5px}.wplan-event-actions button:hover{background:var(--hover);color:var(--text)}.wplan-entry-form{background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-top:8px;padding:14px}.wplan-entry-form-title{align-items:center;color:var(--text);display:flex;font-size:.9rem;font-weight:700;justify-content:space-between;margin-bottom:12px}.wplan-entry-close{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:2px 6px}.wplan-entry-close:hover{background:var(--hover);color:var(--text)}.wplan-entry-type-row{display:flex;gap:6px;margin-bottom:8px}.wplan-type-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:6px;transition:all .15s}.wplan-type-btn--expense.active{background:#fdf2f2;border-color:#e74c3c;color:#e74c3c;font-weight:700}.wplan-type-btn--income.active{background:#f0fdf4;border-color:#27ae60;color:#27ae60;font-weight:700}[data-theme=dark] .wplan-type-btn--expense.active{background:#e74c3c26}[data-theme=dark] .wplan-type-btn--income.active{background:#27ae6026}.wplan-type-btn:hover:not(.active){border-color:var(--accent);color:var(--accent)}.wplan-de-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;padding:14px 16px}.wplan-de-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px}.wplan-de-header-left{align-items:baseline;display:flex;flex-wrap:wrap;gap:8px}.wplan-de-title{color:var(--text);font-size:.9rem;font-weight:700}.wplan-de-subtitle{color:var(--text-muted);font-size:.78rem}.wplan-de-add-btn{background:none;border:1px dashed var(--accent);border-radius:8px;color:var(--accent);cursor:pointer;flex-shrink:0;font-size:.83rem;font-weight:600;padding:4px 12px;white-space:nowrap}.wplan-de-add-btn:hover{background:var(--accent);color:#fff}.wplan-de-empty{color:var(--text-muted);font-size:.82rem;font-style:italic;padding:4px 0}.wplan-de-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.wplan-de-row{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;display:flex;gap:8px;padding:7px 10px}.wplan-de-icon{flex-shrink:0;font-size:.95rem}.wplan-de-body{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0}.wplan-de-label{color:var(--text);font-size:.88rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wplan-de-cat{color:var(--text-muted);font-size:.75rem}.wplan-de-amt{flex-shrink:0;font-size:.88rem;font-weight:700;white-space:nowrap}.wplan-de-actions{display:flex;flex-shrink:0;gap:4px}.wplan-de-actions button{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:3px 5px}.wplan-de-actions button:hover{background:var(--hover);color:var(--text)}.wplan-de-form{background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-top:8px;padding:12px}.wplan-de-form-row{display:flex;gap:8px;margin-bottom:4px}.wplan-de-form-label{flex:1 1;margin-bottom:0!important}.wplan-de-form-amt{flex-shrink:0;margin-bottom:0!important;width:100px}.wplan-event--daily{border-color:#3498db33}.wplan-event--overridden{border-color:#f39c1255}.wplan-event-tag--daily{background:#3498db26;color:#3498db}.wplan-event-tag--override{background:#f39c1226;color:#e67e22}.wplan-override-row{align-items:center;background:var(--bg);border:1px solid var(--accent);border-radius:0 0 8px 8px;border-top:none;display:flex;flex-wrap:wrap;gap:6px;margin-top:-4px;padding:6px 10px 6px 36px}.wplan-override-label{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.wplan-override-input{background:var(--input-bg);border:1px solid var(--accent);border-radius:6px;color:var(--text);font-size:.9rem;font-weight:600;padding:4px 7px;width:90px}.wplan-override-input:focus{outline:none}.wplan-override-save{background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:700;padding:4px 10px}.wplan-override-save:disabled{opacity:.6}.wplan-override-cancel{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.82rem;padding:4px 8px}.wplan-override-cancel:hover{background:var(--hover)}.wplan-override-default{color:var(--text-muted);font-size:.75rem;margin-left:auto;white-space:nowrap}@media (max-width:600px){.wplan-list-header{flex-direction:column}.wplan-cards{grid-template-columns:1fr}.wplan-summary-bar{flex-wrap:wrap}.wplan-stat{border-bottom:1px solid var(--border);min-width:50%}.wplan-stat:nth-child(odd){border-right:1px solid var(--border)}.wplan-stat:last-child,.wplan-stat:nth-last-child(2):nth-child(odd){border-bottom:none}.wplan-day-col{min-width:75px}.wplan-detail-header{flex-wrap:wrap}}.pm-page{gap:20px;padding:0}.pm-invite-banner,.pm-page{display:flex;flex-direction:column}.pm-invite-banner{gap:8px}.pm-invite-banner-item{align-items:center;background:#e8f4fd;border:1px solid #b8daf5;border-radius:10px;display:flex;flex-wrap:wrap;font-size:.875rem;gap:12px;justify-content:space-between;padding:12px 16px}.pm-invite-role-badge{background:#3498db;border-radius:10px;color:#fff;font-size:.72rem;font-weight:600;margin-left:8px;padding:2px 8px}.pm-invite-banner-actions{display:flex;flex-shrink:0;gap:8px}.pm-btn{align-items:center;border:none;border-radius:7px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:5px;padding:8px 14px;transition:opacity .15s,background .15s;white-space:nowrap}.pm-btn:disabled{cursor:not-allowed;opacity:.5}.pm-btn--primary{background:#2563eb;background:var(--accent,#2563eb);color:#fff}.pm-btn--primary:hover:not(:disabled){opacity:.88}.pm-btn--ghost{background:var(--surface);border:1px solid var(--border-light);color:var(--text)}.pm-btn--ghost:hover:not(:disabled){background:var(--border-light)}.pm-btn--danger{background:#e74c3c;color:#fff}.pm-btn--danger:hover:not(:disabled){opacity:.88}.pm-btn--accept{background:#27ae60;color:#fff;font-size:.8rem;padding:6px 12px}.pm-btn--decline{background:var(--surface);border:1px solid var(--border-light);color:var(--text-muted);font-size:.8rem;padding:6px 12px}.pm-btn--sm{font-size:.8rem;padding:5px 11px}.pm-icon-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;opacity:.6;padding:3px 5px;transition:opacity .15s}.pm-icon-btn:hover{background:var(--border-light);opacity:1}.pm-list-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.pm-title{color:var(--text);font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0 0 4px}.pm-subtitle{color:var(--text-muted);font-size:.84rem;margin:0}.pm-back-btn{background:none;border:none;color:#2563eb;color:var(--accent,#2563eb);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:4px;padding:0}.pm-back-btn:hover{text-decoration:underline}.pm-project-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.pm-project-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:18px;transition:box-shadow .15s,border-color .15s}.pm-project-card:hover{border-color:#2563eb;border-color:var(--accent,#2563eb);box-shadow:0 4px 16px #00000017}.pm-project-card-top{align-items:center;display:flex;gap:8px;justify-content:space-between}.pm-project-name{color:var(--text);font-size:.975rem;font-weight:600}.pm-project-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-muted);display:-webkit-box;font-size:.82rem;line-height:1.4;margin:0;overflow:hidden}.pm-project-stats{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.78rem;gap:12px}.pm-role-badge{border-radius:10px;font-size:.7rem;font-weight:600;padding:2px 8px;white-space:nowrap}.pm-role-badge--owner{background:#fef3c7;color:#92400e}.pm-role-badge--editor{background:#dbeafe;color:#1e40af}.pm-role-badge--viewer{background:#f3f4f6;color:#6b7280}.pm-role-badge--external{background:#e5e7eb;color:#374151}.pm-progress-bar{background:var(--border-light);border-radius:99px;height:5px;overflow:hidden}.pm-progress-bar--lg{height:8px}.pm-progress-bar--budget{margin-top:3px}.pm-progress-fill{background:#27ae60;border-radius:99px;height:100%;transition:width .3s ease}.pm-progress-fill--budget{background:#3498db}.pm-progress-fill--over{background:#e74c3c}.pm-budget-bar-wrap{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;padding:14px 16px}.pm-budget-bar-labels{color:var(--text-muted);display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:8px}.pm-budget-warning{color:#e67e22;font-size:.8rem;font-weight:500;margin-top:6px}.pm-detail-header{display:flex;flex-direction:column;gap:6px}.pm-detail-title-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.pm-detail-layout{grid-gap:20px;align-items:flex-start;display:grid;gap:20px;grid-template-columns:1fr 320px}.pm-section-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.pm-section-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.pm-section-title{color:var(--text);font-size:.9rem;font-weight:600}.pm-count{background:var(--border-light);border-radius:10px;font-size:.75rem;margin-left:4px;padding:1px 7px}.pm-count,.pm-muted{color:var(--text-muted)}.pm-form-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:18px}.pm-form-card-title{color:var(--text);font-size:.95rem;font-weight:600}.pm-cost-form,.pm-task-form{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;flex-direction:column;gap:10px;margin-bottom:8px;padding:14px}.pm-form-row{display:flex;flex-direction:column;gap:4px}.pm-form-row label{color:var(--text-muted);font-size:.8rem;font-weight:500}.pm-form-row input,.pm-form-row select,.pm-form-row textarea{background:#fff;background:var(--bg,#fff);border:1px solid var(--border-light);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;padding:7px 10px}.pm-form-row textarea{resize:vertical}.pm-form-row-inline{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.pm-form-actions{display:flex;flex-wrap:wrap;gap:8px}.pm-error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-size:.84rem;padding:8px 12px}.pm-invite-form{align-items:center;background:#fff;background:var(--bg,#fff);border:1px solid var(--border-light);border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;padding:10px}.pm-invite-form input,.pm-invite-form select{background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text);flex:1 1;font-size:.84rem;min-width:0;padding:6px 10px}.pm-invite-msg{color:#27ae60;font-size:.8rem;font-weight:500}.pm-invite-msg--error{color:#e74c3c}.pm-member-list{display:flex;flex-direction:column;gap:8px}.pm-member-row{align-items:center;display:flex;gap:10px}.pm-member-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:34px;justify-content:center;width:34px}.pm-member-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.pm-member-name{color:var(--text);font-size:.875rem;font-weight:500}.pm-member-email,.pm-member-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pm-member-email{color:var(--text-muted);font-size:.75rem}.pm-member-right{align-items:center;display:flex;flex-shrink:0;gap:6px}.pm-role-select{background:var(--surface);border:1px solid var(--border-light);border-radius:6px;color:var(--text);cursor:pointer;font-size:.78rem;padding:3px 7px}.pm-member-remove{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:2px 4px}.pm-member-remove:hover{color:#e74c3c}.pm-tasks-col{display:flex;flex-direction:column;gap:8px}.pm-task-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:12px 14px;transition:box-shadow .12s,border-color .12s}.pm-task-row:hover{border-color:#2563eb;border-color:var(--accent,#2563eb);box-shadow:0 2px 10px #00000012}.pm-task-row--done{opacity:.55}.pm-task-check{background:none;border:none;cursor:pointer;flex-shrink:0;font-size:1.1rem;line-height:1;padding:0}.pm-task-info{flex:1 1;min-width:0}.pm-task-title{color:var(--text);display:block;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pm-task-row--done .pm-task-title{text-decoration:line-through}.pm-task-meta{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.75rem;gap:10px;margin-top:3px}.pm-status-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.pm-task-actions{display:flex;flex-shrink:0;gap:2px;opacity:0;transition:opacity .12s}.pm-task-row:hover .pm-task-actions{opacity:1}.pm-done-divider{border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.78rem;font-weight:600;margin-top:4px;padding:8px 0 4px}.pm-empty-tasks{color:var(--text-muted);font-size:.84rem;font-style:italic;padding:8px 0}.pm-cost-list{display:flex;flex-direction:column;gap:6px}.pm-cost-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;font-size:.875rem;gap:10px;justify-content:space-between;padding:8px 0}.pm-cost-row:last-of-type{border-bottom:none}.pm-cost-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.pm-cost-label{color:var(--text);font-weight:500}.pm-cost-task{color:var(--text-muted);font-size:.75rem}.pm-cost-right{align-items:center;display:flex;flex-shrink:0;gap:6px}.pm-cost-amount{color:var(--text);font-weight:600;white-space:nowrap}.pm-cost-total{border-top:2px solid var(--border-light);color:var(--text);display:flex;font-size:.85rem;font-weight:700;justify-content:space-between;margin-top:4px;padding-top:8px}.pm-status-badge{border-radius:10px;color:#fff;display:inline-block;font-size:.72rem;font-weight:600;margin-left:8px;padding:2px 9px}.pm-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.pm-modal{background:#fff;background:var(--bg,#fff);border-radius:16px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;gap:14px;max-height:88vh;max-width:540px;overflow-y:auto;padding:20px;width:100%}.pm-modal-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between}.pm-modal-title{color:var(--text);font-size:1.05rem;font-weight:700}.pm-modal-desc{color:var(--text-muted);font-size:.875rem;line-height:1.5}.pm-modal-meta{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.84rem;gap:16px}.pm-modal-section-title{color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.pm-photo-grid{display:flex;flex-wrap:wrap;gap:10px}.pm-photo-thumb{border:1px solid var(--border-light);border-radius:10px;flex-shrink:0;height:120px;overflow:hidden;position:relative;transition:transform .15s,box-shadow .15s;width:120px}.pm-photo-thumb:hover{box-shadow:0 4px 16px #0000002e;transform:scale(1.03)}.pm-photo-thumb img{display:block;height:100%;object-fit:cover;width:100%}.pm-photo-caption{bottom:0;font-size:.65rem;left:0;overflow:hidden;padding:2px 5px;right:0;text-overflow:ellipsis;white-space:nowrap}.pm-photo-caption,.pm-photo-del{background:#0000008c;color:#fff;position:absolute}.pm-photo-del{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:.75rem;height:20px;justify-content:center;opacity:0;right:3px;top:3px;transition:opacity .15s;width:20px}.pm-photo-thumb:hover .pm-photo-del{opacity:1}.pm-photo-add{align-items:center;border:2px dashed var(--border-light);border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:.8rem;height:120px;justify-content:center;transition:border-color .15s,background .15s;width:120px}.pm-photo-add:hover{background:var(--surface);border-color:#2563eb;border-color:var(--accent,#2563eb);color:var(--text)}.pm-photo-add--uploading{opacity:.5;pointer-events:none}.pm-photo-thumb{cursor:zoom-in}.pm-lightbox-overlay{align-items:center;background:#000000e0;display:flex;inset:0;justify-content:center;outline:none;position:fixed;z-index:2000}.pm-lightbox{align-items:center;display:flex;flex-direction:column;max-height:94vh;max-width:94vw;position:relative}.pm-lightbox-img{border-radius:8px;box-shadow:0 8px 40px #0009;display:block;max-height:80vh;max-width:90vw;object-fit:contain}.pm-lightbox-close{align-items:center;background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:34px;justify-content:center;position:absolute;right:0;top:-40px;transition:background .15s;width:34px}.pm-lightbox-close:hover{background:#ffffff4d}.pm-lightbox-nav{align-items:center;background:#ffffff26;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:2.5rem;height:64px;justify-content:center;line-height:1;position:fixed;top:50%;transform:translateY(-50%);transition:background .15s;width:48px;z-index:2001}.pm-lightbox-nav:hover{background:#ffffff4d}.pm-lightbox-nav--prev{left:12px}.pm-lightbox-nav--next{right:12px}.pm-lightbox-footer{align-items:center;color:#ffffffd9;display:flex;font-size:.9rem;gap:16px;justify-content:center;margin-top:10px}.pm-lightbox-counter{color:#ffffff8c;font-size:.8rem}.pm-lightbox-del{background:#e74c3ccc;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;margin-top:10px;padding:6px 14px;transition:background .15s}.pm-lightbox-del:hover{background:#c0392bf2}.pm-photo-error{background:#fdecea;border:1px solid #f5c6cb;border-radius:6px;color:#c0392b;font-size:.85rem;margin-bottom:8px;padding:8px 12px}.pm-loading{font-size:.9rem;padding:20px 0}.pm-empty,.pm-loading{color:var(--text-muted);text-align:center}.pm-empty{padding:40px 0}.pm-empty-icon{font-size:2.5rem;margin-bottom:10px}.pm-empty p{margin:0 0 6px}.pm-empty-sub{font-size:.82rem}@media (max-width:700px){.pm-detail-layout,.pm-form-row-inline,.pm-project-grid{grid-template-columns:1fr}}.wmm-view{max-width:820px;padding:0 0 48px}.wmm-connect-banner{align-items:center;background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:10px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px 20px}.wmm-connect-banner--loading{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.9rem}.wmm-connect-banner--ok{background:#f0fdf4;border-color:#86efac;color:#166534;font-size:.9rem;font-weight:600}.wmm-connected-check{color:#16a34a;font-size:1.1rem;margin-left:auto}.wmm-connect-banner-text{color:#1a1a1a;color:var(--text,#1a1a1a);flex:1 1;font-size:.92rem;min-width:200px}.wmm-summary-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr);margin-bottom:28px}@media (max-width:600px){.wmm-summary-cards{grid-template-columns:1fr}}.wmm-summary-card{background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:10px;padding:16px 18px}.wmm-summary-card--escrow{background:#fffbeb;border-color:#fcd34d}.wmm-summary-card--released{background:#f0fdf4;border-color:#86efac}.wmm-summary-label{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.78rem;font-weight:600;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.wmm-summary-value{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1.5rem;font-weight:700;line-height:1.2}.wmm-summary-sub{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.78rem;margin-top:2px}.wmm-btn{align-items:center;border:none;border-radius:7px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:6px;justify-content:center;padding:9px 18px;text-decoration:none;transition:background .15s,opacity .15s}.wmm-btn:disabled{cursor:not-allowed;opacity:.6}.wmm-btn--primary{background:#2563eb;background:var(--accent,#2563eb);color:#fff}.wmm-btn--primary:hover:not(:disabled){background:#4338ca}.wmm-btn--ghost{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);color:#1a1a1a;color:var(--text,#1a1a1a)}.wmm-btn--ghost:hover:not(:disabled){background:#f8f9fa;background:var(--surface,#f8f9fa)}.wmm-btn--danger{background:#0000;border:1px solid #fca5a5;color:#dc2626}.wmm-btn--danger:hover:not(:disabled){background:#fef2f2}.wmm-btn--sm{font-size:.82rem;padding:6px 12px}.wmm-pill{border-radius:999px;display:inline-block;font-size:.76rem;font-weight:600;padding:3px 10px;white-space:nowrap}.wmm-pill--draft{background:#f1f5f9;color:#64748b}.wmm-pill--sent{background:#eff6ff;color:#2563eb}.wmm-pill--deposit_paid{background:#fef9c3;color:#a16207}.wmm-pill--in_progress{background:#fef3c7;color:#d97706}.wmm-pill--final_sent{background:#dbeafe;color:#1d4ed8}.wmm-pill--final_paid{background:#d1fae5;color:#065f46}.wmm-pill--paid_out{background:#dcfce7;color:#15803d}.wmm-pill--cancelled{background:#fee2e2;color:#991b1b}.wmm-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.wmm-list-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1rem;font-weight:700;margin:0}.wmm-engagement-list{display:flex;flex-direction:column;gap:10px}.wmm-engagement-card{background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:10px;cursor:pointer;padding:14px 18px;text-align:left;transition:border-color .15s,box-shadow .15s;width:100%}.wmm-engagement-card:hover{border-color:#2563eb;border-color:var(--accent,#2563eb);box-shadow:0 2px 8px #4f46e514}.wmm-card-top{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:6px}.wmm-card-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.95rem;font-weight:600}.wmm-card-meta{align-items:center;color:#94a3b8;color:var(--text-muted,#94a3b8);display:flex;font-size:.84rem;justify-content:space-between}.wmm-card-amount{color:#1a1a1a;color:var(--text,#1a1a1a);font-weight:700}.wmm-card-schedule{font-size:.76rem;margin-top:4px}.wmm-card-schedule,.wmm-loading{color:#94a3b8;color:var(--text-muted,#94a3b8)}.wmm-loading{font-size:.9rem;padding:48px 0;text-align:center}.wmm-empty{padding:56px 0;text-align:center}.wmm-empty-icon{font-size:2.5rem;margin-bottom:12px}.wmm-empty-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1.05rem;font-weight:700;margin-bottom:6px}.wmm-empty-sub{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.88rem}.wmm-form-card{background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:12px;margin-bottom:28px;padding:24px}.wmm-form-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1rem;font-weight:700;margin:0 0 18px}.wmm-form{gap:14px}.wmm-form,.wmm-form label{display:flex;flex-direction:column}.wmm-form label{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.84rem;font-weight:600;gap:5px}.wmm-form input,.wmm-form select,.wmm-form textarea{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:7px;color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.9rem;outline:none;padding:9px 11px;transition:border-color .15s}.wmm-form input:focus,.wmm-form select:focus,.wmm-form textarea:focus{border-color:#2563eb;border-color:var(--accent,#2563eb)}.wmm-form textarea{min-height:72px;resize:vertical}.wmm-form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}@media (max-width:540px){.wmm-form-row{grid-template-columns:1fr}}.wmm-form-actions{display:flex;flex-wrap:wrap;gap:10px}.wmm-fee-preview{background:#f8faff;border:1px solid #c7d2fe;border-radius:7px;color:#64748b;color:var(--text-muted,#64748b);font-size:.84rem;line-height:1.6;padding:10px 14px}.wmm-fee-note{color:#94a3b8}.wmm-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:7px;color:#dc2626;font-size:.85rem;padding:9px 14px}.wmm-label-required{color:#555;color:var(--text-secondary,#555);display:flex;flex-direction:column;font-size:.82rem;font-weight:600;gap:5px}.wmm-required-star{color:#dc2626;margin-left:2px}.wmm-contract-input-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.wmm-contract-filename{color:#2563eb;color:var(--accent,#2563eb);font-size:.82rem;font-weight:500}.wmm-field-hint{font-size:.78rem;font-weight:400}.wmm-detail-dates,.wmm-field-hint{color:#888;color:var(--text-muted,#888)}.wmm-detail-dates{align-items:center;display:flex;flex-wrap:wrap;font-size:.82rem;gap:6px;margin-top:4px}.wmm-dates-sep{color:#bbb;color:var(--text-muted,#bbb)}.wmm-detail{max-width:640px}.wmm-back{background:none;border:none;color:#2563eb;color:var(--accent,#2563eb);cursor:pointer;display:inline-block;font-size:.88rem;font-weight:600;margin-bottom:20px;padding:0}.wmm-back:hover{text-decoration:underline}.wmm-detail-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.wmm-detail-title{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:1.25rem;font-weight:700;margin:0 0 4px}.wmm-detail-client{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.85rem}.wmm-detail-amounts{background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:10px;margin-bottom:20px;padding:16px 18px}.wmm-amount-row{align-items:center;color:#1a1a1a;color:var(--text,#1a1a1a);display:flex;font-size:.9rem;justify-content:space-between;padding:5px 0}.wmm-amount-row--muted{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.84rem}.wmm-amount-label{color:inherit}.wmm-amount-value{font-weight:700}.wmm-schedule-badge{color:#64748b;color:var(--text-muted,#64748b);font-size:.76rem;font-weight:600;letter-spacing:.04em;margin-top:10px;text-transform:uppercase}.wmm-detail-section{margin-bottom:24px}.wmm-detail-section-title{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.78rem;font-weight:700;letter-spacing:.06em;margin-bottom:10px;text-transform:uppercase}.wmm-detail-notes{background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:8px;color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.88rem;line-height:1.5;margin-bottom:20px;padding:12px 16px}.wmm-contract-row{align-items:center;display:flex;gap:12px;margin-bottom:10px}.wmm-contract-upload{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.wmm-file-input{color:#64748b;color:var(--text-muted,#64748b);font-size:.82rem}.wmm-actions{align-items:flex-start;display:flex;flex-direction:column;gap:10px}.wmm-action-hint{background:#f8faff;border:1px solid #c7d2fe;border-radius:7px;color:#64748b;color:var(--text-muted,#64748b);font-size:.85rem;line-height:1.5;padding:10px 14px}.wmm-success-state{align-items:center;background:#f0fdf4;border:1px solid #86efac;border-radius:10px;display:flex;gap:14px;padding:16px 18px}.wmm-success-icon{color:#16a34a;font-size:1.4rem;font-weight:700}.wmm-success-title{color:#166534;font-size:.95rem;font-weight:700}.wmm-success-sub{color:#4ade80;color:#15803d;font-size:.83rem}.wmm-cancelled-state{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;font-size:.88rem;padding:12px 16px}.wmm-timeline{display:flex;flex-direction:column;gap:6px}.wmm-timeline-row{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border,#f1f5f9);color:#64748b;color:var(--text-muted,#64748b);display:flex;font-size:.84rem;justify-content:space-between;padding:4px 0}.wmm-timeline-row:last-child{border-bottom:none}.wmm-text-muted{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.84rem}.wmm-installment-config{background:#f8f9ff;border:1px solid #c7d2fe;border-radius:10px;display:flex;flex-direction:column;gap:12px;padding:16px}.wmm-installment-config-title{color:#4f46e5;font-size:.78rem;font-weight:700;letter-spacing:.06em;margin-bottom:2px;text-transform:uppercase}.wmm-checkbox-label{align-items:center;color:#1a1a1a;color:var(--text,#1a1a1a);cursor:pointer;display:flex!important;flex-direction:row!important;font-size:.86rem;font-weight:500;gap:8px}.wmm-checkbox-label input[type=checkbox]{flex-shrink:0;height:16px;margin:0;padding:0;width:16px}.wmm-field-hint--info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1d4ed8;font-size:.82rem;padding:8px 12px}.wmm-schedule-preview{background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.82rem;padding:12px 14px}.wmm-schedule-preview-title{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.74rem;font-weight:700;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.wmm-schedule-preview-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:10px;padding:4px 0}.wmm-schedule-preview-row:last-child{border-bottom:none}.wmm-schedule-num{color:#94a3b8;color:var(--text-muted,#94a3b8);font-weight:700;min-width:24px}.wmm-schedule-date{flex:1 1;min-width:100px}.wmm-schedule-amt,.wmm-schedule-date{color:#1a1a1a;color:var(--text,#1a1a1a)}.wmm-schedule-amt{font-weight:700}.wmm-schedule-receive{color:#16a34a;font-size:.78rem}.wmm-schedule-more{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.78rem;font-style:italic;padding:4px 0 0}.wmm-inst-pill{border-radius:999px;display:inline-block;font-size:.72rem;font-weight:600;padding:2px 8px;white-space:nowrap}.wmm-inst-pill--pending{background:#f1f5f9;color:#64748b}.wmm-inst-pill--sent{background:#eff6ff;color:#2563eb}.wmm-inst-pill--paid{background:#fef9c3;color:#a16207}.wmm-inst-pill--released{background:#dcfce7;color:#15803d}.wmm-inst-pill--cancelled{background:#fee2e2;color:#991b1b}.wmm-installments{display:flex;flex-direction:column;gap:10px}.wmm-inst-header{margin-bottom:4px}.wmm-inst-funding-badge{background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;display:inline-block;font-size:.82rem;font-weight:600;padding:4px 10px}.wmm-inst-list{display:flex;flex-direction:column;gap:8px}.wmm-inst-row{align-items:center;background:#f8f9fa;background:var(--surface,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;padding:10px 14px}.wmm-inst-row--released{background:#f0fdf4;border-color:#86efac;opacity:.85}.wmm-inst-row--paid{background:#fffbeb;border-color:#fde68a}.wmm-inst-row--sent{background:#eff6ff;border-color:#bfdbfe}.wmm-inst-row--cancelled{opacity:.55}.wmm-inst-num{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.82rem;font-weight:700;min-width:28px}.wmm-inst-info{flex:1 1;min-width:120px}.wmm-inst-amount{color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.95rem;font-weight:700}.wmm-inst-date{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.78rem;margin-top:2px}.wmm-inst-future{color:#fbbf24;font-style:italic}.wmm-inst-auto{color:#d97706;font-size:.74rem;font-style:italic;margin-top:2px}.wmm-inst-actions,.wmm-inst-summary{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.wmm-inst-summary{border-top:1px solid #e2e8f0;border-top:1px solid var(--border,#e2e8f0);color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.84rem;font-weight:600;justify-content:space-between;padding:8px 0 0}@font-face{font-display:block;font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_AMS-Regular.73ea273a72f4aca30ca5.woff2) format("woff2"),url(/static/media/KaTeX_AMS-Regular.d562e886c52f12660a41.woff) format("woff"),url(/static/media/KaTeX_AMS-Regular.853be92419a6c3766b9a.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Caligraphic-Bold.a1abf90dfd72792a577a.woff2) format("woff2"),url(/static/media/KaTeX_Caligraphic-Bold.d757c535a2e5902f1325.woff) format("woff"),url(/static/media/KaTeX_Caligraphic-Bold.7489a2fbfb9bfe704420.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Caligraphic-Regular.d6484fce1ef428d5bd94.woff2) format("woff2"),url(/static/media/KaTeX_Caligraphic-Regular.db074fa22cf224af93d7.woff) format("woff"),url(/static/media/KaTeX_Caligraphic-Regular.7e873d3833eb108a0758.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Fraktur-Bold.931d67ea207ab37ee693.woff2) format("woff2"),url(/static/media/KaTeX_Fraktur-Bold.354501bac435c3264834.woff) format("woff"),url(/static/media/KaTeX_Fraktur-Bold.4c761b3711973ab04edf.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Fraktur-Regular.172d3529b26f8cedef6b.woff2) format("woff2"),url(/static/media/KaTeX_Fraktur-Regular.6fdf0ac577be0ba82a4c.woff) format("woff"),url(/static/media/KaTeX_Fraktur-Regular.ed305b5434865e06ffde.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Main-Bold.39890742bc957b368704.woff2) format("woff2"),url(/static/media/KaTeX_Main-Bold.0c3b8929d377c0e9b2f3.woff) format("woff"),url(/static/media/KaTeX_Main-Bold.8169508bf58f8bd92ad8.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/static/media/KaTeX_Main-BoldItalic.20f389c4120be058d80a.woff2) format("woff2"),url(/static/media/KaTeX_Main-BoldItalic.428978dc7837d46de091.woff) format("woff"),url(/static/media/KaTeX_Main-BoldItalic.828abcb200061cffbaae.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/static/media/KaTeX_Main-Italic.fe2176f79edaa716e621.woff2) format("woff2"),url(/static/media/KaTeX_Main-Italic.fd947498bc16392e76c2.woff) format("woff"),url(/static/media/KaTeX_Main-Italic.fa675e5e4bec9eb250b6.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Main-Regular.f650f111a3b890d116f1.woff2) format("woff2"),url(/static/media/KaTeX_Main-Regular.4f35fbcc9ee8614c2bcc.woff) format("woff"),url(/static/media/KaTeX_Main-Regular.9eba1d77abcf2aa6e94e.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/static/media/KaTeX_Math-BoldItalic.dcbcbd93bac0470b462d.woff2) format("woff2"),url(/static/media/KaTeX_Math-BoldItalic.3f07ed67f06c720120ce.woff) format("woff"),url(/static/media/KaTeX_Math-BoldItalic.bf2d440b3a42ea78a998.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/static/media/KaTeX_Math-Italic.6d3d25f4820d0da8f01f.woff2) format("woff2"),url(/static/media/KaTeX_Math-Italic.96759856b4e70f3a8338.woff) format("woff"),url(/static/media/KaTeX_Math-Italic.8a5f936332e8028c7278.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:normal;font-weight:700;src:url(/static/media/KaTeX_SansSerif-Bold.95591a929f0d32aa282a.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Bold.b9cd458ac6d5889ff9c3.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Bold.5b49f4993ae22d7975b4.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:italic;font-weight:400;src:url(/static/media/KaTeX_SansSerif-Italic.7d393d382f3e7fb1c637.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Italic.8d593cfaa96238d5e2f8.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Italic.b257a18c016f37ee4543.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:normal;font-weight:400;src:url(/static/media/KaTeX_SansSerif-Regular.cd5e231e0cc53b2cb2c0.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Regular.02271ec5cb9f5b4588ac.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Regular.2f7bc363fc5424ebda59.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Script-Regular.c81d1b2a4b75d3eded60.woff2) format("woff2"),url(/static/media/KaTeX_Script-Regular.073b3402d036714b4370.woff) format("woff"),url(/static/media/KaTeX_Script-Regular.fc9ba5249878cd8f8d88.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size1-Regular.6eec866c69313624be60.woff2) format("woff2"),url(/static/media/KaTeX_Size1-Regular.0108e89c9003e8c14ea3.woff) format("woff"),url(/static/media/KaTeX_Size1-Regular.6de7d4b539221a49e9e2.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size2-Regular.2960900c4f271311eb36.woff2) format("woff2"),url(/static/media/KaTeX_Size2-Regular.3a99e70aee4076660d38.woff) format("woff"),url(/static/media/KaTeX_Size2-Regular.57f5c1837853986ea1db.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size3-Regular.e1951519f6f0596f7356.woff2) format("woff2"),url(/static/media/KaTeX_Size3-Regular.7947224e8a9914fa332b.woff) format("woff"),url(/static/media/KaTeX_Size3-Regular.8d6b6822586eea3d3b20.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size4-Regular.e418bf257af1052628d8.woff2) format("woff2"),url(/static/media/KaTeX_Size4-Regular.aeffd8025cba3647f1a6.woff) format("woff"),url(/static/media/KaTeX_Size4-Regular.4ad7c7e8bb8d10a34bb7.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Typewriter-Regular.c295e7f71970f03c0549.woff2) format("woff2"),url(/static/media/KaTeX_Typewriter-Regular.4c6b94fd1d07f8beff7c.woff) format("woff"),url(/static/media/KaTeX_Typewriter-Regular.c5c02d763c89380dcb4e.ttf) format("truetype")}.katex{font:normal 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;position:relative;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.45"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .smash{display:inline;line-height:0}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex svg{fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.sc-page{align-items:center;background:var(--bg);color:var(--text);display:flex;flex-direction:column;min-height:100vh;padding:32px 20px}.sc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-top:40px;max-width:420px;padding:32px 28px;width:100%}.sc-empty,.sc-loading{color:var(--text-muted);padding:40px 20px;text-align:center}.sc-title{font-family:var(--font-display);font-size:1.8rem;font-weight:400;margin:0 0 10px}.sc-logo-row{align-items:baseline;display:flex;gap:10px;margin-bottom:8px}.sc-logo-icon{font-size:1.6rem}.sc-class-name{font-family:var(--font-display);font-size:1.5rem;font-weight:400}.sc-class-desc{color:var(--text-muted);font-size:.92rem;line-height:1.5;margin:0 0 22px}.sc-label{color:var(--text-muted);display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:12px 0 6px;text-transform:uppercase}.sc-input{font-size:.95rem;padding:10px 12px;width:100%}.sc-fine-print{color:var(--text-light);font-size:.82rem;margin-top:16px;text-align:center}.sc-error{background:#fdecea;border:1px solid #f5b7b1;border-radius:var(--radius-sm);color:var(--priority-high);font-size:.88rem;margin-top:12px;padding:10px 12px}.sc-btn-primary{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.98rem;font-weight:600;margin-top:14px;padding:11px;transition:background .15s;width:100%}.sc-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.sc-btn-primary:disabled{cursor:not-allowed;opacity:.5}.sc-btn-sm{font-size:.85rem;margin-top:0;padding:6px 12px;width:auto}.sc-btn-lg{font-size:1rem;padding:14px}.sc-btn-ghost{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:.88rem;padding:8px 14px;transition:background .15s}.sc-btn-ghost:hover{background:var(--bg-hover)}.sc-classroom{align-items:stretch;margin:0 auto;max-width:760px}.sc-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:22px;padding-bottom:14px}.sc-class-title{font-family:var(--font-display);font-size:1.75rem;font-weight:400;margin:0 0 2px}.sc-welcome{color:var(--text-muted);font-size:.92rem}.sc-section{margin-bottom:26px}.sc-section-title{color:var(--text-muted);font-size:.82rem;font-weight:700;letter-spacing:.05em;margin:0 0 10px;text-transform:uppercase}.sc-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.sc-item{align-items:center;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:14px 16px}.sc-item-body{align-items:flex-start;display:flex;flex:1 1;gap:12px;min-width:0}.sc-item-icon{flex-shrink:0;font-size:1.3rem}.sc-item-desc{color:var(--text-muted);font-size:.86rem;margin-top:2px}.sc-item-meta{color:var(--text-muted);font-size:.78rem;margin-top:4px}.sc-score{color:var(--accent);font-weight:600}.sc-item-actions{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.sc-result-q-image{background:#fff;border:1px solid #00000014;border-radius:var(--radius-sm);display:block;margin:8px 0;max-width:100%}.sc-result-review-tag{color:var(--text-muted);font-size:.85rem;margin-bottom:4px}.sc-powered{color:var(--text-light);font-size:.78rem;margin-top:32px;text-align:center}.sc-powered a{color:var(--accent);text-decoration:none}.sc-powered a:hover{text-decoration:underline}.sc-quiz-wrap{align-items:stretch;margin:0 auto;max-width:680px}.sc-quiz-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.sc-quiz-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin:0}.sc-quiz-desc{color:var(--text-muted);margin-bottom:16px}.sc-quiz-questions{display:flex;flex-direction:column;gap:14px}.sc-quiz-q{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 18px}.sc-quiz-q-prompt{font-size:1rem;line-height:1.5;margin-bottom:10px}.sc-quiz-q-image{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);display:block;margin:0 auto 14px;max-width:100%}.sc-quiz-choices{display:flex;flex-direction:column;gap:6px}.sc-quiz-choice{align-items:center;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:.92rem;gap:10px;padding:9px 12px;transition:background .15s,border-color .15s}.sc-quiz-choice:hover{background:var(--bg-hover)}.sc-quiz-choice--on{background:var(--accent-soft);border-color:var(--accent)}.sc-quiz-fr{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-wrap:wrap;gap:10px;padding:10px 14px}.sc-quiz-fr-label{color:var(--text);font-size:.95rem;font-weight:600}.sc-quiz-fr-input{flex:0 1 200px;font-family:var(--font-body);font-size:1rem;padding:8px 12px}.sc-quiz-fr-unit{color:var(--text-muted);font-size:.92rem}.sc-result-wrap{align-items:center}.sc-result-card{max-width:560px;padding:36px 28px;text-align:center}.sc-result-emoji{font-size:3rem}.sc-result-h2{font-family:var(--font-display);font-size:2.2rem;font-weight:400;margin:8px 0 4px}.sc-result-sub{color:var(--text-muted);margin-bottom:20px}.sc-result-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0 0 20px;padding:0;text-align:left}.sc-result-item{border:1px solid;border-radius:var(--radius-sm);font-size:.9rem;padding:10px 12px}.sc-result-item--right{background:#dcfce7;border-color:#86efac;color:#166534}.sc-result-item--wrong{background:#fdecea;border-color:#f5b7b1;color:var(--priority-high)}.sc-result-q{color:var(--text);margin-bottom:4px}.sc-result-ans{font-size:.85rem}.sc-result-solution{border-top:1px dashed;margin-top:10px;opacity:.95;padding-top:8px}.sc-result-solution-label{font-size:.78rem;font-weight:700;letter-spacing:.04em;margin-bottom:6px;opacity:.7;text-transform:uppercase}.sc-result-solution-img{background:#fff;border:1px solid #00000014;border-radius:var(--radius-sm);display:block;max-width:100%}.sc-result-explanation{background:#ffffff80;border-radius:var(--radius-sm);color:var(--text);font-size:.88rem;line-height:1.45;margin-top:8px;padding:8px 10px}.sc-flash-wrap{align-items:center;margin:0 auto;max-width:520px}.sc-flash-counter{color:var(--text-muted);font-size:.88rem;margin-bottom:14px}.sc-flash-card{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);cursor:pointer;display:flex;justify-content:center;min-height:280px;padding:32px 28px;transition:background var(--transition),border-color var(--transition);width:100%}.sc-flash-card--flipped{background:var(--bg);border-color:var(--border-light)}.sc-flash-side{line-height:1.55;width:100%}.sc-flash-front{font-family:var(--font-display);font-size:1.5rem;font-weight:400;text-align:center}.sc-flash-back{font-family:var(--font-body);font-size:1.02rem;text-align:left}.rc-math-display{margin:12px 0;overflow-x:auto;overflow-y:hidden;text-align:center}.rc-math-fallback{background:var(--bg-hover);border-radius:3px;font-family:ui-monospace,monospace;font-family:var(--font-mono,ui-monospace,monospace);font-size:.92em;padding:1px 5px}.sc-flash-front .rc-math-display{font-size:1.15em;margin:8px 0}.sc-flash-front .rc-math-inline{font-size:1.05em}.sc-flash-hint{color:var(--text-light);font-size:.82rem;margin-top:10px}.sc-flash-nav{display:flex;gap:12px;margin-top:24px;max-width:360px;width:100%}.sc-flash-nav button{flex:1 1}.sc-preview-banner{align-items:center;align-self:stretch;background:#fef3c7;border-bottom:1px solid #fcd34d;border-radius:var(--radius-sm);color:#92400e;display:flex;font-size:.88rem;font-weight:600;gap:10px;justify-content:space-between;margin-bottom:8px;max-width:760px;padding:10px 16px;position:sticky;top:0;width:100%;z-index:30}.sc-preview-banner-text{flex:1 1}.sc-preview-banner-btn{background:#92400e1a;border:1px solid #92400e;border-radius:var(--radius-sm);color:#92400e;cursor:pointer;font-size:.8rem;font-weight:600;padding:5px 10px}.sc-preview-banner-btn:hover{background:#92400e2e}@media (max-width:640px){.sc-page{padding:16px 14px}.sc-card{margin-top:20px;padding:24px 20px}.sc-class-title{font-size:1.5rem}.sc-item{padding:12px 14px}.sc-flash-side{font-size:1.15rem;padding:22px}.sc-preview-banner{font-size:.82rem;padding:8px 12px}}.sc-pages-wrap{padding-bottom:60px}.sc-pages-count{color:var(--text-muted);font-size:.85rem;margin-left:auto;white-space:nowrap}.sc-pages-desc{color:var(--text-muted);font-size:.92rem;line-height:1.5;margin:0 auto 18px;max-width:900px;padding:0 16px}.sc-pages-list{display:flex;flex-direction:column;gap:28px;margin:0 auto;max-width:1100px;padding:0 16px}.sc-pages-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:0;overflow:hidden}.sc-pages-label{background:var(--bg-hover);border-bottom:1px solid var(--border-light);color:var(--text-muted);font-size:.84rem;font-weight:500;letter-spacing:.02em;padding:8px 14px}.sc-pages-img{background:#fff;cursor:zoom-in;display:block;height:auto;width:100%}.sc-pages-lightbox{align-items:center;background:#000000db;cursor:zoom-out;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:300}.sc-pages-lightbox-img{background:#fff;border-radius:var(--radius-sm);max-height:100%;max-width:100%;object-fit:contain}.sc-pages-lightbox-close{background:#ffffffe6;font-size:1.2rem;height:38px;right:16px;top:16px;width:38px}.sc-pages-lightbox-close,.sc-pages-lightbox-next,.sc-pages-lightbox-prev{border:none;border-radius:50%;color:var(--text);cursor:pointer;font-weight:700;position:absolute}.sc-pages-lightbox-next,.sc-pages-lightbox-prev{background:#ffffffd9;font-size:2rem;height:56px;line-height:1;top:50%;transform:translateY(-50%);transition:background var(--transition),opacity var(--transition);-webkit-user-select:none;user-select:none;width:56px;z-index:1}.sc-pages-lightbox-prev{left:24px}.sc-pages-lightbox-next{right:24px}.sc-pages-lightbox-next:hover:not(:disabled),.sc-pages-lightbox-prev:hover:not(:disabled){background:#fff}.sc-pages-lightbox-next:disabled,.sc-pages-lightbox-prev:disabled{cursor:not-allowed;opacity:.3}.sc-pages-lightbox-counter{align-items:center;background:#000000b3;border-radius:999px;bottom:24px;color:#fff;cursor:default;display:flex;font-size:.84rem;font-weight:500;gap:12px;left:50%;padding:8px 14px;position:absolute;transform:translateX(-50%);white-space:nowrap}.sc-pages-lightbox-label{letter-spacing:.02em;opacity:.85}.sc-pages-lightbox-index{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}@media (max-width:640px){.sc-pages-lightbox-next,.sc-pages-lightbox-prev{font-size:1.6rem;height:44px;width:44px}.sc-pages-lightbox-prev{left:10px}.sc-pages-lightbox-next{right:10px}.sc-pages-lightbox-counter{bottom:14px;font-size:.78rem;padding:6px 10px}.sc-pages-list{gap:18px;padding:0 8px}.sc-pages-label{font-size:.78rem;padding:6px 10px}}.sc-book{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:18px;padding:18px 18px 14px}.sc-book-title{color:var(--text);font-family:var(--font-display);font-size:1.5rem;margin:0 0 2px}.sc-book-subtitle{color:var(--text-muted);font-size:.86rem;font-style:italic;margin-bottom:12px}.sc-chapter{border-top:1px solid var(--border-light);margin-top:14px;padding-top:12px}.sc-chapter:first-of-type{border-top:none;padding-top:4px}.sc-chapter-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:8px}.sc-chapter-title{align-items:baseline;color:var(--text);display:flex;font-size:1.02rem;gap:10px;margin:0}.sc-chapter-number{background:var(--accent-soft);border-radius:999px;color:var(--accent);display:inline-block;font-size:.78rem;font-weight:600;padding:2px 8px}@media (max-width:640px){.sc-book{padding:14px 14px 10px}.sc-book-title{font-size:1.25rem}}.sc-cr-wrap{background:var(--bg);min-height:100vh;padding-bottom:80px}.sc-cr-stickynav{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;gap:10px;justify-content:space-between;padding:8px 16px;position:sticky;top:0;z-index:50}.sc-cr-back{font-weight:500}.sc-cr-header{margin:0 auto;max-width:1400px;padding:22px 20px 6px}.sc-cr-chapter-num{background:var(--accent-soft);border-radius:999px;color:var(--accent);display:inline-block;font-size:.78rem;font-weight:600;margin-bottom:6px;padding:2px 10px}.sc-cr-title{color:var(--text);font-family:var(--font-display);font-size:1.6rem;line-height:1.2;margin:0}.sc-cr-meta{color:var(--text-muted);font-size:.85rem;margin-top:4px}.sc-cr-toc-toggle{flex-shrink:0}.sc-cr-body{align-items:flex-start;display:flex;gap:28px;margin:0 auto;max-width:1400px;padding:20px}.sc-cr-toc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex:0 0 280px;max-height:calc(100vh - 80px);overflow-y:auto;padding:14px 12px;position:sticky;top:60px}.sc-cr-toc-heading{border-bottom:1px solid var(--border-light);color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.08em;margin:0 0 8px;padding:0 8px 8px;text-transform:uppercase}.sc-cr-toc-list{display:flex;flex-direction:column;gap:2px;list-style:none;margin:0;padding:0}.sc-cr-toc-link{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;display:flex;font-family:inherit;font-size:.88rem;gap:8px;justify-content:space-between;padding:7px 10px;text-align:left;transition:background var(--transition);width:100%}.sc-cr-toc-link:hover{background:var(--bg-hover)}.sc-cr-toc-link-count{font-feature-settings:"tnum";color:var(--text-muted);flex-shrink:0;font-size:.72rem;font-variant-numeric:tabular-nums}.sc-cr-toc-item--active .sc-cr-toc-link{background:var(--accent-soft);color:var(--accent);font-weight:600}.sc-cr-toc-item--active .sc-cr-toc-link-count{color:var(--accent)}.sc-cr-main{flex:1 1;gap:32px;min-width:0}.sc-cr-main,.sc-cr-section{display:flex;flex-direction:column}.sc-cr-section{gap:18px}.sc-cr-section-header{border-bottom:2px solid var(--border-light);padding-bottom:8px;scroll-margin-top:64px}.sc-cr-section-title{color:var(--text);font-family:var(--font-display);font-size:1.2rem;margin:0}.sc-cr-section-desc{color:var(--text-muted);font-size:.86rem;line-height:1.5;margin:4px 0 0}.sc-cr-toc-toggle{display:none}@media (max-width:900px){.sc-cr-toc-toggle{display:inline-flex}.sc-cr-body{flex-direction:column;gap:14px;padding:14px}.sc-cr-toc{border-radius:0;bottom:0;flex:none;left:0;max-height:none;overflow-y:auto;padding:60px 16px 24px;position:fixed;right:0;top:0;transform:translateY(-100%);transition:transform .25s ease;z-index:60}.sc-cr-toc--open{transform:translateY(0)}.sc-cr-title{font-size:1.3rem}.sc-cr-header{padding:16px 14px 4px}.sc-cr-section-header{scroll-margin-top:64px}}.sc-nav-row{background:var(--bg);margin:0 0 14px;padding:10px 0;position:sticky;top:0;z-index:30}.sc-page-header{border-bottom:1px solid var(--border-light);margin-bottom:18px;padding-bottom:14px}.sc-page-eyebrow{color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.06em;margin-bottom:4px;text-transform:uppercase}.sc-page-title{color:var(--text);font-family:var(--font-display);font-size:1.7rem;line-height:1.2;margin:0}.sc-page-sub{color:var(--text-muted);font-size:.92rem;font-style:italic;margin-top:4px}.sc-chapter-page-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;margin-top:4px}.sc-cards{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.sc-nav-card{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:16px;padding:16px 18px;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition)}.sc-nav-card:hover{background:var(--bg-hover);border-color:var(--text-light);box-shadow:var(--shadow-md)}.sc-card-icon{flex-shrink:0;font-size:1.8rem}.sc-card-number{flex-shrink:0;font-size:.92rem;min-width:36px;padding:5px 12px!important;text-align:center}.sc-card-body{flex:1 1;min-width:0}.sc-card-title{color:var(--text);font-size:1.02rem;font-weight:600}.sc-card-sub{color:var(--text-muted);font-size:.85rem;font-style:italic;margin-top:2px}.sc-card-meta{color:var(--text-muted);font-size:.82rem;margin-top:4px}.sc-card-chev{color:var(--text-light);flex-shrink:0;font-size:1.6rem;transition:color var(--transition),transform var(--transition)}.sc-nav-card:hover .sc-card-chev{color:var(--accent);transform:translateX(2px)}@media (max-width:640px){.sc-page-title{font-size:1.4rem}.sc-nav-card{gap:12px;padding:12px 14px}.sc-card-icon{font-size:1.4rem}.sc-card-title{font-size:.96rem}}.sc-tr-wrap{align-items:stretch;margin:0 auto;max-width:1500px;padding:0;width:100%}.sc-tr-counter{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:0;text-align:center}.sc-tr-title{color:var(--text);font-size:.92rem;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sc-tr-counter-num{color:var(--text-muted);font-size:.78rem;margin-top:1px}.sc-tr-nav{display:flex;flex-shrink:0;gap:6px}.sc-tr-body{align-items:stretch;display:flex;gap:16px;padding:16px}.sc-tr-pane{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.sc-tr-pane-header{align-items:center;background:var(--bg-hover);border-bottom:1px solid var(--border-light);color:var(--text);display:flex;font-size:.86rem;font-weight:600;gap:8px;justify-content:space-between;padding:10px 14px}.sc-tr-pane-count{background:var(--accent-soft);border-radius:999px;color:var(--accent);font-size:.74rem;font-weight:600;padding:1px 8px}.sc-tr-pane-image-wrap{align-items:flex-start;background:#fff;display:flex;flex:1 1;justify-content:center;min-height:200px;overflow-y:auto;padding:16px}.sc-tr-pane-image{cursor:zoom-in;display:block;height:auto;max-width:100%}.sc-tr-ref-list{border-bottom:1px solid var(--border-light);flex-shrink:0;gap:4px;list-style:none;margin:0;max-height:35vh;overflow-y:auto;padding:8px}.sc-tr-ref-link,.sc-tr-ref-list{display:flex;flex-direction:column}.sc-tr-ref-link{background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-family:inherit;padding:8px 12px;text-align:left;transition:background var(--transition),border-color var(--transition);width:100%}.sc-tr-ref-link:hover{background:var(--bg-hover)}.sc-tr-ref-link--active{background:var(--accent-soft);border-color:var(--accent)}.sc-tr-ref-label{font-size:.92rem;font-weight:600}.sc-tr-ref-link--active .sc-tr-ref-label{color:var(--accent)}.sc-tr-ref-note{color:var(--text-muted);font-size:.8rem;line-height:1.4;margin-top:2px}.sc-tr-no-image,.sc-tr-no-refs{color:var(--text-muted);font-size:.9rem;padding:28px 16px;text-align:center}.sc-tr-ref-image-wrap{border-top:1px solid var(--border-light)}@media (max-width:900px){.sc-tr-body{flex-direction:column;gap:12px;padding:12px}.sc-tr-pane{min-height:380px}.sc-tr-counter{align-items:flex-start;text-align:left}.sc-tr-title{font-size:.86rem}}.sc-files-breadcrumb{align-items:center;display:flex;flex-wrap:wrap;font-size:.95rem;gap:4px;padding:8px 0 16px}.sc-files-crumb{background:none;border:none;border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:4px 8px}.sc-files-crumb:hover{background:var(--bg-hover)}.sc-files-crumb-sep{color:var(--text-muted)}.sc-files-card .sc-card-icon{font-size:1.6rem}.sc-files-list{gap:6px}.sc-files-row-link{align-items:center;color:inherit;display:flex;flex:1 1;gap:8px;justify-content:space-between;padding:12px 14px;text-decoration:none}.sc-files-row-link:hover{background:var(--bg-hover);border-radius:6px}.sc-files-row-link:hover .sc-row-title{text-decoration:underline}.tutor-root{padding-bottom:40px}.tutor-error,.tutor-loading{color:var(--text-muted);padding:40px 20px;text-align:center}.tutor-error{color:var(--priority-high)}.tutor-empty-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);margin:20px auto;max-width:520px;padding:28px 28px 32px}.tutor-empty-title{font-family:var(--font-display);font-size:1.75rem;font-weight:400;margin:0 0 6px}.tutor-empty-sub{color:var(--text-muted);font-size:.95rem;line-height:1.45;margin:0 0 22px}.tutor-empty-cap{color:var(--text-light);font-size:.8rem;margin-top:14px;text-align:center}.tutor-header{border-bottom:1px solid var(--border-light);margin-bottom:16px;padding:8px 0 16px}.tutor-h2{color:var(--text);font-family:var(--font-display);font-size:1.8rem;font-weight:400;margin:0 0 6px}.tutor-h3{font-size:1rem;font-weight:600;margin:0}.tutor-h3--gap{margin-top:20px}.tutor-slug-display{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.88rem;gap:6px}.tutor-slug-label{font-weight:500}.tutor-slug-link{color:var(--accent);font-family:monospace;font-size:.85rem;text-decoration:none}.tutor-slug-link:hover{text-decoration:underline}.tutor-copy-btn{transition:background .15s,color .15s,border-color .15s}.tutor-copy-btn--done{background:#dcfce7;border-color:#86efac;color:#166534;font-weight:600}.tutor-copy-btn--done:hover{background:#dcfce7}.tutor-tabs{border-bottom:1px solid var(--border);display:flex;gap:4px;margin-bottom:16px;overflow-x:auto}.tutor-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;font-size:.92rem;margin-bottom:-1px;padding:10px 14px;transition:color .15s,border-color .15s;white-space:nowrap}.tutor-tab:hover{color:var(--text)}.tutor-tab--on{border-bottom-color:var(--accent);color:var(--accent);font-weight:600}.tutor-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:14px;padding:16px 18px}.tutor-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:12px}.tutor-count{color:var(--text-muted);font-size:.82rem;font-weight:400;margin-left:6px}.tutor-label{color:var(--text-muted);display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:12px 0 6px;text-transform:uppercase}.tutor-input{font-size:.95rem;padding:9px 12px;width:100%}.tutor-input-sm{font-size:.85rem;padding:6px 10px;width:auto}.tutor-input-inline{font-size:.85rem;padding:6px 10px;width:160px}.tutor-slug-row{align-items:stretch;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;overflow:hidden}.tutor-slug-prefix{background:var(--bg-hover);border-right:1px solid var(--border);color:var(--text-muted);font-family:monospace;font-size:.85rem;padding:9px 10px;white-space:nowrap}.tutor-input-slug{border:none!important;border-radius:0;flex:1 1;font-family:monospace;min-width:0}.tutor-slug-status{font-size:.82rem;margin-top:4px}.tutor-slug-status--ok{color:var(--success)}.tutor-slug-status--bad{color:var(--priority-high)}.tutor-btn-primary{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.92rem;font-weight:600;padding:9px 16px;transition:background .15s}.tutor-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.tutor-btn-primary:disabled{cursor:not-allowed;opacity:.5}.tutor-btn-lg{font-size:1rem;margin-top:10px;padding:12px 20px;width:100%}.tutor-btn-sm{font-size:.82rem;padding:6px 10px}.tutor-btn-ghost{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:.88rem;padding:8px 12px;transition:background .15s}.tutor-btn-ghost:hover{background:var(--bg-hover)}.tutor-btn-danger{background:#0000;border:1px solid var(--priority-high);border-radius:var(--radius-sm);color:var(--priority-high);cursor:pointer;font-size:.88rem;padding:8px 12px;transition:background .15s,color .15s}.tutor-btn-danger:hover{background:var(--priority-high);color:#fff}.tutor-error-inline{background:#fdecea;border:1px solid #f5b7b1;border-radius:var(--radius-sm);color:var(--priority-high)}.tutor-error-inline,.tutor-msg-inline{font-size:.88rem;margin-top:10px;padding:9px 12px}.tutor-msg-inline{background:var(--accent-soft);border:1px solid #bfdbfe;color:var(--accent)}.tutor-hint,.tutor-msg-inline{border-radius:var(--radius-sm)}.tutor-hint{background:var(--bg-hover);color:var(--text-muted);font-size:.82rem;margin-bottom:12px;padding:10px 12px}.tutor-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.tutor-row{align-items:center;background:var(--bg-hover);border-radius:var(--radius-sm);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:10px 12px}.tutor-row-body{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.tutor-row-meta,.tutor-row-meta-inline{color:var(--text-muted);font-size:.8rem}.tutor-row-meta-inline{margin-left:8px}.tutor-row-actions{display:flex;flex-wrap:wrap;gap:6px}.tutor-mat-icon{margin-right:6px}.tutor-empty-state{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.9rem;padding:20px 16px;text-align:center}.tutor-add-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;padding:14px}.tutor-add-form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.tutor-add-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.tutor-add-menu{display:flex;flex-wrap:wrap;gap:6px}.tutor-material-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px;padding:14px}.tutor-qb{margin-top:10px}.tutor-qb-item{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:8px;padding:10px 12px}.tutor-qb-head{align-items:center;display:flex;gap:8px;margin-bottom:6px}.tutor-qb-num{color:var(--text-muted);font-weight:700;min-width:28px}.tutor-qb-choice{align-items:center;display:flex;gap:8px;margin-top:6px}.tutor-qb-choice input[type=radio]{flex-shrink:0}.tutor-qb-tf{display:flex;font-size:.9rem;gap:18px;margin-top:6px}.tutor-qb-card{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr 1fr auto;margin-bottom:6px}.tutor-qb-image-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}.tutor-qb-image-label{color:var(--text-muted);font-size:.85rem}.tutor-qb-solution{border-top:1px dashed var(--border-light);margin-top:12px;padding-top:12px}.tutor-qb-solution-label{margin-top:0}.tutor-steps{line-height:1.7;margin:8px 0 0 18px}.tutor-steps li{margin-bottom:4px}.tutor-desc{color:var(--text);line-height:1.55}.tutor-table{border-collapse:collapse;font-size:.9rem;width:100%}.tutor-table th{border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.04em;padding:8px 10px;text-align:left;text-transform:uppercase}.tutor-table td{border-bottom:1px solid var(--border-light);padding:10px}.tutor-settings-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-top:20px}.tutor-table--clickable .tutor-attempt-row{cursor:pointer;transition:background .12s}.tutor-table--clickable .tutor-attempt-row:hover{background:var(--bg-hover)}.tutor-attempt-toggle{color:var(--text-muted);font-size:.85rem;width:22px}.tutor-attempt-detail-row td{background:var(--bg-hover);border-bottom:1px solid var(--border-light);padding:14px 18px}.tutor-attempt-summary{color:var(--text-muted);font-size:.92rem;margin-bottom:10px}.tutor-attempt-questions{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.tutor-attempt-q{background:var(--bg-card);border:1px solid var(--border-light);border-left:3px solid;border-radius:var(--radius-sm);padding:10px 14px}.tutor-attempt-q--right{border-left-color:var(--success)}.tutor-attempt-q--wrong{border-left-color:var(--priority-high)}.tutor-attempt-q-head{align-items:baseline;display:flex;gap:8px;margin-bottom:6px}.tutor-attempt-q-num{color:var(--text-muted);font-size:.82rem;font-weight:700;min-width:28px}.tutor-attempt-q-mark{font-weight:700}.tutor-attempt-q--right .tutor-attempt-q-mark{color:var(--success)}.tutor-attempt-q--wrong .tutor-attempt-q-mark{color:var(--priority-high)}.tutor-attempt-q-prompt{flex:1 1;font-size:.92rem;line-height:1.4}.tutor-attempt-q-image{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-sm);display:block;margin:8px 0;max-width:360px}.tutor-attempt-q-answers{display:flex;flex-direction:column;font-size:.88rem;gap:3px;margin-top:4px}.tutor-attempt-q-label{color:var(--text-muted);font-weight:500}.tutor-attempt-q-given-wrong{color:var(--priority-high);font-weight:600;text-decoration:line-through}.tutor-attempt-q-solution{font-size:.88rem;margin-top:8px}.tutor-attempt-q-solution summary{color:var(--accent);cursor:pointer;font-weight:500}.tutor-attempt-q-solution summary:hover{text-decoration:underline}.tutor-attempt-q-solimg{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-sm);display:block;margin:6px 0;max-width:100%}.tutor-attempt-q-expl{background:var(--bg);border-radius:var(--radius-sm);font-size:.86rem;line-height:1.45;margin-top:4px;padding:6px 10px}.tutor-preview-overlay{background:var(--bg);inset:0;overflow-y:auto;position:fixed;z-index:200}@media (max-width:640px){.tutor-add-form-row,.tutor-qb-card{grid-template-columns:1fr}.tutor-table{font-size:.82rem}.tutor-table td,.tutor-table th{padding:6px 8px}}.tutor-portal-card{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:14px;justify-content:space-between;margin-bottom:14px;padding:14px 18px}.tutor-portal-card-body{align-items:center;display:flex;gap:14px;min-width:0}.tutor-portal-card-icon{flex-shrink:0;font-size:1.6rem}.tutor-portal-card-text{min-width:0}.tutor-portal-card-title{color:var(--text);font-size:.95rem;font-weight:600}.tutor-portal-card-sub{color:var(--text-muted);font-size:.84rem;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tutor-portal-card-link{color:var(--accent);text-decoration:none}.tutor-portal-card-link:hover{text-decoration:underline}.tutor-portal-card-actions{display:flex;flex-shrink:0;gap:8px}.tutor-portal-modal{max-width:520px}.tutor-portal-modal-intro{color:var(--text-muted);font-size:.88rem;line-height:1.5;margin:4px 0 16px}.tutor-portal-modal-intro code{background:var(--bg-hover);border-radius:3px;font-size:.82rem;padding:1px 5px}.tutor-portal-modal-actions{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-top:18px}.tutor-portal-modal-actions-right{display:flex;gap:8px;margin-left:auto}@media (max-width:640px){.tutor-portal-card{align-items:stretch;flex-direction:column;gap:10px}.tutor-portal-card-actions{justify-content:flex-end}.tutor-portal-card-sub{white-space:normal}.tutor-portal-modal-actions{align-items:stretch;flex-direction:column}.tutor-portal-modal-actions-right{margin-left:0}}.tutor-classroom-switcher{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:12px;margin-bottom:4px;padding:10px 0 14px}.tutor-classroom-pills{display:flex;flex:1 1;flex-wrap:wrap;gap:6px;min-width:0}.tutor-classroom-pill{background:var(--bg-card);border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer;font-size:.88rem;font-weight:500;max-width:240px;overflow:hidden;padding:7px 14px;text-overflow:ellipsis;transition:background var(--transition),border-color var(--transition),color var(--transition);white-space:nowrap}.tutor-classroom-pill:hover{background:var(--bg-hover);border-color:var(--text-light)}.tutor-classroom-pill--on{background:var(--accent);border-color:var(--accent);color:#fff}.tutor-classroom-pill--on:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.tutor-classroom-add{flex-shrink:0}.tutor-new-classroom-modal{max-width:480px}@media (max-width:640px){.tutor-classroom-switcher{padding:8px 0 12px}.tutor-classroom-pill{font-size:.84rem;max-width:180px;padding:6px 12px}}.tutor-mat-tree{display:flex;flex-direction:column;gap:18px;margin-top:8px}.tutor-book{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.tutor-book-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:10px;padding-bottom:10px}.tutor-book-title-row{align-items:baseline;display:flex;flex-wrap:wrap;gap:10px;min-width:0}.tutor-book-icon{font-size:1.2rem}.tutor-book-title{color:var(--text);font-family:var(--font-display);font-size:1.25rem}.tutor-book-subtitle{color:var(--text-muted);font-size:.86rem;font-style:italic}.tutor-book-actions{display:flex;flex-shrink:0;gap:6px}.tutor-chapter{border-left:3px solid var(--border-light);margin-top:12px;padding-left:12px}.tutor-chapter-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:6px 0}.tutor-chapter-title-row{align-items:baseline;display:flex;flex-wrap:wrap;gap:10px;min-width:0}.tutor-chapter-number{background:var(--accent-soft);border-radius:999px;color:var(--accent);display:inline-block;font-size:.78rem;font-weight:600;padding:2px 8px}.tutor-chapter-title{color:var(--text);font-size:.98rem;font-weight:600}.tutor-chapter-count{color:var(--text-muted);font-size:.78rem;white-space:nowrap}.tutor-chapter-actions{display:flex;flex-shrink:0;gap:6px}.tutor-list--nested{margin:4px 0 0}.tutor-empty-state--inset{font-size:.86rem;padding:12px 0}.tutor-loose{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius);margin-top:8px;padding:14px 16px}.tutor-loose-header{align-items:baseline;border-bottom:1px solid var(--border-light);display:flex;gap:8px;margin-bottom:4px;padding-bottom:6px}.tutor-loose-icon{font-size:1rem}@media (max-width:640px){.tutor-book{padding:10px 12px}.tutor-book-title{font-size:1.1rem}.tutor-chapter{padding-left:8px}}.tutor-files-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tutor-files-btn-label{align-items:center;cursor:pointer;display:inline-flex;-webkit-user-select:none;user-select:none}.tutor-files-btn--disabled{opacity:.5;pointer-events:none}.tutor-files-breadcrumb{align-items:center;display:flex;flex-wrap:wrap;font-size:.9rem;gap:4px;padding:8px 4px}.tutor-files-crumb{background:none;border:none;border-radius:4px;color:var(--text-primary);cursor:pointer;padding:4px 8px}.tutor-files-crumb:hover{background:var(--bg-hover)}.tutor-files-crumb-sep{color:var(--text-muted)}.tutor-files-dropzone{border:2px dashed #0000;border-radius:8px;min-height:120px;padding:8px;transition:background .15s,border-color .15s}.tutor-files-dropzone--over{background:var(--bg-hover);border-color:var(--accent)}.tutor-files-row{align-items:center;display:flex;gap:12px;justify-content:space-between}.tutor-files-row-name{align-items:center;display:flex;gap:6px;word-break:break-word}.tutor-files-row-link{align-items:center;color:inherit;display:flex;flex:1 1;gap:8px;justify-content:space-between;text-decoration:none}.tutor-files-row-link:hover .tutor-files-row-name{text-decoration:underline}.tutor-files-icon{font-size:1.1rem}.tutor-files-progress{background:var(--bg-hover);border-radius:6px;margin-top:16px;padding:10px 12px}.tutor-files-progress-bar{background:var(--bg-card);background:var(--bg-input,var(--bg-card));border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden;width:100%}.tutor-files-progress-fill{background:var(--accent);height:100%;transition:width .2s ease}.tp-page{align-items:center;background:var(--bg);color:var(--text);display:flex;font-family:var(--font-body);justify-content:center;min-height:100vh;padding:24px 16px}.tp-loading{color:var(--text-muted)}.tp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:32px 28px;width:100%}.tp-card-narrow{max-width:440px}.tp-title{color:var(--text);font-family:var(--font-display);font-size:1.8rem;margin:0 0 4px}.tp-username{color:var(--text-muted);font-size:.95rem;margin:0 0 22px}.tp-label{color:var(--text);display:block;font-size:.85rem;font-weight:500;margin:12px 0 6px}.tp-input{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:1rem;padding:10px 12px;width:100%}.tp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.tp-btn-primary{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.98rem;font-weight:600;margin-top:16px;padding:11px 16px;transition:background var(--transition);width:100%}.tp-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.tp-btn-primary:disabled{cursor:not-allowed;opacity:.6}.tp-error{background:#fef2f2;border-radius:var(--radius-sm);color:var(--priority-high);font-size:.88rem;margin-top:12px;padding:8px 12px}.tp-muted{color:var(--text-muted);font-size:.92rem;margin:8px 0 16px}.tp-link{color:var(--accent);font-weight:500;text-decoration:none}.tp-link:hover{text-decoration:underline}.tp-foot{border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.86rem;margin-top:22px;padding-top:18px}.tp-shell{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh}.tp-shell-header{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;gap:16px;justify-content:space-between;padding:14px 20px}.tp-shell-brand{align-items:center;display:flex;gap:12px;min-width:0}.tp-shell-brand-mark{font-size:1.6rem}.tp-shell-brand-line{color:var(--text);font-size:.96rem;font-weight:600}.tp-shell-brand-sub{color:var(--text-muted);font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-shell-logout{background:#0000;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;flex-shrink:0;font-size:.9rem;font-weight:500;padding:8px 14px;transition:background var(--transition),border-color var(--transition)}.tp-shell-logout:hover{background:var(--bg-hover);border-color:var(--text-light)}.tp-shell-main{margin:0 auto;max-width:1200px;padding:20px 20px 80px}@media (max-width:640px){.tp-shell-header{padding:10px 14px}.tp-shell-brand-mark{font-size:1.4rem}.tp-shell-brand-line{font-size:.9rem}.tp-shell-brand-sub{font-size:.76rem}.tp-shell-main{padding:14px 12px 80px}}.sbv-wrap{display:flex;flex-direction:column;height:100%;min-height:0}.sbv-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;gap:14px;margin-bottom:16px;padding:0 0 16px}.sbv-back{background:none;border:1px solid var(--border-light);border-radius:8px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.85rem;padding:6px 12px;transition:background .15s,color .15s;white-space:nowrap}.sbv-back:hover{background:var(--surface);color:var(--text)}.sbv-header-info{display:flex;flex-direction:column;gap:2px;min-width:0}.sbv-owner{color:var(--text);font-size:.95rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sbv-badge{background:var(--surface);border:1px solid var(--border-light);border-radius:20px;color:var(--text-muted);display:inline-block;font-size:.74rem;padding:2px 9px;width:fit-content}.sbv-loading{align-items:center;color:var(--text-muted);display:flex;font-size:.9rem;gap:10px;justify-content:center;padding:40px 0}.sbv-error{background:#fdecea;border-radius:10px;color:#c0392b;font-size:.875rem;padding:14px 16px}.sbv-content{display:flex;flex:1 1;flex-direction:column;gap:20px;min-height:0;overflow-y:auto;padding-bottom:40px}.sbv-summary-bar{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.sbv-summary-bar--3{grid-template-columns:1fr 1fr 1fr}.sbv-summary-item{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:12px 14px}.sbv-summary-item--total{background:#3498db0f;border-color:#2563eb;border-color:var(--accent,#2563eb)}.sbv-summary-item--income{border-left:3px solid #27ae60}.sbv-summary-item--expense,.sbv-summary-item--over{border-left:3px solid #e74c3c}.sbv-summary-item--positive{border-left:3px solid #27ae60}.sbv-summary-val{color:var(--text);font-size:1.1rem;font-weight:700}.sbv-summary-label{color:var(--text-muted);font-size:.74rem;letter-spacing:.03em;text-transform:uppercase}.sbv-month-nav{align-items:center;display:flex;gap:12px;justify-content:center}.sbv-month-btn{background:var(--surface);border:1px solid var(--border-light);border-radius:8px;color:var(--text);cursor:pointer;font-size:1rem;line-height:1.4;padding:4px 12px;transition:background .15s}.sbv-month-btn:hover:not(:disabled){background:var(--border-light)}.sbv-month-btn:disabled{cursor:default;opacity:.35}.sbv-month-label{color:var(--text);font-size:.9rem;font-weight:600;min-width:140px;text-align:center}.sbv-section{display:flex;flex-direction:column;gap:6px}.sbv-section-title{color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.04em;margin-bottom:2px;text-transform:uppercase}.sbv-row{align-items:center;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;display:flex;gap:10px;padding:10px 12px}.sbv-row--income{border-left:3px solid #27ae60}.sbv-row-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.sbv-row-name{color:var(--text);font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sbv-row-meta{color:var(--text-muted);font-size:.75rem}.sbv-row-amts{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:2px}.sbv-row-amt{color:var(--text);font-size:.9rem;font-weight:700;white-space:nowrap}.sbv-row-cycle{color:var(--text-muted);font-size:.75rem;font-weight:400}.sbv-row-total{color:var(--text-muted);font-size:.72rem}.sbv-empty{color:var(--text-muted);font-size:.875rem;padding:32px 0;text-align:center}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{color-scheme:light}:root{--bg:#f6f3ee;--bg-card:#fff;--bg-sidebar:#f0ede6;--bg-hover:#faf8f5;--text:#1a1a1a;--text-muted:#7a7570;--text-light:#b0a99f;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-soft:#eff6ff;--border:#e8e3dc;--border-light:#f0ece6;--success:#4a8c6f;--priority-high:#c4553a;--priority-medium:#d4963a;--priority-low:#7a9a6b;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-modal:0 20px 60px #00000040;--radius:12px;--radius-sm:8px;--font-display:"Instrument Serif",Georgia,serif;--font-body:"DM Sans",-apple-system,sans-serif;--transition:0.2s cubic-bezier(0.4,0,0.2,1);--surface:var(--bg-card);--hover:var(--bg-hover);--input-bg:var(--bg-card);--card-bg:var(--bg-card)}.app-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.app-modal{background:#fff;background:var(--bg-card);border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 20px 60px #00000040;box-shadow:var(--shadow-modal);max-height:90vh;max-width:480px;overflow-y:auto;padding:24px;width:100%}input,select,textarea{appearance:none;background:#fff;border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--text);color-scheme:light;font:inherit}input::placeholder,textarea::placeholder{color:#b0a99f;color:var(--text-light);opacity:1}input:focus,select:focus,textarea:focus{border-color:#2563eb;border-color:var(--accent);outline:none}input[type=checkbox],input[type=radio]{appearance:auto;background:#0000 none repeat 0 0/auto auto padding-box border-box scroll;background:initial;border:initial;height:auto;width:auto}.app-input{padding:10px 14px;transition:border-color .15s;width:100%}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:#f6f3ee;background:var(--bg);color:#1a1a1a;color:var(--text);font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font-body);line-height:1.5;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e8e3dc;background:var(--border);border-radius:3px}.app-layout{display:flex;min-height:100vh}.main{flex:1 1;min-width:0}.main-inner{margin:0 auto;max-width:640px;padding:0 24px calc(80px + env(safe-area-inset-bottom, 0px))}.mobile-header{align-items:center;background:#f0ede6;background:var(--bg-sidebar);border-bottom:1px solid #f0ece6;border-bottom:1px solid var(--border-light);display:none;gap:12px;padding:14px 20px}.hamburger{background:none;border:none;color:#1a1a1a;color:var(--text);cursor:pointer;padding:4px}.loading{color:#7a7570;color:var(--text-muted);font-size:.9rem;padding:80px 20px;text-align:center}.spinner{animation:spin .6s linear infinite;border:2px solid #e8e3dc;border-top-color:#2563eb;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:28px;margin:0 auto 12px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.error-banner{background:#eff6ff;background:var(--accent-soft);border-radius:8px;border-radius:var(--radius-sm);color:#2563eb;color:var(--accent)}.error-banner,.warning-banner{font-size:.85rem;margin-bottom:16px;padding:12px 16px}.warning-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;border-radius:var(--radius-sm);color:#92400e}.view-tabs{background:#f0ede6;background:var(--bg-sidebar);border:1px solid #f0ece6;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-sm);display:flex;gap:4px;margin-bottom:20px;padding:3px;width:fit-content}.view-tab{background:none;border:none;border-radius:6px;color:#7a7570;color:var(--text-muted);cursor:pointer;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font-body);font-size:.82rem;font-weight:500;padding:6px 18px;transition:.2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.view-tab.active,.view-tab:hover{color:#1a1a1a;color:var(--text)}.view-tab.active{background:#fff;background:var(--bg-card);box-shadow:0 1px 3px #0000000a;box-shadow:var(--shadow-sm)}.main-inner-wide{max-width:820px}.mobile-header-btn{background:none;border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:6px;color:#7a7570;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-family:inherit;font-size:.75rem;padding:4px 8px}.mobile-header-btn:hover{border-color:#2563eb;border-color:var(--accent);color:#2563eb;color:var(--accent)}.mobile-signout:hover{border-color:#ef5350;color:#ef5350}.cat-pills{background:#f0ede6;background:var(--bg-sidebar);border-bottom:1px solid #f0ece6;border-bottom:1px solid var(--border-light);display:none;gap:6px;overflow-x:auto;padding:10px 16px;scrollbar-width:none}.cat-pills::-webkit-scrollbar{display:none}.cat-pill{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:100px;color:#7a7570;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-family:inherit;font-size:.78rem;gap:5px;padding:5px 12px;transition:.2s cubic-bezier(.4,0,.2,1);transition:var(--transition);white-space:nowrap}.cat-pill:hover{color:#2563eb;color:var(--accent)}.cat-pill.active,.cat-pill:hover{border-color:#2563eb;border-color:var(--accent)}.cat-pill.active{background:#2563eb;background:var(--accent);color:#fff}.cat-pill.active .cat-pill-count{background:#ffffff40;color:#fff}.cat-pill-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.cat-pill-count{background:#f6f3ee;background:var(--bg);border-radius:100px;color:#b0a99f;color:var(--text-light);font-size:.65rem;padding:1px 5px}@media (max-width:768px){.cat-pills,.mobile-header{display:flex}}.upgrade-wall{align-items:center;color:#b0a99f;color:var(--text-light);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px;text-align:center}.upgrade-wall p{font-size:1rem;line-height:1.5;max-width:360px}.upgrade-wall-btn{background:#2563eb;background:var(--accent);border-radius:8px;color:#fff;display:inline-block;font-family:"Instrument Serif",Georgia,serif;font-family:var(--font-display);font-size:.9rem;padding:10px 24px;text-decoration:none;transition:.2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.upgrade-wall-btn:hover{background:#1d4ed8;background:var(--accent-hover)}.organize-prompt-overlay{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.organize-prompt{background:#fff;background:var(--bg-card);border-radius:14px;box-shadow:0 8px 32px #00000024;display:flex;flex-direction:column;gap:12px;max-width:360px;padding:28px 24px;width:100%}.organize-prompt h3{color:#1a1a1a;color:var(--text);font-size:1.05rem;font-weight:700;margin:0}.organize-prompt p{color:#7a7570;color:var(--text-muted);font-size:.875rem;line-height:1.5;margin:0}.organize-prompt-runs{background:#f6f3ee;background:var(--bg,#f9fafb);border-radius:6px;color:#7a7570;color:var(--text-muted);font-size:.8rem;margin:-4px 0 4px;padding:6px 10px}.organize-prompt-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.organize-prompt-btn{background:#2563eb;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:11px;transition:background .15s}.organize-prompt-btn:hover{background:#1d4ed8;background:var(--accent-hover)}.organize-prompt-cancel{background:none;border:none;color:#7a7570;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:8px;text-align:center}.organize-prompt-cancel:hover{color:#1a1a1a;color:var(--text)}