.payment-calendar{margin-bottom:2rem}.payment-calendar-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.payment-calendar-header .summary-panel-title{margin:0}.payment-calendar-nav{display:flex;align-items:center;gap:.5rem}.payment-calendar-nav-btn{padding:.35rem .6rem;font-size:1.25rem;line-height:1;color:var(--text-primary);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:background .15s,color .15s}.payment-calendar-nav-btn:hover{background:var(--bg-elevated);color:var(--primary)}.payment-calendar-month-label{font-size:1rem;font-weight:600;color:var(--text-primary);min-width:10rem;text-align:center}.payment-calendar-grid-wrap{overflow-x:auto}.payment-calendar-grid{width:100%;min-width:280px;border-collapse:collapse;table-layout:fixed}.payment-calendar-day-name{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;padding:.35rem .2rem;text-align:center;border-bottom:1px solid var(--border)}.payment-calendar-cell{padding:.2rem;vertical-align:top;border:1px solid var(--border);text-align:center;position:relative}.payment-calendar-cell--empty{background:var(--bg-base);border-color:var(--border)}.payment-calendar-day-inner{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;min-height:2.25rem;width:100%;font-size:.875rem;font-weight:500;color:var(--text-primary);border-radius:var(--radius);position:relative}.payment-calendar-cell--today .payment-calendar-day-inner{background:var(--primary);color:var(--bg-base)}.payment-calendar-cell--has-due .payment-calendar-day-inner{font-weight:600}.payment-calendar-dot{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--danger)}.payment-calendar-cell--today .payment-calendar-dot{background:var(--bg-base)}.payment-calendar-tooltip{visibility:hidden;opacity:0;position:absolute;z-index:20;bottom:100%;left:50%;transform:translate(-50%) translateY(-6px);min-width:180px;max-width:260px;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:.8125rem;pointer-events:none;transition:opacity .15s ease,visibility .15s ease,transform .15s ease}.payment-calendar-cell:hover .payment-calendar-tooltip,.payment-calendar-cell:focus-within .payment-calendar-tooltip{visibility:visible;opacity:1;transform:translate(-50%) translateY(-6px)}.payment-calendar-tooltip-title{font-weight:600;color:var(--text-primary);margin-bottom:.35rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}.payment-calendar-tooltip-list{margin:0;padding-left:1.1rem;color:var(--text-secondary);line-height:1.5}.payment-calendar-tooltip-list li{margin-bottom:.15rem}.payment-calendar-tooltip-list li:last-child{margin-bottom:0}.payments-due-week{margin-bottom:2rem}.payments-due-week .summary-panel-title{margin:0 0 .25rem}.payments-due-week-range{font-size:.875rem;color:var(--text-muted);margin:0 0 1rem}.payments-due-week-empty{font-size:.9375rem;color:var(--text-secondary);margin:0;font-style:italic}.payments-due-week-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.payments-due-week-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius);font-size:.9375rem}.payments-due-week-date{font-weight:500;color:var(--text-secondary);white-space:nowrap}.payments-due-week-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis}.payments-due-week-amount{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary)}.dashboard-page{padding:0;max-width:100%}.dashboard-overview .summary-panel-title{margin:0 0 1.25rem}.summary-card{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1rem;text-align:center;transition:box-shadow .2s ease,transform .15s ease;box-shadow:var(--shadow-sm)}.dashboard-widgets-row{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}@media(min-width:720px){.dashboard-widgets-row{grid-template-columns:minmax(0,320px) 1fr}}.dashboard-chart-panel .summary-panel-title{margin:0 0 1rem}.dashboard-bar-chart{display:flex;flex-direction:column;gap:.5rem}.dashboard-bar-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(80px,2fr) auto;align-items:center;gap:.75rem}.dashboard-bar-label{font-size:.875rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-bar-track{height:1.25rem;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.dashboard-bar-fill{height:100%;min-width:2px;border-radius:4px;background:var(--danger);transition:width .4s ease}.dashboard-bar-value{font-size:.875rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary);min-width:5rem;text-align:right}@media(max-width:560px){.dashboard-bar-row{grid-template-columns:1fr;gap:.25rem}.dashboard-bar-value{text-align:left;min-width:0}}.credit-cards-page{padding:0;max-width:100%}.credit-cards-section{max-width:100%;margin:0}.credit-cards-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.credit-cards-header h2{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.add-card-btn{background:var(--primary);color:#0f172a;border:none;border-radius:var(--radius-md);padding:.625rem 1.25rem;font-size:1rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;box-shadow:0 2px 12px #2dd4bf4d}.add-card-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px #2dd4bf66}.add-card-btn:active{transform:translateY(0)}.credit-cards-header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.export-btn,.import-btn{padding:.5rem .875rem;font-size:.875rem;font-weight:600;font-family:var(--font-sans);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s ease,border-color .2s ease;border:1px solid var(--border);background:var(--bg-base);color:var(--text-primary)}.export-btn:hover,.import-btn:hover{background:var(--bg-elevated)}.export-import-label{cursor:pointer;margin:0}.export-import-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden}.import-btn{display:inline-block}.overview-utilization{margin-top:1.25rem;margin-bottom:0;padding-bottom:0;border-bottom:none}.overview-utilization .total-utilization-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.overview-utilization .total-utilization-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.overview-utilization .total-utilization-value{font-size:1rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.overview-utilization .total-utilization-empty{font-size:.875rem;font-weight:400;color:var(--text-muted);font-style:italic}.total-utilization-track{min-height:10px;height:10px;background:var(--bg-elevated);border-radius:5px;overflow:hidden;display:block}.total-utilization-fill{height:100%;border-radius:5px;background:var(--primary);transition:width .3s ease}.total-utilization-fill--empty{background:transparent}.summary-panel .summary-cards{margin-bottom:0}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1rem;text-align:center;transition:box-shadow .2s ease,transform .15s ease;box-shadow:var(--shadow-sm)}.summary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.summary-sublabel{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-top:.25rem;font-variant-numeric:tabular-nums}.summary-card-util .util-bar-wrap{margin-top:.5rem;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.summary-card-util .util-bar{height:100%;border-radius:3px;background:var(--primary);transition:width .3s ease}.form-group-full{grid-column:1 / -1}.form-group-checkbox .form-hint{margin-top:.25rem}.checkbox-label{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:500;color:var(--text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:1.125rem;height:1.125rem;accent-color:var(--primary);cursor:pointer}.form-hint{font-size:.75rem;font-weight:400;color:var(--text-muted);margin-top:.25rem;font-family:var(--font-sans)}.emoji-picker-field{position:relative}.emoji-picker-trigger{display:inline-flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-base);color:var(--text-primary);font:inherit;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;width:100%;text-align:left}.emoji-picker-trigger:hover{border-color:var(--border-focus)}.emoji-picker-trigger:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #0ea5e926}.emoji-picker-trigger-emoji{font-size:1.75rem;line-height:1}.emoji-picker-trigger-label{font-size:1rem;font-weight:500;color:var(--text-secondary)}.emoji-picker-dropdown{position:absolute;top:100%;left:0;margin-top:.5rem;z-index:50;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border)}.emoji-picker-dropdown .EmojiPickerReact{--epr-bg-color: var(--bg-surface);--epr-category-icon-bg-color: var(--bg-elevated);--epr-hover-bg-color: var(--bg-elevated);--epr-active-category-indicator-color: var(--primary);--epr-search-input-bg-color: var(--bg-base);--epr-search-input-text-color: var(--text-primary);--epr-search-input-placeholder-color: var(--text-muted);--epr-search-border-color: var(--border)}.add-card-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow-y:auto}.add-card-modal{width:100%;max-width:640px;max-height:calc(100vh - 3rem);overflow-y:auto}.add-card-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:0;box-shadow:var(--shadow-md)}.add-card-form-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.add-card-form-header h3,.add-card-form h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;font-family:var(--font-sans)}.add-card-modal-close{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .2s ease,color .2s ease}.add-card-modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.add-card-form form{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin-bottom:1.25rem}.add-card-form form .form-group-full{grid-column:1 / -1}@media(max-width:520px){.add-card-form form{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary);font-family:var(--font-sans)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date]{padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-weight:500;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);transition:border-color .2s ease,box-shadow .2s ease}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #0ea5e926}.form-group select{padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-weight:500;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.form-group select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #0ea5e926}.form-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.5rem}.form-actions-right{display:flex;gap:.75rem;margin-left:auto}.delete-btn-inline{padding:.625rem 1.25rem;font-size:1rem;font-weight:600;font-family:var(--font-sans);color:var(--danger);background:var(--danger-light);border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s ease,color .2s ease}.delete-btn-inline:hover{background:var(--danger);color:#fff}.save-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:.625rem 1.25rem;font-size:1rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background .2s ease,transform .15s ease}.save-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.cancel-btn{background:var(--bg-base);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.625rem 1.25rem;font-size:1rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background .2s ease,border-color .2s ease}.cancel-btn:hover{background:var(--border);border-color:var(--text-muted)}.credit-used-bar-always{padding:0 1.25rem 1rem;border-top:1px solid var(--border);background:var(--bg-base)}.credit-card-details .credit-used-bar-wrap{padding:0 0 1rem;margin-top:0}.credit-used-bar-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem}.credit-used-bar-always .util-bar-wrap{margin-top:.25rem}.credit-used-bar-always .credit-used-bar-label+.util-bar-wrap{margin-top:0}.credit-used-bar-value{font-variant-numeric:tabular-nums;color:var(--text-muted);font-weight:500}.credit-used-bar-empty{font-size:.75rem;color:var(--text-muted);font-style:italic}.util-bar--empty{min-width:0;background:transparent}.util-bar-wrap{height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.util-bar{height:100%;border-radius:4px;background:var(--primary);transition:width .3s ease}.util-bar-card{min-width:2%;background:var(--primary)}.cards-overview-section{margin-bottom:.5rem}.cards-overview-section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.overview-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.cards-view-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.view-mode-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-surface)}.sort-by-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.sort-by-text{font-weight:500}.sort-by-select{padding:.375rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);cursor:pointer}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.cards-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-surface)}.cards-table-sort-trigger{display:inline-flex;align-items:center;gap:.25rem;width:100%;padding:0;margin:0;border:none;font:inherit;font-weight:600;color:inherit;background:transparent;cursor:pointer;text-align:left;white-space:nowrap}.cards-table-sort-trigger:hover{color:var(--text-primary)}.cards-table-sort-trigger:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.cards-table-cell--actions{width:1%;white-space:nowrap;padding-right:.5rem}.card-action-trigger--table{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:background .2s ease,color .2s ease}.card-action-trigger--table:hover{background:var(--bg-elevated);color:var(--primary)}.card-action-trigger--table .card-action-pencil{width:1rem;height:1rem}.cards-table-row--zero .cards-table-cell{opacity:.7}.cards-table-cell--credit-used{min-width:140px}.cards-table-util-wrap{display:flex;flex-direction:column;gap:.25rem}.cards-table-util-bar{width:100%;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.cards-table-util-fill{height:100%;width:calc(var(--util-pct, 0) * 1%);border-radius:3px;background:var(--primary);transition:width .3s ease,background .2s ease}.cards-table-util-wrap[data-util-level=warning] .cards-table-util-fill{background:var(--warning)}.cards-table-util-wrap[data-util-level=danger] .cards-table-util-fill{background:var(--danger)}.cards-table-util-text{font-size:.8125rem;font-variant-numeric:tabular-nums;color:var(--text-secondary)}.card-due-overview{font-size:.875rem;font-weight:500;color:var(--warning);margin-right:.5rem}.credit-cards-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(323px,1fr));gap:1.25rem}.credit-card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:visible;transition:box-shadow .2s ease,border-color .2s ease;box-shadow:var(--shadow-sm)}.credit-card--physical{padding:0;width:323px;min-width:0;max-width:100%;margin:0 auto;border-radius:12px;overflow:hidden;border:none;box-shadow:none}.credit-card--flippable{cursor:pointer;perspective:1000px;aspect-ratio:323 / 204}.credit-card-flip-inner{position:relative;width:100%;height:100%;transition:transform .5s ease;transform-style:preserve-3d}.credit-card--flipped .credit-card-flip-inner{transform:rotateY(180deg)}.credit-card-face--front,.credit-card-face--back{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:12px;overflow:hidden}.credit-card-face--front{display:block;position:relative;z-index:1}.credit-card-face--back{transform:rotateY(180deg);z-index:0}.credit-card-face{width:100%;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;color:#f1f5f9f2}.credit-card--zero-balance .credit-card-plastic{opacity:.9}.credit-card-face--front .credit-card-plastic{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border-radius:12px;box-sizing:border-box}.credit-card-plastic{width:100%;aspect-ratio:323 / 204;min-height:0;flex-shrink:0;box-sizing:border-box;border-radius:12px 12px 0 0;border:1px solid rgba(255,255,255,.08);border-bottom:none;background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,transparent 28%),linear-gradient(145deg,#1e3a5f,#152a45 25%,#0f172a 55%,#0c1324);box-shadow:0 1px #ffffff0f inset,0 0 0 1px #0003,0 4px 12px #00000059,0 2px 4px #0003;display:flex;flex-direction:column;justify-content:space-between;padding:.5rem .65rem;overflow:hidden}.credit-card-face-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.35rem;flex-shrink:0}.credit-card-number{flex-shrink:0;padding:.25rem 0 0}.credit-card-face-bottom{flex-shrink:0;padding:.25rem 0 0;display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.credit-card-chip{width:20px;height:15px;border-radius:3px;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(0,0,0,.15) 2px,rgba(0,0,0,.15) 3px),linear-gradient(160deg,#e8c547,#c9a227 30%,#9a7b1a 70%,#b8962e);box-shadow:inset 0 1px #fff6,inset 0 -1px #00000040,0 1px 2px #00000059;flex-shrink:0;border:1px solid rgba(0,0,0,.2)}.credit-card-logo-stripe{width:32px;height:20px;border-radius:4px;background:linear-gradient(125deg,#ffc86440,#ffffff59,#96dcff4d,#ffffff40,#ffb49633);flex-shrink:0;box-shadow:inset 0 0 8px #fff3;position:relative}.credit-card-logo-stripe:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);opacity:.6;pointer-events:none}.credit-card-number{font-size:.65rem;font-variant-numeric:tabular-nums;letter-spacing:.12em;font-weight:600;opacity:.98;text-shadow:0 1px 0 rgba(255,255,255,.15),0 -1px 0 rgba(0,0,0,.4)}.credit-card-face-bottom{display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.credit-card-valid-label{font-size:.35rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;opacity:.75;margin-bottom:.0625rem;text-shadow:0 .5px 0 rgba(255,255,255,.12),0 -.5px 0 rgba(0,0,0,.25)}.credit-card-name{font-size:.4375rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;opacity:.98;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.12),0 -1px 0 rgba(0,0,0,.35)}.credit-card-valid-thru{display:flex;flex-direction:column;align-items:flex-end}.credit-card-valid-value{font-size:.4375rem;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:.04em;text-shadow:0 .5px 0 rgba(255,255,255,.1),0 -.5px 0 rgba(0,0,0,.3)}.credit-card-face--front .credit-card-tap-hint{position:absolute;bottom:0;left:0;right:0;padding:.25rem .5rem;font-size:.5625rem;font-weight:500;color:#f1f5f980;text-align:center;text-transform:uppercase;letter-spacing:.04em;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);pointer-events:none}.credit-card-tap-hint{flex-shrink:0;padding:.35rem .5rem;font-size:.625rem;font-weight:500;color:#f1f5f98c;text-align:center;text-transform:uppercase;letter-spacing:.04em;background:#0003}.credit-card-back-content{height:100%;padding:.5rem .5rem .35rem;background:linear-gradient(180deg,#1e3a5f,#152a45 40%,#0f172a);border-radius:12px;display:flex;flex-direction:column;gap:.2rem;overflow-y:auto;box-sizing:border-box}.credit-card-back-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-shrink:0}.credit-card-back-name{font-size:.75rem;font-weight:700;color:#f1f5f9f2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.credit-card-back-content .card-actions{flex-shrink:0;margin:0}.credit-card-back-content .credit-card-detail-balance{margin:.1rem 0 0}.credit-card-back-tap-hint{margin-top:auto;padding-top:.35rem;font-size:.5625rem;font-weight:500;color:#f1f5f980;text-align:center;text-transform:uppercase;letter-spacing:.04em}.credit-card-face .card-actions{margin:-.2rem -.2rem 0 0;flex-shrink:0}.card-action-trigger--on-card{color:#f1f5f9bf;width:1.35rem;height:1.35rem}.card-action-trigger--on-card:hover{color:#fff;background:#ffffff1f}.credit-card-face .card-action-pencil{width:.7rem;height:.7rem}.credit-card-details-section{padding:.2rem .5rem .35rem;background:#00000040;display:flex;flex-direction:column;gap:.15rem;flex-shrink:0}.credit-card-detail-balance{font-size:.75rem;font-weight:700;font-variant-numeric:tabular-nums;color:#f1f5f9;line-height:1.1}.credit-card-detail-list{display:grid;grid-template-columns:1fr 1fr;gap:.05rem .75rem;margin:0;font-size:.5rem}.credit-card-detail-row{display:flex;justify-content:space-between;align-items:baseline;gap:.35rem}.credit-card-detail-row dt{margin:0;font-weight:500;color:#f1f5f9a6;text-transform:uppercase;letter-spacing:.02em;flex-shrink:0}.credit-card-detail-row dd{margin:0;font-weight:600;font-variant-numeric:tabular-nums;color:#f1f5f9f2;text-align:right}.card-util-bar-wrap--on-card{margin:0;margin-top:.15rem;padding:.1rem 0 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}.card-util-bar-wrap--on-card .card-util-bar-track{height:2px;margin-bottom:.1rem;background:#ffffff1a;border-radius:1px}.card-util-bar-wrap--on-card .card-util-bar-fill{border-radius:1px}.card-util-bar-wrap--on-card .card-credit-used-line{flex-wrap:wrap;gap:.15rem}.card-util-bar-wrap--on-card .card-credit-used-label,.card-util-bar-wrap--on-card .card-credit-used-value{font-size:.45rem;color:#f1f5f9bf}.card-util-bar-wrap--on-card .card-credit-used-pct{color:#f1f5f98c}.credit-card--zero-balance{opacity:.6}.credit-card--zero-balance .credit-card-overview{border-left-color:var(--text-muted)}.credit-card.is-expanded{box-shadow:var(--shadow-md);border-color:var(--border-focus)}.credit-card-overview{width:100%;background:var(--bg-surface);border-left:4px solid var(--primary);padding:.75rem 1.25rem}.card-overview-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:0;min-width:0}.card-util-bar-wrap{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.card-util-bar-track{width:100%;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin-bottom:.375rem}.card-util-bar-fill{height:100%;width:calc(var(--util-pct, 0) * 1%);border-radius:3px;background:var(--primary);transition:width .3s ease,background .2s ease}.card-util-bar-wrap[data-util-level=warning] .card-util-bar-fill{background:var(--warning)}.card-util-bar-wrap[data-util-level=danger] .card-util-bar-fill{background:var(--danger)}.card-util-bar-wrap .card-credit-used-line{border-top:none;padding:0 0 .125rem;background:transparent}.card-overview-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.card-overview-right .card-actions{position:relative;display:flex;align-items:center;gap:0;margin:0;padding:0}.card-action-trigger{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:background .2s ease,color .2s ease}.card-action-trigger:hover{background:var(--bg-elevated);color:var(--text-primary)}.card-action-trigger[aria-expanded=true]{background:var(--bg-elevated);color:var(--primary)}.card-action-pencil{width:1.125rem;height:1.125rem;flex-shrink:0}.card-action-menu{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:8rem;padding:.25rem 0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:10}.card-action-menu-item{display:block;width:100%;padding:.5rem .75rem;border:none;border-radius:0;background:none;font-size:.875rem;font-weight:500;font-family:var(--font-sans);color:var(--text-primary);text-align:left;cursor:pointer;transition:background .15s ease}.card-action-menu-item:hover{background:var(--bg-base)}.card-action-menu-item--edit:hover{color:var(--primary)}.card-action-menu-item--delete{color:var(--danger)}.card-action-menu-item--delete:hover{background:var(--danger-light);color:var(--danger)}.card-credit-used-line{display:flex;justify-content:space-between;align-items:center;padding:0;font-size:.875rem;background:transparent}.card-credit-used-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.card-credit-used-value{font-size:.875rem;font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:500}.card-credit-used-pct{color:var(--text-muted);font-weight:400}.credit-card-overview .card-logo{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;margin-right:.75rem}.credit-card-overview .card-info{display:flex;align-items:center;min-width:0;flex:1}.card-logo-emoji .card-emoji{font-size:1.75rem;line-height:1}.card-network-icon{display:inline-block;flex-shrink:0;line-height:0;vertical-align:middle}.card-network-icon svg{display:block;width:100%;height:100%;object-fit:contain}.credit-card-overview .card-logo .card-network-icon{flex-shrink:0}.credit-card-overview .card-logo-initial{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:700;letter-spacing:-.02em}.credit-card-overview .card-details{display:flex;flex-direction:column;gap:.15rem;min-width:0}.card-info--one-line{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem .5rem;min-width:0;flex:1}.card-header-field-inline--due .card-header-field-value{color:var(--warning)}.card-info--one-line .card-name{margin-right:.25rem}.card-header-sep{color:var(--text-muted);font-weight:500;opacity:.7;-webkit-user-select:none;user-select:none}.card-header-field-inline{display:inline-flex;align-items:baseline;gap:.35rem}.card-header-field-inline .card-header-field-label{font-size:1rem;font-weight:600;color:var(--text-primary)}.card-header-field-inline .card-header-field-value{font-size:1rem;font-weight:600;font-variant-numeric:tabular-nums}.card-overview-row .card-name{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.card-overview-row .card-last-four{font-weight:500;color:var(--text-muted);font-variant-numeric:tabular-nums}.card-header-fields{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin-top:.5rem}.card-header-field{display:flex;flex-direction:column;gap:.125rem}.card-header-field-label{font-size:.75rem;font-weight:600;color:var(--text-muted)}.card-header-field-value{font-size:.875rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.card-overview-row .card-meta{font-size:.875rem;font-weight:400;color:var(--text-secondary)}.card-meta-sep{opacity:.8}.card-overview-row .card-balance-overview{font-size:1.125rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.credit-card.is-expanded .card-chevron{transform:rotate(0)}.credit-card-details{padding:0 1.25rem 1rem;border-top:1px solid var(--border);background:var(--bg-base)}.credit-card-details[hidden]{display:none}.card-details-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.75rem 0 .5rem}.card-details-meta{display:flex;gap:1rem;font-size:.875rem;color:var(--text-secondary)}.card-details-meta span{font-variant-numeric:tabular-nums}.card-info{display:flex;align-items:center;gap:1rem}.card-logo{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;flex-shrink:0}.card-details h3{margin:0 0 .2rem;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.card-details p{margin:0;font-size:.875rem;font-weight:400;color:var(--text-secondary)}.card-balance{font-size:1.25rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.card-rate{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.card-min-payment{font-size:.875rem;font-weight:500;color:var(--text-muted);font-variant-numeric:tabular-nums}.empty-state{text-align:center;padding:3rem 2rem;background:var(--bg-surface);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-secondary)}.empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.empty-state p{font-size:1rem;font-weight:400;max-width:280px;margin:0 auto;color:var(--text-secondary)}@media(max-width:768px){.credit-cards-header{flex-direction:column;align-items:flex-start}.summary-cards{grid-template-columns:1fr}.credit-card-overview{flex-wrap:wrap}.card-overview-right{width:100%;justify-content:flex-end}.card-details-header{flex-direction:column;align-items:flex-start}.card-actions{width:100%;justify-content:flex-end}}.payoff-page{padding:0;max-width:100%}.payoff-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.payoff-page-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.summary-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.summary-panel-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin:0 0 1.25rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.summary-card{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem 1rem;text-align:center;transition:box-shadow .2s ease;box-shadow:var(--shadow-sm)}.summary-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem;display:block}.summary-value{font-size:1.25rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.summary-value.balance{color:var(--danger)}.view-mode-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-base)}.view-mode-tab{padding:.4rem .75rem;font-size:.875rem;font-weight:600;font-family:var(--font-sans);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .2s ease,color .2s ease}.view-mode-tab:hover{color:var(--text-primary);background:var(--bg-elevated)}.view-mode-tab--active{color:var(--primary);background:var(--bg-elevated)}.payoff-controls-panel .summary-panel-title,.payoff-mode-row,.payoff-strategy-row{margin-bottom:1rem}.payoff-strategy-row .view-mode-tabs{margin-bottom:.35rem}.payoff-strategy-tabs .view-mode-tab{padding:.4rem .75rem}.payoff-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.payoff-hint{font-size:.8125rem;color:var(--text-muted);margin:.35rem 0 0;line-height:1.4}.payoff-card-select-row{margin-bottom:1rem}.payoff-select{width:100%;max-width:380px;padding:.5rem .75rem;font-size:.9375rem;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.payoff-payment-row{margin-top:.25rem}.payoff-payment-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.payoff-slider{flex:1;min-width:160px;height:8px;accent-color:var(--primary);cursor:pointer}.payoff-payment-input-wrap{display:inline-flex;align-items:center;gap:.15rem;padding:.5rem .75rem;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:6.5rem}.payoff-currency{font-size:.875rem;font-weight:600;color:var(--text-muted)}.payoff-payment-input{flex:1;min-width:2.5rem;padding:0;border:none;background:transparent;font-size:.9375rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary);font-family:var(--font-sans)}.payoff-payment-input:focus{outline:none}.payoff-per-mo{font-size:.8125rem;color:var(--text-muted)}.payoff-empty-state{text-align:center}.payoff-empty-text{margin:0;font-size:.9375rem;color:var(--text-muted)}.payoff-summary-section{margin-bottom:2rem}.payoff-summary-cards{margin-bottom:0}.payoff-table-section .summary-panel-title{margin-bottom:1rem}.cards-table-wrap{overflow-x:auto}.cards-table{width:100%;border-collapse:collapse;font-size:.875rem}.cards-table th,.cards-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.cards-table th{font-weight:600;color:var(--text-secondary);background:var(--bg-elevated);white-space:nowrap}.cards-table tbody tr:last-child td{border-bottom:none}.cards-table tbody tr:hover{background:#ffffff05}.cards-table-cell{font-variant-numeric:tabular-nums;color:var(--text-primary)}.cards-table-cell--name{font-weight:600}.cards-table-cell--balance{font-weight:600;color:var(--danger)}@media(max-width:640px){.payoff-payment-controls{flex-direction:column;align-items:stretch}.payoff-slider{min-width:100%}.payoff-summary-cards{grid-template-columns:1fr 1fr}}:root{--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--bg-base: #0f172a;--bg-surface: #1e293b;--bg-elevated: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #334155;--border-focus: #38bdf8;--primary: #2dd4bf;--primary-hover: #5eead4;--primary-light: #134e4a;--danger: #f87171;--danger-light: #450a0a;--success: #34d399;--success-light: #064e3b;--warning: #fbbf24;--warning-light: #422006;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .35), 0 4px 12px rgba(0, 0, 0, .2)}*{margin:0;padding:0;box-sizing:border-box}html{height:100%}body{font-family:var(--font-sans);font-size:1rem;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-base);color:var(--text-primary);min-height:100%;height:100%}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(45,212,191,.06),transparent),radial-gradient(ellipse 60% 40% at 100% 50%,rgba(56,189,248,.04),transparent),radial-gradient(ellipse 50% 30% at 0% 80%,rgba(45,212,191,.05),transparent);pointer-events:none;z-index:0}#root{min-height:100%;height:100%;position:relative;z-index:1}.app-shell{min-height:100%;height:100%;display:flex;flex-direction:column}.app-header{padding:clamp(.75rem,1.5vw,1.25rem) clamp(1.25rem,4vw,2rem);border-bottom:1px solid var(--border);background:var(--bg-surface);box-shadow:var(--shadow-sm);flex-shrink:0}.app-header-inner{width:100%;max-width:none;margin:0}.app-logo{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0 0 .25rem;display:flex;align-items:baseline;gap:.5rem}.app-logo-emoji{font-size:1.35em;line-height:1;vertical-align:baseline}.app-tagline{font-size:1rem;font-weight:500;color:var(--text-secondary);margin:0}.app-nav{display:flex;gap:1rem;margin-top:.75rem}.app-nav-link{font-size:.9375rem;font-weight:600;color:var(--text-secondary);text-decoration:none;padding:.25rem 0;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}.app-nav-link:hover{color:var(--text-primary)}.app-nav-link--active{color:var(--primary);border-bottom-color:var(--primary)}.app-main{flex:1;min-height:0;padding:clamp(1rem,2vw,2rem) clamp(1.25rem,4vw,2.5rem) clamp(1.5rem,3vw,2.5rem);width:100%;overflow:auto}
