@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.175, .885, .32, 1.275)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;min-height:100vh;line-height:1.6}#root{width:100%;min-height:100vh}::selection{color:inherit;background:#6366f14d}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}a{color:var(--accent-primary);transition:var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-primary-hover)}img{max-width:100%;height:auto}:root{--bg-main:#0a0c10;--bg-sidebar:#0d1117;--bg-card:#161b22;--bg-card-hover:#1c2128;--bg-overlay:#000000bf;--border-color:#ffffff14;--border-color-hover:#ffffff26;--border-color-focus:#6366f180;--text-primary:#f0f6fc;--text-secondary:#8b949e;--text-muted:#6e7681;--accent-primary:#6366f1;--accent-primary-hover:#4f46e5;--accent-primary-subtle:#6366f11a;--accent-secondary:#a855f7;--accent-secondary-subtle:#a855f71a;--success:#238636;--success-text:#3fb950;--success-bg:#23863626;--error:#da3633;--error-text:#f85149;--error-bg:#da363326;--warning:#d29922;--warning-text:#e3b341;--warning-bg:#d2992226;--info:#58a6ff;--info-bg:#58a6ff26;--sidebar-width:260px;--sidebar-width-collapsed:72px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #0006, 0 8px 10px -6px #0000004d;--shadow-glow:0 0 20px #6366f14d;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);overflow-x:hidden}.auth-layout{min-height:100vh;padding:var(--space-6);background:radial-gradient(ellipse at 0% 0%, #6366f11f 0%, transparent 50%), radial-gradient(ellipse at 100% 100%, #a855f714 0%, transparent 50%), var(--bg-main);justify-content:center;align-items:center;display:flex}.dashboard-layout{width:100%;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);padding:var(--space-6) var(--space-4);z-index:100;height:100vh;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-brand{align-items:center;gap:var(--space-3);padding:0 var(--space-3);margin-bottom:var(--space-8);display:flex}.sidebar-brand-icon{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));border-radius:var(--radius-md);width:36px;height:36px;font-weight:700;font-size:var(--text-lg);justify-content:center;align-items:center;display:flex}.sidebar-brand-text{font-size:var(--text-lg);background:linear-gradient(135deg, #fff 0%, var(--accent-primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.nav-group{gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.nav-section{margin-bottom:var(--space-4)}.nav-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);font-weight:500;font-size:var(--text-sm);border:1px solid #0000;display:flex;position:relative;overflow:hidden}.nav-item:before{content:"";background:var(--accent-primary);opacity:0;width:3px;transition:var(--transition-fast);position:absolute;top:0;bottom:0;left:0}.nav-item:hover{color:var(--text-primary);background:#ffffff08}.nav-item:hover:before{opacity:.5}.nav-item.active{background:var(--accent-primary-subtle);color:var(--accent-primary);border-color:#6366f133}.nav-item.active:before{opacity:1}.nav-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-item-text{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-footer{padding-top:var(--space-6);border-top:1px solid var(--border-color);margin-top:auto}.invitations-btn{position:relative}.invitation-badge{background:var(--error);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:8px;padding:0 5px;font-size:.7rem;font-weight:600;display:inline-flex}.invitations-list{gap:var(--space-3);flex-direction:column;display:flex}.invitation-item{padding:var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);justify-content:space-between;align-items:center;display:flex}.invitation-info{flex:1}.invitation-actions{gap:var(--space-2);display:flex}.main-content{margin-left:var(--sidebar-width);padding:var(--space-8) var(--space-10);flex:1;min-height:100vh}.container{width:100%;max-width:1400px;margin:0 auto}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.container-fluid{max-width:none}.section{margin-bottom:var(--space-8)}.section-header{margin-bottom:var(--space-6)}.section-title{font-size:var(--text-xl);margin-bottom:var(--space-1);font-weight:600}.section-subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.section-actions{align-items:center;gap:var(--space-3);margin-top:var(--space-4);display:flex}.view-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-6);display:flex}.view-title h1{font-size:var(--text-3xl);letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700}.view-title p{color:var(--text-secondary);font-size:var(--text-sm)}.user-badge{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex}.user-badge-info{text-align:right}.user-badge-name{font-weight:600;font-size:var(--text-sm)}.user-badge-roles{font-size:var(--text-xs);color:var(--text-muted)}.user-badge-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:40px;height:40px;font-weight:600;font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);transition:var(--transition-base)}.card:hover{border-color:var(--border-color-hover)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.card-body{color:var(--text-secondary)}.card-footer{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-color);align-items:center;gap:var(--space-3);display:flex}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-gradient{background:linear-gradient(135deg, var(--bg-card) 0%, #6366f10d 100%)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-family:inherit;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-primary:hover:not(:disabled){background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{color:var(--text-primary);border-color:var(--border-color);background:0 0}.btn-secondary:hover:not(:disabled){border-color:var(--border-color-hover);background:#ffffff08}.btn-danger{background:var(--error);color:#fff;border-color:var(--error)}.btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #da363359}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#1d6f32}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.btn-block{width:100%}.btn-loading{pointer-events:none;position:relative;color:#0000!important}.btn-loading:after{content:"";border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;margin:-8px 0 0 -8px;animation:.6s linear infinite spin;position:absolute;top:50%;left:50%}.form-group{margin-bottom:var(--space-5)}.form-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:500;display:block}.form-input{background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;padding:var(--space-3) var(--space-4);color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition-fast);font-family:inherit}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-subtle);outline:none}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-input-error{border-color:var(--error)}.form-input-error:focus{box-shadow:0 0 0 3px var(--error-bg)}.form-error{font-size:var(--text-xs);color:var(--error-text);margin-top:var(--space-1)}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.form-row{gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-actions{gap:var(--space-3);margin-top:var(--space-6);display:flex}.form-check{align-items:center;gap:var(--space-2);cursor:pointer;display:flex}.form-check-input{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.form-check-label{font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238b949e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10)}.table-container{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{padding:var(--space-4);text-align:left;font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap;background:#ffffff05}.table td{padding:var(--space-4);border-bottom:1px solid var(--border-color);vertical-align:middle}.table tbody tr{transition:var(--transition-fast)}.table tbody tr:hover{background:#ffffff05}.table tbody tr:last-child td{border-bottom:none}.table-actions{gap:var(--space-2);align-items:center;display:flex}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-flex}.badge-primary{background:var(--accent-primary-subtle);color:var(--accent-primary)}.badge-secondary{background:var(--accent-secondary-subtle);color:var(--accent-secondary)}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-error{background:var(--error-bg);color:var(--error-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{color:var(--text-secondary);background:#ffffff14}.toast-container{top:var(--space-6);right:var(--space-6);gap:var(--space-3);z-index:10000;pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);box-shadow:var(--shadow-xl);align-items:center;gap:var(--space-3);pointer-events:auto;max-width:400px;animation:slideInRight var(--transition-spring) forwards;display:flex}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-message{font-size:var(--text-sm);flex:1}.toast-success{border-color:var(--success)}.toast-success .toast-icon{color:var(--success-text)}.toast-error{border-color:var(--error)}.toast-error .toast-icon{color:var(--error-text)}.toast-warning{border-color:var(--warning)}.toast-warning .toast-icon{color:var(--warning-text)}.toast-info{border-color:var(--info)}.toast-info .toast-icon{color:var(--info)}.modal-overlay{background:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:var(--space-6);animation:fadeIn var(--transition-fast);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;animation:scaleIn var(--transition-spring);overflow:hidden}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);font-weight:600}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff0d}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-color);display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideInTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn var(--transition-slow) ease-out}.slide-in{animation:slideInTop var(--transition-spring)}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, #ffffff0d 50%, var(--bg-card) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.empty-state{padding:var(--space-12);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--space-4);color:var(--text-muted);opacity:.5}.empty-state-title{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:600}.empty-state-description{color:var(--text-muted);font-size:var(--text-sm);max-width:300px;margin-bottom:var(--space-6)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success-text)}.text-error{color:var(--error-text)}.text-warning{color:var(--warning-text)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.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)}.w-full{width:100%}.h-full{height:100%}.hidden{display:none}@media (width<=1200px){.main-content{padding:var(--space-6) var(--space-8)}}@media (width<=768px){.sidebar{width:var(--sidebar-width);padding:var(--space-4)}.sidebar-brand-text,.nav-item-text,.nav-section-title{display:none}.sidebar.sidebar-open .sidebar-brand-text,.sidebar.sidebar-open .nav-item-text,.sidebar.sidebar-open .nav-section-title,.sidebar.sidebar-open .invitation-badge{display:inline-flex}.invitation-badge{display:none}.sidebar-brand{padding:0 var(--space-3);margin-bottom:var(--space-6);justify-content:flex-start}.nav-item{padding:var(--space-3);justify-content:flex-start}.nav-item:before{display:block}.main-content{padding:var(--space-4);padding-top:calc(var(--space-4) + 48px);margin-left:0}.user-badge-info{display:none}.view-header{gap:var(--space-4);flex-direction:column}}.expense-container{gap:var(--space-6);grid-template-columns:280px 1fr;min-height:calc(100vh - 200px);display:grid}.expense-sidebar{border-right:1px solid var(--border-color);padding-right:var(--space-6)}.expense-content{min-width:0}.log-list{gap:var(--space-2);flex-direction:column;display:flex}.log-item{padding:var(--space-3) var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.log-item:hover{border-color:var(--accent-primary);background:var(--bg-card-hover)}.log-item.active{background:var(--accent-primary-subtle);border-color:var(--accent-primary)}@media (width<=992px){.expense-container{grid-template-columns:1fr}.expense-sidebar{border-right:none;border-bottom:1px solid var(--border-color);padding-right:0;padding-bottom:var(--space-6)}}@media (width<=768px){.main-content{padding:var(--space-4);padding-top:calc(var(--space-4) + 48px);margin-left:0;position:relative}.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{background:var(--bg-overlay);z-index:99;position:fixed;inset:0}.hamburger-btn{top:var(--space-4);left:var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;z-index:98;width:40px;height:40px;transition:var(--transition-fast);justify-content:center;align-items:center;display:flex;position:fixed}.hamburger-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-primary)}.hamburger-icon{flex-direction:column;gap:4px;width:18px;display:flex}.hamburger-icon span{background:var(--text-secondary);width:100%;height:2px;transition:var(--transition-fast);border-radius:1px;display:block}.hamburger-icon.open span:first-child{transform:rotate(45deg)translate(4px,4px)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:rotate(-45deg)translate(4px,-4px)}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@media (width>=769px){.hamburger-btn,.sidebar-overlay{display:none}}
