.ai-fab{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--ai-primary, var(--color-primary, #3b82f6)),var(--ai-secondary, #8b5cf6));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--ai-shadow, rgba(59, 130, 246, .4));z-index:9999;transition:box-shadow .3s ease;padding:0}.ai-fab:hover{box-shadow:0 6px 28px var(--ai-shadow, rgba(59, 130, 246, .6))}.ai-fab.open{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 20px #ef444466}.ai-fab:before{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid var(--ai-primary, var(--color-primary, #3b82f6));animation:ai-pulse 2s ease-out infinite;pointer-events:none}.ai-fab.open:before{display:none}@keyframes ai-pulse{0%{transform:scale(1);opacity:.6}to{transform:scale(1.6);opacity:0}}.ai-chat-window{position:fixed;bottom:6rem;right:2rem;width:380px;height:500px;display:flex;flex-direction:column;background:var(--ai-bg, rgba(15, 23, 42, .95));backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--ai-border, rgba(59, 130, 246, .2));border-radius:20px;box-shadow:0 8px 40px #00000080;z-index:9998;overflow:hidden}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;background:color-mix(in srgb,var(--ai-primary, #3b82f6) 8%,transparent);border-bottom:1px solid var(--ai-border, rgba(59, 130, 246, .15))}.ai-chat-header-left{display:flex;align-items:center;gap:.6rem}.ai-chat-header-icon{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--ai-primary, var(--color-primary, #3b82f6)),var(--ai-secondary, #8b5cf6));display:flex;align-items:center;justify-content:center;font-size:.9rem}.ai-chat-title{font-size:.95rem;font-weight:700;color:var(--ai-text, var(--color-text, #e2e8f0))}.ai-chat-subtitle{font-size:.7rem;color:var(--ai-text-dim, var(--color-text-dim, #94a3b8))}.ai-chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.8rem}.ai-chat-messages::-webkit-scrollbar{width:4px}.ai-chat-messages::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--ai-primary, #3b82f6) 30%,transparent);border-radius:2px}.ai-message-row{display:flex}.ai-message-row.user{justify-content:flex-end}.ai-message-row.model{justify-content:flex-start}.ai-message{max-width:85%;padding:.7rem 1rem;border-radius:16px;font-size:.88rem;line-height:1.6;word-break:break-word;white-space:pre-wrap}.ai-message.user{background:linear-gradient(135deg,var(--ai-primary, var(--color-primary, #3b82f6)),color-mix(in srgb,var(--ai-primary, #3b82f6) 80%,#000));color:#fff;border-bottom-right-radius:4px}.ai-message.model{background:var(--ai-bg-surface, rgba(255, 255, 255, .08));color:var(--ai-text, var(--color-text, #e2e8f0));border-bottom-left-radius:4px}.ai-message strong{color:#fff;font-weight:700}.ai-welcome{display:flex;justify-content:center;padding:.5rem 0}.ai-welcome-hints{display:flex;flex-direction:column;gap:.4rem}.ai-hint-chip{background:color-mix(in srgb,var(--ai-primary, #3b82f6) 10%,transparent);border:1px solid color-mix(in srgb,var(--ai-primary, #3b82f6) 20%,transparent);padding:.5rem .8rem;border-radius:20px;font-size:.78rem;color:var(--ai-primary, var(--color-primary, #3b82f6));cursor:pointer;transition:background .2s;text-align:left}.ai-hint-chip:hover{background:color-mix(in srgb,var(--ai-primary, #3b82f6) 20%,transparent)}.ai-typing{background:var(--ai-bg-surface, rgba(255, 255, 255, .05));border-radius:16px 16px 16px 4px;padding:.7rem 1rem;display:flex;align-items:center;gap:.5rem}.ai-typing-spinner{color:var(--ai-primary, var(--color-primary, #3b82f6));animation:ai-spin 1s linear infinite}@keyframes ai-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-typing-text{font-size:.75rem;color:var(--ai-text-dim, var(--color-text-dim, #94a3b8))}.ai-chat-input-area{padding:.8rem 1rem;border-top:1px solid var(--ai-border, rgba(59, 130, 246, .15));background:#0003}.ai-input-wrapper{position:relative}.ai-chat-input{width:100%;background:var(--ai-bg-surface, rgba(255, 255, 255, .05));border:1px solid var(--ai-border, rgba(255, 255, 255, .1));padding:.75rem 3rem .75rem 1rem;border-radius:12px;color:var(--ai-text, var(--color-text, #e2e8f0));font-size:.88rem;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.ai-chat-input:focus{border-color:color-mix(in srgb,var(--ai-primary, #3b82f6) 50%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--ai-primary, #3b82f6) 10%,transparent)}.ai-chat-input::placeholder{color:var(--ai-text-dim, rgba(255, 255, 255, .3))}.ai-send-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:8px;background:color-mix(in srgb,var(--ai-primary, #3b82f6) 15%,transparent);color:var(--ai-primary, var(--color-primary, #3b82f6));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s,color .2s}.ai-send-btn:hover{background:var(--ai-primary, var(--color-primary, #3b82f6));color:#fff}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:480px){.ai-chat-window{right:.5rem;left:.5rem;bottom:5rem;width:auto;height:420px}.ai-fab{bottom:1rem;right:1rem}}:root{--primary: #1e293b;--accent: #3b82f6;--accent-light: #60a5fa;--header-bg: #0f172a;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--color-dispatch: #1e40af;--color-track: #0891b2;--color-settle: #059669;--color-comply: #dc2626;--color-match: #7c3aed}[data-theme=dark]{--gray-50: #1f2937;--gray-100: #111827;--gray-200: #374151;--gray-300: #4b5563;--gray-500: #9ca3af;--gray-700: #d1d5db;--gray-900: #f9fafb;--shadow: 0 1px 3px rgba(0,0,0,.3)}[data-theme=dark] body{background:#0f172a;color:#f1f5f9}[data-theme=dark] .card,[data-theme=dark] .service-card{background:#1e293b}[data-theme=dark] .service-mini-chart{filter:brightness(.9)}[data-theme=dark] .service-list-body,[data-theme=dark] .status-card,[data-theme=dark] .status-card-header,[data-theme=dark] .announcement-card{background:#1e293b}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background:#1e293b;color:#f1f5f9;border-color:#374151}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,sans-serif;background:var(--gray-50);color:var(--gray-900);line-height:1.6}.app-portal{min-height:100vh;display:flex;flex-direction:column}.top-nav{background:var(--header-bg);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:56px;box-shadow:0 2px 8px #0003;flex-shrink:0;position:sticky;top:0;z-index:100}.top-nav-left{display:flex;align-items:center;gap:2rem}.top-nav-logo{font-size:1.1rem;font-weight:700;cursor:pointer;white-space:nowrap;color:#fff}.top-nav-links{display:flex;gap:.2rem}.top-nav-links a{color:#ffffffb3;text-decoration:none;padding:.4rem .8rem;border-radius:var(--radius);font-size:.85rem;transition:all .15s;white-space:nowrap}.top-nav-links a:hover{background:#ffffff1a;color:#fff}.top-nav-links a.active{background:var(--accent);color:#fff}.top-nav-right{display:flex;align-items:center;gap:1rem}.user-info{font-size:.85rem;color:#fffc}.user-role{margin-left:.5rem;font-size:.72rem;background:#ffffff26;padding:.1rem .4rem;border-radius:4px}.logout-link{color:#fff9;text-decoration:none;font-size:.8rem}.logout-link:hover{color:#fff}.main-content{flex:1;padding:2rem;max-width:1280px;margin:0 auto;width:100%}.page-title{font-size:1.4rem;margin-bottom:1.2rem;color:var(--gray-900)}.loading{text-align:center;padding:3rem;color:var(--gray-500)}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem;margin-bottom:1rem}.card-title{font-size:1rem;font-weight:600;margin-bottom:.8rem}.service-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.service-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);padding:1.2rem;border-left:4px solid #94a3b8;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.service-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000026}.service-card-enhanced{padding:1.4rem}.service-card-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}.service-icon{font-size:2rem}.service-name{font-size:1rem;font-weight:600;margin:0}.status-dot{font-size:.72rem;padding:.1rem .5rem;border-radius:10px;font-weight:500}.status-dot.online{background:#d1fae5;color:#065f46}.status-dot.offline{background:#fee2e2;color:#991b1b}.service-kpis{display:flex;gap:1rem;margin-bottom:1rem;flex:1}.service-kpis-enhanced{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1rem;flex:1}.service-kpi-numbers{display:flex;gap:1rem}.service-mini-chart{display:flex;align-items:center;justify-content:center;padding:.2rem 0}.service-kpi{text-align:center;flex:1}.service-kpi-value{font-size:1.4rem;font-weight:700;color:var(--gray-900)}.service-kpi-value-enhanced{font-size:1.6rem;font-weight:800;line-height:1.2}.service-kpi-label{font-size:.72rem;color:var(--gray-500)}.service-no-data{color:var(--gray-500);font-size:.85rem;padding:.5rem 0}.service-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.service-list-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}.service-list-header{padding:1.2rem;color:#fff;display:flex;align-items:center;gap:.8rem}.service-list-icon{font-size:2rem}.service-list-header h3{flex:1;font-size:1.1rem}.service-list-body{padding:1.2rem}.service-list-body p{font-size:.88rem;color:var(--gray-700);margin-bottom:.8rem;line-height:1.6}.service-list-url{font-size:.78rem;color:var(--gray-500);word-break:break-all}.health-badge{font-size:.72rem;padding:.15rem .5rem;border-radius:10px;font-weight:600}.health-online{background:#ffffff40;color:#fff}.health-degraded{background:#fef3c7;color:#92400e}.health-offline{background:#ffffff26;color:#fffc}.announcement-banner{padding:.6rem 1rem;border-radius:var(--radius);margin-bottom:.8rem;font-size:.88rem;display:flex;align-items:center;gap:.6rem}.announcement-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.announcement-critical{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.announcement-badge{font-size:.72rem;font-weight:600;padding:.1rem .4rem;border-radius:4px;background:#0000001a}.announcement-item{display:flex;align-items:center;gap:.8rem;padding:.6rem 0;border-bottom:1px solid var(--gray-200);font-size:.88rem}.announcement-item:last-child{border-bottom:none}.announcement-title{flex:1}.announcement-date{color:var(--gray-500);font-size:.78rem;white-space:nowrap}.priority-badge{font-size:.72rem;font-weight:600;padding:.1rem .4rem;border-radius:4px;white-space:nowrap}.priority-info{background:#dbeafe;color:#1e40af}.priority-warning{background:#fef3c7;color:#92400e}.priority-critical{background:#fee2e2;color:#991b1b}.announcement-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem;margin-bottom:1rem}.announcement-card.inactive{opacity:.6}.announcement-card-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem}.announcement-card-date{color:var(--gray-500);font-size:.78rem;margin-left:auto}.badge-inactive{background:var(--gray-200);color:var(--gray-700);font-size:.68rem;padding:.1rem .4rem;border-radius:4px}.announcement-card-title{font-size:1rem;font-weight:600;margin-bottom:.5rem}.announcement-card-body{font-size:.88rem;color:var(--gray-700);line-height:1.6;margin-bottom:.8rem}.announcement-card-actions{display:flex;gap:.5rem}.overall-status{padding:1rem 1.5rem;border-radius:var(--radius);margin-bottom:1.5rem;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.8rem}.overall-status.status-ok{background:#d1fae5;color:#065f46}.overall-status.status-degraded{background:#fef3c7;color:#92400e}.overall-icon{font-size:1.3rem}.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.2rem}.status-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.status-card-header{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;border-left:4px solid #94a3b8;background:var(--gray-50)}.status-card-header h3{flex:1;font-size:.95rem}.smoke-test-checks{padding:.5rem 1rem}.check-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;border-bottom:1px solid var(--gray-100)}.check-item:last-child{border-bottom:none}.check-icon{width:1.2rem;text-align:center;font-weight:700}.check-ok .check-icon{color:var(--success)}.check-warn .check-icon{color:var(--warning)}.check-error .check-icon{color:var(--danger)}.check-name{font-weight:500;min-width:80px}.check-detail{color:var(--gray-500);font-size:.78rem;flex:1;text-align:right}.smoke-test-unavailable{padding:1rem;color:var(--gray-500);font-size:.85rem;text-align:center}.btn{display:inline-block;padding:.5rem 1rem;border-radius:var(--radius);border:none;font-size:.85rem;font-weight:500;cursor:pointer;text-decoration:none;transition:opacity .15s;text-align:center;color:#fff}.btn:hover{opacity:.85}.btn-primary{background:var(--accent)}.btn-success{background:var(--success)}.btn-warning{background:var(--warning)}.btn-danger{background:var(--danger)}.btn-sm{padding:.3rem .6rem;font-size:.78rem}.btn-open{display:block;text-align:center;padding:.5rem;border-radius:var(--radius);font-size:.85rem;font-weight:500;color:#fff;text-decoration:none;transition:opacity .15s}.btn-open:hover{opacity:.85}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--gray-700);margin-bottom:.3rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem .7rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #3b82f626}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#1e40af)}.login-card{background:#fff;border-radius:12px;padding:2.5rem;width:380px;box-shadow:0 8px 32px #0003}.login-icon{text-align:center;font-size:3rem;margin-bottom:.5rem}.login-card h1{text-align:center;margin-bottom:.3rem;color:var(--primary)}.login-card p{text-align:center;color:var(--gray-500);font-size:.85rem;margin-bottom:1.5rem}.login-error{background:#fee2e2;color:#991b1b;padding:.5rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:1rem;text-align:center}@media(max-width:768px){.top-nav{flex-direction:column;height:auto;padding:.5rem 1rem;gap:.3rem}.top-nav-left{flex-direction:column;gap:.3rem;width:100%}.top-nav-links{width:100%;overflow-x:auto;flex-wrap:nowrap}.top-nav-links a{font-size:.78rem;padding:.3rem .5rem}.top-nav-right{width:100%;justify-content:flex-end;padding:.2rem 0;font-size:.78rem}.main-content{padding:1rem}.service-card-grid,.service-list-grid,.status-grid{grid-template-columns:1fr}}@media print{.sidebar,.bottom-nav,.top-header,.btn,.notification-bell,.ai-fab,.ai-chat-window,nav,button{display:none!important}.app{display:block!important}.main{padding:0!important;max-width:100%!important;margin:0!important}body{background:#fff!important;color:#000!important;font-size:12pt}.card{box-shadow:none!important;border:1px solid #ddd;break-inside:avoid}table{font-size:10pt}th{background:#f0f0f0!important}.badge{border:1px solid #999}.kpi{border:1px solid #ddd}@page{margin:15mm}}
