:root{--brand:#016085;--brand-600:#014b68;--ink:#0f172a;--muted:#64748b;--ok:#16a34a;--warn:#ef4444;--bg:#f3f4f6;--card:#fff;--surface-2:#f9fafb;--chip:#eaf4f8;--radius:8px;--shadow:0 1px 3px #0f172a14, 0 10px 24px #0f172a0a;--shadow-lg:0 18px 45px #0f172a21;--sidebar-w:320px;--sidebar-mini:64px;--nav-item-h:34px;--nav-icon-size:20px;--nav-label-size:14px;--nav-label-weight:500;--sidebar-brand-mark:36px;--divider:#e5e7eb;--primary-600:#016085;--focus:#93c5fd;--text-muted:#6b7280;--danger:#dc2626;--danger-bg:#dc26261f}*{box-sizing:border-box}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;overflow-x:hidden}html,body,#root{min-height:100%}.material-symbols-rounded{font-variation-settings:"FILL" 0, "wght" 300, "GRAD" 0, "opsz" 20;-webkit-font-feature-settings:"liga";font-feature-settings:"liga" 1;font-family:Material Symbols Rounded;font-style:normal;font-weight:400;font-size:var(--nav-icon-size);letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;direction:ltr;justify-content:center;align-items:center;line-height:1;display:inline-flex}.login-shell{background:var(--bg);grid-template-columns:minmax(0,1fr) minmax(420px,1fr);min-height:100vh;display:grid}.login-visual{background:#0b2238;border-top-right-radius:45px;border-bottom-right-radius:45px;min-height:100vh;position:relative;overflow:hidden}.login-visual img,.login-mobile-visual img{object-fit:cover;width:100%;height:100%;display:block}.login-visual:after{content:"";background:linear-gradient(#0f172a0a,#0f172aad);position:absolute;inset:0}.login-visual-caption{z-index:1;color:#fff;position:absolute;bottom:40px;left:40px;right:40px}.login-kicker{min-height:24px;color:var(--primary-600);letter-spacing:.06em;text-transform:uppercase;align-items:center;font-size:12px;font-weight:800;display:inline-flex}.login-visual-caption .login-kicker{color:#d9f4ff}.login-visual-caption h1{max-width:520px;margin:8px 0 0;font-size:40px;line-height:1.05}.login-form-panel{justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.login-card{width:min(100%,420px);box-shadow:none;background:0 0;border:0;border-radius:0;flex-direction:column;gap:16px;padding:0;display:flex}.login-mobile-visual{border-bottom-right-radius:20px;border-bottom-left-radius:20px;height:154px;margin:0 0 8px;display:none;overflow:hidden}.login-heading h2{color:#0b2238;margin:4px 0 0;font-size:30px;line-height:1.1}.login-heading p{color:var(--muted);margin:8px 0 0;line-height:1.45}.login-field{flex-direction:column;gap:6px;display:flex}.input-with-icon{position:relative}.input-with-icon .material-symbols-rounded{color:#94a3b8;pointer-events:none;font-size:20px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-with-icon .input{min-height:50px;padding-left:42px}.password-input-wrap .input{padding-right:46px}.password-visibility-toggle{border-radius:var(--radius);width:34px;height:34px;color:var(--text-muted);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;transition:background .16s,color .16s;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.password-visibility-toggle:hover{background:var(--surface-2);color:var(--ink)}.password-visibility-toggle:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.password-visibility-toggle .material-symbols-rounded{color:currentColor;pointer-events:none;font-size:20px;position:static;transform:none}.login-error{border-radius:var(--radius);background:#fef2f2;border-left:4px solid #ef4444;padding:10px 12px}.login-submit{justify-content:center;width:100%;min-height:46px;margin-top:4px;font-weight:700}.app-loading{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.app-loading-card{border-radius:var(--radius);width:min(100%,360px);box-shadow:var(--shadow);background:#fff;border:1px solid #e5e7eb;align-items:center;gap:12px;padding:16px;display:flex}.app-loading-mark{width:38px;height:38px;color:var(--primary-600);background:#eaf4f8;border:1px solid #01608533;border-radius:50%;justify-content:center;align-items:center;font-weight:900;display:flex}.app-loading-card strong{color:#0b2238;display:block}.app-loading-card p{color:var(--muted);margin:2px 0 0;font-size:13px}@media (width<=900px){.login-shell{grid-template-columns:1fr}.login-visual{display:none}.login-form-panel{align-items:flex-start;min-height:100vh;padding:16px}.login-card{width:100%;max-width:480px;margin:0 auto;padding:0}.login-mobile-visual{margin:0 0 8px;display:block}.login-heading h2{font-size:26px}}.app{min-height:100vh;display:flex}@supports (min-height:100dvh){.login-shell,.login-visual,.login-form-panel,.app,.app-loading{min-height:100dvh}}.app.sidebar-mini .sidebar{width:var(--sidebar-mini);padding-left:8px;padding-right:8px}.app.sidebar-mini .nav-item{text-align:center;justify-content:center;width:34px;margin-left:auto;margin-right:auto;padding:0}.app.sidebar-mini .nav-ico{margin:0}.app.sidebar-mini .sidebar:hover .nav-item{text-align:left;justify-content:flex-start;width:100%;margin-left:0;margin-right:0;padding:0}.app.sidebar-mini .nav-label{opacity:0;width:0;padding-right:0;overflow:hidden}.app.sidebar-mini .sidebar:hover{width:var(--sidebar-w);padding-left:16px;padding-right:16px}.app.sidebar-mini .sidebar:hover .nav-label{opacity:1;width:auto;padding-right:13px}.app.sidebar-mini .sidebar:hover .sb-text{opacity:1;width:auto}.app.sidebar-mini .sb-text{opacity:0;width:0;overflow:hidden}.app.sidebar-mini .sb-brand{width:var(--sidebar-brand-mark);justify-content:center;align-items:center;gap:0;min-height:36px;margin-left:auto;margin-right:auto;padding:0}.app.sidebar-mini .sidebar:hover .sb-brand{justify-content:flex-start;gap:12px;width:100%;min-height:36px;margin-left:0;margin-right:0;padding:0}.app.sidebar-mini .nav-item .nav-ico{flex-basis:100%;width:100%;margin:0;padding:0}.app.sidebar-mini .sidebar:hover .nav-item .nav-ico{flex-basis:38px;width:38px;padding:0 7px}.overlay{opacity:0;pointer-events:none;z-index:69;background:#0f172a80;transition:opacity .18s;position:fixed;inset:0}.overlay.show{opacity:1;pointer-events:auto}.sidebar{width:var(--sidebar-w);color:var(--ink);border-right:1px solid var(--divider);z-index:70;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;gap:24px;padding:20px 16px;transition:width .3s,transform .3s,padding .3s;display:flex;position:fixed;inset:0 auto 0 0}.sidebar h1{display:none}.sidebar-head{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.sb-brand{border-radius:var(--radius);box-shadow:none;cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:12px;min-height:36px;padding:0;display:flex}.sidebar-mobile-close{border:1px solid var(--divider);border-radius:var(--radius);background:var(--surface-2);width:36px;height:36px;color:var(--text-muted);cursor:pointer;flex:none;justify-content:center;align-items:center;padding:0;transition:background .16s,color .16s,border-color .16s;display:none}.sidebar-mobile-close:hover{color:var(--ink);background:#fff;border-color:#cbd5e1}.sidebar-mobile-close:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.sb-mark{width:var(--sidebar-brand-mark);height:var(--sidebar-brand-mark);background:0 0;border:0;border-radius:50%;flex:none;justify-content:center;align-items:center;display:flex;overflow:hidden}.sb-mark img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.sb-text{min-width:0}.sb-title{color:#0b2238;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sb-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.nav{flex-direction:column;flex:1;gap:6px;min-height:0;padding:0;display:flex}.nav-section,.nav-bottom{flex-direction:column;gap:6px;display:flex}.nav-bottom{border-top:1px solid var(--divider);margin-top:auto;padding-top:16px}.nav-item{height:var(--nav-item-h);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;width:100%;font-size:var(--nav-label-size);font-weight:var(--nav-label-weight);background:0 0;border:0;outline:none;align-items:center;gap:0;margin-bottom:0;padding:0;line-height:20px;transition:background .16s,color .16s,transform .16s;display:flex}.nav-item.active{background:var(--primary-600);color:#fff;box-shadow:0 1px 2px #0f172a14}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active:hover{background:var(--primary-600);color:#fff}.nav-item:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.nav-ico{color:currentColor;opacity:1;width:38px;height:34px;font-family:Material Symbols Rounded;font-size:var(--nav-icon-size);font-variation-settings:"FILL" 0, "wght" 300, "GRAD" 0, "opsz" 20;-webkit-font-feature-settings:"liga";font-feature-settings:"liga" 1;flex:0 0 38px;padding:0 7px;font-style:normal;font-weight:400;line-height:1}.nav-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;padding-right:13px;line-height:20px;transition:width .16s,opacity .16s,padding .16s;overflow:hidden}.nav-danger{color:var(--danger)}.nav-danger .nav-ico{color:currentColor}.nav-danger:hover{background:var(--danger-bg);color:var(--danger)}.nav-item.active .nav-ico,.app.sidebar-mini .nav-item.active .nav-ico{color:#fff;opacity:1}.main{min-width:0;margin-left:var(--sidebar-w);flex-direction:column;flex:1;transition:margin-left .2s;display:flex}.app.sidebar-mini .main{margin-left:var(--sidebar-mini)}.app.sidebar-mini .sidebar:hover~.main{margin-left:var(--sidebar-w)}.mobile-nav-toggle{border-radius:var(--radius);cursor:pointer;color:#0b2238;z-index:59;width:36px;height:36px;box-shadow:var(--shadow);background:#fff;border:1px solid #e2e8f0;justify-content:center;align-items:center;padding:0;transition:background .16s,border-color .16s,transform .16s;display:inline-flex;position:fixed;top:12px;left:12px}.mobile-nav-toggle .material-symbols-rounded{font-size:20px}.mobile-nav-toggle:hover{background:#f8fafc;border-color:#cbd5e1}.mobile-nav-toggle:active{transform:scale(.98)}.mobile-nav-toggle:focus-visible{outline:2px solid var(--focus);outline-offset:2px}@media (width>=901px){.mobile-nav-toggle{display:none}}.page{flex:1;min-height:0;padding:16px;overflow:auto}.page-stack{flex-direction:column;gap:16px;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-title-group{min-width:0}.page-title-group h2{margin:0;font-size:24px;line-height:1.15}.page-title-group p{color:var(--muted);max-width:720px;margin:6px 0 0;line-height:1.45}.page-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #e5e7eb;padding:16px;transition:box-shadow .2s,transform .2s}.card h3{margin:0}.card-toolbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.card-toolbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.range-select{width:160px}.section{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.table{border-collapse:collapse;width:100%;font-size:14px}.table-shell{margin-top:12px;overflow-x:auto}.table-wide{min-width:720px}.table th,.table td{border-bottom:1px solid var(--divider);text-align:left;vertical-align:top;padding:10px 8px}.table th{color:#475569;text-transform:uppercase;letter-spacing:.03em;background:#f8fafc;font-size:12px;font-weight:800}.table tbody tr{transition:background .16s}.table tbody tr:hover{background:#f8fafc}.table-empty{color:var(--muted);text-align:center;padding:18px 8px}.badge{background:var(--chip);color:var(--primary-600);border-radius:999px;padding:4px 8px;font-size:12px;font-weight:600}.btn{border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:36px;box-shadow:none;color:#0b2238;background:#fff;border:1px solid #e7ecf7;align-items:center;gap:8px;padding:8px 14px;font-weight:700;transition:background .16s,border-color .16s,box-shadow .16s,color .16s,transform .16s;display:inline-flex}.btn.primary{background:var(--brand);color:#fff;border-color:#0000;box-shadow:0 8px 18px #0160852e}.btn.ghost{color:#0b2238;background:#fff;border:1px solid #e2e8f0}.btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.btn.primary:hover:not(:disabled){background:var(--brand-600);color:#fff;border-color:#0000}.btn:active{transform:scale(.98)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.input{border:1px solid var(--divider);border-radius:var(--radius);width:100%;min-height:42px;color:var(--ink);font:inherit;background:#fff;padding:10px 12px;transition:border-color .16s,box-shadow .16s,background .16s}.input:focus{border-color:var(--primary-600);outline:none;box-shadow:0 0 0 3px #01608524}.input-error{background:#fff5f5;border-color:#ef4444}.searchbox{border:1px solid var(--divider);border-radius:var(--radius);background:#fff;align-items:center;gap:8px;min-height:42px;margin-bottom:12px;padding:0 12px;transition:border-color .16s,box-shadow .16s;display:flex}.searchbox:focus-within{border-color:var(--primary-600);box-shadow:0 0 0 3px #01608524}.searchbox .icon{color:var(--muted)}.searchbox input{border:0;outline:none;width:100%;font-size:14px}.alert-item{border:1px solid var(--divider);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:10px;display:flex}.alert-item strong{display:block}.alerts-panel{width:min(420px,100vw - 28px);height:min(560px,100vh - 100px);color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:81;background:#fff;border:1px solid #e7ecf7;display:none;position:fixed;bottom:70px;right:14px;overflow:hidden}.alerts-panel.open{flex-direction:column;display:flex}.modal-overlay{z-index:100}.centered-modal{z-index:91;inset:10vh auto auto 50%;transform:translate(-50%)}.modal-overlay .centered-modal{z-index:101}.blacklist-modal{width:min(720px,100vw - 28px);height:auto;max-height:min(760px,100vh - 56px);top:28px}.blocking-alert-modal{width:min(640px,100vw - 28px);height:auto;max-height:min(560px,100vh - 100px);top:12vh}.history-detail-modal{width:min(720px,100vw - 28px);height:auto;max-height:min(620px,100vh - 100px);top:12vh}.delete-confirm-modal{width:min(420px,100vw - 28px);height:auto;max-height:min(420px,100vh - 56px)}.alerts-subtitle{color:var(--muted);margin-top:4px;font-size:13px}.alerts-head{background:#fff;border-bottom:1px solid #eef2f7;justify-content:space-between;align-items:center;padding:16px;display:flex}.alerts-body{flex-direction:column;gap:10px;padding:16px;display:flex;overflow-y:auto}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label,.login-field label{color:#334155;font-size:13px;font-weight:700}.form-field-full{grid-column:1/-1}.form-error{color:#ef4444;margin-top:8px}.form-error-compact{margin-top:4px}.modal-actions,.permission-actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.confirm-copy{color:#334155;margin-bottom:8px;line-height:1.45}.permission-page{justify-content:center;align-items:flex-start;display:flex}.permission-card{width:min(100%,520px);margin-top:40px}.permission-copy{color:#475569;line-height:1.5}.truncate-cell{white-space:nowrap;text-overflow:ellipsis;max-width:240px;overflow:hidden}.image-upload-help{color:var(--muted);font-size:13px;line-height:1.4}.image-preview-shell{margin-top:8px}.form-image-preview,.alert-reference-image{border-radius:var(--radius);object-fit:cover;background:#f8fafc;border:1px solid #dbe3ee;width:100%;max-width:280px;display:block}.form-image-preview{aspect-ratio:4/3}.image-placeholder{border-radius:var(--radius);max-width:280px;min-height:180px;color:var(--muted);text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;justify-content:center;align-items:center;padding:16px;line-height:1.45;display:flex}.image-upload-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.link-button{color:var(--brand);cursor:pointer;background:0 0;border:0;padding:0;font-weight:700;text-decoration:underline}.link-button:focus-visible{outline:2px solid var(--focus);border-radius:6px}.settings-layout{flex-direction:column;gap:16px;display:flex}.settings-catalog-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.settings-catalog-card{flex-direction:column;gap:12px;min-height:148px;display:flex}.settings-catalog-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.settings-catalog-head h3,.settings-summary h3{margin:0}.settings-helper{color:var(--muted);margin:6px 0 0;font-size:14px;line-height:1.4}.settings-manage-btn{flex:none}.settings-manage-btn .material-symbols-rounded{font-size:19px}.settings-chip-list{flex-wrap:wrap;align-content:flex-start;gap:6px;max-height:76px;display:flex;overflow:hidden}.settings-chip{color:#334155;background:#f8fafc;border:1px solid #dbe3ee;border-radius:999px;align-items:center;max-width:100%;min-height:26px;padding:4px 8px;font-size:12px;font-weight:700;line-height:1.1;display:inline-flex}.settings-chip-muted{background:var(--chip);color:var(--primary-600);border-color:#0160852e}.settings-option-list{flex-direction:column;gap:8px;display:flex}.settings-option-row{border:1px solid var(--divider);border-radius:var(--radius);background:#fbfcff;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.settings-option-value{color:#0b2238;word-break:break-word;font-weight:700}.settings-option-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.settings-create-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.settings-note{border-radius:var(--radius);color:#475569;background:#f8fafc;border:1px solid #e2e8f0;padding:10px 12px;font-size:13px;line-height:1.45}.settings-summary{grid-template-columns:minmax(260px,1fr) auto;align-items:center;gap:16px;display:grid}.settings-summary-grid{grid-template-columns:repeat(4,minmax(72px,1fr));gap:8px;min-width:min(100%,420px);display:grid}.settings-summary-label{color:var(--muted);margin-bottom:2px;font-size:12px;display:block}.settings-summary-grid>div{border-radius:var(--radius);background:#f8fafc;border:1px solid #e2e8f0;padding:10px 12px}.settings-summary-grid strong{color:#0b2238;font-size:18px}.settings-catalog-modal{width:min(720px,100vw - 28px);height:auto;max-height:min(720px,100vh - 56px);top:28px}.danger-soft{color:#b91c1c}.danger-soft:hover:not(:disabled){color:#991b1b;background:#fef2f2;border-color:#fecaca}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.overview-summary-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;display:grid}.overview-summary-card{flex-direction:column;grid-column:span 2;justify-content:space-between;gap:8px;min-height:140px;display:flex}.overview-summary-card-wide{grid-column:span 4}.overview-summary-label{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:700}.overview-summary-value{color:#0b2238;font-size:clamp(24px,2.6vw,36px);font-weight:900;line-height:1.05}.overview-summary-helper,.overview-section-helper{color:var(--muted);margin:0;font-size:13px;line-height:1.45}.overview-layout-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;display:grid}.overview-span-12{grid-column:span 12}.overview-span-8{grid-column:span 8}.overview-span-6{grid-column:span 6}.overview-span-4{grid-column:span 4}.overview-mini-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.overview-mini-head h3,.overview-head-actions h3{margin:0}.overview-head-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.chart-shell{width:100%;min-width:0;height:250px}.chart-shell-sm{height:240px}.chart-shell-md{height:260px}.chart-shell-lg{height:280px}.overview-heatmap-scroll{overflow-x:auto}.overview-heatmap-grid{grid-template-columns:72px repeat(24,minmax(34px,1fr));gap:6px;min-width:980px;display:grid}.overview-heatmap-corner,.overview-heatmap-hour,.overview-heatmap-label,.overview-heatmap-cell{text-align:center;border-radius:10px;justify-content:center;align-items:center;min-height:34px;font-size:12px;display:flex}.overview-heatmap-corner,.overview-heatmap-hour,.overview-heatmap-label{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;font-weight:700}.overview-heatmap-cell{font-variant-numeric:tabular-nums;border:1px solid #cbd5e1e6;font-weight:800}.overview-share-list{flex-direction:column;gap:12px;display:flex}.overview-share-row{flex-direction:column;gap:8px;display:flex}.overview-share-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.overview-share-name{color:#0b2238;font-weight:700}.overview-share-value{color:#475569;font-variant-numeric:tabular-nums;font-size:13px}.overview-share-track{background:#e2e8f0;border-radius:999px;height:10px;overflow:hidden}.overview-share-fill{border-radius:999px;height:100%}.overview-list-card{flex-direction:column;gap:10px;display:flex}.overview-list-row{border-radius:var(--radius);background:#f8fafc;border:1px solid #e2e8f0;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.overview-list-position{color:var(--primary-600);font-weight:900}.overview-list-copy{min-width:0}.overview-list-title{color:#0b2238;letter-spacing:.04em;font-weight:800}.overview-list-helper{color:var(--muted);margin-top:4px;font-size:12px}.overview-list-value{color:#0b2238;font-variant-numeric:tabular-nums;font-weight:900}.kpi-card{padding:12px}.kpi-ranking-card{grid-column:span 2;min-width:0}.kpi-ranking-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.kpi-ranking-columns{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;grid-template-columns:repeat(2,minmax(52px,auto));gap:12px;font-size:11px;font-weight:700;display:grid}.kpi-ranking-list{flex-direction:column;gap:8px;margin-top:12px;display:flex}.kpi-ranking-row{border-radius:var(--radius);background:#f8fafc;border:1px solid #e2e8f0;grid-template-columns:24px minmax(0,1fr) repeat(2,minmax(52px,auto));align-items:center;gap:12px;padding:8px 10px;display:grid}.kpi-ranking-position{color:var(--primary-600);font-weight:800}.kpi-ranking-label{color:#0b2238;min-width:0;font-weight:700}.kpi-ranking-metric{text-align:right;font-variant-numeric:tabular-nums;color:#334155}.chart-card-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.chart-card-head h3{margin:0}.chart-toggle{background:#eef2f7;border:1px solid #dbe3ee;border-radius:999px;align-items:center;gap:4px;max-width:100%;padding:4px;display:inline-flex;overflow-x:auto}.chart-toggle-btn{color:#475569;white-space:nowrap;cursor:pointer;background:0 0;border:0;border-radius:999px;flex:none;min-height:32px;padding:8px 12px;font-weight:700;transition:background .16s,color .16s,box-shadow .16s}.chart-toggle-btn.active{color:var(--primary-600);background:#fff;box-shadow:0 2px 8px #0f172a14}.chart-toggle-btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.section-footer{justify-content:flex-end;margin-top:12px;display:flex}@media (width<=900px){.app.sidebar-mini .sidebar,.sidebar{width:100%;max-width:400px;padding:max(20px, env(safe-area-inset-top)) 16px max(20px, env(safe-area-inset-bottom));overscroll-behavior:contain;overflow-y:auto;transform:translate(-100%)}.app.sidebar-mini .sidebar:hover{width:100%;max-width:400px;padding-left:16px;padding-right:16px}.sidebar-mobile-close{display:inline-flex}.app.sidebar-open .sidebar{transform:translate(0)}.app.sidebar-mini .main,.main,.app.sidebar-mini .sidebar:hover~.main{margin-left:0}.app.sidebar-mini .sb-text{display:block}.app.sidebar-mini .nav-label{opacity:1;width:auto;padding-right:13px;overflow:visible}.app.sidebar-mini .nav-item,.app.sidebar-mini .sidebar:hover .nav-item{text-align:left;justify-content:flex-start;width:100%;margin-left:0;margin-right:0;padding:0}.app.sidebar-mini .sb-brand{flex:auto;justify-content:flex-start;gap:12px;width:100%;min-width:0;min-height:36px;margin-left:0;margin-right:0;padding:0}.app.sidebar-mini .sb-text{opacity:1;width:auto;overflow:visible}.app.sidebar-mini .nav-item .nav-ico{flex-basis:38px;width:38px;padding:0 7px}.page{padding:60px 12px 14px}.mobile-nav-toggle{top:max(12px, env(safe-area-inset-top));left:max(12px, env(safe-area-inset-left))}.page-stack{gap:12px}.page-title-group h2{font-size:22px}.page-title-group p{font-size:14px}.card{padding:14px}.page-header,.card-toolbar,.card-toolbar-actions,.page-actions{flex-direction:column;align-items:flex-start}.card-toolbar-actions,.card-toolbar-actions .input,.card-toolbar-actions .btn,.range-select{width:100%}.card-toolbar-actions .btn{justify-content:center}.centered-modal{top:max(14px, env(safe-area-inset-top));left:max(14px, env(safe-area-inset-left));right:max(14px, env(safe-area-inset-right));width:auto;transform:none}.alerts-panel,.blacklist-modal,.blocking-alert-modal,.history-detail-modal,.delete-confirm-modal,.settings-catalog-modal{max-height:calc(100vh - 28px)}@supports (max-height:100dvh){.alerts-panel,.blacklist-modal,.blocking-alert-modal,.history-detail-modal,.delete-confirm-modal,.settings-catalog-modal{max-height:calc(100dvh - 28px)}}.alerts-panel:not(.centered-modal){right:12px;bottom:max(12px, env(safe-area-inset-bottom));width:calc(100vw - 24px);height:min(520px,100vh - 84px)}.alerts-head{align-items:flex-start;gap:12px}.alerts-head .btn{flex:none}.alerts-body{padding:14px}.modal-actions .btn,.permission-actions .btn{flex:140px;justify-content:center}.form-grid,.settings-option-row,.settings-create-row,.settings-summary{grid-template-columns:1fr}.settings-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}.settings-catalog-head{flex-direction:column}.settings-option-actions{justify-content:flex-start}.kpi-ranking-card{grid-column:auto}.overview-summary-grid,.overview-layout-grid{grid-template-columns:1fr;gap:12px}.overview-summary-card,.overview-summary-card-wide,.overview-span-12,.overview-span-8,.overview-span-6,.overview-span-4{grid-column:auto}.overview-mini-head,.overview-head-actions{flex-direction:column;align-items:flex-start;width:100%}.overview-head-actions .btn,.overview-head-actions .chart-toggle,.chart-card-head .chart-toggle{width:100%}.chart-shell{height:230px}.chart-shell-sm{height:220px}.chart-shell-md,.chart-shell-lg{height:240px}.overview-heatmap-scroll{margin:0 -2px;padding-bottom:4px}.overview-heatmap-grid{grid-template-columns:56px repeat(24,minmax(30px,1fr));gap:4px;min-width:860px}.overview-heatmap-corner,.overview-heatmap-hour,.overview-heatmap-label,.overview-heatmap-cell{border-radius:8px;min-height:30px}.kpi-ranking-head{flex-direction:column;align-items:flex-start}.kpi-ranking-row{grid-template-columns:24px minmax(0,1fr) repeat(2,minmax(42px,auto));gap:8px}.kpi-ranking-metric{text-align:right}.chart-card-head{flex-direction:column;align-items:flex-start}.overview-share-head,.overview-list-row{grid-template-columns:24px minmax(0,1fr) auto}.overview-share-head{flex-direction:column;align-items:flex-start}.overview-list-value{grid-column:auto}.alert-detail-layout{grid-template-columns:1fr}.alert-detail-image{justify-content:flex-start}.form-image-preview,.alert-reference-image,.image-placeholder{max-width:100%}.section-footer{justify-content:flex-start}.table-wide{min-width:640px}}.alert-row{border:1px solid var(--divider);border-radius:var(--radius);background:#fff;margin-bottom:10px;padding:12px}.alert-detail-layout{grid-template-columns:minmax(0,1fr) minmax(220px,280px);align-items:start;gap:16px;display:grid}.alert-detail-copy{flex-direction:column;gap:8px;display:flex}.alert-detail-patente{font-size:24px;display:block}.alert-detail-meta{color:#334155;font-size:15px}.alert-detail-line{color:#0f172a;line-height:1.45}.alert-detail-image{justify-content:flex-end;display:flex}.alert-row.red{background:#ef444414;border-color:#ef444459}.alert-row.yellow{background:#f59e0b1a;border-color:#f59e0b59}.alert-row small{color:var(--muted)}.alert-actions{justify-content:flex-end;margin-top:8px;display:flex}.alert-actions-spaced{margin-top:16px}
