:root{font-family:Plus Jakarta Sans,PingFang SC,Noto Sans SC,sans-serif;color:#232842;background:radial-gradient(circle at top center,rgba(110,108,255,.16),transparent 26%),radial-gradient(circle at left top,rgba(115,198,255,.16),transparent 20%),linear-gradient(180deg,#f6f7ff,#f4f6ff 38%,#fbfbfe);--bg-soft: rgba(255, 255, 255, .72);--bg-card: rgba(255, 255, 255, .94);--bg-card-muted: rgba(247, 248, 255, .94);--ink-strong: #232842;--ink-base: #49506c;--ink-muted: #7b82a0;--ink-soft: #a0a7c0;--line-soft: rgba(112, 121, 171, .14);--line-strong: rgba(102, 111, 166, .22);--brand: #6f6cff;--brand-deep: #5856f2;--brand-soft: rgba(111, 108, 255, .1);--accent: #59b8ff;--success-bg: #e9f8ef;--success-ink: #1f8c59;--warn-bg: #fff4de;--warn-ink: #b37b15;--danger-bg: #ffe6ec;--danger-ink: #c24e66;--shadow-panel: 0 28px 80px rgba(88, 94, 138, .08);--shadow-card: 0 18px 40px rgba(93, 101, 147, .1);--radius-panel: 28px;--radius-card: 22px;--radius-input: 16px}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%}body{min-height:100vh;color:var(--ink-strong)}a{color:inherit}button,input,textarea,select{font:inherit}input,textarea,select{width:100%;border:1px solid var(--line-soft);background:#fbfcfff5;border-radius:var(--radius-input);padding:13px 15px;color:var(--ink-strong);outline:none;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}input:hover,textarea:hover,select:hover{border-color:var(--line-strong)}input:focus,textarea:focus,select:focus{border-color:#6f6cff7a;box-shadow:0 0 0 4px #6f6cff1f}textarea{min-height:160px;resize:vertical}button{border:none;border-radius:999px;padding:12px 18px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;cursor:pointer;font-weight:700;letter-spacing:.01em;box-shadow:0 14px 28px #615ff13d;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease,filter .12s ease}button:hover{transform:translateY(-1px);box-shadow:0 18px 34px #615ff14d;filter:saturate(1.04)}button:focus-visible,.sidebar a:focus-visible,.inline-link:focus-visible{outline:3px solid rgba(111,108,255,.18);outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.68;transform:none;box-shadow:none}button.secondary{background:#fffffff5;color:#343c58;box-shadow:none;border:1px solid var(--line-soft)}button.ghost{background:transparent;color:#57607f;border:1px solid rgba(111,108,255,.16);box-shadow:none}.shell{min-height:100vh;display:grid;grid-template-columns:290px 1fr;gap:22px;padding:22px}.sidebar{padding:24px 20px;background:linear-gradient(180deg,#fffffff2,#f7f8fff5);color:var(--ink-strong);position:sticky;top:22px;height:calc(100vh - 44px);display:flex;flex-direction:column;gap:22px;border:1px solid rgba(121,129,184,.12);border-radius:28px;box-shadow:var(--shadow-panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.sidebar-top{display:grid;gap:18px}.sidebar-brand{display:flex;gap:14px;align-items:center}.sidebar-mark{width:56px;height:56px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,#7c73ff,#5856f2);color:#fff;font-weight:800;letter-spacing:.08em;box-shadow:0 14px 26px #615ff13d}.sidebar h1{margin:0;font-size:28px}.sidebar p{margin:6px 0 0;color:var(--ink-muted);line-height:1.55}.sidebar-summary,.sidebar-note,.sidebar-metrics{border-radius:22px;border:1px solid rgba(118,127,180,.12);background:#f7f8ffeb}.sidebar-summary{padding:18px}.sidebar-summary-label,.sidebar-nav-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#9197b2}.sidebar-summary-value{margin-top:10px;font-size:22px;font-weight:800;color:var(--ink-strong)}.sidebar-summary-copy{margin-top:8px;line-height:1.6;color:var(--ink-muted)}.sidebar-nav{display:grid;gap:10px}.sidebar a{color:var(--ink-strong);text-decoration:none;padding:16px 18px;border-radius:18px;background:#ffffffe0;border:1px solid rgba(120,128,182,.08);transition:background .12s ease,border-color .12s ease,transform .12s ease;display:grid;gap:4px}.sidebar a span{font-size:15px;font-weight:700}.sidebar a small{color:var(--ink-muted);font-size:12px}.sidebar a.router-link-active{background:linear-gradient(135deg,#6f6cff1f,#59b8ff14);border-color:#6f6cff2e;box-shadow:inset 0 0 0 1px #6f6cff14}.sidebar a:hover{transform:translate(2px)}.sidebar-metrics{padding:8px;display:grid;gap:8px}.sidebar-metric{padding:12px 14px;border-radius:16px;background:#ffffffdb;display:flex;justify-content:space-between;gap:16px;align-items:center}.sidebar-metric span{color:var(--ink-muted);font-size:13px}.sidebar-metric strong{color:var(--ink-strong);font-size:13px}.sidebar-note{margin-top:auto;padding:18px;line-height:1.65;color:var(--ink-base);font-size:14px}.content{padding:8px 8px 28px 0}.content-login-only{min-height:100vh;padding:24px}.content-topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;padding:10px 4px 0}.content-actions{display:flex;flex-wrap:wrap;gap:10px}.content-chip{padding:10px 14px;border-radius:999px;background:#ffffffeb;border:1px solid rgba(112,120,172,.1);color:#646d8e;font-size:12px;font-weight:700;box-shadow:0 8px 22px #5f659a14}.content-intro{display:flex;align-items:stretch;justify-content:space-between;gap:20px;margin-bottom:20px}.content-kicker{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:#6f6cff1a;color:var(--brand-deep);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.content-intro-main{flex:1;padding:28px 30px;border-radius:26px;background:linear-gradient(180deg,#fffffff0,#f8f9fff5);border:1px solid rgba(121,130,184,.1);box-shadow:var(--shadow-panel)}.content-intro h2{margin:0 0 10px;font-size:40px;line-height:1.06;letter-spacing:-.03em}.content-intro p{margin:0;max-width:760px;color:var(--ink-muted);line-height:1.7}.content-spotlight{width:310px;border-radius:26px;background:linear-gradient(135deg,#6f6cfffa,#59b8ffe0);padding:24px 22px;color:#fff;box-shadow:0 22px 44px #615ff13d;display:grid;gap:10px}.content-spotlight-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#ffffffbd}.content-spotlight strong{font-size:24px;line-height:1.2}.content-spotlight span{color:#ffffffd1;font-size:14px;line-height:1.6}.panel{background:var(--bg-soft);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius-panel);padding:28px;box-shadow:var(--shadow-panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:26px}.page-title{margin:0;font-size:34px;line-height:1.06;letter-spacing:-.03em}.page-subtitle{margin:10px 0 0;max-width:760px;color:var(--ink-muted);line-height:1.7}.section-stack{display:grid;gap:20px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.compact-stats .stat-card{min-height:150px}.stat-value-small{font-size:24px;line-height:1.25;word-break:break-word}.crm-board{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:18px}.crm-board-main,.crm-board-side{border-radius:24px;padding:22px 24px;border:1px solid rgba(116,124,178,.1);box-shadow:var(--shadow-card)}.crm-board-main{background:linear-gradient(135deg,#fffffffa,#f4f5fff0)}.crm-board-side{background:linear-gradient(135deg,#6f6cfff5,#7fa2ffeb);color:#fff}.crm-board-kicker,.crm-board-side-label{display:inline-flex;align-items:center;padding:6px 11px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.crm-board-kicker{background:#6f6cff1a;color:var(--brand-deep)}.crm-board-side-label{background:#ffffff2e;color:#ffffffd1}.crm-board-main h3,.crm-board-side strong{display:block;margin:14px 0 10px;font-size:28px;line-height:1.15;letter-spacing:-.03em}.crm-board-main p,.crm-board-side p{margin:0;line-height:1.7}.crm-board-main p{color:var(--ink-muted)}.crm-board-side p{color:#ffffffd1}.crm-inline-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.crm-inline-metric{padding:14px 16px;border-radius:18px;background:#f8f9fff5;border:1px solid rgba(116,124,178,.1)}.crm-inline-metric span{display:block;font-size:12px;color:var(--ink-muted)}.crm-inline-metric strong{display:block;margin-top:8px;font-size:28px;color:var(--ink-strong)}.filter-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.filter-pill{border:1px solid rgba(116,124,178,.1);background:#f7f8fff5;color:var(--ink-base);box-shadow:none}.filter-pill.active{background:linear-gradient(135deg,#6f6cfff5,#7fa2ffeb);color:#fff;border-color:transparent}.stat-card{position:relative;overflow:hidden;padding:20px 20px 18px;border-radius:24px;background:linear-gradient(180deg,#fffffffa,#f7f8fff5);border:1px solid rgba(115,123,176,.08);box-shadow:var(--shadow-card)}.stat-card:after{content:"";position:absolute;inset:auto 0 0;height:4px;background:linear-gradient(90deg,#6f6cffe6,#59b8ffc7)}.stat-label{color:var(--ink-muted);font-size:13px}.stat-value{margin-top:12px;font-size:34px;font-weight:800;color:var(--ink-strong)}.stat-note{margin-top:8px;color:var(--ink-soft);font-size:13px;line-height:1.5}.row{display:flex;gap:12px;flex-wrap:wrap}.inline-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.button-secondary{background:#fffffff5;color:#343c58;box-shadow:none;border:1px solid var(--line-soft)}.card-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);gap:18px}.device-workbench{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);gap:18px;align-items:start}.device-feed{display:grid;gap:12px}.device-inspector{position:sticky;top:22px}.detail-shell{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:18px}.detail-side{display:grid;gap:12px;align-content:start}.detail-main{display:grid;gap:18px}.mini-card{padding:16px 18px;border-radius:18px;background:#ffffffeb;border:1px solid rgba(121,128,183,.08);cursor:pointer;display:grid;gap:8px}.mini-card.selected{border-color:#6f6cff47;background:linear-gradient(180deg,#6f6cff14,#fffffff2);box-shadow:var(--shadow-card)}.muted-text{color:var(--ink-muted);font-size:13px;line-height:1.5}.status-badge.neutral{background:#747cb21f;color:var(--ink-base)}.group-editor-list{display:grid;gap:14px;margin-top:12px}.group-editor-card{display:grid;gap:12px;padding:14px;border-radius:18px;background:#fafbfff0;border:1px solid rgba(116,124,178,.1)}.group-editor-items{display:grid;gap:10px}.group-editor-row{display:grid;grid-template-columns:minmax(180px,.9fr) minmax(220px,1.1fr) auto;gap:10px;align-items:center}.status-stack{display:grid;gap:10px;margin-top:16px}.card{padding:22px;border-radius:var(--radius-card);background:var(--bg-card);border:1px solid rgba(117,124,178,.1);box-shadow:var(--shadow-card)}.card-muted{background:var(--bg-card-muted)}.card-title{margin:0;font-size:20px;line-height:1.3;color:#232945}.card-subtitle{margin:8px 0 0;color:var(--ink-muted);line-height:1.65}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid label,.field{display:flex;flex-direction:column;gap:8px}.field-label{font-size:14px;font-weight:700;color:#37405f}.field-hint{color:var(--ink-soft);font-size:13px}.checkbox-field{display:flex;align-items:center;gap:10px;padding-top:28px}.checkbox-field input{width:18px;height:18px}.inline-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#ffffffeb;border:1px solid rgba(115,124,178,.1);text-decoration:none;color:#56608b;font-size:13px;font-weight:700}.inline-link:hover{text-decoration:none;background:#6f6cff14}.preview-block{padding:16px 18px;border-radius:18px;background:#f9fafff0;border:1px solid rgba(116,124,178,.1)}.preview-title{font-weight:800;color:var(--ink-strong);margin-bottom:12px}.chapter-list{display:grid;gap:10px}.chapter-list-tall{max-height:540px;overflow:auto;padding-right:4px}.chapter-item{padding:12px 14px;border-radius:14px;background:#ffffffeb;border:1px solid rgba(121,128,183,.08)}.chapter-path{font-weight:700;color:var(--ink-strong)}.chapter-meta,.image-meta{margin-top:4px;font-size:12px;color:var(--ink-soft)}.image-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.image-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr))}.image-card{display:block;color:inherit;text-decoration:none;padding:10px;border-radius:16px;background:#fffffff0;border:1px solid rgba(117,125,179,.1)}.image-card img{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:12px;background:#eef2ff}.image-caption{margin-top:10px;font-weight:700;color:var(--ink-strong);line-height:1.45}.manual-preview{margin:0;white-space:pre-wrap;word-break:break-word;line-height:1.6;max-height:480px;overflow:auto;padding:14px;border-radius:16px;background:#fffffff0;border:1px solid rgba(116,124,178,.1)}.list{display:grid;gap:14px;margin-top:16px}.device-card{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start}.device-card-selectable{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.device-card-selectable:hover{transform:translateY(-2px)}.device-card-selectable.active{border-color:#6f6cff47;box-shadow:0 22px 44px #615ff11f}.device-main h3,.record-title{margin:0;font-size:20px}.device-model{margin:8px 0 0;font-size:14px;color:var(--ink-muted)}.device-meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}.device-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.tag{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;background:var(--brand-soft);color:#5b648e;font-size:13px;font-weight:700}.tag-warn{background:var(--warn-bg);color:var(--warn-ink)}.tag-danger{background:var(--danger-bg);color:var(--danger-ink)}.tag-success{background:var(--success-bg);color:var(--success-ink)}.metrics-list,.detail-list{display:grid;gap:10px;margin-top:14px}.metric-row,.detail-row{display:grid;grid-template-columns:140px 1fr;gap:12px;font-size:14px;line-height:1.6}.metric-label,.detail-label{color:var(--ink-muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.status-banner{padding:14px 16px;border-radius:18px;background:#6f6cff14;color:#56628b;border:1px solid rgba(111,108,255,.1);line-height:1.6}.status-banner.warn{background:var(--warn-bg);color:var(--warn-ink)}.status-banner.error{background:var(--danger-bg);color:var(--danger-ink)}.attempt-list,.task-list{display:grid;gap:12px}.attempt-card,.task-card,.record-card{padding:16px;border-radius:18px;background:#fffffff0;border:1px solid rgba(116,124,178,.1)}.attempt-head,.task-head,.record-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.mono,pre{font-family:SF Mono,JetBrains Mono,monospace;font-size:12px}.inline-code{padding:2px 6px;border-radius:8px;background:#525a8e14}pre{margin:0;white-space:pre-wrap;word-break:break-word;background:#f7f8fff5;color:#313a5a;padding:14px;border-radius:16px;border:1px solid rgba(116,124,178,.1)}.empty-state{padding:18px;border-radius:18px;background:#f8f9ffe6;color:var(--ink-muted);border:1px dashed rgba(116,124,178,.16)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;min-width:860px}.table th,.table td{padding:12px 10px;border-bottom:1px solid rgba(116,124,178,.12);text-align:left;vertical-align:middle}.table th{color:var(--ink-muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.table td input,.table td select{margin:0}.toggle-check{width:18px;height:18px;min-height:18px;padding:0;border-radius:4px}.manual-preview-layout{display:grid;grid-template-columns:minmax(280px,.75fr) minmax(0,1.25fr);gap:16px}.error-text{color:#b64662}@media(max-width:1200px){.crm-board,.device-workbench,.manual-preview-layout,.card-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:960px){.shell{grid-template-columns:1fr;padding:14px}.sidebar{position:static;height:auto}.content{padding:0 0 24px}.content-topbar,.content-intro{display:grid}.crm-board,.device-workbench,.manual-preview-layout,.crm-inline-metrics{grid-template-columns:1fr}.content-spotlight{width:100%}.panel{padding:18px;border-radius:22px}.page-head,.device-card,.attempt-head,.task-head,.record-head{grid-template-columns:1fr;display:block}.device-actions{justify-content:flex-start}.stats-grid,.card-grid,.form-grid,.image-grid{grid-template-columns:1fr}.metric-row,.detail-row,.group-editor-row{grid-template-columns:1fr;gap:4px}}
