:root{--bg:#f4f5fa;--panel:#fff;--nav:#fff;--nav-2:#f7f7fb;--nav-text:#5d6679;--text:#111827;--muted:#6b7280;--line:#dde2ef;--blue:#7367f0;--green:#22c55e;--amber:#eab308;--red:#ef4444;--cyan:#06b6d4;--shadow:0 12px 30px #0f172a12;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,Segoe UI,Roboto,Arial,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;margin:0}body:before{content:"";z-index:-1;background:var(--bg);position:fixed;inset:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.login{background:linear-gradient(120deg,#111827db,#0e7490b8),url(/og-image.png) 50%/cover;grid-template-columns:minmax(0,1fr) 430px;min-height:100svh;display:grid}.login-hero{color:#fff;flex-direction:column;justify-content:space-between;padding:42px;display:flex}.login-copy{max-width:680px}.login-copy h1{letter-spacing:0;margin:0;font-size:52px;line-height:1.02}.login-copy p{color:#d7ecf7;max-width:560px;margin:18px 0 0;font-size:18px}.login-panel{background:#fff;border-radius:8px;align-self:center;margin:28px;padding:30px;box-shadow:0 24px 80px #0000003d}.login-panel h2{margin:6px 0 22px;font-size:26px}.section-kicker{color:var(--blue);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:800}.logo-row{align-items:center;gap:12px;min-width:0;display:flex}.logo-row strong{color:inherit;white-space:nowrap;font-size:16px;line-height:1.15;display:block}.logo-row small{color:#94a3b8;margin-top:3px;font-size:11px;display:block}.logo-box{color:#fff;background:linear-gradient(135deg,#0ea5e9,#0369a1);border-radius:8px;flex:none;place-items:center;width:38px;height:38px;display:grid;box-shadow:inset 0 1px #ffffff47}.field{color:#334155;gap:7px;margin-bottom:14px;font-size:13px;font-weight:700;display:grid}.field input,.field select,.field textarea{border:1px solid var(--line);width:100%;color:var(--text);background:#fff;border-radius:7px;outline:none;padding:10px 11px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0ea5e924}.check-field{color:#334155;align-items:center;gap:10px;font-size:13px;font-weight:700;display:flex}.check-field input{width:17px;height:17px}.error{color:#b4232a;background:#fff1f2;border-radius:7px;margin-bottom:14px;padding:10px 12px}.btn,.mini,.icon-btn{border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex}.btn{min-height:40px;padding:10px 14px}.btn.primary{color:#fff;background:var(--blue)}.btn.secondary{color:#1f2937;background:#e8eef5}.mini{color:#fff;min-height:30px;padding:6px 9px;font-size:12px}.mini.success{background:var(--green)}.mini.danger{background:var(--red)}.icon-btn{color:#cbd5e1;background:#253244;border:1px solid #334155;width:30px;height:30px}.collapse-btn{color:#5d6679;background:#f1f2f8;border-color:#dde2ef}.shell{background:var(--bg);grid-template-columns:260px minmax(0,1fr);gap:0;min-height:100svh;padding:0;transition:grid-template-columns .18s;display:grid}.shell.collapsed{grid-template-columns:78px minmax(0,1fr)}.sidebar{background:var(--nav);min-height:100svh;color:var(--nav-text);border:0;border-right:1px solid var(--line);border-radius:0;flex-direction:column;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;min-height:74px;padding:18px 16px;display:flex}.collapse-btn{border-radius:999px;margin-left:auto}.nav{gap:4px;padding:18px 12px;display:grid}.nav button{width:100%;min-height:43px;color:var(--nav-text);text-align:left;background:0 0;border:0;border-radius:7px;align-items:center;gap:12px;padding:0 10px;display:flex}.nav button.active,.nav button:hover{color:var(--blue);background:#7367f01a}.nav button.active{color:var(--blue);box-shadow:none;background:#7367f024}.nav svg{flex:none}.sidebar-user{border-top:1px solid var(--line);align-items:center;gap:10px;margin-top:auto;padding:14px 16px;display:flex}.sidebar-scene{background:linear-gradient(#0000 10%,#010b16b8 68%),url(/sidebar-machinery.png) top/cover;border:1px solid #94a3b838;border-radius:8px;align-items:flex-end;min-height:260px;margin:auto 14px 18px;padding:12px;display:none}.commit-card{color:#fff;background:#041328c7;border:1px solid #60a5fa73;border-radius:10px;align-items:center;gap:10px;width:100%;padding:12px;display:flex}.commit-card svg{color:#bfdbfe;flex:none}.commit-card strong{font-size:12px;line-height:1.25;display:block}.commit-card span{color:#2990ff;margin-top:3px;font-size:11px;font-weight:800;display:block}.sidebar-user strong{color:#2f3349;font-size:13px;display:block}.sidebar-user small{text-overflow:ellipsis;color:#81899d;max-width:170px;font-size:11px;display:block;overflow:hidden}.avatar{color:#cffafe;background:#0f7490;border-radius:999px;place-items:center;width:34px;height:34px;font-weight:800;display:grid}.logout{min-height:52px;color:var(--nav-text);border:0;border-top:1px solid var(--line);background:0 0;align-items:center;gap:12px;padding:0 24px;font-size:15px;display:flex}.collapsed .logo-text,.collapsed .nav span,.collapsed .sidebar-user div,.collapsed .logout span,.collapsed .collapse-btn{display:none}.collapsed .sidebar-head,.collapsed .sidebar-user,.collapsed .logout{justify-content:center;padding-inline:10px}.collapsed .nav button{justify-content:center;padding:0}.workspace{min-width:0;padding:24px}.workspace>.page-header,.workspace>.panel,.workspace>.kpi-grid,.workspace>.panel-grid,.workspace>.report-grid,.workspace>.settings-grid{margin-left:0}.page-header{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:24px;display:flex}.dashboard-composition{grid-template-columns:minmax(0,1fr);align-items:start;gap:0;display:grid}.dashboard-main-card{min-height:calc(100svh - 48px);box-shadow:none;background:0 0;border:0;border-radius:0;padding:0}.dashboard-top{border:1px solid var(--line);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:20px;margin-bottom:18px;padding:18px 20px;display:flex;box-shadow:0 2px 8px #0f172a0a}.dashboard-top h1{letter-spacing:0;margin:0;font-size:25px}.dashboard-top p{color:#64748b;margin:7px 0 0;font-size:13px}.dashboard-actions{align-items:center;gap:18px;display:flex}.bell-btn{color:#263852;background:0 0;border:0;width:40px;height:40px;position:relative}.bell-btn span{color:#fff;background:#1479ff;border-radius:999px;place-items:center;width:17px;height:17px;font-size:10px;font-weight:900;display:grid;position:absolute;top:3px;right:5px}.profile-chip{color:#0f172a;align-items:center;gap:10px;display:flex}.profile-chip strong{font-size:13px;display:block}.profile-chip small{color:#475569;font-size:12px}.profile-photo{color:#0f172a;background:linear-gradient(#f8fafc,#dbeafe);border:1px solid #dbe4ef;border-radius:999px;place-items:center;width:44px;height:44px;display:grid}.outline-btn,.year-select{color:#0f3d83;background:#fff;border:1px solid #1479ff;border-radius:7px;align-items:center;gap:8px;min-height:39px;padding:0 15px;font-size:13px;font-weight:800;display:inline-flex}.year-select{color:#334155;border-color:#d8e5f6;min-height:34px;box-shadow:0 4px 12px #0f172a0a}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px;display:grid}.metric-card{background:#fff;border:1px solid #e4ebf5;border-radius:8px;min-height:142px;padding:13px 15px 10px;box-shadow:0 2px 8px #0f172a0a}.metric-head{align-items:center;gap:10px;margin-bottom:6px;display:flex}.metric-head h3{color:#0f172a;margin:0;font-size:14px;line-height:1.25}.metric-icon{color:#fff;border-radius:10px;place-items:center;width:36px;height:36px;display:grid}.metric-blue{background:linear-gradient(135deg,#3182ff,#045ee5)}.metric-green{background:linear-gradient(135deg,#30d070,#13a34a)}.metric-orange{background:linear-gradient(135deg,#ffba3a,#fb7b19)}.metric-red{background:linear-gradient(135deg,#ff6a6a,#ef3338)}.metric-card strong{margin-left:46px;font-size:24px;line-height:1;display:block}.metric-card small{color:#64748b;margin:5px 0 0 46px;display:block}.sparkline{width:100%;height:44px;margin-top:5px;display:block;overflow:visible}.analytics-grid{grid-template-columns:minmax(0,1.12fr) minmax(0,.95fr) minmax(300px,.58fr);gap:16px;margin-bottom:16px;display:grid}.glass-panel{background:#fff;border:1px solid #e4ebf5;border-radius:8px;box-shadow:0 2px 8px #0f172a0a}.hours-panel,.project-panel,.trifr-panel{min-height:390px;padding:18px}.panel-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.panel-title-row h3,.project-panel h3,.trifr-panel h3{color:#172033;align-items:center;gap:8px;margin:0;font-size:16px;display:flex}.project-content{align-items:center;gap:14px;min-height:325px;display:flex;position:relative}.project-content .recharts-responsive-container{flex:0 0 52%;min-width:240px}.project-total{text-align:center;pointer-events:none;position:absolute;top:48%;left:26%;transform:translate(-50%,-50%)}.project-total strong{font-size:22px;display:block}.project-total span{color:#64748b;font-size:11px}.project-legend{flex:1;gap:13px;font-size:11px;display:grid}.project-legend div{grid-template-columns:10px minmax(78px,1fr) 42px 54px;align-items:center;gap:8px;display:grid}.project-legend span{border-radius:999px;width:9px;height:9px}.project-legend strong{color:#0f172a;font-size:11px}.project-legend em{color:#475569;text-align:right;font-style:normal}.project-legend small{color:#475569;text-align:right}.trifr-panel{align-content:start;justify-items:center;display:grid}.gauge{text-align:center;width:220px;height:146px;margin-top:24px;position:relative}.gauge-arc{background:conic-gradient(from 270deg, #20c768 0 38%, #ffb22e 38% 63%, #ff7433 63% 78%, #ff4248 78% 100%);clip-path:polygon(0 0,100% 0,100% 72%,0 72%);border-radius:180px 180px 0 0;position:absolute;inset:0}.gauge-arc:after{content:"";background:#fff;border-radius:130px 130px 0 0;position:absolute;inset:18px 18px -2px}.gauge strong{z-index:1;padding-top:74px;font-size:34px;display:block;position:relative}.gauge small{z-index:1;color:#64748b;margin-top:4px;display:block;position:relative}.target-badge{color:#16a34a;background:#d9f7e4;border-radius:999px;margin:16px 0 18px;padding:7px 16px;font-size:12px;font-weight:900;display:inline-flex}.trifr-list{border-top:1px solid #edf2f7;width:100%;margin-top:6px}.trifr-list div{color:#64748b;border-bottom:1px solid #edf2f7;justify-content:space-between;align-items:center;gap:12px;min-height:43px;font-size:11px;display:flex}.trifr-list strong{color:#0f172a}.trifr-link{color:#1479ff;justify-self:stretch;margin-top:16px;font-size:12px;font-weight:900}.records-panel{padding:16px 18px}.records-panel .table-wrap{border:1px solid #e6edf6;border-radius:10px;overflow:hidden}.records-panel table{min-width:720px}.records-panel th,.records-panel td{padding:10px 13px;font-size:12px}.records-panel th{background:#f8fafc}.mobile-register-card{border:1px solid var(--line);background:#fff;border-radius:8px;min-height:auto;margin-bottom:24px;overflow:hidden;box-shadow:0 2px 8px #0f172a0a}.register-hero{color:#fff;background:linear-gradient(135deg,#061a3df5,#042a56f5),radial-gradient(circle at 20% 10%,#1479ff59,#0000 38%);justify-content:space-between;align-items:center;min-height:90px;padding:24px 30px;display:flex}.register-hero div{align-items:center;gap:16px;display:flex}.register-hero h1{letter-spacing:0;margin:0;font-size:24px}.register-back{background:#ffffff17;border-radius:999px;place-items:center;width:34px;height:34px;font-size:34px;line-height:1;display:grid}.register-subhead{color:#fff;background:#071d3e;border-top:1px solid #ffffff14;align-items:center;gap:10px;min-height:48px;padding:0 30px;font-weight:900;display:flex}.register-form{background:#fff;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 18px;padding:28px 30px 30px;display:grid}.register-form .field{margin:0}.register-form .field input,.register-form .field select,.register-form .field textarea{color:#233854;border-color:#dbe4ef;border-radius:8px;min-height:46px;font-weight:700}.register-form .field textarea{resize:vertical;min-height:112px}.register-save{border-radius:9px;min-width:220px;min-height:48px;box-shadow:0 15px 28px #1479ff3d;background:linear-gradient(135deg,#2189ff,#0560e8)!important}.phone-shell{padding-top:105px}.phone-frame{background:#05070b;border:4px solid #2a2f38;border-radius:42px;width:298px;height:602px;margin-inline:auto;padding:12px;position:relative;box-shadow:0 26px 70px #00000075}.phone-notch{z-index:2;background:#02050a;border-radius:999px;width:88px;height:23px;position:absolute;top:18px;left:50%;transform:translate(-50%)}.phone-screen{background:#f7fbff;border-radius:31px;height:100%;overflow:hidden}.phone-top,.phone-title,.phone-sub{color:#fff;background:linear-gradient(135deg,#09234c,#031a3d)}.phone-top{justify-content:space-between;align-items:center;height:34px;padding:0 18px;font-size:13px;font-weight:800;display:flex}.phone-title{justify-content:space-between;align-items:center;height:55px;padding:0 17px;display:flex}.phone-title button{color:#fff;background:0 0;border:0;font-size:32px;line-height:1}.phone-sub{border-top:1px solid #ffffff12;align-items:center;gap:9px;padding:12px 18px 16px;font-size:12px;font-weight:800;display:flex}.phone-form{background:#fff;border-radius:13px 13px 0 0;gap:14px;margin:0;padding:18px;display:grid}.phone-form label{color:#263852;gap:8px;font-size:12px;font-weight:900;display:grid}.phone-form label>div{color:#263852;border:1px solid #dbe4ef;border-radius:7px;align-items:center;gap:10px;min-height:40px;padding:0 11px;font-size:14px;font-weight:700;display:flex}.phone-form label>div svg:last-child{margin-left:auto}.phone-form label span{color:#64748b;margin-left:auto}.phone-form textarea{resize:none;color:#263852;border:1px solid #dbe4ef;border-radius:7px;width:100%;height:86px;padding:11px}.phone-form small{color:#94a3b8;justify-self:end;margin-top:-24px;padding-right:9px}.phone-form button{color:#fff;background:linear-gradient(135deg,#2189ff,#0560e8);border:0;border-radius:8px;justify-content:center;align-items:center;gap:9px;min-height:45px;font-weight:900;display:flex;box-shadow:0 15px 28px #1479ff42}.phone-nav{background:#fff;border-top:1px solid #eef2f7;grid-template-columns:repeat(4,1fr);padding:12px 12px 16px;display:grid}.phone-nav span{color:#52657e;justify-items:center;gap:3px;font-size:10px;font-weight:800;display:grid}.phone-nav span:first-child{color:#1479ff}.page-header h1{color:#111827;letter-spacing:0;margin:0;font-size:30px;line-height:1.15}.page-header p{color:var(--muted);margin:8px 0 0}.toast{z-index:5;color:#075985;box-shadow:var(--shadow);background:#eff6ff;border:1px solid #bae6fd;border-radius:8px;padding:12px 14px;position:fixed;top:20px;right:22px}.kpi-grid{grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.trifr-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;min-height:138px;padding:16px;box-shadow:0 2px 6px #0f172a08}.stat-icon{border-radius:8px;place-items:center;width:42px;height:42px;margin-bottom:15px;display:grid}.stat-card strong{margin-bottom:8px;font-size:26px;line-height:1;display:block}.stat-card small{color:var(--muted)}.blue-soft{color:#075985;background:#e0f2fe}.cyan-soft{color:#0e7490;background:#cffafe}.green-soft{color:#15803d;background:#dcfce7}.amber-soft{color:#a16207;background:#fef9c3}.red-soft{color:#b91c1c;background:#fee2e2}.panel-grid{grid-template-columns:minmax(0,1fr) minmax(360px,.8fr);gap:24px;margin-bottom:24px;display:grid}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;min-width:0;margin-bottom:24px;padding:22px;box-shadow:0 2px 6px #0f172a08}.chart-panel h3,.compact-panel h3,.form-title{color:#1f2937;align-items:center;gap:9px;margin:0 0 16px;font-size:16px;display:flex}.compact-panel{padding:0;overflow:hidden}.compact-panel h3{padding:20px 22px 0}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;display:grid}.catalog-form{grid-template-columns:repeat(4,minmax(0,1fr));align-items:end}.span2{grid-column:span 2}.form-actions{align-items:end;gap:10px;display:flex}.table-wrap{width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:860px}th,td{border-bottom:1px solid var(--line);text-align:left;padding:13px 18px;font-size:14px}th{color:#64748b;text-transform:uppercase;letter-spacing:.03em;background:#f8fafc;font-size:12px}td{color:#334155}.empty{color:#94a3b8;text-align:center;padding:26px}.actions{flex-wrap:wrap;gap:8px;display:flex}.badge{border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;display:inline-flex}.approved{color:#166534;background:#dcfce7}.pending{color:#92400e;background:#fef3c7}.rejected{color:#991b1b;background:#ffe4e6}.report-grid,.settings-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-bottom:24px;display:grid}.report-card,.setting-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;min-height:174px;padding:22px;box-shadow:0 2px 6px #0f172a08}.report-card svg{color:var(--blue)}.report-card strong,.setting-card strong{margin:18px 0 8px;font-size:26px;display:block}.report-card h3{margin:0 0 8px;font-size:17px}.report-card p,.setting-card p{color:var(--muted);margin:0;line-height:1.5}.setting-card span{color:var(--blue);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:800}@media (width<=1180px){.kpi-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}.panel-grid,.report-grid,.settings-grid,.analytics-grid{grid-template-columns:1fr}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-total{left:24%}}@media (width<=1500px) and (width>=1181px){.analytics-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.55fr)}.hours-panel{grid-column:1/-1}.project-panel,.trifr-panel{min-height:420px}}@media (width<=820px){.login{grid-template-columns:1fr}.login-hero{min-height:300px;padding:28px}.login-copy h1{font-size:36px}.login-panel{margin:20px}body:before{background:var(--bg)}.shell,.shell.collapsed{grid-template-columns:1fr;padding:0}.sidebar{border:0;border-radius:0;min-height:auto;position:static}.sidebar-head{min-height:64px}.collapse-btn,.sidebar-scene{display:none}.nav{grid-template-columns:repeat(5,minmax(0,1fr));padding:8px;overflow-x:auto}.nav button{justify-content:center;min-width:48px;padding:0}.nav span,.sidebar-user,.logout{display:none}.workspace{padding:0}.page-header{flex-direction:column}.page-header h1{font-size:25px}.kpi-grid,.trifr-grid,.form-grid,.catalog-form,.metric-grid,.register-form{grid-template-columns:1fr}.span2{grid-column:auto}.dashboard-main-card,.mobile-register-card{min-height:auto;box-shadow:none;border:0;border-radius:0}.dashboard-main-card{padding:18px 14px}.dashboard-top{flex-direction:column;align-items:flex-start}.dashboard-actions{justify-content:space-between;gap:8px;width:100%}.profile-chip{max-width:170px}.outline-btn{padding-inline:10px}.analytics-grid{grid-template-columns:1fr}.project-content{flex-direction:column;align-items:stretch}.project-content .recharts-responsive-container{width:100%!important}.project-total{top:35%;left:50%}.project-legend{margin-top:4px}.register-hero{border-radius:0;min-height:74px;padding:18px}.register-hero h1{font-size:18px}.register-back{width:30px;height:30px;font-size:30px}.register-subhead{align-items:center;min-height:48px;padding:0 18px;font-size:13px}.register-form{border-radius:14px 14px 0 0;gap:15px;padding:18px}.register-form .field{color:#243957;font-size:13px}.register-form .field input,.register-form .field select{min-height:40px}.register-form .field textarea{min-height:86px}.register-save{width:100%;min-width:0;min-height:48px;font-size:16px}table{min-width:760px}}
