:root{--bg: #f5f7fa;--panel: #ffffff;--panel-soft: #fbfcfe;--ink: #303133;--muted: #606266;--muted-soft: #909399;--accent: #5b78e8;--accent-strong: #4865d6;--accent-soft: #eef2ff;--accent-mist: #e6ebfa;--warm: #c98567;--line: #e4e7ed;--line-soft: rgba(48, 49, 51, .08);--shadow: 0 10px 30px rgba(24, 39, 75, .06);--shadow-sm: 0 6px 18px rgba(24, 39, 75, .05)}*,*:before,*:after{box-sizing:border-box}html,body,#app{width:100%;height:100%;min-height:100%}body{margin:0;font-family:Avenir Next,PingFang SC,Microsoft YaHei,Segoe UI,Arial,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,rgba(91,120,232,.12),transparent 30%),radial-gradient(circle at top right,rgba(201,133,103,.08),transparent 24%),var(--bg);min-height:100vh;min-height:100dvh;overflow:hidden}a{color:inherit;text-decoration:none}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid rgba(91,120,232,.28);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:12px;border:1px solid transparent;font-weight:600;font-size:14px;cursor:pointer;transition:transform .22s ease,box-shadow .22s ease,background .2s ease,border-color .2s ease,color .2s ease}.btn:disabled{cursor:not-allowed;opacity:.7}.btn.primary{background:var(--accent);color:#fff;box-shadow:0 10px 20px #5b78e82e}.btn.primary:hover:not(:disabled){transform:translateY(-2px);background:var(--accent-strong);box-shadow:0 14px 24px #5b78e838}.btn.ghost{background:#ffffffb8;border-color:var(--line);color:var(--muted)}.btn.ghost:hover:not(:disabled){transform:translateY(-2px);background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}.error-text{color:#b85d55;font-size:13px}.login-shell{min-height:100%;display:flex;justify-content:center;align-items:center;padding:28px;animation:fadeUp .5s ease;overflow:auto;background:radial-gradient(circle at top left,rgba(91,120,232,.14),transparent 32%),linear-gradient(180deg,#f7f9fc,#eef2f8)}.login{display:flex;flex-direction:column;align-items:center;width:min(420px,100%);padding:40px 38px;background:#ffffffeb;border:1px solid rgba(228,231,237,.96);border-radius:20px;box-shadow:0 24px 48px #18274b14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.login h2{color:var(--ink);margin:0 0 28px;font-size:34px;line-height:1.2;letter-spacing:.02em}.login-form{width:100%;display:flex;flex-direction:column;align-items:center}.login .login_box{position:relative;width:100%}.login .login_box input{outline:none;width:100%;padding:16px 12px 12px;margin-bottom:30px;color:var(--ink);font-size:16px;line-height:1.2;border:1px solid var(--line);border-radius:14px;background:#ffffffd6;transition:border-color .25s ease,box-shadow .25s ease}.login .login_box label{position:absolute;top:15px;left:12px;padding:0;color:var(--muted-soft);pointer-events:none;line-height:1;background:#fff;transform-origin:left top;transition:transform .25s ease,color .25s ease,top .25s ease,left .25s ease}.login .login_box input::placeholder{color:transparent}.login .login_box input:focus+label,.login .login_box input:not(:placeholder-shown)+label,.login .login_box input:-webkit-autofill+label{top:-7px;left:10px;padding:0 4px;color:var(--accent);transform:scale(.75)}.login .login_box input.is-invalid{border-color:#d9897d}.login .login_box input.is-invalid+label{color:#d9897d}.login .login_box input:focus{border-color:#5b78e899;box-shadow:0 0 0 4px #5b78e81f}.login-error{width:100%;margin:-12px 0 12px;color:#c75b57;font-size:13px}.login-status{width:100%;margin:-12px 0 12px;color:var(--accent);font-size:12px;font-weight:600}.login-submit{display:inline-flex;justify-content:center;align-items:center;width:auto;min-width:132px;min-height:44px;align-self:center;padding:10px 20px;border:1px solid transparent;border-radius:12px;background:var(--accent);color:#fff;text-decoration:none;box-shadow:0 12px 24px #5b78e833;transition:transform .22s ease,background .22s ease,box-shadow .22s ease;cursor:pointer;appearance:none;-webkit-appearance:none}.login-submit:hover:not(:disabled){transform:translateY(-2px);background:var(--accent-strong);box-shadow:0 16px 28px #5b78e83d}.login-submit:disabled{opacity:.55;cursor:not-allowed}.login-submit-text{position:relative;z-index:2}.login-submit-line{display:none}.login .login_box input:-webkit-autofill,.login .login_box input:-webkit-autofill:hover,.login .login_box input:-webkit-autofill:focus,.login .login_box input:-webkit-autofill:active{-webkit-text-fill-color:var(--ink);-webkit-box-shadow:0 0 0 1000px #ffffff inset;transition:background-color 9999s ease-out;box-shadow:0 0 0 1000px #fff inset;caret-color:var(--ink)}.app-shell{height:100%;min-height:0;display:flex;flex-direction:column;animation:fadeUp .5s ease;overflow:hidden}.app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:24px clamp(24px,6vw,80px) 18px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:40px;height:40px;border-radius:14px;background:linear-gradient(135deg,#5b78e8,#7a8fb9);box-shadow:0 12px 22px #5b78e838}.brand-title{margin:0;font-size:18px;color:var(--ink);font-weight:700}.brand-sub{margin:2px 0 0;color:var(--muted-soft);font-size:12px}.app-nav{display:flex;gap:8px;color:var(--muted);justify-self:center;padding:6px;border-radius:18px;border:1px solid rgba(228,231,237,.9);background:#ffffffb8;box-shadow:var(--shadow-sm)}.nav-item{padding:9px 16px;border-radius:12px;border:1px solid transparent;font-weight:600;transition:transform .22s ease,background .2s ease,border-color .2s ease,color .2s ease,box-shadow .22s ease}.nav-item:hover{transform:translateY(-1px);color:var(--ink);background:#f9fbff}.nav-item.is-active{border-color:#5b78e824;background:#fff;color:var(--ink);box-shadow:0 8px 16px #18274b0f}.app-main{flex:1;min-height:0;overflow:hidden;padding:0 clamp(20px,4vw,80px) clamp(18px,3vh,52px)}.page{height:100%;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden}.page-body-scroll{min-height:0;overflow:auto;display:grid;align-content:start;gap:clamp(18px,2.2vh,28px);padding-right:clamp(2px,.4vw,10px);padding-bottom:clamp(12px,1.8vh,28px)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.page-header h2{margin:0;font-size:34px;font-weight:700;line-height:1.2;color:var(--ink)}.page-header p{margin:8px 0 0;color:var(--muted);font-size:14px}.header-actions{display:flex;gap:12px;align-items:center}.hidden-file-input{display:none}.card{background:var(--panel);border-radius:18px;padding:24px;border:1px solid rgba(228,231,237,.92);box-shadow:var(--shadow)}.cockpit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-bottom:10px}.metric-card{position:relative;overflow:hidden;display:grid;gap:18px;min-height:176px;border:1px solid rgba(228,231,237,.96);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}.metric-card:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:1px;background:linear-gradient(90deg,var(--metric-accent, var(--accent)),transparent 55%);opacity:.85}.metric-card:hover{transform:translateY(-3px);box-shadow:0 18px 34px #18274b14;border-color:#5b78e829}.metric-card.is-key{background:linear-gradient(180deg,#fff,#fafcff)}.metric-card.is-key .metric-value{font-size:36px}.metric-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.metric-info{display:grid;gap:10px}.metric-name{color:var(--muted);font-size:12px;margin:0;letter-spacing:.05em}.metric-value{font-size:32px;font-weight:700;margin:0;color:var(--ink);letter-spacing:-.03em}.metric-icon{width:46px;height:46px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.72);box-shadow:inset 0 1px #ffffff73}.metric-icon-svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.metric-tag{display:inline-block;padding:6px 10px;border-radius:999px;font-size:11px;letter-spacing:.08em;background:#5b78e814;color:var(--muted)}.metric-note{color:var(--muted-soft);font-size:12px;line-height:1.5}.cockpit-row{display:grid;grid-template-columns:minmax(320px,2fr) minmax(240px,1fr);gap:22px;align-items:stretch}.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px}.trend-chart{display:grid;gap:14px}.trend-plot{position:relative;border-radius:18px;padding:8px 6px 4px;background:linear-gradient(180deg,#fff,#f8fafc)}.trend-svg{display:block;width:100%;height:170px}.trend-summary{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.trend-stat{min-width:78px;padding:10px 12px;border-radius:14px;background:var(--panel-soft);border:1px solid rgba(228,231,237,.96);text-align:right}.trend-stat strong{display:block;color:var(--ink);font-size:16px;letter-spacing:-.02em}.trend-stat small{color:var(--muted-soft);font-size:11px}.trend-gridline{stroke:#30313314;stroke-width:1}.trend-area{fill:url(#attendanceTrendFill)}.trend-line{fill:none;stroke:var(--accent);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.trend-point{fill:#fff;stroke:var(--accent);stroke-width:1.8}.trend-legend{display:flex;gap:16px;font-size:12px;color:var(--muted-soft)}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.legend-dot.teal{background:var(--accent)}.trend-axis{display:grid;font-size:11px;color:var(--muted-soft);gap:6px}.trend-axis span{text-align:center}.filter-panel{margin-bottom:2px;background:linear-gradient(180deg,#fffffff5,#fbfcfef5)}.filter-panel-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}.filter-panel-title{margin:0;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-soft);font-weight:700}.filter-panel-sub{margin:8px 0 0;color:var(--muted);font-size:13px}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;align-items:end}.filter-field{display:grid;gap:10px;font-size:13px}.filter-field label{color:var(--muted-soft);letter-spacing:.08em;font-size:11px}.filter-field select{padding:11px 14px;border-radius:14px;border:1px solid var(--line);background:#ffffffe6;font-size:14px;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.filter-field select:hover{transform:translateY(-1px)}.filter-field select:focus-visible{border-color:#5b78e866;box-shadow:0 0 0 4px #5b78e814;outline:none}.active-filter-wrap{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;background:#f5f7fae6}.active-filter-title{margin:0;color:var(--muted);font-size:12px;font-weight:600}.active-filter-list{display:flex;flex-wrap:wrap;gap:8px}.active-filter-chip{display:inline-flex;align-items:center;border-radius:999px;border:1px solid rgba(91,120,232,.12);background:#5b78e80f;color:var(--accent-strong);font-size:12px;padding:5px 10px;line-height:1;cursor:pointer}.dist-card .card-head{margin-bottom:16px;align-items:flex-start}.tab-group{display:inline-flex;gap:6px;padding:4px;border-radius:14px;background:#f3f5f8}.tab-btn{border:none;background:transparent;color:var(--muted);font-size:12px;padding:6px 12px;border-radius:999px;cursor:pointer}.tab-btn.active{background:#fff;color:var(--ink);font-weight:600;box-shadow:var(--shadow-sm)}.bar-chart,.bar-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:minmax(120px,1fr) 2fr auto;gap:12px;align-items:center}.bar-label{color:var(--ink);font-size:13px;max-width:none;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word;line-height:1.35}.bar-track{width:100%;height:10px;background:#eceff4;border-radius:999px;overflow:hidden}.bar-fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#92a7ea,#5b78e8)}.bar-value{font-size:12px;color:var(--muted)}.donut-wrap{display:grid;gap:12px}.donut-layout{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center}.donut-chart{width:156px;height:156px;filter:drop-shadow(0 10px 18px rgba(24,39,75,.06))}.donut-legend{display:grid;gap:10px;font-size:13px}.legend-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-name{color:var(--ink)}.legend-value{color:var(--muted);font-size:12px}.dist-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.dist-title{margin:0 0 10px;font-weight:600}.dist-list{display:grid;gap:10px}.dist-item{display:grid;grid-template-columns:minmax(72px,1fr) 2fr auto;gap:8px;align-items:center}.dist-bar{width:100%;height:8px;background:#f1ece3;border-radius:999px;overflow:hidden}.dist-bar span{display:block;height:100%;background:var(--accent);border-radius:999px}.dist-value{font-size:12px;color:var(--muted)}.rank-card .card-head{margin-bottom:16px}.rank-card{height:560px;min-height:0;display:flex;flex-direction:column;overflow:hidden}.rank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}.rank-title{margin:0 0 12px;font-weight:600;color:var(--ink)}.rank-list{list-style:none;margin:0;padding:0 4px 0 0;display:grid;gap:12px;font-size:14px;flex:1;min-height:0;overflow-y:auto}.rank-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(48,49,51,.06)}.rank-badge{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:#f4e8e4;color:#a05d49}.rank-badge.gold{background:#f0e2be;color:#9b7335}.rank-badge.silver{background:#edf0f4;color:#708091}.rank-badge.bronze{background:#ecd8cc;color:#9b6c56}.rank-body{flex:1;display:grid;gap:6px}.rank-name{font-weight:600;color:var(--ink)}.rank-progress{display:flex;align-items:center;gap:12px}.rank-value{font-size:12px;color:var(--muted);min-width:52px}.mini-progress{flex:1;height:6px;background:#eef1f5;border-radius:999px;overflow:hidden}.mini-bar{display:block;height:100%;border-radius:999px}.mini-bar.high{background:#d9897d}.mini-bar.medium{background:#d2a767}.mini-bar.low{background:#7ea998}.alert-card{display:flex;flex-direction:column}.alert-list{list-style:none;padding:0 4px 0 0;margin:0;display:grid;gap:12px;flex:1;min-height:0;overflow-y:auto}.alert-card{height:560px;min-height:0;display:flex;flex-direction:column;overflow:hidden}.alert-item{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:14px;border-radius:16px;border:1px solid rgba(228,231,237,.96);background:linear-gradient(180deg,#fff,#fbfcfe)}.alert-level{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--warm);font-weight:700}.alert-level.is-high{color:#b86a58}.alert-level.is-medium{color:#af8751}.alert-level.is-low{color:#6f9283}.alert-item p{margin:0 0 4px;color:var(--ink);font-size:14px;font-weight:600}.alert-item small{color:var(--muted);font-size:12px}.table-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.data-feedback{margin:0 0 12px;padding:8px 10px;border-radius:10px;font-size:13px;line-height:1.4}.data-feedback.is-success{background:#ecfdf3;border:1px solid #bbf7d0;color:#166534}.data-feedback.is-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.table-title{font-weight:600;margin:0;color:var(--ink)}.table-sub{margin:6px 0 0;color:var(--muted);font-size:13px}.meta-count{padding:6px 12px;border-radius:999px;background:#f3f5f8;font-size:12px;color:var(--muted);border:1px solid var(--line)}.filter-card{display:grid;gap:16px;margin-bottom:2px}.filter-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.filter-group{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.filter-label{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted-soft)}.table-switcher{display:flex;flex-wrap:wrap;gap:8px}.switcher-btn{border:1px solid var(--line);border-radius:12px;padding:8px 16px;background:#fff;color:var(--ink);font-size:13px;cursor:pointer;transition:transform .22s ease,background .2s ease,color .2s ease,border .2s ease,box-shadow .22s ease}.switcher-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.switcher-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.filter-actions{display:flex;gap:12px;align-items:center}.filter-list{display:grid;gap:12px}.filter-field-search{min-width:220px}.filter-item{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.filter-input,.filter-select{padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:14px;color:var(--ink);min-width:160px}.filter-remove{padding:8px 14px}.data-table{width:100%;border-collapse:collapse;font-size:14px;min-width:960px}.data-table th,.data-table td{padding:14px 10px;text-align:center;vertical-align:middle;border-bottom:1px solid var(--line)}.data-table th{background:#f9fafc;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted-soft);font-weight:700;position:sticky;top:0;z-index:1}.data-table-wrap{border:1px solid var(--line);border-radius:16px;overflow:auto;max-height:62vh;background:#fff}.data-table tbody tr:hover{background:#f7f9fc}.table-state{padding:24px 0;color:var(--muted)}.table-actions{display:flex;gap:10px;justify-content:center}.btn.action{padding:6px 12px;font-size:12px;border-radius:999px;border:1px solid transparent;background:#fff;font-weight:600}.btn.action.edit{border-color:#bfdbfe;color:#2563eb}.btn.action.view{border-color:#c7d2fe;color:#4f46e5}.btn.action.delete{border-color:#fecaca;color:#dc2626}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#f3f4f6;color:#6b7280}.status-badge.ok{background:#dcfce7;color:#166534}.status-badge.warn{background:#fef3c7;color:#92400e}.status-badge.off{background:#fee2e2;color:#b91c1c}.pagination-bar{margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.pagination-controls{display:flex;align-items:center;gap:8px}.page-btn{border:1px solid var(--line);background:#fff;border-radius:12px;padding:6px 10px;font-size:12px;cursor:pointer;color:var(--muted)}.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-size{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.page-size select{padding:6px 10px;border-radius:10px;border:1px solid var(--line);background:#fff}.chat-session{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid var(--line);color:var(--muted);font-size:12px;background:#f3f5f8}.chat-shell{display:grid;grid-template-columns:clamp(240px,24vw,320px) minmax(0,1fr);gap:16px;align-items:stretch;height:100%;min-height:0}.chat-sidebar{display:flex;flex-direction:column;min-height:0;padding:0;overflow:hidden}.chat-sidebar-head{display:flex;justify-content:space-between;align-items:center;padding:14px 14px 8px}.chat-sidebar-head-actions{display:flex;align-items:center;gap:8px}.chat-clear-btn{padding:7px 12px;font-size:12px}.chat-sidebar-title{margin:0;color:var(--ink);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.chat-sidebar-search{padding:0 14px 12px;border-bottom:1px solid var(--line);display:grid;gap:6px}.chat-search-label{font-size:12px;color:var(--muted)}.chat-search-input{height:36px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:13px;padding:0 12px}.chat-search-input::placeholder{color:#9ca3af}.chat-search-input:focus-visible{border-color:#93c5fd;box-shadow:0 0 0 3px #2563eb1f;outline:none}.chat-session-list{flex:1;min-height:0;overflow:auto;padding:12px;display:grid;gap:10px}.chat-session-item{border:1px solid var(--line);border-radius:14px;background:#fff;padding:11px 12px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:5px;transition:transform .22s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease}.chat-session-open{border:none;background:transparent;margin:0;padding:0;text-align:left;display:grid;gap:5px;width:100%;cursor:pointer;font:inherit;color:inherit}.chat-session-remove{border:1px solid #e2e8f0;background:#fff;color:#64748b;border-radius:999px;padding:3px 8px;font-size:11px;line-height:1.3;cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease}.chat-session-remove:hover{color:#b85d55;border-color:#efcec7;background:#fbf1ef}.chat-session-item:hover{transform:translateY(-1px);border-color:#5b78e83d;background:#f8faff}.chat-session-item.is-active{border-color:#5b78e857;background:#eef2ff;box-shadow:0 1px 2px #5b78e81a}.chat-session-preview{color:var(--ink);font-size:13px;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.chat-session-time{color:var(--muted-soft);font-size:11px}.chat-side-tip{margin:4px 2px;color:var(--muted);font-size:12px}.chat-side-error{margin-top:6px}.chat-main{display:grid;grid-template-rows:auto 1fr auto;min-height:0;padding:0;overflow:hidden}.chat-main-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line);background:#fcfdff}.chat-empty-shell{min-height:min(72vh,760px);display:grid;grid-template-rows:auto auto;align-content:center;justify-items:center;gap:20px;padding:clamp(20px,3vw,36px)}.chat-empty-hero{width:min(860px,100%);border:1px dashed var(--line);border-radius:20px;padding:clamp(20px,3vw,34px);background:linear-gradient(180deg,#fff,#f9fbfe);display:grid;gap:12px;justify-items:center;text-align:center}.chat-empty-eyebrow{margin:0;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-soft);font-weight:700}.chat-empty-hero h3{margin:0;font-size:clamp(22px,2.6vw,30px);line-height:1.2;color:var(--ink)}.chat-empty-hero p{margin:0;color:var(--muted);font-size:14px;max-width:58ch}.chat-empty-composer{width:min(860px,100%);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}.chat-empty-error{margin-top:6px}.chat-empty{margin:16px;border:1px dashed var(--line);border-radius:16px;padding:20px;color:var(--muted);text-align:center;background:#f8fafc}.chat-empty p{margin:0}.chat-quick-prompts{margin-top:14px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.chat-prompt-btn{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:var(--muted);padding:6px 12px;font-size:12px;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.chat-prompt-btn:hover{border-color:#5b78e83d;background:#5b78e80f;color:var(--accent-strong)}.chat-message-list{min-height:0;overflow:auto;padding:16px;display:grid;align-content:start;gap:10px;background:linear-gradient(180deg,#fff,#f8fafc)}.chat-msg-row{display:flex}.chat-msg-row.is-user{justify-content:flex-end}.chat-msg-row.is-assistant{justify-content:flex-start}.chat-msg-bubble{max-width:min(78ch,86%);border-radius:14px;padding:10px 12px;line-height:1.6;font-size:14px;white-space:pre-wrap;word-break:break-word}.chat-msg-content{margin:0}.chat-msg-status-list{margin:0 0 6px;display:grid;gap:2px}.chat-msg-status{margin:0;font-size:12px}.chat-msg-row.is-user .chat-msg-bubble{background:var(--accent);color:#fff}.chat-msg-row.is-assistant .chat-msg-bubble{background:#edf1f6;color:#3d4652}.chat-msg-row.is-assistant .chat-msg-status{color:var(--muted-soft)}.chat-load-tip{margin:0;font-size:12px;color:#64748b;text-align:center}.chat-composer{border-top:1px solid var(--line);padding:12px 14px 14px;display:grid;gap:10px;background:#fff}.chat-composer.is-focused{box-shadow:inset 0 0 0 1px #5b78e838}.chat-label{color:var(--muted);font-size:13px;font-weight:600}.chat-textarea{width:100%;min-height:92px;resize:none;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:14px;color:var(--ink);line-height:1.5}.chat-textarea:focus-visible{border-color:#5b78e866;box-shadow:0 0 0 4px #5b78e814;outline:none}.chat-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.chat-shortcut-tip{margin:0;color:var(--muted-soft);font-size:12px}.chat-mobile-toggle{display:none}.modal-backdrop{position:fixed;inset:0;background:#11182759;display:flex;align-items:center;justify-content:center;padding:24px;z-index:100}.modal-card{width:min(720px,100%);background:var(--panel);border-radius:18px;border:1px solid var(--line);box-shadow:0 24px 48px #18274b1f;padding:24px;max-height:min(82vh,760px);overflow-y:auto}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-head h3{margin:0;font-size:22px}.icon-btn{width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer}.modal-form{display:grid;gap:16px}.modal-form .field input,.modal-form .field textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:14px;color:var(--ink)}.modal-form .field textarea{min-height:90px;resize:none}.modal-actions{margin-top:4px;display:flex;justify-content:flex-end;gap:12px}.modal-body{display:grid;gap:12px}.field-required{margin-left:4px;color:var(--warm);font-size:12px}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.login-shell{min-height:100vh;padding:24px 16px}.login{width:100%;max-width:400px;padding:32px 24px}.login h2{font-size:30px;margin-bottom:26px}.app-header{grid-template-columns:1fr;gap:12px}.app-nav{justify-self:start;overflow-x:auto}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.header-actions{flex-wrap:wrap}.cockpit-row{grid-template-columns:1fr}.trend-summary{justify-content:flex-start}.rank-card,.alert-card{height:auto;min-height:420px}.chat-shell{grid-template-columns:1fr;height:auto;min-height:0}.chat-mobile-toggle{display:inline-flex}.chat-sidebar{display:none}.chat-sidebar.is-open{display:flex;max-height:320px}.chat-main{min-height:65vh}.chat-empty-shell{min-height:0;padding:0;gap:12px}.chat-empty-hero,.chat-empty-composer{width:100%}.chat-empty-hero{padding:18px 14px}.chat-actions{justify-content:flex-end}.chat-shortcut-tip{width:100%;text-align:right}}@media(prefers-reduced-motion:reduce){.login-shell,.app-shell{animation:none}.btn,.switcher-btn,.nav-item,.metric-card,.chat-session-item{transition:none}}
