:root{--color-primary: #1e40af;--color-primary-light: #3b82f6;--color-primary-dark: #1e3a8a;--color-success: #059669;--color-warning: #d97706;--color-danger: #dc2626;--color-bg: #f8fafc;--color-surface: #ffffff;--color-border: #e2e8f0;--color-text: #1e293b;--color-text-muted: #64748b;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--color-primary-dark);color:#fff;padding:1.5rem 0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100}.sidebar-brand{padding:0 1.5rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1rem}.sidebar-brand h1{font-size:1.25rem;font-weight:700}.sidebar-brand p{font-size:.75rem;opacity:.7;margin-top:.25rem}.sidebar-nav{list-style:none}.sidebar-nav a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#fffc;text-decoration:none;font-size:.9rem;transition:all .15s}.sidebar-nav a:hover,.sidebar-nav a.active{background:#ffffff1a;color:#fff}.sidebar-nav a.active{border-left:3px solid white;padding-left:calc(1.5rem - 3px)}.main-content{flex:1;margin-left:240px;padding:2rem;max-width:1200px}.page-header{margin-bottom:2rem}.page-header h2{font-size:1.5rem;font-weight:700;color:var(--color-text)}.page-header p{color:var(--color-text-muted);margin-top:.25rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.card-header{font-size:1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);text-decoration:none;color:inherit;transition:box-shadow .15s,transform .15s;display:flex;align-items:center;gap:1rem}.dashboard-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-card .icon-box{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-card .icon-box.blue{background:#dbeafe;color:var(--color-primary)}.dashboard-card .icon-box.green{background:#d1fae5;color:var(--color-success)}.dashboard-card .icon-box.amber{background:#fef3c7;color:var(--color-warning)}.dashboard-card .icon-box.red{background:#fee2e2;color:var(--color-danger)}.dashboard-card h3{font-size:.9rem;font-weight:600}.dashboard-card p{font-size:.8rem;color:var(--color-text-muted);margin-top:.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.375rem;color:var(--color-text)}.form-control{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.9rem;transition:border-color .15s;background:var(--color-surface);color:var(--color-text)}.form-control:focus{outline:none;border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f626}.form-control:read-only{background:#f1f5f9;color:var(--color-text-muted)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{padding:.625rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}th{font-weight:600;background:#f8fafc;white-space:nowrap}td input{width:100%;padding:.375rem .5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.85rem}td input:focus{outline:none;border-color:var(--color-primary-light)}td.numeric,th.numeric{text-align:right}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:#047857}.btn-danger{background:var(--color-danger);color:#fff}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover{background:#f1f5f9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-group{display:flex;gap:.75rem;margin-top:1.5rem}.stepper{display:flex;gap:0;margin-bottom:2rem;border-bottom:2px solid var(--color-border)}.stepper-step{flex:1;padding:.75rem 1rem;text-align:center;font-size:.85rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;position:relative;transition:all .15s}.stepper-step.active{color:var(--color-primary);border-bottom:2px solid var(--color-primary);margin-bottom:-2px}.stepper-step.completed{color:var(--color-success)}.stepper-step .step-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-border);color:var(--color-text-muted);font-size:.75rem;margin-right:.5rem}.stepper-step.active .step-number{background:var(--color-primary);color:#fff}.stepper-step.completed .step-number{background:var(--color-success);color:#fff}.callout{padding:1rem;border-radius:var(--radius);margin:1rem 0;font-size:.9rem}.callout-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.callout-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.callout-warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.callout-danger{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.callout strong{display:block;margin-bottom:.25rem}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.9rem}.summary-row.total{font-weight:700;border-top:2px solid var(--color-text);padding-top:.75rem;margin-top:.5rem}.summary-row .label{color:var(--color-text-muted)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:1rem}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:2rem;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:1.5rem}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.login-header p{color:var(--color-text-muted);font-size:.85rem;margin-top:.25rem}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-google:hover{background:#f1f5f9;box-shadow:var(--shadow)}.login-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0;color:var(--color-text-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-submit{width:100%;justify-content:center;margin-top:.5rem}.login-toggle{text-align:center;font-size:.85rem;color:var(--color-text-muted);margin-top:1.25rem}.link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:inherit;font-weight:600;text-decoration:underline}.link-btn:hover{color:var(--color-primary-dark)}.sidebar{display:flex;flex-direction:column}.sidebar-footer{margin-top:auto;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{margin-bottom:.75rem}.sidebar-user-email{display:block;font-size:.8rem;opacity:.9;word-break:break-all}.sidebar-user-role{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;opacity:.6;margin-top:.25rem}.sidebar-logout{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);color:#fffc;padding:.5rem .75rem;font-size:.8rem;cursor:pointer;transition:all .15s;width:100%;justify-content:center}.sidebar-logout:hover{background:#ffffff1a;color:#fff}.project-selector{width:100%;margin-top:.5rem;padding:.375rem .5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.75rem}.project-selector option{background:var(--color-primary-dark);color:#fff}@media(max-width:768px){.sidebar{width:100%;position:relative;padding:1rem 0}.main-content{margin-left:0;padding:1rem}.app-layout{flex-direction:column}.stepper{overflow-x:auto}.stepper-step{font-size:.75rem;padding:.5rem}}
