@import"https://fonts.googleapis.com/css2?family=Manrope:wght@500;600;700&display=swap";.light-pillar-fallback{width:100%;height:100%;position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;background:transparent;color:transparent;font-size:0}.light-pillar-container{width:100%;height:100%;position:absolute;top:0;left:0;pointer-events:none;opacity:1}.light-pillar-container canvas{width:100%;height:100%;display:block;animation:light-pillar-drift 16s ease-in-out infinite;transform-origin:center;will-change:transform,opacity;opacity:1}.light-pillar-container.is-ready{opacity:1}@keyframes light-pillar-drift{0%{transform:scale(1) translateZ(0);opacity:.95}50%{transform:scale(1.03) translate3d(-1.5%,1%,0);opacity:1}to{transform:scale(1.01) translate3d(1%,-1.5%,0);opacity:.9}}:root{font-family:Manrope,Inter,system-ui,-apple-system,sans-serif;color:#0f172a;background-color:#f8fafc;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}*{box-sizing:border-box}.mobile-only{display:none}.desktop-only{display:block}body{margin:0;background:#f1f5f9;color:#0f172a}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;color:#fff}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.menu-toggle{display:none;position:fixed;top:14px;right:14px;width:38px;height:38px;border-radius:10px;border:1px solid rgba(15,23,42,.12);background:#fff;box-shadow:0 10px 25px #0f172a26;z-index:1200;gap:4px;align-items:center;justify-content:center;flex-direction:column}.menu-toggle span{display:block;width:16px;height:2px;background:#0f172a;border-radius:999px;transition:transform .2s ease,opacity .2s ease}.app-shell.menu-open .menu-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}.app-shell.menu-open .menu-toggle span:nth-child(2){opacity:0}.app-shell.menu-open .menu-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.menu-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1100}.app-shell.menu-open .menu-overlay{opacity:1;pointer-events:auto}.sidebar{background:#0b1321;color:#e2e8f0;padding:24px 18px;display:flex;flex-direction:column;gap:22px}.sidebar-brand{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:700}.brand-icon{width:12rem;height:12rem;display:grid;place-items:center}.brand-logo{width:100%;height:100%;object-fit:contain}.nav-group{display:grid;gap:8px}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;color:#cbd5f5;font-weight:600;transition:background .2s ease,color .2s ease}.nav-link.active,.nav-link:hover{background:#0f172acc;color:#fff}.nav-link span{font-size:14px}.sidebar-footer{margin-top:auto;background:#0f172acc;border-radius:16px;padding:16px;color:#94a3b8;font-size:13px}.main{display:flex;flex-direction:column;min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:20px 28px;display:flex;align-items:center;justify-content:space-between}.topbar h1{font-size:22px;margin:0}.topbar-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.badge{background:#e0f2fe;color:#0ea5e9;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700}.button{--btn-blue: #0ea5e9;font-size:15px;letter-spacing:1.6px;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;font-weight:700;padding:.7em 2em;border:3px solid var(--btn-blue);border-radius:6px;position:relative;cursor:pointer;color:var(--btn-blue);background:transparent;box-shadow:0 2px 10px #00000029,0 3px 6px #0000001a;transition:.3s ease all;z-index:1;overflow:hidden;min-height:46px}.app-shell .button{font-size:13px;letter-spacing:.8px;padding:.45em 1.4em;border-width:2px;min-height:36px}.button.compact{font-size:12px;letter-spacing:.6px;padding:.35em 1.1em;min-height:30px;border-width:2px}.button.compact.ghost{background:#0f172a0d}.button:active{transform:scale(.96)}.button.primary{border-color:var(--btn-blue);color:var(--btn-blue)}.button.ghost{border-color:#0f172a4d;color:#0284c7;background:#0f172a08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.content{padding:28px;display:grid;gap:24px}.card{background:#fff;border-radius:18px;padding:20px;box-shadow:0 12px 30px #0f172a14}.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat{display:grid;gap:6px}.stat-title{color:#64748b;font-size:14px;font-weight:600}.stat-value{font-size:28px;font-weight:800}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:10px 0;color:#64748b;font-weight:600;border-bottom:1px solid #e2e8f0}.table td{padding:12px 0;border-bottom:1px solid #f1f5f9}.stack{display:grid;gap:6px}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.calendar-header .topbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;max-width:100%}.calendar-header .button{padding:8px 12px;font-size:12px;white-space:nowrap}.week-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.calendar-grid{overflow-x:auto;max-width:100%}.time-entries-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.time-entries-table{width:100%;min-width:980px}.time-entries-filters{border:0;padding:0;margin:0}.time-entries-filters>summary{list-style:none;cursor:pointer;font-weight:700;color:#0f172a;margin-bottom:8px;display:none}.time-entries-filters>summary::-webkit-details-marker{display:none}.time-entries-section{border:0;margin:0}.time-entries-section>summary{list-style:none;cursor:pointer;font-weight:700;color:#0f172a;margin:8px 0;display:none}.time-entries-section>summary::-webkit-details-marker{display:none}.calendar-table{min-width:980px;width:100%;border-spacing:0 8px;border-collapse:separate;table-layout:fixed}.calendar-table th,.calendar-table td{border-bottom:none;padding:8px;vertical-align:top}.calendar-table th:first-child,.calendar-table td:first-child{width:180px}.calendar-table th:not(:first-child),.calendar-table td:not(:first-child){width:140px}.calendar-table thead th{padding-bottom:8px}.calendar-day{display:grid;gap:4px;text-transform:capitalize}.calendar-day-label{font-size:12px;color:#94a3b8;font-weight:600}.calendar-cell{padding:10px 8px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;min-height:86px}.calendar-cell.has-planned{background:#eef2ff;border-color:#c7d2fe}.calendar-cell.has-worked{background:#ecfdf3;border-color:#bbf7d0}.calendar-cell.has-planned.has-worked{background:linear-gradient(135deg,#eef2ff,#ecfdf3);border-color:#cbd5e1}.calendar-cell.delta-positive{box-shadow:inset 0 0 0 1px #22c55e40}.calendar-cell.delta-negative{box-shadow:inset 0 0 0 1px #ef444440}.calendar-cell.total{background:#eef2ff;border-color:#c7d2fe}.calendar-employee{font-weight:700;color:#0f172a}.calendar-line{display:flex;justify-content:space-between;font-size:12px;font-weight:600}.calendar-line span{color:#64748b;font-weight:500}.calendar-line strong{font-weight:700}.calendar-line.planned strong{color:#2563eb}.calendar-line.worked strong{color:#16a34a}.calendar-times{margin:2px 0 8px;font-size:11px;color:#94a3b8;font-weight:500}.has-tooltip{position:relative}.has-tooltip:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);background:#0f172a;color:#f8fafc;padding:8px 10px;border-radius:8px;font-size:12px;font-weight:500;white-space:pre-line;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:20;max-width:320px;text-align:left;line-height:1.4;box-shadow:0 10px 30px #0f172a2e}.has-tooltip:before{content:"";position:absolute;left:50%;bottom:calc(100% + 2px);transform:translate(-50%);border-width:6px;border-style:solid;border-color:#0f172a transparent transparent transparent;opacity:0;transition:opacity .15s ease,transform .15s ease;pointer-events:none;z-index:20}.has-tooltip:hover:after,.has-tooltip:hover:before,.has-tooltip:focus-visible:after,.has-tooltip:focus-visible:before{opacity:1;transform:translate(-50%) translateY(-2px)}.calendar-total-row td{font-weight:700;background:#f1f5f9}.calendar-legend{display:flex;gap:10px;align-items:center;font-size:12px;color:#475569;font-weight:600;flex-wrap:wrap}.legend-item{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0}.legend-item.planned{background:#eef2ff;border-color:#c7d2fe;color:#1d4ed8}.legend-item.worked{background:#ecfdf3;border-color:#bbf7d0;color:#15803d}.legend-item.delta-positive{background:#dcfce7;border-color:#86efac;color:#166534}.legend-item.delta-negative{background:#fee2e2;border-color:#fecaca;color:#991b1b}.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.legend-dot.planned{background:#2563eb}.legend-dot.worked{background:#16a34a}.day-card{border:1px solid #e2e8f0;border-radius:16px;padding:14px;background:#f8fafc;min-height:160px;display:grid;gap:12px;align-content:start}.day-header{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;text-transform:capitalize}.day-empty{color:#94a3b8;font-size:14px}.shift-chip{background:#fff;border-radius:12px;padding:12px;box-shadow:0 8px 16px #0f172a14;display:grid;gap:8px}.shift-actions{display:flex;gap:8px;align-items:center;justify-content:space-between}.modal-backdrop{position:fixed;inset:0;background:#0f172a80;display:grid;place-items:center;z-index:20;padding:24px}.modal-card{background:#fff;border-radius:20px;padding:24px;width:min(900px,95vw);max-height:90vh;overflow:auto;box-shadow:0 30px 60px #0f172a33;display:grid;gap:16px}.modal-header{display:flex;justify-content:space-between;align-items:center}.tag{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.tag.success{background:#22c55e26;color:#15803d}.tag.warn{background:#f59e0b26;color:#b45309}.tag.danger{background:#ef444426;color:#b91c1c}.form{display:grid;gap:12px}.checkbox{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:#203046;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:#4b6bff;border-radius:6px}.checkbox input[type=checkbox]:focus-visible{outline:2px solid rgba(75,107,255,.35);outline-offset:2px}.checkbox:hover input[type=checkbox]{filter:brightness(.95)}.input-group{display:flex;gap:10px;align-items:center}.input-group .input{flex:1}.input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;background:#fff;color:#0f172a}.input::placeholder{color:#94a3b8}.login-wrapper{min-height:100vh;display:grid;place-items:center;background:radial-gradient(900px 600px at 20% -10%,rgba(34,211,238,.2),transparent 60%),linear-gradient(180deg,#0b1226,#121a35);color:#f8fafc}.login-card{width:min(420px,90vw);background:#0f172ae6;border-radius:20px;padding:32px;box-shadow:0 30px 60px #0f172a73;display:grid;gap:14px}.login-logo{width:280px;height:auto;object-fit:contain}.login-card p{color:#94a3b8;margin-bottom:18px}.error{color:#f87171;font-size:14px}.success{background:#10b9811f;color:#065f46;border:1px solid rgba(16,185,129,.3);padding:10px 12px;border-radius:8px}.login-links{margin-top:12px;text-align:center;font-size:13px}.login-links a{color:#0ea5e9;text-decoration:none;font-weight:600}.login-links a:hover,.login-links a:focus{text-decoration:underline}.reports{display:grid;gap:20px}.reports-head{display:flex;justify-content:space-between;align-items:center;gap:16px}.eyebrow{color:#94a3b8;margin:0 0 6px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:12px}.reports h2{margin:0;font-size:28px}.export-block{position:relative}.export-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid #22c55e;background:linear-gradient(135deg,#34d399,#10b981);color:#064e3b;padding:10px 14px;border-radius:12px;font-weight:700;cursor:pointer;box-shadow:0 10px 24px #10b98147}.export-btn .chevron{font-size:14px}.export-menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:8px;display:grid;gap:6px;min-width:150px;box-shadow:0 20px 40px #0f172a1f;z-index:5}.export-item{padding:10px 12px;border-radius:10px;font-weight:700;color:#0f172a;border:1px solid transparent}.export-item:hover{border-color:#e2e8f0;background:#f8fafc}.filters-card{display:grid;gap:14px}.filters-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.table-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.table-head>div{flex:1 1 280px}.table-head .topbar-actions{justify-content:flex-end}.filter-field{display:grid;gap:6px;font-weight:700;color:#0f172a}.filter-field span{color:#475569;font-weight:700;font-size:14px}.filter-field select,.filter-field input[type=date]{padding:12px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;font-weight:600;color:#0f172a}.icon-btn{border:none;background:#e2f3ff;color:#0ea5e9;border-radius:8px;padding:6px 8px;cursor:pointer;font-size:14px}.icon-btn--secondary{background:#eef2ff;color:#6366f1}.icon-btn svg{width:16px;height:16px;display:block}.icon-btn:hover{background:#d6efff}.icon-btn--secondary:hover{background:#e0e7ff}.icon-btn--disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.icon-btn--disabled:hover{background:#f1f5f9}.photo-actions{display:flex;gap:6px;align-items:center}.photo-modal{position:fixed;inset:0;display:grid;place-items:center;z-index:50}.photo-backdrop{position:absolute;inset:0;background:#0f172a99;border:none}.photo-card{position:relative;z-index:1;background:#fff;border-radius:16px;padding:16px;width:min(90vw,720px);max-height:80vh;box-shadow:0 20px 40px #0f172a59;display:grid;gap:12px}.photo-close{position:absolute;top:10px;right:12px;border:none;background:#f1f5f9;color:#111827;width:30px;height:30px;border-radius:999px;cursor:pointer;font-weight:700}.photo-image{width:100%;height:auto;border-radius:12px;object-fit:contain;max-height:70vh}.filter-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 8px 24px #0f172a0f}.stat-card p{margin:0;color:#475569;font-weight:600}.stat-card strong{font-size:22px}.stat-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:18px;font-weight:700}.stat-icon svg{width:22px;height:22px}.stat-icon.teal{background:#0d94881f;color:#0f766e}.stat-icon.blue{background:#3b82f61f;color:#1d4ed8}.stat-icon.green{background:#22c55e1f;color:#15803d}.stat-icon.purple{background:#8b5cf61f;color:#6b21a8}.chart-card{display:grid;gap:12px}.chart-header h3{margin:0 0 4px}.chart-header .muted{margin:0}.bar-chart{padding:12px 6px 6px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;overflow-x:hidden}.bars{display:grid;gap:16px;align-items:end;padding:8px 6px 12px;border-bottom:1px dashed #cbd5f5;min-height:220px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.bar{display:grid;gap:6px;justify-items:center}.bar-fill{width:64px;min-height:16px;border-radius:14px 14px 6px 6px;background:linear-gradient(180deg,#38bdf8,#0ea5e9);box-shadow:0 8px 16px #0ea5e940}.bar-label{font-weight:700;color:#0f172a;text-align:center}.bar-value{color:#475569;font-size:13px;font-weight:600}.daily-chart{position:relative;min-height:340px;display:grid;align-items:center}.chart-svg{width:100%;height:320px}.chart-grid line{stroke:#c3d4e8;stroke-dasharray:6 6;stroke-width:1.2}.chart-axis text{fill:#94a3b8;font-size:10px;font-weight:600}.chart-line polyline{fill:none;stroke:#0ea5e9;stroke-width:2.2}.chart-line circle{fill:#0ea5e9;r:2.5}.chart-tooltip{position:absolute;top:60px;transform:translate(-50%);background:#fff;border-radius:12px;padding:10px 12px;box-shadow:0 12px 24px #0f172a1f;display:grid;gap:4px;font-size:13px;color:#0f172a;pointer-events:none}.table-clean th,.table-clean td{padding:12px 10px}.custom-report-table{border-radius:12px;overflow:hidden}.custom-report-table thead th{background:#f1f5f9;font-weight:700;color:#0f172a;position:sticky;top:0;z-index:1}.custom-report-table tbody tr:nth-child(2n){background:#f8fafc}.custom-report-table th,.custom-report-table td{border-bottom:1px solid #e2e8f0}.table-clean tbody tr:hover{background:#f8fafc}.note-cell{display:flex;align-items:center;justify-content:space-between;gap:8px}.link-button{border:none;background:transparent;color:#0ea5e9;font-weight:600;cursor:pointer;padding:0}.link-button:disabled{color:#94a3b8;cursor:not-allowed}.quick-filters{display:flex;gap:8px;flex-wrap:wrap}.quick-filters .button.active{background:#1f4fc9;color:#fff;border-color:#1f4fc9}.positive{color:#16a34a;font-weight:700}.negative{color:#ef4444;font-weight:700}.shift-list{border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;background:#fff}.shift-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.shift-filter{padding:8px 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-weight:600;font-size:14px;color:#0f172a}.shift-row{display:grid;grid-template-columns:44px 140px 1fr 140px;align-items:center;gap:16px;padding:16px 18px;border-bottom:1px solid #e2e8f0;font-size:15px}.shift-row:last-child{border-bottom:none}.shift-link{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:#111827;background:#f1f5f9;font-size:16px}.shift-time{color:#111827;font-weight:600}.shift-name{color:#1f2937;font-weight:700}.shift-role{display:flex;justify-content:flex-end}.shift-role-pill{padding:6px 12px;border-radius:10px;font-weight:700;font-size:13px;text-transform:lowercase}.time-entry-mobile-list{display:grid;gap:12px}.time-entry-card{display:grid;gap:10px}.time-entry-card__header{display:flex;justify-content:space-between;align-items:center;gap:10px}.time-entry-card__title{font-weight:800;font-size:16px}.time-entry-card__meta{font-size:12px;color:#64748b;font-weight:600}.time-entry-card__row{display:flex;justify-content:space-between;gap:12px;font-size:13px}.time-entry-card__row span{color:#64748b;font-weight:600}.time-entry-card__row strong{font-weight:700;color:#0f172a;text-align:right}.time-entry-card__actions{display:flex;flex-wrap:wrap;gap:8px}.time-entry-card__actions .link-button{padding:8px 10px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-weight:700;color:#0f172a}.time-entry-card__actions .link-button:disabled{opacity:.6;cursor:not-allowed}.shift-role-empty{color:#9ca3af;font-weight:600}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.menu-toggle{display:inline-flex}.sidebar{position:fixed;top:0;left:0;height:100%;width:260px;transform:translate(-110%);transition:transform .25s ease;z-index:1150}.app-shell.menu-open .sidebar{transform:translate(0)}.sidebar-footer{display:block}.brand-icon{width:8rem;height:8rem}.topbar{padding-right:68px}.content{padding:20px}.table-head{align-items:flex-start}.table-head .topbar-actions{width:100%;justify-content:flex-start}.shift-row{grid-template-columns:36px 1fr;grid-template-areas:"icon time" "icon name" "icon role";align-items:start}.shift-header{flex-direction:column;align-items:flex-start}.shift-filter{width:100%}.shift-link{grid-area:icon}.shift-time{grid-area:time}.shift-name{grid-area:name}.shift-role{grid-area:role;justify-content:flex-start}.desktop-only{display:none!important}.mobile-only{display:block!important}}@media(max-width:720px){.topbar{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 18px}.topbar-actions{width:100%}.topbar-actions .button{white-space:nowrap}.quick-filters{flex-wrap:wrap;gap:8px}.content{padding:18px}.card{padding:16px}.grid-3,.grid-4{grid-template-columns:1fr}.table{display:block;overflow-x:auto;width:100%;min-width:100%;max-width:100%}.desktop-only{display:none}.mobile-only{display:block}.table thead th,.table tbody td{white-space:nowrap}.table-head{align-items:flex-start}.table-head>div{flex:1 1 100%}.table-head .topbar-actions{width:100%;justify-content:flex-start}.filters-grid{grid-template-columns:1fr}.input-group{flex-direction:column;align-items:stretch}.time-entries-page{width:100%}.time-entries-page .card{padding:14px}.time-entries-page .form{gap:12px}.time-entries-page .grid-3{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.time-entries-filters>summary{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#e0f2fe;color:#0ea5e9;font-size:12px}.time-entries-section>summary{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#f1f5f9;color:#0f172a;font-size:12px}.time-entries-page .table-head{align-items:flex-start}.time-entries-page .table-head .topbar-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.time-entries-page .topbar-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-items:stretch}.time-entries-page .topbar-actions>*{width:100%}.time-entries-page .quick-filters,.time-entries-page .export-block{grid-column:1 / -1}.time-entries-page .quick-filters{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.time-entries-page .time-entries-table-scroll{max-height:52vh;overflow-y:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.time-entries-page .export-menu{left:0;right:auto;min-width:100%}.calendar-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-table{min-width:860px}.calendar-table th,.calendar-table td{padding:6px}.calendar-cell{min-height:72px;padding:8px}.calendar-table th:first-child,.calendar-table td:first-child{position:sticky;left:0;background:#fff;z-index:2;box-shadow:8px 0 12px #0f172a0f}.time-entries-table{min-width:640px}.time-entries-table th,.time-entries-table td{padding:8px 10px;font-size:12px;white-space:nowrap}.time-entries-table .col-planning,.time-entries-table .col-pause,.time-entries-table .col-delta,.time-entries-table .col-anomalies,.time-entries-table .col-photo,.time-entries-table .col-history,.time-entries-table .col-note{display:none}}@media(max-width:560px){.time-entries-page .grid-3{grid-template-columns:1fr}.time-entries-table{min-width:520px}.time-entries-table .col-type{display:none}}@media(max-width:560px){.time-entries-page{font-size:14px}.time-entries-page .card h2{font-size:20px}.time-entries-page .card h3{font-size:18px}.time-entries-page .badge{font-size:11px}.time-entries-page .topbar-actions{gap:8px;grid-template-columns:1fr}.time-entries-page .button{font-size:13px;padding:.6em 1.4em;min-height:40px}.time-entries-page .input,.time-entries-page .filter-field select,.time-entries-page .filter-field input[type=date]{font-size:13px;padding:10px 12px}.time-entries-page .filter-field span{font-size:12px}.time-entries-page .table thead th,.time-entries-page .table tbody td{font-size:12px;padding:8px 10px}.time-entries-page .time-entries-table-scroll{margin:0 -6px;padding:0 6px;max-height:48vh}.time-entries-page .export-menu{left:0;right:auto;min-width:100%}.time-entries-page .calendar-grid{max-width:100%}.time-entries-page .calendar-table{min-width:680px}.time-entries-page .calendar-table th:first-child,.time-entries-page .calendar-table td:first-child{width:140px}.time-entries-page .calendar-table th:not(:first-child),.time-entries-page .calendar-table td:not(:first-child){width:120px}}@media(max-width:480px){.time-entries-page{font-size:13px}.time-entries-page .card{padding:14px;border-radius:14px}.time-entries-page .button{font-size:12px;padding:.55em 1.2em;min-height:38px}.time-entries-page .input,.time-entries-page .filter-field select,.time-entries-page .filter-field input[type=date]{font-size:12px;padding:9px 10px}.time-entries-page .filters-grid,.time-entries-page .grid-3,.time-entries-page .grid-4{gap:10px}.time-entries-page .calendar-grid{max-width:100%}.time-entries-page .calendar-table{min-width:620px}}.formula-panel{border:1px solid #fbbf24;background:#fffbeb;border-radius:12px;padding:16px}.formula-panel__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;color:#b45309}.formula-panel__icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#fde68a;color:#b45309;font-weight:700}.formula-panel textarea{width:100%;min-height:120px;border:1px solid #f59e0b;border-radius:10px;padding:12px 14px;font-size:14px;line-height:1.5;color:#0f172a;background:#fff;resize:vertical}.formula-panel textarea::placeholder{color:#9ca3af}.super-admin{display:grid;gap:20px}.super-admin-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(135deg,#f8fbff,#f1f5ff 55%,#eef2ff)}.super-admin-hero h2{margin:6px 0 4px}.super-admin-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.summary-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 24px #0f172a14;border:2px solid transparent;display:grid;gap:6px}.summary-title{color:#64748b;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.summary-value{font-size:26px;font-weight:800}.summary-sub{color:#94a3b8;font-size:12px}.accent-blue{border-color:#0ea5e959}.accent-purple{border-color:#6366f159}.accent-cyan{border-color:#06b6d459}.accent-amber{border-color:#f9731659}.super-admin-filters{display:grid;gap:12px}.filter-row{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,240px) minmax(180px,240px);gap:12px}.muted{color:#94a3b8}.form-error{color:#b91c1c;font-weight:600}.small{font-size:12px}.tag.neutral{background:#94a3b833;color:#475569}.support-page{display:grid;gap:20px}.support-header{display:flex;align-items:center;gap:16px}.support-header h2{font-size:22px;margin:0 0 4px}.support-header p{color:#64748b;font-size:14px;margin:0}.support-icon{width:52px;height:52px;border-radius:14px;background:#0ea5e91f;color:#0ea5e9;display:grid;place-items:center}.support-icon svg{width:22px;height:22px;fill:currentColor}.support-card{background:#fff;border-radius:18px;padding:22px;box-shadow:0 12px 30px #0f172a14;border:1px solid #e2e8f0}.support-card-header h3{font-size:18px;margin:0 0 6px}.support-card-header p{color:#64748b;font-size:14px;margin:0 0 18px}.support-form{display:grid;gap:14px}.support-row{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.support-form label{display:grid;gap:8px;font-size:14px;color:#0f172a;font-weight:600}.support-form input,.support-form textarea{width:100%;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;padding:12px 14px;font-family:inherit;font-size:14px}.support-form input:focus,.support-form textarea:focus{outline:2px solid rgba(14,165,233,.2);border-color:#0ea5e966}.file-field input{padding:10px;background:#f1f5f9}.support-alert{min-height:18px;font-size:13px;color:#64748b}.support-alert.success{color:#16a34a}.support-alert.error{color:#dc2626}.support-form button[disabled]{opacity:.7;cursor:not-allowed}.support-note{border-radius:16px;padding:16px 18px;background:#0ea5e914;border:1px solid rgba(14,165,233,.25);color:#0f172a}.support-note p{color:#475569;font-size:14px;margin:6px 0 0}.privacy-page{min-height:100vh;padding:40px 20px;display:grid;place-items:center;background:#f1f5f9}.privacy-card{width:min(900px,92vw);background:#fff;border-radius:18px;padding:28px;box-shadow:0 12px 30px #0f172a14;border:1px solid #e2e8f0;color:#0f172a;line-height:1.6}.privacy-card h1{margin:0 0 8px;font-size:26px}.privacy-card h2{margin:18px 0 8px;font-size:18px}.privacy-card p{margin:0 0 12px;color:#475569;font-size:14px}.privacy-card ul{margin:0 0 12px 18px;color:#475569;font-size:14px}.landing{min-height:100vh;background:transparent;color:#0f172a;position:relative;display:flex;flex-direction:column;gap:48px;padding:32px 8vw 80px}.landing-bg{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none;opacity:1;background:radial-gradient(circle at 20% 10%,rgba(59,130,246,.35),transparent 45%),radial-gradient(circle at 80% 20%,rgba(14,116,144,.28),transparent 55%),#0b1020;background-size:140% 140%;animation:landing-bg-drift 26s ease-in-out infinite}.landing-bg canvas{opacity:.68;mix-blend-mode:screen;position:absolute;inset:0}.landing-bg .light-pillar-container{opacity:1;z-index:1}.landing-content{position:relative;z-index:2;display:flex;flex-direction:column;gap:48px}.landing-header{display:flex;align-items:center;justify-content:space-between;gap:24px;color:#e2e8f0}.landing-brand{display:flex;align-items:center;gap:12px;justify-content:space-between;width:100%;font-weight:800;font-size:18px}.landing-logo{width:124px;height:124px;object-fit:contain}.landing-brand-name{letter-spacing:.4px}.landing-nav{display:flex;gap:18px;font-weight:600;color:#cbd5f5}.landing-nav a{color:inherit;opacity:.9}.landing-nav-actions{display:none;gap:10px;margin-top:8px;flex-direction:column}.landing-cta{display:flex;gap:12px;align-items:center}.landing-cta .button{min-width:140px;white-space:nowrap}.hamburgers{display:none;justify-content:center;align-items:center}.hamburger{cursor:pointer;padding-bottom:3px;position:relative}.hamburger input{position:absolute;width:100%;height:100%;margin:0;cursor:pointer;opacity:0;z-index:2}.bar{display:block;width:30px;height:3px;margin:6px auto;border-radius:40px;transition:all .3s cubic-bezier(.37,-1.11,.79,2.02);background-color:#e2e8f0}.hamburger input:checked~.bar:nth-child(2){transform:translateY(9.5px) rotate(45deg)}.hamburger input:checked~.bar:nth-child(3){opacity:0}.hamburger input:checked~.bar:nth-child(4){transform:translateY(-8px) rotate(-45deg)}.landing-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:36px;align-items:center;position:relative}.landing-hero-copy{display:grid;gap:18px;color:#e2e8f0;text-shadow:0 6px 18px rgba(5,12,24,.6)}.landing-hero-copy h1{font-size:clamp(32px,4vw,48px);margin:0;color:#f8fafc}.landing-hero-copy p{color:#cbd5f5;font-size:16px;margin:0}.landing-pill{display:inline-flex;width:fit-content;padding:6px 14px;border-radius:999px;background:#0ea5e92e;color:#7dd3fc;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.12em}.landing-actions{display:flex;gap:12px;flex-wrap:wrap}.landing-meta{display:flex;gap:18px;flex-wrap:wrap;color:#94a3b8;font-weight:600;font-size:13px}.landing-hero-card{background:#0f172acc;border-radius:24px;padding:24px;box-shadow:0 20px 60px #0f172a66;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.landing-preview{background:#0b1324;color:#e2e8f0;border-radius:18px;padding:20px;display:grid;gap:16px;border:1px solid rgba(148,163,184,.2)}.landing-hero-card:hover{transform:translateY(-8px);border-color:#38bdf88c;box-shadow:0 28px 60px #050b1a8c}@keyframes softFloat{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.landing-preview{animation:softFloat 6s ease-in-out infinite}.preview-header{font-weight:700;color:#93c5fd}.preview-row{display:flex;justify-content:space-between;align-items:center}.preview-title{margin:0;font-weight:700}.preview-sub{margin:2px 0 0;font-size:13px;color:#94a3b8}.preview-pill{background:#0ea5e9;color:#0b1324;font-weight:700;padding:6px 12px;border-radius:999px;font-size:12px}.preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.preview-stat{background:#0f172ab3;padding:12px;border-radius:14px;display:grid;gap:4px}.preview-stat h4{margin:0;font-size:20px;color:#e2e8f0}.preview-stat span{color:#94a3b8;font-size:12px}.preview-footer{font-size:12px;color:#94a3b8}.landing-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:-8px}.landing-stats .stat-card{background:#f8fafc2e;border:1px solid rgba(148,163,184,.25);border-radius:18px;padding:18px;box-shadow:0 18px 30px #0f172a2e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#e2e8f0;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.landing-stats .stat-card:hover{transform:translateY(-6px);border-color:#38bdf880;box-shadow:0 20px 45px #0f172a59}.landing-stats .stat-card h3{margin:0;font-size:26px;color:#f8fafc}.landing-stats .stat-card p{margin:6px 0 0;color:#cbd5f5;font-weight:600}.landing-section{background:#0f172a47;border:1px solid rgba(148,163,184,.2);border-radius:28px;padding:40px;display:grid;gap:24px;box-shadow:0 24px 44px #0f172a33;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#e2e8f0}.section-title h2{margin:0;color:#f8fafc;font-size:28px}.section-title p{margin:6px 0 0;color:#cbd5f5}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.feature-card{background:#0f172a73;border-radius:18px;padding:18px;box-shadow:0 12px 24px #0f172a4d;border:1px solid rgba(148,163,184,.22);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#e2e8f0;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.feature-card:hover{transform:translateY(-8px);border-color:#38bdf880;box-shadow:0 24px 50px #050b1a73}.feature-card h3{margin:0 0 6px}.feature-card p{margin:0;color:#cbd5f5}.landing-highlight{background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#e2e8f0;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:24px;position:relative}.landing-highlight h2{color:#f8fafc}.highlight-list{display:grid;gap:8px;font-weight:600;color:#cbd5f5}.highlight-card{background:#0f172a99;border-radius:18px;padding:24px;border:1px solid rgba(226,232,240,.2);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.highlight-card:hover{transform:translateY(-6px);border-color:#38bdf880;box-shadow:0 24px 50px #050b1a73}.sector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.sector-card{background:#0f172a66;border-radius:18px;padding:18px;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#e2e8f0;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.sector-card:hover{transform:translateY(-6px);border-color:#38bdf880;box-shadow:0 24px 50px #050b1a73}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.step-card{background:#0f172a66;border-radius:18px;padding:18px;display:grid;gap:8px;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#e2e8f0;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.step-card:hover{transform:translateY(-6px);border-color:#38bdf880;box-shadow:0 24px 50px #050b1a73}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.pricing-card{background:#0f172a73;border-radius:20px;padding:22px;border:1px solid rgba(148,163,184,.25);box-shadow:0 18px 32px #0f172a59;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#e2e8f0;display:grid;gap:16px;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}.pricing-card:hover{transform:translateY(-8px);border-color:#38bdf880;box-shadow:0 30px 60px #050b1a80}.pricing-card.featured{border:1px solid rgba(59,130,246,.6);box-shadow:0 20px 36px #2563eb59}.pricing-card.featured:hover{box-shadow:0 35px 80px #0ea5e959}.pricing-header h3{margin:0 0 6px;font-size:20px}.pricing-header p{margin:0;color:#cbd5f5}.pricing-price{display:flex;align-items:baseline;gap:8px;font-weight:800;color:#f8fafc;font-size:28px}.pricing-price small{font-size:14px;font-weight:600;color:#93c5fd}.pricing-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:#3b82f640;color:#93c5fd;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.pricing-list strong{display:block;margin:12px 0 6px;color:#f8fafc}.pricing-list ul{margin:0 0 8px 18px;padding:0;display:grid;gap:6px}.pricing-list ul.muted{color:#94a3b8}.pricing-page .pricing-card{background:#fff;color:#0f172a;border:1px solid #e2e8f0;box-shadow:0 18px 30px #0f172a1f}.pricing-page .pricing-header p{color:#64748b}.pricing-page .pricing-price{color:#0f172a}.pricing-page .pricing-price small{color:#64748b}.pricing-page .pricing-badge{background:#0ea5e91f;color:#0284c7}.pricing-page .pricing-list strong{color:#0f172a}.pricing-page .pricing-list ul.muted{color:#94a3b8}.pricing-page .pricing-card .button.primary{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.pricing-page .pricing-card .button.primary:before{background:#0ea5e9}.step-card span{font-weight:800;color:#1d4ed8}.landing-cta-section{background:#08101e99;color:#e2e8f0;border:1px solid rgba(148,163,184,.22);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.cta-card{text-align:center;display:grid;gap:12px}.cta-card h2{margin:0;color:#f8fafc}.cta-card p{margin:0;color:#cbd5f5}.landing-footer{display:flex;justify-content:space-between;gap:24px;padding:16px 0 0;color:#cbd5f5}.landing:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#050a1438,#080e1a2e 45%,#080e1a1f);z-index:1;pointer-events:none}@keyframes landing-bg-drift{0%{background-position:0% 0%}50%{background-position:100% 60%}to{background-position:0% 0%}}.footer-brand{display:flex;gap:12px;align-items:center}.footer-brand img{width:64px;height:64px;object-fit:contain}.footer-links{display:flex;gap:48px}.footer-links h4{margin:0 0 8px;color:#e2e8f0}.footer-links a{display:block;color:#cbd5f5;margin-bottom:6px}@media(max-width:980px){.landing-header{flex-direction:column;align-items:flex-start}.landing-hero,.landing-highlight{grid-template-columns:1fr}.landing-footer{flex-direction:column}}@media(max-width:820px){.landing{padding:28px 6vw 72px}.landing-nav{display:none;flex-direction:column;gap:10px;width:100%;padding:14px;border-radius:14px;background:#0f172a80;border:1px solid rgba(148,163,184,.3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:14px}.landing-nav.open,.landing-nav-actions{display:flex}.landing-cta{display:none}.hamburgers{display:inline-flex}.landing-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-section{padding:28px}}@media(max-width:640px){.landing{padding:24px 18px 64px;gap:36px}.landing-hero-copy h1{font-size:clamp(26px,7vw,36px)}.landing-actions .button{width:100%}.landing-hero-card{padding:16px}.preview-grid,.landing-stats,.feature-grid,.sector-grid,.steps-grid,.pricing-grid{grid-template-columns:1fr}.landing-section{padding:22px}.footer-links{flex-direction:column;gap:16px}}.pricing-page,.checkout-page,.profile-page{display:grid;gap:20px}.pricing-intro{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.pricing-actions{display:flex;gap:12px;flex-wrap:wrap}.billing-toggle{display:inline-flex;gap:6px;padding:6px;border-radius:999px;background:#94a3b826}.billing-toggle .button.ghost{border-color:transparent;box-shadow:none;padding:.4em 1.1em;min-height:32px}.billing-toggle .button.ghost.active{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.pricing-footer{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.plan-current{display:flex;align-items:center;gap:12px;font-weight:600}.status-pill{padding:6px 12px;border-radius:999px;background:#0ea5e91f;color:#0ea5e9;font-size:12px;font-weight:700}.pricing-alert{border:1px solid rgba(239,68,68,.3);color:#b91c1c}.checkout-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:20px}.checkout-section{margin-top:20px;display:grid;gap:10px}.checkout-list{margin:0;padding-left:18px;color:#475569}.promo-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.checkout-alert{margin-top:10px;padding:10px 12px;border-radius:10px;font-size:13px}.checkout-alert.success{background:#22c55e1f;color:#15803d}.checkout-alert.error{background:#ef44441f;color:#b91c1c}.checkout-note{margin-top:20px;padding:12px 14px;border-radius:12px;background:#0ea5e914;color:#0369a1}.checkout-summary{display:grid;gap:12px;align-self:start}.summary-row{display:flex;justify-content:space-between;font-size:14px}.summary-total{margin-top:8px;padding-top:12px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;font-size:16px;font-weight:700}.profile-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.profile-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(148,163,184,.4);font-size:14px}.profile-row:last-child{border-bottom:none}.profile-alert{padding:12px 16px;border-radius:12px;font-size:14px;background:#f973161f;color:#9a3412}.profile-alert.success{background:#22c55e1f;color:#15803d}.profile-alert.error{background:#ef44441f;color:#b91c1c}.profile-actions{display:grid;gap:12px;align-content:start}.row-menu{position:relative;display:inline-flex}.row-menu-button{border:1px solid #e2e8f0;background:#fff;border-radius:8px;padding:6px 8px;font-size:18px;line-height:1;color:#0f172a;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.row-menu-icon{font-size:18px;line-height:1}.button.ghost.danger{border-color:#ef444466;color:#b91c1c}.row-menu-list{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 12px 24px #0f172a1f;display:grid;z-index:5;min-width:140px}.row-menu-item{background:transparent;border:none;padding:10px 12px;text-align:left;cursor:pointer;font-size:14px;color:#0f172a}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.detail-row{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;font-size:13px;color:#475569}.detail-row strong{color:#0f172a;font-size:14px}.profile-form{display:grid;gap:16px}.profile-form-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.profile-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.profile-form-grid label{display:grid;gap:6px;font-size:13px;color:#475569}.profile-input{border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;font-size:14px;background:#fff;color:#0f172a}.profile-input:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.profile-form-actions{display:flex;justify-content:flex-end}@media(max-width:960px){.checkout-grid,.promo-row{grid-template-columns:1fr}.pricing-intro{align-items:flex-start}}
