@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{font-family:Space Grotesk,system-ui,-apple-system,sans-serif;color:#1f2937;background:#f3f6fb}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(1200px 600px at 10% -10%,#e7eefc,#f8fafc 55%,#f1f5f9)}html,body,#root{width:100%;min-height:100%}a{color:inherit}.app-shell{display:grid;grid-template-columns:clamp(220px,18vw,260px) minmax(0,1fr);min-height:100vh}.sidebar{background:linear-gradient(180deg,#fff,#f8fafc);border-right:1px solid #dbe5f2;padding:24px 18px;display:flex;flex-direction:column;gap:24px}.sidebar-brand{display:flex;align-items:center;gap:12px}.brand-mark{width:42px;height:42px;border-radius:12px;background:conic-gradient(from 180deg,#7c5cff,#00c2ff,#7c5cff)}.brand-title{font-weight:700;letter-spacing:.5px}.brand-sub{font-size:12px;color:#66758f}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-section{font-size:12px;text-transform:uppercase;letter-spacing:.15em;color:#7a8699;margin-bottom:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;border-radius:12px;background:transparent;color:#334155;cursor:pointer;font-size:14px;transition:all .2s ease;text-decoration:none}.nav-item:hover{background:#e8eef9}.nav-item.active{background:#dbeafe;box-shadow:inset 0 0 0 1px #93c5fd}.nav-parent{justify-content:space-between}.nav-parent-label{display:flex;align-items:center;gap:10px}.nav-chevron{transition:transform .2s ease}.nav-chevron.open{transform:rotate(180deg)}.nav-sub-list{display:grid;gap:6px;margin-top:-2px}.nav-sub{margin-left:16px;padding:8px 12px;font-size:13px}.nav-item.danger{color:#ffb0b0}.sidebar-footer{margin-top:auto}.app-main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 32px;border-bottom:1px solid #dbe5f2;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:90}.topbar-title .title{font-size:22px;font-weight:600}.topbar-title .subtitle{font-size:13px;color:#64748b}.topbar-actions{display:flex;align-items:center;gap:12px}.search{display:flex;align-items:center;gap:8px;background:#fff;padding:8px 12px;border-radius:12px;border:1px solid #dbe5f2}.search input{background:transparent;border:none;color:#1f2937;outline:none}.icon-btn{background:#fff;border:1px solid #dbe5f2;color:#475569;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;cursor:pointer}.user-chip{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #dbe5f2;padding:6px 12px;border-radius:14px;font-size:12px}.user-chip-btn{border:none;cursor:pointer}.user-menu{position:relative;z-index:95}.menu-chevron{color:#64748b;transition:transform .2s ease}.menu-chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:170px;background:#fff;border:1px solid #dbe5f2;border-radius:10px;box-shadow:0 10px 25px #0f172a1f;padding:8px;display:grid;gap:6px;z-index:120}.user-dropdown-item{display:flex;align-items:center;gap:8px;background:transparent;border:none;border-radius:8px;padding:8px 10px;color:#334155;cursor:pointer;text-align:left}.user-dropdown-item:hover{background:#f1f5f9}.user-dropdown-item.danger{color:#dc2626}.user-chip .avatar{width:30px;height:30px;border-radius:10px;background:#7c5cff;display:grid;place-items:center;font-weight:700}.user-chip .name{font-weight:600}.user-chip .role{color:#64748b}.app-content{padding:28px 32px 40px;min-width:0}.dashboard{display:flex;flex-direction:column;gap:24px}.traffic-dashboard{gap:16px}.traffic-main-panel{min-height:760px}.traffic-main-header{align-items:stretch;flex-direction:column;gap:8px}.traffic-chart-wrap{margin-bottom:16px}.traffic-filter-shell{display:flex;align-items:center;gap:6px;width:fit-content;max-width:100%;margin-left:auto}.traffic-filter-label{font-size:11px;font-weight:700;color:#243247;line-height:1;padding-right:1px}.traffic-picker-wrap{position:relative;width:380px;max-width:calc(100vw - 140px)}.traffic-date-trigger{width:100%;height:36px;border-radius:8px;border:1px solid #9ab8ec;background:#fff;color:#344153;display:flex;align-items:center;justify-content:space-between;padding:0 11px 0 14px;font-size:10px;font-weight:600;line-height:1;cursor:pointer}.traffic-date-trigger svg{width:12px;height:12px}.traffic-date-trigger.is-open,.traffic-date-trigger:hover{border-color:#3f7de8}.traffic-date-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:35;width:100%;border-radius:8px;border:1px solid #d9dee8;background:#fff;box-shadow:0 8px 18px #1e2d4824;overflow:hidden}.traffic-date-zone{height:34px;display:flex;align-items:center;justify-content:flex-end;padding:0 15px;color:#51627d;font-size:10px;border-bottom:1px solid #e4e9f1}.traffic-date-month-head{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid #e4e9f1}.traffic-month-nav{min-height:45px;display:flex;align-items:center;gap:6px;padding:0 10px}.traffic-month-nav strong{flex:1 1 auto;text-align:center;font-size:10px;color:#2e3a4d;font-weight:700}.traffic-month-nav-right{border-left:1px solid #edf1f6}.traffic-nav-btn{width:19px;height:19px;border-radius:5px;border:1px solid transparent;color:#6b7b91;background:transparent;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.traffic-nav-btn svg{width:11px;height:11px}.traffic-nav-btn:hover{border-color:#d7e2f5;background:#f5f8ff}.traffic-calendar-dual{display:grid;grid-template-columns:1fr 1fr}.traffic-calendar{padding:9px 9px 6px}.traffic-calendar+.traffic-calendar{border-left:1px solid #edf1f6}.traffic-week-head{display:grid;grid-template-columns:repeat(7,1fr);color:#3e4b5c;font-size:10px;font-weight:600;margin-bottom:5px}.traffic-week-head span{text-align:center}.traffic-day-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px 1px}.traffic-day-btn{width:21px;height:21px;margin:0 auto;border-radius:50%;border:none;background:transparent;color:#2e3a4d;font-size:9px;cursor:pointer}.traffic-day-btn.is-muted{color:#c8ced8}.traffic-day-btn:hover:not(:disabled):not(.is-selected){background:#edf3ff}.traffic-day-btn.is-selected{background:#2d6bff;color:#fff}.traffic-day-btn:disabled{color:#d9dde6;cursor:not-allowed}.traffic-date-actions{min-height:39px;border-top:1px solid #e4e9f1;display:flex;align-items:center;justify-content:space-between;padding:0 11px}.traffic-time-toggle{display:inline-flex;align-items:center;gap:6px;color:#b8c0ce;font-size:10px;font-weight:600}.traffic-time-toggle .switch{width:35px;height:20px;border-radius:10px;background:#d8dde6;position:relative}.traffic-time-toggle .switch:after{content:"";width:16px;height:16px;border-radius:50%;background:#f5f6fa;position:absolute;top:2px;left:2px}.traffic-action-buttons{display:inline-flex;align-items:center;gap:6px}.traffic-action-buttons .ghost{min-width:48px;min-height:25px;font-size:10px;padding:0 8px}.traffic-action-buttons .btn{min-width:48px;min-height:25px;border-radius:6px;border:1px solid #2d6bff;background:linear-gradient(180deg,#3f7dff,#2d6bff);color:#fff;font-weight:600;font-size:10px;padding:0 10px;cursor:pointer;box-shadow:0 4px 9px #2d6bff42}.traffic-action-buttons .btn:hover:not(:disabled){border-color:#2460ef;background:linear-gradient(180deg,#4e89ff,#356fff)}.traffic-action-buttons .btn:active:not(:disabled){border-color:#2057de;background:linear-gradient(180deg,#2f69ec,#245fe5)}.traffic-action-buttons .btn:disabled{border-color:#c7d7fb;background:#dce7ff;color:#95b2f5;box-shadow:none;cursor:not-allowed}.traffic-filter-sub{margin-left:3px}.traffic-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin-bottom:16px}.traffic-stat-card{border:1px solid #d6e2f5;border-radius:16px;padding:16px 18px;background:linear-gradient(170deg,#fff,#f4f8ff);box-shadow:0 8px 20px #1e408214}.traffic-stat-card.is-total{background:radial-gradient(180px 120px at 90% -10%,#2d6bff33,#2d6bff00 70%),linear-gradient(170deg,#fff,#f4f8ff)}.traffic-stat-card.is-remaining{background:radial-gradient(220px 130px at 100% 0%,#1bad922e,#1bad9200 72%),linear-gradient(170deg,#fff,#f2fbf8)}.traffic-stat-card.is-profit{background:radial-gradient(220px 130px at 100% 0%,#2d6bff29,#2d6bff00 72%),linear-gradient(170deg,#fff,#f2f8ff)}.traffic-stat-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.traffic-stat-title{color:#334155;font-size:14px;font-weight:700}.traffic-stat-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;font-size:11px;color:#31548f;background:#e7f0ff;border:1px solid #c9daf8}.traffic-stat-badge.is-soft{color:#0f766e;background:#d9f8ef;border-color:#aee8d5}.traffic-stat-badge.is-loss{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.traffic-stat-value{margin-top:10px;font-size:30px;line-height:1.1;font-weight:700;color:#172554}.traffic-stat-meta{margin-top:4px;color:#64748b;font-size:12px}.traffic-usage-panel{margin-top:12px;border-radius:12px;border:1px solid #dce8fb;background:#f5f9ffe6;padding:10px 12px}.traffic-usage-row{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#284169;font-size:12px;font-weight:600}.traffic-usage-row.is-muted{margin-top:8px;color:#5f728f;font-weight:500}.traffic-usage-track{height:8px;margin-top:8px;border-radius:999px;background:#d8e5fb;overflow:hidden}.traffic-usage-fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#3f7dff,#1f5de0)}.traffic-remain-wrap{margin-top:10px;display:flex;align-items:flex-start;gap:20px}.traffic-remain-ring{--traffic-ring-pct: 0%;width:120px;height:120px;border-radius:50%;background:conic-gradient(#10b981 var(--traffic-ring-pct),#d8efe8 0);display:grid;place-items:center;flex:0 0 auto}.traffic-remain-ring-inner{width:92px;height:92px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px #dcebe5}.traffic-remain-ring-inner strong{font-size:20px;line-height:1;color:#0f766e}.traffic-remain-ring-inner span{margin-top:4px;font-size:11px;color:#64748b}.traffic-remain-info{min-width:0;flex:1 1 auto}.traffic-profit-ring{background:conic-gradient(#2d6bff var(--traffic-ring-pct),#dae6ff 0)}.traffic-profit-ring .traffic-remain-ring-inner{box-shadow:inset 0 0 0 1px #d9e5ff}.traffic-profit-ring .traffic-remain-ring-inner strong{color:#1d4ed8}.traffic-profit-ring.is-loss{background:conic-gradient(#ef4444 var(--traffic-ring-pct),#fee2e2 0)}.traffic-profit-ring.is-loss .traffic-remain-ring-inner strong{color:#b91c1c}.traffic-profit-list{margin-top:6px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:18px;row-gap:8px}.traffic-stat-card.is-profit .traffic-remain-wrap{justify-content:center;align-items:center}.traffic-stat-card.is-profit .traffic-remain-info{flex:0 1 780px;display:flex;flex-direction:column;align-items:center}.traffic-stat-card.is-profit .traffic-profit-list{width:min(780px,100%);margin-top:2px}.traffic-stat-card.is-profit .traffic-profit-row{width:100%}.traffic-stat-card.is-profit .traffic-stat-meta{margin-top:8px;text-align:center}.traffic-profit-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:#4a5d79}.traffic-profit-row strong{font-size:16px;line-height:1.2;font-weight:700;color:#1e293b}.traffic-profit-row.is-profit strong{color:#1d4ed8}.traffic-profit-row.is-loss strong{color:#b91c1c}.traffic-detail-head{display:flex;justify-content:space-between;align-items:center;margin:8px 0 10px}.traffic-detail-title{font-size:28px;font-weight:700}.traffic-detail-tabs{display:flex;align-items:center;gap:8px}.traffic-detail-tabs .ghost.is-active{background:#2563eb;color:#fff;border-color:#2563eb}.traffic-table-wrap{max-height:none}.dashboard-hourly-section{margin-top:24px;padding-top:16px;border-top:1px dashed #d7deea}.dashboard-hourly-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dashboard-hourly-filters select{min-width:120px;padding:8px 10px;border-radius:10px;border:1px solid #c7d4e6;background:#fff;color:#1f2f46}.dashboard-hourly-summary{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.dashboard-hourly-chart{margin-top:14px}.hourly-type-tabs{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px;border:1px solid #dbe5f2;border-radius:14px;background:#f8fbff}.hourly-type-tabs-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hourly-type-tab{border:1px solid #dbe5f2;background:#fff;color:#1f2f46;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease}.hourly-type-tab:hover{border-color:#93c5fd;background:#eff6ff}.hourly-type-tab.active{border-color:#3b82f6;background:linear-gradient(180deg,#dbeafe,#bfdbfe);box-shadow:0 6px 14px #3b82f62e}.hourly-type-tabs .dashboard-hourly-filters{justify-content:flex-end}.hourly-type-tabs .dashboard-hourly-filters select{min-width:154px;height:36px;padding:0 34px 0 12px;border-radius:12px;border:1px solid #bdd0eb;background:linear-gradient(180deg,#fffffff5,#f4f8fff5),#fff;color:#1f2f46;font-size:13px;font-weight:600;appearance:none;-webkit-appearance:none;-moz-appearance:none;box-shadow:0 3px 10px #1f2f4614;transition:all .2s ease;background-image:linear-gradient(45deg,transparent 50%,#5f7395 50%),linear-gradient(135deg,#5f7395 50%,transparent 50%),linear-gradient(180deg,#fffffff5,#f4f8fff5);background-position:calc(100% - 16px) 15px,calc(100% - 10px) 15px,0 0;background-size:6px 6px,6px 6px,100% 100%;background-repeat:no-repeat}.hourly-type-tabs .dashboard-hourly-filters select:hover{border-color:#8db4e8;box-shadow:0 5px 14px #2d6bff29}.hourly-type-tabs .dashboard-hourly-filters select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f629,0 8px 18px #2d6bff29}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.kpi-card{background:#fff;border:1px solid #dbe5f2;border-radius:16px;padding:16px}.kpi-label{color:#64748b;font-size:13px}.kpi-value{font-size:24px;font-weight:700;margin:8px 0}.kpi-change{font-size:12px;color:#4ee3a5}.kpi-change.down{color:#ff9b9b}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}.panel{background:#fff;border:1px solid #dbe5f2;border-radius:18px;padding:16px;min-height:320px;display:flex;flex-direction:column;min-width:0}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.panel-title{font-weight:600}.panel-sub{font-size:12px;color:#64748b}.panel-body{flex:1}.ghost{background:transparent;color:#2563eb;border:1px solid #bfdbfe;padding:6px 12px;border-radius:10px;cursor:pointer}.traffic-toolbar{display:flex;align-items:center;gap:10px}.traffic-range-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.traffic-range.is-active{background:#2563eb;color:#fff;border-color:#2563eb}.pie-wrap{display:grid;grid-template-columns:1fr 140px;gap:12px;align-items:center}.legend{display:flex;flex-direction:column;gap:8px;font-size:12px;color:#475569}.legend-item{display:flex;align-items:center;gap:8px}.legend .dot{width:10px;height:10px;border-radius:999px}.events{list-style:none;padding:0;margin:0;display:grid;gap:12px}.events li{display:grid;grid-template-columns:60px 1fr;gap:12px;padding:10px;border-radius:12px;background:#f8fafc}.muted{color:#64748b;font-size:12px}.login-page{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;overflow:hidden;background:radial-gradient(640px 340px at 14% 16%,#00c2ff33,#00c2ff00 72%),radial-gradient(720px 380px at 86% 88%,#7c5cff33,#7c5cff00 70%),linear-gradient(180deg,#f4f8ff,#edf3fb)}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:50%;filter:blur(10px);pointer-events:none}.login-page:before{width:300px;height:300px;top:-90px;right:-70px;background:radial-gradient(circle,#00c2ff33,#00c2ff00 70%)}.login-page:after{width:360px;height:360px;bottom:-140px;left:-120px;background:radial-gradient(circle,#7c5cff33,#7c5cff00 72%)}.login-card{width:min(420px,100%);position:relative;z-index:1;background:#fffffff5;border:1px solid #dbe5f2;border-radius:20px;padding:28px;box-shadow:0 22px 50px #0f172a1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px}.login-form{display:grid;gap:14px;margin-top:16px}.login-form input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#1f2937}.login-form label{display:grid;gap:6px;font-size:13px}.primary{background:linear-gradient(135deg,#7c5cff,#00c2ff);color:#fff;font-weight:700;border:none;padding:12px 14px;border-radius:12px;cursor:pointer}.primary:disabled{opacity:.7;cursor:not-allowed}.error{color:#ff9b9b;font-size:12px}.login-footer{margin-top:16px;font-size:12px;color:#7f8fb4}.users-page{display:flex;flex-direction:column;gap:18px}.users-create-panel{min-height:auto}.users-form{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.users-form input,.users-form select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#1f2937}.users-error{margin-top:-8px}.users-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:18px}.device-config-page{display:flex;flex-direction:column;gap:16px}.device-config-kpi{margin-top:6px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.device-config-kpi-card{border:1px solid #dbe5f2;background:#f8fbff;border-radius:12px;padding:10px 12px}.device-config-kpi-label{color:#64748b;font-size:12px}.device-config-kpi-value{margin-top:4px;font-size:22px;font-weight:700;color:#1f2f46}.device-config-kpi-value.is-small{font-size:14px;font-weight:600}.device-config-add-grid{grid-template-columns:1.2fr .8fr 1fr}.device-config-actions{margin-top:4px;display:flex;align-items:center;justify-content:flex-start;gap:10px}.device-config-table-wrap{margin-top:12px}.device-config-region-input{width:100%;min-width:110px;padding:8px 10px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#1f2937}.device-config-row-actions{display:flex;align-items:center;gap:8px}.device-monitor-updated-card{border:1px solid #dbe5f2;background:#f8fbff;border-radius:16px;padding:18px 20px;display:flex;flex-direction:column;gap:8px}.device-monitor-updated-label{color:#64748b;font-size:14px;font-weight:600}.device-monitor-updated-value{font-size:40px;font-weight:700;color:#1e2f48;line-height:1.1}.device-monitor-group-list{margin-top:12px;display:flex;flex-direction:column;gap:12px}.device-monitor-overview{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.device-monitor-overview-card{border:1px solid #dbe5f2;background:radial-gradient(140px 70px at 95% -10%,#2d6bff29,#2d6bff00 80%),#f8fbff;border-radius:14px;padding:12px 14px}.device-monitor-overview-label{color:#64748b;font-size:12px;font-weight:600}.device-monitor-overview-value{margin-top:4px;color:#1f2f46;font-size:28px;font-weight:700;line-height:1.1}.device-monitor-overview-value.is-small{font-size:20px}.device-monitor-tabs{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px;padding:8px;border:1px solid #dbe5f2;border-radius:14px;background:#f8fbff}.device-monitor-tab{border:1px solid #dbe5f2;background:#fff;color:#1f2f46;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.device-monitor-tab:hover{border-color:#93c5fd;background:#eff6ff}.device-monitor-tab.active{border-color:#3b82f6;background:linear-gradient(180deg,#dbeafe,#bfdbfe);box-shadow:0 6px 14px #3b82f62e}.device-monitor-group-card{border:1px solid #dbe5f2;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);padding:12px 14px;box-shadow:0 8px 20px #0f172a0d}.device-monitor-group-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.device-monitor-toolbar{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.device-monitor-sync-switches{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px}button.ghost.is-enabled{border-color:#86efac;background:#f0fdf4;color:#166534}.device-monitor-pagination{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:10px}.device-monitor-table tbody tr{cursor:default}.device-monitor-table{table-layout:fixed}.device-monitor-col-id{width:40%}.device-monitor-col-reported{width:36%}.device-monitor-col-status{width:24%}.device-monitor-table tbody tr:nth-child(2n){background:#fbfdff}.device-monitor-table tbody tr:hover{background:#f2f7ff}.device-monitor-device-id{display:inline-flex;align-items:center;padding:2px 10px;border:1px solid #dbe5f2;border-radius:999px;background:#fff;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px}.device-monitor-count-badge{display:inline-flex;min-width:28px;justify-content:center;align-items:center;border-radius:999px;padding:2px 8px;background:#e0f2fe;color:#0f4c81;font-weight:700}.device-monitor-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:2px 10px;border-radius:999px;font-weight:700;font-size:12px}.device-monitor-status-badge.is-alive{background:#dcfce7;color:#166534}.device-monitor-status-badge.is-offline{background:#fee2e2;color:#991b1b}@media(max-width:960px){.device-monitor-overview,.users-authorize-options,.users-authorize-summary,.users-authorize-footer{grid-template-columns:1fr}}button.danger{border:1px solid #fecdd3;background:#fff1f2;color:#be123c}button.danger:hover{background:#ffe4e6}.users-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table{width:100%;border-collapse:collapse;min-width:680px}.users-table th,.users-table td{padding:10px 8px;border-bottom:1px solid #e2e8f0;text-align:left;font-size:13px}.users-table tbody tr{cursor:pointer}.users-table tbody tr:hover{background:#f1f5f9}.users-table tbody tr.is-active{background:#dbeafe}.users-name{font-weight:600}.users-danger-btn{color:#ffb0b0}.users-row-actions{display:flex;align-items:center;gap:8px}.users-authorize-dialog{width:min(760px,calc(100vw - 32px))}.users-authorize-summary{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px 16px;align-items:center;padding:14px 18px;margin-bottom:16px;border:1px solid #d9e7fb;border-radius:16px;background:linear-gradient(135deg,#f8fbff,#eef5ff);color:#1e293b}.users-authorize-summary strong{font-size:26px;line-height:1;color:#2563eb}.users-authorize-summary span{margin-left:8px;font-size:14px;font-weight:600}.users-authorize-groups{display:grid;gap:16px}.users-authorize-group{border:1px solid #dbe7f7;border-radius:18px;padding:18px;background:linear-gradient(180deg,#fdfefe,#f7faff);display:grid;gap:14px;box-shadow:0 12px 30px #94a3b814}.users-authorize-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid #e6edf7}.users-authorize-group-head .panel-title{font-size:18px}.users-authorize-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.users-authorize-option{display:flex;align-items:center;gap:10px;min-width:0;color:#1f2937;font-size:14px;font-weight:600;padding:14px 16px;border:1px solid #dce7f6;border-radius:14px;background:#fff;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease,transform .2s ease;cursor:pointer}.users-authorize-option:hover{border-color:#9dbcf9;box-shadow:0 10px 20px #3b82f614;transform:translateY(-1px)}.users-authorize-option.is-checked{border-color:#5b8cff;background:linear-gradient(135deg,#3b82f61a,#2563eb0a);box-shadow:0 12px 24px #2563eb1f}.users-authorize-option input{margin:0;width:18px;height:18px;accent-color:#3b82f6}.users-authorize-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px 16px;align-items:center;margin-top:18px;padding-top:18px;border-top:1px solid #e5edf8}.records-list{display:grid;gap:10px;max-height:520px;overflow:auto}.record-item{border:1px solid #dbe5f2;background:#f8fafc;border-radius:12px;padding:10px;display:grid;gap:8px}.record-line{display:grid;grid-template-columns:70px 1fr;gap:10px;align-items:start;font-size:12px}.record-ua{word-break:break-word}.task-page{display:block}.task-page-detail{margin-top:-13px}.task-page-detail .task-workbench{margin-top:0}.toast{position:fixed;top:20px;right:20px;z-index:60;min-width:180px;max-width:360px;padding:10px 14px;border-radius:10px;border:1px solid transparent;box-shadow:0 8px 24px #0f172a29;font-size:13px;font-weight:600}.toast.success{background:#ecfdf3;border-color:#86efac;color:#166534}.toast.error{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.task-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.task-kpi{border:1px solid #dbe5f2;background:#f8fafc;border-radius:12px;padding:14px}.task-kpi-label{font-size:12px;color:#64748b}.task-kpi-value{margin-top:8px;font-size:24px;font-weight:700}.task-form{display:grid;gap:12px}.task-form-readonly-group{border:0;margin:0;padding:0;min-inline-size:0;display:grid;gap:12px}.task-form-readonly-tip{font-size:12px;color:#b45309;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;padding:8px 10px}.task-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.task-form-full{grid-column:1 / -1}.task-inline-row{display:flex;gap:8px;align-items:center}.task-inline-row input{flex:1 1 auto}.task-list-head{display:inline-flex;align-items:center;gap:12px}.task-platform-switch{display:inline-flex;align-items:center;gap:6px;padding:4px;border:1px solid #dbe5f2;border-radius:10px;background:#f8fbff}.task-platform-switch .ghost{min-height:30px;padding:4px 12px;border-radius:8px;border-color:transparent;color:#5b6f86}.task-platform-switch .ghost.is-active{background:#e8f0ff;border-color:#b9cdf4;color:#1f4a86}.task-detail-filter{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 10px;border:1px solid #dbe5f2;border-radius:12px;background:linear-gradient(180deg,#fff,#f8fbff)}.task-detail-filter label{display:flex;align-items:center;gap:6px;font-size:12px;color:#475569;font-weight:600}.task-detail-filter input[type=date]{height:34px;padding:6px 10px;border-radius:8px;border:1px solid #dbe5f2;background:#fff;color:#0f172a}.task-detail-filter-actions{display:flex;align-items:center;gap:6px}.task-detail-filter-actions .ghost{min-height:34px;padding:6px 12px;border-radius:9px}.task-detail-filter-actions .ghost.is-active{border-color:#2563eb;color:#1d4ed8;background:#e8f0ff}.task-form label{display:grid;gap:6px;font-size:13px}.task-checkbox,.task-form label.task-checkbox{display:flex;align-items:center;gap:8px}.task-checkbox input[type=checkbox]{width:16px;height:16px}.task-form input,.task-form select,.task-form textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#1f2937}.task-form select{min-height:44px}.task-priority-account-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.task-priority-account-row label{gap:8px}.task-priority-account-row select{-webkit-appearance:none;appearance:none;height:44px;min-height:44px;padding:10px 40px 10px 12px;border-radius:12px;border:1px solid #c8d8ee;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5.25L7 9.25L11 5.25' fill='none' stroke='%2364798b' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px 14px;box-shadow:0 1px 2px #0f172a08;transition:border-color .2s ease,box-shadow .2s ease}.task-priority-account-row select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd38}.task-workbench{margin-top:18px;display:block}.task-subnav{display:flex;gap:8px;margin-bottom:12px}.task-subnav-item{border:1px solid #2a3c62;background:#10182e;color:#cfe0ff;border-radius:10px;padding:8px 12px;cursor:pointer}.task-subnav-item.active{border-color:#4665a0;background:#1a2948;color:#fff}.task-detail-wrap{display:grid;grid-template-columns:260px 1fr;gap:12px}.task-detail-single{grid-template-columns:1fr}.task-detail-table tbody tr{cursor:default}.task-detail-table{width:100%;min-width:900px;table-layout:fixed}.task-detail-table th,.task-detail-table td{overflow-wrap:anywhere}.analysis-page{display:grid;gap:14px}.analysis-days-select{display:grid;gap:6px;font-size:12px;color:#475569}.analysis-days-select select{min-width:120px;height:36px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#0f172a;padding:6px 10px}.analysis-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:10px}.analysis-kpi{border:1px solid #dbe5f2;border-radius:12px;background:linear-gradient(180deg,#fff,#f8fbff);padding:12px 14px}.analysis-kpi-label{color:#64748b;font-size:12px}.analysis-kpi-value{margin-top:6px;font-size:26px;font-weight:700;color:#0f172a}.analysis-chart-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.analysis-span-2{grid-column:1 / -1}.analysis-logad-controls{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.analysis-logad-progress{display:inline-flex;align-items:center;gap:8px;padding:0 2px}.analysis-logad-progress-label{font-size:12px;color:#475569;white-space:nowrap}.analysis-logad-progress-track{width:180px;height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.analysis-logad-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#2563eb,#10b981)}.analysis-logad-progress .ghost{min-height:28px;padding:2px 10px;border-radius:8px;font-size:12px}.analysis-logad-controls label{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#475569}.analysis-logad-controls select{min-width:110px;height:32px;border-radius:8px;border:1px solid #dbe5f2;background:#fff;color:#0f172a;padding:4px 8px}.analysis-multi-select-wrap,.analysis-multi-select{position:relative}.analysis-multi-select-trigger{min-width:200px;max-width:340px;height:32px;border-radius:8px;font-size:12px;border:1px solid #dbe5f2;background:#fff;color:#0f172a;padding:4px 10px;text-align:left;display:inline-flex;align-items:center}.analysis-multi-select-trigger span{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.analysis-multi-select-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:40;width:min(420px,72vw);border-radius:10px;border:1px solid #dbe5f2;background:#fff;box-shadow:0 12px 24px #0f172a1f;padding:8px}.analysis-multi-select-actions{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.analysis-multi-select-actions .ghost{min-height:28px;border-radius:8px;padding:2px 10px;font-size:12px}.analysis-multi-select-search{padding-top:8px}.analysis-multi-select-search input{width:100%;height:32px;border-radius:8px;border:1px solid #dbe5f2;background:#fff;color:#0f172a;padding:4px 10px;font-size:12px;outline:none}.analysis-multi-select-search input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f61f}.analysis-multi-select-list{max-height:220px;overflow:auto;padding-top:8px;display:grid;gap:4px}.analysis-multi-select-item{display:flex;align-items:center;gap:8px;min-height:28px;font-size:12px;color:#334155}.analysis-multi-select-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:1200px){.analysis-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.task-detail-page{display:grid;gap:12px}.detail-block{border:1px solid #e5e7eb;border-radius:10px;background:#fff;padding:10px}.detail-toolbar{margin-top:0;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.detail-presets{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.detail-presets .ghost.is-active{border-color:#93c5fd;color:#1d4ed8;background:#eff6ff;box-shadow:none}.detail-presets .ghost{min-height:32px;font-weight:500;border-color:#e5e7eb;color:#334155;background:#fff;border-radius:8px;padding:4px 10px}.detail-range{display:flex;align-items:center;gap:6px;color:#64748b;font-size:12px}.detail-range input[type=date]{height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;padding:4px 8px;color:#0f172a;font-size:12px}.detail-filters-grid{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.detail-filters-panel{margin-top:10px;display:grid;grid-template-columns:56px 1fr;align-items:start;gap:8px}.detail-filters-head{height:36px;display:inline-flex;align-items:center;gap:4px;color:#334155;font-weight:600;font-size:14px}.detail-filters-grid-flat{margin-top:0}.detail-filter-item{position:relative;height:36px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;display:flex;align-items:center;padding:0 8px;gap:4px}.detail-filter-prefix{color:#374151;font-size:12px;font-weight:500;white-space:nowrap}.detail-filter-item select{border:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:transparent;background-image:none;box-shadow:none;width:100%;height:100%;color:#475569;padding:0;font-size:12px;line-height:1.2}.detail-filter-item select:focus{outline:none;background-color:transparent;box-shadow:none}.detail-filter-item:focus-within{border-color:#cbd5e1;box-shadow:0 0 0 2px #cbd5e138}.detail-chip-section{margin-top:2px;display:grid;gap:6px}.detail-chip-label{font-size:12px;font-weight:600;color:#475569}.detail-chip-row{display:flex;flex-wrap:wrap;gap:6px}.detail-chip-row-dimensions{flex-wrap:wrap;overflow:visible}.detail-chip-row-metrics{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:2px;scrollbar-width:thin}.detail-chip-row-metrics .detail-chip{flex:0 0 auto}.detail-chip{min-height:30px;border-color:#e5e7eb;color:#475569;background:#fff;font-weight:500;border-radius:16px;padding:4px 10px;font-size:12px}.detail-chip.is-active{border-color:#bfdbfe;color:#1d4ed8;background:#eff6ff;box-shadow:none}.detail-chip.is-required{border-style:dashed}.detail-metrics-table{min-width:980px}.detail-table-wrap{margin-top:10px;border:1px solid #e5e7eb;border-radius:10px;overflow:auto;-webkit-overflow-scrolling:touch}.detail-metrics-table th{background:#f8fafc;color:#334155;font-weight:600;position:sticky;top:0;z-index:1;font-size:12px;padding-top:10px;padding-bottom:10px}.detail-col-dim{position:sticky;z-index:2}.detail-col-date{left:0;min-width:140px;max-width:180px}.detail-col-secondary{min-width:220px;max-width:340px}.detail-metrics-table thead .detail-col-dim{z-index:3;background:#f8fafc}.detail-metrics-table tbody .detail-col-dim{background:#fff}.detail-metrics-table tbody tr:nth-child(2n) .detail-col-dim{background:#fcfcfd}.detail-metrics-table tbody tr:hover .detail-col-dim{background:#f8fafc}.detail-metrics-table tbody tr:nth-child(2n){background:#fcfcfd}.detail-metrics-table tbody tr:hover{background:#f8fafc}.detail-summary-grid{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.detail-summary-card{border:1px solid #e5e7eb;border-radius:10px;background:#fff;padding:10px}.detail-summary-label{font-size:11px;color:#64748b}.detail-summary-value{margin-top:4px;font-size:20px;line-height:1.15;font-weight:600;color:#111827}.detail-summary-status{font-size:13px;line-height:1.45;font-weight:500;color:#334155}@media(max-width:1200px){.detail-filters-grid,.detail-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-filters-panel{grid-template-columns:1fr;gap:8px}.detail-filters-head{font-size:16px;height:auto}}.task-text-ellipsis{display:block;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-detail-table th:nth-child(1),.task-detail-table td:nth-child(1){width:8%}.task-detail-table th:nth-child(2),.task-detail-table td:nth-child(2){width:17%}.task-detail-table th:nth-child(3),.task-detail-table td:nth-child(3){width:19%}.task-detail-table th:nth-child(4),.task-detail-table td:nth-child(4){width:8%}.task-detail-table th:nth-child(5),.task-detail-table td:nth-child(5){width:10%}.task-detail-table th:nth-child(6),.task-detail-table td:nth-child(6){width:38%}.task-detail-table td{vertical-align:middle}.task-action-col,.task-row-action-cell{text-align:right}.task-progress-cell{min-width:300px}.task-list{display:grid;gap:8px;max-height:360px;overflow:auto}.task-list-item{width:100%;text-align:left;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;border:1px solid #dbe5f2;background:#f8fafc;color:#1f2937;border-radius:10px;padding:10px}.task-list-item.is-active{border-color:#93c5fd;background:#dbeafe}.task-list-meta{flex:1 1 auto;min-width:0}.task-list-name{font-weight:600;margin-bottom:4px}.task-status-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.5;border:1px solid transparent}.task-status-badge.is-pending{background:#fef3c7;border-color:#fcd34d;color:#92400e}.task-status-badge.is-running{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.task-status-badge.is-paused{background:#fef3c7;border-color:#fcd34d;color:#92400e}.task-status-badge.is-done{background:#dcfce7;border-color:#86efac;color:#166534}.task-status-badge.is-expired{background:#fff7ed;border-color:#fdba74;color:#c2410c}.task-status-badge.is-offline{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.task-detail{border:1px solid #dbe5f2;background:#f8fafc;border-radius:12px;padding:12px;display:grid;gap:10px}.task-detail-line{display:grid;grid-template-columns:max-content minmax(0,1fr);gap:10px;align-items:center;font-size:13px}.task-detail-line .muted{white-space:nowrap}.task-detail-dual{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.task-detail-line input,.task-detail-line select,.task-detail-line textarea{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #dbe5f2;background:#fff;color:#1f2937}.task-readonly-plain{border:none!important;background:transparent!important;box-shadow:none!important;padding:0!important;color:#0f172a!important;-webkit-text-fill-color:#0f172a;opacity:1!important;cursor:default!important}.task-dialog-priority select{-webkit-appearance:none;appearance:none;height:44px;min-height:44px;padding:10px 40px 10px 12px;border-radius:12px;border:1px solid #c8d8ee;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5.25L7 9.25L11 5.25' fill='none' stroke='%2364798b' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px 14px;box-shadow:0 1px 2px #0f172a08;transition:border-color .2s ease,box-shadow .2s ease}.task-dialog-priority select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd38}.task-edit-form{gap:10px}.task-actions{display:flex;gap:10px;flex-wrap:wrap}.task-row-actions{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;justify-content:flex-end;margin-left:auto;transform:none;white-space:nowrap}.task-progress-inline{display:flex;align-items:center;justify-content:flex-start;gap:16px}.task-row-actions .ghost{min-width:62px;min-height:30px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;font-size:12px;font-weight:600;background:#2563eb;color:#fff;border-color:#2563eb}.task-row-actions .ghost:hover{background:#1d4ed8;border-color:#1d4ed8}.task-row-actions .users-danger-btn{min-width:70px;background:#dc2626;color:#fff;border-color:#dc2626}.task-row-actions .users-danger-btn:hover{background:#b91c1c;border-color:#b91c1c}.task-row-actions .task-toggle-btn.is-start{min-width:50px;background:#16a34a;border-color:#16a34a}.task-row-actions .task-toggle-btn.is-start:hover{background:#15803d;border-color:#15803d}.task-row-actions .task-toggle-btn.is-pause{min-width:50px;background:#d97706;border-color:#d97706}.task-row-actions .task-toggle-btn.is-pause:hover{background:#b45309;border-color:#b45309}.task-row-actions .task-toggle-btn.is-done{min-width:50px;background:#94a3b8;border-color:#94a3b8;cursor:not-allowed}.task-row-actions .task-toggle-btn.is-offline{min-width:50px;background:#ef4444;border-color:#ef4444;cursor:not-allowed}.task-progress-wrap{display:flex;align-items:center;gap:8px;width:clamp(216px,32.7vw,327px);min-width:216px;flex:0 0 auto}.task-progress-bar{position:relative;height:8px;border-radius:999px;background:#dbe5f2;overflow:hidden;flex:1}.task-progress-fill{position:relative;height:100%;border-radius:999px;background:linear-gradient(120deg,#ffffff38 0% 18%,#fff0 18% 36%),linear-gradient(90deg,#60a5fa,#2563eb);background-size:32px 100%,100% 100%;animation:task-progress-flow 1.25s linear infinite}.task-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,#fff0 20%,#ffffff61,#fff0 80%);transform:translate(-100%);animation:task-progress-shine 1.8s ease-in-out infinite}@keyframes task-progress-flow{0%{background-position:0 0,0 0}to{background-position:32px 0,0 0}}@keyframes task-progress-shine{0%{transform:translate(-120%)}to{transform:translate(120%)}}.task-progress-value{display:inline-flex;align-items:center;justify-content:center;min-width:68px;flex:0 0 68px;text-align:center;font-size:12px;font-weight:700;color:#0f172a;background:#e2e8f0;border:1px solid #cbd5e1;border-radius:999px;padding:0 8px;line-height:1;white-space:nowrap}.task-list-progress{max-width:240px;margin-top:8px}.task-progress-cell .task-progress-bar{flex:1 1 auto}.task-progress-cell .task-row-actions{margin-top:0;justify-content:flex-end}.task-pagination{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.task-pagination-meta{font-size:12px;color:#64748b}.task-pagination-actions{display:inline-flex;align-items:center;gap:8px}.task-pagination-size{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#334155}.task-pagination-size select{min-height:32px;border-radius:8px;padding:4px 8px;border:1px solid #cbd5e1;background:#fff}.task-pagination-actions .ghost{min-height:32px;padding:4px 10px}.task-dialog-mask{position:fixed;inset:0;background:linear-gradient(180deg,#e2ecfa94,#d0dff3a3),#94a3b81a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;z-index:160;padding:16px}.task-dialog{width:min(720px,100%);max-height:85vh;overflow:auto;background:linear-gradient(180deg,#fffffffa,#f7fbff),#fff;border:1px solid #dbe5f2;border-radius:20px;padding:18px;box-shadow:0 24px 60px #0f172a29,0 6px 18px #3b82f614}.task-dialog-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.task-confirm-dialog{width:min(420px,100%);background:#fff;border:1px solid #dbe5f2;border-radius:12px;padding:14px;display:grid;gap:12px}.task-saved{margin-top:10px}.app-package-page{display:flex;flex-direction:column;gap:16px}.app-list-page{display:flex;flex-direction:column;gap:18px}.app-list-panel{display:grid;gap:18px;padding:0;border:none;border-radius:0;min-height:auto;background:transparent}.app-list-workbench{display:grid;gap:18px;padding:20px 20px 16px;border:1px solid #dbe5f2;border-radius:24px;background:#fff;box-shadow:none}.app-list-tabs-shell{position:relative;z-index:2;padding:0 0 14px;margin-bottom:0;width:100%;border-bottom:1px solid #dbe5f2}.app-list-view-switch{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none;width:100%}.app-list-tab-item{position:relative;min-width:0;flex:0 0 auto}.app-list-tab-item.has-action .app-list-view-btn{padding-right:52px}.app-list-view-btn{width:100%;min-height:52px;border-radius:14px;border:1px solid #dbe5f2;background:#fff;color:#567091;font-size:15px;font-weight:700;padding:10px 18px 10px 16px;text-align:left;transition:border-color .2s ease,background-color .2s ease,color .2s ease,box-shadow .2s ease}.app-list-view-btn:hover{border-color:#bcd2ee;color:#1d4ed8;box-shadow:none}.app-list-view-btn.is-locked{cursor:not-allowed}.app-list-view-btn.is-locked:hover{border-color:#d2def0;color:#1e3a8a;box-shadow:none}.app-list-view-btn.is-disabled,.app-list-view-btn:disabled{border-color:#d7e3f3;background:#f8fafc;color:#94a3b8;cursor:not-allowed;box-shadow:none}.app-list-view-btn.is-active{border-color:#93c5fd;background:#eff6ff;color:#15346f;box-shadow:none}.app-list-view-btn-copy{display:grid;gap:4px}.app-list-view-btn-title{display:block;font-size:16px;font-weight:800;line-height:1.1}.app-list-view-btn-meta{display:block;color:#7a8ca7;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.app-list-tab-add-btn{position:absolute;top:50%;right:12px;width:26px;height:26px;border-radius:999px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-size:16px;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;transform:translateY(-50%);transition:border-color .2s ease,background-color .2s ease,color .2s ease}.app-list-tab-add-btn:hover{border-color:#93c5fd;background:#dbeafe;color:#1d4ed8}.app-list-preview-card{border:none;border-radius:0;background:transparent;min-height:0;padding:0;display:grid;gap:10px}.app-list-preview-card.is-audio,.app-list-preview-card.is-sdk,.app-list-preview-card.is-ai{box-shadow:none}.app-list-preview-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.app-list-preview-head-copy{min-width:0}.app-list-empty-title{font-size:18px;font-weight:800;color:#22324a}.app-list-preview-badge{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;background:#eef4ff;border:1px solid #c7daf8;color:#34527c;font-size:12px;font-weight:700;white-space:nowrap}.app-list-preview-badge.accent-slate{background:#f1f5f9;border-color:#d6e0ea;color:#4b617a}.app-list-preview-badge.accent-muted{background:#f8fafc;border-color:#dde5ef;color:#7a8798}.app-list-preview-table{border:none;border-radius:0;overflow:hidden;background:transparent}.app-list-preview-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;align-items:center;min-height:56px;padding:0 8px;border-top:none;border-bottom:1px solid #e2e8f0}.app-list-preview-row:first-child{border-top:none}.app-list-preview-row.is-head{min-height:46px;background:transparent}.app-list-preview-row.is-head span{color:#1f2f46;font-size:14px;font-weight:700;letter-spacing:0}.app-list-preview-cell{display:flex;align-items:center}.app-list-preview-line{display:block;height:10px;width:78%;border-radius:999px;background:linear-gradient(100deg,#fff0 10%,#ffffffb3 42%,#fff0 58%),linear-gradient(90deg,#e5edf9,#eef4fb);background-size:140px 100%,100% 100%;animation:app-list-skeleton-shimmer 1.8s linear infinite}.app-list-preview-row .app-list-preview-cell:nth-child(2) .app-list-preview-line{width:66%}.app-list-preview-row .app-list-preview-cell:nth-child(3) .app-list-preview-line{width:54%}.app-list-preview-row .app-list-preview-cell:nth-child(4) .app-list-preview-line{width:48%}.app-list-add-btn{min-height:36px;border-radius:999px;padding:0 16px;white-space:nowrap}.app-list-data-wrap{display:grid;gap:12px}.app-list-empty-message{border:none;border-radius:0;padding:18px 0;background:transparent;color:#5f728f;font-size:14px;font-weight:600}.app-list-data-table-wrap{border:none;border-radius:0;overflow:auto;background:transparent;padding:0}.app-list-data-table{width:100%;min-width:1080px;border-collapse:collapse;table-layout:fixed}.app-list-data-table th{padding:10px 12px 14px;background:transparent;color:#1f2f46;font-size:14px;font-weight:700;letter-spacing:0;text-transform:none;white-space:nowrap;border:none;border-bottom:1px solid #e2e8f0}.app-list-data-table td{vertical-align:middle;border-top:none;border-bottom:1px solid #e2e8f0;background:transparent;padding:18px 12px}.app-list-data-table th:nth-child(1),.app-list-data-table td:nth-child(1){width:22%}.app-list-data-table th:nth-child(2),.app-list-data-table td:nth-child(2){width:29%}.app-list-data-table th:nth-child(3),.app-list-data-table td:nth-child(3){width:9%}.app-list-data-table th:nth-child(4),.app-list-data-table td:nth-child(4){width:9%}.app-list-data-table th:nth-child(5),.app-list-data-table td:nth-child(5){width:9%}.app-list-data-table th:nth-child(6),.app-list-data-table td:nth-child(6){width:22%}.app-list-data-table th:last-child{color:transparent}.app-list-data-row{transition:background-color .2s ease}.app-list-data-row td:first-child{padding-left:12px}.app-list-data-row td:last-child{padding-right:0}.app-list-data-table tbody tr:hover td{border-color:#dbe5f2;background:#f8fbff}.app-list-product-cell,.app-list-package-cell{display:grid;gap:2px;min-width:0}.app-list-product-cell{grid-template-columns:auto minmax(0,1fr);align-items:center;column-gap:14px}.app-list-product-order{display:inline-flex;align-items:center;justify-content:center;min-width:26px;color:#7f8ea5;font-size:13px;font-weight:800;line-height:1}.app-list-product-name{color:#20314f;font-size:15px;font-weight:700;line-height:1.25}.app-list-package-name{color:#35506f;display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;font-family:SFMono-Regular,JetBrains Mono,Fira Code,monospace}.app-list-version-chip{display:inline-flex;align-items:center;justify-content:flex-start;min-height:24px;min-width:0;padding:0;border-radius:0;background:transparent;color:#28476e;font-size:14px;font-weight:700}.app-list-version-name{color:#314866;display:inline-flex;align-items:center;justify-content:flex-start;min-height:24px;font-size:14px;font-weight:700}.app-list-inline-spinner{display:inline-block;width:18px;height:18px;border-radius:999px;border:2px solid #d7e3f6;border-top-color:#3b82f6;animation:app-list-inline-spin .8s linear infinite}.app-list-status-pill{display:inline-flex;align-items:center;gap:6px;justify-content:flex-start;min-height:24px;min-width:0;padding:0;border-radius:0;background:transparent;color:#425875;font-size:14px;font-weight:700}.app-list-status-pill.is-online{color:#166534}.app-list-status-pill.is-offline{color:#b42318}.app-list-status-pill.is-unknown{color:#5b6b81}.app-list-status-dot{width:8px;height:8px;border-radius:999px;background:currentColor;box-shadow:none}.app-list-status-dot.is-online{background:#22c55e}.app-list-status-dot.is-offline{background:#ef4444}.app-list-status-dot.is-unknown{background:#94a3b8}.app-list-cell-action{white-space:nowrap;text-align:right;vertical-align:middle}.app-list-col-status{vertical-align:middle}.app-list-detail-btn{min-height:32px;border-radius:10px;padding:0 12px;border-color:#c6daf5;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:800;box-shadow:none}.app-list-cell-link,.app-list-cell-params{max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-list-cell-params{max-width:360px}.app-list-create-dialog{width:min(1040px,100%)}.app-list-create-header{align-items:flex-start;margin-bottom:12px}.app-list-create-head-copy{display:grid;gap:2px}.app-list-create-sub{color:#64748b;font-size:12px}.app-list-form-layout{display:grid;gap:10px}.app-list-form-section{display:grid;gap:10px;padding:12px 14px 14px;border:1px solid #e2eaf5;border-radius:14px;background:linear-gradient(180deg,#fffffff2,#f9fcfffa);box-shadow:inset 0 1px #ffffffc7}.app-list-form-section-head{display:grid;gap:2px}.app-list-form-section-head .panel-title{font-size:15px}.app-list-form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.app-list-form-grid-base{grid-template-columns:repeat(3,minmax(0,1fr))}.app-list-form-grid-base-split{grid-template-columns:repeat(2,minmax(0,1fr))}.app-list-form-grid-config{grid-template-columns:minmax(260px,.95fr) minmax(360px,1.05fr);align-items:start}.app-list-config-groups{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr) minmax(0,.82fr);gap:10px;align-items:start}.app-list-config-card{display:grid;gap:10px;min-height:100%;padding:12px;border:1px solid #dfe8f4;border-radius:12px;background:linear-gradient(180deg,#fffffffa,#f8fbfffa)}.app-list-config-card-head{display:grid;gap:2px}.app-list-config-card-head .panel-title{font-size:14px}.app-list-field{display:grid;gap:5px;color:#4b607d;font-size:12px;font-weight:700}.app-list-field-store{gap:6px}.app-list-store-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.app-list-field input,.app-list-field textarea{width:100%;min-height:40px;border-radius:10px;border:1px solid #d7e3f3;background:#fff;padding:9px 12px;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.app-list-field input:hover,.app-list-field textarea:hover{border-color:#c6d8f3}.app-list-field input:focus,.app-list-field textarea:focus{outline:none;border-color:#8fb3ec;box-shadow:0 0 0 3px #3b82f61f}.app-list-field textarea{min-height:132px;resize:vertical;line-height:1.55}.app-list-parse-btn{min-height:40px;min-width:104px;border-radius:10px;padding:0 14px;align-self:end;white-space:nowrap}.app-list-parse-btn:disabled{opacity:.56;cursor:not-allowed}.app-list-form-grid .is-wide{grid-column:span 2}.app-list-upload-stack,.app-list-credentials-grid{display:grid;gap:10px}.app-list-credentials-grid{grid-template-columns:1fr}.app-list-summary-grid{display:grid;gap:10px}.app-list-file-field{display:grid;gap:5px;color:#4b607d;font-size:12px;font-weight:700}.app-list-file-field input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.app-list-file-box{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:46px;padding:8px 10px 8px 12px;border:1px solid #d7e3f3;border-radius:12px;background:linear-gradient(180deg,#fff,#fbfdff);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.app-list-file-box:hover{border-color:#c6d8f3;box-shadow:0 6px 14px #3b82f60f}.app-list-file-name{min-width:0;color:#425875;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-list-file-trigger{flex:none;display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid #c9daf4;background:#fff;color:#2563eb;font-size:12px;font-weight:700}.app-list-firebase-preview{display:grid;gap:6px}.app-list-firebase-preview-head{color:#4b607d;font-size:12px;font-weight:700}.app-list-firebase-preview-body{height:220px;margin:0;padding:12px;border:1px solid #d7e3f3;border-radius:12px;background:#fbfdff;color:#334155;font-size:12px;line-height:1.55;white-space:pre-wrap;word-break:break-word;overflow-x:auto;overflow-y:auto}.app-list-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.app-list-data-table td.app-list-cell-action{padding-left:12px;padding-right:0;text-align:right;vertical-align:middle}.app-list-action-group{display:flex;width:100%;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:nowrap;white-space:nowrap}.app-list-detail-btn{min-height:32px;border-radius:999px;padding:0 12px;border-color:#c6daf5;background:linear-gradient(180deg,#fff,#eef5ff);color:#1d4ed8;font-size:12px;font-weight:800;box-shadow:0 8px 16px #3b82f61a}.app-list-build-btn{min-height:32px;border-radius:10px;padding:0 12px;border-color:#d2dae6;background:#f8fafc;color:#334155;font-size:12px;font-weight:800}.app-list-detail-dialog{max-width:880px}.app-list-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.app-list-detail-item{display:grid;gap:6px;padding:12px 14px;border:1px solid #d7e3f3;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff)}.app-list-detail-item span{color:#5f7695;font-size:12px;font-weight:700}@keyframes app-list-inline-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-list-detail-item strong,.app-list-detail-item pre{margin:0;color:#1f314f;font-size:13px;line-height:1.6;font-weight:600;white-space:pre-wrap;word-break:break-word}.app-list-detail-item.is-wide{grid-column:span 2}@keyframes app-list-skeleton-shimmer{0%{background-position:-160px 0,0 0}to{background-position:160px 0,0 0}}.app-package-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.app-package-toolbar .ghost{min-height:38px;border-radius:10px;padding:8px 14px;display:inline-flex;align-items:center;gap:8px}.app-package-toolbar .ghost:disabled{opacity:.45;cursor:not-allowed}.app-package-toolbar .app-btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.app-package-toolbar .icon-refresh{width:38px;height:38px;justify-content:center;padding:0}.app-file-hidden{display:none}.app-package-upload-form{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:12px}.app-package-upload-form input{width:100%;min-height:38px;border-radius:10px;border:1px solid #dbe5f2;background:#fff;color:#0f172a;padding:8px 10px}.app-package-upload-form .is-wide{grid-column:span 2}.app-package-upload-form .primary{min-height:38px;padding:0 16px}.app-build-page{display:flex;flex-direction:column;gap:18px}.apk-build-shell{padding-top:12px}.apk-build-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.apk-build-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.apk-build-status-pill,.apk-build-job-pill{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid #dbe5f2;background:#f8fbff;color:#24364f;font-size:12px;font-weight:700}.apk-build-status-pill.is-idle{color:#4b5d79}.apk-build-status-pill.is-running{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.apk-build-status-pill.is-success{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.apk-build-status-pill.is-failed{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.apk-build-job-pill strong{font-size:12px;color:#0f172a}.apk-build-form{display:flex;flex-direction:column;gap:14px}.apk-build-section{border:1px solid #dbe5f2;border-radius:16px;background:#fff;padding:16px 16px 14px}.apk-build-section-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:#385072}.apk-build-section-head h3{margin:0;font-size:15px;color:#22324a}.apk-build-grid-base-row,.apk-build-grid-sdk,.apk-build-toggle-grid,.apk-build-footer{display:grid;gap:12px}.apk-build-grid-base-row{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start}.apk-build-grid-base-row.is-spaced{margin-top:12px}.apk-build-grid-sdk{grid-template-columns:minmax(220px,.9fr) minmax(440px,1.4fr) minmax(240px,1fr);align-items:stretch}.apk-build-field{display:flex;flex-direction:column;min-width:0}.apk-build-version-stack{display:grid;gap:12px;grid-template-rows:repeat(2,minmax(0,1fr));align-content:stretch;align-self:stretch;height:100%}.apk-build-service-side{display:grid;gap:12px;align-content:stretch;align-self:stretch;height:100%}.apk-build-service-text{align-self:stretch}.apk-build-signing-stack{display:grid;gap:12px;grid-template-rows:repeat(3,minmax(0,1fr));align-content:stretch;height:100%}.apk-build-version-stack .apk-build-field,.apk-build-signing-stack .apk-build-field{justify-content:space-between}.apk-build-field>span{margin-bottom:7px;color:#42546f;font-size:12px;font-weight:700;letter-spacing:.02em}.apk-build-field input,.apk-build-field select,.apk-build-field textarea{width:100%;min-height:42px;border-radius:12px;border:1px solid #d9e4f2;background:#fbfdff;color:#142338;padding:10px 13px;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.apk-build-field select{-webkit-appearance:none;appearance:none;-moz-appearance:none;padding-right:42px;background-color:#fbfdff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5.25L7 9.25L11 5.25' fill='none' stroke='%2364798b' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:14px 14px}.apk-build-field textarea{min-height:214px;resize:vertical;line-height:1.55}.apk-build-field input:focus,.apk-build-field select:focus,.apk-build-field textarea:focus{border-color:#93c5fd;background:#fff;box-shadow:0 0 0 4px #93c5fd29}.apk-build-upload{position:relative;min-height:44px;border-radius:12px;border:1px dashed #c8d8ee;background:#f8fbff;padding:8px 10px 8px 12px;display:flex;align-items:center;gap:10px;color:#355174}.apk-build-upload-name{flex:1;min-width:0;color:#22324a;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.apk-build-upload-hitbox{position:relative;position:absolute;inset:0;border-radius:12px;cursor:pointer}.apk-build-upload-hitbox input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.apk-build-field-hint{margin-top:6px;color:#72839b;font-size:12px;line-height:1.5}.apk-build-inline-note{min-height:42px;border-radius:12px;border:1px dashed #cfe0f6;background:#f8fbff;padding:10px 13px;color:#5f7391;font-size:13px;display:flex;align-items:center}.apk-build-toggle-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.apk-build-toggle{position:relative;min-height:104px;border-radius:14px;border:1px solid #dbe5f2;background:#fbfdff;padding:15px 15px 15px 42px;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background-color .2s ease}.apk-build-toggle:hover{transform:translateY(-1px);border-color:#c6dbf8;box-shadow:0 8px 18px #2563eb0f}.apk-build-toggle input{position:absolute;left:14px;top:17px}.apk-build-toggle strong{color:#24354d;font-size:14px}.apk-build-toggle span{color:#6d7f97;font-size:12px;line-height:1.55}.apk-build-toggle.is-checked{border-color:#b7d2f5;background:#f4f8ff;box-shadow:0 10px 22px #3b82f614}.apk-build-footer{grid-template-columns:280px minmax(0,1fr);gap:16px}.apk-build-actions{border:1px solid #dbe5f2;border-radius:16px;background:#fff;padding:16px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;gap:14px}.apk-build-submit{min-width:128px;min-height:42px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#38bdf8);border:none;color:#fff;box-shadow:0 12px 22px #2563eb2e}.apk-build-action-meta{display:flex;flex-direction:column;gap:8px}.apk-build-actions .builder-status{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:#e8eef9;color:#334155;font-size:12px;font-weight:700}.apk-build-actions .builder-status.running{background:#dbeafe;color:#1d4ed8}.apk-build-actions .builder-status.success{background:#dcfce7;color:#15803d}.apk-build-actions .builder-status.failed{background:#fee2e2;color:#b91c1c}.apk-build-logs{min-height:228px;border-radius:16px;border:1px solid #c8d7ea;background:linear-gradient(180deg,#172034fa,#111827fa),linear-gradient(135deg,rgba(37,99,235,.15),transparent 40%);color:#dbeafe;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.apk-build-logs-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid rgba(148,163,184,.18);color:#eff6ff;font-size:12px;font-weight:700;letter-spacing:.04em}.apk-build-logs .builder-job-id{color:#93c5fd;font-size:11px}.apk-build-logs pre{margin:0;padding:14px;max-height:250px;overflow-y:auto;font-size:12px;line-height:1.62;white-space:pre-wrap;color:#dbe7ff}.app-package-table-wrap{border:1px solid #dbe5f2;border-radius:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.app-package-table{min-width:1060px;table-layout:fixed}.app-package-table th{background:#f8fafc;font-weight:600}.app-package-table .is-checkbox{width:44px;text-align:center}.app-package-table .is-action{width:220px;text-align:left}.app-package-table .is-apk-file{width:220px;max-width:220px}.app-package-table .is-version-code{width:120px;max-width:120px}.app-package-table .is-version-name{width:170px;max-width:170px}.app-package-table .is-package{width:280px;max-width:280px}.app-package-table td.is-apk-file,.app-package-table td.is-version-code,.app-package-table td.is-version-name,.app-package-table td.is-package{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sync-btn{min-height:30px;padding:4px 10px;border-radius:8px;font-size:12px;background:#eaf2ff;color:#2c5d96;border-color:#c9d9f4;white-space:nowrap}.app-sync-btn:hover{background:#dce9ff;border-color:#b7ccf1;color:#254f80}.app-sync-btn:disabled{background:#eef2f8;color:#7b8aa3;border-color:#d3ddea}.app-sync-task-btn{min-height:28px;padding:4px 10px;border-radius:8px;font-size:12px;background:#e9f7f3;color:#246b5b;border-color:#c4e6dc;white-space:nowrap}.app-sync-task-btn:hover{background:#dcf1ea;border-color:#b1dccf;color:#1f5d4f}.app-sync-actions-inline{display:inline-flex;align-items:center;gap:8px;flex-wrap:nowrap}.app-sync-progress-block{margin:8px 0 12px}.app-sync-progress-label{font-size:12px;color:#475569;margin-bottom:6px}.app-sync-progress-track{width:min(420px,100%);height:8px;border-radius:999px;background:#dbe5f2;overflow:hidden}.app-sync-progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#0ea5e9);transition:width .3s ease}.app-sync-inline-track{width:84px;height:5px;margin-top:4px;border-radius:999px;background:#dbe5f2;overflow:hidden}.app-sync-inline-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#0ea5e9);transition:width .3s ease}.app-sync-inline-msg{margin-top:4px;font-size:11px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.app-package-foot{padding:10px 8px 2px}@media(max-width:1440px){.topbar{padding:18px 22px}.app-content{padding:20px 22px 28px}.topbar-title .title{font-size:20px}.task-progress-wrap{width:clamp(190px,28vw,280px);min-width:190px}}@media(max-width:1200px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.topbar{padding:16px 18px}.app-content{padding:16px 18px 24px}.traffic-main-panel{min-height:auto}.analysis-chart-grid{grid-template-columns:1fr}.task-progress-cell{min-width:240px}.task-progress-wrap{width:clamp(170px,32vw,240px);min-width:170px}.app-package-table .is-action{width:180px}.apk-build-grid-base-row,.apk-build-grid-sdk,.apk-build-toggle-grid,.apk-build-footer{grid-template-columns:1fr 1fr}.app-list-tabs-shell{padding:0 0 12px}.app-list-view-switch{width:100%;padding-top:0}.app-list-tab-add-btn{top:10px;right:10px}.app-list-preview-row{gap:12px;padding:0 14px}.app-list-form-grid-base{grid-template-columns:repeat(2,minmax(0,1fr))}.app-list-config-groups,.app-list-form-grid-base-split,.app-list-form-grid-config,.app-list-credentials-grid{grid-template-columns:1fr}}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;overflow-x:auto;padding:14px 12px;gap:12px}.sidebar-nav{flex-direction:row;align-items:center;flex-wrap:nowrap;min-width:max-content}.nav-sub-list{margin-top:0}.nav-sub{margin-left:0}.sidebar-footer{margin-top:0}.topbar{flex-direction:column;align-items:flex-start;gap:12px}.topbar-actions{width:100%;flex-wrap:wrap}.pie-wrap{grid-template-columns:1fr}.traffic-toolbar{width:100%;justify-content:flex-start;flex-wrap:wrap}.traffic-filter-shell{width:100%;justify-content:flex-end;gap:5px}.traffic-picker-wrap{width:min(325px,calc(100vw - 120px))}.traffic-filter-label{font-size:10px}.traffic-date-trigger{height:25px;min-width:138px;font-size:10px}.traffic-date-dropdown{right:0;left:auto;width:min(500px,calc(100vw - 24px))}.traffic-stat-grid{grid-template-columns:1fr}.traffic-remain-wrap{flex-direction:column;align-items:flex-start}.traffic-stat-card.is-profit .traffic-remain-wrap{align-items:center}.traffic-remain-ring{width:104px;height:104px}.traffic-remain-ring-inner{width:80px;height:80px}.traffic-stat-value{font-size:24px}.traffic-range-group{width:100%;flex-wrap:wrap}.traffic-detail-head{flex-direction:column;align-items:flex-start;gap:8px}.traffic-profit-list{grid-template-columns:1fr;row-gap:6px}.login-page{padding:16px}.login-card{border-radius:16px;padding:22px}.users-form,.users-grid,.device-config-kpi,.device-config-add-grid{grid-template-columns:1fr}.device-config-row-actions{flex-wrap:wrap}.task-page{display:block}.task-kpi-grid,.task-workbench,.task-form-grid,.task-priority-account-row,.task-detail-wrap,.task-detail-dual{grid-template-columns:1fr}.task-list-item{grid-template-columns:1fr;align-items:stretch}.task-row-actions{justify-content:start;margin-left:0}.task-list-head{flex-wrap:wrap;gap:8px}.task-platform-switch{width:100%}.task-pagination{flex-direction:column;align-items:flex-start}.app-package-upload-form{grid-template-columns:1fr}.app-package-upload-form .is-wide{grid-column:auto}.apk-build-topbar{flex-direction:column;align-items:flex-start}.apk-build-meta-row{width:100%;justify-content:flex-start}.apk-build-grid-base-row,.apk-build-grid-sdk,.apk-build-toggle-grid,.apk-build-footer{grid-template-columns:1fr}.app-list-tabs-shell{padding:0 0 12px}.app-list-view-switch{padding:0;gap:6px}.app-list-view-btn{min-height:42px;font-size:14px;padding:8px 14px}.app-list-tab-item.has-action .app-list-view-btn{padding-right:34px}.app-list-tab-add-btn{top:50%;right:8px;width:22px;height:22px;font-size:15px}.app-list-preview-row{grid-template-columns:repeat(2,minmax(0,1fr))}.app-list-form-grid,.app-list-form-grid-base,.app-list-form-grid-base-split,.app-list-form-grid-config,.app-list-credentials-grid,.app-list-config-groups,.app-list-summary-grid,.app-list-store-row{grid-template-columns:1fr}.app-list-form-grid .is-wide{grid-column:auto}}@media(max-width:640px){.topbar-title .title{font-size:18px}.icon-btn{width:36px;height:36px}.user-chip{padding:6px 10px}.panel{border-radius:14px;padding:12px}.apk-build-section{padding:12px;border-radius:14px}.apk-build-topbar{margin-bottom:10px}.apk-build-grid{gap:10px}.apk-build-field textarea{min-height:128px}.apk-build-actions{padding:14px}.apk-build-toggle{min-height:96px}.task-row-actions{gap:4px;flex-wrap:wrap}.task-row-actions .ghost,.task-row-actions .users-danger-btn{min-width:58px;min-height:28px;font-size:11px}}
