@import"https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@500&family=Inter:wght@400;600;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@500;700&family=Inter:wght@400;600;800&display=swap";.sidebar{width:260px;background:#0f172a;color:#f8fafc;height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid #1e293b;z-index:100;padding:0;overflow:hidden}.sidebar-top-section{display:flex;flex-direction:column;flex:1;overflow-y:auto;min-height:0}.sidebar-top-section::-webkit-scrollbar{width:6px}.sidebar-top-section::-webkit-scrollbar-track{background:#0f172a}.sidebar-top-section::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.sidebar-top-section::-webkit-scrollbar-thumb:hover{background:#475569}.sidebar-brand{padding:24px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0;background:transparent;border:none;cursor:pointer;width:100%;text-align:left;transition:all .2s;border-radius:8px;margin-bottom:8px}.sidebar-brand:hover{background:#2563eb1a}.sidebar-brand:active{background:#2563eb26}.brand-logo{width:40px;height:40px;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;border-radius:10px;box-shadow:0 4px 12px #2563eb33;flex-shrink:0}.brand-info h1{margin:0 0 4px;font-size:20px;font-weight:800;letter-spacing:-.5px;line-height:1.2;color:#fff}.brand-info p{margin:0;font-size:10px;text-transform:uppercase;color:#94a3b8;font-weight:700;letter-spacing:1px;line-height:1.3}.sidebar-nav{padding:0 16px;flex:1;min-height:0}.nav-section{margin-bottom:20px}.nav-divider{margin:0 12px 12px;font-size:10px;text-transform:uppercase;color:#475569;letter-spacing:1.5px;font-weight:800}.nav-group{margin-bottom:8px}.group-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:transparent;border:none;color:#94a3b8;cursor:pointer;border-radius:10px;transition:all .2s;font-size:14px;font-weight:600}.group-header:hover{background:#1e293b;color:#fff}.header-label{display:flex;align-items:center;gap:12px}.header-label svg{width:20px;height:20px;flex-shrink:0}.chevron{transition:transform .2s;color:#475569}.group-header.expanded .chevron{transform:rotate(180deg)}.group-items{padding:4px 0 4px 40px;display:flex;flex-direction:column;gap:2px}.group-items button{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:transparent;border:none;color:#64748b;font-size:13px;border-radius:6px;cursor:pointer;text-align:left}.group-items button:hover{color:#fff;background:#1e293b}.group-items button.active{color:#3b82f6;background:#3b82f60d;font-weight:700}.badge{font-size:10px;background:#1e293b;padding:2px 6px;border-radius:4px;color:#94a3b8;font-weight:700;flex-shrink:0}.nav-link{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;color:#94a3b8;cursor:pointer;border-radius:10px;font-size:14px;font-weight:600;margin-bottom:4px}.nav-link svg{width:20px;height:20px;flex-shrink:0}.nav-link:hover{background:#1e293b;color:#fff}.nav-link.active{background:#1e293b;color:#3b82f6;box-shadow:inset 4px 0 #3b82f6}.sidebar-footer{padding:16px;border-top:1px solid #1e293b;display:flex;flex-direction:column;gap:6px;flex-shrink:0;background:#0f172a}.user-profile-btn,.logout-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;color:#94a3b8;font-size:14px;font-weight:600;cursor:pointer;border-radius:10px;transition:all .2s}.user-profile-btn svg,.logout-btn svg{width:20px;height:20px;flex-shrink:0}.user-profile-btn:hover{background:#1e293b;color:#fff}.logout-btn:hover{color:#ef4444;background:#ef444414}.ailly-root{position:fixed;bottom:30px;right:30px;z-index:9999}.ailly-window{background-color:#020617;border:1px solid #1e293b;box-shadow:0 20px 50px #0009;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease-out}.ailly-window.collapsed{width:60px;height:60px;border-radius:30px;background-color:#2563eb;cursor:pointer}.ailly-window.expanded{width:380px;height:600px;border-radius:12px}.collapsed-trigger{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;position:relative}.ailly-messages{flex:1;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.msg-wrapper{display:flex;width:100%}.msg-wrapper.assistant{justify-content:flex-start}.msg-wrapper.user{justify-content:flex-end}.msg-bubble{padding:10px 14px;font-size:13.5px;line-height:1.5;max-width:80%;word-wrap:break-word}.msg-wrapper.assistant .msg-bubble{background:#1e293b;color:#f1f5f9;border-radius:0 12px 12px;border:1px solid #334155}.msg-wrapper.user .msg-bubble{background:#2563eb;color:#fff;border-radius:12px 12px 0;text-align:right}.ailly-header{padding:10px 16px;background:#0f172a;display:flex;justify-content:space-between;border-bottom:1px solid #1e293b}.header-status{display:flex;align-items:center;gap:8px;font-family:Roboto Mono,monospace;font-size:10px;color:#38bdf8}.icon-btn{background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;width:32px;height:32px}.icon-btn:hover{background:#334155;border-color:#475569;color:#fff;transform:scale(1.05)}.icon-btn:active{transform:scale(.95)}.ailly-controls{padding:16px;background:#0f172a;display:flex;flex-direction:column;gap:10px;border-top:1px solid #1e293b}.input-group{display:flex;background:#020617;border:1px solid #334155;border-radius:6px}.input-group input{flex:1;padding:10px;background:transparent;border:none;color:#fff;font-size:14px}.voice-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#fff;font-weight:700;font-size:11px;cursor:pointer}.online-ping{position:absolute;top:12px;right:12px;width:10px;height:10px;background:#10b981;border-radius:50%;border:2px solid #2563eb}.pulse-icon{animation:pulse-opacity 2s infinite}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.3}}.thinking-dots{display:flex;gap:4px;padding:5px}.thinking-dots span{width:5px;height:5px;background:#38bdf8;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}body,html,#root{background:#0f172a!important}.login-container{position:fixed;inset:0;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#0f172a!important;padding:20px;overflow:hidden;width:100%;margin:0;z-index:1}.login-card{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:48px 40px;box-shadow:0 20px 60px #0006;width:100%;max-width:420px;animation:fadeIn .5s ease-in;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:36px;margin:0 0 12px;color:#fff;font-weight:700;letter-spacing:-.5px}.login-subtitle{color:#94a3b8;margin:0;font-size:15px;font-weight:400}.form-group label{font-weight:600;color:#fff;font-size:14px}.form-group input{padding:12px 16px;background:#0f172a;border:1px solid #334155;border-radius:10px;font-size:16px;color:#fff;transition:all .3s ease;outline:none}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.login-button{background:#2563eb;color:#fff;border:none;padding:16px 24px;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;margin-top:8px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #2563eb4d;width:100%}.login-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #2563eb66;background:#1d4ed8}.login-error{margin-top:16px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:13px;text-align:center;font-weight:600}.login-footer p{margin:10px 0;font-size:14px;color:#94a3b8}.login-footer a{color:#60a5fa;text-decoration:none;font-weight:600;transition:color .2s}.login-footer a:hover{color:#fff;text-decoration:underline}.auth-note{font-size:12px!important;color:#64748b!important;margin-top:20px!important}@media(max-width:480px){.login-card{padding:36px 24px}.login-header h1{font-size:28px}}.home-container{flex:1;padding:32px 48px;background:#0f172a;min-height:100vh;overflow-y:auto}.home-header{margin-bottom:40px}.home-header h1{margin:0 0 8px;font-size:2.5em;color:#fff;font-weight:700}.home-header .subtitle{margin:0;font-size:1.1em;color:#94a3b8}.home-content{max-width:1400px;display:flex;flex-direction:column;gap:32px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 20px}.loading-state .spinner{width:50px;height:50px;border:4px solid #1e293b;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:#94a3b8;font-size:16px}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.stat-card{background:#1e293b;border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;gap:12px;transition:all .3s;border:1px solid #334155;border-left:4px solid #2563eb}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #2563eb4d;border-color:#475569}.stat-card.jobs .stat-icon{color:#60a5fa}.stat-card.jobs{border-left-color:#2563eb}.stat-card.expenses .stat-icon{color:#f87171}.stat-card.expenses{border-left-color:#ef4444}.stat-card.revenue .stat-icon{color:#34d399}.stat-card.revenue{border-left-color:#10b981}.stat-card.profit .stat-icon{color:#fbbf24}.stat-card.profit{border-left-color:#f59e0b}.stat-icon{font-size:.75em;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#94a3b8;font-family:Roboto Mono,monospace}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:1.8em;font-weight:700;color:#fff}.stat-label{font-size:.9em;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.stat-breakdown{display:flex;gap:12px;flex-wrap:wrap}.stat-detail{font-size:.85em;color:#cbd5e1;background:#0f172a;padding:4px 10px;border-radius:12px;border:1px solid #334155}.stat-detail.pending{background:#f59e0b1a;color:#fbbf24;border-color:#f59e0b4d}.stat-detail.completed{background:#10b9811a;color:#34d399;border-color:#10b9814d}.placeholder-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.placeholder-card{background:#1e293b;border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000004d;text-align:center;transition:all .3s;border:1px solid #334155}.placeholder-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #2563eb4d;border-color:#2563eb}.placeholder-icon{font-size:3em;margin-bottom:16px;opacity:.8}.placeholder-card h3{margin:0 0 8px;font-size:1.3em;color:#fff;font-weight:600}.placeholder-card p{margin:0;color:#94a3b8;font-size:.95em;line-height:1.5}.quick-actions{background:#1e293b;border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000004d;border:1px solid #334155}.quick-actions h2{margin:0 0 20px;font-size:1.5em;color:#fff;font-weight:600}.action-buttons{display:flex;gap:16px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:12px;padding:16px 28px;border:none;border-radius:12px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s}.action-btn.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 12px #2563eb4d}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb80;background:linear-gradient(135deg,#1d4ed8,#1e40af)}.action-btn.secondary{background:#0f172a;color:#fff;border:1px solid #334155}.action-btn.secondary:hover{background:#1e293b;border-color:#2563eb;color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb33}.btn-icon{font-size:.7em;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-family:Roboto Mono,monospace;padding:4px 8px;background:#ffffff1a;border-radius:4px}.action-btn.primary .btn-icon{background:#fff3;color:#fff}.action-btn.secondary .btn-icon{background:#ffffff0d;color:#60a5fa}.recent-activity{background:#1e293b;border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000004d;border:1px solid #334155}.recent-activity h2{margin:0 0 20px;font-size:1.5em;color:#fff;font-weight:600}.activity-placeholder{text-align:center;padding:60px 20px;background:#0f172a;border-radius:12px;border:1px dashed #334155}.activity-placeholder .placeholder-title{margin:0 0 8px;font-size:1.2em;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:1px;font-family:Roboto Mono,monospace}.placeholder-text{display:block;color:#64748b;font-size:.95em}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;align-items:center;gap:16px;padding:16px;background:#0f172a;border-radius:12px;transition:all .2s;border:1px solid #334155}.activity-item:hover{background:#1e293b;border-color:#475569;transform:translate(4px)}.activity-item.job{border-left:3px solid #2563eb}.activity-item.expense{border-left:3px solid #ef4444}.activity-icon{font-size:.7em;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-family:Roboto Mono,monospace;padding:6px 10px;background:#ffffff0d;border-radius:6px;min-width:50px;text-align:center}.activity-item.job .activity-icon{color:#60a5fa;background:#2563eb1a;border:1px solid rgba(37,99,235,.2)}.activity-item.expense .activity-icon{color:#f87171;background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.activity-content{display:flex;flex-direction:column;gap:4px;flex:1}.activity-title{font-weight:600;color:#fff}.activity-meta{font-size:.85em;color:#94a3b8}.home-container::-webkit-scrollbar{width:8px}.home-container::-webkit-scrollbar-track{background:#0f172a}.home-container::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.home-container::-webkit-scrollbar-thumb:hover{background:#475569}@media(max-width:1024px){.home-container{padding:24px}.home-header h1{font-size:2em}.placeholder-section{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media(max-width:768px){.home-container{padding:20px}.home-header h1{font-size:1.8em}.stats-section{grid-template-columns:1fr 1fr}.placeholder-section{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-btn{width:100%;justify-content:center}}@media(max-width:480px){.stats-section{grid-template-columns:1fr}}.profile-container{min-height:100vh;background:#0f172a!important;display:flex;justify-content:center;align-items:center;padding:40px 20px;box-sizing:border-box;font-family:Inter,sans-serif}.profile-card{background:#1e293b!important;border:1px solid #334155;border-radius:10px;padding:20px 28px;box-shadow:0 10px 40px #0006;width:100%;max-width:440px}.profile-card h2{color:#fff!important;text-align:center;margin:0 0 4px;font-size:20px}.profile-subtitle{color:#fff!important;opacity:.6;text-align:center;margin-bottom:15px;font-size:12px}.profile-form{display:flex;flex-direction:column;gap:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-group{display:flex;flex-direction:column;gap:2px}.form-group label{font-size:11px;font-weight:700!important;color:#fff!important;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select{padding:6px 10px;background:#0f172a!important;border:1px solid #334155;border-radius:4px;font-size:13px;color:#fff!important;width:100%;box-sizing:border-box}.form-group input::placeholder{color:#fff!important;opacity:.5!important}.submit-button{background:#2563eb!important;color:#fff!important;border:none;padding:10px;border-radius:4px;font-size:13px;font-weight:700;cursor:pointer;width:100%;margin-top:10px;transition:background .2s}.submit-button:hover{background:#1d4ed8!important}.loading-state p{color:#fff!important;font-size:14px}.error-banner{background:#ef444433;color:#fff!important;padding:6px 10px;font-size:11px;margin-bottom:10px;border-radius:4px;border:1px solid #ef4444}.calendar-container{padding:40px;max-width:1400px;margin:0 auto;background:#0f172a;color:#f8fafc;min-height:100vh;font-family:Inter,sans-serif}.calendar-header{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;border-bottom:1px solid #1e293b;padding-bottom:32px;padding-top:20px}.header-content h1{margin:0;font-size:32px;font-weight:900;text-transform:uppercase;letter-spacing:-1px}.header-content .subtitle{margin:4px 0 0;color:#38bdf8;font-family:Roboto Mono,monospace;font-size:12px;font-weight:700;text-transform:uppercase}.header-actions{display:flex;gap:12px;flex-shrink:0;margin-left:auto}.header-content{flex:1;min-width:0}.create-event-btn{background:#2563eb!important;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:800;text-transform:uppercase;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb33}.create-event-btn:hover{background:#1d4ed8!important;transform:translateY(-2px)}.calendar-picker-wrapper{position:relative;display:inline-block}.calendar-picker-btn{background:#1e293b;color:#f8fafc;border:2px solid #334155;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s;font-family:Inter,sans-serif}.calendar-picker-btn:hover{background:#334155;border-color:#475569}.calendar-picker-btn .dropdown-arrow{margin-left:auto;font-size:10px;transition:transform .2s;color:#94a3b8}.calendar-picker-btn:hover .dropdown-arrow{color:#fff}.calendar-picker-overlay{position:fixed;inset:0;z-index:998;background:transparent}.calendar-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#1e293b;border:2px solid #334155;border-radius:8px;box-shadow:0 8px 24px #0006;z-index:999;max-height:300px;overflow-y:auto;min-width:250px;animation:slideDown .2s ease-out}.calendar-picker-dropdown::-webkit-scrollbar{width:6px}.calendar-picker-dropdown::-webkit-scrollbar-track{background:#0f172a}.calendar-picker-dropdown::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.calendar-picker-dropdown::-webkit-scrollbar-thumb:hover{background:#64748b}.calendar-option{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;color:#f8fafc;cursor:pointer;font-size:14px;font-weight:500;text-align:left;transition:all .2s;border-bottom:1px solid #334155;font-family:Inter,sans-serif}.calendar-option:last-child{border-bottom:none}.calendar-option:hover{background:#334155;color:#fff}.calendar-option.selected{background:#38bdf81a;color:#38bdf8;border-left:3px solid #38bdf8}.calendar-option.selected:hover{background:#38bdf826}.calendar-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.2);box-shadow:0 0 0 1px #0003}.calendar-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.primary-badge{font-size:10px;padding:2px 6px;background:#334155;color:#94a3b8;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;font-family:Roboto Mono,monospace}.calendar-option.selected .primary-badge{background:#38bdf833;color:#38bdf8}.modal-overlay{background-color:#0f172ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.create-calendar-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:40px;color:#f8fafc;box-shadow:0 25px 50px #00000080}.create-calendar-modal h2{color:#fff;font-size:24px;font-weight:900;text-transform:uppercase}.modal-btn.primary{background:#2563eb;color:#fff;font-weight:800;text-transform:uppercase}.calendar-content{background:#1e293b;border-radius:12px;border:1px solid #334155;padding:24px;box-shadow:0 10px 30px #0000004d}.calendar-content.empty-state{padding:80px 40px;display:flex;align-items:center;justify-content:center;min-height:600px}.google-signin-prompt{text-align:center;max-width:500px;width:100%;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.prompt-icon{width:120px;height:120px;margin:0 auto 32px;background:linear-gradient(135deg,#2563eb,#38bdf8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:60px;box-shadow:0 20px 60px #2563eb4d;position:relative;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 20px 60px #2563eb4d}50%{transform:scale(1.05);box-shadow:0 25px 70px #2563eb66}}.prompt-icon:before{content:"📅";font-size:60px}.google-signin-prompt h3{margin:0 0 16px;font-size:32px;font-weight:800;color:#fff;letter-spacing:-.5px;font-family:Inter,sans-serif}.google-signin-prompt p{margin:0 0 40px;font-size:16px;color:#94a3b8;line-height:1.6;font-family:Inter,sans-serif}.google-signin-btn-large{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:700;border-radius:12px;text-transform:none;padding:16px 40px;font-size:16px;display:inline-flex;align-items:center;justify-content:center;gap:12px;transition:all .3s;box-shadow:0 8px 24px #2563eb4d;border:none;cursor:pointer;font-family:Inter,sans-serif;letter-spacing:.3px;margin:0 auto}.google-signin-btn-large:hover{transform:translateY(-3px);box-shadow:0 12px 32px #2563eb66;background:linear-gradient(135deg,#1d4ed8,#1e40af)}.google-signin-btn-large:active{transform:translateY(-1px)}.google-signin-btn-large span{font-size:20px}.calendar-content .fc{--fc-border-color: #334155;--fc-button-bg-color: #334155;--fc-button-border-color: #475569;--fc-button-hover-bg-color: #475569;--fc-today-bg-color: rgba(56, 189, 248, .05)}.calendar-content .fc-toolbar-title{font-family:Roboto Mono,monospace;font-size:22px!important;font-weight:700;color:#fff;text-transform:uppercase}.calendar-content .fc-col-header-cell{background-color:#0f172a;padding:15px;font-family:Roboto Mono,monospace;font-size:11px;font-weight:800;color:#94a3b8;text-transform:uppercase}.calendar-content .fc-daygrid-day-number{color:#94a3b8;font-family:Roboto Mono,monospace;font-weight:700;padding:10px}.calendar-content .fc-daygrid-day.fc-day-today{border:1px solid #38bdf8!important}.calendar-content .fc-daygrid-day.fc-day-today .fc-daygrid-day-number{background-color:#38bdf8;color:#0f172a;border-radius:4px;width:24px;height:24px;margin:4px;display:flex;align-items:center;justify-content:center}.calendar-content .fc-event{background:#2563eb;border:none;border-radius:4px;padding:4px 8px;font-size:12px;font-weight:700;text-transform:uppercase;font-family:Roboto Mono,monospace}.calendar-content .fc-event:hover{background:#3b82f6;transform:scale(1.02);box-shadow:0 4px 12px #0006}.calendar-loading-overlay{background:#0f172acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner{border-top-color:#38bdf8}.google-signin-btn,.google-signout-btn{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;text-transform:uppercase;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb33;display:flex;align-items:center;gap:8px;font-family:Inter,sans-serif}.google-signin-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px #2563eb4d}.google-signout-btn{background:#334155;box-shadow:0 4px 12px #0003}.google-signout-btn:hover{background:#475569;transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.google-signin-btn-large{background:#fff;color:#0f172a;font-weight:900;border-radius:8px;text-transform:uppercase;padding:14px 28px;font-size:16px;display:flex;align-items:center;gap:10px;transition:all .2s;box-shadow:0 4px 12px #0003}.google-signin-btn-large:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.calendar-error-banner{background:#ef44441a;border:1px solid #ef4444;color:#ef4444;font-family:Roboto Mono,monospace;font-size:13px;text-transform:uppercase}.error-state{padding:80px 40px;display:flex;align-items:center;justify-content:center;min-height:600px}.error-message{text-align:center;max-width:600px;width:100%;background:#1e293b;border:2px solid #334155;border-radius:12px;padding:40px;box-shadow:0 10px 30px #0000004d}.error-message h3{margin:0 0 16px;font-size:24px;font-weight:800;color:#ef4444;font-family:Inter,sans-serif}.error-message p{margin:0 0 24px;font-size:16px;color:#94a3b8;line-height:1.6;font-family:Inter,sans-serif}.error-message ol{text-align:left;max-width:500px;margin:20px auto;color:#f8fafc;line-height:1.8}.error-message li{margin-bottom:12px}.error-message code{background:#0f172a;padding:2px 6px;border-radius:4px;font-family:Roboto Mono,monospace;font-size:14px;color:#38bdf8}.error-message pre{background:#0f172a;padding:16px;margin-top:12px;border-radius:8px;border:1px solid #334155;font-family:Roboto Mono,monospace;font-size:13px;color:#f8fafc;overflow-x:auto;text-align:left}@media(max-width:768px){.calendar-container{padding:20px}.calendar-header h1{font-size:24px}.header-actions{flex-direction:column;width:100%}.calendar-content.empty-state{padding:60px 20px;min-height:500px}.google-signin-prompt h3{font-size:24px}.google-signin-prompt p{font-size:14px}.prompt-icon{width:100px;height:100px;font-size:50px}.prompt-icon:before{font-size:50px}.google-signin-btn-large{padding:14px 32px;font-size:15px}}.jobs-container{padding:32px 48px;max-width:100%;margin:0;display:flex;flex-direction:column;height:100%;min-height:calc(100vh - 64px)}.jobs-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;min-height:80px}.header-left{flex:1}.header-content h1{margin:0 0 8px;font-size:32px;color:#1a1a1a;font-weight:700}.header-content .subtitle{margin:0;color:#666;font-size:16px}.create-job-btn{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;padding:14px 28px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s;box-shadow:0 4px 12px #4a90e24d}.create-job-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.create-job-btn span:first-child{font-size:20px}.jobs-tabs{display:flex;gap:12px;margin-bottom:32px;border-bottom:2px solid #e5e5e5;min-height:60px}.tab-btn{background:none;border:none;padding:16px 24px;font-size:16px;font-weight:600;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;display:flex;align-items:center;gap:8px;white-space:nowrap}.tab-btn:hover{color:#333;background-color:#f8f8f8}.tab-btn.active{color:#4a90e2;border-bottom-color:#4a90e2}.tab-icon{font-size:20px}.tab-count{background-color:#e5e5e5;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600;margin-left:4px}.tab-btn.active .tab-count{background-color:#4a90e2;color:#fff}.jobs-content{flex:1;min-height:500px}.empty-state{padding:20px 0;width:100%;color:#fff}.empty-state p{margin:0;color:#999;font-size:16px;font-style:italic}.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}@media(min-width:1400px){.jobs-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px)and (max-width:1399px){.jobs-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px)and (max-width:1023px){.jobs-grid{grid-template-columns:repeat(2,1fr)}}.job-card{background:#1e293b;border-radius:12px;border:2px solid #e5e5e5;padding:20px;transition:all .3s;cursor:pointer;color:#fff}.job-card:hover{border-color:#4a90e2;box-shadow:0 8px 24px #0000001a;transform:translateY(-4px)}.job-card.past{opacity:.85}.job-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.job-title{display:flex;align-items:center;gap:12px;flex:1}.job-icon{font-size:24px}.job-title h3{margin:0;font-size:18px;color:#fff;font-weight:600;line-height:1.3}.job-status{padding:6px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.status-pending{background-color:#fff3cd;color:#856404}.status-in_progress{background-color:#cce5ff;color:#004085}.status-completed{background-color:#d4edda;color:#155724}.status-cancelled{background-color:#f8d7da;color:#721c24}.job-card-body{margin-bottom:16px}.job-time{display:flex;flex-direction:column;gap:12px}.time-item{display:flex;flex-direction:column;gap:4px}.time-label{font-size:11px;color:#999;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.time-value{font-size:14px;color:#fff;font-weight:500}.job-location{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background-color:#f8f9fa;border-radius:6px;font-size:14px;color:#666}.location-icon{font-size:16px}.job-card-footer{display:flex;gap:8px;padding-top:16px;border-top:1px solid #f0f0f0}.job-action-btn{flex:1;background:none;border:2px solid #e5e5e5;padding:10px;border-radius:8px;font-size:18px;cursor:pointer;transition:all .2s}.job-action-btn:hover{background-color:#f8f9fa;border-color:#4a90e2;transform:scale(1.05)}.job-action-btn.complete:hover{background-color:#d4edda;border-color:#28a745}.job-action-btn.delete:hover{background-color:#fee;border-color:#dc3545}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.job-modal{background:#1e293b;border-radius:16px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;color:#f8fafc}.modal-header h2{margin:0;font-size:24px;color:#fff;font-weight:600}.close-btn{background:none;border:none;font-size:32px;color:#94a3b8;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.job-form{padding:32px}.error-banner{background-color:#fee;border:2px solid #fcc;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:500}.error-banner span:first-child{font-size:20px}.form-group{margin-bottom:24px}.form-group.checkbox-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#fff;font-size:14px}.form-group.checkbox-group label{margin-bottom:0}.field-hint{display:block;margin-top:6px;font-size:12px;color:#94a3b8;font-style:italic}.form-group input,.form-group textarea{width:100%;padding:12px;border:2px solid #334155;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s;box-sizing:border-box;background-color:#0f172a;color:#fff}.form-group input:disabled,.form-group textarea:disabled{background-color:#1e293b;cursor:not-allowed;opacity:.7;border-color:#334155}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833;background-color:#0f172a}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;color:#fff;font-size:14px;margin:0;padding:0;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:20px;height:20px;min-width:20px;min-height:20px;cursor:pointer;accent-color:#38bdf8;margin:0;flex-shrink:0;border:2px solid #334155;border-radius:4px;background-color:#0f172a}.checkbox-label input[type=checkbox]:checked{background-color:#38bdf8;border-color:#38bdf8}.checkbox-label span{line-height:1.5;flex:1}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.client-fields-section{background-color:#0f172a;border:2px solid #38bdf8;border-radius:8px;padding:20px;margin-top:16px;margin-bottom:24px;animation:slideDown .3s ease-out;box-shadow:0 2px 8px #38bdf833}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.client-fields-section .section-title{margin:0 0 20px;font-size:16px;font-weight:700;color:#38bdf8;border-bottom:2px solid #38bdf8;padding-bottom:8px}.client-fields-section .form-group{margin-bottom:20px}.client-fields-section .form-group:last-child{margin-bottom:0}.client-select{width:100%;padding:12px;border:2px solid #334155;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s;box-sizing:border-box;background-color:#0f172a;color:#fff;cursor:pointer}.client-select:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833}.client-select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.btn-create-new-client,.btn-cancel-new-client{width:100%;padding:10px 20px;border:2px solid #38bdf8;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background-color:transparent;color:#38bdf8;margin-top:12px}.btn-create-new-client:hover{background-color:#38bdf8;color:#0f172a;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf84d}.btn-cancel-new-client{border-color:#64748b;color:#94a3b8;margin-top:16px}.btn-cancel-new-client:hover{background-color:#334155;border-color:#94a3b8;color:#fff}.btn-create-new-client:disabled,.btn-cancel-new-client:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:2px solid #334155}.btn-primary,.btn-secondary{padding:12px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#4a90e2;color:#fff}.btn-primary:hover{background-color:#357abd;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e24d}.btn-primary:hover:disabled{transform:none;box-shadow:none}.btn-secondary{background-color:transparent;color:#94a3b8;border:2px solid #64748b}.btn-secondary:hover{background-color:#334155;border-color:#94a3b8;color:#fff}@media(max-width:768px){.jobs-container{padding:20px;min-height:auto}.jobs-header{flex-direction:column;gap:20px;align-items:stretch;min-height:auto}.create-job-btn{width:100%;justify-content:center}.jobs-header h1{font-size:24px}.jobs-tabs{overflow-x:auto;min-height:50px}.tab-btn{white-space:nowrap;padding:12px 16px}.jobs-grid{grid-template-columns:1fr}.jobs-content{min-height:300px}.job-modal{width:95%;max-height:95vh}.modal-header,.job-form{padding:20px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.invoices-container{padding:32px 48px;max-width:100%;margin:0;display:flex;flex-direction:column;min-height:calc(100vh - 64px);background:#0f172a;color:#f8fafc;font-family:Inter,sans-serif}.invoices-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.header-content h1{margin:0 0 8px;font-size:32px;color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:-1px}.header-content .subtitle{margin:0;color:#38bdf8;font-family:Roboto Mono,monospace;font-size:16px;font-weight:600}.create-invoice-btn{background:#2563eb;color:#fff;border:none;padding:14px 28px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s;box-shadow:0 4px 12px #2563eb4d;text-transform:uppercase}.create-invoice-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.spinner{border:4px solid #1e293b;border-top:4px solid #38bdf8}.error-banner{background-color:#ef44441a;border:2px solid #ef4444;color:#ef4444;font-family:Roboto Mono,monospace}.invoice-card{background:#1e293b;border-radius:12px;border:2px solid #334155;padding:28px;transition:all .3s}.invoice-card:hover{border-color:#38bdf8;box-shadow:0 8px 24px #0006;transform:translateY(-4px)}.invoice-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #334155}.invoice-number h3{margin:0;font-size:18px;color:#fff;font-weight:600;font-family:Roboto Mono,monospace}.invoice-status{padding:6px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;font-family:Roboto Mono,monospace}.status-draft{background-color:#334155;color:#94a3b8}.status-sent{background-color:#38bdf81a;color:#38bdf8;border:1px solid #38bdf8}.status-paid{background-color:#10b9811a;color:#10b981;border:1px solid #10b981}.status-overdue{background-color:#ef44441a;color:#ef4444;border:1px solid #ef4444}.invoice-card-body,.invoice-amount{margin-bottom:24px}.amount-label{color:#64748b;font-family:Roboto Mono,monospace}.amount-value{color:#38bdf8;font-family:Roboto Mono,monospace}.invoice-dates{display:flex;flex-direction:column;gap:16px;margin-bottom:12px}.date-label{color:#64748b;font-family:Roboto Mono,monospace}.date-value{color:#f8fafc}.invoice-card-footer{padding-top:20px;border-top:1px solid #334155;display:flex;gap:12px}.invoice-action-btn{flex:1;background:#0f172a;border:2px solid #334155;color:#94a3b8;padding:12px 16px;font-size:13px;font-family:Roboto Mono,monospace;text-transform:uppercase;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.invoice-action-btn:hover{background-color:#1e293b;border-color:#38bdf8;color:#fff;transform:translateY(-2px)}.invoice-action-btn.delete{color:#ef4444}.invoice-action-btn.delete:hover{background-color:#ef444426;border-color:#ef4444;color:#f87171}.modal-overlay{position:fixed;inset:0;background-color:#0f172ae6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:flex-start;z-index:1000;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.invoice-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;color:#f8fafc;width:100%;max-width:800px;max-height:90vh;margin:auto;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;overflow:hidden}.modal-header{border-bottom:2px solid #334155;background:#0f172a;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h2{color:#fff;margin:0;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:-.5px}.close-btn{color:#94a3b8;background:transparent;border:none;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.close-btn:hover{background-color:#334155;color:#fff}.invoice-form{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}.invoice-form::-webkit-scrollbar{width:8px}.invoice-form::-webkit-scrollbar-track{background:#0f172a}.invoice-form::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.invoice-form::-webkit-scrollbar-thumb:hover{background:#475569}.form-section{display:flex;flex-direction:column;gap:16px;padding:20px;background:#0f172a;border:1px solid #334155;border-radius:8px}.form-section h3{color:#38bdf8;border-bottom:2px solid #334155;font-family:Roboto Mono,monospace;text-transform:uppercase;font-size:12px;font-weight:700;padding-bottom:8px;margin:0 0 8px;letter-spacing:.5px}.form-group label{color:#fff!important;font-family:Roboto Mono,monospace;text-transform:uppercase;font-size:11px;font-weight:600;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{background-color:#0f172a!important;border:2px solid #334155;color:#fff!important;padding:12px;border-radius:6px;font-size:14px;font-family:Inter,sans-serif;transition:all .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-group small{color:#64748b;font-size:12px;font-family:Roboto Mono,monospace}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:768px){.invoice-modal{max-width:95%;max-height:95vh}.modal-header{padding:16px 20px}.modal-header h2{font-size:18px}.invoice-form{padding:20px;gap:20px}.form-section{padding:16px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.item-row{background-color:#0f172a;border:1px solid #334155;border-radius:8px;padding:16px;display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:12px;align-items:end;position:relative}@media(max-width:768px){.item-row{grid-template-columns:1fr;gap:12px}.item-row .remove-item-btn{position:absolute;top:12px;right:12px}}.remove-item-btn{background:transparent;border:2px solid #ef4444;color:#ef4444;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s;flex-shrink:0}.remove-item-btn:hover{background:#ef44441a;border-color:#f87171;color:#f87171}.add-item-btn{background:transparent;border:2px solid #38bdf8;color:#38bdf8;padding:12px 20px;border-radius:8px;cursor:pointer;font-family:Roboto Mono,monospace;text-transform:uppercase;font-size:12px;font-weight:600;transition:all .2s;width:100%;margin-top:8px}.add-item-btn:hover{background:#38bdf81a;border-color:#60a5fa;color:#60a5fa}.invoice-total{background-color:#0f172a;border:2px solid #38bdf8;border-radius:8px;padding:20px;margin-top:8px}.invoice-total h3{color:#38bdf8;font-family:Roboto Mono,monospace;margin:0;font-size:18px;font-weight:700;text-align:center}.form-actions{display:flex;gap:12px;padding-top:16px;border-top:2px solid #334155;flex-shrink:0}.btn-primary{background-color:#2563eb;color:#fff;text-transform:uppercase;border:none;padding:14px 28px;border-radius:8px;font-size:14px;font-weight:600;font-family:Roboto Mono,monospace;cursor:pointer;transition:all .2s;flex:1}.btn-primary:hover:not(:disabled){background-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:transparent;color:#94a3b8;border:2px solid #334155;text-transform:uppercase;padding:14px 28px;border-radius:8px;font-size:14px;font-weight:600;font-family:Roboto Mono,monospace;cursor:pointer;transition:all .2s;flex:1}.btn-secondary:hover{background-color:#334155;color:#fff;transform:translateY(-1px)}.btn-create-new-job,.btn-create-new-client{width:100%;padding:12px 20px;margin-top:8px;border:2px solid #38bdf8;border-radius:8px;background:transparent;color:#38bdf8;font-weight:600;font-family:Roboto Mono,monospace;text-transform:uppercase;font-size:12px;cursor:pointer;transition:all .2s}.btn-create-new-job:hover,.btn-create-new-client:hover{background:#38bdf81a;border-color:#60a5fa;color:#60a5fa}.btn-cancel-new-job,.btn-cancel-new-client{width:100%;padding:12px 20px;margin-top:8px;border:2px solid #64748b;border-radius:8px;background:transparent;color:#94a3b8;font-weight:600;font-family:Roboto Mono,monospace;text-transform:uppercase;font-size:12px;cursor:pointer;transition:all .2s}.btn-cancel-new-job:hover,.btn-cancel-new-client:hover{background:#64748b1a;border-color:#94a3b8;color:#cbd5e1}.info-banner{margin-bottom:16px;padding:12px 16px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;color:#fbbf24;font-size:13px;font-family:Roboto Mono,monospace;display:flex;align-items:center;gap:8px}.info-banner span{font-size:16px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;gap:16px}.loading-state p{color:#94a3b8;font-family:Roboto Mono,monospace;font-size:14px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:28px;margin:0 0 10px;color:#333;font-weight:700}.login-header p{color:#666;margin:0;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;transition:all .3s ease;outline:none}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active{transform:translateY(0)}.login-footer{margin-top:25px;text-align:center}.login-footer p{margin:10px 0;font-size:14px;color:#666}.login-footer a{color:#667eea;text-decoration:none;font-weight:600}.login-footer a:hover{text-decoration:underline}.auth-note{font-size:12px!important;color:#999!important;margin-top:20px!important}@media(max-width:480px){.login-card{padding:30px 20px}.login-header h1{font-size:24px}}.expenses-container{padding:32px 48px;max-width:1400px;margin:0 auto;background:#0f172a;color:#f8fafc;min-height:100vh;font-family:Inter,sans-serif}.expenses-container h1{margin:0 0 8px;font-size:32px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:-.5px}.expenses-subtitle{color:#94a3b8;font-family:Roboto Mono,monospace;font-size:12px;font-weight:600;margin:0 0 32px;text-transform:uppercase;letter-spacing:1px}.expenses-tabs{display:flex;gap:12px;margin-bottom:32px;background:transparent;padding:0;border-radius:0;border:none}.expenses-tabs .tab-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;background:#1e293b;border:1px solid #334155;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;transition:all .2s}.expenses-tabs .tab-btn:hover{background:#334155;border-color:#475569;color:#fff}.expenses-tabs .tab-btn.active{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#2563eb;box-shadow:0 4px 12px #2563eb4d}.tab-count{font-family:Roboto Mono,monospace;background:#0003;padding:2px 8px;border-radius:4px;font-size:11px;margin-left:8px;font-weight:700}.expenses-tabs .tab-btn.active .tab-count{background:#fff3}.expenses-content{display:flex;gap:24px;align-items:flex-start}.upload-section{flex:0 0 360px;background:#1e293b;border:1px solid #334155;border-radius:16px;padding:24px;position:relative;box-shadow:0 4px 12px #0003}.upload-zone{border:2px dashed #475569;border-radius:12px;padding:60px 20px;text-align:center;cursor:pointer;background:#0f172a;transition:all .3s}.upload-zone:hover{border-color:#2563eb;background:#2563eb0d}.upload-zone p{margin:12px 0 8px;font-size:14px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;font-family:Roboto Mono,monospace}.upload-zone span{font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.upload-icon{color:#60a5fa;margin-bottom:16px}.receipt-preview{width:100%;border-radius:8px;border:1px solid #334155;box-shadow:0 4px 12px #0003}.change-image-btn{margin-top:12px;width:100%;padding:10px;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#60a5fa;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s;font-family:Roboto Mono,monospace}.change-image-btn:hover{background:#1e293b;border-color:#2563eb;color:#fff}.expense-form{flex:1;background:#1e293b;padding:32px;border-radius:16px;border:1px solid #334155;box-shadow:0 4px 12px #0003}.expense-form h2{font-size:20px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #334155}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:11px;font-weight:700;color:#94a3b8!important;text-transform:uppercase;font-family:Roboto Mono,monospace;margin-bottom:8px;display:block;letter-spacing:1px}.form-group input,.form-group select{background:#0f172a!important;border:1px solid #334155!important;border-radius:8px;padding:12px 16px;font-size:14px;color:#fff!important;width:100%;box-sizing:border-box;transition:all .2s;font-family:Inter,sans-serif}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb!important;box-shadow:0 0 0 3px #2563eb1a}.form-group input::placeholder{color:#64748b}.line-items-section{margin-top:24px;padding-top:24px;border-top:1px solid #334155}.line-items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.line-items-header h3{font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;font-family:Roboto Mono,monospace;margin:0}.add-item-btn{padding:8px 16px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#60a5fa;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s;font-family:Roboto Mono,monospace}.add-item-btn:hover{background:#1e293b;border-color:#2563eb;color:#fff}.line-item{display:grid;grid-template-columns:2fr 1fr auto;gap:12px;margin-bottom:12px;align-items:center}.line-item input{background:#0f172a!important;border:1px solid #334155!important;border-radius:6px;padding:10px 12px;font-size:13px;color:#fff!important;transition:all .2s}.line-item input:focus{outline:none;border-color:#2563eb!important;box-shadow:0 0 0 2px #2563eb1a}.remove-item-btn{width:32px;height:32px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#f87171;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.remove-item-btn:hover{background:#ef444433;border-color:#ef4444;color:#fff}.submit-btn{width:100%;margin-top:24px;padding:14px 24px;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb4d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66;background:linear-gradient(135deg,#1d4ed8,#1e40af)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{margin-top:16px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:13px;display:flex;align-items:center;gap:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:Roboto Mono,monospace}.expenses-list-container{width:100%}.expenses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-bottom:32px}.expense-card{background:#1e293b;border:1px solid #334155;border-radius:16px;overflow:hidden;transition:all .3s;box-shadow:0 4px 12px #0003}.expense-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:#475569}.expense-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#0f172a4d;border-bottom:1px solid #334155}.expense-vendor{display:flex;align-items:center;gap:12px;flex:1}.expense-vendor svg{color:#60a5fa;flex-shrink:0}.expense-vendor h3{margin:0;font-size:16px;color:#fff;font-weight:600;text-transform:none;letter-spacing:0}.expense-amount{color:#60a5fa;font-family:Roboto Mono,monospace;font-weight:700;font-size:18px}.expense-card-body{padding:20px;display:flex;flex-direction:column;gap:12px}.expense-date,.expense-tax{display:flex;align-items:center;gap:8px;font-size:13px;color:#94a3b8}.expense-date svg,.expense-tax svg{color:#64748b;flex-shrink:0}.tax-label{font-family:Roboto Mono,monospace;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.expense-card-footer{padding:12px 20px;background:#0f172a;display:flex;justify-content:flex-end;border-top:1px solid #334155}.expense-action-btn{padding:8px 12px;background:transparent;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.expense-action-btn:hover{background:#ef44441a;border-color:#ef4444;color:#f87171}.expense-action-btn.delete:hover{background:#ef444433}.expenses-summary{margin-top:32px;background:#1e293b;border-radius:16px;padding:32px;border:1px solid #334155;box-shadow:0 4px 12px #0003}.expenses-summary h2{font-size:18px;font-weight:700;margin:0 0 24px;color:#fff;text-transform:uppercase;letter-spacing:.5px;padding-bottom:16px;border-bottom:2px solid #334155}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px}.summary-stat{display:flex;flex-direction:column;gap:8px}.stat-label{font-family:Roboto Mono,monospace;text-transform:uppercase;font-weight:700;font-size:11px;color:#94a3b8;letter-spacing:1px}.stat-value{font-size:28px;font-weight:700;color:#fff;letter-spacing:-.5px}.processing-overlay{position:absolute;inset:0;background:#0f172af2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:16px;text-align:center;padding:20px}.processing-overlay p{margin-top:16px;color:#60a5fa;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:Roboto Mono,monospace}.spinner{color:#60a5fa;animation:spin 1s linear infinite}.expenses-container::-webkit-scrollbar{width:8px}.expenses-container::-webkit-scrollbar-track{background:#0f172a}.expenses-container::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.expenses-container::-webkit-scrollbar-thumb:hover{background:#475569}@media(max-width:1024px){.expenses-container{padding:24px}.expenses-content{flex-direction:column}.upload-section{width:100%;flex:none}.form-row{grid-template-columns:1fr}}@media(max-width:768px){.expenses-container{padding:20px}.expenses-grid{grid-template-columns:1fr}.summary-stats{grid-template-columns:1fr;gap:24px}.expenses-tabs{flex-direction:column}.expenses-tabs .tab-btn{width:100%}}.clients-container{padding:32px 48px;max-width:100%;margin:0;display:flex;flex-direction:column;min-height:calc(100vh - 64px);background:#0f172a;color:#f8fafc;font-family:Inter,sans-serif}.clients-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.header-content h1{margin:0 0 8px;font-size:32px;color:#fff;font-weight:700;text-transform:uppercase}.header-content .subtitle{margin:0;color:#38bdf8;font-size:16px;font-family:Roboto Mono,monospace;font-weight:600}.create-client-btn{background:#2563eb;color:#fff;border:none;padding:14px 28px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s;box-shadow:0 4px 12px #0000004d;text-transform:uppercase}.create-client-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px #0006}.loading-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px}.spinner{width:40px;height:40px;border:4px solid #1e293b;border-top:4px solid #38bdf8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-banner{background-color:#ef44441a;border:2px solid #ef4444;color:#f87171;padding:12px 16px;border-radius:8px;margin-bottom:24px;display:flex;align-items:center;gap:8px;font-family:Roboto Mono,monospace;font-size:14px}.empty-state p{color:#64748b;font-size:16px;font-style:italic;font-family:Roboto Mono,monospace}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.client-card{background:#1e293b;border-radius:12px;border:2px solid #334155;padding:20px;transition:all .3s;cursor:pointer;display:flex;flex-direction:column;gap:12px}.client-card:hover{border-color:#38bdf8;box-shadow:0 4px 12px #0006;transform:translateY(-2px)}.client-name{font-size:20px;font-weight:700;color:#fff;margin:0;text-transform:uppercase}.client-archived-badge{background:#334155;color:#94a3b8;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;font-family:Roboto Mono,monospace;text-transform:uppercase}.client-info-item{display:flex;align-items:center;gap:8px;color:#94a3b8;font-size:14px}.client-info-item svg{width:16px;height:16px;color:#38bdf8;flex-shrink:0}.client-actions{display:flex;gap:8px;margin-top:auto;padding-top:12px;border-top:1px solid #334155}.client-action-btn{flex:1;padding:8px 16px;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#94a3b8;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:Roboto Mono,monospace;text-transform:uppercase}.client-action-btn:hover{background:#1e293b;border-color:#38bdf8;color:#38bdf8}.client-action-btn.archive,.client-action-btn.delete{color:#ef4444}.client-action-btn.archive:hover,.client-action-btn.delete:hover{background:#ef44441a;border-color:#ef4444}.client-action-btn.unarchive{color:#10b981}.client-action-btn.unarchive:hover{background:#10b9811a;border-color:#10b981}.modal-overlay{position:fixed;inset:0;background:#0f172ae6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content{background:#1e293b;border:1px solid #334155;border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid #334155;position:sticky;top:0;background:#1e293b;border-radius:16px 16px 0 0;z-index:10}.modal-header h2{margin:0;font-size:24px;color:#fff;font-weight:600;text-transform:uppercase;letter-spacing:-.5px}.modal-close-btn{background:transparent;border:none;font-size:32px;color:#94a3b8;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close-btn:hover{background:#334155;color:#fff}.modal-form{flex:1;overflow-y:auto;padding:32px;display:flex;flex-direction:column;gap:24px}.modal-form::-webkit-scrollbar{width:8px}.modal-form::-webkit-scrollbar-track{background:#0f172a}.modal-form::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.modal-form::-webkit-scrollbar-thumb:hover{background:#475569}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#fff!important;font-family:Roboto Mono,monospace;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea{padding:12px;background:#0f172a!important;border:2px solid #334155;border-radius:8px;font-size:14px;color:#fff!important;font-family:Inter,sans-serif;transition:all .2s;box-sizing:border-box;width:100%}.form-group textarea{resize:vertical;min-height:100px}.form-group input::placeholder,.form-group textarea::placeholder{color:#64748b!important;opacity:.8}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833;background-color:#0f172a!important}.form-group input:disabled,.form-group textarea:disabled{background-color:#1e293b!important;cursor:not-allowed;opacity:.7;border-color:#334155}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:2px solid #334155;flex-shrink:0}.modal-btn{padding:12px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-family:Roboto Mono,monospace;text-transform:uppercase}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.modal-btn-primary{background:#38bdf8;color:#0f172a;text-transform:uppercase}.modal-btn-primary:hover:not(:disabled){background:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #38bdf84d}.modal-btn-secondary{background:transparent;border:2px solid #64748b;color:#94a3b8;text-transform:uppercase}.modal-btn-secondary:hover{background:#334155;border-color:#94a3b8;color:#fff;transform:translateY(-1px)}@media(max-width:768px){.modal-content{max-width:95%;max-height:95vh}.modal-header{padding:16px 20px}.modal-header h2{font-size:18px}.modal-form{padding:20px;gap:20px}.modal-actions{flex-direction:column-reverse}.modal-btn{width:100%}}#root{width:100%;margin:0;padding:0}*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f172a;overflow-x:hidden}.app-container{display:flex;min-height:100vh;background:#0f172a}.main-content{margin-left:280px;flex:1;display:flex;flex-direction:column;min-height:100vh}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.5em;font-weight:600}@media(max-width:1024px){.main-content{margin-left:240px}}@media(max-width:768px){.main-content{margin-left:0}}
