@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css";:root,[data-theme=dark]{--primary: #20c997;--primary-dark: #17a87a;--secondary: #6c757d;--success: #28a745;--danger: #dc3545;--warning: #ffc107;--info: #17a2b8;--bg-primary: #0f0c29;--bg-secondary: #1a162e;--bg-tertiary: #24243e;--text: #ffffff;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .72);--text-muted-css: rgba(255, 255, 255, .72);--text-muted: rgba(255, 255, 255, .6);--border: rgba(255, 255, 255, .16);--border-light: rgba(255, 255, 255, .1);--card-bg: rgba(255, 255, 255, .05);--card-bg-hover: rgba(255, 255, 255, .08);--glass-bg: rgba(255, 255, 255, .05);--glass-bg-hover: rgba(255, 255, 255, .1);--glass-item-bg: rgba(255, 255, 255, .03);--glass-item-border: rgba(255, 255, 255, .1);--bg-gradient: linear-gradient(135deg, #0f0c29 0%, #302b63 50%, #24243e 100%);--overlay-bg: rgba(0, 0, 0, .6);--shadow: rgba(0, 0, 0, .3);--light: #f8f9fa;--dark: #343a40}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text: #212529;--text-primary: #212529;--text-secondary: #495057;--text-muted-css: #495057;--text-muted: #6c757d;--border: rgba(0, 0, 0, .2);--border-light: rgba(0, 0, 0, .1);--card-bg: #ffffff;--card-bg-hover: #f8f9fa;--glass-bg: rgba(255, 255, 255, .95);--glass-bg-hover: #ffffff;--glass-item-bg: rgba(0, 0, 0, .03);--glass-item-border: rgba(0, 0, 0, .1);--bg-gradient: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 50%, #dee2e6 100%);--overlay-bg: rgba(0, 0, 0, .4);--shadow: rgba(0, 0, 0, .15)}html,body{height:100%;overscroll-behavior:none}html{background:var(--bg-gradient)}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;background:var(--bg-gradient);color:var(--text);overflow-x:hidden;transition:background .3s ease,color .3s ease}#root{min-height:100vh}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(32,201,151,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(138,35,135,.1) 0%,transparent 50%);animation:backgroundPulse 15s ease-in-out infinite;pointer-events:none;z-index:0;transition:opacity .3s ease}[data-theme=light] body:before{background:radial-gradient(circle at 20% 50%,rgba(32,201,151,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(138,35,135,.05) 0%,transparent 50%);opacity:.5}@keyframes backgroundPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.pulse-animation{animation:pulse 2s ease-in-out infinite}.fade-in{animation:fadeIn .3s ease-in}.slide-in{animation:slideIn .3s ease-out}.main-container{position:relative;z-index:1;padding:0}.dashboard-container{display:flex;min-height:100vh}.main-content.sidebar-collapsed{margin-left:70px}.content{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:30px;min-height:calc(100vh - 140px);border:1px solid var(--border);transition:background .3s ease,border-color .3s ease}.rois-page,.acionaveis-page,.cameras-page,.eventos-page,.relatorios-page,.metricas-page,.overview-page,.notificacoes-page{min-height:calc(100vh - 40px)}@media(max-width:640px){.eventos-page .glass-card>.d-flex.justify-content-between.align-items-center{flex-direction:column;align-items:flex-start;gap:.75rem}.eventos-page .glass-card>.d-flex.justify-content-between.align-items-center .btn.btn-glass.btn-sm{align-self:stretch;text-align:center}}.rois-page .glass-card,.acionaveis-page .glass-card,.cameras-page .glass-card,.eventos-page .glass-card,.relatorios-page .glass-card,.metricas-page .glass-card,.notificacoes-page .glass-card{width:100%}.table-container{width:100%;overflow-x:auto}.acionaveis-page .glass-card{height:100%;display:flex;flex-direction:column;justify-content:space-between}.acionaveis-page .btn-primary-custom{margin-top:auto}.cameras-page .row.g-4{margin:0 -12px}.cameras-page .col{padding:0 12px}.sidebar{position:fixed;top:0;left:0;height:100vh;width:260px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border);padding:20px 0;transition:transform .3s cubic-bezier(.4,0,.2,1),width .3s ease,background .3s ease,border-color .3s ease;z-index:1000;overflow-y:auto;overflow-x:hidden}.sidebar.collapsed{width:70px}.sidebar.mobile{transform:translate(-100%);width:280px;max-width:85vw}.sidebar.mobile.mobile-open{transform:translate(0)}.sidebar-header{padding:0 20px 20px;border-bottom:1px solid var(--border);margin-bottom:20px;display:flex;align-items:center;gap:10px}.sidebar-header i{font-size:32px;color:var(--primary)}.sidebar-header h2,.sidebar-header h4{font-size:24px;font-weight:700;margin:0;transition:opacity .3s}.sidebar.collapsed .sidebar-header h4 span{display:none}.sidebar-menu{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.sidebar-menu li{margin-bottom:5px}.sidebar-menu a{display:flex;align-items:center;gap:15px;padding:15px 20px;color:var(--text-secondary);text-decoration:none;transition:all .3s;border-left:3px solid transparent}.sidebar-menu a:hover{background:var(--glass-bg-hover);color:var(--text-primary);border-left-color:var(--primary)}.sidebar-menu a.active{background:#20c9971a;color:var(--primary);border-left-color:var(--primary)}.sidebar-menu a i{font-size:18px;min-width:30px}.sidebar-menu a span{transition:opacity .3s}.sidebar.collapsed .sidebar-menu a span{opacity:0;width:0}.header{display:flex;justify-content:space-between;align-items:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid var(--border);padding:20px 30px;margin-bottom:30px;transition:background .3s ease,border-color .3s ease;box-shadow:0 2px 8px var(--shadow)}[data-theme=light] .header{box-shadow:0 2px 12px #00000014,0 1px 3px #0000001a}.top-header{display:flex;justify-content:space-between;align-items:center;gap:20px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid var(--border);padding:20px 30px;margin-bottom:30px;transition:background .3s ease,border-color .3s ease;box-shadow:0 2px 8px var(--shadow)}[data-theme=light] .top-header{box-shadow:0 2px 12px #00000014,0 1px 3px #0000001a}.top-header h1,.top-header h2{font-size:28px;font-weight:700;margin:0;color:var(--text-primary);display:flex;align-items:center;gap:10px}.top-header .header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.header h1{font-size:28px;font-weight:700}.header-actions{display:flex;gap:15px;align-items:center}.user-menu{display:flex;align-items:center;gap:10px;padding:10px 15px;background:#ffffff0d;border-radius:12px;cursor:pointer;transition:all .3s}.user-menu:hover{background:#ffffff1a}.btn-logout{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#dc354533;border:1px solid rgba(220,53,69,.3);border-radius:8px;color:#ff6b6b;cursor:pointer;transition:all .3s}.btn-logout:hover{background:#dc35454d;transform:translateY(-2px)}.glass-card{position:relative;background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid var(--border);padding:25px;margin-bottom:20px;transition:all .3s ease,background .3s ease,border-color .3s ease;box-shadow:0 2px 8px var(--shadow);overflow:hidden}.glass-card:hover{transform:translateY(-5px);background:var(--card-bg-hover);box-shadow:0 10px 30px var(--shadow)}[data-theme=light] .glass-card{box-shadow:0 2px 12px #00000014,0 1px 3px #0000001a}[data-theme=light] .glass-card:hover{box-shadow:0 8px 24px #0000001f,0 4px 8px #0000001a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stats-card,.stat-card{background:var(--card-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:center;gap:20px;transition:all .3s,background .3s ease,border-color .3s ease;box-shadow:0 2px 8px var(--shadow)}.stats-card:hover,.stat-card:hover{transform:translateY(-5px);background:var(--card-bg-hover);box-shadow:0 8px 24px var(--shadow)}[data-theme=light] .stat-card,[data-theme=light] .stats-card{box-shadow:0 2px 12px #00000014,0 1px 3px #0000001a}[data-theme=light] .stat-card:hover,[data-theme=light] .stats-card:hover{box-shadow:0 8px 24px #0000001f,0 4px 8px #0000001a}.stat-card.text-center{flex-direction:column;text-align:center;gap:10px}.stat-card .icon,.stats-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:15px}.stat-card.text-center h3{font-size:36px;font-weight:700;margin:0}.stat-card.text-center p{color:var(--text-muted-css);margin:5px 0 0}.stats-content h6{font-size:14px;color:var(--text-muted-css);margin-bottom:8px}.stats-content h3{font-size:32px;font-weight:700}.bg-danger,.stat-icon.bg-danger{background:linear-gradient(135deg,#dc3545,#c82333)}.bg-warning,.stat-icon.bg-warning{background:linear-gradient(135deg,#ffc107,#e0a800)}.bg-info,.stat-icon.bg-info{background:linear-gradient(135deg,#17a2b8,#117a8b)}.bg-success,.stat-icon.bg-success{background:linear-gradient(135deg,#28a745,#218838)}.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff}.stat-info{flex:1}.stat-value{font-size:20px;font-weight:700;color:var(--text);line-height:1}.stat-label{font-size:11px;color:var(--text-muted-css);margin-top:4px}.metric-box{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff0d;border-radius:8px;padding:8px 12px;margin:4px;min-width:70px;transition:all .3s ease}.metric-box:hover{background:#ffffff1a;transform:scale(1.05)}.metric-box i{font-size:1.2rem;margin-bottom:4px}.metric-box .metric-value{font-size:1.1rem;font-weight:700;margin:0}.metric-box .metric-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin:0;transition:color .3s ease}.badge{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;display:inline-block;background:var(--primary-dark);color:#fff;border:1px solid var(--border);transition:border-color .3s ease}.badge-severity-baixa,.badge-severity-normal{background-color:#0dcaf026;color:#0dcaf0;border:1px solid rgba(13,202,240,.3)}.badge-severity-info{background-color:#20c99726;color:#20c997;border:1px solid rgba(32,201,151,.3)}.badge-severity-media,.badge-severity-medium,.badge-severity-alerta{background-color:#ffc10726;color:#ffc107;border:1px solid rgba(255,193,7,.3)}.badge-severity-alta,.badge-severity-high,.badge-severity-erro{background-color:#fd7e1426;color:#fd7e14;border:1px solid rgba(253,126,20,.3)}.badge-severity-critica,.badge-severity-critical,.badge-severity-perigo{background-color:#dc354526;color:#dc3545;border:1px solid rgba(220,53,69,.3)}.badge-status-pendente{background:#6c757d;color:#fff}.badge-status-em_analise{background:#0dcaf0;color:#000}.badge-status-resolvido{background:#20c997;color:#fff}.badge-status-falso_positivo{background:#6c757d;color:#fff}.badge-priority-critical{background:linear-gradient(135deg,red,#c00);color:#fff}.badge-priority-high{background:linear-gradient(135deg,#ff6b00,#f80);color:#fff}.badge-priority-medium{background:linear-gradient(135deg,#ffc107,#ffb300);color:#000}.badge-priority-low{background:linear-gradient(135deg,#20c997,#17a689);color:#fff}.btn{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s;font-size:14px;font-weight:500}.btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px var(--shadow)}[data-theme=light] .btn:hover{box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a}.btn-glass{background:var(--glass-bg);border:1px solid var(--border);color:var(--text-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease,background .3s ease,border-color .3s ease;box-shadow:0 1px 3px var(--shadow)}.btn-glass:hover{background:var(--glass-bg-hover);color:var(--text-primary);border-color:var(--primary);box-shadow:0 4px 12px var(--shadow)}[data-theme=light] .btn-glass{box-shadow:0 1px 4px #0000001a,0 1px 2px #0000000f}[data-theme=light] .btn-glass:hover{box-shadow:0 4px 16px #0000001f,0 2px 4px #00000014;background:var(--bg-secondary)}.btn-primary-custom,.btn-primary{background:linear-gradient(135deg,#20c997,#17a87a);border:none;color:var(--text)}.btn-primary-custom:hover,.btn-primary:hover{box-shadow:0 5px 20px #20c99766}.btn-success{background:var(--success);color:#fff}.btn-secondary{background:var(--secondary);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-warning{background:#f59e0b;color:#fff}.btn-info{background:var(--info);color:#fff}.form-control,.form-select,textarea.form-control{background-color:var(--card-bg)!important;border:1px solid var(--border)!important;color:var(--text-primary)!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:10px 15px;border-radius:8px;transition:all .3s ease,background-color .3s ease,border-color .3s ease;box-shadow:0 1px 3px var(--shadow)}[data-theme=light] .form-select{background-color:var(--bg-secondary)!important;box-shadow:0 1px 4px #00000014,0 1px 2px #0000000f}[data-theme=light] .form-select:focus{background-color:var(--card-bg)!important;box-shadow:0 0 0 .2rem #20c99740,0 2px 8px #0000001a}.form-control::placeholder{color:var(--text-muted)!important}.form-control:focus,.form-select:focus,textarea.form-control:focus{background-color:var(--card-bg-hover)!important;border-color:var(--primary)!important;color:var(--text-primary)!important;box-shadow:0 0 0 .2rem #20c99740!important;outline:none}.form-select option{background-color:var(--bg-secondary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.form-label{color:var(--text-primary);font-weight:500;margin-bottom:8px;display:block;transition:color .3s ease}.form-control:disabled,.form-select:disabled{background-color:#32324680!important;color:#ffffff80!important;cursor:not-allowed}[data-theme=light] .form-control:disabled,[data-theme=light] .form-select:disabled{background-color:#0000000d!important;color:#0006!important}.form-control[readonly]{background-color:#3232464d!important;cursor:default}.table-container{background:var(--card-bg);border-radius:12px;margin-top:20px;border:1px solid var(--border);transition:background .3s ease,border-color .3s ease;overflow-x:auto;-webkit-overflow-scrolling:touch}.table,.custom-table{width:100%;border-collapse:collapse;background:transparent;color:var(--text)}.table thead th,.custom-table thead th{padding:15px;text-align:left;border-bottom:2px solid var(--border);font-weight:600;background:var(--glass-bg);color:var(--text-primary);transition:background .3s ease,border-color .3s ease}.table tbody td,.custom-table tbody td{padding:15px;border-bottom:1px solid var(--border);color:var(--text-primary);transition:border-color .3s ease,color .3s ease}.table tbody tr:hover,.custom-table tbody tr:hover{background:#20c9971a;transition:background .3s ease}.table-dark{--bs-table-color: var(--text-primary);--bs-table-bg: var(--card-bg);--bs-table-striped-bg: rgba(32, 201, 151, .05);--bs-table-hover-bg: rgba(32, 201, 151, .1);background:var(--card-bg);color:var(--text-primary);transition:background .3s ease}.table-light{background:var(--card-bg);color:var(--text-primary);transition:background .3s ease}.table-light thead th{border-bottom:2px solid var(--border);font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px;background:var(--glass-bg);color:var(--text-primary)}.table-light tbody tr{border-bottom:1px solid var(--border);transition:all .3s,border-color .3s ease}.table-light tbody tr:hover{background:#4f46e51a;transform:translate(5px)}.table-dark thead th{background:var(--glass-bg);color:var(--text-primary);border-bottom:2px solid var(--border);font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.table-dark tbody tr{border-bottom:1px solid var(--border);transition:all .3s,border-color .3s ease}.table-dark tbody tr:hover{background:#20c9971a;transform:translate(5px)}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.eventos-list{display:grid;gap:20px}.evento-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all .3s,background .3s ease,border-color .3s ease}.evento-card:hover{transform:translate(5px);background:#20c9971a}.evento-header{display:flex;justify-content:space-between;margin-bottom:15px}.evento-tipo{background:var(--primary);padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600}.evento-data{color:var(--text-secondary);font-size:14px;transition:color .3s ease}.evento-image img{width:100%;max-width:400px;border-radius:8px;margin-top:15px}.cameras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.camera-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .3s,background .3s ease,border-color .3s ease}.camera-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow)}.camera-header{padding:15px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.camera-status{padding:4px 12px;border-radius:6px;font-size:12px}.camera-status.running{background:#28a74533;color:#28a745}.camera-preview{width:100%;height:200px;background:#000}.camera-preview img{width:100%;height:100%;object-fit:cover}.camera-info{padding:15px}.camera-type-card,.roi-type-card{background:var(--card-bg);border:2px solid var(--border);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease,background .3s ease,border-color .3s ease;height:100%;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 8px var(--shadow)}.camera-type-card:hover,.roi-type-card:hover{background:var(--card-bg-hover);border-color:var(--primary);transform:translateY(-3px);box-shadow:0 4px 16px var(--shadow)}.camera-type-card.selected,.roi-type-card.selected{background:#20c99726;border-color:var(--primary);border-width:3px;box-shadow:0 4px 16px #20c99733}[data-theme=light] .roi-type-card{background:var(--bg-secondary)!important;box-shadow:0 2px 12px #00000014,0 1px 3px #0000001a!important}[data-theme=light] .roi-type-card:hover{background:var(--card-bg)!important;box-shadow:0 4px 20px #0000001f,0 2px 6px #0000001a!important}[data-theme=light] .roi-type-card.selected{box-shadow:0 4px 20px #20c99740,0 2px 6px #20c99726!important}.camera-type-icon,.roi-type-icon{font-size:36px;margin-bottom:10px;color:var(--text-secondary);transition:all .3s ease,color .3s ease}.camera-type-card.selected .camera-type-icon,.roi-type-card.selected .roi-type-icon{color:var(--primary);transform:scale(1.1)}.camera-type-card h6,.roi-type-card h6{margin:10px 0 5px;font-weight:600;color:var(--text-primary);transition:color .3s ease}.camera-type-card p,.roi-type-card p{font-size:13px;color:var(--text-muted);margin:0;line-height:1.4;transition:color .3s ease}.camera-type-card.selected p,.roi-type-card.selected p{color:var(--text-secondary);transition:color .3s ease}.camera-view-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid var(--border);border-radius:16px;overflow:hidden}.camera-modal-header{background:#0000004d;padding:20px 30px;border-bottom:1px solid var(--border)}.camera-icon-badge{width:50px;height:50px;background:linear-gradient(135deg,#20c997,#17a87a);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}.camera-modal-header h4{color:var(--text);font-weight:600}.camera-modal-header small{color:var(--text-muted-css)}.camera-split-layout{display:flex;height:85vh;min-height:650px}.camera-preview-area{flex:1;background:#000;display:flex;flex-direction:column;position:relative;min-width:0}.camera-info-panel{width:320px;min-width:280px;max-width:380px;background:#0006;border-left:1px solid var(--border);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;padding:20px;transition:width .3s ease}.camera-stream-container{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#000;min-height:0}.camera-stream-img{width:100%;height:100%;object-fit:contain;display:none;transition:opacity .3s ease}.camera-stream-img.loaded{display:block}.camera-loading-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);z-index:10;transition:background .3s ease}.loading-content{text-align:center;color:var(--text-primary);transition:color .3s ease}.camera-loading-state.hidden{display:none}.stream-overlay-info{position:absolute;top:16px;left:16px;z-index:5}.camera-controls-bar{background:#000000e6;padding:12px 20px;border-top:1px solid var(--border)}.info-section{margin-bottom:20px}.info-section-title{color:var(--primary);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.info-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);margin:20px 0}.info-grid{display:grid;gap:16px}.info-item label{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:500;transition:color .3s ease}.info-value{color:var(--text);font-size:14px;font-weight:500;padding:8px 12px;background:#ffffff0d;border-radius:6px;border:1px solid var(--border)}.info-description{color:var(--text-secondary);font-size:13px;line-height:1.6;margin:0;padding:12px;background:var(--glass-bg);border-radius:8px;border-left:3px solid var(--primary);transition:color .3s ease,background .3s ease}.roi-canvas-container{background:#0000004d;border-radius:12px;padding:15px;border:1px solid var(--border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background .3s ease,border-color .3s ease}[data-theme=light] .roi-canvas-container{background:#0000000d!important;border:1px solid rgba(0,0,0,.15)!important;box-shadow:0 2px 8px #00000014!important}#roi-canvas-wrapper{max-width:100%;border-radius:8px;overflow:hidden}.roi-controls{margin-top:10px}#roi-points-list{max-height:100px;overflow-y:auto;padding:8px;background:#0003;border-radius:6px;font-size:12px;color:var(--text-muted-css)}#roi-points-list:empty:after{content:"Nenhum ponto adicionado ainda";color:var(--text-muted);font-style:italic}.modal-content{background:var(--card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:16px;color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}@media(max-width:640px){.modal-dialog{margin:1.5rem}.modal-content{max-height:calc(100vh - 3rem);overflow-y:auto}}[data-theme=light] .modal-content{background:var(--card-bg)!important;color:var(--text-primary)!important;box-shadow:0 8px 32px #0000001f,0 4px 16px #00000014!important}.modal-header{border-bottom:1px solid var(--border);padding:20px}[data-theme=light] .modal-header{border-bottom:1px solid var(--border)!important}.modal-title{color:var(--text-primary);font-weight:600;transition:color .3s ease}.modal-body{padding:20px}@media(max-width:640px){.modal-body{max-height:calc(100vh - 9rem);overflow-y:auto}}.modal-footer{border-top:1px solid var(--border);padding:20px}[data-theme=light] .modal-footer{border-top:1px solid var(--border)!important}.btn-close,.btn-close-white{filter:invert(1);opacity:.8}[data-theme=light] .btn-close,[data-theme=light] .btn-close-white{filter:invert(0)!important;opacity:.5}.btn-close:hover,.btn-close-white:hover{opacity:1}[data-theme=light] .btn-close:hover,[data-theme=light] .btn-close-white:hover{opacity:.75}[data-theme=light] .list-group-item{background-color:transparent!important;color:var(--text-primary)!important;border-color:var(--border)!important}.nav-tabs{border-bottom:1px solid var(--border)}.nav-tabs .nav-link{color:var(--text-secondary);border:none;border-bottom:2px solid transparent;padding:12px 20px;transition:all .3s,color .3s ease}.nav-tabs .nav-link:hover{color:var(--text-primary);border-bottom-color:var(--primary)}.nav-tabs .nav-link.active{color:var(--primary);background:#20c9971a;border-bottom-color:var(--primary)}.alert{padding:15px 20px;border-radius:12px;margin-bottom:20px;border:1px solid}.alert-info{background-color:#0dcaf01a;border-color:#0dcaf04d;color:#0dcaf0}.alert-success{background-color:#28a7451a;border-color:#28a7454d;color:#28a745}.alert-warning{background-color:#ffc1071a;border-color:#ffc1074d;color:#ffc107}.alert-danger{background-color:#dc35451a;border-color:#dc35454d;color:#dc3545}.chart-container{position:relative;height:300px;padding:20px 0}.screenshot-thumb{width:60px;height:40px;object-fit:cover;border-radius:4px;cursor:pointer;transition:transform .2s}.screenshot-thumb:hover{transform:scale(1.1)}.screenshot-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000}.screenshot-full{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 10px 30px var(--shadow)}.spinner-custom{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;display:inline-block;transition:border-color .3s ease}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);transition:color .3s ease}.empty-state i{font-size:64px;margin-bottom:20px;opacity:.3}.relatorios-page .table{color:var(--text-primary);background:var(--card-bg)}.relatorios-page .table.table-light{--bs-table-color: var(--text-primary);--bs-table-bg: var(--card-bg);--bs-table-striped-bg: rgba(79, 70, 229, .05);--bs-table-hover-bg: rgba(79, 70, 229, .1)}.relatorios-page .table.table-dark{--bs-table-color: var(--text-primary);--bs-table-bg: var(--card-bg);--bs-table-striped-bg: rgba(32, 201, 151, .05);--bs-table-hover-bg: rgba(32, 201, 151, .1)}.relatorios-page .table thead th{background:var(--glass-bg);color:var(--text-primary);border-color:var(--border)}.relatorios-page .table td,.relatorios-page .table th{color:var(--text-primary);border-color:var(--border)}.relatorios-page .table>:not(caption)>*>*{background-color:var(--bs-table-bg);color:var(--bs-table-color)}.relatorios-page .table.table-striped>tbody>tr:nth-of-type(odd)>*{background-color:var(--bs-table-striped-bg)}.relatorios-page .table.table-hover>tbody>tr:hover>*{background-color:var(--bs-table-hover-bg)}.relatorios-page .table tbody tr{background:transparent}.relatorios-page .table tbody tr:nth-child(2n){background:transparent}@media(max-width:992px){.camera-split-layout{flex-direction:column;height:auto}.camera-info-panel{width:100%;border-left:none;border-top:1px solid var(--border)}.camera-preview-area{min-height:400px}.sidebar.collapsed+.main-content{margin-left:70px}}@media(max-width:768px){.main-content{margin-left:0!important;width:100%!important;padding:15px}.main-content.sidebar-collapsed{margin-left:0!important;width:100%!important}.stats-grid,.cameras-grid{grid-template-columns:1fr}.header{flex-direction:row;gap:10px;padding:15px 20px}}@media(max-width:576px){.glass-card{padding:15px}.header h1{font-size:22px}.stat-card .icon{width:50px;height:50px;font-size:20px}.stats-content h3{font-size:24px}.btn{padding:8px 16px;font-size:13px}}.text-primary{color:var(--primary)!important}.text-secondary{color:var(--secondary)!important}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.text-warning{color:var(--warning)!important}.text-info{color:var(--info)!important}.text-light{color:var(--light)!important}.text-dark{color:var(--dark)!important}.text-muted-css{color:var(--text-muted-css)!important}.text-muted-css-css{color:var(--text-primary)!important}.glass-item{background:var(--glass-item-bg)!important;border:1px solid var(--glass-item-border)!important;border-radius:8px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .3s ease,background .3s ease,border-color .3s ease}.bg-primary{background-color:var(--primary)!important}.bg-secondary{background-color:var(--secondary)!important}.bg-success{background-color:var(--success)!important}.bg-danger{background-color:var(--danger)!important}.bg-warning{background-color:var(--warning)!important}.bg-info{background-color:var(--info)!important}.d-none{display:none!important}.d-block{display:block!important}.d-flex{display:flex!important}.d-grid{display:grid!important}.d-inline-flex{display:inline-flex!important}.justify-content-between{justify-content:space-between!important}.justify-content-center{justify-content:center!important}.justify-content-start{justify-content:flex-start!important}.justify-content-end{justify-content:flex-end!important}.align-items-center{align-items:center!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}.flex-column{flex-direction:column!important}.flex-row{flex-direction:row!important}.gap-2{gap:.5rem!important}.gap-3{gap:1rem!important}.gap-4{gap:1.5rem!important}.m-0{margin:0!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:1rem!important}.mb-4{margin-bottom:1.5rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:1rem!important}.mt-4{margin-top:1.5rem!important}.mx-auto{margin-left:auto!important;margin-right:auto!important}.p-0{padding:0!important}.p-2{padding:.5rem!important}.p-3{padding:1rem!important}.p-4{padding:1.5rem!important}.text-center{text-align:center!important}.text-left{text-align:left!important}.text-right{text-align:right!important}.w-100{width:100%!important}.h-100{height:100%!important}.cursor-pointer{cursor:pointer!important}.rounded{border-radius:.375rem!important}.rounded-lg{border-radius:.75rem!important}.opacity-50{opacity:.5!important}.opacity-75{opacity:.75!important}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--glass-bg);border-radius:12px;margin:4px;transition:background .3s ease}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary-color),rgba(32,201,151,.8));border-radius:12px;border:2px solid var(--glass-bg);min-height:24px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #20c99733}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--primary-color),rgba(32,201,151,1));transform:scale(1.1);box-shadow:0 4px 12px #20c9974d}::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,var(--primary-color),rgba(32,201,151,.9));transform:scale(.95)}::-webkit-scrollbar-corner{background:var(--glass-bg)}*{scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--glass-bg)}.table-responsive::-webkit-scrollbar-track,.modal-content::-webkit-scrollbar-track{background:#ffffff05;border-radius:8px}.table-responsive::-webkit-scrollbar-thumb,.modal-content::-webkit-scrollbar-thumb{background:#20c99799;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.table-responsive::-webkit-scrollbar-thumb:hover,.modal-content::-webkit-scrollbar-thumb:hover{background:#20c997cc}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}.tab-pane{display:none}.tab-pane.active{display:block}.btn-group{display:inline-flex;gap:0}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-top-left-radius:8px;border-bottom-left-radius:8px}.btn-group .btn:last-child{border-top-right-radius:8px;border-bottom-right-radius:8px}.border-bottom{border-bottom:1px solid var(--border)!important}.border-top{border-top:1px solid var(--border)!important}.border-secondary{border-color:var(--border)!important}.play-button-hover{transition:all .3s ease}.glass-card:hover .play-button-hover{transform:scale(1.15);box-shadow:0 12px 48px #20c99799;background:#20c997}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}.modal.show{animation:fadeInModal .3s ease-in-out}body.modal-open{overflow:hidden}.universal-search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;animation:fadeIn .2s ease-out;transition:background .3s ease}.universal-search-modal{width:90%;max-width:700px;max-height:80vh;background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 60px var(--shadow);display:flex;flex-direction:column;overflow:hidden;animation:slideDown .3s ease-out;transition:background .3s ease,border-color .3s ease}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.search-input-container{padding:24px;border-bottom:1px solid var(--border);transition:border-color .3s ease}.search-input-wrapper{position:relative;display:flex;align-items:center;margin-bottom:12px}.search-input-icon{position:absolute;left:16px;color:var(--text-muted);font-size:18px;z-index:1;transition:color .3s ease}.search-input{width:100%;padding:16px 16px 16px 48px;background:var(--glass-bg);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:16px;outline:none;transition:all .3s ease,background .3s ease,border-color .3s ease}.search-input:focus{background:var(--glass-bg-hover);border-color:var(--primary);box-shadow:0 0 0 3px #20c9971a}.search-input::placeholder{color:var(--text-muted)}.search-clear-button{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease,background .3s ease,color .3s ease;display:flex;align-items:center;justify-content:center}.search-clear-button:hover{background:var(--glass-bg-hover);color:var(--text-primary)}.search-shortcut-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-top:8px;transition:color .3s ease}.search-shortcut-hint kbd{background:var(--glass-bg);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:11px;font-family:monospace;color:var(--text-secondary);transition:background .3s ease,border-color .3s ease,color .3s ease}.search-hint-text{margin-left:4px}.search-results-container{flex:1;overflow-y:auto;padding:0;min-height:200px;max-height:calc(80vh - 200px)}.search-results-container::-webkit-scrollbar{width:8px}.search-results-container::-webkit-scrollbar-track{background:var(--glass-bg)}.search-results-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.search-results-container::-webkit-scrollbar-thumb:hover{background:var(--primary)}.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);gap:16px;transition:color .3s ease}.search-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;transition:border-color .3s ease}.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted);transition:color .3s ease}.search-empty i{font-size:48px;margin-bottom:16px;opacity:.5}.search-empty p{font-size:16px;margin:0 0 8px;color:var(--text-secondary);transition:color .3s ease}.search-empty-hint{font-size:14px;color:var(--text-muted);transition:color .3s ease}.search-results-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);background:var(--glass-bg);transition:background .3s ease,border-color .3s ease}.search-results-count{font-size:14px;color:var(--text-secondary);font-weight:500;transition:color .3s ease}.search-time{font-size:12px;color:var(--text-muted);font-family:monospace;transition:color .3s ease}.search-results-content{padding:8px 0}.search-result-group{margin-bottom:16px}.search-result-group-header{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--glass-bg);transition:background .3s ease,color .3s ease}.search-result-group-label{color:var(--text-secondary);transition:color .3s ease}.search-result-group-count{color:var(--text-muted);transition:color .3s ease}.search-result-group-items{display:flex;flex-direction:column}.search-result-item{display:flex;align-items:flex-start;gap:16px;padding:16px 24px;cursor:pointer;transition:all .2s ease;border-left:3px solid transparent}.search-result-item:hover{background:var(--glass-bg-hover);border-left-color:var(--primary)}.search-result-item.selected{background:#20c99726;border-left-color:var(--primary)}.search-result-icon{font-size:24px;flex-shrink:0;margin-top:2px}.search-result-content{flex:1;min-width:0}.search-result-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.search-result-title{font-size:15px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;transition:color .3s ease}.search-result-type-badge{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);background:var(--glass-bg);padding:2px 8px;border-radius:4px;letter-spacing:.5px;white-space:nowrap;transition:background .3s ease,color .3s ease}.search-result-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .3s ease}.search-result-description{font-size:12px;color:var(--text-muted);line-height:1.4;margin-top:4px;transition:color .3s ease}.search-footer{padding:16px 24px;border-top:1px solid var(--border);background:var(--glass-bg);transition:background .3s ease,border-color .3s ease}.search-footer-hints{display:flex;align-items:center;gap:20px;flex-wrap:wrap;font-size:12px;color:var(--text-muted);transition:color .3s ease}.search-footer-hints span{display:flex;align-items:center;gap:6px}.search-footer-hints kbd{background:var(--glass-bg);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:11px;font-family:monospace;color:var(--text-secondary);min-width:24px;text-align:center;transition:background .3s ease,border-color .3s ease,color .3s ease}@media(max-width:768px){.universal-search-modal{width:95%;max-height:90vh;padding-top:5vh}.search-input-container{padding:20px}.search-result-item{padding:12px 20px}.search-footer-hints{gap:12px;font-size:11px}}:root{--primary-h: 163;--primary-s: 72%;--primary-l: 44%;--primary: hsl(var(--primary-h), var(--primary-s), var(--primary-l));--primary-light: hsl(var(--primary-h), var(--primary-s), 54%);--primary-dark: hsl(var(--primary-h), var(--primary-s), 34%);--primary-glow: hsl(var(--primary-h), 80%, 60%);--secondary-h: 260;--secondary-s: 60%;--secondary-l: 50%;--secondary: hsl(var(--secondary-h), var(--secondary-s), var(--secondary-l));--secondary-light: hsl(var(--secondary-h), var(--secondary-s), 65%);--secondary-dark: hsl(var(--secondary-h), var(--secondary-s), 35%);--accent-h: 320;--accent-s: 70%;--accent-l: 55%;--accent: hsl(var(--accent-h), var(--accent-s), var(--accent-l));--accent-light: hsl(var(--accent-h), var(--accent-s), 70%);--blue-h: 210;--blue-s: 100%;--blue-l: 60%;--blue: hsl(var(--blue-h), var(--blue-s), var(--blue-l));--blue-light: hsl(var(--blue-h), var(--blue-s), 75%);--success: hsl(145, 63%, 42%);--warning: hsl(45, 100%, 51%);--danger: hsl(0, 72%, 51%);--info: hsl(190, 90%, 50%);--bg-h: 248;--bg-s: 53%;--bg-l: 11%;--bg-primary: hsl(var(--bg-h), var(--bg-s), var(--bg-l));--bg-secondary: hsl(var(--bg-h), 45%, 16%);--bg-tertiary: hsl(var(--bg-h), 40%, 20%);--bg-elevated: hsl(var(--bg-h), 50%, 14%);--gradient-primary: linear-gradient(135deg, hsl(248, 53%, 12%) 0%, hsl(280, 50%, 18%) 50%, hsl(248, 53%, 12%) 100%);--gradient-hero: linear-gradient(135deg, hsl(260, 60%, 15%) 0%, hsl(280, 50%, 20%) 25%, hsl(248, 53%, 15%) 50%, hsl(260, 55%, 18%) 75%, hsl(248, 53%, 12%) 100%);--gradient-card: linear-gradient(145deg, hsla(260, 60%, 25%, .3) 0%, hsla(280, 50%, 20%, .2) 100%);--gradient-accent: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 50%, var(--accent) 100%);--gradient-button: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 50%, var(--primary) 100%);--gradient-button-hover: linear-gradient(135deg, var(--primary-light) 0%, var(--primary) 50%, var(--primary-light) 100%);--gradient-glow: radial-gradient(circle, hsla(var(--primary-h), 80%, 50%, .4) 0%, transparent 70%);--gradient-mesh: radial-gradient(at 40% 20%, hsla(280, 70%, 40%, .3) 0px, transparent 50%), radial-gradient(at 80% 0%, hsla(var(--primary-h), 70%, 40%, .25) 0px, transparent 50%), radial-gradient(at 0% 50%, hsla(320, 70%, 40%, .2) 0px, transparent 50%), radial-gradient(at 80% 50%, hsla(260, 60%, 35%, .3) 0px, transparent 50%), radial-gradient(at 0% 100%, hsla(var(--primary-h), 80%, 40%, .2) 0px, transparent 50%), radial-gradient(at 80% 100%, hsla(280, 60%, 35%, .25) 0px, transparent 50%);--text-primary: hsl(0, 0%, 98%);--text-secondary: hsl(240, 5%, 70%);--text-muted: hsl(240, 5%, 50%);--text-inverse: hsl(248, 53%, 11%);--glass-bg: hsla(260, 50%, 20%, .4);--glass-bg-hover: hsla(260, 50%, 25%, .5);--glass-border: hsla(0, 0%, 100%, .08);--glass-border-hover: hsla(0, 0%, 100%, .15);--border: hsla(0, 0%, 100%, .1);--border-strong: hsla(0, 0%, 100%, .2);--shadow: hsla(0, 0%, 0%, .4);--shadow-glow: 0 0 60px hsla(var(--primary-h), 80%, 50%, .3);--shadow-card: 0 8px 32px hsla(0, 0%, 0%, .3), 0 0 80px hsla(280, 60%, 40%, .1);--shadow-elevated: 0 20px 60px hsla(0, 0%, 0%, .5);--blur-amount: 20px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--font-display: "Sora", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--dark: hsl(248, 53%, 11%);--dark-2: hsl(260, 40%, 28%);--dark-3: hsl(252, 25%, 19%);--text: hsl(0, 0%, 100%);--text-muted-css: hsl(240, 5%, 70%);--bs-secondary-color: hsl(240, 5%, 70%);--bg-gradient: var(--gradient-hero);--card-bg: var(--glass-bg)}[data-theme=light]{--bg-primary: hsl(240, 20%, 98%);--bg-secondary: hsl(240, 15%, 95%);--bg-tertiary: hsl(240, 10%, 92%);--bg-elevated: hsl(0, 0%, 100%);--gradient-primary: linear-gradient(135deg, hsl(240, 20%, 98%) 0%, hsl(250, 30%, 95%) 100%);--gradient-hero: linear-gradient(135deg, hsl(250, 40%, 97%) 0%, hsl(280, 35%, 95%) 25%, hsl(260, 30%, 97%) 50%, hsl(250, 35%, 96%) 75%, hsl(240, 20%, 98%) 100%);--gradient-card: linear-gradient(145deg, hsla(250, 40%, 95%, .8) 0%, hsla(260, 30%, 98%, .6) 100%);--gradient-mesh: radial-gradient(at 40% 20%, hsla(280, 60%, 85%, .4) 0px, transparent 50%), radial-gradient(at 80% 0%, hsla(var(--primary-h), 60%, 80%, .3) 0px, transparent 50%), radial-gradient(at 0% 50%, hsla(320, 50%, 88%, .3) 0px, transparent 50%), radial-gradient(at 80% 50%, hsla(260, 50%, 85%, .35) 0px, transparent 50%), radial-gradient(at 0% 100%, hsla(var(--primary-h), 60%, 85%, .25) 0px, transparent 50%), radial-gradient(at 80% 100%, hsla(280, 50%, 88%, .3) 0px, transparent 50%);--text-primary: hsl(248, 53%, 15%);--text-secondary: hsl(248, 20%, 40%);--text-muted: hsl(248, 15%, 55%);--text-inverse: hsl(0, 0%, 98%);--glass-bg: hsla(0, 0%, 100%, .7);--glass-bg-hover: hsla(0, 0%, 100%, .85);--glass-border: hsla(248, 30%, 50%, .1);--glass-border-hover: hsla(248, 30%, 50%, .2);--border: hsla(248, 30%, 50%, .12);--border-strong: hsla(248, 30%, 50%, .25);--shadow: hsla(248, 50%, 20%, .08);--shadow-glow: 0 0 60px hsla(var(--primary-h), 70%, 45%, .2);--shadow-card: 0 8px 32px hsla(248, 50%, 20%, .1), 0 0 80px hsla(280, 50%, 60%, .05);--shadow-elevated: 0 20px 60px hsla(248, 50%, 20%, .15);--text-muted-css: hsl(248, 20%, 40%);--bg-gradient: var(--gradient-hero);--card-bg: var(--glass-bg)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;position:relative;transition:background var(--transition-base),color var(--transition-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:var(--gradient-mesh);pointer-events:none;z-index:0;animation:meshFloat 30s ease-in-out infinite}@keyframes meshFloat{0%,to{opacity:1;transform:scale(1) rotate(0)}25%{opacity:.8;transform:scale(1.02) rotate(.5deg)}50%{opacity:.9;transform:scale(1.01) rotate(-.5deg)}75%{opacity:.85;transform:scale(1.03) rotate(.3deg)}}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-.02em}h2{font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-.01em}h3{font-size:clamp(1.5rem,3vw,2rem);font-weight:600}p{line-height:1.7;color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-light)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(1deg)}50%{transform:translateY(-5px) rotate(-1deg)}75%{transform:translateY(-15px) rotate(.5deg)}}@keyframes floatSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px hsla(var(--primary-h),80%,50%,.4)}50%{box-shadow:0 0 40px hsla(var(--primary-h),80%,50%,.6)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes particleFloat{0%,to{transform:translateY(100vh) translate(0) scale(0);opacity:0}10%{opacity:.6;transform:translateY(80vh) translate(10px) scale(1)}90%{opacity:.6;transform:translateY(10vh) translate(-10px) scale(1)}to{transform:translateY(-10vh) translate(20px) scale(0);opacity:0}}@keyframes borderGlow{0%,to{border-color:hsla(var(--primary-h),70%,50%,.3)}50%{border-color:hsla(var(--primary-h),70%,50%,.6)}}@keyframes textGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .6s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .8s ease-out forwards}.animate-fade-in-down{animation:fadeInDown .8s ease-out forwards}.animate-fade-in-left{animation:fadeInLeft .8s ease-out forwards}.animate-fade-in-right{animation:fadeInRight .8s ease-out forwards}.animate-scale-in{animation:scaleIn .6s ease-out forwards}.animate-float{animation:float 6s ease-in-out infinite}.animate-float-slow{animation:floatSlow 8s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-pulse-glow{animation:pulseGlow 2s ease-in-out infinite}.animate-gradient{background-size:200% 200%;animation:gradientShift 8s ease infinite}.animate-rotate{animation:rotate 20s linear infinite}.animate-shimmer{background:linear-gradient(90deg,transparent 0%,hsla(0,0%,100%,.1) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}.delay-700{animation-delay:.7s}.delay-800{animation-delay:.8s}.glass-card{position:relative;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);transition:all var(--transition-base);overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);opacity:.8}.glass-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);transform:translateY(-5px);box-shadow:var(--shadow-elevated)}.gradient-text{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 50%,var(--accent) 100%);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:textGradient 5s ease infinite}.gradient-border{position:relative;background:var(--glass-bg);border-radius:var(--radius-xl)}.gradient-border:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:var(--gradient-accent);border-radius:calc(var(--radius-xl) + 2px);z-index:-1;opacity:.5;transition:opacity var(--transition-base)}.gradient-border:hover:before{opacity:1}.btn-primary-gradient{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--text-inverse);background:var(--gradient-button);background-size:200% 200%;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 20px hsla(var(--primary-h),70%,40%,.4)}.btn-primary-gradient:hover{background:var(--gradient-button-hover);transform:translateY(-3px);box-shadow:0 8px 30px hsla(var(--primary-h),70%,40%,.5)}.btn-primary-gradient:active{transform:translateY(-1px)}.hover-glow{transition:all var(--transition-base)}.hover-glow:hover{box-shadow:var(--shadow-glow)}.loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:var(--text-secondary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);transition:background var(--transition-base)}.spinner{width:50px;height:50px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--glass-bg);border-radius:var(--radius-full);border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--glass-bg-hover)}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}::selection{background:hsla(var(--primary-h),var(--primary-s),var(--primary-l),.3);color:var(--text-primary)}
