:root{color-scheme:light;--bg: #eaf1f8;--panel: rgba(255, 255, 255, .86);--panel-strong: #ffffff;--line: rgba(20, 42, 84, .1);--line-strong: rgba(20, 42, 84, .16);--text: #19304f;--muted: #7183a0;--brand: #1f74ff;--brand-soft: rgba(31, 116, 255, .1);--danger: #d9485f;--success: #1d7d53;--shadow: 0 24px 60px rgba(35, 68, 122, .12);--shell-pad: clamp(14px, 1.8vw, 24px);--shell-gap: clamp(12px, 1.4vw, 18px);--panel-radius: clamp(22px, 2vw, 28px);--card-radius: clamp(16px, 1.2vw, 20px);--compact-height: 38px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Segoe UI,PingFang SC,Microsoft YaHei UI,sans-serif;font-size:clamp(13px,.25vw + 11.8px,16px);color:var(--text);background:radial-gradient(circle at top left,rgba(31,116,255,.12),transparent 28%),radial-gradient(circle at right top,rgba(43,191,255,.14),transparent 24%),linear-gradient(180deg,#edf4fb,#e7eef7)}button,input,select,textarea{font:inherit;color:inherit}button,input,select,textarea{border:1px solid var(--line);border-radius:12px;background:#fff}button{cursor:pointer}input,select,textarea{width:100%;padding:10px 12px}textarea{resize:vertical;min-height:86px}.admin-login-shell,.admin-app-shell{min-height:100vh;padding:var(--shell-pad)}.admin-login-shell{display:grid;place-items:center}.admin-login-card,.admin-table-panel,.admin-panel,.admin-link-card,.admin-feedback-card,.admin-modal-card,.admin-device-card{background:var(--panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.55);box-shadow:var(--shadow)}.admin-login-card{width:min(460px,100%);padding:clamp(20px,2vw,28px);border-radius:var(--panel-radius);display:grid;gap:14px}.admin-login-card label{display:grid;gap:8px;font-weight:600}.admin-login-card h1,.admin-page-head h1,.admin-modal-head h3{margin:0}.admin-login-card p,.admin-page-head p,.admin-modal-head p,.admin-section-copy p{margin:0;color:var(--muted);line-height:1.6}.admin-login-eyebrow,.admin-eyebrow{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--brand)}.ghost-btn,.primary-btn{min-height:clamp(38px,2.9vw,42px);padding:0 16px;border-radius:12px;background:#ffffffd1}.primary-btn{border-color:#1f74ff33;color:#fff;background:linear-gradient(180deg,#3386ff,#1f74ff)}.ghost-btn.danger{color:var(--danger)}.admin-mini-btn{min-height:34px;padding:0 12px;border-radius:10px;font-size:13px}.admin-app-shell{display:block}.admin-main{display:grid;gap:var(--shell-gap)}.admin-brand{display:flex;align-items:center;gap:14px}.admin-brand-compact{gap:10px}.admin-brand-mark{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(180deg,#3386ff,#1f74ff);color:#fff;font-weight:900;font-size:24px}.admin-brand strong,.admin-brand span{display:block}.admin-brand span,.admin-head-meta{color:var(--muted);font-size:13px}.admin-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:clamp(14px,1.5vw,20px);padding:4px 2px 0}.admin-page-title{display:grid;gap:6px}.admin-page-head h1{font-size:clamp(28px,2vw,40px);line-height:1.12}.admin-page-head p{max-width:64ch;font-size:clamp(14px,.3vw + 13px,16px)}.admin-head-actions{display:grid;gap:8px;justify-items:end;max-width:520px}.admin-session-strip,.admin-session-actions,.admin-feedback-pills,.admin-pagination,.row-actions,.form-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.admin-session-strip{justify-content:flex-end}.admin-session-badge{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#2ba76d1f;color:var(--success);font-size:12px;font-weight:700}.admin-inline-error,.admin-inline-notice{width:100%;padding:10px 12px;border-radius:12px;font-size:14px}.admin-inline-error{background:#d9485f1a;color:#b02d48}.admin-inline-notice{background:#2ba76d1f;color:var(--success)}.admin-top-tabs-shell{padding:0}.admin-top-tabs{display:flex;gap:8px;flex-wrap:wrap}.admin-top-tabs button{min-height:var(--compact-height);padding:0 14px;border-radius:999px;background:#ffffffb8;font-size:13px;font-weight:700}.admin-top-tabs button.active{border-color:#1f74ff3d;background:linear-gradient(180deg,#1f74ff24,#1f74ff14);color:var(--brand)}.admin-summary-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.admin-summary-item{min-height:62px;padding:10px 12px;border-radius:18px;border:1px solid rgba(20,42,84,.08);background:#ffffffb8;display:grid;gap:4px}.admin-summary-item span{color:var(--muted);font-size:12px}.admin-summary-item strong{font-size:clamp(20px,1.7vw,28px);line-height:1.1}.admin-summary-link{align-self:stretch;justify-self:stretch}.admin-table-panel,.admin-panel{border-radius:var(--panel-radius);padding:clamp(14px,1.4vw,18px)}.admin-toolbar{display:grid;gap:10px;margin-bottom:14px}.admin-toolbar-main,.admin-toolbar-secondary{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.admin-search{min-width:260px;flex:1 1 300px}.admin-toolbar-main select,.admin-toolbar-secondary select{width:auto;min-width:140px}.admin-customer-head{display:grid;grid-template-columns:minmax(120px,1.05fr) minmax(180px,1.3fr) minmax(140px,1fr) minmax(150px,1.05fr) minmax(170px,1.25fr) minmax(120px,.8fr) minmax(140px,1fr) auto;gap:10px;padding:0 12px 10px;color:var(--muted);font-size:12px;font-weight:700}.admin-customer-list{display:grid;gap:10px}.admin-customer-row{display:grid;grid-template-columns:minmax(120px,1.05fr) minmax(180px,1.3fr) minmax(140px,1fr) minmax(150px,1.05fr) minmax(170px,1.25fr) minmax(120px,.8fr) minmax(140px,1fr) auto;gap:10px;align-items:start;padding:12px;border-radius:18px;border:1px solid rgba(20,42,84,.1);background:#ffffffd6}.admin-customer-row:hover{background:#ffffffeb;border-color:#1f74ff29}.admin-row-primary,.admin-row-email,.admin-row-field,.admin-row-actions{min-width:0}.admin-row-primary,.admin-row-email,.admin-row-field{display:grid;gap:6px;align-content:start}.admin-row-field-label{font-size:12px;font-weight:700;color:var(--muted)}.admin-row-primary strong,.admin-row-email .linkish-btn{font-size:14px}.admin-row-primary small,.admin-row-email small{color:var(--muted)}.admin-row-identity{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-row-field input,.admin-row-field select,.admin-date-trigger{min-height:var(--compact-height);padding:0 12px;border-radius:12px}.admin-row-field input::placeholder{color:#7183a0cc}.admin-expiry-wrap{position:relative}.admin-date-trigger{width:100%;display:grid;gap:2px;justify-items:start;text-align:left;background:#fff}.admin-date-trigger small{color:var(--muted);font-size:11px}.admin-date-popover{position:absolute;z-index:6;top:calc(100% + 8px);left:0;width:min(280px,calc(100vw - 48px));padding:12px;border-radius:16px;border:1px solid rgba(20,42,84,.12);background:#fffffffa;box-shadow:0 22px 40px #1a30532e;display:grid;gap:10px}.admin-date-popover-head,.admin-date-popover-actions,.admin-date-quick-list{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.admin-tag-trigger{min-height:var(--compact-height);padding:0 12px;justify-content:flex-start;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.admin-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.sort-btn,.linkish-btn,.tag-trigger{border:none;background:none;padding:0;color:inherit}.linkish-btn{color:var(--brand);font-weight:700;text-align:left}.tag-trigger{padding:9px 12px;border-radius:999px;background:var(--brand-soft);color:var(--brand)}.admin-status-badge,.feedback-state{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:700}.admin-status-badge{background:#1f74ff1f;color:var(--brand)}.admin-status-badge.disabled{background:#d9485f1f;color:#b22c46}.admin-status-badge.expired,.feedback-state.open{background:#fcb71a2e;color:#9a6a00}.feedback-state.reviewing{background:#1f74ff1f;color:var(--brand)}.feedback-state.resolved{background:#2ba76d24;color:var(--success)}.admin-empty{padding:32px 16px;text-align:center;color:var(--muted)}.admin-card-empty{border-radius:18px;border:1px dashed rgba(20,42,84,.16);background:#ffffffb8}.admin-feedback-list,.admin-device-list,.admin-link-grid{display:grid;gap:12px}.admin-feedback-card,.admin-device-card,.admin-link-card{border-radius:var(--card-radius);padding:clamp(14px,1.2vw,16px)}.admin-feedback-card-top,.admin-feedback-card-foot,.admin-modal-head{display:flex;justify-content:space-between;gap:14px}.admin-feedback-card-top{align-items:flex-start}.admin-feedback-card-foot{align-items:center;margin-top:12px}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-form-grid-tight{gap:12px}.admin-form-grid label{display:grid;gap:8px;font-weight:600}.admin-form-grid .span-2{grid-column:1 / -1}.admin-expiry-preview-card{min-height:82px;padding:12px;border-radius:14px;border:1px dashed rgba(31,116,255,.18);background:#1f74ff0d;display:grid;gap:6px;align-content:center}.admin-expiry-preview-card span{color:var(--muted);font-size:12px;font-weight:700}.admin-expiry-preview-card strong{font-size:14px;line-height:1.5}.toggle-line{display:flex!important;align-items:center;gap:10px;font-weight:700}.toggle-line input{width:auto}.admin-modal-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;padding:24px;display:grid;place-items:center}.admin-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#111f3447}.admin-modal-card{position:relative;width:min(980px,calc(100vw - 48px));max-height:calc(100vh - 48px);border-radius:var(--panel-radius);display:flex;flex-direction:column;overflow:hidden}.admin-modal-card--editor{width:min(1040px,calc(100vw - 48px))}.admin-modal-card--manager{width:min(980px,calc(100vw - 48px))}.admin-modal-card--device{width:min(760px,calc(100vw - 48px))}.admin-modal-card.is-draggable{transition:box-shadow .18s ease}.admin-modal-card.is-draggable:has(.admin-modal-head.is-draggable:active){box-shadow:0 36px 110px #23447a38}.admin-modal-head{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid rgba(20,42,84,.08);background:linear-gradient(180deg,#fffffff5,#f5f9ffe6)}.admin-modal-head.is-draggable{cursor:grab;-webkit-user-select:none;user-select:none}.admin-modal-head.is-draggable:active{cursor:grabbing}.admin-modal-head-copy{min-width:0;display:grid;gap:4px}.admin-modal-head-actions{flex:none;display:flex;align-items:center;gap:10px}.admin-modal-close{min-width:72px}.admin-modal-body{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.admin-modal-body>*{flex:1 1 auto;min-height:0}.admin-modal-scroll{min-height:0;overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(31,116,255,.28) rgba(20,42,84,.06)}.admin-modal-scroll::-webkit-scrollbar{width:10px;height:10px}.admin-modal-scroll::-webkit-scrollbar-track{background:#142a540d;border-radius:999px}.admin-modal-scroll::-webkit-scrollbar-thumb{background:#1f74ff3d;border-radius:999px}.admin-modal-scroll::-webkit-scrollbar-thumb:hover{background:#1f74ff57}.admin-modal-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px 16px;border-top:1px solid rgba(20,42,84,.08);background:linear-gradient(180deg,#eaf1f8db,#eaf1f8fa)}.admin-editor-layout{display:grid;grid-template-columns:minmax(210px,220px) minmax(0,1fr);gap:16px;height:100%;min-height:0}.admin-editor-nav{min-height:0;display:grid;align-content:start;gap:10px}.admin-editor-nav button{display:grid;gap:4px;justify-items:start;padding:14px;border-radius:18px;border:1px solid rgba(20,42,84,.1);background:#ffffffd6;text-align:left}.admin-editor-nav button strong{font-size:14px}.admin-editor-nav button small{color:var(--muted)}.admin-editor-nav button.active{border-color:#1f74ff3d;background:linear-gradient(180deg,#1f74ff24,#1f74ff14);color:var(--brand)}.admin-editor-nav button.active small{color:inherit}.admin-editor-form{min-width:0;min-height:0;display:flex;overflow:hidden}.admin-editor-panel-shell{flex:1 1 auto;min-height:0;padding-right:4px}.admin-template-editor,.admin-template-editor-shell{min-width:0;min-height:0}.admin-template-editor-shell{display:flex;overflow:hidden}.admin-template-editor{flex:1 1 auto;display:grid;gap:14px;padding-right:4px}.admin-editor-section,.admin-feature-group,.admin-feature-summary,.admin-template-sidebar{border:1px solid rgba(20,42,84,.08);border-radius:18px;background:#ffffffb8;padding:14px}.admin-section-copy{display:grid;gap:4px;margin-bottom:12px}.admin-inline-tip{margin-bottom:12px;color:var(--muted);font-size:13px;line-height:1.5}.admin-section-copy h4,.admin-section-copy h5{margin:0}.admin-section-copy-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.admin-feature-groups{display:grid;gap:12px}.admin-feature-summary{display:grid;gap:10px}.admin-selected-feature-list{display:flex;flex-wrap:wrap;gap:8px}.admin-selected-feature-pill{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#1f74ff1a;color:var(--brand);font-size:12px;font-weight:700}.admin-feature-group-collapsible{padding:0;overflow:hidden}.admin-feature-group-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;list-style:none;padding:12px 14px}.admin-feature-group-summary::-webkit-details-marker{display:none}.admin-feature-group-summary strong,.admin-feature-group-summary small{display:block}.admin-feature-group-summary small{margin-top:4px;color:var(--muted)}.admin-feature-group-count{flex:none;display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:999px;background:#142a540f;color:var(--muted);font-size:11px;font-weight:700}.admin-feature-options{display:flex;flex-wrap:wrap;gap:8px;padding:0 14px 14px}.admin-feature-option{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;max-width:100%;padding:0 12px;border-radius:999px;border:1px solid rgba(20,42,84,.1);background:#ffffffeb;color:var(--text);transition:border-color .15s ease,background-color .15s ease,transform .15s ease,color .15s ease}.admin-feature-option.checked{border-color:#1f74ff42;background:#1f74ff1f;color:var(--brand)}.admin-feature-option span{font-weight:700;font-size:13px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-feature-option small{color:inherit;font-size:11px;font-weight:700;opacity:.78}.admin-feature-option.locked{cursor:not-allowed;opacity:.86}.admin-feature-option.locked:hover{transform:none;border-color:#1f74ff42;background:#1f74ff1f}.admin-feature-option:hover{transform:translateY(-1px);border-color:#1f74ff33;background:#1f74ff14}.admin-advanced-panel{border:1px solid rgba(20,42,84,.08);border-radius:18px;background:#ffffffb8;padding:14px}.admin-template-tip{padding:10px 12px;border-radius:12px;background:#1f74ff14;color:var(--muted)}.admin-template-tip--compact{background:#1f74ff0f}.admin-template-tip strong{color:var(--text)}.admin-advanced-panel summary{cursor:pointer;font-weight:700;margin-bottom:12px}.admin-advanced-note{padding:12px;border-radius:12px;background:#1f74ff14;color:var(--muted)}.admin-template-layout{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr);gap:14px;height:100%;min-height:0}.admin-template-sidebar{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;overflow:hidden}.admin-template-actions{display:grid;gap:10px}.admin-template-list{min-height:0;display:grid;gap:10px;padding-right:4px}.admin-template-pill{display:grid;gap:2px;justify-items:start;padding:12px;border-radius:14px;background:#ffffffe0;text-align:left}.admin-template-pill.active{border-color:#1f74ff3d;background:linear-gradient(180deg,#1f74ff24,#1f74ff14)}.admin-template-pill strong{font-size:14px}.admin-template-pill small{color:var(--muted)}.admin-device-modal-body{display:flex;flex-direction:column;gap:12px;height:100%;min-height:0;overflow:hidden}.admin-device-list{flex:1 1 auto;min-height:0}.admin-table-foot,.admin-feedback-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px}@media (max-width: 1480px){.admin-summary-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-page-head{align-items:stretch}}@media (max-width: 1280px){.admin-customer-head,.admin-customer-row{grid-template-columns:minmax(140px,1fr) minmax(180px,1.2fr) minmax(150px,1fr) minmax(150px,1fr)}.admin-row-actions{grid-column:1 / -1;justify-content:flex-start}.admin-feature-options,.admin-template-layout{grid-template-columns:1fr}}@media (max-width: 920px){.admin-modal-layer{padding:16px}.admin-modal-card,.admin-modal-card--editor,.admin-modal-card--manager,.admin-modal-card--device{width:min(100%,calc(100vw - 32px));max-height:calc(100vh - 32px)}.admin-editor-layout{grid-template-columns:1fr}.admin-editor-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-editor-nav button{justify-items:center;min-height:52px;text-align:center}.admin-editor-nav button small{display:none}}@media (max-width: 768px){.admin-login-shell,.admin-app-shell{padding:14px}.admin-summary-strip,.admin-form-grid,.admin-feature-options{grid-template-columns:1fr}.admin-toolbar-main,.admin-toolbar-secondary,.admin-table-foot,.admin-page-head,.admin-feedback-header,.admin-modal-head,.admin-section-copy-row,.admin-modal-footer{flex-direction:column;align-items:stretch}.admin-head-actions{justify-items:stretch;max-width:none}.admin-session-strip{justify-content:space-between}.admin-top-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-customer-head{display:none}.admin-customer-row{grid-template-columns:1fr}.admin-search,.admin-toolbar-main select,.admin-toolbar-secondary select{min-width:0;width:100%}.admin-page-head h1{font-size:clamp(28px,8vw,38px)}.admin-modal-body{padding:14px}.admin-modal-footer{padding:12px 14px 14px}}
