: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:#f7f9fc;grid-template-columns:minmax(0,1fr) minmax(440px,.72fr);min-height:100svh;display:grid}.login-hero{isolation:isolate;color:#fff;background:linear-gradient(145deg,#071a33 0%,#0b3c64 52%,#0e7490 100%);flex-direction:column;justify-content:center;padding:clamp(42px,7vw,104px);display:flex;position:relative;overflow:hidden}.login-hero:before{content:"";z-index:-1;aspect-ratio:1;border:1px solid #7dd3fc47;border-radius:50%;width:min(58vw,760px);position:absolute;top:-17%;right:-23%;box-shadow:0 0 0 48px #7dd3fc0d,0 0 0 96px #7dd3fc0a}.login-hero:after{content:"";z-index:-1;opacity:.2;background-image:linear-gradient(#bae6fd33 1px,#0000 1px),linear-gradient(90deg,#bae6fd33 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#000,#0000 72%);mask-image:linear-gradient(90deg,#000,#0000 72%)}.login-hero .logo-row{position:absolute;top:42px;left:clamp(42px,7vw,104px)}.login-copy{max-width:620px}.login-copy:before{content:"OPERACIONES · SEGURIDAD · DATOS";color:#bae6fd;letter-spacing:.1em;background:#071a333d;border:1px solid #bae6fd52;border-radius:999px;margin-bottom:20px;padding:7px 11px;font-size:11px;font-weight:800;display:inline-flex}.login-copy h1{letter-spacing:-.03em;margin:0;font-size:clamp(38px,4vw,62px);line-height:1.05}.login-copy p{color:#d7ecf7;max-width:530px;margin:20px 0 0;font-size:17px;line-height:1.6}.login-panel{background:#fff;border:1px solid #e3e8f2;border-radius:16px;align-self:center;width:min(100% - 56px,410px);margin:28px auto;padding:38px;box-shadow:0 28px 70px #0f172a1f}.login-panel h2{letter-spacing:-.02em;margin:7px 0 28px;font-size:27px}.section-kicker{color:var(--blue);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:800}.login-panel .field{margin-bottom:18px}.login-panel .field input{min-height:46px;padding-inline:13px}.login-panel .btn{border-radius:9px;width:100%;min-height:48px;margin-top:4px;box-shadow:0 12px 22px #7367f03d}.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;height:100svh;padding:0;transition:grid-template-columns .18s;display:grid;overflow:hidden}.shell.collapsed{grid-template-columns:78px minmax(0,1fr)}.sidebar{background:var(--nav);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{display:none}.collapsed .sidebar-head,.collapsed .sidebar-user,.collapsed .logout{justify-content:center;padding-inline:10px}.collapsed .nav button{justify-content:center;padding:0}.collapsed .collapse-btn{transform:rotate(180deg)}.workspace{overscroll-behavior:contain;min-width:0;height:100svh;padding:24px;overflow-y:auto}.mobile-menu-toggle,.mobile-menu-backdrop{display:none}.workspace>.page-header,.workspace>.panel,.workspace>.kpi-grid,.workspace>.panel-grid,.workspace>.report-grid,.workspace>.settings-grid{margin-left:0}.workspace>:not(.dashboard-composition){max-width:1240px;margin-left:auto;margin-right:auto}.page-header{justify-content:space-between;align-items:center;gap:18px;min-height:72px;margin-bottom:18px;animation:.42s cubic-bezier(.22,1,.36,1) both dashboard-card-in;display:flex}.page-heading{align-items:center;gap:11px;display:flex}.page-heading-icon{color:#075985;place-items:center;display:grid}.page-heading-icon svg{stroke-width:2.25px;width:24px;height:24px}.page-actions{align-items:center;gap:9px;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;animation:.56s cubic-bezier(.22,1,.36,1) both dashboard-card-in;box-shadow:0 2px 8px #0f172a0a}.metric-card:nth-child(2){animation-delay:80ms}.metric-card:nth-child(3){animation-delay:.16s}.metric-card:nth-child(4){animation-delay:.24s}.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}.sparkline polyline{stroke-dasharray:250;stroke-dashoffset:250px;animation:1s cubic-bezier(.22,1,.36,1) .32s forwards draw-sparkline}.sparkline path{transform-origin:bottom;animation:.7s ease-out .45s both sparkline-fill}.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;animation:.65s cubic-bezier(.22,1,.36,1) .3s both dashboard-card-in;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;animation:.9s cubic-bezier(.22,1,.36,1) .55s both gauge-enter;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}@keyframes dashboard-card-in{0%{opacity:0;transform:translateY(14px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes draw-sparkline{to{stroke-dashoffset:0}}@keyframes sparkline-fill{0%{opacity:0;transform:scaleY(.4)}to{opacity:.09;transform:scaleY(1)}}@keyframes gauge-enter{0%{opacity:0;transform:scale(.78)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.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:4px 0 0;font-size:14px}.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;animation:.45s cubic-bezier(.22,1,.36,1) both dashboard-card-in;box-shadow:0 2px 6px #0f172a08}.filter-panel{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:18px;display:grid}.filter-panel .field{margin:0}.filter-panel input,.filter-panel select{min-height:40px}.mobile-register-card.is-hidden{display:none}.entry-panel{border-top:3px solid #0ea5e9}.catalog-modal{z-index:60;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.catalog-backdrop{background:#0f172aad;border:0;animation:.2s both modal-backdrop-in;position:absolute;inset:0}.catalog-dialog{z-index:1;background:#fff;border-radius:16px;width:min(100%,460px);padding:24px;animation:.28s cubic-bezier(.22,1,.36,1) both modal-dialog-in;position:relative;box-shadow:0 26px 70px #0f172a47}.catalog-dialog header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.catalog-dialog h2{color:#172033;margin:0;font-size:20px}.modal-close{color:#64748b;background:0 0;border:0;border-radius:8px;place-items:center;width:32px;height:32px;display:grid}.modal-close:hover{background:#f1f5f9}.modal-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:6px;display:grid}.modal-actions .btn{min-height:44px}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-dialog-in{0%{opacity:0;transform:translateY(18px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.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:360px;padding:120px 28px 44px}.login-hero .logo-row{top:28px;left:28px}.login-copy h1{font-size:38px}.login-copy p{font-size:15px}.login-panel{z-index:1;width:min(100% - 32px,440px);margin:-22px auto 28px;padding:28px}body:before{background:var(--bg)}.shell,.shell.collapsed{height:auto;min-height:100svh;padding:0;display:block;overflow:visible}.sidebar{z-index:30;border:0;border-radius:0 14px 14px 0;width:min(280px,100vw - 54px);height:100svh;min-height:0;transition:transform .24s cubic-bezier(.22,1,.36,1);position:fixed;top:0;bottom:0;left:0;transform:translate(-105%);box-shadow:18px 0 42px #0f172a38}.mobile-menu-open .sidebar{transform:translate(0)}.sidebar-head{min-height:72px}.collapse-btn,.sidebar-scene{display:none}.nav{gap:4px;padding:16px 12px;display:grid;overflow:visible}.nav button{justify-content:flex-start;width:100%;min-width:0;padding:0 11px}.nav span{display:inline}.sidebar-user,.logout{display:flex}.workspace{height:auto;min-height:100svh;padding:0;overflow:visible}.mobile-menu-toggle{z-index:40;color:#fff;background:#0b3c64;border:1px solid #ffffff42;border-radius:12px;place-items:center;width:44px;height:44px;display:grid;position:fixed;top:24px;left:26px;box-shadow:0 10px 24px #0f172a3d}.mobile-menu-open .mobile-menu-toggle{color:#1e293b;background:#fff;border-color:#e2e8f0}.mobile-menu-backdrop{z-index:20;opacity:0;pointer-events:none;background:#0f172a61;border:0;transition:opacity .2s;display:block;position:fixed;inset:0}.mobile-menu-open .mobile-menu-backdrop{opacity:1;pointer-events:auto}.workspace>:not(.dashboard-composition){margin-inline:16px}.page-header{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:14px;padding-top:76px}.page-header h1{font-size:25px}.page-header p{font-size:13px}.page-heading{padding-left:0}.page-heading-icon{display:none}.page-actions{flex-wrap:nowrap;width:100%;padding-left:0}.page-actions .btn{min-height:38px;padding-inline:11px}.filter-panel{grid-template-columns:repeat(2,minmax(0,1fr));gap:13px 10px;padding:15px}.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{color:#172033;background:#fff;border-radius:14px 14px 0 0;justify-content:flex-start;min-height:86px;padding:20px 18px 10px}.register-hero h1{font-size:22px}.register-back{color:#334155;background:#f1f5f9;width:30px;height:30px;font-size:30px}.register-subhead{border:0;height:0;min-height:0;padding:0;overflow:hidden}.register-form{border-radius:0 0 14px 14px;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}.catalog-modal{align-items:end;padding:0}.catalog-dialog{border-radius:18px 18px 0 0;width:100%;padding:24px 24px 26px;animation-name:modal-sheet-in}.modal-actions{grid-template-columns:1fr}.modal-actions .btn:first-child{order:-1}@keyframes modal-sheet-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}table{min-width:760px}}
