:root{--bg: #000000;--surface: #0a0a0a;--surface2: #111111;--surface3: #1a1a1a;--border: #222222;--border-accent: #ff0000;--red: #ff0000;--red-dark: #cc0000;--red-glow: rgba(255, 0, 0, .15);--red-glow2: rgba(255, 0, 0, .08);--text: #ffffff;--text2: #aaaaaa;--text3: #666666;--green: #00d4aa;--yellow: #ffaa00;--blue: #4488ff;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .6);--shadow-red: 0 0 20px rgba(255, 0, 0, .2)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--red);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-red{color:var(--red)}.text-muted{color:var(--text2)}.w-full{width:100%}.relative{position:relative}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:none;transition:all .2s}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark);box-shadow:var(--shadow-red)}.btn-primary:disabled{background:#400;color:#888;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface3);color:var(--text);border-color:#444}.card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:600;color:var(--text)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-active{background:#00d4aa26;color:#00d4aa}.badge-paused{background:#ffaa0026;color:#fa0}.badge-archived{background:#64646433;color:#888}.badge-deleted{background:#ff000026;color:var(--red)}.badge-draft{background:#4488ff26;color:#48f}.page{min-height:100vh;background:var(--bg)}.container{max-width:1400px;margin:0 auto;padding:0 24px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid #1a1a1a;color:var(--text);font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface3)}tr.clickable{cursor:pointer}tr.clickable:hover td{background:#ff00000d}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.section{margin-bottom:28px}.section-title{font-size:17px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}.section-title .dot{width:4px;height:18px;background:var(--red);border-radius:2px;display:inline-block}.input{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s;width:100%}.input:focus{border-color:var(--red)}.input::placeholder{color:var(--text3)}.select{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 36px 10px 14px;color:var(--text);font-size:14px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .2s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.select:focus{border-color:var(--red)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:100%;max-width:480px;box-shadow:var(--shadow)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:var(--surface3);border-radius:6px;animation:pulse 1.5s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.chatbot-fab{position:fixed;bottom:28px;right:28px;width:54px;height:54px;border-radius:50%;background:var(--red);border:none;color:#fff;display:flex;align-items:center;justify-content:center;z-index:50;box-shadow:0 4px 20px #f006;transition:transform .2s,box-shadow .2s}.chatbot-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #f009}.chatbot-panel{position:fixed;bottom:96px;right:28px;width:440px;height:580px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);z-index:50;display:flex;flex-direction:column;box-shadow:0 8px 40px #000c;overflow:hidden;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chatbot-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface3);flex-shrink:0}.chatbot-messages{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:10px}.chat-msg{max-width:92%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.65;word-break:break-word}.chat-msg.user{background:var(--red);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.chat-msg.assistant{background:var(--surface3);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid var(--border);max-width:97%;width:fit-content}.chat-msg.assistant p{margin:0 0 8px}.chat-msg.assistant p:last-child{margin-bottom:0}.chat-msg.assistant .cm-heading{font-weight:700;color:var(--text);font-size:13px;margin:10px 0 5px;padding-bottom:4px;border-bottom:1px solid var(--border)}.chat-msg.assistant .cm-heading:first-child{margin-top:0}.chat-msg.assistant strong{color:#fff;font-weight:700}.chat-msg.assistant em{color:var(--text2);font-style:italic}.chat-msg.assistant code{background:#ffffff14;border-radius:4px;padding:1px 5px;font-family:monospace;font-size:12px;color:#f99}.chat-msg.assistant ul,.chat-msg.assistant ol{margin:6px 0;padding-inline-start:18px}.chat-msg.assistant[dir=rtl] ul,.chat-msg.assistant[dir=rtl] ol{padding-inline-start:0;padding-inline-end:18px}.chat-msg.assistant li{margin-bottom:4px;color:var(--text2);line-height:1.6}.chat-msg.assistant li strong{color:var(--text)}.chat-msg.assistant ul li::marker{color:var(--red)}.chat-msg.assistant ol li::marker{color:var(--red);font-weight:700}.chat-thinking{display:flex;align-items:center;gap:5px;padding:12px 16px;max-width:80px}.chat-thinking span{width:7px;height:7px;background:var(--text3);border-radius:50%;display:inline-block;animation:bounce 1.2s infinite}.chat-thinking span:nth-child(2){animation-delay:.2s}.chat-thinking span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-5px);opacity:1}}.chatbot-input-row{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}.chatbot-input-row .input{flex:1;padding:8px 12px;font-size:13px}@media (max-width: 768px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.chatbot-panel{width:calc(100vw - 40px);right:20px}}@media (max-width: 480px){.metrics-grid{grid-template-columns:1fr}}.analysis-prose{font-size:13.5px;line-height:1.7;color:var(--text2)}.analysis-prose h3{font-size:14px;font-weight:700;color:var(--text);margin:14px 0 6px}.analysis-prose ul{list-style:none;padding:0}.analysis-prose ul li{padding:4px 0 4px 16px;position:relative}.analysis-prose ul li:before{content:"▸";color:var(--red);position:absolute;left:0;font-size:10px;top:6px}.analysis-prose strong{color:var(--text);font-weight:600}.rate-notice{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ffaa001a;border:1px solid rgba(255,170,0,.3);border-radius:var(--radius-sm);font-size:12px;color:var(--yellow)}.error-box{display:flex;align-items:flex-start;gap:10px;padding:14px;background:#ff000014;border:1px solid rgba(255,0,0,.25);border-radius:var(--radius-sm);color:#f66;font-size:13px}.metric-row{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);-webkit-user-select:none;user-select:none}.metric-row:hover{border-color:#2e4536}.seg-tab{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;transition:all .15s}.seg-tab:hover{border-color:var(--red)!important;color:var(--red)!important}.token-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.token-dot.valid{background:var(--green);box-shadow:0 0 6px #00d4aa80}.token-dot.invalid{background:var(--red);box-shadow:0 0 6px #ff000080}
