:root{color-scheme:light;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--color-bg: #f4f5f7;--color-surface: #ffffff;--color-border: #e2e8f0;--color-text: #1f2937;--color-muted: #6b7280;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-secondary: #e0e7ff;--color-secondary-text: #1e3a8a;--color-danger: #b91c1c;--sidebar-bg: #111827;--sidebar-border: rgba(255, 255, 255, .08)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;max-width:100vw;overflow-x:hidden}body{margin:0;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}.app-shell{display:flex;min-height:100vh;background:var(--color-bg);max-width:100vw;overflow-x:hidden}.sidebar{width:240px;background:var(--sidebar-bg);color:#f9fafb;padding:32px 24px;display:flex;flex-direction:column;gap:32px;border-right:1px solid var(--sidebar-border)}.sidebar-header h1{margin:0 0 6px;font-size:1.4rem;font-weight:600}.sidebar-header p{margin:0;color:#f9fafbb3;font-size:.85rem;word-break:break-word}.nav-links{display:flex;flex-direction:column;gap:8px}.nav-link{display:flex;align-items:center;padding:10px 14px;border-radius:10px;color:#f9fafbd9;font-weight:500;transition:background .2s ease,color .2s ease}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link-active{background:#ffffff2e;color:#fff;box-shadow:inset 0 0 0 1px #ffffff26}.btn{border:none;border-radius:10px;padding:10px 18px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 12px 20px -12px #2563ebb3}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-secondary);color:var(--color-secondary-text)}.btn-secondary:hover{background:#c7d2fe}.btn-ghost{background:transparent;color:inherit;border:1px solid rgba(17,24,39,.12)}.btn-ghost:hover{background:#1118270d}.sidebar .btn-ghost{border-color:#ffffff2e;color:#f9fafb;align-self:stretch;margin-top:auto}.sidebar .btn-ghost:hover{background:#ffffff14}.app-content{flex:1;padding:48px clamp(24px,5vw,60px);background:var(--color-bg);overflow-y:auto;max-width:100vw}.page{display:flex;flex-direction:column;gap:24px;max-width:960px;width:100%;margin:0 auto}.page-header h2{margin:0;font-size:1.85rem;font-weight:700}.page-subtitle{margin:8px 0 0;color:var(--color-muted);font-size:.95rem}.panel{background:var(--color-surface);border-radius:14px;padding:clamp(16px,4vw,24px);border:1px solid var(--color-border);box-shadow:0 20px 40px -24px #0f172a59}.form-inline{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.input,.select{font:inherit;padding:12px 14px;border-radius:10px;border:1px solid var(--color-border);background:#fff;min-width:220px;transition:border-color .2s ease,box-shadow .2s ease}.input:focus,.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb33}.form-grid{display:grid;gap:18px}.form-grid .form-actions{display:flex;align-items:flex-end}.form-actions{display:flex;align-items:center;gap:12px}.form-field{display:flex;flex-direction:column;gap:8px;color:var(--color-text);font-weight:500}.form-field span{font-size:.9rem}.form-error{background:#fee2e2;color:var(--color-danger);padding:12px 14px;border-radius:10px;border:1px solid rgba(185,28,28,.2)}.radio-group{display:flex;flex-wrap:wrap;gap:10px}.radio-option{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;color:var(--color-text)}.radio-option input{accent-color:var(--color-primary)}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top right,rgba(37,99,235,.18),transparent 60%),var(--color-bg);padding:32px 16px}.auth-card{width:min(420px,100%);background:var(--color-surface);border-radius:18px;padding:clamp(28px,8vw,40px);box-shadow:0 24px 48px -24px #0f172a59;display:flex;flex-direction:column;gap:18px}.auth-card h2{margin:0;font-size:1.9rem}.auth-subtitle{margin:0;color:var(--color-muted);font-size:.95rem}.client-card-list{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}.client-card{background:var(--color-surface);border-radius:16px;padding:16px 18px;border:1px solid var(--color-border);box-shadow:0 18px 36px -28px #0f172a73;display:flex;flex-direction:column;gap:12px}.client-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.client-card-title{margin:0 0 4px;font-size:1.05rem;font-weight:600}.client-card-meta{margin:0;font-size:.8rem;color:var(--color-muted)}.client-card-badges{display:flex;flex-wrap:wrap;gap:6px}.client-card-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 24px}.client-card-column{display:flex;flex-direction:column;gap:8px}.client-card-field{display:flex;flex-direction:column;gap:2px;font-size:.9rem}.client-card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.client-card-value{color:var(--color-text);word-break:break-word}.client-card-footer{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px}.client-card-status{display:flex;flex-direction:column;gap:6px}.client-status-select{min-width:160px}.client-card-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}@media (max-width: 640px){.client-card-body{grid-template-columns:1fr}.client-card-footer{flex-direction:column;align-items:stretch}.client-card-actions{justify-content:flex-start}}.item-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.item{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center;justify-content:space-between;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:18px 20px}.item-main{display:flex;align-items:center;justify-content:space-between;flex:1 1 240px;gap:20px}.item-title{font-weight:600}.item-meta{color:var(--color-muted);font-size:.9rem}.item-detail{display:grid;gap:4px;min-width:160px;color:var(--color-text)}.item-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.item-actions{display:flex;gap:10px}.item-tags{display:flex;flex-wrap:wrap;gap:8px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize;background:#94a3b82e;color:var(--color-text)}.badge-success{background:#22c55e29;color:#166534}.badge-warning{background:#facc1533;color:#854d0e}.badge-muted{background:#94a3b82e;color:#334155}.badge-soft{background:#3b82f626;color:#1d4ed8}.badge-info{background:#818cf833;color:#3730a3}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat-card{background:var(--color-surface);border-radius:16px;padding:18px 20px;border:1px solid var(--color-border);display:grid;gap:6px;box-shadow:0 18px 36px -28px #0f172a73}.stat-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted)}.stat-value{font-size:1.8rem;font-weight:700;color:var(--color-text)}.stat-caption{font-size:.85rem;color:var(--color-muted)}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.loading-card{display:flex;align-items:center;gap:14px;background:var(--color-surface);padding:18px 24px;border-radius:14px;border:1px solid var(--color-border);box-shadow:0 18px 36px -24px #0f172a59;font-weight:500}.loading-spinner{width:18px;height:18px;border:3px solid rgba(37,99,235,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--color-surface);border-radius:14px;border:1px solid var(--color-border);padding:12px 16px;box-shadow:0 18px 36px -28px #0f172a73;margin-bottom:16px}.toast-success{border-left:4px solid var(--color-primary)}.toast-error{border-left:4px solid var(--color-danger)}.icon-button{border:none;background:transparent;color:inherit;font-size:1.1rem;cursor:pointer;padding:4px 6px;border-radius:8px}.icon-button:hover{background:#0f172a14}.helper-text{display:block;font-size:.75rem;color:var(--color-muted);margin-top:4px}.job-filters{display:flex;flex-direction:column;gap:20px}.filters-row{display:flex;gap:16px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:10px}.filter-label{font-size:.85rem;font-weight:600;color:var(--color-muted)}.filter-toggle-group{display:flex;gap:10px}.btn-secondary.is-active{background:var(--color-primary);color:#fff}.filter-spacer{flex:1}.filter-actions{display:flex;gap:10px}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.job-groups{display:flex;flex-direction:column;gap:24px}.job-group{display:flex;flex-direction:column;gap:16px}.job-group-header{display:flex;justify-content:space-between;align-items:baseline;padding:0 4px;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.job-group-list{display:flex;flex-direction:column;gap:14px}.job-card{display:flex;flex-direction:column;gap:12px;padding:16px 18px;border-radius:16px;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 18px 36px -28px #0f172a73}.job-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.job-card-header-main{display:flex;flex-direction:column;gap:4px}.job-card-time{margin:0;font-size:.9rem;color:var(--color-muted)}.job-card-body{display:flex;flex-direction:column;gap:10px}.job-card-client{display:flex;flex-direction:column;gap:4px}.job-card-client h4{margin:0;font-size:1.05rem}.job-card-address{margin:0;font-size:.9rem;color:var(--color-muted)}.job-card-assignees{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.job-card-notes{margin:0;font-size:.9rem;color:var(--color-muted);line-height:1.4;white-space:pre-line}.job-card-footer{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}@media (min-width: 900px){.job-card-body{flex-direction:row;justify-content:space-between;align-items:flex-start}.job-card-notes{max-width:320px}}.job-item{display:grid;gap:16px;grid-template-columns:140px minmax(0,1fr) 200px 120px auto;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:18px;box-shadow:0 18px 36px -28px #0f172a73}.job-time{display:grid;gap:4px;font-size:.9rem}.job-main h4{margin:0 0 4px;font-size:1.05rem}.job-main p{margin:4px 0;color:var(--color-muted)}.job-address{font-size:.9rem}.job-notes{font-size:.85rem;color:var(--color-muted)}.job-assignees{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#2563eb26;color:#1d4ed8;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.job-status{justify-self:center}.job-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.btn-danger{color:var(--color-danger);border-color:#b91c1c4d}.btn-danger:hover{background:#b91c1c1f}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:grid;place-items:center;padding:24px;z-index:1000}.modal{background:var(--color-surface);border-radius:18px;border:1px solid var(--color-border);width:min(560px,100%);max-height:calc(100vh - 80px);display:flex;flex-direction:column;box-shadow:0 24px 48px -28px #0f172a73}.modal-header,.modal-footer{padding:20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-body{padding:0 20px 20px;overflow-y:auto;display:grid;gap:16px}.job-modal-body{grid-template-columns:1fr}.option-list{display:grid;gap:10px;max-height:220px;overflow-y:auto;padding:6px 4px;border:1px solid var(--color-border);border-radius:12px;background:#0f172a05}.option-item{display:flex;gap:10px;align-items:center;font-size:.9rem}.option-title{font-weight:600;display:block}.option-subtitle{font-size:.8rem;color:var(--color-muted)}.info-note{background:#2563eb14;border:1px solid rgba(37,99,235,.2);border-radius:12px;padding:12px;font-size:.85rem}.textarea{font-family:inherit;border-radius:10px;border:1px solid var(--color-border);padding:10px 12px;resize:vertical;min-height:80px}.tabs{display:inline-flex;background:var(--color-surface);border-radius:999px;padding:4px;border:1px solid var(--color-border);gap:4px;margin-bottom:20px}.tab-button{border:none;background:transparent;padding:8px 18px;border-radius:999px;font-weight:600;color:var(--color-muted)}.tab-button.is-active{background:var(--color-primary);color:#fff}.job-card-list{display:grid;gap:16px}.my-job-card{display:flex;flex-direction:column;gap:16px}.my-job-header{display:flex;justify-content:space-between;align-items:center}.my-job-header h3{margin:0 0 4px}.my-job-header p{margin:0;color:var(--color-muted);font-size:.9rem}.my-job-body{display:grid;gap:12px}.my-job-client{display:grid;gap:6px}.address-row{display:flex;align-items:center;gap:8px;font-size:.9rem}.my-job-notes{margin:0;font-size:.9rem;color:var(--color-muted)}.my-job-actions{display:flex;gap:12px;justify-content:flex-end}.worklog-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.worklog-header-text h3{margin:0}.worklog-summary-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.worklog-user-card{padding:6px 16px;margin-bottom:15px;border-radius:12px;border:1px solid var(--sidebar-bg);background:var(--color-surface-soft);display:flex;flex-direction:column}.worklog-user-hours{font-size:1.4rem;font-weight:600}.worklog-list{display:flex;flex-direction:column;gap:12px}.worklog-entry{border:1px solid var(--color-border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px;background:#0f172a05}.worklog-entry h4{margin:0}.worklog-entry-main{display:flex;align-items:center;justify-content:space-between;gap:12px}.worklog-entry-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.worklog-notes{margin:0;font-size:.9rem}.worklog-entry-actions{display:flex;justify-content:flex-end}.empty-state{text-align:center;color:var(--color-muted)}@media (max-width: 1200px){.app-content{padding:40px clamp(20px,4vw,40px)}.sidebar{padding:28px 22px}}@media (max-width: 1100px){.job-item{grid-template-columns:minmax(0,1fr);justify-items:flex-start}.job-status{justify-self:flex-start}.job-actions{width:100%;justify-content:flex-start}}@media (max-width: 1024px){.page-header h2{font-size:1.65rem}.sidebar{gap:24px}}@media (max-width: 920px){.app-shell{flex-direction:column}.sidebar{width:100%;position:sticky;top:0;z-index:20;border-right:none;border-bottom:1px solid var(--sidebar-border);padding:20px 16px;background:#111827fa;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sidebar-header{display:flex;flex-direction:column;gap:2px}.nav-links{flex-direction:row;flex-wrap:wrap;gap:10px}.nav-link{flex:1 1 calc(50% - 10px);justify-content:center}.sidebar .btn-ghost{width:100%;margin-top:0}.app-content{margin-left:0;padding:32px 20px 48px}}@media (max-width: 760px){.page{gap:20px}.filters-row{flex-direction:column;align-items:flex-start}.filter-actions{width:100%;justify-content:flex-start}.tabs{width:100%;justify-content:space-between}.my-job-actions{flex-direction:column;align-items:stretch}.my-job-actions .btn{width:100%}.worklog-entry-main{flex-direction:column;align-items:flex-start}.worklog-entry-meta{justify-content:flex-start}.panel{padding:18px}.form-inline{flex-direction:column;align-items:stretch}}@media (max-width: 600px){.sidebar{gap:16px}.nav-links{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px}.nav-link{flex:0 0 auto;min-width:120px}.app-content{padding:24px 16px 36px}.page-header h2{font-size:1.4rem}.page-subtitle{font-size:.9rem}.item,.panel{padding:16px}.item{flex-direction:column;align-items:stretch}}.fc-job-event{font-size:.75rem;display:grid;gap:2px}.fc-job-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-job-meta{display:flex;gap:4px;color:var(--color-muted)}.fc-job-assignees{color:var(--color-muted)}.calendar-panel{overflow-x:auto}.calendar-panel .fc{min-width:720px}.fc-event-inner{font-size:.75rem;display:grid;gap:2px}.fc-event-title{font-weight:600}.fc-event-meta{display:flex;flex-direction:column}@media (max-width: 760px){.calendar-panel .fc-header-toolbar{flex-direction:column;align-items:flex-start;gap:8px}.calendar-panel .fc-toolbar-title{font-size:1rem}.calendar-panel .fc-timegrid-slot-label{font-size:.7rem}.calendar-panel .fc-timegrid-slot{height:2.2em}}
