.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);position:relative;overflow:hidden}.auth-bg-decoration{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.auth-bg-glow{position:absolute;border-radius:50%;filter:blur(120px)}.auth-bg-glow-1{width:600px;height:600px;background:#1a6b3c1f;top:-200px;left:-100px}.auth-bg-glow-2{width:500px;height:500px;background:#8b5cf614;bottom:-200px;right:-100px}.auth-bg-glow-3{width:300px;height:300px;background:#d4a8530f;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-container{width:100%;max-width:440px;position:relative;z-index:1}.onboarding-container{max-width:560px}.auth-header{text-align:center;margin-bottom:var(--space-8);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.auth-subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.auth-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-form-title{font-size:var(--text-xl);font-weight:700;text-align:center;margin-bottom:var(--space-2)}.auth-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.auth-input-wrapper{position:relative;display:flex;align-items:center}.auth-input-wrapper input{padding-left:44px;padding-right:44px}.auth-input-icon{position:absolute;left:14px;color:var(--text-tertiary);pointer-events:none;z-index:1}.auth-password-toggle{position:absolute;right:6px;padding:var(--space-2);color:var(--text-tertiary);border-radius:var(--radius-sm);transition:color var(--duration-fast)}.auth-password-toggle:hover{color:var(--text-primary)}.auth-forgot{text-align:right;margin-top:calc(var(--space-2) * -1)}.auth-forgot a{font-size:var(--text-sm);color:var(--text-secondary)}.auth-forgot a:hover{color:var(--gold)}.auth-submit{width:100%;margin-top:var(--space-2)}.auth-spinner{width:20px;height:20px;border:2px solid rgba(0,0,0,.2);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.auth-divider{display:flex;align-items:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-google-btn{background:var(--bg-tertiary)}.auth-terms{display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.auth-terms input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold);margin-top:1px;flex-shrink:0}.auth-terms a{color:var(--gold)}.auth-demo-section{margin-top:var(--space-6);text-align:center}.auth-demo-label{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-3)}.auth-demo-buttons{display:flex;gap:var(--space-3);justify-content:center}.auth-demo-btn{font-size:var(--text-sm);padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.auth-demo-btn:hover{border-color:var(--border-gold);background:var(--bg-active)}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer a{color:var(--gold);font-weight:500}.onboarding-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:var(--space-8)}.onboarding-step-dot{width:12px;height:12px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border-light);transition:all var(--duration-normal)}.onboarding-step-dot.active{background:var(--gold);border-color:var(--gold);box-shadow:0 0 10px #d4a85366}.onboarding-step-line{width:60px;height:2px;background:var(--border);transition:background var(--duration-normal)}.onboarding-step-line.active{background:var(--gold)}.onboarding-step{text-align:center}.onboarding-title{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-2)}.onboarding-desc{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-8)}.onboarding-cards{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-8)}.onboarding-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.onboarding-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);text-align:left;position:relative}.onboarding-card:hover{border-color:var(--border-light);background:var(--bg-hover);transform:translateY(-2px)}.onboarding-card.selected{border-color:var(--gold);background:var(--bg-active);box-shadow:var(--shadow-glow-gold)}.onboarding-card-icon{color:var(--gold);flex-shrink:0}.onboarding-card-content h3{font-size:var(--text-base);font-weight:600;margin-bottom:2px}.onboarding-card-content p{font-size:var(--text-sm);color:var(--text-secondary)}.onboarding-card-compact{flex-direction:column;text-align:center;padding:var(--space-5) var(--space-4)}.onboarding-card-emoji{font-size:2rem;margin-bottom:var(--space-1)}.onboarding-card-compact h3{font-size:var(--text-base);font-weight:600;margin-bottom:2px}.onboarding-card-compact p{font-size:var(--text-xs);color:var(--text-secondary)}.onboarding-card-check{position:absolute;top:var(--space-3);right:var(--space-3);width:24px;height:24px;border-radius:50%;background:var(--gold);color:#0a0c10;display:flex;align-items:center;justify-content:center;animation:fadeInScale var(--duration-fast) var(--ease-out)}.onboarding-actions{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-4)}@media(max-width:480px){.auth-page{padding:var(--space-4)}.auth-form{padding:var(--space-5)}.onboarding-cards-grid{grid-template-columns:1fr}.auth-demo-buttons{flex-direction:column}}.chat-layout{display:flex;height:100vh;overflow:hidden}.chat-sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.chat-sidebar-header{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border)}.chat-new-conv-btn{margin:var(--space-4) var(--space-4) 0;width:calc(100% - var(--space-8))}.chat-conv-list{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-3)}.chat-conv-group{margin-bottom:var(--space-4)}.chat-conv-group-label{display:block;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.chat-conv-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out);position:relative}.chat-conv-item:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-conv-item.active{background:var(--bg-active);color:var(--gold);border:1px solid rgba(212,168,83,.15)}.chat-conv-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.chat-conv-delete{opacity:0;padding:var(--space-1);border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all var(--duration-fast)}.chat-conv-item:hover .chat-conv-delete{opacity:1}.chat-conv-delete:hover{color:var(--danger);background:var(--danger-bg)}.chat-sidebar-shortcuts{padding:var(--space-3);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-1)}.chat-shortcut-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--duration-fast)}.chat-shortcut-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.chat-user-info{display:flex;align-items:center;gap:var(--space-3);min-width:0}.chat-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--felt-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.chat-user-details{display:flex;flex-direction:column;min-width:0}.chat-user-name{font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.chat-user-actions{display:flex;gap:var(--space-1)}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.chat-main-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border);background:var(--bg-secondary)}.chat-main-title{font-size:var(--text-lg);font-weight:600}.chat-main-actions{display:flex;gap:var(--space-2)}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-6)}.chat-messages-inner{max-width:var(--chat-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--space-5)}.chat-msg{display:flex;gap:var(--space-3);max-width:85%}.chat-msg-user{align-self:flex-end;flex-direction:row-reverse}.chat-msg-assistant{align-self:flex-start}.chat-msg-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.chat-msg-avatar.assistant{background:linear-gradient(135deg,var(--felt-dark),var(--felt-green));box-shadow:0 0 12px #1a6b3c4d}.chat-msg-avatar.user{background:var(--gold-gradient);color:#0a0c10;font-weight:600;font-size:var(--text-sm)}.chat-msg-bubble{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);position:relative}.chat-msg-bubble.user{background:linear-gradient(135deg,#d4a85326,#d4a85314);border:1px solid rgba(212,168,83,.2);border-top-right-radius:4px}.chat-msg-bubble.assistant{background:var(--bg-card);border:1px solid var(--border);border-top-left-radius:4px}.chat-msg-text{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-primary)}.chat-msg-time{display:block;font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-2)}.chat-typing-dots{display:flex;gap:4px;padding:var(--space-2) 0}.typing-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:typingDot 1.4s infinite ease-in-out both}.typing-dot:nth-child(1){animation-delay:0ms}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.response-sections{margin-top:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.response-section{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.response-summary{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#1a6b3c14;border-color:#1a6b3c26}.response-section-icon{font-size:1rem;flex-shrink:0;margin-top:2px}.response-section-content{flex:1}.response-section-label{display:block;font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.response-section-content p,.response-section-body p{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary)}.response-section-header{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);transition:background var(--duration-fast)}.response-section-header:hover{background:var(--bg-hover)}.response-section-header .response-section-label{flex:1;text-align:left;margin-bottom:0}.response-section-body{padding:0 var(--space-4) var(--space-4) calc(var(--space-4) + 1rem + var(--space-3));display:flex;flex-direction:column;gap:var(--space-2)}.response-reference-card{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary)}.response-reference-card strong{color:var(--text-primary);display:block;font-size:var(--text-sm)}.response-ref-source{font-size:var(--text-xs);color:var(--text-tertiary)}.response-action-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.response-action-item svg{color:var(--gold);flex-shrink:0}.chat-templates{padding:0 var(--space-6) var(--space-4)}.chat-templates-label{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-3);text-align:center}.chat-templates-list{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center;max-width:var(--chat-max-width);margin:0 auto}.chat-template-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out)}.chat-template-chip:hover{border-color:var(--border-gold);color:var(--gold);background:var(--bg-active);transform:translateY(-1px)}.chat-input-area{padding:var(--space-4) var(--space-6) var(--space-5);border-top:1px solid var(--border);background:var(--bg-secondary)}.chat-input-wrapper{max-width:var(--chat-max-width);margin:0 auto;display:flex;align-items:flex-end;gap:var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2);transition:border-color var(--duration-fast)}.chat-input-wrapper:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px #d4a8531a}.chat-input{flex:1;border:none;background:none;padding:var(--space-2) var(--space-3);resize:none;min-height:24px;max-height:120px;font-size:var(--text-base);line-height:var(--leading-normal)}.chat-input:focus{box-shadow:none;border:none}.chat-input-attach,.chat-input-send{padding:var(--space-2);border-radius:var(--radius-md);transition:all var(--duration-fast);flex-shrink:0}.chat-input-attach{color:var(--text-tertiary)}.chat-input-attach:hover{color:var(--text-primary);background:var(--bg-hover)}.chat-input-send{background:var(--gold-gradient);color:#0a0c10;padding:var(--space-2) var(--space-3)}.chat-input-send:hover:not(:disabled){box-shadow:0 0 15px #d4a8534d}.chat-input-send:disabled{opacity:.4;cursor:not-allowed}.chat-input-hint{display:flex;align-items:center;gap:var(--space-1);justify-content:center;font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-2)}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-secondary)}.chat-empty-icon{font-size:4rem;opacity:.5}.chat-empty h2{font-size:var(--text-2xl);color:var(--text-primary)}.chat-context-panel{width:var(--context-panel-width);background:var(--bg-sidebar);border-left:1px solid var(--border);overflow-y:auto;padding:var(--space-5);flex-shrink:0}.context-section{margin-bottom:var(--space-2)}.context-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-3)}.context-profile-info{display:flex;flex-direction:column;gap:var(--space-2)}.context-info-row{display:flex;align-items:center;justify-content:space-between}.context-info-label{font-size:var(--text-sm);color:var(--text-tertiary)}.context-mode-buttons{display:flex;gap:var(--space-1);background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px}.context-mode-btn{flex:1;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);transition:all var(--duration-fast)}.context-mode-btn.active{background:var(--gold);color:#0a0c10;font-weight:600;box-shadow:var(--shadow-sm)}.context-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary)}.toggle-switch{width:44px;height:24px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-full);position:relative;cursor:pointer;transition:all var(--duration-fast);flex-shrink:0}.toggle-switch.active{background:var(--felt-green);border-color:var(--felt-light)}.toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-sm)}.toggle-switch.active .toggle-thumb{transform:translate(20px)}.context-toggle-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-2)}.context-spots-list{display:flex;flex-direction:column;gap:var(--space-2)}.context-spot-item{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:var(--text-sm)}.context-spot-item svg{color:var(--gold);flex-shrink:0;margin-top:2px}.context-spot-title{color:var(--text-primary);display:block;font-weight:500}.context-spot-date{color:var(--text-tertiary);font-size:var(--text-xs)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4)}.hand-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.hand-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border)}.hand-modal-header h3{font-size:var(--text-lg);font-weight:600}.hand-modal-body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.hand-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.hand-positions{display:flex;gap:var(--space-2);flex-wrap:wrap}.hand-pos-chip{padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-fast)}.hand-pos-chip:hover{border-color:var(--gold);color:var(--gold);background:var(--bg-active)}.hand-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border)}@media(max-width:1200px){.chat-context-panel{display:none}}@media(max-width:768px){.chat-sidebar{display:none}.chat-messages{padding:var(--space-4)}.chat-input-area{padding:var(--space-3) var(--space-4)}.chat-msg{max-width:95%}}.admin-layout{display:flex;height:100vh;overflow:hidden}.admin-sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.admin-sidebar-header{padding:var(--space-5);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.admin-nav{flex:1;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-fast) var(--ease-out);text-decoration:none}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{background:var(--bg-active);color:var(--gold);border:1px solid rgba(212,168,83,.15)}.admin-nav-item.active svg{color:var(--gold)}.admin-sidebar-divider{height:1px;background:var(--border);margin:var(--space-2) var(--space-3)}.admin-chat-link{margin:0 var(--space-3)}.admin-chat-link:hover{color:var(--felt-light)!important}.admin-sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.admin-main{flex:1;overflow-y:auto;background:var(--bg-primary)}.admin-page{padding:var(--space-8);max-width:1200px;animation:fadeIn var(--duration-normal) var(--ease-out)}.admin-page-header{margin-bottom:var(--space-8)}.admin-page-header h1{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-2)}.admin-page-header p{color:var(--text-secondary);font-size:var(--text-sm)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--duration-normal) var(--ease-out)}.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-icon.gold{background:#d4a8531f;color:var(--gold)}.stat-card-icon.green{background:#22c55e1f;color:var(--success)}.stat-card-icon.purple{background:#8b5cf61f;color:var(--purple)}.stat-card-icon.blue{background:#3b82f61f;color:var(--info)}.stat-card-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:var(--space-1)}.stat-card-label{font-size:var(--text-sm);color:var(--text-secondary)}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.data-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-hover)}.upload-area{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:var(--space-10);text-align:center;color:var(--text-secondary);transition:all var(--duration-normal);cursor:pointer;margin-bottom:var(--space-6)}.upload-area:hover{border-color:var(--gold);background:var(--bg-active)}.upload-area.upload-area-dragging{border-color:var(--gold);background:#d4a85314;box-shadow:0 0 20px #d4a85326;transform:scale(1.01)}.upload-area.upload-area-uploading{pointer-events:none;opacity:.7;border-color:var(--gold)}.upload-area-icon{margin-bottom:var(--space-3);color:var(--text-tertiary)}.upload-area p{font-size:var(--text-sm);margin-bottom:var(--space-1)}.upload-area span{font-size:var(--text-xs);color:var(--text-tertiary)}.config-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.config-section-title{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-5);display:flex;align-items:center;gap:var(--space-2)}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.config-full-width{grid-column:1 / -1}.slider-wrapper{display:flex;align-items:center;gap:var(--space-3)}.slider-wrapper input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--bg-tertiary);border-radius:3px;padding:0;border:none}.slider-wrapper input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 0 6px #d4a85366}.slider-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--gold);min-width:40px;text-align:right}.tag-chips{display:flex;flex-wrap:wrap;gap:var(--space-1)}.tag-chip{padding:2px var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary)}.table-actions{display:flex;gap:var(--space-1)}.tone-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.tone-card{padding:var(--space-5);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--duration-normal) var(--ease-out)}.tone-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.tone-card.selected{border-color:var(--gold);background:var(--bg-active);box-shadow:var(--shadow-glow-gold)}.tone-card-icon{font-size:2rem;margin-bottom:var(--space-2)}.tone-card h4{font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-1)}.tone-card p{font-size:var(--text-xs);color:var(--text-secondary)}.prompt-editor{font-family:var(--font-mono);font-size:var(--text-sm);min-height:200px;line-height:var(--leading-relaxed);background:var(--bg-tertiary);border:1px solid var(--border);resize:vertical}.prompt-editor:focus{border-color:var(--gold)}.rules-list{display:flex;flex-direction:column;gap:var(--space-2)}.rule-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.rule-item .rule-number{width:24px;height:24px;border-radius:50%;background:var(--gold);color:#0a0c10;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;flex-shrink:0}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.admin-toolbar-search{max-width:320px}.admin-toolbar-actions{display:flex;gap:var(--space-2)}.activity-feed{display:flex;flex-direction:column;gap:var(--space-1)}.activity-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--duration-fast)}.activity-item:hover{background:var(--bg-hover)}.activity-icon{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem}.activity-content{flex:1;min-width:0}.activity-content strong{color:var(--text-primary)}.activity-content p{font-size:var(--text-sm);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-time{font-size:var(--text-xs);color:var(--text-tertiary);flex-shrink:0}@media(max-width:768px){.admin-sidebar{display:none}.admin-page{padding:var(--space-4)}.stats-grid{grid-template-columns:1fr 1fr}.config-grid,.tone-cards{grid-template-columns:1fr}}:root{--bg-primary: #0a0c10;--bg-secondary: #12151c;--bg-tertiary: #1a1e28;--bg-sidebar: #0e1016;--bg-card: #161a24;--bg-hover: rgba(255, 255, 255, .04);--bg-active: rgba(212, 168, 83, .08);--felt-green: #1a6b3c;--felt-dark: #145530;--felt-light: #22884d;--felt-gradient: linear-gradient(135deg, #145530 0%, #1a6b3c 50%, #22884d 100%);--gold: #d4a853;--gold-light: #e8c06a;--gold-dark: #b8923f;--gold-gradient: linear-gradient(135deg, #b8923f 0%, #d4a853 50%, #e8c06a 100%);--gold-glow: 0 0 20px rgba(212, 168, 83, .3);--purple: #8b5cf6;--purple-light: #a78bfa;--purple-dark: #7c3aed;--success: #22c55e;--success-bg: rgba(34, 197, 94, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .1);--text-primary: #f0f0f2;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--text-gold: #d4a853;--text-link: #a78bfa;--border: rgba(255, 255, 255, .07);--border-light: rgba(255, 255, 255, .12);--border-gold: rgba(212, 168, 83, .3);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 50px rgba(0, 0, 0, .7);--shadow-glow-gold: 0 0 30px rgba(212, 168, 83, .15);--shadow-glow-green: 0 0 30px rgba(26, 107, 60, .2);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--sidebar-width: 280px;--sidebar-collapsed: 72px;--header-height: 64px;--chat-max-width: 800px;--context-panel-width: 320px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px);max-height:0}to{opacity:1;transform:translateY(0);max-height:500px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes chipBounce{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-12px) scale(1.05)}50%{transform:translateY(-6px) scale(1.02)}70%{transform:translateY(-3px) scale(1.01)}to{transform:translateY(0) scale(1)}}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}@keyframes glowPulse{0%,to{box-shadow:0 0 8px #d4a85333}50%{box-shadow:0 0 20px #d4a85366}}@keyframes cardFlip{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(0)}}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--ease-out) both}.animate-slide-up{animation:slideInUp var(--duration-slow) var(--ease-out) both}.animate-slide-left{animation:slideInLeft var(--duration-normal) var(--ease-out) both}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-shimmer{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.stagger-children>*{animation:fadeIn var(--duration-normal) var(--ease-out) both}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.stagger-children>*:nth-child(7){animation-delay:.3s}.stagger-children>*:nth-child(8){animation-delay:.35s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(ellipse at 30% 20%,rgba(26,107,60,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(139,92,246,.04) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}a{color:var(--text-link);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--gold-light)}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;color:inherit;font-size:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);outline:none;transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);width:100%}input:focus,textarea:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4a85326}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}img{max-width:100%;height:auto}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:var(--leading-tight);font-weight:600;color:var(--text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;line-height:1}.btn-primary{background:var(--gold-gradient);color:#0a0c10;font-weight:600;box-shadow:var(--shadow-sm),0 0 20px #d4a85326}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md),0 0 30px #d4a85340}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-gold)}.btn-ghost{color:var(--text-secondary);padding:var(--space-2) var(--space-3)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out)}.btn-icon:hover{color:var(--text-primary);background:var(--bg-hover)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;line-height:1.4}.badge-gold{background:#d4a85326;color:var(--gold-light);border:1px solid rgba(212,168,83,.2)}.badge-green{background:var(--success-bg);color:var(--success);border:1px solid rgba(34,197,94,.2)}.badge-red{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.badge-purple{background:#8b5cf626;color:var(--purple-light);border:1px solid rgba(139,92,246,.2)}.badge-blue{background:var(--info-bg);color:var(--info);border:1px solid rgba(59,130,246,.2)}.badge-yellow{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--duration-normal) var(--ease-out)}.card:hover{border-color:var(--border-light)}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-gold)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.form-hint{font-size:var(--text-xs);color:var(--text-tertiary)}.divider{height:1px;background:var(--border);border:none;margin:var(--space-4) 0}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot-online{background:var(--success);box-shadow:0 0 6px #22c55e66}.status-dot-offline{background:var(--text-tertiary)}.status-dot-error{background:var(--danger);box-shadow:0 0 6px #ef444466}.status-dot-processing{background:var(--warning);animation:pulse 1.5s infinite}
