.module-page.tp-view-big{max-width:none}.tp-topbar{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.tp-brand{align-items:center;gap:14px;display:flex}.tp-brand-logo{object-fit:contain;width:auto;height:38px;display:block}@media (width<=480px){.tp-brand-logo{height:28px}.tp-brand{gap:10px}}.tp-clock{font-variant-numeric:tabular-nums;flex-direction:column;align-items:flex-end;display:flex}.tp-clock-time{color:var(--text);letter-spacing:.5px;font-size:22px;font-weight:700}.tp-clock-tz{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:-2px;font-size:11px}@media (width<=480px){.tp-clock-time{font-size:18px}}.tp-tabs{border-bottom:1px solid var(--border);gap:0;margin:24px 0 16px;display:flex}.tp-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 18px;font-family:inherit;font-size:14px;font-weight:500}.tp-tab:hover{color:var(--text)}.tp-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tp-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.tp-card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.tp-card-header h3{color:var(--text);margin:0;font-size:15px;font-weight:600}.tp-card h3{color:var(--text);margin:0 0 12px;font-size:15px;font-weight:600}.tp-label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.tp-input{border:1px solid var(--border);width:100%;color:var(--text);background:var(--white);border-radius:6px;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.tp-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ac6ff826}textarea.tp-input{resize:vertical;min-height:50px}.tp-form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 16px;margin-bottom:16px;display:grid}.tp-actions{justify-content:flex-end;gap:10px;margin-top:12px;display:flex}.tp-meta{color:var(--text-muted);font-size:13px}.tp-dot{background:var(--green);border-radius:50%;width:8px;height:8px;display:inline-block}.tp-dot.offline{background:#9ca3af}.tp-teams-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-right:4px;display:inline-block;box-shadow:0 0 0 1px #ffffffa6}.tp-live-teams-pill{letter-spacing:.02em;border-radius:6px;align-items:center;gap:4px;margin:6px 0;padding:4px 8px;font-size:12px;display:flex}.tp-live-teams-pill.tp-live-teams-on{color:#3d6b14;background:#92c3531f}.tp-live-teams-pill.tp-live-teams-off{color:#6b7280;background:#f3f4f6}.tp-live-teams-pill .tp-teams-dot{margin-right:2px}.tp-teams-diary-table{border-collapse:collapse;width:100%;font-size:13px}.tp-teams-diary-table th,.tp-teams-diary-table td{text-align:right;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums;padding:8px 10px}.tp-teams-diary-table th:first-child,.tp-teams-diary-table td:first-child{text-align:left}.tp-teams-diary-table thead th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:11px;font-weight:600}.tp-teams-diary-table tbody tr:hover{background:#00000005}.tp-teams-diary-cell{justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.tp-teams-diary-bar{background:#e5e7eb;border-radius:3px;width:56px;height:6px;position:relative;overflow:hidden}.tp-teams-diary-bar-fill{background:linear-gradient(90deg,#92c353,#5a8f1f);border-radius:3px;position:absolute;inset:0}.tp-teams-diary-zero{color:#d1d5db}.tp-diary-bar-row{grid-template-columns:130px 1fr auto;display:grid}.tp-diary-bar-track{height:18px;position:relative}.tp-diary-bar-fill.tp-diary-bar-fill-teams{background:linear-gradient(90deg,#92c35359,#92c35326);border:1px dashed #92c3538c;border-radius:4px;position:absolute;inset:0}.tp-diary-bar-fill.tp-diary-bar-fill-worked{position:absolute;inset:0}.tp-diary-bar-hours-stack{flex-direction:column;align-items:flex-end;font-size:12px;line-height:1.2;display:flex}.tp-diary-bar-hours-stack .tp-diary-bar-hours-teams{color:#5a8f1f}.tp-diary-bar-hours-stack .tp-diary-bar-hours-active{color:#047857;font-weight:500}.tp-diary-bar-hours-stack .tp-diary-bar-hours-idle{color:#92400e}.tp-diary-bar-fill.tp-diary-bar-fill-active{background:#047857b3;border-radius:3px;position:absolute;inset:4px auto 4px 0}.tp-diary-presence-timeline{margin-top:12px;font-size:13px}.tp-diary-presence-timeline .tp-diary-presence-row{border-top:1px dashed var(--border,#e5e7eb);grid-template-columns:110px 1fr;padding:4px 0;display:grid}.tp-diary-presence-timeline .tp-diary-presence-row:first-child{border-top:none}.tp-big-btn{border-radius:8px;min-width:200px;padding:14px 36px;font-size:16px;font-weight:600}.tp-big-btn-stop{background:var(--red)}.tp-big-btn-stop:hover{background:#dc2626}.tp-live-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}@media (width<=1400px){.tp-live-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=1000px){.tp-live-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=700px){.tp-live-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=480px){.tp-live-grid{grid-template-columns:1fr}}.tp-live-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-width:0;padding:10px 12px;overflow:hidden}.tp-live-card .tp-actions{flex-wrap:wrap;justify-content:flex-start;gap:4px}.tp-live-card .tp-actions :where(button){white-space:nowrap;padding:3px 8px;font-size:11px}.tp-live-card-offline{opacity:.85;background:#f9fafb;border-color:#e5e7eb}.tp-live-card-offline .tp-live-timer{color:var(--text-muted);font-size:14px;font-weight:600}.tp-live-card-notstarted{opacity:.7;background:#fafafa;border-color:#e5e7eb}.tp-live-card-notstarted .tp-live-timer{color:var(--text-muted);font-size:13px;font-weight:500}.tp-live-name{color:var(--text);word-break:break-word;flex-wrap:wrap;align-items:center;gap:6px;min-width:0;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.tp-live-offline-pill,.tp-live-notstarted-pill,.tp-live-name .tp-status{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:999px;flex-shrink:0;max-width:100%;padding:2px 8px;font-size:10px;font-weight:700}.tp-live-offline-pill{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.tp-live-notstarted-pill{color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb}.tp-live-description{color:var(--text-light);min-height:36px;margin-bottom:8px;font-size:13px}.tp-live-timer{font-variant-numeric:tabular-nums;color:var(--green);font-size:22px;font-weight:700}.tp-live-today{border-top:1px dashed var(--border);color:var(--text-muted);margin-top:6px;padding-top:8px;font-size:12px}.tp-live-log{border-top:1px dashed var(--border);flex-direction:column;gap:4px;max-height:220px;margin-top:8px;padding-top:8px;display:flex;overflow-y:auto}.tp-live-log-row{justify-content:space-between;gap:8px;font-size:12px;display:flex}.tp-live-log-row .tp-live-log-desc{text-overflow:ellipsis;white-space:nowrap;color:var(--text);flex:1;overflow:hidden}.tp-live-log-row .tp-live-log-dur{font-variant-numeric:tabular-nums;color:var(--text-muted);white-space:nowrap;font-weight:600}.tp-live-log-row.running .tp-live-log-dur{color:var(--green)}.tp-live-log-toggle{color:var(--primary);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;background:0 0;border:none;margin-top:8px;padding:0;font-size:11px;font-weight:600}.tp-table{border-collapse:collapse;width:100%;font-size:14px}.tp-table th,.tp-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.tp-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:var(--bg);font-size:12px;font-weight:600}.tp-table tr:last-child td{border-bottom:none}.tp-table .tp-num{text-align:right;font-variant-numeric:tabular-nums}.tp-pill{border-radius:12px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.tp-pill-active{color:#047857;background:#d1fae5}.tp-pill-muted{color:var(--text-muted);background:#f3f4f6}.tp-idle-pill{vertical-align:middle;border-radius:10px;align-items:center;gap:4px;margin-left:6px;padding:1px 8px;font-size:11px;font-weight:500;display:inline-flex}.tp-idle-pill .tp-idle-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.tp-idle-pill-active{color:#047857;background:#d1fae5}.tp-idle-pill-idle{color:#92400e;background:#fef3c7}.tp-sync-row{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);background:#fff;align-items:center;gap:8px;margin-bottom:12px;padding:6px 10px;font-size:13px;display:flex}.tp-sync-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:9px;height:9px;display:inline-block}.tp-sync-dot.off{background:#ef4444}.tp-sync-text{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.tp-sync-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:40%;font-weight:600;overflow:hidden}.tp-refresh-btn{white-space:nowrap;padding:4px 12px;font-size:13px}.tp-banner{border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.tp-banner-info{color:#1e40af;background:#dbeafe}.tp-banner-warn{color:#92400e;background:#fef3c7}.tp-banner-error{color:#991b1b;background:#fee2e2}.tp-banner-success{color:#047857;background:#d1fae5}.tp-empty{text-align:center;color:var(--text-muted);padding:28px 16px;font-size:14px}.tp-presets-row{flex-wrap:wrap;align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.tp-presets-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding-top:6px;font-size:12px;font-weight:600}.tp-presets-chips{flex-wrap:wrap;flex:1;gap:6px;display:flex}.tp-chip{color:#6d28d9;cursor:pointer;background:#f5edff;border:1px solid #d8c2f5;border-radius:999px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,transform 80ms,color .12s}.tp-chip:hover:not(:disabled){color:#fff;background:#ac6ff8;border-color:#ac6ff8}.tp-chip:active:not(:disabled){transform:translateY(1px)}.tp-chip:disabled{opacity:.5;cursor:not-allowed}.tp-chip-edit{background:var(--bg);border:1px dashed var(--border);color:var(--text-muted);font-weight:400}.tp-chip-edit:hover:not(:disabled){background:var(--bg);border-color:var(--primary);color:var(--primary)}.tp-chip-break{color:#92400e;background:#fef3c7;border-color:#f59e0b;font-weight:600}.tp-chip-break:hover:not(:disabled){color:#fff;background:#d97706;border-color:#d97706}.tp-chip-logoff{color:#991b1b;background:#fee2e2;border-color:#ef4444;font-weight:600}.tp-chip-logoff:hover:not(:disabled){color:#fff;background:#b91c1c;border-color:#b91c1c}.tp-modes{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.tp-mode{background:var(--white);border:1.5px solid var(--border);min-width:140px;color:var(--text);cursor:pointer;border-radius:10px;flex:1;padding:10px 14px;font-family:inherit;font-size:14px;font-weight:500;transition:border-color .12s,background .12s,color .12s}.tp-mode:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.tp-mode:disabled{opacity:.55;cursor:not-allowed}.tp-mode.active{background:var(--primary);border-color:var(--primary);color:#fff}.tp-mode-logoff.active{background:#b91c1c;border-color:#b91c1c}.tp-mode-break.active{background:#d97706;border-color:#d97706}.tp-actions-split{justify-content:space-between;align-items:center}.tp-big-btn-logoff{background:#b91c1c}.tp-big-btn-logoff:hover{background:#991b1b}.tp-today-card{padding-top:0;overflow:hidden}.tp-today-bar{background:var(--primary);margin:0 -20px 14px;padding:12px 20px}.tp-today-bar .tp-today-heading,.tp-today-bar h3{color:#fff;letter-spacing:.01em;font-weight:600}.tp-today-bar .tp-today-meta{color:#fff;opacity:.92;font-size:13px}.tp-row-delete{color:#b91c1c}.tp-row-delete:hover{background:#fee2e2;border-color:#fca5a5}.tp-status{letter-spacing:.02em;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.tp-status-on_time{color:#047857;background:#d1fae5}.tp-status-late{color:#92400e;background:#fef3c7}.tp-status-absent{color:#991b1b;background:#fee2e2}.tp-status-upcoming{color:#374151;background:#e5e7eb}.tp-status-off{color:#3730a3;background:#e0e7ff}.tp-role-pill{letter-spacing:.05em;text-transform:uppercase;color:#5b21b6;background:#ede9fe;border-radius:999px;margin-left:8px;padding:1px 7px;font-size:10px;font-weight:700;display:inline-block}.tp-attendance-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:8px 0 12px;display:flex}.tp-attendance-date-nav{align-items:center;gap:6px;display:inline-flex}.tp-attendance-date-nav .btn-secondary{min-width:0;padding:6px 10px}.tp-attendance-date-input{width:auto;padding:6px 8px;font-size:13px}.tp-attendance-toggle{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:inline-flex}.tp-attendance-expand{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:2px 6px;font-size:14px}.tp-attendance-expand:hover{color:var(--primary)}.tp-attendance-detail-row>td{background:#f9fafb;padding:8px 16px 14px}.tp-attendance-task-table{margin:0}.tp-attendance-task-table th{padding:4px 8px;font-size:11px}.tp-attendance-task-table td{padding:4px 8px;font-size:13px}.tp-review-range{border:1px solid var(--border);background:var(--white);border-radius:8px;gap:0;padding:2px;display:inline-flex}.tp-review-range .tp-tab{background:0 0;border:none;border-radius:6px;margin:0;padding:6px 14px;font-size:13px}.tp-review-range .tp-tab.active{background:var(--primary);color:#fff}.tp-workdays-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.tp-workday-pill{border:1px solid var(--border);background:var(--white);cursor:pointer;color:var(--text);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600}.tp-workday-pill:hover{border-color:var(--primary);color:var(--primary)}.tp-workday-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.tp-loggedoff{text-align:center;padding:32px 20px}.tp-loggedoff h3{font-size:20px}.tp-modal-backdrop{z-index:1000;background:#0f172a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.tp-modal{background:var(--white);border-radius:var(--radius);width:100%;max-width:520px;max-height:80vh;padding:24px;overflow-y:auto;box-shadow:0 20px 50px #00000040}.tp-compact-bar{background:var(--white);border-bottom:1px solid var(--border);-webkit-app-region:drag;z-index:5;justify-content:space-between;align-items:center;gap:6px;padding:6px 8px;display:flex;position:sticky;top:0}.tp-compact-bar>*{-webkit-app-region:no-drag}.tp-topbar-right{align-items:center;gap:10px;display:flex}.tp-view-picker{-webkit-app-region:no-drag;gap:4px;display:inline-flex}.tp-view-btn{border:1px solid var(--border);background:var(--white);width:28px;height:26px;color:var(--text-dim,#475569);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0;display:inline-flex}.tp-view-slim .tp-compact-bar .tp-clock-tz,.tp-view-chat .tp-compact-bar .tp-clock-tz{display:none}.tp-view-slim .tp-compact-bar .tp-clock-time,.tp-view-chat .tp-compact-bar .tp-clock-time{font-size:13px}.tp-view-slim .tp-view-btn,.tp-view-chat .tp-view-btn{width:26px;height:24px}.tp-view-btn:hover{border-color:var(--primary);color:var(--primary)}.tp-view-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.tp-back-to-big{border:1px solid var(--primary);background:var(--primary);color:#fff;cursor:pointer;-webkit-app-region:no-drag;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #00000014}.tp-back-to-big:hover{filter:brightness(1.08)}.tp-running-ribbon{background:var(--primary);color:#fff;border-radius:8px;align-items:center;gap:8px;margin:4px 4px 0;padding:8px 10px;display:flex;box-shadow:0 2px 6px #0000001f}.tp-running-ribbon-main{flex:1;min-width:0}.tp-running-ribbon-label{letter-spacing:.06em;text-transform:uppercase;opacity:.85;font-size:10px;font-weight:700}.tp-running-ribbon-desc{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.tp-running-ribbon-time{font-variant-numeric:tabular-nums;background:#ffffff2e;border-radius:6px;padding:2px 8px;font-size:18px;font-weight:700}.tp-view-slim{max-width:100%;padding:4px}.tp-view-slim .tp-card{margin:4px 0;padding:8px}.tp-view-slim .tp-today-card{display:none}.tp-view-slim .tp-presets-row{flex-direction:column;gap:4px;margin-bottom:8px}.tp-view-slim .tp-presets-label{display:none}.tp-view-slim .tp-presets-chips{grid-template-columns:1fr 1fr;gap:4px;width:100%;display:grid}.tp-view-slim .tp-chip{text-align:center;white-space:normal;word-break:normal;padding:5px 6px;font-size:11px;line-height:1.15}.tp-view-slim .tp-chip-break,.tp-view-slim .tp-chip-logoff{grid-column:1/-1}.tp-view-slim .tp-label{margin:2px 0 4px;font-size:12px}.tp-view-slim .tp-input{padding:6px 8px;font-size:13px}.tp-view-slim textarea.tp-input{min-height:40px}.tp-view-slim .tp-big-btn{width:100%;min-width:0;padding:7px 14px;font-size:13px}.tp-view-slim .tp-actions{justify-content:stretch;margin-top:6px}.tp-diary-grid{grid-template-columns:280px 1fr;gap:24px;margin-top:12px;display:grid}@media (width<=760px){.tp-diary-grid{grid-template-columns:1fr}}.tp-diary-cal{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);padding:12px}.tp-diary-cal-head{justify-content:space-between;align-items:center;gap:6px;margin-bottom:8px;display:flex}.tp-diary-cal-head .btn-secondary{padding:2px 8px;font-size:14px;line-height:1}.tp-diary-cal-row{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.tp-diary-cal-dows{margin-bottom:4px}.tp-diary-cal-dow{text-align:center;color:var(--text-muted);padding:4px 0;font-size:11px;font-weight:600}.tp-diary-cal-day{aspect-ratio:1;cursor:pointer;font:inherit;color:var(--text);background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;padding:0;font-size:13px;display:flex;position:relative}.tp-diary-cal-day:hover:not(:disabled){background:#ac6ff81f}.tp-diary-cal-day:disabled{cursor:default;color:var(--text-muted);opacity:.45}.tp-diary-cal-day.off-month{color:var(--text-muted);opacity:.55}.tp-diary-cal-day.in-week{color:#fff;background:#0f172a}.tp-diary-cal-day.in-week.is-today{box-shadow:inset 0 0 0 2px var(--primary,#ac6ff8)}.tp-diary-cal-day.is-today:not(.in-week){color:var(--text);background:#ac6ff82e}.tp-diary-cal-dot{background:#22c55e;border-radius:50%;width:4px;height:4px;position:absolute;bottom:5px}.tp-diary-cal-day.in-week .tp-diary-cal-dot{background:#86efac}.tp-diary-bars{flex-direction:column;display:flex}.tp-diary-bar-row{border-top:1px solid var(--border);cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;background:0 0;border-bottom:none;border-left:none;border-right:none;grid-template-columns:140px 1fr 80px;align-items:center;gap:12px;padding:14px 4px;display:grid}.tp-diary-bars>div:first-child .tp-diary-bar-row{border-top:none}.tp-diary-bar-row:hover:not(:disabled){background:#ac6ff80f}.tp-diary-bar-row.empty{cursor:default;color:var(--text-muted)}.tp-diary-bar-row.expanded{background:#ac6ff814}.tp-diary-bar-label{font-size:14px}.tp-diary-bar-label strong{font-weight:600}.tp-diary-bar-track{background:#e5e7eb;border-radius:999px;height:10px;position:relative;overflow:hidden}.tp-diary-bar-fill{background:linear-gradient(90deg,#86efac,#22c55e);border-radius:999px;height:100%;transition:width .2s}.tp-diary-bar-hours{text-align:right;color:var(--text);font-size:14px;font-weight:600}.tp-diary-bar-row.empty .tp-diary-bar-hours{color:var(--text-muted);font-weight:500}.tp-diary-day-detail{background:#f8fafc99;padding:8px 4px 16px 152px}@media (width<=760px){.tp-diary-bar-row{grid-template-columns:110px 1fr 70px}.tp-diary-day-detail{padding-left:12px}}.tp-diary-footer{border-top:1px solid var(--border);align-items:center;gap:16px;margin-top:16px;padding-top:14px;display:flex}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:260px;--topbar-h:56px;--bg:#f5f6fa;--sidebar-bg:#fff;--sidebar-hover:#f3f0ff;--sidebar-active:#ece6ff;--text:#1a1a2e;--text-muted:#6b7280;--text-light:#475467;--primary:#ac6ff8;--primary-light:#be8fff;--white:#fff;--border:#e5e7eb;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--blue:#3b82f6;--radius:8px}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}.dashboard-layout{min-height:100vh;display:flex}.dashboard-layout.app-mode{display:block}.dashboard-layout.app-mode .content{max-width:none;margin:0;padding:24px 32px}.main-area{margin-left:var(--sidebar-w);flex-direction:column;flex:1;display:flex}.content{flex:1;padding:24px 32px}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--text-light);z-index:100;border-right:1px solid var(--border);flex-direction:column;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar--collapsed{transform:translate(-100%)}.sidebar-collapsed .main-area{margin-left:0;transition:margin-left .25s}.main-area{transition:margin-left .25s}.sidebar-brand{border-bottom:1px solid var(--border);justify-content:center;align-items:center;padding:14px 20px;display:flex}.brand-logo{object-fit:contain;width:auto;max-width:180px;height:40px}.brand-logo-text{color:var(--primary);letter-spacing:-.5px;font-size:22px;font-weight:700}.sidebar-nav{flex:1;padding:12px 0}.nav-home-link{color:var(--text-light);margin-bottom:2px;padding:10px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s;display:block}.nav-home-link:hover{background:var(--sidebar-hover)}.nav-home-link.active{background:var(--sidebar-active);color:var(--primary);font-weight:600}.nav-group{margin-bottom:2px}.nav-dept-btn{width:100%;color:var(--text-light);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s;display:flex}.nav-dept-btn:hover{background:var(--sidebar-hover)}.nav-dept-btn.open{background:var(--sidebar-hover);color:var(--text)}.nav-dept-btn--single.active{background:var(--sidebar-active);color:var(--primary);font-weight:600}.dept-icon{flex-shrink:0;width:18px;height:18px}.dept-label{flex:1}.chevron{opacity:.5;font-size:18px;transition:transform .2s}.chevron.rotated{transform:rotate(90deg)}.nav-modules{padding:4px 0;list-style:none}.nav-module-link{color:var(--text-muted);border-left:3px solid #0000;align-items:center;gap:4px;padding:8px 20px 8px 36px;font-size:13px;text-decoration:none;transition:all .15s;display:flex}.nav-module-link:hover{background:var(--sidebar-hover);color:var(--text)}.nav-module-link.active{background:var(--sidebar-active);color:var(--primary);border-left-color:var(--primary);font-weight:500}.topbar{height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 32px;display:flex}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{font-size:18px;font-weight:600}.sidebar-toggle-btn{border-radius:var(--radius);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex}.sidebar-toggle-btn:hover{background:var(--sidebar-hover)}.hamburger{flex-direction:column;justify-content:center;gap:4px;width:20px;height:20px;display:flex}.hamburger span{background:var(--text);border-radius:2px;width:100%;height:2px;transition:transform .25s,opacity .25s;display:block}.hamburger.closed span:first-child{transform:translateY(6px)rotate(45deg)}.hamburger.closed span:nth-child(2){opacity:0}.hamburger.closed span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.topbar-right{align-items:center;display:flex;position:relative}.profile-trigger{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:0 0;align-items:center;gap:10px;padding:6px 10px;font-family:inherit;transition:all .15s;display:flex}.profile-trigger:hover{background:var(--bg)}.profile-avatar{background:var(--primary);width:32px;height:32px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.profile-avatar-lg{width:40px;height:40px;font-size:14px}.profile-info{flex-direction:column;align-items:flex-start;line-height:1.3;display:flex}.profile-name{color:var(--text);font-size:13px;font-weight:600}.profile-email{color:var(--text-muted);font-size:11px}.profile-chevron{color:var(--text-muted);font-size:16px;transition:transform .2s}.profile-chevron.open{transform:rotate(90deg)}.profile-dropdown{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);z-index:200;width:280px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.profile-dropdown-header{background:#faf8ff;align-items:center;gap:12px;padding:16px;display:flex}.profile-dropdown-name{color:var(--text);font-size:14px;font-weight:600}.profile-dropdown-email{color:var(--text-muted);margin-bottom:4px;font-size:12px}.profile-dropdown-divider{background:var(--border);height:1px}.profile-dropdown-section{padding:8px 0}.profile-dropdown-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:4px 16px 8px;font-size:11px;font-weight:600;display:block}.profile-dropdown-item{cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 16px;font-family:inherit;font-size:13px;transition:background .15s;display:flex}.profile-dropdown-item:hover{background:var(--sidebar-hover)}.profile-dropdown-item.active{background:var(--sidebar-active);color:var(--primary);font-weight:600}.profile-dropdown-item-email{color:var(--text-muted);font-size:11px}.profile-dropdown-admin{color:var(--primary);padding:12px 16px;font-weight:500}.role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.role-admin{color:#9333ea;background:#f3e8ff}.role-manager{color:#1d4ed8;background:#dbeafe}.role-viewer{color:#6b7280;background:#f3f4f6}.favorites-bar{background:var(--white);border-bottom:1px solid var(--border);scrollbar-width:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 32px;display:flex;overflow-x:auto}.favorites-bar::-webkit-scrollbar{display:none}.fav-chip{color:var(--text-light);white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.fav-chip:hover{background:var(--sidebar-hover);color:var(--text)}.fav-chip--active{background:var(--sidebar-active);color:var(--primary);font-weight:600}.fav-chip-dot{background:var(--primary-light);border-radius:50%;flex-shrink:0;width:6px;height:6px}.module-page{max-width:1100px}.module-page h2{margin-bottom:6px;font-size:22px;font-weight:600}.subtitle{color:var(--text-muted);margin-bottom:24px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:20px;display:grid}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-label{color:var(--text-muted);margin-bottom:6px;font-size:13px}.stat-value{font-size:28px;font-weight:700}.dept-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;align-items:center;gap:8px;padding:24px;font-family:inherit;transition:all .15s;display:flex}.dept-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 2px 8px #ac6ff826}.dept-card .dept-icon{width:32px;height:32px;color:var(--primary)}.dept-card-label{font-size:16px;font-weight:600}.dept-card-count{color:var(--text-muted);font-size:13px}.data-table{border-collapse:collapse;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);width:100%;margin-top:16px;overflow:hidden}.data-table th,.data-table td{text-align:left;padding:12px 16px;font-size:14px}.data-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f9fafb;font-size:12px;font-weight:600}.data-table tr:not(:last-child) td{border-bottom:1px solid var(--border)}.data-table tr:hover td{background:#fafaff}.status-badge{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.status-shipped,.status-delivered,.status-active,.status-accepted{color:#065f46;background:#d1fae5}.status-processing,.status-pending,.status-in-transit{color:#92400e;background:#fef3c7}.status-paused{color:#6b7280;background:#f3f4f6}.low-stock{color:var(--red);font-weight:600}.settings-form{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);max-width:480px;margin-top:16px;padding:24px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid var(--border);border-radius:6px;width:100%;padding:8px 12px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ac6ff81a}.btn-primary{background:var(--primary);color:var(--white);cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s}.btn-primary:hover{background:var(--primary-light)}.no-access{text-align:center;padding:60px 20px}.no-access h2{color:var(--red);margin-bottom:8px}.no-access p{color:var(--text-muted)}.permissions-page{max-width:1200px}.permissions-layout{gap:24px;min-height:500px;margin-top:20px;display:flex}.permissions-user-list{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0;width:280px;padding:16px}.permissions-user-list h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:600}.permissions-search{border:1px solid var(--border);background:var(--bg);box-sizing:border-box;border-radius:6px;outline:none;width:100%;margin-bottom:12px;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.permissions-search:focus{border-color:var(--primary)}.permissions-user-btn{background:var(--bg);cursor:pointer;text-align:left;border:2px solid #0000;border-radius:6px;flex-wrap:wrap;align-items:center;gap:6px;width:100%;margin-bottom:6px;padding:12px;font-family:inherit;transition:all .15s;display:flex;position:relative}.permissions-user-btn:hover{border-color:var(--border)}.permissions-user-btn.selected{border-color:var(--primary);background:#f0f0ff}.permissions-user-name{width:100%;font-size:14px;font-weight:600}.permissions-user-email{color:var(--text-muted);flex:1;font-size:12px}.permissions-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);flex:1;padding:24px;overflow-y:auto}.permissions-empty{height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:15px;display:flex}.permissions-editor h3{margin-bottom:20px;font-size:16px}.permissions-dept-block{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow:hidden}.permissions-dept-header{border-bottom:1px solid var(--border);background:#f9fafb;padding:12px 16px}.permissions-dept-header .toggle-text{font-size:15px;font-weight:600}.permissions-modules{padding:0}.permissions-modules.disabled{opacity:.4;pointer-events:none}.permissions-col-headers{border-bottom:1px solid var(--border);background:#fafafa;align-items:center;padding:8px 16px;display:flex}.permissions-col-page{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;flex:1;font-size:12px;font-weight:600}.permissions-col-level{text-align:center;width:70px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.permissions-module-row-ve{border-bottom:1px solid #f3f4f6;align-items:center;padding:10px 16px;display:flex}.permissions-module-row-ve:last-child{border-bottom:none}.permissions-module-row-ve .permissions-col-page{color:var(--text);text-transform:none;letter-spacing:0;font-size:13px;font-weight:500}.permissions-module-row-ve .permissions-col-level{justify-content:center;align-items:center;display:flex}.perm-radio{background:var(--white);cursor:pointer;border:2px solid #d1d5db;border-radius:50%;width:22px;height:22px;transition:all .15s;position:relative}.perm-radio:hover{border-color:var(--primary-light)}.perm-radio.on{border-color:var(--primary);background:var(--primary)}.perm-radio.on:after{content:"";background:var(--white);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.perm-radio:disabled{cursor:not-allowed;opacity:.4}.toggle-label{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.toggle-text{font-size:14px;font-weight:500}.toggle-switch{cursor:pointer;background:#d1d5db;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle-switch.on{background:var(--primary)}.toggle-switch .toggle-knob{background:var(--white);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle-switch.on .toggle-knob{transform:translate(20px)}.toggle-switch:disabled{cursor:not-allowed}.btn-add-user{border:2px dashed var(--border);width:100%;color:var(--primary);cursor:pointer;background:0 0;border-radius:6px;margin-top:8px;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-add-user:hover{border-color:var(--primary);background:#f0f0ff}.add-user-form{background:var(--bg);border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:8px;margin-top:10px;padding:12px;display:flex}.add-user-form input,.add-user-form select{border:1px solid var(--border);border-radius:5px;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.add-user-form input:focus,.add-user-form select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #ac6ff81a}.add-user-actions{gap:8px;display:flex}.btn-sm{border-radius:5px;padding:6px 14px;font-size:12px}.btn-secondary{background:var(--white);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s}.btn-secondary:hover{background:var(--bg)}.permissions-remove-btn{width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:flex;position:absolute;top:6px;right:6px}.permissions-user-btn:hover .permissions-remove-btn{opacity:1}.permissions-remove-btn:hover{color:var(--red);background:#fee2e2}.permissions-user-badge{letter-spacing:.3px;text-transform:uppercase;color:#4f46e5;vertical-align:middle;background:#eef2ff;border-radius:4px;margin-left:8px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.permissions-reset-btn{background:var(--white);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:3px 8px;font-family:inherit;font-size:11px;transition:all .15s}.permissions-reset-btn:hover{border-color:var(--primary);color:var(--primary)}.permissions-reset-success{color:#059669;font-size:11px;font-weight:600}.permissions-reset-form{flex-direction:column;gap:6px;width:100%;margin-top:6px;display:flex}.permissions-reset-form input{border:1px solid var(--border);border-radius:6px;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.permissions-reset-form input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #ac6ff81a}.permissions-tab-bar{border-bottom:2px solid var(--border);gap:0;margin:16px 0 12px;display:flex}.permissions-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.permissions-tab:hover{color:var(--text)}.permissions-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.bp-view{margin-top:8px}.bp-departments{flex-direction:column;gap:24px;display:flex}.bp-dept-title{color:var(--text);border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:6px;font-size:16px;font-weight:700}.bp-module{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}.bp-module-header{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.bp-module-name{color:var(--text);font-size:14px;font-weight:600}.bp-module-count{color:var(--text-muted);font-size:12px}.bp-user-list{padding:8px 16px 12px}.bp-no-users{color:var(--text-muted);padding:8px 0;font-size:13px}.bp-user-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:6px 0;display:flex}.bp-user-row:last-of-type{border-bottom:none}.bp-user-info{flex:1;min-width:0}.bp-user-name{color:var(--text);font-size:13px;font-weight:600;display:block}.bp-user-email{color:var(--text-muted);font-size:11px;display:block}.bp-level-select{border:1px solid var(--border);background:var(--white);cursor:pointer;color:var(--text);border-radius:4px;padding:3px 8px;font-family:inherit;font-size:12px}.bp-remove-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.bp-remove-btn:hover{color:#dc2626;background:#fee2e2}.bp-add-btn{color:var(--primary);border:1px dashed var(--primary);cursor:pointer;background:0 0;border-radius:4px;margin-top:6px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s;display:inline-block}.bp-add-btn:hover{background:#f0f0ff}.bp-add-panel{background:var(--bg);border-radius:6px;margin-top:8px;padding:10px}.bp-add-search{border:1px solid var(--border);box-sizing:border-box;border-radius:6px;outline:none;width:100%;padding:7px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.bp-add-search:focus{border-color:var(--primary)}.bp-add-results{max-height:200px;margin-top:6px;overflow-y:auto}.bp-add-user-btn{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:4px;width:100%;padding:8px 10px;font-family:inherit;transition:background .1s;display:block}.bp-add-user-btn:hover{background:#e0e7ff}.bp-add-user-btn .bp-user-name{font-size:13px;font-weight:600}.bp-add-user-btn .bp-user-email{color:var(--text-muted);font-size:11px}.module-page-full{max-width:none;height:calc(100vh - var(--topbar-h) - 48px)}.battery-iframe{border-radius:var(--radius);border:none;width:100%;height:100%}.iframe-wrapper{padding:0;position:relative;overflow:hidden}.iframe-wrapper .battery-iframe{position:absolute;top:0;left:0}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);text-align:center;width:100%;max-width:400px;padding:48px 40px;box-shadow:0 4px 16px #0000000f}.login-logo{object-fit:contain;width:auto;max-width:200px;height:48px;margin-bottom:20px}.login-title{color:var(--text);margin-bottom:8px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px}.login-ms-btn{background:var(--white);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;align-items:center;gap:12px;padding:12px 28px;font-family:inherit;font-size:15px;font-weight:500;transition:all .15s;display:inline-flex}.login-ms-btn:hover{background:var(--bg);border-color:#bbb}.login-ms-btn:disabled{opacity:.6;cursor:not-allowed}.login-ms-icon{flex-shrink:0}.login-divider{color:var(--text-muted);align-items:center;gap:12px;margin:24px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-email-btn{background:var(--white);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;border-radius:6px;padding:12px 28px;font-family:inherit;font-size:15px;font-weight:500;transition:all .15s;display:block}.login-email-btn:hover{background:var(--bg);border-color:#bbb}.login-form{text-align:left;flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.login-input{border:1px solid var(--border);width:100%;color:var(--text);background:var(--white);border-radius:6px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.login-input:focus{border-color:var(--primary,#7c6cf0);box-shadow:0 0 0 3px #7c6cf01a}.login-input::placeholder{color:var(--text-muted)}.login-submit-btn{background:var(--primary,#7c6cf0);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;padding:12px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .15s}.login-submit-btn:hover{opacity:.9}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#ef4444;text-align:center;margin:0;font-size:13px}.login-register-link{color:var(--text-muted);margin-top:16px;font-size:13px}.login-link-btn{color:var(--primary,#7c6cf0);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:600;text-decoration:underline}.login-link-btn:hover{opacity:.8}.login-back-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin:12px auto 0;padding:4px 0;font-family:inherit;font-size:13px;display:block}.login-back-btn:hover{color:var(--text)}.login-code-input{letter-spacing:8px;text-align:center;font-weight:600;font-size:24px!important}.add-user-toggle{color:var(--text-muted);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.add-user-toggle input[type=checkbox]{cursor:pointer}.add-user-error{color:#ef4444;margin:0;font-size:12px}.permissions-header{align-items:center;gap:14px;margin-bottom:16px;display:flex}.permissions-save-status{border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.permissions-save-saving{color:#92400e;background:#fef3c7}.permissions-save-saved{color:#065f46;background:#d1fae5}.permissions-save-error{color:#991b1b;background:#fee2e2}.permissions-save-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;width:10px;height:10px;animation:.7s linear infinite permissions-save-spin;display:inline-block}@keyframes permissions-save-spin{to{transform:rotate(360deg)}}.favorites-empty{text-align:center;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);margin-top:20px;padding:60px 20px}.favorites-empty-icon{color:var(--text-muted);margin-bottom:12px;font-size:48px}.favorites-empty .text-muted{color:var(--text-muted);margin-top:4px;font-size:14px}.fav-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all .15s;position:relative;overflow:hidden}.fav-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 2px 8px #ac6ff826}.fav-card-body{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;width:100%;padding:16px 24px 24px;font-family:inherit;display:flex}.fav-card .dept-icon{width:32px;height:32px;color:var(--primary)}.fav-card-label{color:var(--text);font-size:16px;font-weight:600}.fav-card-dept{color:var(--text-muted);font-size:13px}.fav-card-star{cursor:pointer;width:28px;height:28px;color:var(--text-muted);opacity:0;z-index:1;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex;position:absolute;top:6px;right:6px}.fav-card:hover .fav-card-star{opacity:1}.fav-card-star.active{color:#f59e0b}.fav-card-star:hover{background:#0000000d}.btn-add-favorites{border:2px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--primary);cursor:pointer;background:0 0;margin-top:16px;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s;display:block}.btn-add-favorites:hover{border-color:var(--primary);background:#faf8ff}.favorites-picker{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);margin-top:24px;overflow:hidden}.favorites-picker-header{border-bottom:1px solid var(--border);background:#faf8ff;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.favorites-picker-header h3{font-size:16px;font-weight:600}.favorites-picker-group{border-bottom:1px solid var(--border)}.favorites-picker-group:last-child{border-bottom:none}.favorites-picker-dept{color:var(--text);background:#f9fafb;align-items:center;gap:10px;padding:12px 20px;font-size:14px;font-weight:600;display:flex}.favorites-picker-dept .dept-icon{width:18px;height:18px;color:var(--primary)}.favorites-picker-modules{padding:4px 0}.favorites-picker-item{cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:10px 20px 10px 48px;font-family:inherit;font-size:14px;transition:background .15s;display:flex}.favorites-picker-item:hover{background:var(--sidebar-hover)}.favorites-picker-item.selected{background:var(--sidebar-active);color:var(--primary);font-weight:500}.favorites-picker-add{background:var(--bg);width:24px;height:24px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.favorites-picker-item:hover .favorites-picker-add{background:var(--primary);color:var(--white)}.sidebar-fav-btn{cursor:pointer;width:22px;height:22px;color:var(--text-muted);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:14px;transition:all .15s;display:none}.nav-module-link:hover .sidebar-fav-btn{display:flex}.sidebar-fav-btn.active{color:#f59e0b;display:flex}.sidebar-fav-btn:hover{background:#0000000f}.nav-module-link-text{flex:1}.production-tools-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.production-tools-tab{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);cursor:pointer;padding:8px 20px;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .15s}.production-tools-tab:hover{border-color:var(--primary);background:var(--sidebar-hover)}.production-tools-tab.active{background:var(--primary);color:var(--white);border-color:var(--primary)}.production-tools-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.production-tools-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;padding:40px 24px;font-family:inherit;transition:all .15s;display:flex}.production-tools-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 2px 8px #ac6ff826}.production-tools-card-label{color:var(--text);font-size:1rem;font-weight:600}.production-tools-active{flex-direction:column;display:flex}.production-tools-active>.module-page-full{flex-direction:column;flex:1;height:auto;display:flex}.production-tools-active>.module-page-full>.battery-iframe{flex:1}@media (width<=768px){.dashboard-layout{overflow-x:hidden}.main-area,.sidebar-collapsed .main-area{min-width:0;max-width:100vw;overflow-x:hidden;margin-left:0!important}.sidebar{z-index:200;box-shadow:8px 0 30px #0000002e}.sidebar-backdrop{z-index:150;cursor:pointer;background:#00000073;animation:.15s ease-out iu-fade;position:fixed;inset:0}@keyframes iu-fade{0%{opacity:0}to{opacity:1}}.content{padding:12px!important}.topbar{height:52px!important;padding:0 10px!important}.topbar-title{font-size:14px!important}.topbar-left{gap:6px}.profile-info,.profile-chevron{display:none!important}.profile-trigger{gap:0!important;padding:4px!important}.profile-dropdown{min-width:240px!important;left:auto!important;right:8px!important}.favorites-bar{white-space:nowrap;-webkit-overflow-scrolling:touch;overflow-x:auto;padding:6px 8px!important}.favorites-bar::-webkit-scrollbar{height:0;display:none}table{font-size:12px}h1,h2{line-height:1.2}body{-webkit-text-size-adjust:100%}input[type=text],input[type=number],input[type=email],input[type=search],input[type=tel],input[type=password],select,textarea{font-size:16px}}
