.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#1f2937}.navbar{background:#1e3a5f;color:#fff;padding:8px 24px;min-height:76px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0003}.navbar-logo{font-size:20px;font-weight:700;letter-spacing:-.5px}.navbar-logo span{color:#60a5fa}.navbar-spacer{flex:1}.navbar-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:9px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s}.navbar-btn:hover{background:#fff3}.navbar-btn.primary{background:#3b82f6;border-color:#3b82f6}.navbar-btn.primary:hover{background:#2563eb}.navbar-btn.danger{background:#ef444433;border-color:#ef444466}.nav-user-menu{position:relative}.nav-user{display:flex;align-items:center;gap:9px;padding:6px 10px;background:none;border:none;color:inherit;cursor:pointer;border-radius:8px;font:inherit}.nav-user:hover{background:#ffffff1f}.navbar-light .nav-user:hover{background:#f1f5f9}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.user-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:190px;background:#fff;border:1px solid #E5E7EB;border-radius:10px;box-shadow:0 10px 30px #0000002e;padding:5px;display:flex;flex-direction:column;z-index:100}.user-dropdown button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:10px 12px;font-size:14px;font-weight:500;color:#374151;border-radius:7px}.user-dropdown button:hover{background:#f3f4f6}.user-dropdown button.danger{color:#dc2626}.user-dropdown button.danger:hover{background:#fef2f2}.nav-user-avatar{width:30px;height:30px;border-radius:50%;background:#3b82f6;color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-user-name{font-size:14px;font-weight:600;opacity:.95}.nav-logout{display:inline-flex;align-items:center;gap:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.22);color:#fff;padding:9px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.nav-logout span{font-size:16px;line-height:1}.nav-logout:hover{background:#ef4444;border-color:#ef4444;box-shadow:0 3px 10px #ef444466}.navbar-light .navbar-btn{background:#f1f5f9;border-color:#e2e8f0;color:#334155}.navbar-light .navbar-btn:hover{background:#e2e8f0}.navbar-light .navbar-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.navbar-light .nav-user-name{color:#1f2937}.navbar-light .nav-logout{background:#f1f5f9;border-color:#e2e8f0;color:#334155}.navbar-light .nav-logout:hover{background:#ef4444;border-color:#ef4444;color:#fff}.navbar-light .navbar-select{background:#f1f5f9;border-color:#e2e8f0;color:#1f2937}.navbar.navbar-light .period-seg{border-color:#e2e8f0}.navbar.navbar-light .period-btn{color:#334155}.navbar.navbar-light .period-btn:hover:not(.active){background:#f1f5f9}.navbar.navbar-light .period-btn.active{background:#3b82f6;color:#fff}.navbar-brand-logo{height:44px;max-width:200px;object-fit:contain;background:#fff;border-radius:6px;padding:3px 7px}.navbar-dash-name{font-size:18px;font-weight:700;line-height:1.15}.navbar-dash-sub{font-size:11px;opacity:.75}.navbar-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#fff;padding:6px 10px;border-radius:6px;font-size:13px;cursor:pointer}.navbar-select option{color:#1f2937}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1e3a5f}.login-card{background:#fff;border-radius:12px;padding:40px;width:360px;box-shadow:0 20px 60px #0000004d}.login-title{font-size:24px;font-weight:700;color:#1e3a5f;margin-bottom:4px}.login-subtitle{font-size:14px;color:#6b7280;margin-bottom:28px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid #D1D5DB;border-radius:6px;font-size:14px;color:#1f2937;background:#fff;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;font-family:Courier New,monospace;font-size:13px}.form-error{color:#ef4444;font-size:13px;margin-top:8px}.btn{padding:11px 22px;border-radius:9px;border:none;cursor:pointer;font-size:14.5px;font-weight:600;transition:all .15s}.btn:active{transform:translateY(1px)}.btn-primary{background:#3b82f6;color:#fff;box-shadow:0 2px 8px #3b82f659}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f673}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed;box-shadow:none}.btn-secondary{background:#fff;color:#374151;border:1px solid #D1D5DB}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-danger{background:#ef4444;color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{background:#fca5a5;cursor:not-allowed;box-shadow:none}.btn-sm{padding:7px 14px;font-size:13px;border-radius:8px}.btn-full{width:100%}.dashboard-content{padding:10px}.empty-state{text-align:center;padding:80px 20px;color:#9ca3af}.empty-state h3{font-size:20px;margin-bottom:8px;color:#6b7280}.widget-card{background:#fff;border-radius:8px;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;height:100%;overflow:hidden;border:1px solid #E5E7EB}.widget-header{padding:12px 14px 8px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F3F4F6;flex-shrink:0}.widget-title{font-size:13px;font-weight:600;color:#1f2937}.widget-actions{display:flex;gap:4px}.widget-action-btn{background:none;border:none;cursor:pointer;padding:3px 6px;border-radius:4px;font-size:13px;color:#9ca3af;transition:background .15s}.widget-action-btn:hover{background:#f3f4f6;color:#374151}.widget-body{flex:1;padding:10px;overflow:hidden;min-height:0}.widget-footer{padding:4px 14px 6px;font-size:11px;color:#9ca3af;border-top:1px solid #F3F4F6;flex-shrink:0;display:flex;justify-content:space-between;align-items:center}.widget-loading{height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:13px}.widget-error{padding:8px;background:#fef2f2;border-radius:4px;color:#dc2626;font-size:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal-box{background:#fff;border-radius:10px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-box.modal-lg{max-width:900px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid #E5E7EB;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:17px;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:#9ca3af;line-height:1}.modal-close:hover{color:#374151}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid #E5E7EB;display:flex;gap:10px;justify-content:flex-end}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;justify-content:flex-end;background:transparent;pointer-events:none}.drawer-panel{background:#fff;width:520px;max-width:94vw;height:100%;display:flex;flex-direction:column;box-shadow:-10px 0 40px #00000047;animation:drawerIn .2s ease;pointer-events:auto}@keyframes drawerIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-overlay.drawer-below{top:79px}.drawer-panel .modal-header{flex-shrink:0}.drawer-panel .modal-body{flex:1;overflow-y:auto}.drawer-panel .modal-footer{flex-shrink:0}.widget-card{position:relative}.widget-hover-tools{position:absolute;top:8px;right:8px;z-index:5;display:flex;align-items:center;gap:6px;opacity:0;pointer-events:none;transition:opacity .15s}.widget-card:hover .widget-hover-tools,.widget-card.selected .widget-hover-tools{opacity:1;pointer-events:auto}.widget-edit-overlay{display:flex;align-items:center;gap:5px;padding:6px 12px;background:#3b82f6;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 3px 10px #3b82f666}.widget-edit-overlay:hover{background:#2563eb}.widget-tool-btn{width:30px;height:30px;background:#fff;border:1px solid #E5E7EB;color:#6b7280;border-radius:7px;cursor:pointer;font-size:14px;box-shadow:0 2px 6px #0000001f}.widget-tool-btn:hover{background:#f9fafb;color:#374151}.widget-tool-btn.danger:hover{background:#fef2f2;color:#dc2626}.widget-card.selected{outline:2px solid #3B82F6;outline-offset:1px}.tabs{display:flex;border-bottom:2px solid #E5E7EB;margin-bottom:20px}.tab-btn{padding:10px 20px;background:none;border:none;cursor:pointer;font-size:14px;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab-btn.active{color:#3b82f6;border-bottom-color:#3b82f6;font-weight:500}.tab-btn:hover{color:#374151}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{padding:10px 12px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #E5E7EB;background:#f9fafb}.data-table td{padding:9px 12px;border-bottom:1px solid #F3F4F6;color:#374151}.data-table tr:hover td{background:#f9fafb}.kpi-container{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.kpi-value{font-size:42px;font-weight:700;line-height:1}.kpi-label{font-size:12px;color:#6b7280;margin-top:8px;text-transform:uppercase;letter-spacing:.05em}.preview-table-wrap{overflow:auto;max-height:180px;border:1px solid #E5E7EB;border-radius:6px;margin-top:8px}.preview-table{width:100%;border-collapse:collapse;font-size:12px}.preview-table th{padding:6px 10px;background:#f3f4f6;border-bottom:1px solid #E5E7EB;font-weight:600;color:#374151;white-space:nowrap;position:sticky;top:0}.preview-table td{padding:5px 10px;border-bottom:1px solid #F3F4F6;white-space:nowrap;color:#374151}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500}.badge-admin{background:#dbeafe;color:#1d4ed8}.badge-viewer{background:#f3f4f6;color:#6b7280}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid #E5E7EB;border-top-color:#3b82f6;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-size:15px;font-weight:600;color:#1f2937}.react-grid-item>.react-resizable-handle{z-index:10;width:22px;height:22px;right:0;bottom:0;padding:0;background:none;opacity:0;transition:opacity .15s}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:5px;bottom:5px;width:9px;height:9px;border:0;border-right:2px solid #9CA3AF;border-bottom:2px solid #9CA3AF;border-bottom-right-radius:4px;transition:border-color .15s}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:hover:after{border-color:#3b82f6}.react-grid-item.resizing>.react-resizable-handle{opacity:1}.react-grid-item.resizing>.react-resizable-handle:after{border-color:#3b82f6}.app-shell{display:flex;min-height:100vh}.sidebar{width:264px;flex-shrink:0;background:linear-gradient(180deg,#0f172a,#15213b);color:#cbd5e1;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:22px 14px;box-shadow:2px 0 16px #0000002e;z-index:50}.sidebar-brand{font-size:26px;font-weight:800;letter-spacing:-.5px;color:#fff;padding:6px 14px 24px}.sidebar-brand span{color:#60a5fa}.sidebar-nav{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:13px;width:100%;padding:13px 14px;background:none;border:none;border-radius:12px;color:#cbd5e1;font-size:15.5px;font-weight:600;cursor:pointer;text-align:left;transition:all .15s}.sidebar-item:hover{background:#ffffff12;color:#fff}.sidebar-item:hover .sidebar-icon{background:#ffffff1f}.sidebar-item.active{background:linear-gradient(90deg,#3b82f647,#3b82f61f);color:#fff;box-shadow:inset 3px 0 #3b82f6}.sidebar-item.active .sidebar-icon{background:#3b82f666}.sidebar-icon{font-size:18px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border-radius:10px;flex-shrink:0;transition:background .15s}.sidebar-label{flex:1}.sidebar-chevron{font-size:11px;opacity:.7}.sidebar-sublist{display:flex;flex-direction:column;gap:2px;margin:2px 0 6px;padding-left:8px;max-height:42vh;overflow-y:auto}.sidebar-subitem{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;cursor:pointer;font-size:13px;color:#94a3b8;transition:background .15s,color .15s}.sidebar-subitem:hover{background:#ffffff0f;color:#e2e8f0}.sidebar-subitem.active{background:#ffffff1a;color:#fff;font-weight:600}.sidebar-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0}.sidebar-subname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-edit{background:none;border:none;color:#64748b;cursor:pointer;font-size:13px;opacity:0;padding:2px 5px;border-radius:5px;transition:opacity .15s,color .15s}.sidebar-subitem:hover .sidebar-edit{opacity:1}.sidebar-edit:hover{color:#60a5fa;background:#ffffff14}.sidebar-empty{font-size:12px;color:#64748b;padding:6px 11px}.sidebar-add{margin-top:4px;background:none;border:1px dashed rgba(148,163,184,.4);color:#94a3b8;border-radius:8px;padding:8px 11px;font-size:12.5px;cursor:pointer;transition:all .15s}.sidebar-add:hover{border-color:#3b82f6;color:#93c5fd;background:#3b82f614}.sidebar-footer{border-top:1px solid rgba(148,163,184,.15);padding-top:12px;margin-top:8px}.sidebar-user{display:flex;align-items:center;gap:11px;padding:6px 14px 12px;font-size:14px;color:#cbd5e1;font-weight:500}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:#3b82f6;color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-item.logout:hover{background:#ef44442e;color:#fca5a5}.app-main{flex:1;min-width:0;display:flex;flex-direction:column}.dashboard-content.focusing{padding-right:540px;transition:padding-right .2s ease}@media (max-width: 1100px){.dashboard-content.focusing{padding-right:10px}}.focus-widget{max-width:680px;height:440px;margin:24px auto 0}.topbar{background:#fff;min-height:72px;padding:10px 24px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:40;box-shadow:0 2px 8px #0000000f}.topbar-brand{display:flex;align-items:center;gap:12px}.topbar .topbar-brand .navbar-logo{color:#1e3a5f}.topbar .topbar-brand .navbar-dash-name{color:#1f2937}.topbar .topbar-brand .navbar-dash-sub{color:#6b7280}.topbar-title{font-size:18px;font-weight:700;color:#1f2937}.topbar .navbar-btn{background:#f1f5f9;border:1px solid #E2E8F0;color:#334155}.topbar .navbar-btn:hover{background:#e2e8f0}.topbar .navbar-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.topbar .navbar-btn.primary:hover{background:#2563eb}.panel{padding:24px}.period-seg{display:inline-flex;border-radius:9px;overflow:hidden;border:1px solid}.period-btn{padding:8px 15px;background:transparent;border:none;cursor:pointer;font-size:13.5px;font-weight:600;transition:background .15s,color .15s}.period-btn.active{background:#3b82f6;color:#fff}.navbar .period-seg{border-color:#ffffff40}.navbar .period-btn{color:#ffffffd9}.navbar .period-btn:hover:not(.active){background:#ffffff1f}.topbar .period-seg{border-color:#e2e8f0}.topbar .period-btn{color:#334155}.topbar .period-btn:hover:not(.active){background:#f1f5f9}.link-name{display:inline-flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:600;color:#1f2937;padding:0}.link-name:hover{color:#3b82f6}.drawer-overlay.dim{background:#0006;pointer-events:auto}
