@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-main:#070913;--bg-surface:#0d1122b3;--bg-surface-hover:#161c36cc;--border-color:#ffffff14;--border-color-glow:#3b82f64d;--primary:#3b82f6;--primary-glow:#3b82f626;--secondary:#a855f7;--teal:#14b8a6;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#10b981;--success-glow:#10b9811a;--warning:#f59e0b;--error:#ef4444;--error-glow:#ef44441a;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-display:"Outfit", sans-serif;--font-mono:"JetBrains Mono", monospace;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 24px #0006;--shadow-lg:0 16px 40px #00000080;--glass-shadow:0 8px 32px 0 #0000005e;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);background-image:radial-gradient(circle at 10% 20%,#a855f714 0%,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f614 0%,#0000 40%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}button,input,textarea,select{color:inherit;font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);z-index:100;background:#070913cc;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.brand{align-items:center;gap:.75rem;display:flex}.brand-logo{object-fit:contain;width:80px;height:80px}.brand-name{font-family:var(--font-display);background:linear-gradient(135deg, var(--text-primary) 30%, var(--primary) 70%, var(--secondary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;font-size:1.5rem;font-weight:800}.user-profile{align-items:center;gap:1rem;display:flex}.user-email{color:var(--text-secondary);font-size:.875rem;font-weight:500}.auth-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--bg-surface);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--glass-shadow);text-align:center;flex-direction:column;align-items:center;padding:3rem 2.5rem;animation:.4s ease-out fadeIn;display:flex}.auth-logo{object-fit:contain;width:240px;height:240px;margin-bottom:1.5rem}.auth-title{font-family:var(--font-display);margin-bottom:.5rem;font-size:2rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.auth-form{text-align:left;width:100%}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition-fast);background:#0000004d;padding:.875rem 1rem;font-size:16px}.form-input:focus{border-color:var(--primary);background:#0006;outline:none;box-shadow:0 0 0 3px #3b82f626}input:-webkit-autofill{transition:background-color 5000s ease-in-out;-webkit-text-fill-color:var(--text-primary)!important;-webkit-box-shadow:inset 0 0 0 30px #1a1e30!important}input:-webkit-autofill:hover{transition:background-color 5000s ease-in-out;-webkit-text-fill-color:var(--text-primary)!important;-webkit-box-shadow:inset 0 0 0 30px #1a1e30!important}input:-webkit-autofill:focus{transition:background-color 5000s ease-in-out;-webkit-text-fill-color:var(--text-primary)!important;-webkit-box-shadow:inset 0 0 0 30px #1a1e30!important}input:-webkit-autofill:active{transition:background-color 5000s ease-in-out;-webkit-text-fill-color:var(--text-primary)!important;-webkit-box-shadow:inset 0 0 0 30px #1a1e30!important}.input-icon-wrapper{align-items:center;display:flex;position:relative}.input-icon-wrapper .icon{color:var(--text-secondary);pointer-events:none;font-weight:500;position:absolute;left:1rem}.input-icon-wrapper .form-input{padding-left:2rem}.auth-error{background:var(--error-glow);border:1px solid var(--error);color:#fca5a5;border-radius:var(--radius-sm);width:100%;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.4}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-normal);border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff;box-shadow:0 4px 12px #a855f733}.btn-primary:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 6px 20px #a855f759}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-primary);background:#ffffff0d}.btn-secondary:hover{border-color:var(--text-secondary);background:#ffffff1a}.btn-danger{background:var(--error-glow);border:1px solid var(--error);color:#fca5a5}.btn-danger:hover{background:var(--error);color:#fff}.auth-toggle{color:var(--text-secondary);margin-top:1.5rem;font-size:.9rem}.auth-toggle-link{color:var(--primary);cursor:pointer;font-weight:600;text-decoration:none}.auth-toggle-link:hover{text-decoration:underline}.dashboard-main{flex:1;grid-template-columns:1fr 400px;gap:2rem;width:100%;max-width:1400px;margin:0 auto;padding:2rem;display:grid}@media (width<=1024px){.dashboard-main{grid-template-columns:1fr}}.dashboard-content,.dashboard-sidebar{flex-direction:column;gap:2rem;display:flex}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;display:grid}.metric-card{background:var(--bg-surface);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition-normal);flex-direction:column;gap:.5rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.metric-card:hover{border-color:var(--border-color-glow);box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-card:before{content:"";background:var(--accent-gradient,var(--primary));width:4px;height:100%;position:absolute;top:0;left:0}.metric-card.total:before{--accent-gradient:linear-gradient(to bottom, var(--primary), var(--secondary))}.metric-card.cash:before{--accent-gradient:var(--success)}.metric-card.owed:before{--accent-gradient:var(--warning)}.metric-card.paychecks:before{--accent-gradient:var(--teal)}.metric-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.85rem;font-weight:600}.metric-value{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.metric-sub{color:var(--text-muted);font-size:.8rem}.calendar-wrapper{background:var(--bg-surface);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.calendar-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.calendar-nav{gap:.5rem;display:flex}.btn-icon{border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;transition:var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;display:flex}.btn-icon:hover{border-color:var(--text-secondary);background:#ffffff1a}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.calendar-weekday{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding-bottom:1rem;font-size:.8rem;font-weight:700}.calendar-day{aspect-ratio:1;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast);background:#ffffff05;flex-direction:column;justify-content:space-between;min-height:80px;padding:.5rem;display:flex;position:relative}.calendar-day:hover{background:var(--bg-surface-hover);border-color:var(--border-color-glow);z-index:2;transform:scale(1.02)}.calendar-day.empty{visibility:hidden;pointer-events:none}.calendar-day.today{border-color:var(--primary);background:#3b82f60d}.day-number{color:var(--text-secondary);font-size:.9rem;font-weight:600}.calendar-day.today .day-number{color:var(--primary)}.day-data{flex-direction:column;align-items:flex-end;gap:.2rem;width:100%;display:flex}.day-tip-badge{background:var(--success-glow);color:var(--success);border:1px solid #10b98133;border-radius:4px;padding:.1rem .4rem;font-size:.75rem;font-weight:700}.day-owed-indicator{background:var(--warning);border-radius:var(--radius-full);width:6px;height:6px;box-shadow:0 0 6px var(--warning);position:absolute;top:8px;right:8px}.day-sales{color:var(--text-muted);font-size:.65rem;font-family:var(--font-mono)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:1.5rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.25s cubic-bezier(.34,1.56,.64,1) scaleUp;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700}.modal-body{flex:1;padding:2rem;overflow-y:auto}.modal-content form{flex-direction:column;flex:1;display:flex;overflow:hidden}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;display:flex}.panel-card{background:var(--bg-surface);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.panel-title{font-family:var(--font-display);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.panel-list{flex-direction:column;gap:.75rem;max-height:350px;padding-right:.5rem;display:flex;overflow-y:auto}.panel-item{border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:var(--transition-fast);background:#ffffff05;justify-content:space-between;align-items:center;padding:1rem;display:flex}.panel-item:hover{border-color:var(--border-color-glow);background:#ffffff0d}.item-info{flex-direction:column;gap:.25rem;display:flex}.item-title{font-size:.95rem;font-weight:600}.item-sub{color:var(--text-secondary);font-size:.8rem}.item-value{text-align:right;font-size:1.1rem;font-weight:700}.item-extra{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}.analytics-grid{grid-template-columns:1fr;gap:2rem;display:grid}.weekly-table{border-collapse:collapse;width:100%;margin-top:1rem}.weekly-table th,.weekly-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.9rem}.weekly-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.weekly-table tr:hover td{background:#ffffff05}.weekly-table td.numeric{font-family:var(--font-mono);text-align:right}.weekly-table th.numeric{text-align:right}.badge-percent{font-family:var(--font-mono);border-radius:4px;padding:.2rem .5rem;font-size:.8rem;font-weight:700}.badge-percent.good{color:var(--success);background:#10b9811a}.badge-percent.average{color:var(--warning);background:#f59e0b1a}.badge-percent.low{color:var(--error);background:#ef44441a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.loading-spinner{border:3px solid #ffffff1a;border-left-color:var(--primary);border-radius:50%;width:40px;height:40px;margin:2rem auto;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.view-tabs{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0003;margin-bottom:1.5rem;padding:4px;display:flex}.view-tab{cursor:pointer;color:var(--text-secondary);transition:var(--transition-fast);background:0 0;border:none;border-radius:4px;flex:1;padding:.5rem 1rem;font-size:.9rem;font-weight:500}.view-tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.view-tab:not(.active):hover{color:var(--text-primary);background:#ffffff05}.tip-detail-row{color:var(--text-secondary);justify-content:space-between;margin-top:.25rem;font-size:.85rem;display:flex}.note-tooltip{color:var(--text-muted);word-break:break-word;max-width:100%;margin-top:.5rem;font-size:.8rem;font-style:italic}@media (width<=600px){.dashboard-main{gap:1.25rem;padding:1rem}.app-header{padding:.75rem 1rem}.brand-name{font-size:1.25rem}.user-profile{gap:.5rem}.user-email{display:none}.metrics-grid{grid-template-columns:1fr 1fr;gap:.75rem}.metric-card{border-radius:var(--radius-sm);padding:1rem}.metric-value{font-size:1.2rem}.metric-label{font-size:.75rem}.calendar-wrapper{border-radius:var(--radius-md);padding:1rem}.calendar-header{margin-bottom:1.25rem}.calendar-title{font-size:1.25rem}.calendar-grid{gap:2px}.calendar-weekday{padding-bottom:.5rem;font-size:.7rem}.calendar-day{min-height:60px;padding:4px}.day-number{font-size:.75rem}.day-tip-badge{border-radius:2px;padding:.5px 2px;font-size:.6rem}.day-sales{font-size:.5rem}.day-owed-indicator{width:4px;height:4px;top:4px;right:4px}.panel-card{padding:1.25rem 1rem}.weekly-table th,.weekly-table td{padding:.5rem .25rem;font-size:.75rem}.weekly-table th{font-size:.65rem}.badge-percent{padding:.1rem .3rem;font-size:.7rem}.modal-overlay{padding:.75rem}.modal-content{border-radius:var(--radius-md)}.modal-body{padding:1.25rem}.modal-header,.modal-footer{padding:1rem 1.25rem}.auth-card{padding:2rem 1.25rem}}@media (width<=360px){.metrics-grid{grid-template-columns:1fr}}
