*{box-sizing:border-box}html{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%;box-sizing:border-box;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s;-webkit-tap-highlight-color:transparent}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media(max-width:768px){h1{font-size:2.5em}button{padding:.5em 1em;font-size:.95em}}@media(max-width:480px){h1{font-size:2em}button{padding:.4em .8em;font-size:.9em}}@supports (padding: max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-bottom:max(0px,env(safe-area-inset-bottom))}}input[type=text],input[type=number],input[type=email],input[type=password],select,textarea{font-size:16px!important}canvas{max-width:100%!important;height:auto!important}.dashboard,.dashboard__charts-col,.dashboard__chart,.patrimoine-history-chart,.contrib-chart-bar-container,.net-worth-chart,.pret-remboursement-chart,.financial-goal-modal{max-width:100vw!important;overflow-x:hidden!important;box-sizing:border-box!important}:root{--primary-color: #1e3a8a;--secondary-color: #152c6e;--accent-color: #00c9a7;--positive-color: #10b981;--negative-color: #ef4444;--text-color: #17202a;--text-muted: #566573;--text-light: #6b7280;--text-dark: #111827;--bg-card: rgba(255, 255, 255, .9);--bg-card-alt: rgba(248, 250, 252, .9);--bg-gray-light: #f3f4f6;--bg-success: #f0fdf4;--bg-error: #fef2f2;--bg-info: #f0f9ff;--text-xs: .75rem;--text-sm: .875rem;--text-md: 1rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 2rem;--border-color: rgba(174, 182, 191, .5);--border-light: #d1d5db;--border-success: #bbf7d0;--border-error: #fecaca;--border-info: #7dd3fc;--gradient-primary: linear-gradient(135deg, #1e3a8a 0%, #152c6e 100%);--gradient-accent: linear-gradient(135deg, #00c9a7 0%, #00b4db 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #6ee7b7 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #f87171 100%);--gradient-blue: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3: .75rem;--spacing-5: 1.25rem;--spacing-9: 2.25rem;--spacing-10: 2.5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--shadow-sm: 0 1px 4px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 4px 12px rgba(0,0,0,.1);--shadow-xl: 0 6px 20px rgba(0,0,0,.15);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--spacing-md) 1.25rem;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:saturate(160%) blur(6px);backdrop-filter:saturate(160%) blur(6px)}.page-header__title{flex:1}.page-header__title h1{font-size:2rem;font-weight:700;color:var(--text-dark);margin:0 0 .5rem;letter-spacing:-.02em}.page-header__subtitle{color:var(--text-light);margin:0;font-size:1rem;line-height:1.5}.page-header__date{font-size:.875rem;color:var(--text-light);text-align:right;white-space:nowrap}.card{background:#ffffffe6;padding:2.5em;border-radius:20px;box-shadow:0 25px 50px #0000001a,0 10px 25px #0000000d;text-align:center;position:relative;overflow:hidden;border:1px solid rgba(174,182,191,.5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s cubic-bezier(.4,0,.2,1)}.card--overflow{overflow:visible}.summary-card{padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.summary-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:#3b82f61a;font-size:1.5rem;flex-shrink:0}.summary-card__icon--primary{background:#1e3a8a1f;color:var(--primary-color)}.summary-card__icon--success{background:#10b9811f;color:var(--positive-color)}.summary-card__icon--danger{background:#ef44441f;color:var(--negative-color)}.summary-card__icon--accent{background:#00c9a71f;color:var(--accent-color)}.summary-card__content{flex:1;min-width:0}.summary-card__label{font-size:.875rem;font-weight:500;margin:0 0 .5rem;color:var(--text-light)}.summary-card__value{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;color:var(--text-dark)}.summary-card__sublabel{font-size:.75rem;color:var(--text-light);margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:1rem;font-family:inherit;transition:all var(--transition-normal);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn--primary{background:var(--gradient-primary);color:#fff}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1e3a8a4d}.btn--success{background:var(--gradient-success);color:#fff}.btn--success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn--danger{background:var(--gradient-danger);color:#fff}.btn--danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn--ghost{background:#fff;border:1px solid var(--border-light);color:var(--text-dark)}.btn--ghost:hover:not(:disabled){background:var(--bg-gray-light);border-color:var(--border-color)}.btn--link{background:transparent;color:var(--primary-color);padding:.5rem 1rem}.btn--link:hover:not(:disabled){background:#1e3a8a1a}.btn--sm{padding:.5rem 1rem;font-size:.875rem}.btn--lg{padding:1rem 2rem;font-size:1.125rem}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-weight:500;color:#374151;font-size:.875rem;margin-bottom:var(--spacing-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e3a8a1a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--bg-gray-light);cursor:not-allowed;opacity:.6}.form-textarea{resize:vertical;min-height:100px}.form-help{display:block;font-size:.75rem;color:var(--text-light);margin-top:var(--spacing-xs)}.form-error{display:block;font-size:.75rem;color:var(--negative-color);margin-top:var(--spacing-xs)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--spacing-lg);line-height:1.5}.alert--success{background:var(--bg-success);border:1px solid var(--border-success);color:#059669}.alert--error{background:var(--bg-error);border:1px solid var(--border-error);color:#dc2626}.alert--info{background:var(--bg-info);border:1px solid var(--border-info);color:#0369a1}.alert--warning{background:#fffbeb;border:1px solid #fde68a;color:#d97706}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg);padding:var(--spacing-xl)}.loading-spinner{width:40px;height:40px;border:3px solid var(--bg-gray-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:var(--text-light);font-size:1rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg);text-align:center;max-width:500px;margin:0 auto;padding:var(--spacing-xl);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.error-icon{font-size:4rem;margin-bottom:var(--spacing-sm)}.error-container h2{color:var(--negative-color);margin:0;font-size:1.5rem}.error-container p{color:var(--text-light);line-height:1.6;margin:0;font-size:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-light);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.empty-state__icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{font-size:1.25rem;font-weight:600;margin:0 0 var(--spacing-sm) 0;color:var(--text-dark)}.empty-state p{color:var(--text-light);margin:0 0 var(--spacing-lg) 0;max-width:400px}.progress{width:100%;height:8px;background:var(--bg-gray-light);border-radius:4px;overflow:hidden;margin-bottom:var(--spacing-sm)}.progress__fill{height:100%;background:var(--gradient-success);transition:width var(--transition-slow);border-radius:4px}.progress__fill--primary{background:var(--gradient-primary)}.progress__fill--danger{background:var(--gradient-danger)}.progress__labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-light)}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.table thead{background:var(--gradient-blue)}.table th{color:#fff;padding:var(--spacing-md) 1.2rem;text-align:left;font-weight:700;font-size:.875rem;border:none;letter-spacing:.02em;text-transform:uppercase}.table tbody tr{transition:background var(--transition-fast);border-bottom:1px solid var(--border-light)}.table tbody tr:nth-child(2n){background:var(--bg-gray-light)}.table tbody tr:hover{background:#e0e7ef}.table tbody tr:last-child{border-bottom:none}.table td{padding:var(--spacing-md) 1.2rem;color:var(--text-color);font-size:.9rem}.table td.align-right{text-align:right}.table td.align-center{text-align:center}.table__cell--primary{font-weight:700;color:var(--positive-color)}.table__cell--currency{font-weight:700;color:var(--primary-color)}.table__cell--symbol{font-weight:700;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.grid{display:grid;gap:var(--spacing-lg)}.grid--cols-2{grid-template-columns:repeat(2,1fr)}.grid--cols-3{grid-template-columns:repeat(3,1fr)}.grid--cols-4{grid-template-columns:repeat(4,1fr)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--primary-color)}.text-success{color:var(--positive-color)}.text-danger{color:var(--negative-color)}.text-muted{color:var(--text-muted)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.flex-wrap{flex-wrap:wrap}.w-full{width:100%}.btn--icon{background:transparent;border:none;cursor:pointer;padding:.375rem;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--text-light);transition:all var(--transition-normal)}.btn--icon:hover{background:var(--bg-gray-light);color:var(--text-dark)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.01em}.badge--success{background:#10b9811f;color:#059669}.badge--danger{background:#ef44441f;color:#dc2626}.badge--info{background:#3b82f61f;color:#2563eb}.badge--neutral{background:var(--bg-gray-light);color:var(--text-muted)}.divider{border:none;border-top:1px solid var(--border-light);margin:var(--spacing-lg) 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin:0;letter-spacing:-.01em}.section-subtitle{font-size:.875rem;color:var(--text-light);margin:.25rem 0 0}@media(max-width:1024px){.grid--cols-4,.grid--cols-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-header{flex-direction:column;gap:.75rem;align-items:flex-start;padding:.75rem var(--spacing-md)}.page-header__title h1{font-size:1.5rem}.page-header__subtitle{font-size:.95rem}.page-header__date{text-align:left}.grid--cols-2,.grid--cols-3,.grid--cols-4{grid-template-columns:1fr}.summary-card{padding:var(--spacing-md)}.card{padding:1.25em;margin-left:.25rem;margin-right:.25rem}.btn{padding:.65rem 1.2rem;font-size:.95rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:600px}}@media(max-width:600px){.card{padding:1em;margin-left:.25rem;margin-right:.25rem}}@media(max-width:480px){.page-header{padding:.6rem .85rem;border-radius:.75rem}.page-header__title h1{font-size:1.35rem}.page-header__subtitle{font-size:.9rem}.page-header__date{font-size:.8rem}.summary-card{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.summary-card__icon{width:40px;height:40px;font-size:1.25rem}.summary-card__value{font-size:1.25rem}.card{padding:.85em;border-radius:12px;margin-left:.15rem;margin-right:.15rem}.btn{padding:.6rem 1rem;font-size:.9rem}.loading-container,.error-container{min-height:300px;padding:var(--spacing-lg)}}@media(max-width:414px){.page-header__title h1{font-size:1.25rem}.summary-card__value{font-size:1.125rem}}.app-layout{min-height:100vh;width:100vw;display:flex;background:linear-gradient(135deg,#eaf2f8,#d6eaf8);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;color:#17202a;position:relative}.sidebar-toggle{position:fixed;top:1rem;left:76px;z-index:1000;background:#fff;border:none;border-radius:.5rem;padding:.75rem;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);display:none;align-items:center;justify-content:center;color:#374151}.sidebar-toggle:hover{background:#f9fafb;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.sidebar-toggle:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.main-content{flex:1;padding:2em;box-sizing:border-box;min-height:100vh;background:#f8fafc;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-content--sidebar-open{margin-left:280px}.main-content--sidebar-closed{margin-left:64px}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:150;display:none}@media(max-width:768px){.app-layout{flex-direction:column}.sidebar-toggle{top:.5rem;left:.5rem;padding:.5rem;display:flex}.sidebar-overlay{display:block}.main-content--sidebar-open,.main-content--sidebar-closed{margin-left:0}.main-content{padding:1rem}}@media(max-width:600px){.main-content{padding:.5rem}}@media(max-width:480px){.main-content{padding:1em}}@media(prefers-color-scheme:dark){.sidebar-toggle{background:#111827;color:#f9fafb}.sidebar-toggle:hover{background:#1f2937}}.dashboard{max-width:1400px;margin:0 auto;padding:2rem 3rem;display:flex;flex-direction:column;gap:var(--spacing-10);width:100%;box-sizing:border-box}.dashboard-hero{position:relative;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:var(--spacing-9) var(--spacing-10);border-radius:1.5rem;background:linear-gradient(135deg,#0d1b2a,#1a3a5c 45%,#1e3a8a);color:#e2e8f0;box-shadow:0 20px 60px #0d1b2a66,0 1px #ffffff0d inset;overflow:hidden}.dashboard-hero:before{content:"";position:absolute;top:-60px;right:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.18) 0%,transparent 70%);pointer-events:none}.dashboard-hero:after{content:"";position:absolute;bottom:-80px;left:30%;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);pointer-events:none}.dashboard-hero__content{position:relative;z-index:1}.dashboard-hero__content h1{margin:0;font-size:2rem;font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1.15}.dashboard-hero__content p{margin:.4rem 0 1rem;color:#e2e8f0b3;font-size:.95rem;letter-spacing:.01em}.dashboard-hero__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem var(--spacing-5);font-size:.8rem;color:#e2e8f08c;text-transform:uppercase;letter-spacing:.05em}.dashboard__summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-5);margin-bottom:1rem;align-items:start}.summary-card{position:relative;padding:1rem;display:flex;flex-direction:row;align-items:flex-start;gap:var(--spacing-3);min-width:0;max-width:350px;background:#fff;text-align:left;border-radius:1rem;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a,0 4px 16px #0000000a;transition:box-shadow .25s ease,transform .25s ease;overflow:visible}.summary-card:hover{box-shadow:0 2px 8px #0000000d,0 8px 24px #00000014;transform:translateY(-3px)}.summary-card__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;font-size:1.15rem;background:#eff6ff;box-shadow:0 2px 8px #3b82f626}.dashboard__summary .summary-card:nth-child(1) .summary-card__icon{background:linear-gradient(135deg,#eff6ff,#dbeafe);box-shadow:0 3px 10px #3b82f633}.dashboard__summary .summary-card:nth-child(2) .summary-card__icon{background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 3px 10px #10b98133}.dashboard__summary .summary-card:nth-child(3) .summary-card__icon{background:linear-gradient(135deg,#fffbeb,#fef3c7);box-shadow:0 3px 10px #f59e0b33}.dashboard__summary .summary-card:nth-child(4) .summary-card__icon{background:linear-gradient(135deg,#f5f3ff,#ede9fe);box-shadow:0 3px 10px #8b5cf633}.summary-card__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.summary-card__content h3{font-size:.8rem;font-weight:500;margin:0 0 .35rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;line-height:1.3}.summary-card__value{font-size:1.25rem;font-weight:700;margin:0;color:#0f172a;letter-spacing:-.03em;line-height:1.1;white-space:nowrap}.summary-card__change{margin-top:.5rem;font-size:.78rem;font-weight:600;display:flex;flex-direction:column;gap:.2rem}.summary-card__change.positive{color:#059669}.summary-card__change.negative{color:#dc2626}.summary-card__change-detail{font-size:.72rem;font-weight:400;color:#94a3b8}.summary-card__label{font-size:.75rem;color:#94a3b8}.dashboard__common-section{background:transparent;border-radius:0;padding:0;border:none;box-shadow:none}.common-section-header{text-align:center;margin-bottom:2rem;position:relative}.common-section-header:after{content:"";display:block;width:48px;height:3px;background:linear-gradient(90deg,#3b82f6,#6366f1);border-radius:99px;margin:1rem auto 0}.common-section-title{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0 0 .35rem;letter-spacing:-.025em}.common-section-subtitle{font-size:.9rem;color:#94a3b8;margin:0;font-weight:400}.common-section-body{display:flex;flex-direction:column;gap:1.5rem}.common-summary{margin-bottom:0}.common-summary-card{background:#fff;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a,0 4px 16px #0000000a;transition:box-shadow .25s ease,transform .25s ease}.common-summary-card:hover{box-shadow:0 2px 8px #0000000d,0 8px 24px #00000014;transform:translateY(-3px)}.common-chart{background:#fff;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a,0 4px 16px #0000000a;border-radius:1.25rem;width:100%}.dashboard__person-section{background:transparent;border-radius:0;padding:0;border:none;box-shadow:none}.person-section-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:1.5rem;align-items:start}.person-section-grid.yann-grid,.person-section-grid.carolyn-grid{grid-template-columns:minmax(0,1fr)}.person-section-main{display:flex;flex-direction:column;gap:1.5rem}.person-section-side{display:flex;flex-direction:column;gap:var(--spacing-5)}.person-section-side .dashboard__charts-col{width:100%}.person-section-side .dashboard__chart{height:100%}.person-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:0;border-bottom:none}.person-section-title{font-size:1.35rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.02em}.person-section-controls{display:flex;align-items:center;gap:var(--spacing-3)}.person-section-indicator{display:flex;align-items:center;gap:.625rem;background:#fff;padding:.6rem 1.1rem;border-radius:2rem;border:1.5px solid #e2e8f0;box-shadow:0 1px 4px #0000000a}.person-section-content{animation:fadeIn .3s ease-in-out}.person-avatar{font-size:1.4rem}.person-name{font-weight:600;color:#0f172a;font-size:1rem}.section-collapse-btn,.collapse-btn,.input-toggle-btn{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.625rem;padding:.45rem 1.1rem;font-size:.82rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.4rem;letter-spacing:.01em}.section-collapse-btn:hover,.collapse-btn:hover,.input-toggle-btn:hover,.section-collapse-btn.collapsed,.collapse-btn.collapsed{background:#e2e8f0;color:#334155;border-color:#cbd5e1}.input-toggle-btn.active{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border-color:transparent;box-shadow:0 2px 8px #3b82f64d}.collapse-btn:hover{transform:translateY(-1px)}.save-settings-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.625rem;padding:.45rem 1.1rem;font-size:.82rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;margin-left:.5rem;box-shadow:0 2px 8px #10b98140;letter-spacing:.01em}.save-settings-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b98159}.save-settings-btn.saved{background:linear-gradient(135deg,#059669,#047857);animation:pulse .5s ease-in-out}.dashboard__accounts-grid-section{margin-bottom:.5rem}.accounts-controls{display:flex;align-items:center;gap:var(--spacing-3)}.accounts-section-title{font-size:1.05rem;font-weight:600;margin-bottom:.25rem;color:#0f172a;letter-spacing:-.01em}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem}.account-card{display:flex;align-items:center;gap:1rem;padding:var(--spacing-5);border-radius:1rem;background:#fff;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a;text-align:left;min-width:0;transition:box-shadow .25s ease,transform .25s ease}.account-card:hover{box-shadow:0 4px 12px #00000014,0 1px 4px #0000000a;transform:translateY(-2px)}.account-card__icon{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;box-shadow:0 3px 8px #00000026}.account-card__icon span{width:30px;height:30px;display:inline-block;border-radius:50%}.account-card__icon-text{font-size:.9rem;font-weight:700;text-transform:uppercase}.account-card__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.account-card__value{font-size:1.1rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.account-card__number{font-size:.78rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-card__percentage{font-size:.75rem;color:#059669;font-weight:600}.input-group{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.value-input,.growth-input{flex:1;min-width:0;padding:.5rem var(--spacing-3);border:1.5px solid #e2e8f0;border-radius:.5rem;font-size:.95rem;color:#0f172a;background:#fff;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.value-input:focus,.growth-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.input-currency{font-weight:600;color:#94a3b8;font-size:.82rem}.input-label{font-size:.82rem;color:#94a3b8}.dashboard__content{display:grid;grid-template-columns:1fr;gap:1.5rem}.dashboard__chart{padding:1.5rem;text-align:left;border-radius:1.25rem;background:#fff;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a,0 4px 16px #0000000a;display:flex;flex-direction:column;gap:1rem}.dashboard__charts-col{width:100%;box-sizing:border-box}.dashboard__divider{display:none}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-5)}.chart-header h2,.chart-header h3{font-size:1.05rem;font-weight:600;margin:0;color:#0f172a;letter-spacing:-.01em}.chart-controls{display:flex;gap:.35rem;background:#f1f5f9;padding:.25rem;border-radius:.625rem}.chart-control{padding:.35rem .875rem;border:none;background:transparent;color:#64748b;border-radius:.4rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.chart-control--active{background:#fff;color:#0f172a;box-shadow:0 1px 4px #00000014;font-weight:600}.chart-control:hover:not(.chart-control--active){color:#334155;background:#fff9}.chart-container{height:300px;width:100%}.add-account-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;padding:.6rem var(--spacing-5);border:none;border-radius:.625rem;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:0 2px 8px #3b82f64d}.add-account-btn:hover{background:linear-gradient(135deg,#2563eb,#4f46e5);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.edit-account-card .account-inputs{display:flex;gap:var(--spacing-3);margin-bottom:.5rem}.edit-account-card .account-number-input,.edit-account-card .account-type-input{flex:1;padding:.5rem var(--spacing-3);border:1.5px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;color:#0f172a;transition:border-color .15s ease}.edit-account-card .account-number-input:focus,.edit-account-card .account-type-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.edit-account-card .value-input-group{display:flex;align-items:center;gap:.5rem;flex:1}.edit-account-card .account-value-input{flex:1;padding:.5rem var(--spacing-3);border:1.5px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;color:#0f172a;transition:border-color .15s ease}.edit-account-card .account-value-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.edit-account-card .remove-account-btn{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:.5rem .8rem;border-radius:.5rem;cursor:pointer;font-size:1.1rem;transition:all .2s;align-self:flex-start}.edit-account-card .remove-account-btn:hover{background:#dc2626;color:#fff;border-color:#dc2626;transform:translateY(-1px)}.save-error-message{display:flex;align-items:center;gap:var(--spacing-3);background:#fef2f2;border:1px solid #fecaca;border-radius:.875rem;padding:1rem var(--spacing-5);margin-bottom:1rem;animation:slideDown .3s ease-out}.save-error-message .error-icon{font-size:1.4rem;flex-shrink:0}.save-error-message .error-text{color:#991b1b;font-weight:500;font-size:.9rem}.questrade-warning{margin:0}.warning-card{background:#fffbeb;border:1px solid #fcd34d;border-radius:1rem;box-shadow:0 1px 4px #0000000a}.warning-content{display:flex;align-items:center;gap:1rem;padding:1.1rem var(--spacing-5)}.warning-icon{font-size:1.75rem;flex-shrink:0}.warning-text{flex:1}.warning-text h3{margin:0 0 .35rem;color:#92400e;font-size:.95rem;font-weight:600}.warning-text p{margin:0;color:#b45309;font-size:.85rem;line-height:1.5}.connect-questrade-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:.625rem;padding:.6rem var(--spacing-5);cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px #10b98140}.connect-questrade-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b98159}.refresh-btn{background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#ffffff80;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#ffffff1f;color:#fff}.refresh-btn:disabled{opacity:.4;cursor:not-allowed}.spin-animation{animation:spin 1s linear infinite}.dashboard-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;padding:3rem 2rem;text-align:center;max-width:600px;margin:0 auto}.empty-state-illustration{position:relative;width:150px;height:150px;margin-bottom:2rem;display:flex;align-items:center;justify-content:center}.empty-state-icon{font-size:5rem;animation:float 3s ease-in-out infinite;position:relative;z-index:2}.empty-state-chart{position:absolute;bottom:0;left:50%;transform:translate(-50%);display:flex;align-items:flex-end;gap:8px;z-index:1}.chart-bar{width:20px;background:linear-gradient(180deg,#3b82f6,#60a5fa);border-radius:4px 4px 0 0;animation:growBar 2s ease-in-out infinite}.chart-bar.bar-1{height:30px;animation-delay:0s}.chart-bar.bar-2{height:45px;animation-delay:.2s}.chart-bar.bar-3{height:35px;animation-delay:.4s}.dashboard-empty-state h2{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0 0 1rem;letter-spacing:-.02em}.empty-state-description{font-size:1rem;color:#64748b;line-height:1.7;margin:0 0 2rem;max-width:500px}.empty-state-actions{display:flex;gap:1rem;margin-bottom:var(--spacing-10);flex-wrap:wrap;justify-content:center}.primary-action-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:.875rem;padding:.9rem 1.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.primary-action-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.secondary-action-btn{background:#fff;color:#374151;border:1.5px solid #e2e8f0;border-radius:.875rem;padding:.9rem 1.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.secondary-action-btn:hover{border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.empty-state-features{display:flex;flex-direction:column;gap:var(--spacing-3);width:100%;max-width:400px}.feature-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:#fff;border-radius:.875rem;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a;transition:all .2s ease}.feature-item:hover{border-color:#bfdbfe;background:#eff6ff;transform:translate(4px)}.feature-icon{font-size:1.35rem;flex-shrink:0}.feature-text{font-size:.9rem;color:#374151;font-weight:500;text-align:left}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes growBar{0%,to{transform:scaleY(1);opacity:.7}50%{transform:scaleY(1.2);opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.dashboard__summary{grid-template-columns:1fr 1fr;gap:1rem}.accounts-grid{grid-template-columns:1fr;gap:.875rem}.dashboard__content{grid-template-columns:1fr}.common-section-body,.person-section-grid{grid-template-columns:1fr;gap:1.5rem}}@media(max-width:768px){.dashboard{padding:var(--spacing-5) var(--spacing-3);gap:2rem}.dashboard-hero{flex-direction:column;align-items:flex-start;padding:1.5rem;gap:1rem}.dashboard-hero__content h1{font-size:1.6rem}.dashboard-hero__meta{flex-direction:column;gap:.25rem}.dashboard__common-section,.dashboard__person-section{padding:0;border-radius:0}.common-section-title{font-size:1.35rem}.common-section-subtitle{font-size:.85rem}.person-section-header{flex-direction:column;gap:1rem;align-items:flex-start}.dashboard__summary{grid-template-columns:1fr;gap:.875rem}.summary-card{padding:1.1rem}.common-section-actions{padding:1rem}.person-section-grid{gap:var(--spacing-5)}.dashboard__title h1{font-size:1.5rem}.chart-header{flex-direction:column;gap:var(--spacing-3);align-items:flex-start}.accounts-grid{grid-template-columns:1fr;gap:.875rem}.dashboard__chart{padding:var(--spacing-3)}.common-section-actions .add-history-btn{width:100%}.dashboard__charts-col{width:100%;min-width:0;max-width:100vw}.input-group{flex-direction:column;align-items:stretch;gap:.25rem}.value-input,.growth-input{width:100%;min-width:0;max-width:100%;box-sizing:border-box;font-size:.9rem;padding:.4rem .6rem}.input-currency,.input-label{align-self:flex-start;font-size:.8rem}.warning-content{flex-direction:column;text-align:center;gap:1rem}.warning-text{text-align:center}.connect-questrade-btn{width:100%;max-width:300px}.dashboard-empty-state{padding:2rem 1rem;min-height:400px}.dashboard-empty-state h2{font-size:1.4rem}.empty-state-description{font-size:.95rem}.empty-state-actions{flex-direction:column;width:100%}.primary-action-btn,.secondary-action-btn{width:100%;max-width:300px}.empty-state-illustration{width:120px;height:120px}.empty-state-icon{font-size:4rem}}@media(max-width:480px){.dashboard{padding:1rem .25rem}.summary-card{padding:.875rem;gap:var(--spacing-3)}.summary-card__icon{width:40px;height:40px}.summary-card__content h3{font-size:.75rem;margin-bottom:.3rem}.summary-card__value{font-size:1.35rem}.input-group{gap:.2rem}.value-input,.growth-input{font-size:.85rem;padding:.35rem .5rem}.input-currency,.input-label{font-size:.75rem}.dashboard__charts-col{width:100%;min-width:0;max-width:100vw;padding:0;margin:0}.dashboard__chart{padding:.625rem;margin:0;width:100%;min-width:0;max-width:100vw;box-sizing:border-box}.common-charts{padding:0;margin:0}.common-chart{padding:.625rem;margin:0;width:100%;min-width:0;max-width:100vw;box-sizing:border-box}.dashboard__common-section,.dashboard__person-section{padding:.5em}.common-section-header,.person-section-header{padding:0;margin-bottom:1rem}.common-section-title,.person-section-title{font-size:1.2rem;margin:0}.common-section-subtitle{font-size:.85rem;margin:.5rem 0 0}.dashboard__summary{gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.accounts-grid{gap:.625rem}.account-card{padding:.875rem}}.tab-switcher{display:inline-flex;align-items:center;gap:.35rem;background:#f1f5f9;border-radius:999px;padding:.25rem;border:1px solid #e2e8f0}.tab-switcher__btn{background:transparent;border:none;color:#475569;padding:.35rem 1rem;border-radius:999px;cursor:pointer;font-weight:600;font-size:.85rem;letter-spacing:.01em;transition:all .2s ease}.tab-switcher__btn--active{background:#fff;color:#0f172a;box-shadow:0 10px 30px #94a3b859}.dashboard-hero .tab-switcher{background:#0f172a59;border-color:#ffffff2e}.dashboard-hero .tab-switcher__btn{color:#e2e8f0d9}.dashboard-hero .tab-switcher__btn--active{background:#ffffff2e;color:#fff;box-shadow:0 10px 30px #0f172a66}.dashboard-hero.budget-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.85fr);gap:2.5rem;align-items:stretch;padding:2.75rem 3rem;background:linear-gradient(135deg,#0f172a,#1e3a8a 45%,#312e81);border:1px solid rgba(255,255,255,.08)}.budget-hero__content{display:flex;flex-direction:column;gap:1rem;position:relative;z-index:1}.budget-hero__eyebrow{text-transform:uppercase;font-size:.78rem;letter-spacing:.2em;color:#e2e8f0b3;margin:0}.budget-hero__title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.budget-hero__title-row h1{margin:0;font-size:2.25rem;letter-spacing:-.04em;color:#fff}.budget-hero__subtitle{margin:0;color:#e2e8f0cc;font-size:1rem}.budget-hero__controls{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-top:.25rem}.budget-hero__current-date{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0e6;padding:.4rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.15)}.budget-hero__meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.85rem;margin-top:.75rem}.budget-hero__meta-card{padding:.9rem 1rem;border-radius:1rem;background:#0f172a73;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff0d}.budget-hero__meta-card span{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0a6;margin-bottom:.2rem}.budget-hero__meta-card strong{font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:-.03em}.budget-hero__meta-card p{margin:.3rem 0 0;color:#e2e8f0b3;font-size:.85rem}.budget-hero .btn--icon{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:#f8fafc;border-radius:.85rem}.budget-hero .btn--icon:hover{background:#fff3;transform:translateY(-1px)}.budget-hero__panel{position:relative;z-index:1;background:#0f172a8c;border-radius:1.5rem;padding:1.75rem;border:1px solid rgba(255,255,255,.08);box-shadow:0 25px 60px #0f172a59,inset 0 1px #ffffff0d;display:flex;flex-direction:column;gap:1.35rem}.budget-hero__panel-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.85rem}.budget-hero__panel-stat{padding:1rem;border-radius:1rem;background:#0f172a66;border:1px solid rgba(255,255,255,.08)}.budget-hero__panel-stat span{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:#e2e8f0b3}.budget-hero__panel-stat strong{display:block;margin-top:.35rem;font-size:1.5rem;font-weight:700;color:#fff}.budget-hero__panel-stat--income strong{color:#34d399}.budget-hero__panel-stat--expense strong{color:#f87171}.budget-hero__panel-stat p{margin:.2rem 0 0;color:#e2e8f0a6;font-size:.85rem}.budget-hero__progress{display:flex;flex-direction:column;gap:.35rem}.budget-hero__progress-head{display:flex;align-items:center;justify-content:space-between;color:#e2e8f0bf;font-size:.9rem}.budget-hero__progress-head strong{font-size:1.2rem;letter-spacing:-.02em}.budget-hero__progress-track{width:100%;height:.45rem;border-radius:999px;background:#fff3;overflow:hidden}.budget-hero__progress-bar{height:100%;border-radius:inherit;background:#22c55e;transition:width .3s ease}.budget-hero__progress small{color:#e2e8f0b3;font-size:.75rem}.budget-actions-row{display:flex;flex-wrap:wrap;gap:.75rem}.budget-actions-row .btn{border-radius:.9rem;padding:.85rem 1.4rem;font-size:.95rem;box-shadow:0 15px 30px #0f172a40}.budget-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem;margin:2.5rem 0}.budget-summary-card{display:flex;align-items:flex-start;gap:1rem;padding:1.4rem 1.5rem;border-radius:1.25rem;background:#fff;border:1px solid #e2e8f0;box-shadow:0 15px 35px #0f172a14,0 1px #fffc;transition:transform .2s ease,box-shadow .2s ease}.budget-summary-card:hover{transform:translateY(-4px);box-shadow:0 20px 45px #0f172a1f,0 1px #ffffffe6}.budget-summary-card__icon{width:54px;height:54px;border-radius:1rem;display:inline-flex;align-items:center;justify-content:center;color:#0f172a;flex-shrink:0;box-shadow:inset 0 1px #fff9}.budget-summary-card__content{display:flex;flex-direction:column;gap:.35rem}.budget-summary-card__label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.budget-summary-card__value{font-size:1.85rem;font-weight:700;color:#0f172a;letter-spacing:-.03em}.budget-summary-card__sub{font-size:.9rem;color:#475569}.budget-ledger-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem}.budget-ledger-card{background:#fff;border:1px solid #e2e8f0;border-radius:1.25rem;padding:1.5rem;box-shadow:0 15px 35px #0f172a14,0 1px #fffc;display:flex;flex-direction:column;gap:1.25rem}.budget-ledger-card--income{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.budget-ledger-card--expense{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fecaca}.budget-ledger-card__head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.budget-ledger-card__eyebrow{margin:0;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:#94a3b8}.budget-ledger-card__total{font-size:1.4rem;font-weight:700;color:#0f172a;display:inline-flex;align-items:baseline;gap:.35rem}.budget-ledger-card__total small{font-size:.75rem;color:#94a3b8}.budget-ledger-card--income .budget-ledger-card__total{color:#15803d}.budget-ledger-card--expense .budget-ledger-card__total{color:#b91c1c}.budget-ledger-list{display:flex;flex-direction:column;gap:.65rem;max-height:360px;overflow-y:auto;padding-right:.25rem}.budget-ledger-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.budget-ledger-row__info{display:flex;align-items:center;gap:.65rem;min-width:0}.budget-ledger-row__icon{width:36px;height:36px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:.9rem;background:#f1f5f9;color:#0f172a}.budget-ledger-row__label{margin:0;font-size:.9rem;font-weight:600;color:#0f172a}.budget-ledger-row__hint{display:block;font-size:.75rem;color:#94a3b8}.budget-ledger-row__value{font-weight:600;color:#0f172a;white-space:nowrap}.budget-ledger-empty{font-size:.85rem;color:#94a3b8;margin:0}.budget-stat-sublabel{font-size:.85rem;color:#64748b;margin-top:.35rem}.budget-rule-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.budget-filter-bar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.budget-table-wrapper{overflow-x:auto}@media(max-width:1200px){.dashboard-hero.budget-hero{grid-template-columns:1fr;padding:2.25rem}.budget-hero__panel{width:100%}}@media(max-width:900px){.budget-summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(max-width:768px){.dashboard{padding:1.25rem!important}.dashboard-hero.budget-hero{padding:1.75rem;gap:1.5rem}.budget-hero__title-row h1{font-size:1.8rem}.budget-hero__meta-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.budget-actions-row{flex-direction:column}.budget-actions-row .btn{width:100%;justify-content:center}}@media(max-width:430px){.dashboard{padding:.75rem!important}.dashboard-hero.budget-hero{padding:1.25rem}.budget-hero__title-row{flex-direction:column;align-items:flex-start}.budget-summary-grid{grid-template-columns:repeat(2,1fr);gap:.85rem}.budget-summary-card{padding:1rem}.budget-actions-row{gap:.5rem}.budget-filter-bar{flex-direction:column;gap:.5rem!important}.budget-filter-bar input,.budget-filter-bar select{width:100%!important}.budget-table-wrapper{margin:0 -.75rem}.budget-table-wrapper table{font-size:.75rem!important}.budget-table-wrapper th,.budget-table-wrapper td{padding:.4rem .3rem!important}.budget-table-wrapper th:nth-child(3),.budget-table-wrapper td:nth-child(3){display:none}.abonnements-header{flex-direction:column!important;gap:.75rem!important;text-align:center!important}.abonnement-row{flex-direction:column!important;align-items:flex-start!important;gap:.5rem!important}.abonnement-row>div:last-child{width:100%;justify-content:space-between!important}.portrait-row{flex-direction:column!important;gap:.25rem!important}.card{padding:1rem!important}.card h2{font-size:1rem!important}.budget-rule-grid{grid-template-columns:1fr!important}.budget-modal-overlay>div{width:95vw!important;max-width:95vw!important;padding:1rem!important;max-height:90vh!important}}.budget-hero--streamlined{padding:2rem;border-radius:1rem;background:linear-gradient(135deg,#0f172ad9,#1e293be6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);margin-bottom:1.5rem}.budget-hero__top-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.budget-hero__top-row h1{margin:.25rem 0 0;font-size:1.75rem;font-weight:700;color:#f8fafc}.budget-hero__inline-metrics{display:flex;align-items:center;gap:1.5rem;margin-top:1.25rem;padding:1rem 1.25rem;background:#ffffff0d;border-radius:.75rem;border:1px solid rgba(255,255,255,.06)}.budget-hero__metric{display:flex;flex-direction:column;gap:.25rem}.budget-hero__metric-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#f8fafc99;font-weight:500}.budget-hero__metric-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums}.budget-hero__metric-divider{width:1px;height:2.5rem;background:#ffffff1f}.budget-action-bar{display:flex;justify-content:flex-end;gap:.75rem;margin-bottom:1.5rem}@media(max-width:640px){.budget-hero__inline-metrics{flex-direction:column;gap:.75rem}.budget-hero__metric-divider{width:100%;height:1px}.budget-action-bar{flex-direction:column}.budget-action-bar .btn{width:100%;justify-content:center}}.budget-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.budget-chart-title{margin:0;font-size:1.25rem;font-weight:700}.budget-chart-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.budget-chart-type-toggle,.budget-chart-tabs{display:flex;background:#f3f4f6;border-radius:.5rem;padding:.25rem}.budget-chart-type-btn,.budget-chart-tab{background:transparent;border:none;color:#6b7280;padding:.25rem .75rem;border-radius:.3rem;cursor:pointer;font-weight:400;font-size:.875rem;transition:all .15s ease}.budget-chart-type-btn--active{background:#fff;color:#1e293b;font-weight:600;box-shadow:0 1px 3px #0000001a}.budget-chart-tab--active{background:#fff;font-weight:600;box-shadow:0 1px 3px #0000001a}.budget-chart-tab--active.budget-chart-tab--expense{color:#ef4444}.budget-chart-tab--active.budget-chart-tab--income{color:#10b981}.budget-chart-tab--active.budget-chart-tab--combined{color:#3b82f6}@media(max-width:640px){.budget-chart-header{flex-direction:column;align-items:flex-start}.budget-chart-controls{width:100%;flex-direction:column}.budget-chart-type-toggle,.budget-chart-tabs{width:100%}.budget-chart-type-btn,.budget-chart-tab{flex:1;text-align:center}}.dettes-page{max-width:1200px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem;width:100%;box-sizing:border-box}.dettes-hero{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:2rem 2.5rem;border-radius:1.25rem;background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#e2e8f0;box-shadow:0 20px 40px #0f172a40}.dettes-hero__content h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;color:#fff;margin:0}.dettes-hero__content p{margin:.5rem 0 1.25rem;font-size:1.1rem;max-width:600px;color:#e2e8f0cc}.dettes-hero__meta{display:flex;gap:1rem;align-items:center}.meta-badge{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.35rem .8rem;border-radius:999px;font-size:.85rem;font-weight:500;color:#cbd5e1;border:1px solid rgba(255,255,255,.1)}.dettes-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;padding:.75rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:12px;height:12px;border-radius:50%;display:inline-block;border:1px solid rgba(0,0,0,.1)}.legend-name{font-size:.85rem;color:#374151}.summary-section{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1rem}.summary-card{padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:transform .2s ease,box-shadow .2s ease;min-width:0;overflow:hidden}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.summary-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:#3498db1f}.summary-card__content{flex:1;min-width:0;overflow:hidden}.summary-card__content h3{font-size:.875rem;font-weight:500;margin:0 0 .5rem;opacity:.9;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-card__value{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:700;margin:0 0 .25rem;color:var(--text-dark);word-break:break-word;overflow-wrap:break-word;line-height:1.2}.summary-card__change{font-size:.75rem;font-weight:500}.summary-card__change.positive{color:var(--positive-color)}.summary-card__label{font-size:.75rem;opacity:.7;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-content{display:flex;flex-direction:column;gap:2rem}.dette-card{padding:2rem}.summary-global-card{padding:2rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #e2e8f0}.summary-global-content h3{font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;color:#1e293b;text-align:center}.global-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.global-stat{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.stat-label{font-size:.875rem;color:#64748b;font-weight:500}.stat-value{font-size:1.1rem;font-weight:700;color:#1e293b}.stat-value.positive{color:var(--positive-color)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.card-actions{display:flex;align-items:center;gap:1rem}.card-title h2{font-size:1.5rem;font-weight:600;margin:0 0 .25rem;color:var(--text-dark)}.card-subtitle{font-size:.875rem;color:var(--text-light)}.title-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;margin-right:.5rem;border:2px solid transparent;background:#fff}.title-chips{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border-radius:9999px;font-size:.75rem;border:1px solid var(--border-color);background:#00000005;color:var(--text-color)}.chip-rate{background:#10b98114;border-color:#10b98140}.chip-payment{background:#00c9a714;border-color:#00c9a740}.status-badge{padding:.5rem 1rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge.active{background:#10b98126;color:#166534}.details-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.detail-label{font-size:.875rem;color:var(--text-light);font-weight:500}.detail-value{font-size:1rem;font-weight:600;color:var(--text-dark)}.detail-value.highlight,.detail-value.total{color:var(--negative-color);font-size:1.1rem}.detail-value.payment{color:var(--accent-color);font-size:1.1rem}.progress-section{margin-top:1rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-title{font-size:.875rem;font-weight:500;color:#374151}.progress-percentage{font-size:.875rem;font-weight:600;color:var(--positive-color)}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--gradient-success);transition:width .3s ease}.progress-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-light)}.edit-btn{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.edit-btn:hover{background:var(--secondary-color)}.edit-actions{display:flex;gap:.5rem}.save-btn{padding:.5rem 1rem;background:var(--positive-color);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover{filter:brightness(.95)}.cancel-btn{padding:.5rem 1rem;background:var(--negative-color);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.cancel-btn:hover{filter:brightness(.95)}.save-sim-btn{padding:.5rem .75rem;background:#f8fafc;color:var(--text-dark);border:1px solid #e5e7eb;border-radius:.5rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s}.save-sim-btn:hover{background:#eef2ff;border-color:#bfdbfe}.edit-input{width:120px;padding:.5rem;border:2px solid var(--primary-color);border-radius:.375rem;font-size:.875rem;font-weight:600;text-align:right;background:#fff}.edit-input:focus{outline:none;border-color:var(--secondary-color);box-shadow:0 0 0 3px #3b82f61f}.add-debt-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background .2s}.add-debt-btn:hover{background:var(--secondary-color)}.empty-card{padding:3rem 2rem;text-align:center}.empty-content{max-width:300px;margin:0 auto}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-content h3{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;color:var(--text-dark)}.empty-content p{color:var(--text-light);margin:0 0 1.5rem}@media(max-width:1024px){.summary-section,.details-grid{grid-template-columns:repeat(2,1fr)}.global-stats{grid-template-columns:1fr}}@media(max-width:768px){.dettes-page{padding:1em}.dettes-hero{flex-direction:column;align-items:flex-start;padding:1.25rem 1rem;gap:1rem}.dettes-hero__content h1{font-size:1.5rem}.summary-section{grid-template-columns:1fr}.dette-card{padding:1.5em}.global-stats{grid-template-columns:1fr}.summary-global-card{padding:1.5em}.card-header{flex-direction:column;gap:1em;align-items:flex-start}.card-actions{flex-direction:column;gap:.5rem;align-items:flex-start}.edit-actions{flex-direction:column;gap:.5rem}.edit-input{width:100%;text-align:left}.details-grid{grid-template-columns:1fr;gap:1em}.detail-item{flex-direction:column;align-items:flex-start;gap:.5rem;text-align:left}}@media(max-width:480px){.dettes-page{padding:.5rem}.summary-section{gap:.75rem;margin-bottom:.75rem}.summary-card{padding:.75rem;border-radius:12px}.summary-card h3{font-size:.9rem;margin-bottom:.25rem;font-weight:600}.dette-card{padding:.75rem;margin-bottom:.75rem;border-radius:12px}.card-header{gap:.5rem;margin-bottom:.75rem}.card-header h3{font-size:1rem;margin:0;line-height:1.2}.card-actions{gap:.5rem;align-items:stretch}.card-actions button{padding:.6rem .75rem;font-size:.8rem;width:100%;border-radius:8px}.edit-actions{gap:.5rem;margin-top:.75rem}.edit-actions button{padding:.6rem .75rem;font-size:.8rem;width:100%;border-radius:8px}.edit-input{font-size:.85rem;padding:.6rem;border-radius:8px;border:2px solid #e5e7eb}.edit-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.details-grid{gap:.5rem;margin-top:.75rem}.detail-item{gap:.5rem;padding:.6rem;background:#ffffff80;border-radius:8px}.progress-bar{height:6px;border-radius:3px;margin-bottom:.5rem}.progress-labels{font-size:.65rem;color:var(--text-light)}.global-stats{gap:.75rem;margin-top:.75rem}.summary-global-card{padding:.75rem;border-radius:12px}.empty-card{padding:1.5rem .75rem;text-align:center}.empty-content{max-width:100%}.empty-icon{font-size:2rem;margin-bottom:.75rem}.empty-content h3{font-size:1rem;margin-bottom:.5rem;font-weight:600}.empty-content p{font-size:.85rem;margin-bottom:1rem;color:var(--text-light)}.add-debt-btn{padding:.75rem 1rem;font-size:.85rem;width:100%;max-width:280px;border-radius:8px}.chart-section{margin-top:.75rem}.chart-section h3{font-size:1rem;margin-bottom:.75rem;font-weight:600}.chart-container{padding:0;margin:0;width:100%;min-width:0;max-width:100vw;box-sizing:border-box}.remboursement-buttons{gap:.5rem;margin-bottom:.75rem}.remboursement-buttons button{padding:.5rem .75rem;font-size:.8rem;border-radius:8px;min-height:40px}.remboursement-slider-section{padding:.75rem;border-radius:12px;margin-bottom:.75rem}.slider-value{font-size:1.1rem;font-weight:700;color:#059669}.slider-container{margin:.75rem 0}.remboursement-slider{width:100%;height:8px;border-radius:4px}}.heatmap-page{display:flex;flex-direction:column;gap:2rem;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;padding:2rem 3rem}.heatmap-hero{position:relative;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:2.25rem 2.5rem;border-radius:1.5rem;background:linear-gradient(135deg,#0d1b2a,#1a3a5c 45%,#1e3a8a);color:#e2e8f0;box-shadow:0 20px 60px #0d1b2a66,0 1px #ffffff0d inset;overflow:hidden}.heatmap-hero:before{content:"";position:absolute;top:-60px;right:-40px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%);pointer-events:none}.heatmap-hero:after{content:"";position:absolute;bottom:-80px;left:25%;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);pointer-events:none}.heatmap-hero__content{position:relative;z-index:1}.heatmap-hero__content h1{margin:0;font-size:2rem;font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1.15}.heatmap-hero__content p{margin:.4rem 0 0;color:#e2e8f0a6;font-size:.95rem;letter-spacing:.01em}.heatmap-tabs{display:flex;gap:.5rem;flex-wrap:wrap;background:#fff;padding:.375rem;border-radius:1rem;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a;width:fit-content}.heatmap-tab{padding:.45rem 1.1rem;border-radius:.625rem;border:none;background:transparent;color:#64748b;font-weight:500;font-size:.85rem;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.heatmap-tab:hover:not(.heatmap-tab--active){background:#f1f5f9;color:#334155}.heatmap-tab--active{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;font-weight:600;box-shadow:0 2px 8px #3b82f64d}.heatmap-container{border-radius:1.25rem!important;border:1px solid #e8edf3!important;box-shadow:0 1px 4px #0000000a,0 4px 16px #0000000a!important;padding:1.25rem!important;background:#fff!important}.heatmap-loading,.heatmap-error,.heatmap-empty{padding:3rem 2rem;text-align:center;font-size:1rem;color:#64748b;display:flex;flex-direction:column;align-items:center;gap:.75rem}.heatmap-error{color:#dc2626}.heatmap-container .loading,.heatmap-container .empty{padding:3rem 2rem;text-align:center;font-size:1rem;color:#64748b}.heatmap-container .error{padding:3rem 2rem;text-align:center;font-size:1rem;color:#dc2626}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b8;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:heatmap-fadeIn .2s ease-out}.modal-content{background:#1e293b;border:1px solid #334155;border-radius:1rem;width:90%;max-width:600px;color:#e2e8f0;box-shadow:0 25px 50px -12px #00000080;animation:heatmap-slideUp .3s cubic-bezier(.16,1,.3,1);max-height:90vh;overflow-y:auto}.modal-header{padding:1.5rem;border-bottom:1px solid #334155;display:flex;justify-content:space-between;align-items:flex-start;background:#1e293b;position:sticky;top:0;z-index:10}.modal-header h2{margin:0;font-size:1.5rem;color:#fff;letter-spacing:-.02em}.current-price{font-size:1.05rem;color:#94a3b8;font-weight:500;margin-top:.2rem;display:block}.close-btn{background:#ffffff14;border:none;color:#94a3b8;font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:.5rem;transition:all .2s;flex-shrink:0}.close-btn:hover{background:#ffffff26;color:#fff}.modal-body{padding:1.5rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.stat-card{background:#0f172a;padding:1rem;border-radius:.75rem;text-align:center;border:1px solid #1e293b}.stat-label{display:block;font-size:.78rem;color:#64748b;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.stat-pct{display:block;font-size:.8rem;font-weight:500;margin-top:.1rem;opacity:.85}.text-green-500{color:#4ade80}.text-red-500{color:#f87171}.text-slate-400{color:#94a3b8}.text-secondary{color:#94a3b8;font-size:.9em}.modal-body .divider{height:1px;background:#1e293b;margin:1.5rem 0}.details-grid{display:grid;gap:.75rem}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:.25rem 0}.detail-row span{color:#64748b}.detail-row strong{color:#e2e8f0;font-weight:600}.modal-body h3{font-size:.82rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;font-weight:600}.breakdown-container{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-top:1rem}@media(min-width:500px){.breakdown-container{grid-template-columns:150px 1fr;align-items:center}}.breakdown-chart{height:150px;width:100%;max-width:200px;margin:0 auto}.account-breakdown{display:flex;flex-direction:column;gap:.625rem}.breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:.625rem .875rem;background:#0f172a;border-radius:.625rem;border-left:3px solid #3b82f6}.breakdown-row:nth-child(1){border-color:#3b82f6}.breakdown-row:nth-child(2){border-color:#8b5cf6}.breakdown-row:nth-child(3){border-color:#10b981}.breakdown-row:nth-child(4){border-color:#f59e0b}.account-badge{color:#fff;font-weight:600;font-size:.9rem}.account-pct{font-size:.75rem;margin-top:.1rem;color:#64748b}.breakdown-stats{text-align:right;display:flex;flex-direction:column;gap:.1rem;font-size:.875rem;color:#94a3b8}@keyframes heatmap-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes heatmap-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.heatmap-page{padding:1.25rem .75rem;gap:1.5rem}.heatmap-hero{flex-direction:column;align-items:flex-start;padding:1.5rem}.heatmap-hero__content h1{font-size:1.6rem}.heatmap-tabs{width:100%;justify-content:flex-start}}@media(max-width:480px){.heatmap-page{padding:1rem .25rem}.modal-overlay{align-items:flex-end}.modal-content{width:100%;max-width:100%;border-radius:1rem 1rem 0 0;border-left:none;border-right:none;border-bottom:none;max-height:calc(92vh - env(safe-area-inset-top,0px));padding-bottom:env(safe-area-inset-bottom,0px);animation:heatmap-slideUpMobile .35s cubic-bezier(.16,1,.3,1)}.modal-header{padding:.75rem 1rem}.modal-header h2{font-size:1rem}.current-price{font-size:.85rem}.modal-body{padding:.75rem 1rem}.stats-grid{gap:.5rem;margin-bottom:.625rem}.stat-card{padding:.5rem}.stat-label{font-size:.72rem}.stat-value{font-size:.9rem}.stat-pct{font-size:.72rem}.modal-body .divider{margin:.625rem 0}.details-grid{gap:.375rem}.detail-row{font-size:.82rem}.modal-body h3{font-size:.75rem;margin:.5rem 0 .375rem}.breakdown-container{gap:.375rem;margin-top:.375rem}.breakdown-chart{display:none}.account-breakdown{gap:.375rem}.breakdown-row{padding:.375rem .5rem}.account-badge{font-size:.82rem}.heatmap-tabs{gap:.375rem}.heatmap-tab{padding:.375rem .875rem;font-size:.8rem}@keyframes heatmap-slideUpMobile{0%{transform:translateY(100%);opacity:1}to{transform:translateY(0);opacity:1}}}.tooltip-wrapper{position:relative;display:inline-flex;align-items:center;cursor:help}.tooltip-content{position:absolute;z-index:1000;background:#1f2937;color:#fff;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;line-height:1.4;max-width:250px;box-shadow:0 10px 25px #0003;animation:tooltipFadeIn .2s ease-out;pointer-events:none;white-space:normal}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid}.tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-top .tooltip-arrow{top:100%;left:50%;transform:translate(-50%);border-width:6px 6px 0 6px;border-color:#1f2937 transparent transparent transparent}.tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-bottom .tooltip-arrow{bottom:100%;left:50%;transform:translate(-50%);border-width:0 6px 6px 6px;border-color:transparent transparent #1f2937 transparent}.tooltip-left{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-left .tooltip-arrow{left:100%;top:50%;transform:translateY(-50%);border-width:6px 0 6px 6px;border-color:transparent transparent transparent #1f2937}.tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-right .tooltip-arrow{right:100%;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent #1f2937 transparent transparent}@media(max-width:768px){.tooltip-content{max-width:200px;font-size:.8rem;padding:.6rem .8rem}.tooltip-left,.tooltip-right{bottom:calc(100% + 8px);left:50%;right:auto;top:auto;transform:translate(-50%)}.tooltip-left .tooltip-arrow,.tooltip-right .tooltip-arrow{top:100%;left:50%;right:auto;bottom:auto;transform:translate(-50%);border-width:6px 6px 0 6px;border-color:#1f2937 transparent transparent transparent}}.dashboard__chart{padding:.8rem}.contrib-chart-header{display:flex;flex-direction:column;gap:.7rem;margin-bottom:.5rem}.contrib-chart-title{font-size:1.15rem;font-weight:600;margin:0;color:#111827}.contrib-sync-btn{background:none;border:1px solid #ddd;border-radius:4px;padding:.3rem .5rem;cursor:pointer;font-size:1rem}.contrib-sync-btn:hover:not(:disabled){background:#f0f0f0}.contrib-sync-btn:disabled{opacity:.5;cursor:not-allowed}.contrib-sync-status{font-size:.8rem;color:#666}.contrib-chart-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.contrib-date-filter-group{display:flex;align-items:center;gap:.5rem}.contrib-date-input{padding:4px;border-radius:4px;border:1px solid #e5e7eb;font-size:14px;min-width:110px}.contrib-date-sep{align-self:center;font-size:1.1em;color:#6b7280}.contrib-select{padding:6px;border-radius:6px;border:1px solid #e5e7eb;font-size:14px;min-width:120px}.contrib-chart-bar-container{height:260px;width:100%;display:flex;justify-content:center;align-items:center}@media(max-width:768px){.dashboard__chart{padding:.25rem .08rem}.contrib-chart-header{gap:.3rem;margin-bottom:.1rem}.contrib-chart-title{font-size:.98rem}.contrib-chart-filters{flex-direction:column;align-items:stretch;gap:.5rem}.contrib-date-filter-group{display:flex;width:100%;gap:.5rem}.contrib-date-input{flex:1;font-size:12.5px;min-width:0}.contrib-select{font-size:12.5px;width:100%}.contrib-chart-bar-container{height:300px}}@media(max-width:480px){.dashboard__chart{padding:1em .1rem!important}.contrib-chart-header{gap:.5rem;margin-bottom:.2rem}.contrib-chart-title{font-size:.9rem;line-height:1.2}.contrib-chart-filters,.contrib-date-filter-group{gap:.75rem}.contrib-date-input{font-size:12px;padding:.5rem;border-radius:4px}.contrib-select{font-size:12px;padding:.75rem;border-radius:6px}.contrib-chart-bar-container{height:280px;width:100%;min-width:0;max-width:100vw;box-sizing:border-box}}.accounts-page{max-width:100%;margin:0;padding:2rem 1rem;display:flex;flex-direction:column;gap:2rem}.accounts-hero{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.8rem 2rem;border-radius:1.25rem;background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#e2e8f0;box-shadow:0 30px 60px #0f172a59;margin-bottom:2rem}.accounts-hero__content{flex:1}.accounts-hero__content h1{margin:0;font-size:2.15rem;font-weight:700;letter-spacing:-.02em;color:#fff}.accounts-hero__content p{margin:.4rem 0 1rem;color:#e2e8f0d9;font-size:1.05rem}.accounts-hero__meta{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;font-size:.9rem;color:#e2e8f0bf;align-items:center}.btn-ibkr-connect{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.25rem .75rem;border-radius:.5rem;font-size:.8rem;cursor:pointer;transition:all .2s}.btn-ibkr-connect:hover{background:#fff3}.main-tabs{display:flex;gap:.75rem;margin-bottom:2rem;padding:.5rem;background:#fff;border-radius:1rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb}.main-tab{flex:1;padding:1rem 1.5rem;background:transparent;border:none;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem;color:#6b7280;position:relative}.main-tab:hover:not(.main-tab--active){background:#f9fafb;color:#374151;transform:translateY(-1px)}.main-tab--active{background:linear-gradient(135deg,#0f172a,#1e40af);color:#fff;box-shadow:0 4px 12px #0f172a40}.main-tab__icon{font-size:1.35rem;filter:grayscale(.3);transition:filter .25s ease}.main-tab--active .main-tab__icon{filter:grayscale(0)}.main-tab__text{font-size:.95rem;font-weight:600}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin-bottom:2rem}.account-card{background:#fff;border:2px solid #e5e7eb;border-radius:1rem;padding:1.25rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;gap:1rem}.account-card:hover:not(.account-card--active){border-color:#cbd5e1;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.account-card--active{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe);box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.account-card--dragging{opacity:.6;transform:rotate(3deg) scale(1.05);box-shadow:0 12px 24px #0003;z-index:1000;cursor:grabbing}.account-card:active:not(.account-card--dragging){transform:scale(.98)}.account-card__header{display:flex;align-items:center;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.account-card--active .account-card__header{border-bottom-color:#bfdbfe}.account-card__drag-handle{font-size:.85rem;color:#9ca3af;opacity:0;transition:opacity .2s ease;cursor:grab;line-height:1}.account-card:hover .account-card__drag-handle{opacity:1}.account-card__drag-handle:active{cursor:grabbing}.account-card__type{flex:1;font-size:1rem;font-weight:700;color:#111827;letter-spacing:-.01em}.account-card--active .account-card__type{color:#1e40af}.account-card__badge{padding:.25rem .75rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #3b82f64d}.account-card__body{display:flex;flex-direction:column;gap:.75rem}.account-card__balance{display:flex;flex-direction:column;gap:.35rem}.account-card__balance-label{font-size:.75rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.account-card__balance-value{font-size:1.65rem;font-weight:700;color:#059669;letter-spacing:-.02em}.account-card--active .account-card__balance-value{color:#047857}.account-card__number{font-size:.85rem;color:#9ca3af;font-family:SF Mono,Monaco,Consolas,monospace;font-weight:500;padding-top:.5rem;border-top:1px solid #f3f4f6}.account-card--active .account-card__number{color:#60a5fa;border-top-color:#bfdbfe}.accounts-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.accounts-content{display:grid;grid-template-columns:1fr;gap:2rem}.table-cell--description{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gain-positive{color:#059669!important;font-weight:600;background:#05966914;padding:.25rem .5rem;border-radius:.375rem}.gain-negative{color:#dc2626!important;font-weight:600;background:#dc262614;padding:.25rem .5rem;border-radius:.375rem}.gain-neutral{color:#6b7280;font-weight:500}.rate-error{text-align:center;padding:1rem;background:#ef44441a;color:#dc2626;border-radius:.5rem;font-size:.875rem}.local-dev-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;margin-bottom:1.5rem;border:1px solid #bfdbfe;border-radius:1rem;background:linear-gradient(135deg,#eff6ff,#f8fbff)}.local-dev-banner__icon{font-size:1.6rem;flex-shrink:0}.local-dev-banner__content{flex:1;min-width:0}.local-dev-banner__content h3{margin:0 0 .25rem;font-size:1rem;color:#1e3a8a}.local-dev-banner__content p{margin:0;font-size:.9rem;color:#475569;line-height:1.45}.local-dev-banner__action{border:none;border-radius:.65rem;background:#2563eb;color:#fff;padding:.7rem .95rem;font-size:.9rem;font-weight:700;cursor:pointer}.local-empty-card__hint{margin-top:.5rem;color:#64748b;font-size:.9rem}@media(max-width:1024px){.accounts-content{grid-template-columns:1fr}}@media(max-width:768px){.accounts-page{padding:1rem}.accounts-hero{flex-direction:column;align-items:flex-start;padding:1.6rem}.accounts-hero__content h1{font-size:1.7rem}.accounts-hero__meta{flex-direction:column;gap:.35rem}.main-tabs{flex-direction:column;gap:.5rem}.main-tab{padding:.875rem 1.25rem}.accounts-grid{grid-template-columns:1fr;gap:1rem}.account-card{padding:1rem}.account-card__balance-value{font-size:1.4rem}.accounts-data-table th,.accounts-data-table td{padding:.6rem;font-size:.8rem}.align-center{text-align:center!important;vertical-align:middle!important}.table-cell--description{max-width:120px}.local-dev-banner{flex-direction:column;align-items:flex-start}.household-overview,.household-overview__grid{grid-template-columns:1fr}.household-overview__lead-header{flex-direction:column}.household-overview__lead-badges{justify-content:flex-start}.person-section-header{align-items:stretch}.person-section-controls,.accounts-controls{width:100%;flex-wrap:wrap}.input-toggle-btn,.save-settings-btn,.collapse-btn,.add-account-btn{flex:1 1 140px;justify-content:center}.person-summary-grid,.person-accounts-grid{grid-template-columns:1fr}}.personnes-tab{display:flex;flex-direction:column;gap:2rem}.household-overview{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:1.25rem;align-items:stretch}.household-overview__lead{background:linear-gradient(135deg,#0f172a,#1d4ed8);border:none;color:#fff}.household-overview__lead .summary-card__content{gap:.75rem}.household-overview__lead-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.household-overview__eyebrow{margin:0 0 .35rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ffffffb8}.household-overview__lead h2{margin:0;font-size:1.65rem;line-height:1.1;color:#fff}.household-overview__lead-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.5rem}.household-overview__badge{display:inline-flex;align-items:center;padding:.4rem .7rem;border-radius:9999px;background:#ffffff24;color:#fff;font-size:.78rem;font-weight:700}.household-overview__badge--danger{background:#ef444433}.household-overview__lead-value{margin:0;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1;letter-spacing:-.03em}.household-overview__lead-caption{margin:0;max-width:44ch;font-size:.95rem;line-height:1.5;color:#ffffffd1}.household-overview__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}.household-stat-card{min-height:100%}.person-section{display:flex;flex-direction:column;gap:1.5rem}.person-divider{border:none;border-top:1px solid #e5e7eb;margin:0}.person-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.person-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.35rem;font-weight:700;color:#111827;margin:0}.person-section-controls{display:flex;gap:.5rem;align-items:center}.person-section-toggle{display:flex;align-items:center;gap:.6rem;background:none;border:none;cursor:pointer;padding:0;font-size:1.35rem;font-weight:700;color:#111827}.person-section-toggle:hover{color:#4f46e5}.person-section-toggle-icon{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:.375rem;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:1rem;flex-shrink:0;transition:all .2s}.person-section-toggle:hover .person-section-toggle-icon{background:#f3f4f6;color:#4f46e5;border-color:#c7d2fe}.person-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.person-accounts-section{display:flex;flex-direction:column;gap:1rem}.accounts-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.accounts-section-title{font-size:1rem;font-weight:600;color:#374151;margin:0}.accounts-controls{display:flex;gap:.5rem;align-items:center}.person-accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.person-account-card{display:flex;align-items:flex-start;gap:.9rem;padding:1rem 1.1rem}.person-account-card__icon{width:44px;height:44px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;font-weight:800;color:#fff;text-align:center;padding:.2rem}.person-account-card__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.45rem}.person-account-card__top,.person-account-card__bottom{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.person-account-card__title{min-width:0;font-size:.95rem;font-weight:700;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-account-card__value{font-size:1.05rem;font-weight:800;color:#059669;white-space:nowrap}.person-account-card__number{font-size:.8rem;color:#6b7280;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.person-account-card__pct{font-size:.78rem;color:#9ca3af;white-space:nowrap}.collapse-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1px solid #e5e7eb;border-radius:.5rem;background:#fff;font-size:.85rem;color:#374151;cursor:pointer;transition:all .2s}.collapse-btn:hover{background:#f3f4f6}.input-toggle-btn{padding:.4rem .75rem;border:1px solid #e5e7eb;border-radius:.5rem;background:#fff;font-size:.85rem;color:#374151;cursor:pointer;transition:all .2s}.input-toggle-btn.active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.save-settings-btn{padding:.4rem .75rem;border:none;border-radius:.5rem;background:#3b82f6;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.save-settings-btn.saved{background:#10b981}.save-error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem}.add-account-btn{padding:.4rem .75rem;border:1px dashed #d1d5db;border-radius:.5rem;background:#fff;font-size:.85rem;color:#374151;cursor:pointer;transition:all .2s}.add-account-btn:hover{background:#f9fafb;border-color:#9ca3af}.remove-account-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;border-radius:.25rem;transition:background .2s}.remove-account-btn:hover{background:#fee2e2}.input-group{display:flex;align-items:center;gap:.5rem;margin:.25rem 0}.value-input{width:100%;padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;font-weight:600;color:#111827}.toggle-field{display:flex;align-items:center;gap:.65rem;margin:.35rem 0;font-size:.95rem;font-weight:600;color:#111827}.toggle-field input{width:1rem;height:1rem;accent-color:#2563eb;cursor:pointer}.input-currency{font-size:.8rem;color:#6b7280;font-weight:500;white-space:nowrap}.account-inputs{display:flex;flex-direction:column;gap:.4rem;flex:1}.account-number-input,.account-type-input,.account-value-input{padding:.35rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.85rem;width:100%}.value-input-group{display:flex;align-items:center;gap:.4rem}.edit-account-card{flex-direction:column;align-items:stretch}@media(max-width:768px){.household-overview,.household-overview__grid{grid-template-columns:1fr}.household-overview__lead-header{flex-direction:column}.household-overview__lead-badges{justify-content:flex-start}.person-section-header{align-items:stretch}.person-section-controls,.accounts-controls{width:100%;flex-wrap:wrap}.input-toggle-btn,.save-settings-btn,.collapse-btn,.add-account-btn{flex:1 1 140px;justify-content:center}.person-summary-grid,.person-accounts-grid{grid-template-columns:1fr}}@media(max-width:430px){.household-overview__lead{padding:1.15rem}.household-overview__lead h2{font-size:1.35rem}.household-overview__lead-value{font-size:2rem}.person-section-toggle{font-size:1.1rem;align-items:flex-start}.person-account-card{padding:.9rem}.person-account-card__top,.person-account-card__bottom{flex-direction:column;align-items:flex-start;gap:.2rem}}.pret-remboursement-container{display:flex;flex-direction:column;gap:1.5rem}.controls-card{border-radius:.75rem;border:1px solid #e5e7eb;overflow:hidden}.controls-card .chart-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1.5rem;border-bottom:1px solid #e5e7eb}.controls-card .chart-header h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#111827;text-align:center}.controls-card .chart-header p{color:#6b7280;margin:0;font-size:1rem;text-align:center}.controls-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:.75rem;border:1px solid #e5e7eb}.controls-row{display:flex;align-items:flex-end;gap:2rem;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.control-group label{font-size:.875rem;font-weight:500;color:#374151}.repartition-mode-selector{display:flex;flex-direction:column;gap:.75rem;min-width:180px}.mode-label{font-size:.875rem;font-weight:500;color:#374151}.mode-buttons{display:flex;gap:.5rem}.mode-btn{padding:.5rem 1rem;border:2px solid #e5e7eb;background:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#3b82f6;background:#f0f9ff}.mode-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.repartition-manuelle-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:.75rem;padding:1.5rem;margin-top:1rem}.repartition-header h4{margin:0 0 .5rem;color:#92400e;font-size:1rem;font-weight:600}.repartition-header p{margin:0 0 1rem;color:#a16207;font-size:.875rem}.repartition-sliders{display:flex;flex-direction:column;gap:1.5rem}.repartition-item{background:#fff;border-radius:.5rem;padding:1rem;border:1px solid #f3f4f6}.repartition-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.pret-icon{font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#fff;border:1px solid #e5e7eb}.pret-color-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.1);display:inline-block;margin:0 .25rem}.pret-name{flex:1;font-weight:500;color:#374151}.pret-amount{font-weight:600;color:#059669;font-size:.875rem}.slider-container{position:relative}.proportion-slider{width:100%;height:8px;border-radius:4px;background:#e5e7eb;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.proportion-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--slider-color, #3b82f6);cursor:pointer;box-shadow:0 2px 4px #0003}.proportion-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--slider-color, #3b82f6);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.slider-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#6b7280}.current-proportion{color:#059669;font-weight:600}.repartition-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #fbbf24}.normalize-btn{padding:.5rem 1rem;background:#f59e0b;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.normalize-btn:hover{background:#d97706}.total-info{font-size:.875rem;color:#92400e}.total-info strong{color:#059669}.conversion-info{margin-top:.75rem;padding:.75rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:.5rem;border:1px solid #3b82f6;border-left:4px solid #3b82f6}.conversion-toggle{background:none;border:none;color:#3b82f6;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem .75rem;border-radius:.375rem;display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;transition:all .2s;border:1px solid transparent}.conversion-toggle:hover{background:#e0f2fe;border-color:#bfdbfe}.conversion-toggle:focus{outline:none;box-shadow:0 0 0 3px #3b82f633;border-color:#3b82f6}.toggle-icon{font-size:.75rem;transition:transform .2s;color:#6b7280}.conversion-info.expanded .toggle-icon{transform:rotate(180deg)}.conversion-content{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #bfdbfe}.conversion-empty{opacity:.7}.conversion-empty .conversion-text{color:#6b7280}.conversion-text{font-size:.875rem;color:#1e40af;display:flex;align-items:center;gap:.5rem}.conversion-text strong{color:#1d4ed8;font-weight:600}.repartition-info{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #bfdbfe}.repartition-title{font-size:.8rem;color:#1e40af;font-weight:600;display:block;margin-bottom:.5rem}.repartition-item{font-size:.8rem;color:#1e40af;margin-bottom:.25rem;display:block}.repartition-item strong{color:#1d4ed8;font-weight:600}.input-with-currency{position:relative;display:inline-block;width:fit-content}.amount-input{padding:.75rem 2rem .75rem 1rem;border:2px solid #d1d5db;border-radius:.5rem;font-size:1rem;font-weight:600;width:150px;text-align:right;transition:border-color .2s}.amount-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.currency-symbol{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#6b7280;font-weight:600;pointer-events:none}.preset-buttons{display:flex;gap:.5rem;flex-wrap:wrap;align-items:flex-end;min-width:300px}.preset-btn{padding:.5rem 1rem;border:2px solid #e5e7eb;background:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.preset-btn:hover{border-color:#3b82f6;background:#f0f9ff}.preset-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.economies-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.economie-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:.75rem;border:1px solid #10b981}.economie-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a}.economie-content{display:flex;flex-direction:column;gap:.25rem}.economie-label{font-size:.75rem;color:#065f46;font-weight:500}.economie-value{font-size:1.1rem;font-weight:700;color:#047857}.chart-container{height:600px;width:100%;margin-top:1rem;margin-bottom:2rem;padding-bottom:2rem}.chart-slider-section{margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:.75rem;border:1px solid #e5e7eb}.slider-header{margin-bottom:.75rem;text-align:center}.slider-header label{font-size:.875rem;font-weight:500;color:#374151;display:flex;align-items:center;gap:.5rem;justify-content:center}.slider-header strong{color:#059669;font-weight:600}.slider-container-large{position:relative;width:100%;height:10px;border-radius:5px;background:#e5e7eb;margin-top:.5rem}.remboursement-slider{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:5px;background:#3b82f6;cursor:pointer;box-shadow:0 2px 4px #0000001a}.remboursement-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:25px;height:25px;border-radius:50%;background:#3b82f6;cursor:pointer;box-shadow:0 2px 4px #0003}.remboursement-slider::-moz-range-thumb{width:25px;height:25px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.chart-card{margin-top:1rem;border-radius:.75rem;border:1px solid #e5e7eb;overflow:hidden}.chart-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.external-legend{display:flex;gap:1rem;flex-wrap:wrap;padding:.75rem 1.25rem 0;align-items:center}.external-legend .legend-item{display:inline-flex;align-items:center;gap:.5rem;background:#f9fafb;border:1px solid #e5e7eb;padding:.35rem .6rem;border-radius:9999px;cursor:pointer;transition:background .2s,opacity .2s,border-color .2s}.external-legend .legend-item:hover{background:#f3f4f6;border-color:#d1d5db}.external-legend .legend-item.hidden{opacity:.5;text-decoration:line-through}.external-legend .legend-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.external-legend .legend-text{font-size:.8rem;color:#374151}.chart-card-header h3{font-size:1.1rem;font-weight:600;color:#111827;margin:0}.collapse-btn{background:none;border:none;color:#3b82f6;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem .75rem;border-radius:.375rem;display:flex;align-items:center;gap:.5rem;transition:all .2s;border:1px solid transparent}.collapse-btn:hover{background:#e0f2fe;border-color:#bfdbfe}.collapse-btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f633;border-color:#3b82f6}.collapse-btn.collapsed{transform:rotate(180deg)}.chart-content{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:0 0 .75rem .75rem;min-height:500px;height:500px}@media(max-width:768px){.pret-remboursement-container{gap:1rem}.controls-card .chart-header,.controls-section{padding:1rem}.controls-row{flex-direction:column;gap:1rem;align-items:stretch}.control-group,.repartition-mode-selector,.preset-buttons{min-width:auto}.mode-buttons{flex-direction:column}.repartition-manuelle-section{padding:1rem}.repartition-item-header{flex-direction:column;align-items:flex-start;gap:.5rem}.repartition-actions{flex-direction:column;gap:1rem;align-items:stretch}.preset-buttons{justify-content:center}.economies-section{grid-template-columns:1fr}.chart-container{height:450px;padding-bottom:1rem}.chart-slider-section{padding:.75rem}.slider-header label{flex-direction:column;align-items:center;gap:.25rem}.slider-header strong{font-size:1rem}.slider-container-large,.remboursement-slider{height:8px}.remboursement-slider::-webkit-slider-thumb{width:20px;height:20px}.remboursement-slider::-moz-range-thumb{width:20px;height:20px}.chart-card{margin-top:1rem}.chart-card-header{padding:1rem 1.5rem}.chart-card-header h3{font-size:1.1rem}.collapse-btn{font-size:.875rem;padding:.5rem .75rem}.chart-content{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:450px;height:450px}.chart-content canvas{max-width:100%!important;height:auto!important}}@media(max-width:480px){.pret-remboursement-container{gap:.75rem}.controls-card .chart-header{padding:.75rem}.chart-header{padding:1em}.chart-header h3{font-size:1.1rem;margin-bottom:.5rem}.chart-header p{font-size:.85rem;line-height:1.3}.controls-section{padding:1em}.controls-row{gap:1em}.control-group label{font-size:.85rem}.control-group input{font-size:.85rem;padding:.75rem}.mode-buttons{gap:.75rem}.mode-button{padding:.75rem 1em;font-size:.9rem}.repartition-manuelle-section{padding:1em}.repartition-item{padding:1em;gap:.75rem}.repartition-item-header{gap:.75rem}.repartition-item-header h4{font-size:.9rem}.repartition-item-header p{font-size:.8rem}.repartition-input{font-size:.85rem;padding:.75rem}.economies-section{gap:1em;padding:1em}.economies-card{padding:1em}.economies-card h4{font-size:.9rem}.economies-card .value{font-size:1rem}.chart-container{height:400px;padding:1em}.chart-slider-section{padding:1em}.slider-header label{gap:.5rem}.slider-header strong{font-size:.9rem}.slider-header span{font-size:.8rem}.slider-container-large,.remboursement-slider{height:8px}.remboursement-slider::-webkit-slider-thumb{width:20px;height:20px}.remboursement-slider::-moz-range-thumb{width:20px;height:20px}.chart-card{margin-top:.75rem}.chart-card-header{padding:.75rem 1em}.chart-card-header h3{font-size:1rem}.collapse-btn{font-size:.8rem;padding:.4rem .6rem}.chart-content{padding:1em;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:350px;height:350px}.chart-content canvas{max-width:100%!important;height:100%!important;min-height:300px!important}}.pension-page-v2{display:flex;flex-direction:column;gap:2rem;max-width:1400px;margin:0 auto;width:100%;padding:2rem 3rem;box-sizing:border-box}.pension-hero{position:relative;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:2.25rem 2.5rem;border-radius:1.5rem;background:linear-gradient(135deg,#0d1b2a,#1a3a5c 45%,#1e3a8a);color:#e2e8f0;box-shadow:0 20px 60px #0d1b2a66,0 1px #ffffff0d inset;overflow:hidden}.pension-hero:before{content:"";position:absolute;top:-60px;right:-40px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%);pointer-events:none}.pension-hero:after{content:"";position:absolute;bottom:-80px;left:25%;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);pointer-events:none}.pension-hero__content{position:relative;z-index:1;flex:1}.pension-hero__badge{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:.875rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);font-size:1.4rem;margin-bottom:.75rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pension-hero__content h1{margin:0;font-size:2rem;font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1.15}.pension-hero__content p{margin:.4rem 0 0;color:#e2e8f0a6;font-size:.95rem;letter-spacing:.01em}.pension-hero__meta{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;font-size:.85rem;color:#e2e8f08c;margin-top:.75rem;align-items:center}.user-tabs{display:flex;gap:.5rem;flex-wrap:wrap;background:#fff;padding:.375rem;border-radius:1rem;border:1px solid #e8edf3;box-shadow:0 1px 4px #0000000a;width:fit-content;position:relative;z-index:1}.user-tab{padding:.45rem 1.25rem;border-radius:.625rem;border:none;background:transparent;color:#64748b;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.user-tab:hover:not(.active){background:#f1f5f9;color:#334155}.user-tab.active{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;font-weight:600;box-shadow:0 2px 8px #3b82f64d}@media(max-width:1024px){.pension-page-v2{padding:1.5rem 2rem}}@media(max-width:768px){.pension-page-v2{padding:1rem .75rem;gap:1.5rem}.pension-hero{flex-direction:column;align-items:flex-start;padding:1.6rem}.pension-hero__content h1{font-size:1.75rem}}@media(max-width:480px){.pension-page-v2{padding:.75rem .5rem;gap:1rem}.pension-hero{padding:1.25rem}.pension-hero__content h1{font-size:1.5rem}.user-tabs{width:100%;justify-content:stretch}.user-tab{flex:1;text-align:center}}
