:root{--bg:#f3f6ef;--surface:#ffffffe0;--surface-strong:#fff;--surface-border:#80968b2e;--text:#26403a;--muted:#6f8780;--accent:#5eaf97;--accent-soft:#5eaf971f;--danger:#c96a3d;--shadow:0 18px 44px #35554a14}*{box-sizing:border-box}html{background:var(--bg);min-height:100%}body{color:var(--text);background:radial-gradient(circle at 0 0,#5eaf9724,#0000 28%),radial-gradient(circle at 100% 0,#e8be7a1f,#0000 24%),linear-gradient(#f8faf6 0%,#f1f5ef 100%);min-height:100vh;margin:0;font-family:Manrope,Segoe UI,sans-serif}.auth-layout{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select{font:inherit}button{cursor:pointer}input,select{border:1px solid var(--surface-border);width:100%;color:var(--text);background:#fffffff0;border-radius:14px;padding:.8rem .95rem;transition:border-color .16s,box-shadow .16s,background .16s}input:focus,select:focus{border-color:#4fa38d80;outline:none;box-shadow:0 0 0 4px #5eaf9714}.shell{grid-template-columns:220px minmax(0,1fr);min-height:100vh;display:grid}.mobile-topbar,.mobile-sidebar-backdrop{display:none}.sidebar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fafcf9cc;border-right:1px solid #80968b24;flex-direction:column;gap:1.5rem;padding:1.5rem 1rem;display:flex}.brand-block{justify-content:center;align-items:center;padding:.25rem .5rem .9rem;display:flex}.brand-logo{object-fit:contain;width:min(100%,200px);height:auto}.eyebrow{color:var(--muted);letter-spacing:.14em;text-transform:uppercase;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;display:inline-flex}.nav-list{gap:.45rem;display:grid}.sidebar-footer{margin-top:auto;padding:.35rem .4rem 0}.nav-link{color:var(--muted);border:1px solid #0000;border-radius:14px;padding:.75rem .9rem;font-weight:600;transition:background .18s,color .18s,transform .18s,border-color .18s}.nav-link:hover,.nav-link.active{color:var(--text);background:#ffffffeb;border-color:#80968b24;transform:none}.main-content{width:100%;max-width:1160px;padding:1.75rem 2.25rem 2.25rem}.page-stack{gap:1.25rem;display:grid}.page-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.page-header h2{letter-spacing:-.055em;margin:.15rem 0 0;font-size:clamp(1.65rem,2.7vw,2.2rem);font-weight:800}.page-header-meta{color:var(--muted);background:#ffffffbd;border-radius:999px;align-items:center;padding:.8rem 1rem;font-weight:700;display:inline-flex}.stack{gap:1rem;display:grid}.section-row,.panel-header,.modal-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.section-caption{color:var(--muted);margin:0;font-size:.94rem}.section-title{letter-spacing:-.03em;margin:.2rem 0 0;font-size:1.15rem}.panel-heading-stack{gap:.2rem;display:grid}.toolbar-caption{color:var(--muted);font-size:.84rem;font-weight:600}.content-grid{grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr);gap:1.5rem;display:grid}.km-header-grid{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:1rem;display:grid}.card-grid{grid-template-columns:repeat(auto-fit,minmax(190px,220px));gap:.85rem;display:grid}.card,.panel,.modal-panel{border:1px solid var(--surface-border);background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:22px}.card{gap:.5rem;min-height:116px;padding:1rem 1rem .95rem;transition:transform .18s,border-color .18s,box-shadow .18s;display:grid;position:relative}.card:hover{border-color:#5eaf972e;transform:translateY(-2px);box-shadow:0 20px 34px #35554a1a}.card-body{align-content:start;gap:.45rem;display:grid}.card-body.compact{gap:.18rem}.card-body h4{letter-spacing:-.03em;margin:0;font-size:1rem;font-weight:700}.card-body p{color:var(--muted);margin:0;line-height:1.5}.card-meta{min-height:30px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;background:#fafcfaeb;border:1px solid #80968b24;border-radius:999px;align-items:center;padding:.35rem .65rem;font-size:.76rem;font-weight:800;display:inline-flex}.card-link-cover{align-content:space-between;gap:.75rem;min-height:100%;display:grid}.dashboard-page{gap:1.25rem;display:grid}.dashboard-section{gap:1rem;display:grid}.dashboard-group{gap:.9rem;display:grid}.dashboard-group-panel{background:linear-gradient(#fff9,#f8fbf9ad);border:1px solid #80968b24;border-radius:20px;padding:.35rem}.dashboard-section-header{align-items:center;padding:.4rem .45rem 0}.dashboard-inline-button{padding:.62rem .92rem;font-size:.86rem}.dashboard-card{cursor:grab;background:radial-gradient(circle at 100% 0,#5eaf971f,#0000 42%),linear-gradient(#fffffff5,#f9fcfaf0);overflow:hidden}.dashboard-card.dragging{opacity:.62;border-color:#5eaf975c;transform:scale(.985)}.dashboard-drag-handle{color:var(--muted);letter-spacing:-.16em;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:.72;font-size:.9rem;position:absolute;top:.75rem;right:.82rem}.dashboard-remove-button{z-index:2;width:28px;height:28px;color:var(--danger);background:#fff7f5f2;border:1px solid #c2410c26;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:.72rem;right:2.15rem}.dashboard-remove-button svg{width:14px;height:14px}.dashboard-card-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.dashboard-card-footer{justify-content:space-between;align-items:center;gap:.75rem;margin-top:auto;display:flex}.dashboard-card-arrow{width:30px;height:30px;color:var(--muted);background:#ffffffdb;border:1px solid #80968b24;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:.92rem;display:inline-flex}.dashboard-empty{border:1px dashed var(--surface-border);color:var(--muted);text-align:center;background:#ffffff8c;border-radius:18px;grid-column:1/-1;padding:1.5rem}.panel{padding:1.3rem}.records-panel{padding:1rem}.records-panel-header{border-bottom:1px solid #27423d14;padding:.05rem .15rem .9rem}.km-batch-panel{padding:1.1rem}.km-batch-form,.km-batch-form .form-grid{gap:.85rem}.km-batch-form .field{gap:.4rem}.km-batch-form .field span{font-size:.84rem}.km-batch-actions{gap:.6rem}.actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.actions.compact{gap:.55rem}.primary-button,.secondary-button,.ghost-button,.icon-button,.primary-icon{border:1px solid #0000;border-radius:999px;transition:transform .16s,opacity .16s,border-color .16s,background .16s,box-shadow .16s}.primary-button,.secondary-button,.ghost-button{padding:.78rem 1rem;font-weight:700}.primary-button{color:#fff;background:linear-gradient(135deg,#5eaf97 0%,#4d9f88 100%);box-shadow:0 12px 24px #5eaf972e}.secondary-button{color:var(--text);border-color:var(--surface-border);background:#ffffffdb}.ghost-button{color:var(--muted);background:0 0}.ghost-button.danger{color:var(--danger)}.icon-button{width:42px;height:42px;color:var(--text);border-color:var(--surface-border);background:#ffffffdb;justify-content:center;align-items:center;display:inline-flex}.primary-icon{color:#fff;background:linear-gradient(135deg,#5eaf97 0%,#4d9f88 100%);box-shadow:0 12px 24px #5eaf972e}.icon-button svg{width:20px;height:20px}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.icon-button:hover{transform:translateY(-1px)}.status{border-radius:16px;margin:0;padding:.9rem 1rem;font-weight:600}.status.success{color:#2f7f6b;background:#4fa38d24}.status.error{color:var(--danger);background:#c2410c1a}.status-toast{z-index:70;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #0000;border-radius:16px;max-width:min(420px,100vw - 2rem);padding:.95rem 1rem;font-weight:700;line-height:1.45;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 18px 40px #181a1f1f}.status-toast.success{color:#2f7f6b;background:#f4faf7f5;border-color:#4fa38d38}.status-toast.error{color:var(--danger);background:#fff7f5f5;border-color:#c2410c29}.field{gap:.5rem;display:grid}.field span{color:var(--muted);font-size:.92rem;font-weight:700}.auth-page{background:radial-gradient(circle at 0 0,#4fa38d2e,#0000 30%),linear-gradient(#f8fbf7 0%,#eef6f1 100%);place-items:center;min-height:100vh;padding:1.5rem;display:grid}.auth-panel{background:#fffffff0;border:1px solid #dde6e1f5;border-radius:24px;gap:1.2rem;width:min(100%,420px);padding:1.5rem;display:grid;box-shadow:0 24px 60px #335c511a}.auth-logo{width:auto;height:58px}.auth-copy{gap:.35rem;display:grid}.auth-copy h1{letter-spacing:-.05em;margin:0;font-size:clamp(1.7rem,3vw,2.1rem)}.auth-copy p{color:var(--muted);margin:0;line-height:1.55}.auth-form{gap:1rem;display:grid}.auth-submit{justify-content:center}.auth-error,.sign-out-error{color:var(--danger);margin:0;font-size:.88rem;font-weight:600}.auth-success{color:#2f7f6b;margin:0;font-size:.88rem;font-weight:600}.auth-secondary-link{color:var(--muted);text-align:left;font-size:.9rem;font-weight:700}.sign-out-stack{gap:.45rem;display:grid}.sign-out-button{justify-content:flex-start;padding-inline:.55rem}.hidden-file-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.mobile-hidden{display:inline-flex}.file-trigger{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.file-trigger.disabled{opacity:.6;cursor:not-allowed}.multi-select{position:relative}.multi-select-trigger{border:1px solid var(--surface-border);width:100%;color:var(--text);font:inherit;background:#fffffff0;border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;padding:.82rem .95rem;display:flex}.multi-select-trigger svg{width:16px;height:16px;color:var(--muted)}.multi-select-menu{z-index:20;border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff5;border-radius:16px;gap:.25rem;padding:.45rem;display:grid;position:absolute;top:calc(100% + .45rem);left:0;right:0;box-shadow:0 22px 44px #35554a1a}.multi-select-option{color:var(--text);border-radius:12px;align-items:center;gap:.65rem;padding:.7rem .75rem;display:flex}.multi-select-option.selected{background:#4fa38d1a}.multi-select-option input{width:16px;height:16px;accent-color:var(--accent)}.multi-select-empty{color:var(--muted);padding:.7rem .75rem}.tag-list{flex-wrap:wrap;gap:.5rem;display:flex}.tag-pill{color:var(--accent);font:inherit;background:#5eaf971c;border:1px solid #5eaf972e;border-radius:999px;padding:.48rem .7rem}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.calendar-toolbar{flex-wrap:wrap;align-items:center;gap:.6rem;width:100%;display:flex}.calendar-nav-button{width:40px;height:40px}.calendar-select{min-width:0}.month-select{width:140px}.year-select{width:104px}.select-shell{align-items:center;display:inline-flex;position:relative}.select-shell select,.compact-select{appearance:none;padding-right:2rem}.select-shell-icon{color:var(--muted);pointer-events:none;justify-content:center;align-items:center;display:inline-flex;position:absolute;right:.75rem}.select-shell-icon svg{width:14px;height:14px}.calendar-weekdays{margin:1rem 0 .9rem}.calendar-weekday{color:var(--muted);text-align:center;padding-inline:.35rem;font-size:.82rem;font-weight:700}.calendar-day{aspect-ratio:1;border:1px solid var(--surface-border);text-align:center;color:var(--text);background:#ffffffd1;border-radius:999px;justify-content:center;align-items:center;width:100%;max-width:54px;margin-inline:auto;padding:0;transition:background .16s,border-color .16s,transform .16s,color .16s;display:inline-flex}.calendar-day span{font-size:1.05rem;font-weight:700}.calendar-day.muted{opacity:.42}.calendar-day.has-entry{color:#2f7d4c;background:#7acd9a29;border-color:#53a87642}.calendar-day.holiday{color:#b55a3b;background:#f4a0922e;border-color:#de655138}.calendar-day.selected{border-color:var(--accent);color:#fff;background:linear-gradient(135deg,#5eaf97 0%,#4d9f88 100%)}.calendar-day.has-entry.selected{color:#fff;background:#3d9a7e;border-color:#3d9a7e}.calendar-day.holiday.selected{color:#fff;background:#dc2626;border-color:#dc2626}.selection-summary{color:var(--muted);background:linear-gradient(#ffffffe6,#f6faf7e0);border:1px solid #80968b24;border-radius:18px;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;display:flex}.selection-summary strong{color:var(--text)}.selected-date-list{flex-wrap:wrap;gap:.55rem;min-height:1.5rem;display:flex}.date-pill{color:var(--accent);background:#5eaf971a;border:1px solid #5eaf972e;border-radius:999px;padding:.62rem .78rem}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.records-table{min-width:700px}.data-table th,.data-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #27423d14;padding:.95rem .75rem}.data-table th{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;font-weight:800}.data-table td input{width:100%;min-width:0;box-shadow:none;background:#fcfefd;border-color:#6d857f38;border-radius:12px;padding:.72rem .8rem}.data-table td input:focus{background:#fff;border-color:#4fa38d6b;box-shadow:0 0 0 4px #4fa38d14}.checkbox-cell{width:36px;min-width:36px;padding-right:.25rem}.checkbox-cell input{width:16px;height:16px;accent-color:var(--accent)}.work-hours-table .hours-cell{width:118px}.work-hours-table .hours-cell input{width:84px;min-width:84px}.compact-row-actions{width:120px;min-width:120px}.row-actions{justify-items:end;gap:.3rem;width:120px;min-width:120px;display:grid}.table-action-button,.table-action-link{font:inherit;font-size:.84rem;font-weight:700}.table-action-button{min-height:38px;color:var(--text);background:#fff;border:1px solid #6d857f2e;border-radius:10px;padding:.5rem .75rem}.table-action-link{color:var(--muted);background:0 0;border:0;padding:.15rem 0}.table-action-link.danger{color:var(--danger)}.table-action-button:hover,.table-action-link:hover{opacity:.82;transform:none}.soft-table-wrap{background:linear-gradient(#fffffffa,#f8fbf9f5);border:1px solid #27423d14;border-radius:20px;overflow:hidden}.records-table tbody tr{transition:background .16s}.records-table tbody tr:hover{background:#4fa38d0a}.records-table tbody tr.selected-row{background:#4fa38d12}.records-table tbody tr:last-child td{border-bottom:0}.records-bulk-actions{gap:.45rem}.records-bulk-actions .secondary-button,.records-bulk-actions .ghost-button{border-radius:12px;padding:.65rem .82rem;font-size:.86rem}.records-bulk-actions .ghost-button{background:0 0;border:1px solid #0000}.table-tools{grid-template-columns:minmax(140px,auto) 110px auto 42px;align-items:center;gap:.8rem;display:grid}.work-tools{grid-template-columns:minmax(140px,auto) 110px auto auto 42px}.table-tools-panel{background:linear-gradient(#ffffffe0,#f7faf8d6);padding:.8rem .95rem}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.page-toolbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.page-toolbar-actions>*{flex-shrink:0}.list-actions{justify-content:flex-end}.overview-inline-card{min-width:0;color:var(--text);background:linear-gradient(#f1faf6f5,#fbfffdf2);border:1px solid #5eaf9729;border-radius:18px;gap:.15rem;padding:.65rem .9rem;display:grid}.overview-inline-label{color:var(--muted);font-size:.8rem;font-weight:700}.overview-inline-card strong{letter-spacing:-.02em;font-size:1rem}.year-filter{gap:0;width:110px;min-width:110px;position:relative}.year-filter select{border-radius:999px;padding:.65rem 2rem .65rem .8rem;line-height:1.2}.no-arrow{background-image:none;padding-right:.8rem}.empty-cell{color:var(--muted);text-align:center;padding:2.25rem 1rem}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;background:#1c232047;place-items:center;padding:1.5rem;display:grid;position:fixed;inset:0}.modal-panel{background:#fffffff5;width:min(720px,100%);max-height:calc(100vh - 3rem);padding:1.3rem;overflow:auto}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.preset-row{grid-template-columns:minmax(0,1fr) auto auto;gap:.7rem;display:grid}@media (max-width:1080px){.shell{grid-template-columns:1fr}.mobile-topbar{z-index:25;border-bottom:1px solid var(--surface-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fbfdfbf0;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;display:flex;position:sticky;top:0}.mobile-topbar-brand{pointer-events:none;flex:1;justify-content:center;align-items:center;min-width:0;display:inline-flex}.mobile-brand-logo{width:auto;max-width:min(56vw,180px);height:38px}.mobile-menu-button{border:1px solid var(--surface-border);width:44px;height:44px;color:var(--text);background:#ffffffeb;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:.22rem;display:inline-flex}.mobile-menu-button span{background:currentColor;border-radius:999px;width:16px;height:1.75px}.mobile-sidebar-backdrop{z-index:29;background:#181a1f47;border:0;display:block;position:fixed;inset:0}.sidebar{z-index:30;border-right:1px solid var(--surface-border);border-bottom:0;gap:1rem;width:min(300px,84vw);transition:transform .18s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:0 24px 48px #181a1f24}.sidebar.mobile-open{transform:translate(0)}.nav-list,.content-grid,.km-header-grid{grid-template-columns:1fr}}@media (min-width:1081px){.sidebar{transform:none!important}}@media (max-width:720px){.main-content,.auth-page{padding:1rem}.auth-panel{border-radius:20px;padding:1.2rem}.mobile-topbar{padding:.85rem 1rem;top:0}.dashboard-header,.dashboard-header-actions,.dashboard-section-header,.page-header,.section-row,.panel-header,.modal-header{flex-direction:column;align-items:flex-start}.table-tools{grid-template-columns:1fr;width:100%}.page-toolbar,.page-toolbar-actions,.list-actions{width:100%}.page-toolbar-actions{justify-content:flex-start}.form-grid,.preset-row{grid-template-columns:1fr}.calendar-grid{gap:.45rem}.calendar-toolbar{grid-template-columns:40px minmax(0,1fr) minmax(0,92px) 40px;gap:.5rem;width:100%;display:grid}.calendar-day{max-width:48px}.month-select,.year-select{width:100%}.selection-summary{flex-direction:column;align-items:flex-start}.mobile-action-group{grid-template-columns:1fr;width:100%;display:grid}.mobile-action-group>*{justify-content:center;width:100%}.mobile-hidden,.mobile-hidden-panel,.responsive-table thead{display:none}.responsive-table,.responsive-table tbody,.responsive-table tr,.responsive-table td{width:100%;display:block}.responsive-table tbody{gap:.85rem;display:grid}.responsive-table tr{border:1px solid var(--surface-border);background:#ffffffb8;border-radius:16px;padding:.95rem}.responsive-table td{border-bottom:0;padding:0}.responsive-table td+td{margin-top:.7rem}.responsive-table td:before{content:attr(data-label);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.35rem;font-size:.75rem;font-weight:800;display:block}.responsive-table td input{width:100%;min-width:0}.responsive-table .row-actions,.responsive-table .compact-row-actions{justify-items:stretch;gap:.55rem;width:100%;min-width:0;display:grid}.responsive-table .row-actions button,.responsive-table .compact-row-actions button{justify-content:center;width:100%}.responsive-table .row-actions .table-action-link,.responsive-table .compact-row-actions .table-action-link{text-align:center}.responsive-table .checkbox-cell{width:100%;min-width:0;padding-right:0}.responsive-table .hours-cell{width:100%}.status-toast{max-width:none;bottom:1rem;left:1rem;right:1rem}}
