@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";.login-page{background-color:#f8fafc;width:100vw;min-height:100vh;display:flex;overflow:hidden auto}.login-split-container{width:100%;min-height:100vh;display:flex}.login-banner{color:#fff;background:linear-gradient(135deg, var(--color-primary) 0%, #1e3a8a 100%);flex-direction:column;flex:1;justify-content:center;max-width:50%;padding:4rem;display:flex;position:relative;overflow:hidden}.banner-decorative-bg{opacity:.5;z-index:1;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.banner-decorative-circle-1{z-index:1;background:radial-gradient(circle,#ffffff14 0%,#fff0 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;left:-200px}.banner-decorative-circle-2{z-index:1;background:radial-gradient(circle,#38bdf81a 0%,#fff0 70%);border-radius:50%;width:800px;height:800px;position:absolute;bottom:-300px;right:-200px}.banner-content{z-index:10;text-align:center;flex-direction:column;align-items:center;max-width:500px;margin:0 auto;display:flex;position:relative}.banner-logo-wrapper{-webkit-backdrop-filter:blur(12px);background:#ffffff1a;border:1px solid #fff3;border-radius:32px;justify-content:center;align-items:center;width:140px;height:140px;margin-bottom:1rem;display:flex;overflow:hidden;box-shadow:0 20px 40px #00000026}.custom-login-logo{object-fit:contain;filter:drop-shadow(0 4px 8px #0003);width:100%;height:100%;padding:8px;transition:transform .3s}.custom-login-logo:hover{transform:scale(1.05)}.banner-title{letter-spacing:-.025em;color:#fff;margin-bottom:1rem;font-size:3rem;font-weight:800;line-height:1.1}.banner-subtitle{color:#ffffffd9;margin-bottom:3rem;font-size:1.15rem;line-height:1.6}.banner-features{flex-direction:column;gap:1rem;display:flex}.glass-pill{-webkit-backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff26;border-radius:100px;align-items:center;gap:1rem;width:fit-content;padding:1rem 1.5rem;font-size:.95rem;font-weight:500;transition:transform .3s,background .3s;display:inline-flex}.glass-pill:hover{background:#ffffff1f;transform:translate(5px)}.feature-icon{color:#38bdf8}.banner-footer{text-align:center;z-index:10;color:#ffffff80;width:100%;font-size:.875rem;position:absolute;bottom:2rem;left:0}.login-form-side{background-color:#f8fafc;flex:1;justify-content:center;align-items:center;max-width:50%;padding:2rem;display:flex;position:relative}.login-form-wrapper{background-color:#fff;border:1px solid #0000000d;border-radius:24px;width:100%;max-width:540px;padding:3rem 3.5rem;box-shadow:0 20px 40px -15px #0000000d}.mobile-logo-header{text-align:center;margin-bottom:2rem;display:none}.mobile-logo-icon{color:var(--color-primary);margin-bottom:.5rem}.mobile-logo-header h2{letter-spacing:-.025em;color:var(--color-text-main);font-size:1.75rem;font-weight:800}.form-header{text-align:center;margin-bottom:2.5rem}.form-header h2{color:var(--color-text-main);margin-bottom:.5rem;font-size:1.85rem;font-weight:700}.form-header p{color:var(--color-text-muted);font-size:.95rem}.error-alert{color:var(--color-danger);border-radius:var(--radius-lg);background-color:#ef44440d;border:1px solid #ef444433;align-items:center;margin-bottom:1.5rem;padding:1rem;font-size:.875rem;font-weight:500;display:flex}.modern-login-form{flex-direction:column;gap:1.5rem;display:flex}.modern-input-group label{color:var(--color-text-main);margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.modern-input{border-radius:var(--radius-lg);height:3.25rem;color:var(--color-text-main);background-color:#fff;border:1px solid #e2e8f0;padding:0 1rem;font-size:.95rem;transition:all .2s;box-shadow:0 1px 2px #00000005}.modern-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb26}.modern-input::placeholder{color:#94a3b8}.password-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.password-header label{margin-bottom:0}.forgot-password-link{color:var(--color-primary);font-size:.85rem;font-weight:600;text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:#1d4ed8;text-decoration:underline}.modern-password-wrapper{align-items:center;display:flex;position:relative}.modern-password-wrapper .modern-input{width:100%;padding-right:3rem}.modern-toggle{color:#94a3b8;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;right:1rem}.modern-toggle:hover{color:var(--color-text-main)}.captcha-group{border-radius:var(--radius-lg);background-color:#f8fafc;border:1px solid #e2e8f0;padding:1.25rem}.captcha-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.75rem;font-weight:700;display:block}.captcha-container{justify-content:space-between;align-items:center;gap:1rem;display:flex}.captcha-question{color:var(--color-text-main);align-items:center;gap:.5rem;font-size:1rem;display:flex}.captcha-question strong{color:var(--color-primary);font-size:1.15rem;font-family:var(--font-mono);border-radius:var(--radius-md);white-space:nowrap;background:#2563eb1a;padding:.25rem .6rem;display:inline-block}.captcha-input-area{align-items:center;gap:.5rem;display:flex}.captcha-input{text-align:center;flex-shrink:0;font-weight:600;width:140px!important;height:2.75rem!important;padding:0 .5rem!important;font-size:1rem!important}.captcha-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.captcha-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.captcha-input[type=number]{-moz-appearance:textfield}.captcha-refresh-btn{border-radius:var(--radius-md);width:2.75rem;height:2.75rem;color:var(--color-text-muted);cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.captcha-refresh-btn:hover{color:var(--color-primary);background-color:#f1f5f9}.captcha-error{color:var(--color-danger);margin-top:.75rem;font-size:.85rem;font-weight:500;display:block}.modern-submit-btn{border-radius:var(--radius-lg);justify-content:center;align-items:center;gap:.5rem;height:3.25rem;margin-top:.5rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 12px #2563eb33}.modern-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb4d}.modern-submit-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=992px){.login-banner{display:none}.mobile-logo-header{display:block}.login-form-side{background-image:radial-gradient(circle at 15%,#2563eb14 0%,#0000 50%),radial-gradient(circle at 85% 30%,#38bdf81a 0%,#0000 50%);max-width:100%;padding:1.5rem}.login-form-wrapper{width:100%;max-width:440px;padding:2.5rem}}@media (width<=480px){.login-form-wrapper{box-shadow:none;background:0 0;border:none;padding:1.5rem}.captcha-container{flex-direction:column;align-items:stretch}.captcha-question{justify-content:space-between}.captcha-input-area{width:100%}.captcha-input{flex:1}}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.resizing{z-index:1;will-change:width, height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.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{cursor:ns-resize;margin-left:-10px;left:50%}.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{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.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{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard-page{min-height:calc(100vh - 80px);padding-bottom:3rem;position:relative}.dashboard-page:before,.dashboard-page:after{content:"";filter:blur(120px);pointer-events:none;z-index:0;border-radius:50%;position:absolute}.dashboard-page:before{background:#4f46e50f;width:420px;height:420px;top:-60px;left:-40px}.dashboard-page:after{background:#10b9810d;width:380px;height:380px;bottom:80px;right:-40px}.dash-header{z-index:2;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex;position:relative}.dash-header-title{align-items:center;gap:.875rem;display:flex}.dash-header-icon{border-radius:var(--radius-lg);width:48px;height:48px;color:var(--color-primary);background:linear-gradient(135deg,#4f46e526,#6366f114);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-header h1{color:var(--color-text-main);letter-spacing:-.02em;font-size:1.625rem;font-weight:800;line-height:1.2}.dash-header p{color:var(--color-text-muted);margin-top:.25rem;margin-left:60px;font-size:.875rem}.dash-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.dash-toolbar-group{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;gap:.375rem;padding:.375rem;display:flex}.dash-toolbar-divider{background:var(--color-border);width:1px;height:24px;margin:0 .25rem}.dash-btn{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.8125rem;font-weight:600;transition:all .15s;display:inline-flex}.dash-btn-ghost{color:var(--color-text-main);background:0 0}.dash-btn-ghost:hover{background:#0000000a}.dash-btn-primary-text{color:var(--color-primary);background:0 0}.dash-btn-primary-text:hover{background:#4f46e514}.dash-btn-warning-text{color:var(--color-warning);background:0 0}.dash-btn-warning-text:hover{background:#f59e0b14}.dash-btn-primary-solid{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #4f46e540}.dash-btn-primary-solid:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e559}.dash-btn-outline{background:var(--glass-bg);color:var(--color-text-main);border:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dash-btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.dash-edit-banner{color:var(--color-primary);border-radius:var(--radius-lg);background:#4f46e50f;border:1px solid #4f46e526;justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.625rem 1rem;font-size:.8125rem;font-weight:600;animation:2s ease-in-out infinite pulse-border;display:flex}@keyframes pulse-border{0%,to{border-color:#4f46e526}50%{border-color:#4f46e559}}.dash-loading{z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:10rem 0;display:flex;position:relative}.dash-loading svg{color:var(--color-primary);animation:1s linear infinite spin}.dash-loading span{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);font-size:.75rem;font-weight:700}.dash-announcements{z-index:2;flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex;position:relative}.dash-announce-banner{border-radius:var(--radius-lg);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);background:var(--color-bg-card);box-shadow:var(--shadow-sm);align-items:flex-start;gap:1rem;padding:1.125rem 1.25rem;transition:box-shadow .2s;animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeIn;display:flex}.dash-announce-banner:hover{box-shadow:var(--shadow-md)}.dash-announce-banner.urgent{border-left-color:var(--color-danger)}.dash-announce-banner.warning{border-left-color:var(--color-warning)}.dash-announce-banner.maintenance{border-left-color:#f97316}.dash-announce-banner.info{border-left-color:var(--color-primary)}.announce-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.announce-icon.urgent{color:var(--color-danger);background:#ef44441a}.announce-icon.warning{color:var(--color-warning);background:#f59e0b1a}.announce-icon.maintenance{color:#f97316;background:#f973161a}.announce-icon.info{color:var(--color-primary);background:#4f46e51a}.announce-body{flex:1;min-width:0}.announce-title-row{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.announce-title-row h4{color:var(--color-text-main);font-size:.9375rem;font-weight:700}.announce-date{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#00000008;padding:.25rem .625rem;font-size:.625rem;font-weight:700}.announce-body p{color:var(--color-text-muted);white-space:pre-line;font-size:.8125rem;line-height:1.6}.announce-dismiss{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:50%;flex-shrink:0;padding:.375rem;transition:all .15s}.announce-dismiss:hover{color:var(--color-danger);background:#ef44441a}.dash-grid-container{z-index:2;width:100%;position:relative}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width, height}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;opacity:.9;transition:none}.react-grid-item.react-grid-placeholder{background:var(--color-primary);opacity:.08;border-radius:var(--radius-lg);z-index:2}.widget-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;height:100%;transition:box-shadow .2s,border-color .2s;display:flex;overflow:hidden}.widget-card:hover{box-shadow:var(--shadow-md);border-color:#4f46e533}.widget-card.editing{outline-offset:-2px;cursor:move;outline:2px solid #4f46e54d}.widget-card.editing:hover{outline-color:#4f46e599}.widget-header{border-bottom:1px solid var(--color-border);background:#00000003;flex-shrink:0;justify-content:space-between;align-items:center;padding:.625rem 1rem;display:flex}[data-theme=dark] .widget-header{background:#ffffff05}.widget-header h3{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-main);align-items:center;gap:.625rem;margin:0;font-size:.6875rem;font-weight:700;display:flex}.widget-header-accent{background:linear-gradient(180deg, var(--color-primary), #818cf8);border-radius:2px;flex-shrink:0;width:3px;height:14px}.widget-delete-btn{cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:.375rem;transition:all .15s;display:flex}.widget-delete-btn:hover{color:var(--color-danger);background:#ef44441a}.widget-body{flex:1;min-height:0;padding:.75rem;position:relative;overflow:hidden}.stat-grid{grid-template-columns:repeat(4,1fr);align-items:center;gap:1rem;height:100%;display:grid}@media (width<=900px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);align-items:center;gap:1rem;padding:1rem 1.125rem;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon.primary{color:var(--color-primary);background:#4f46e51a}.stat-icon.danger{color:var(--color-danger);background:#ef44441a}.stat-icon.warning{color:var(--color-warning);background:#f59e0b1a}.stat-icon.success{color:var(--color-success);background:#10b9811a}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.125rem;font-size:.6875rem;font-weight:600}.stat-value{color:var(--color-text-main);font-variant-numeric:tabular-nums;font-size:1.75rem;font-weight:800;line-height:1}.sla-gauge{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:1rem;display:flex}.sla-ring{justify-content:center;align-items:center;width:160px;height:160px;display:flex;position:relative}.sla-ring svg{transform:rotate(-90deg)}.sla-ring circle.track{fill:#0000;stroke:var(--color-border);stroke-width:10px}.sla-ring circle.progress{fill:#0000;stroke:url(#slaGradient);stroke-width:10px;stroke-linecap:round;transition:stroke-dashoffset 1s ease-out}.sla-center{flex-direction:column;align-items:center;display:flex;position:absolute}.sla-percent{color:var(--color-primary);font-variant-numeric:tabular-nums;font-size:2.25rem;font-weight:800;line-height:1}.sla-caption{color:var(--color-text-muted);text-align:center;max-width:200px;margin-top:.875rem;font-size:.75rem;line-height:1.5}.dash-table-wrap{height:100%;overflow-x:auto}.dash-table{text-align:left;border-collapse:separate;border-spacing:0 .375rem;width:100%;font-size:.8125rem}.dash-table thead th{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);white-space:nowrap;padding:.5rem .75rem;font-size:.6875rem;font-weight:600}.dash-table tbody tr{transition:background .15s}.dash-table tbody tr:hover{background:#00000004}[data-theme=dark] .dash-table tbody tr:hover{background:#ffffff08}.dash-table tbody td{vertical-align:middle;color:var(--color-text-main);white-space:nowrap;padding:.625rem .75rem}.dash-table .cell-ticket{color:var(--color-primary);font-weight:600}.dash-table .cell-ticket a:hover{text-decoration:underline}.dash-table .cell-mono{font-variant-numeric:tabular-nums;font-weight:600}.dash-table .cell-center{text-align:center}.dash-table .cell-right{text-align:right}.dash-table .empty-row td{text-align:center;color:var(--color-text-muted);padding:2rem;font-size:.8125rem}.dash-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;padding:.25rem .625rem;font-size:.625rem;font-weight:700;line-height:1.2;display:inline-flex}.dash-badge.kritis{color:var(--color-danger);background:#ef44441a;border-color:#ef444433}.dash-badge.tinggi{color:var(--color-warning);background:#f59e0b1a;border-color:#f59e0b33}.dash-badge.sedang{color:var(--color-accent);background:#0ea5e91a;border-color:#0ea5e933}.dash-badge.rendah{color:var(--color-success);background:#10b9811a;border-color:#10b98133}.dash-badge-freq{background:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);font-variant-numeric:tabular-nums;justify-content:center;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:700;display:inline-flex}.tech-list{flex-direction:column;gap:.5rem;height:100%;padding:.25rem;display:flex;overflow-y:auto}.tech-row{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:border-color .2s;display:flex}.tech-row:hover{border-color:#4f46e540}.tech-row-left{align-items:center;gap:.75rem;display:flex}.tech-rank{font-variant-numeric:tabular-nums;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.6875rem;font-weight:800;display:flex}.tech-rank.gold{color:#fff;background:linear-gradient(135deg,#fbbf24,#d97706)}.tech-rank.silver{color:#fff;background:linear-gradient(135deg,#d1d5db,#9ca3af)}.tech-rank.bronze{color:#fff;background:linear-gradient(135deg,#d97706,#92400e)}.tech-rank.normal{background:var(--color-bg-main);color:var(--color-text-muted);border:1px solid var(--color-border)}.tech-name{color:var(--color-text-main);font-size:.875rem;font-weight:600}.tech-score{color:var(--color-success);border-radius:var(--radius-sm);background:#10b98114;align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.75rem;font-weight:700;display:inline-flex}.budget-list{flex-direction:column;gap:.75rem;height:100%;padding:.25rem;display:flex;overflow-y:auto}.budget-item{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);padding:.875rem 1rem}.budget-title-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.budget-title{color:var(--color-text-main);text-overflow:ellipsis;white-space:nowrap;max-width:70%;font-size:.8125rem;font-weight:700;overflow:hidden}.budget-pct{border-radius:var(--radius-sm);background:var(--color-bg-main);border:1px solid var(--color-border);font-variant-numeric:tabular-nums;color:var(--color-text-main);padding:.2rem .5rem;font-size:.6875rem;font-weight:700}.budget-bar-track{background:var(--color-bg-main);border:1px solid #00000005;border-radius:3px;width:100%;height:6px;overflow:hidden}.budget-bar-fill{border-radius:3px;height:100%;transition:width .8s ease-out}.budget-bar-fill.safe{background:linear-gradient(90deg, var(--color-primary), #818cf8)}.budget-bar-fill.warn{background:linear-gradient(90deg, var(--color-warning), #fb923c)}.budget-bar-fill.danger{background:linear-gradient(90deg, var(--color-danger), #ef4444)}.budget-detail-row{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:.5rem;font-size:.625rem;font-weight:600;display:flex}.chart-container{width:100%;height:100%}.dash-tooltip{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.625rem .75rem}.dash-tooltip-label{color:var(--color-text-main);margin-bottom:.375rem;font-size:.75rem;font-weight:700}.dash-tooltip-row{align-items:center;gap:.5rem;font-size:.75rem;line-height:1.6;display:flex}.dash-tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dash-tooltip-name{color:var(--color-text-muted)}.dash-tooltip-val{color:var(--color-text-main);font-weight:700}.dash-empty{height:100%;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.25rem;font-size:.8125rem;display:flex}.widget-catalog-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;max-height:60vh;padding:1.5rem;display:grid;overflow-y:auto}.widget-catalog-card{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);flex-direction:column;justify-content:space-between;padding:1.25rem;transition:border-color .2s,box-shadow .2s;display:flex}.widget-catalog-card:hover{box-shadow:var(--shadow-md);border-color:#4f46e54d}.widget-catalog-title{color:var(--color-text-main);margin-bottom:.375rem;font-size:.9375rem;font-weight:700}.widget-catalog-desc{color:var(--color-text-muted);font-size:.8125rem;line-height:1.5}.widget-catalog-add{width:100%;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem;font-family:inherit;font-size:.8125rem;font-weight:600;transition:all .15s;display:flex}.widget-catalog-add:hover{background:var(--color-primary);color:#fff}.widget-catalog-empty{text-align:center;color:var(--color-text-muted);grid-column:1/-1;padding:3rem}.widget-catalog-empty svg{opacity:.5;color:var(--color-success);margin:0 auto .75rem}.popup-icon-wrap{border-radius:50%;margin-bottom:1.5rem;padding:1rem;display:inline-flex}.popup-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);background:#4f46e51a;border-radius:20px;padding:.25rem .75rem;font-size:.625rem;font-weight:800;display:inline-block}.popup-title{color:var(--color-text-main);margin:.75rem 0 .5rem;font-size:1.375rem;font-weight:800}.popup-date{color:var(--color-text-muted);font-size:.75rem}.popup-divider{border-top:1px solid var(--color-border);margin:1rem 0}.popup-content-box{color:var(--color-text-main);white-space:pre-line;text-align:left;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#00000005;max-height:30vh;padding:1rem;font-size:.875rem;line-height:1.6;overflow-y:auto}[data-theme=dark] .popup-content-box{background:#ffffff05}.confirm-dialog{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:420px;padding:2rem 2rem 1.75rem;position:relative;overflow:hidden;box-shadow:0 24px 48px -12px #0000002e}.confirm-dialog:before{content:"";border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.confirm-dialog:has([data-color=warning]):before{background:linear-gradient(90deg, var(--color-warning), #fb923c)}.confirm-dialog:has([data-color=danger]):before{background:linear-gradient(90deg, var(--color-danger), #f87171)}.confirm-dialog:has([data-color=success]):before{background:linear-gradient(90deg, var(--color-success), #34d399)}.confirm-dialog-icon-wrap{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1.25rem;display:inline-flex;position:relative}.confirm-dialog-icon-wrap:after{content:"";opacity:.15;border-radius:50%;animation:2s ease-in-out infinite confirm-glow;position:absolute;inset:-6px}@keyframes confirm-glow{0%,to{opacity:.1;transform:scale(1)}50%{opacity:.2;transform:scale(1.1)}}.confirm-dialog-icon-wrap[data-color=warning]{color:var(--color-warning);background:#f59e0b1a}.confirm-dialog-icon-wrap[data-color=warning]:after{background:var(--color-warning)}.confirm-dialog-icon-wrap[data-color=danger]{color:var(--color-danger);background:#ef44441a}.confirm-dialog-icon-wrap[data-color=danger]:after{background:var(--color-danger)}.confirm-dialog-icon-wrap[data-color=success]{color:var(--color-success);background:#10b9811a}.confirm-dialog-icon-wrap[data-color=success]:after{background:var(--color-success)}.confirm-dialog-title{color:var(--color-text-main);letter-spacing:-.01em;margin:0 0 .5rem;font-size:1.25rem;font-weight:800}.confirm-dialog-message{color:var(--color-text-muted);max-width:340px;margin:0 auto 1.75rem;font-size:.875rem;line-height:1.6}.confirm-dialog-actions{gap:.75rem;display:flex}.confirm-dialog-cancel,.confirm-dialog-confirm{border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;font-weight:700;transition:all .15s}.confirm-dialog-cancel{color:var(--color-text-main);border:1px solid var(--color-border);background:0 0}.confirm-dialog-cancel:hover{border-color:var(--color-text-muted);background:#00000008}.confirm-dialog-confirm[data-color=warning]{background:var(--color-warning);color:#fff;box-shadow:0 4px 12px #f59e0b4d}.confirm-dialog-confirm[data-color=warning]:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 6px 16px #f59e0b66}.confirm-dialog-confirm[data-color=danger]{background:var(--color-danger);color:#fff;box-shadow:0 4px 12px #ef44444d}.confirm-dialog-confirm[data-color=danger]:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 16px #ef444466}.confirm-dialog-confirm[data-color=success]{background:var(--color-success);color:#fff;box-shadow:0 4px 12px #10b9814d}.confirm-dialog-confirm[data-color=success]:hover{background:#059669;transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.skeleton{background:linear-gradient(90deg, var(--color-border) 25%, #ffffff26 37%, var(--color-border) 63%);border-radius:var(--radius-sm);background-size:200% 100%;line-height:1;animation:1.4s ease-in-out infinite skeleton-shimmer}[data-theme=dark] .skeleton{background:linear-gradient(90deg, var(--color-border) 25%, #ffffff0f 37%, var(--color-border) 63%);background-size:200% 100%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{width:100%;height:14px}.skeleton-circular{border-radius:50%}.skeleton-rectangular{border-radius:var(--radius-md)}.skeleton-table{width:100%}.skeleton-table-header,.skeleton-table-row{align-items:center;gap:1rem;padding:.875rem 1rem;display:grid}.skeleton-table-header{border-bottom:1px solid var(--color-border);margin-bottom:.25rem;padding-bottom:1rem}.skeleton-table-row{border-bottom:1px solid #00000008;padding:.75rem 1rem}[data-theme=dark] .skeleton-table-row{border-bottom:1px solid #ffffff08}.skeleton-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:1.5rem}.skeleton-form{flex-direction:column;gap:0;display:flex}.skeleton-form-field{margin-bottom:1rem}.skeleton-detail{flex-direction:column;gap:1.5rem;display:flex}.skeleton-detail-header{align-items:center;gap:1rem;display:flex}.skeleton-detail-tabs{gap:.5rem;display:flex}.skeleton-detail-body{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:1.5rem}.skeleton-detail-info{flex-direction:column;gap:1rem;display:flex}.skeleton-detail-row{align-items:center;gap:1rem;display:flex}.skeleton-dashboard{flex-direction:column;gap:1.5rem;display:flex}.skeleton-dashboard-stats{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.skeleton-dashboard-stat{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:1.5rem}.skeleton-dashboard-charts{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=768px){.skeleton-dashboard-charts{grid-template-columns:1fr}}.skeleton-dashboard-chart{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:1.5rem}.page-container{flex-direction:column;gap:1.5rem;animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeIn;display:flex}.glass-panel-body{padding:1.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.page-title{color:var(--color-text-main);letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.5rem;font-weight:800}.page-subtitle{color:var(--color-text-muted);font-size:.95rem}.toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.toolbar-search{flex:1;min-width:250px;position:relative}.toolbar-search .search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.toolbar-search .form-input{border-radius:var(--radius-md);background-color:var(--color-bg-card);width:100%;min-height:38px;transition:all var(--transition-fast);border:1px solid var(--color-border);padding:.5rem 1rem .5rem 2.4rem;font-size:.85rem}.toolbar-search .form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4f46e526}.toolbar-search .form-input::placeholder{color:var(--color-text-muted);opacity:.6}.toolbar-filter{border-radius:var(--radius-md);appearance:auto;background-color:var(--color-bg-card);cursor:pointer;border:1px solid var(--color-border);min-width:140px;min-height:38px;transition:all var(--transition-fast);color:var(--color-text-main);padding:.4rem 2.2rem .4rem .85rem;font-size:.85rem}.toolbar-filter:hover{border-color:var(--color-text-muted)}.toolbar-filter:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4f46e526}.action-bar{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.action-bar-count{color:var(--color-text-muted);font-size:.9rem;font-weight:600}.action-bar-count span{color:var(--color-text-main)}.btn-export{min-height:36px;color:var(--color-success);border:1px solid var(--color-success);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background-color:#10b9810f;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex}.btn-export:hover{background-color:#10b9811f;transform:translateY(-1px);box-shadow:0 4px 12px #10b98133}.table-responsive{border-radius:var(--radius-md);overflow-x:auto}.table{border-collapse:separate;border-spacing:0;width:100%}.table thead{z-index:5;position:sticky;top:0}.table th{background-color:var(--color-bg-main);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--color-border);white-space:nowrap;text-align:left;padding:.85rem 1.25rem;font-size:.78rem;font-weight:700}.table td{border-bottom:1px solid var(--color-border);color:var(--color-text-main);vertical-align:middle;padding:.85rem 1.25rem;font-size:.88rem;transition:background-color .15s}.table tbody tr{transition:background-color .2s}.table tbody tr:hover td{background-color:#4f46e508}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:nth-child(2n) td{background-color:#00000003}.table tbody tr:nth-child(2n):hover td{background-color:#4f46e50a}.table th.sticky-col,.table td.sticky-col{z-index:3;background-color:var(--color-bg-card);border-right:1px solid var(--color-border);position:sticky;left:0}.table thead th.sticky-col{z-index:12}.table tbody tr:hover td.sticky-col{background-color:#4f46e508}.empty-state{text-align:center;color:var(--color-text-muted);padding:3rem 1.5rem}.empty-state-icon{opacity:.3;margin-bottom:1rem;font-size:3rem}.loading-state{color:var(--color-text-muted);justify-content:center;align-items:center;gap:.75rem;padding:3rem;font-weight:500;display:flex}.card-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.25rem;display:grid}.budget-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);background-color:var(--color-bg-secondary);padding:1.25rem;position:relative;overflow:hidden}.budget-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 24px #4f46e514}.budget-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.budget-card-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.budget-card-title{color:var(--color-text-main);font-size:1.1rem;font-weight:700}.budget-summary{border-radius:var(--radius-md);background-color:var(--color-bg-main);border:1px solid var(--color-border);grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0;padding:.85rem;display:grid}.budget-summary-item{flex-direction:column;gap:.15rem;display:flex}.budget-summary-label{color:var(--color-text-muted);font-size:.75rem}.budget-summary-value{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600}.budget-progress{margin-bottom:1rem}.budget-progress-header{justify-content:space-between;margin-bottom:.35rem;font-size:.8rem;display:flex}.budget-progress-bar{border-radius:var(--radius-full);background-color:var(--color-border);width:100%;height:6px;overflow:hidden}.budget-progress-fill{border-radius:var(--radius-full);height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.budget-card-footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:.5rem;padding-top:1rem;display:flex}.actions-cell{justify-content:flex-end;align-items:center;gap:.35rem;display:flex}.actions-cell .btn-icon{border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;padding:.35rem}.actions-cell .btn-icon:hover{transform:scale(1.1)}.actions-cell .btn-icon.text-warning:hover{color:#d97706;background-color:#f59e0b1f}.actions-cell .btn-icon.text-danger:hover{color:#dc2626;background-color:#ef44441f}.actions-cell .btn-icon.text-primary:hover{color:#4f46e5;background-color:#4f46e51a}.actions-cell .btn-icon.text-info:hover{color:#0284c7;background-color:#0ea5e91f}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.75rem;font-weight:600;line-height:1.4;display:inline-flex}.badge-xs{padding:.1rem .4rem;font-size:.65rem}.badge-info{color:#0284c7;background-color:#0ea5e91f;border:1px solid #0ea5e940}.priority-high{color:var(--color-danger);align-items:center;gap:.25rem;font-weight:600;display:inline-flex}.priority-normal{color:var(--color-text-muted);align-items:center;gap:.25rem;font-weight:600;display:inline-flex}.btn-sm{border-radius:var(--radius-sm);cursor:pointer;min-height:28px;transition:all var(--transition-fast);border:none;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.75rem;font-weight:600;display:inline-flex}.btn-sm-primary{background-color:var(--color-primary);color:#fff}.btn-sm-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-sm-warning{background-color:var(--color-warning);color:#fff}.btn-sm-warning:hover{background-color:#d97706;transform:translateY(-1px)}.btn-sm-success{background-color:var(--color-success);color:#fff}.btn-sm-success:hover{background-color:#059669;transform:translateY(-1px)}.task-link{color:var(--color-primary);white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:600;text-decoration:none}.task-link:hover{color:var(--color-primary-hover);text-decoration:underline}.task-desc{white-space:nowrap;text-overflow:ellipsis;max-width:200px;color:var(--color-text-muted);font-size:.85rem;display:block;overflow:hidden}.task-note{color:var(--color-warning);margin-top:.15rem;font-size:.75rem;display:block}.tab-nav{border-bottom:1px solid var(--color-border);background-color:var(--color-bg-secondary);display:flex;overflow-x:auto}.tab-btn{white-space:nowrap;cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-1px;padding:.85rem 1.5rem;font-size:.88rem;font-weight:600;display:inline-flex}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background-color:var(--color-bg-card)}.page-header-compact{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header-compact .page-title{margin-bottom:.15rem}.btn-add{background:linear-gradient(135deg, var(--color-primary), #6366f1);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 4px 12px #4f46e54d}.btn-add:hover{color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #4f46e566}@media (width<=768px){.page-header{flex-direction:column;align-items:flex-start}.toolbar{flex-direction:column}.toolbar-search{min-width:100%}.toolbar-filter{width:100%}.card-grid{grid-template-columns:1fr}.action-bar{flex-direction:column;align-items:flex-start;gap:.75rem}.table th,.table td{padding:.65rem .85rem;font-size:.8rem}}.text-right{text-align:right}.text-nowrap{white-space:nowrap}.font-mono{font-family:JetBrains Mono,monospace}.tiket-chat-container{background-color:var(--color-bg-main);border-radius:var(--radius-lg);border:1px solid var(--color-border);flex-direction:column;height:500px;display:flex;position:relative;overflow:hidden}.chat-banner.warning{color:#d97706;text-align:center;background-color:#f59e0b1a;border-bottom:1px solid #f59e0b33;padding:.75rem;font-size:.85rem}.chat-messages{background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%234f46e5' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");flex-direction:column;flex:1;gap:1.25rem;padding:1.5rem;display:flex;overflow-y:auto}.empty-chat{color:var(--color-text-muted);margin:auto;font-size:.95rem;font-style:italic}.chat-bubble-wrapper{gap:.75rem;max-width:85%;display:flex}.chat-bubble-wrapper.me{flex-direction:row-reverse;align-self:flex-end}.chat-bubble-wrapper.other{align-self:flex-start}.chat-avatar{color:#fff;width:36px;height:36px;box-shadow:var(--shadow-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.chat-bubble{background-color:#fff;border-radius:12px;min-width:120px;padding:.75rem 1rem;position:relative;box-shadow:0 2px 4px #0000000d}.chat-bubble-wrapper.me .chat-bubble{background-color:#e0e7ff;border-top-right-radius:0}.chat-bubble-wrapper.other .chat-bubble{border-top-left-radius:0}.tiket-chat-container.internal .chat-bubble-wrapper.me .chat-bubble{background-color:#fef3c7}.chat-sender{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.sender-name{color:var(--color-text-main);font-size:.85rem;font-weight:700}.sender-role{background-color:#0000000d;border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.chat-text{color:var(--color-text-main);white-space:pre-wrap;margin-bottom:.5rem;font-size:.95rem;line-height:1.5}.chat-time{color:var(--color-text-muted);text-align:right;margin-top:4px;font-size:.7rem;display:block}.chat-attachment{border-radius:var(--radius-sm);border:1px solid var(--color-border);margin-bottom:.5rem;display:inline-block;overflow:hidden}.chat-attachment.image img{object-fit:cover;max-width:250px;max-height:200px;transition:transform .2s;display:block}.chat-attachment.image:hover img{transform:scale(1.02)}.chat-attachment.doc{background-color:var(--color-bg-main);color:var(--color-primary);align-items:center;gap:.5rem;padding:.75rem;font-size:.85rem;font-weight:600;text-decoration:none;display:flex}.chat-attachment.doc:hover{background-color:var(--color-bg-hover)}.chat-attachment-preview{background-color:var(--color-bg-hover);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.preview-info{color:var(--color-text-main);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.remove-preview{color:var(--color-danger);cursor:pointer;background:0 0;border:none;padding:.25rem}.chat-input-area{border-top:1px solid var(--color-border);background-color:#fff;align-items:center;gap:.75rem;padding:1rem;display:flex}.chat-action-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:all .2s}.chat-action-btn:hover{background-color:var(--color-bg-main);color:var(--color-primary)}.chat-input{border:1px solid var(--color-border);border-radius:20px;flex:1;padding:.75rem 1.25rem;font-size:.95rem;transition:border-color .2s}.chat-input:focus{border-color:var(--color-primary);outline:none}.chat-send-btn{background-color:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.chat-send-btn:hover:not(:disabled){background-color:var(--color-primary-hover);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-loading{height:300px;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.reports-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=1024px){.reports-grid{grid-template-columns:280px 1fr}}.report-tabs{background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);gap:.25rem;margin-bottom:1.5rem;padding:.25rem;display:flex}.report-tab{border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;display:flex}.report-tab:hover{color:var(--color-text-main);background:#4f46e50f}.report-tab.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:0 1px 3px #00000014}.report-type-grid{grid-template-columns:1fr;gap:.75rem;display:grid}@media (width>=768px){.report-type-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1200px){.report-type-grid{grid-template-columns:repeat(3,1fr)}}.report-type-card{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);cursor:pointer;text-align:left;transition:all var(--transition-fast);align-items:center;gap:.875rem;padding:1rem 1.125rem;font-family:inherit;display:flex;position:relative}.report-type-card:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 2px 8px #4f46e51a}.report-type-card.active{border-color:var(--color-primary);background:linear-gradient(135deg,#4f46e50f,#6366f10a);box-shadow:0 2px 12px #4f46e526}.report-type-icon{color:var(--color-text-muted);transition:color var(--transition-fast);flex-shrink:0}.report-type-card.active .report-type-icon{color:var(--color-primary)}.report-type-info{flex:1;min-width:0}.report-type-name{color:var(--color-text-main);margin-bottom:.125rem;font-size:.9rem;font-weight:600}.report-type-desc{color:var(--color-text-muted);font-size:.75rem;line-height:1.35}.report-type-check{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex}.reports-menu-panel{flex-direction:column;gap:.5rem;display:flex}.report-menu-btn{border-radius:var(--radius-md);color:var(--color-text-main);text-align:left;cursor:pointer;width:100%;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;align-items:start;gap:.75rem;padding:.875rem 1rem;font-family:inherit;display:flex}.report-menu-btn svg{color:var(--color-text-muted);transition:color var(--transition-fast);margin-top:.125rem}.report-menu-btn:hover{background-color:var(--color-bg-main);color:var(--color-primary);transform:translate(4px)}.report-menu-btn:hover svg{color:var(--color-primary)}.report-menu-btn.active{background:linear-gradient(135deg, var(--color-primary), #6366f1);color:#fff;border-color:#ffffff1a;box-shadow:0 8px 20px -6px #4f46e566}.report-menu-btn.active svg{color:#fff}.report-menu-btn .report-desc{color:var(--color-text-muted);transition:color var(--transition-fast);margin-top:.125rem;font-size:.75rem;line-height:1.3}.report-menu-btn.active .report-desc{color:#fffc}.report-menu-btn .report-name{font-size:.875rem;font-weight:600}.report-preview-table-container{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-card);width:100%;max-height:500px;overflow-x:auto}.report-preview-table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}.report-preview-table th{background-color:var(--color-bg-main);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);z-index:10;padding:.875rem 1rem;font-size:.75rem;font-weight:700;position:sticky;top:0}.report-preview-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-main);vertical-align:middle;padding:.875rem 1rem}.report-preview-table tbody tr:hover{background-color:#4f46e508}.report-preview-table tbody tr:last-child td{border-bottom:none}.report-filter-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=768px){.report-filter-grid{grid-template-columns:repeat(3,1fr)}}.report-action-bar{border-t:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1.25rem;display:flex}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{text-transform:none;appearance:button;cursor:pointer;overflow:visible}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-toolbar{flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:10px;font-size:16px;display:flex}.rbc-toolbar .rbc-toolbar-label{text-align:center;flex-grow:1;padding:0 10px}.rbc-toolbar button{color:#373a3c;text-align:center;vertical-align:middle;white-space:nowrap;background:0 0;border:1px solid #ccc;border-radius:4px;margin:0;padding:.375rem 1rem;line-height:normal;display:inline-block}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px #00000020}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{white-space:nowrap;display:inline-block}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (width<=767px){.rbc-toolbar{flex-direction:column}}.rbc-event{box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;color:#fff;cursor:pointer;text-align:left;background-color:#3174ad;border:none;border-radius:5px;width:100%;margin:0;padding:2px 5px}.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected{background-color:#265985}.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{text-overflow:ellipsis;white-space:nowrap;font-size:80%;display:block;overflow:hidden}.rbc-event-overlaps{box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-right-radius:0;border-bottom-left-radius:0}.rbc-row{flex-direction:row;display:flex}.rbc-row-segment{padding:0 1px 1px}.rbc-row-segment .rbc-event-content{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{text-overflow:ellipsis;white-space:nowrap;z-index:4;color:#3174ad;background-color:#ffffff4d;height:auto;font-size:85%;font-weight:700;line-height:normal;display:block;overflow:hidden}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{-webkit-user-select:none;user-select:none;border:1px solid #ddd;flex-direction:column;flex:1 0 0;width:100%;height:100%;display:flex;position:relative}.rbc-month-header{flex-direction:row;display:flex}.rbc-month-row{flex-direction:column;flex:1 0 0;height:100%;display:flex;position:relative;overflow:hidden}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{text-align:right;flex:1 1 0;min-width:0;padding-right:5px}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{flex-direction:row;flex:1 0 0;display:flex;position:absolute;inset:0 1px 0 0;overflow:hidden}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{z-index:5;background-color:#fff;border:1px solid #e5e5e5;padding:10px;position:absolute;box-shadow:0 5px 15px #00000040}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{flex-direction:column;flex:1 0 0;display:flex;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border-spacing:0;border-collapse:collapse;border:1px solid #ddd;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{vertical-align:top;padding:5px 10px}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{text-transform:lowercase;padding-left:15px;padding-right:15px}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:left;border-bottom:1px solid #ddd;padding:3px 5px}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{flex-direction:column;min-height:100%;display:flex}.rbc-time-column .rbc-timeslot-group{flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;flex-flow:column;min-height:40px;display:flex}.rbc-time-gutter,.rbc-header-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{margin-right:10px;position:absolute;inset:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;flex-flow:column wrap;align-items:flex-start;min-height:20px;max-height:100%;display:flex;position:absolute;overflow:hidden}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;width:auto;padding-right:5px}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1 0;width:100%;height:100%;min-height:1em;line-height:1}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{z-index:10;background-color:#fff;border-right:1px solid #ddd;margin-right:-1px;position:sticky;left:0}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0 0;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{flex:1 1 0;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;color:#fff;background-color:#00000080;width:100%;padding:3px;font-size:75%;position:absolute}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;flex-direction:column;flex:1;width:100%;min-height:0;display:flex}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{z-index:4;position:relative}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{flex-direction:row;flex:none;display:flex}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row:first-child,.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;flex-direction:column;flex:1;min-width:0;display:flex}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{border-top:2px solid #ddd;flex:1 0;align-items:flex-start;width:100%;display:flex;position:relative;overflow-y:auto}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{-webkit-user-select:none;user-select:none;width:100%}.rbc-current-time-indicator{z-index:3;pointer-events:none;background-color:#74ad31;height:1px;position:absolute;left:0;right:0}.rbc-resource-grouping.rbc-time-header-content{flex-direction:column;display:flex}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.rbc-calendar{box-sizing:border-box;flex-direction:column;align-items:stretch;height:100%;display:flex}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :before,.rbc-calendar :after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full{position:absolute;inset:0;overflow:hidden}.rbc-ellipsis{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{text-overflow:ellipsis;white-space:nowrap;text-align:center;vertical-align:middle;border-bottom:1px solid #ddd;flex:1 0;min-height:0;padding:0 3px;font-size:90%;font-weight:700;overflow:hidden}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;cursor:pointer;-webkit-user-select:text;user-select:text;background:0 0;border:none;margin:0;padding:0}.rbc-row-content{-webkit-user-select:none;user-select:none;z-index:4;position:relative}.rbc-row-content-scrollable{flex-direction:column;height:100%;display:flex}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;scrollbar-width:none;height:100%;overflow-y:scroll}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.settings-container{padding:2rem}.settings-header{margin-bottom:2rem}.settings-header h1{color:var(--color-text-main);align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:1.75rem;font-weight:700;display:flex}.settings-header p{color:var(--color-text-muted);font-size:1rem}.settings-alert{border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;font-weight:500;display:flex}.settings-alert.success{color:#059669;background-color:#10b9811a;border:1px solid #10b98133}.settings-alert.error{color:#dc2626;background-color:#ef44441a;border:1px solid #ef444433}.settings-layout{flex-direction:column;gap:1.5rem;display:flex}.settings-tabs-wrapper{border-bottom:1px solid var(--color-border);width:100%;margin-bottom:1rem;padding-bottom:.5rem}.tabs-container{flex-direction:row;gap:.5rem;padding:.5rem;display:flex;overflow-x:auto}.tabs-container::-webkit-scrollbar{height:6px}.tabs-container::-webkit-scrollbar-track{background:#00000005;border-radius:4px}.tabs-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.tab-btn{text-align:center;border-radius:var(--radius-md);white-space:nowrap;transition:all var(--transition-fast);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.75rem 1.25rem;font-size:.95rem;font-weight:600}.tab-btn:hover{color:var(--color-text-main);background-color:#00000008}.tab-btn.active{background-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.settings-content{flex:1;min-width:0}.settings-form-panel{padding:2rem}.settings-form-header{border-bottom:1px solid var(--color-border);margin-bottom:1.5rem;padding-bottom:1rem}.settings-form-header h2{color:var(--color-text-main);text-transform:capitalize;font-size:1.25rem;font-weight:700}.settings-form-body{flex-direction:column;gap:1.5rem;display:flex}.field-label-wrapper{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.badge-public{color:#0284c7;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;background-color:#0ea5e926;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.field-description{color:var(--color-text-muted);margin-top:.25rem;font-size:.85rem}.color-picker-wrapper{align-items:center;gap:1rem;display:flex}.color-input{border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;width:3rem;height:2.5rem;padding:.2rem}.color-hex{color:var(--color-text-muted);font-family:monospace;font-size:.9rem;font-weight:600}.settings-form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;display:flex}.empty-settings{text-align:center;color:var(--color-text-muted);padding:3rem}.empty-icon{color:var(--color-border);margin:0 auto 1rem}.image-upload-wrapper{flex-direction:column;gap:1rem;display:flex}.image-preview{border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:#00000005;justify-content:center;align-items:center;width:100%;max-width:200px;height:120px;display:flex;position:relative;overflow:hidden}.image-preview img{object-fit:contain;max-width:100%;max-height:100%}.remove-image-btn{color:var(--color-text-main);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;opacity:0;width:28px;height:28px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background-color:#ffffffe6;justify-content:center;align-items:center;display:flex;position:absolute;top:.5rem;right:.5rem;transform:scale(.9)}.image-preview:hover .remove-image-btn{opacity:1;transform:scale(1)}.remove-image-btn:hover{color:#dc2626;background-color:#fee2e2;border-color:#fca5a5}.upload-dropzone{width:100%}.dropzone-content{border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center;background-color:#00000003;flex-direction:column;justify-content:center;align-items:center;padding:2rem 1.5rem;display:flex}.dropzone-content:hover:not(.loading){background-color:rgba(var(--color-primary-rgb), .05);border-color:var(--color-primary)}.image-upload-wrapper.dragging .dropzone-content{background-color:rgba(var(--color-primary-rgb), .1);border-color:var(--color-primary);transform:scale(1.02)}.dropzone-text{color:var(--color-text-main);pointer-events:none;margin-bottom:.25rem;font-weight:500}.dropzone-hint{color:var(--color-text-muted);pointer-events:none;font-size:.85rem}.dropzone-content.loading{opacity:.7;cursor:not-allowed}.kb-search-container{flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;display:flex}@media (width>=640px){.kb-search-container{flex-direction:row}}.kb-search-input-wrapper{flex-grow:1;width:100%;position:relative}.kb-search-input-wrapper svg{color:var(--color-text-muted);position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.kb-search-input-wrapper .kb-search-input{width:100%;font-size:.875rem;padding:.625rem .875rem .625rem 2.5rem!important}.article-list{flex-direction:column;gap:1rem;display:flex}.article-card{cursor:pointer;transition:all var(--transition-normal);border:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:1.25rem;display:flex;position:relative;overflow:hidden}.article-card:hover{box-shadow:var(--shadow-md);border-color:#4f46e54d;transform:translateY(-2px)}.article-card:before{content:"";background-color:var(--color-primary);opacity:0;width:3px;height:100%;transition:opacity var(--transition-fast);position:absolute;top:0;left:0}.article-card:hover:before{opacity:1}.article-card-title{color:var(--color-text-main);transition:color var(--transition-fast);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex}.article-card:hover .article-card-title{color:var(--color-primary)}.article-card-title svg{opacity:0;transition:all var(--transition-fast);color:var(--color-primary);transform:translate(-4px)}.article-card:hover .article-card-title svg{opacity:1;transform:translate(0)}.article-card-excerpt{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.825rem;line-height:1.5;display:-webkit-box;overflow:hidden}.badge-kb{text-transform:uppercase;border-radius:var(--radius-sm);align-items:center;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.badge-kb-info{color:var(--color-accent);background-color:#0ea5e91a;border:1px solid #0ea5e940}.badge-kb-success{color:var(--color-success);background-color:#10b9811a;border:1px solid #10b98140}.badge-kb-warning{color:var(--color-warning);background-color:#f59e0b1a;border:1px solid #f59e0b40}.badge-kb-danger{color:var(--color-danger);background-color:#ef44441a;border:1px solid #ef444440}.article-meta-row{color:var(--color-text-muted);border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.75rem;font-size:.725rem;display:flex}.article-detail-container{flex-direction:column;gap:1.25rem;display:flex}.article-detail-header{border-bottom:1px solid var(--color-border);padding-bottom:1.25rem}.article-detail-title{color:var(--color-text-main);margin-top:.5rem;font-size:1.625rem;font-weight:800;line-height:1.25}.article-detail-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:1rem;margin-top:.875rem;font-size:.75rem;display:flex}.article-detail-body{color:var(--color-text-main);border-bottom:1px solid var(--color-border);padding:.5rem 0 1.5rem;font-size:.925rem;line-height:1.625}.article-detail-body h1{border-bottom:1px solid var(--color-border);margin-top:1.5rem;margin-bottom:.75rem;padding-bottom:.375rem;font-size:1.5rem;font-weight:700}.article-detail-body h2{margin-top:1.25rem;margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.article-detail-body h3{margin-top:1rem;margin-bottom:.375rem;font-size:1.1rem;font-weight:700}.article-detail-body p{margin-bottom:1rem}.article-detail-body blockquote{border-left:4px solid var(--color-primary);background-color:var(--color-bg-main);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--color-text-muted);margin:1rem 0;padding:.75rem 1.25rem;font-style:italic}.article-detail-body ul,.article-detail-body ol{margin:.75rem 0 1rem 1.5rem}.article-detail-body li{margin-bottom:.375rem}.article-detail-body code{background-color:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-primary);padding:.125rem .375rem;font-family:JetBrains Mono,monospace;font-size:.825rem}.kb-sidebar-heading{color:var(--color-text-main);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;font-weight:700;display:flex}.kb-sidebar-heading:before{content:"";background-color:var(--color-primary);border-radius:var(--radius-full);width:4px;height:14px;display:block}.category-menu-list{flex-direction:column;gap:.375rem;display:flex}.category-menu-item{border-radius:var(--radius-md);width:100%;color:var(--color-text-muted);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-family:inherit;font-size:.825rem;font-weight:600;display:flex}.category-menu-item:hover{background-color:var(--color-bg-main);color:var(--color-text-main)}.category-menu-item.active{color:var(--color-primary);background-color:#4f46e514;border-color:#4f46e526}.category-menu-item .item-count{border-radius:var(--radius-full);color:var(--color-text-muted);background-color:#0000000a;padding:.125rem .5rem;font-family:inherit;font-size:.7rem}.category-menu-item.active .item-count{background-color:var(--color-primary);color:#fff}.popular-article-item{cursor:pointer;border-bottom:1px dashed var(--color-border);flex-direction:column;gap:.125rem;padding:.5rem 0;display:flex}.popular-article-item:last-child{border-bottom:none;padding-bottom:0}.popular-article-item h4{color:var(--color-text-main);transition:color var(--transition-fast);font-size:.825rem;font-weight:600;line-height:1.3}.popular-article-item:hover h4{color:var(--color-primary)}.popular-article-item span{color:var(--color-text-muted);font-size:.675rem}.tag-cloud-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background-color:#00000003;padding:.25rem .625rem;font-family:inherit;font-size:.675rem;font-weight:600}.tag-cloud-btn:hover{color:var(--color-primary);background-color:var(--color-bg-main);border-color:#4f46e566}.tag-cloud-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 4px 10px -3px #4f46e54d}.kb-suggestion-banner{border-radius:var(--radius-lg);color:var(--color-text-main);background-color:#4f46e50a;border:1px solid #4f46e526;gap:.75rem;padding:1rem;font-size:.75rem;line-height:1.5;display:flex}.kb-suggestion-banner svg{color:var(--color-primary);flex-shrink:0}.kb-suggestion-banner strong{color:var(--color-primary);margin-bottom:.125rem;font-weight:700;display:block}.wysiwyg-editor-container{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-card);overflow:hidden}.wysiwyg-toolbar{background-color:var(--color-bg-main);border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.25rem;padding:.5rem;display:flex}.wysiwyg-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex}.wysiwyg-btn:hover{background-color:var(--color-border);color:var(--color-text-main)}.wysiwyg-btn:active{color:var(--color-primary);background-color:#4f46e51a}.wysiwyg-divider{background-color:var(--color-border);width:1px;height:16px;margin:0 .25rem}.wysiwyg-editor{background-color:var(--color-bg-card);color:var(--color-text-main);border:none;outline:none;overflow-y:auto}.wysiwyg-editor:empty:before{content:attr(placeholder);color:var(--color-text-muted);opacity:.5;pointer-events:none;display:block}.html-content h1,.html-content h2,.html-content h3,.html-content h4,.html-content h5,.html-content h6{color:var(--color-text-main);margin-top:1.5rem;margin-bottom:.75rem;font-weight:700}.html-content h1{border-bottom:1px solid var(--color-border);padding-bottom:.375rem;font-size:1.5rem}.html-content h2{font-size:1.25rem}.html-content h3{font-size:1.1rem}.html-content p{margin-bottom:1rem;line-height:1.625}.html-content ul{margin-bottom:1rem;padding-left:1.5rem;list-style-type:disc}.html-content ol{margin-bottom:1rem;padding-left:1.5rem;list-style-type:decimal}.html-content li{margin-bottom:.375rem}.html-content img{border-radius:var(--radius-md);max-width:100%;height:auto;margin:1rem 0}.html-content blockquote{border-left:4px solid var(--color-primary);background-color:var(--color-bg-main);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--color-text-muted);margin:1rem 0;padding:.75rem 1.25rem;font-style:italic}.html-content a{color:var(--color-primary);text-decoration:underline}.html-content a:hover{color:var(--color-primary-hover)}.pagination{justify-content:center;align-items:center;gap:4px;padding:12px 0;display:flex}.pagination-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);min-width:32px;height:32px;color:var(--color-text-main);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0 6px;font-size:.8rem;display:inline-flex}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-num{font-weight:500}.pagination-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-active:hover:not(:disabled){background:var(--color-primary-hover);color:#fff;border-color:var(--color-primary-hover)}.pagination-dots{min-width:24px;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:.8rem;display:inline-flex}.datatable-wrapper{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.datatable-toolbar{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.datatable-search{flex:1;min-width:200px;max-width:360px;position:relative}.datatable-search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.datatable-search-input{height:34px;font-size:.85rem;padding-left:32px!important}.datatable-toolbar-actions{align-items:center;gap:4px;display:flex}.datatable-selection-bar{color:var(--color-primary);border-bottom:1px solid var(--color-border);background:#4f46e50f;padding:8px 16px;font-size:.8rem;font-weight:600}.datatable-col-menu{z-index:100;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);padding:8px 0;position:absolute;top:100%;right:0}.datatable-col-menu-header{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);margin-bottom:4px;padding:6px 14px;font-size:.75rem;font-weight:600}.datatable-col-menu-item{color:var(--color-text-main);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:8px;padding:6px 14px;font-size:.85rem;display:flex}.datatable-col-menu-item:hover{background:#00000008}.datatable-col-menu-item input[type=checkbox]{accent-color:var(--color-primary)}.datatable-table-container{overflow-x:auto}.datatable-table{border-collapse:collapse;width:100%}.datatable-th{background:var(--color-bg-main);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--color-border);white-space:nowrap;z-index:5;padding:.85rem 1.25rem;font-size:.78rem;font-weight:700;position:sticky;top:0}.datatable-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.datatable-th-sortable:hover{color:var(--color-text-main)}.datatable-th-content{align-items:center;gap:6px;display:flex}.sort-icon{transition:color var(--transition-fast);flex-shrink:0}.sort-idle{color:var(--color-border)}.datatable-th-sortable:hover .sort-idle{color:var(--color-text-muted)}.sort-active{color:var(--color-primary)}.datatable-check-col{text-align:center;width:40px;min-width:40px;padding:.85rem .5rem}.datatable-check-col input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer}.datatable-td{border-bottom:1px solid var(--color-border);color:var(--color-text-main);vertical-align:middle;padding:.75rem 1.25rem;font-size:.88rem;transition:background-color .15s}.datatable-td:first-child{border-left:3px solid #0000}.datatable-tr{transition:background-color .15s}.datatable-tr:hover .datatable-td{background-color:#4f46e508}.datatable-tr:last-child .datatable-td{border-bottom:none}.datatable-tr:nth-child(2n) .datatable-td{background-color:#00000003}.datatable-tr-selected .datatable-td{background-color:#4f46e50f!important}.datatable-tr-selected .datatable-td:first-child{border-left-color:var(--color-primary)}.datatable-tr-clickable{cursor:pointer}.datatable-loading,.datatable-empty{text-align:center;color:var(--color-text-muted);padding:3rem 1.25rem;font-size:.9rem}.datatable-loading{padding:0}.datatable-pagination{border-top:1px solid var(--color-border);justify-content:center;padding:4px 16px;display:flex}.breadcrumb{margin-bottom:16px}.breadcrumb-list{flex-wrap:wrap;align-items:center;gap:4px;margin:0;padding:0;list-style:none;display:flex}.breadcrumb-item{align-items:center;gap:4px;display:flex}.breadcrumb-link{color:var(--color-text-muted);transition:color var(--transition-fast);align-items:center;gap:4px;font-size:.8rem;text-decoration:none;display:inline-flex}.breadcrumb-link:hover{color:var(--color-primary)}.breadcrumb-sep{color:var(--color-border);flex-shrink:0}.breadcrumb-current{color:var(--color-text-main);font-size:.8rem;font-weight:500}.audit-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.audit-stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center;transition:box-shadow var(--transition-fast);padding:20px}.audit-stat-card:hover{box-shadow:var(--shadow-md)}.audit-stat-icon{color:var(--color-primary);margin-bottom:8px}.audit-stat-value{color:var(--color-text-main);font-size:1.5rem;font-weight:700}.audit-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.75rem}.audit-filters{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:12px;padding:16px;display:flex}.audit-total{color:var(--color-text-muted);white-space:nowrap;margin-left:auto;font-size:.85rem;font-weight:500}.audit-error{color:var(--color-danger);justify-content:center;align-items:center;gap:8px;padding:32px;font-size:.9rem;display:flex}.audit-table{border:none!important;border-radius:0!important}.audit-diff-modal{width:100%;max-width:720px}.audit-diff-meta{color:var(--color-text-main);flex-direction:column;gap:6px;margin-bottom:16px;font-size:.85rem;display:flex}.audit-diff-table{border:1px solid var(--color-border);border-radius:var(--radius-sm);max-height:400px;overflow-y:auto}.audit-diff-table table{border-collapse:collapse;width:100%;font-size:.85rem}.audit-diff-table th,.audit-diff-table td{text-align:left;border-bottom:1px solid var(--color-border);vertical-align:top;word-break:break-word;padding:10px 12px}.audit-diff-table th{background:var(--color-bg-subtle);z-index:1;font-weight:600;position:sticky;top:0}.audit-diff-table td code{font-family:var(--font-mono);background:var(--color-bg-subtle);border-radius:3px;padding:2px 6px;font-size:.8rem}.audit-diff-old{color:var(--color-danger);background:#dc26260d}.audit-diff-new{color:var(--color-success);background:#16a34a0d}.audit-diff-empty{text-align:center;color:var(--color-text-muted);padding:32px;font-size:.9rem}.file-upload-progress{background:var(--color-bg-subtle);border-radius:var(--radius-sm);margin-top:12px;padding:12px}.file-upload-progress-bar{background:var(--color-primary);border-radius:2px;height:4px;margin-bottom:8px;transition:width .3s}.file-upload-progress-text{color:var(--color-text-muted);align-items:center;gap:8px;font-size:.8rem;display:flex}.file-upload-progress-spin{animation:1s linear infinite spin}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{margin:0;font-size:1.1rem}.modal-body{padding:20px}.public-portal{background-color:var(--color-bg-main);min-height:100vh;color:var(--color-text-main);font-family:Plus Jakarta Sans,sans-serif}.public-navbar{z-index:1000;background-color:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);width:100%;transition:all .3s;position:fixed;top:0}.public-navbar-container{justify-content:space-between;align-items:center;max-width:1200px;height:80px;margin:0 auto;padding:0 2rem;display:flex}.public-navbar-logo{cursor:pointer;align-items:center;gap:12px;display:flex}.public-navbar-logo-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 8px 16px #4f46e54d}.public-navbar-logo-text{flex-direction:column;display:flex}.public-navbar-logo-title{color:var(--color-text-main);letter-spacing:-.5px;font-size:1.25rem;font-weight:800;line-height:1.2}.public-navbar-logo-subtitle{color:var(--color-text-muted);font-size:.75rem;font-weight:500}.public-navbar-links{gap:2rem;display:flex}.public-navbar-link{color:var(--color-text-muted);align-items:center;gap:8px;font-weight:600;text-decoration:none;transition:color .2s;display:flex}.public-navbar-link:hover{color:var(--color-primary)}.public-btn-login{background-color:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:50px;align-items:center;gap:8px;padding:.6rem 1.5rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 8px 16px #4f46e54d}.public-btn-login:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 12px 20px #4f46e566}.hero-section{text-align:center;padding:180px 2rem 120px;position:relative;overflow:hidden}.hero-bg-glow{z-index:0;pointer-events:none;background:radial-gradient(circle,#4f46e526 0%,#fff0 70%);width:800px;height:400px;position:absolute;top:0;left:50%;transform:translate(-50%)}.hero-content{z-index:10;max-width:800px;margin:0 auto;position:relative}.hero-title{color:var(--color-text-main);letter-spacing:-1px;margin-bottom:1.5rem;font-size:3.5rem;font-weight:800;line-height:1.1}.hero-title-highlight{background:linear-gradient(to right, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:block}.hero-subtitle{color:var(--color-text-muted);margin-bottom:3rem;font-size:1.25rem;font-weight:400;line-height:1.6}.unified-search-box{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:50px;align-items:center;max-width:650px;margin:0 auto;padding:6px 6px 6px 20px;transition:all .3s;display:flex;box-shadow:0 10px 30px #4f46e51a}.unified-search-box:focus-within{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 0 0 4px #4f46e526}.unified-search-icon{color:var(--color-primary);align-items:center;margin-right:12px;display:flex}.unified-search-input{color:var(--color-text-main);background:0 0;border:none;outline:none;flex:1;width:100%;padding:12px 0;font-family:inherit;font-size:1rem}.unified-search-input::placeholder{color:#94a3b8}.unified-search-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:40px;min-width:130px;padding:12px 28px;font-size:.95rem;font-weight:600;transition:all .3s;box-shadow:0 4px 10px #4f46e54d}.unified-search-btn:hover{transform:translateY(-1px);box-shadow:0 6px 15px #4f46e566}.public-section{max-width:1200px;margin:0 auto;padding:80px 2rem}.section-header{text-align:center;margin-bottom:3rem}.section-title{color:var(--color-text-main);margin-bottom:1rem;font-size:2.25rem;font-weight:800}.section-divider{background:linear-gradient(to right, var(--color-primary), var(--color-accent));border-radius:10px;width:80px;height:5px;margin:0 auto 1.5rem}.section-subtitle{color:var(--color-text-muted);max-width:600px;margin:0 auto;font-size:1.1rem}.kb-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;display:grid}.kb-card{background:var(--color-bg-card);border:1px solid var(--color-border);cursor:pointer;border-radius:20px;flex-direction:column;padding:2rem;transition:all .3s;display:flex}.kb-card:hover{border-color:#4f46e54d;transform:translateY(-5px);box-shadow:0 20px 40px #0000000d}.kb-icon-wrapper{width:50px;height:50px;color:var(--color-primary);background:#4f46e51a;border-radius:14px;justify-content:center;align-items:center;margin-bottom:1.5rem;transition:transform .3s;display:flex}.kb-card:hover .kb-icon-wrapper{transform:scale(1.1)rotate(5deg)}.kb-card-title{color:var(--color-text-main);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:1rem;font-size:1.25rem;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.kb-card-content{color:var(--color-text-muted);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;flex:1;margin-bottom:1.5rem;font-size:.95rem;line-height:1.6;display:-webkit-box;overflow:hidden}.kb-card-footer{color:var(--color-primary);align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.kb-card:hover .kb-card-footer{gap:12px}.monitoring-header{justify-content:space-between;align-items:flex-end;margin-bottom:2rem;display:flex}.monitoring-header-left{text-align:left}.live-badge{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133;border-radius:50px;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:600;display:flex}.pulse-dot{background-color:var(--color-success);border-radius:50%;width:10px;height:10px;position:relative}.pulse-dot:after{content:"";background-color:var(--color-success);opacity:.5;border-radius:50%;animation:1.5s ease-in-out infinite pulse;position:absolute;inset:-4px}@keyframes pulse{0%{opacity:.5;transform:scale(.8)}to{opacity:0;transform:scale(2)}}.monitoring-card-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.monitoring-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:20px;flex-direction:column;padding:1.5rem;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px #00000008}.monitoring-card:before{content:"";background:linear-gradient(to right, var(--color-primary), var(--color-accent));opacity:0;width:100%;height:4px;transition:opacity .3s;position:absolute;top:0;left:0}.monitoring-card:hover{border-color:#4f46e533;transform:translateY(-5px);box-shadow:0 20px 40px #00000014}.monitoring-card:hover:before{opacity:1}.monitoring-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;display:flex}.monitoring-card-ticket{color:var(--color-text-main);font-size:1.1rem;font-weight:800}.monitoring-card-body{flex-direction:column;flex:1;gap:.75rem;margin-bottom:1.5rem;display:flex}.monitoring-detail{flex-direction:column;gap:2px;display:flex}.monitoring-detail-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.monitoring-detail-value{color:var(--color-text-main);font-size:.95rem;font-weight:500}.monitoring-card-footer{border-top:1px dashed var(--color-border);justify-content:space-between;align-items:center;padding-top:1.25rem;display:flex}.monitoring-time{color:var(--color-text-muted);align-items:center;gap:6px;font-size:.85rem;display:flex}.tracking-result-container{max-width:650px;margin:2rem auto 0}.tracking-card{background:var(--color-bg-card);border:1px solid var(--color-primary);text-align:left;border-radius:20px;overflow:hidden;box-shadow:0 25px 50px -12px #4f46e540}.tracking-card-header{border-bottom:1px solid var(--color-border);background:linear-gradient(90deg,#4f46e50d,#0ea5e90d);justify-content:space-between;align-items:flex-start;padding:1.5rem;display:flex}.tracking-close-btn{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:50px;padding:4px 12px;font-size:.8rem;transition:all .2s}.tracking-close-btn:hover{background:var(--color-border);color:var(--color-text-main)}.tracking-card-body{border-bottom:1px solid var(--color-border);grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.5rem;display:grid}.tracking-info-item{flex-direction:column;gap:4px;display:flex}.tracking-info-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.tracking-info-value{color:var(--color-text-main);font-size:1rem;font-weight:700}.tracking-timeline{background:#00000003;padding:1.5rem}.timeline-list{flex-direction:column;gap:1rem;display:flex}.timeline-item{align-items:flex-start;gap:1rem;display:flex}.timeline-dot{background:var(--color-primary);border-radius:50%;width:12px;height:12px;margin-top:6px;position:relative}.timeline-content{flex-direction:column;gap:4px;display:flex}.timeline-status{font-weight:600}.timeline-date{color:var(--color-text-muted);font-size:.85rem}.error-alert{color:var(--color-danger);background:#ef44441a;border:1px solid #ef444433;border-radius:12px;align-items:center;gap:12px;padding:1rem 1.5rem;font-weight:600;display:flex}.kb-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#0f172ab3;justify-content:center;align-items:center;padding:2rem;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.kb-modal-content{background:var(--color-bg-card);text-align:left;border:1px solid #4f46e533;border-radius:24px;width:100%;max-width:800px;max-height:85vh;animation:.4s cubic-bezier(.16,1,.3,1) forwards slideUp;position:relative;overflow-y:auto;transform:translateY(20px);box-shadow:0 25px 50px -12px #4f46e540,0 0 40px #4f46e51a}.kb-modal-header{border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);z-index:10;background:#ffffffe6;justify-content:space-between;align-items:flex-start;padding:2rem 2.5rem 1.5rem;display:flex;position:sticky;top:0}.dark .kb-modal-header{background:#151c2ce6}.kb-modal-title{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.75rem;font-weight:800;line-height:1.3}.kb-modal-close{width:44px;height:44px;color:var(--color-text-muted);cursor:pointer;background:#64748b1a;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.kb-modal-close:hover{color:var(--color-danger);background:#ef444426;transform:rotate(90deg)}.kb-modal-body{color:var(--color-text-main);padding:2rem 2.5rem 3rem;font-size:1.05rem;line-height:1.8}.kb-modal-body ol,.kb-modal-body ul{margin-top:1.25rem;margin-bottom:1.5rem;padding-left:1.5rem}.kb-modal-body li{margin-bottom:.75rem;padding-left:.5rem}.kb-modal-body li::marker{color:var(--color-primary);font-size:1.1em;font-weight:700}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.public-badge{letter-spacing:.5px;border-radius:50px;align-items:center;padding:6px 14px;font-size:.8rem;font-weight:700;display:inline-flex}.public-badge-warning{color:#d97706;background:#f59e0b1a;border:1px solid #f59e0b33}.public-badge-info{color:#0284c7;background:#0ea5e91a;border:1px solid #0ea5e933}.public-badge-primary{color:var(--color-primary);background:#4f46e51a;border:1px solid #4f46e533}.public-badge-success{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133}.public-badge-secondary{color:#475569;background:#64748b1a;border:1px solid #64748b33}.public-footer{background:var(--color-bg-card);border-top:1px solid var(--color-border);padding-top:2px;position:relative}.footer-top-gradient{background:linear-gradient(to right, var(--color-primary), var(--color-accent), var(--color-success));height:2px;position:absolute;top:0;left:0;right:0}.footer-container{max-width:1200px;margin:0 auto;padding:5rem 2rem 2rem}.footer-grid{grid-template-columns:2fr 1fr 1fr;gap:4rem;margin-bottom:4rem;display:grid}.footer-brand{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.footer-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;margin:0;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 8px 16px #4f46e54d}.footer-title{color:var(--color-text-main);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:800}.footer-desc{color:var(--color-text-muted);max-width:400px;line-height:1.8}.footer-heading{color:var(--color-text-main);margin-bottom:1.5rem;font-size:1.1rem;font-weight:700}.footer-links,.footer-contact{margin:0;padding:0;list-style:none}.footer-links li,.footer-contact li{margin-bottom:1rem}.footer-links a{color:var(--color-text-muted);font-weight:500;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--color-primary)}.footer-contact li{color:var(--color-text-muted);font-size:.95rem}.footer-contact span{color:var(--color-text-main);margin-bottom:2px;font-weight:600;display:block}.footer-bottom{border-top:1px solid var(--color-border);justify-content:center;align-items:center;padding-top:2rem;display:flex}.footer-copy{color:var(--color-text-muted);font-size:.9rem;font-weight:500}@media (width<=768px){.public-navbar-links{display:none}.hero-title{font-size:2.5rem}.monitoring-header{flex-direction:column;align-items:flex-start;gap:1rem}.monitoring-table-container{overflow-x:auto}.footer-grid{grid-template-columns:1fr;gap:2.5rem}.tracking-card-body{grid-template-columns:1fr}}.layout-wrapper{background-image:radial-gradient(circle at 0 0,#4f46e50d 0%,#0000 40%),radial-gradient(circle at 100% 100%,#0ea5e90d 0%,#0000 40%);background-color:var(--color-bg-main);width:100%;min-height:100vh;display:flex;overflow:hidden}.sidebar{z-index:40;background-color:var(--color-sidebar-bg);border-right:1px solid var(--color-sidebar-border);flex-direction:column;width:280px;height:100vh;transition:width .3s cubic-bezier(.16,1,.3,1),transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #00000005}.sidebar.collapsed{width:80px}.sidebar-header{border-bottom:1px solid #ffffff0d;align-items:center;gap:1rem;height:76px;padding:0 1.75rem;display:flex}.custom-logo-expanded{object-fit:contain;filter:drop-shadow(0 4px 6px #0003);border-radius:8px;width:44px;height:44px;transition:all .3s}.custom-logo-collapsed{object-fit:contain;filter:drop-shadow(0 2px 4px #0003);border-radius:6px;width:36px;height:36px;transition:all .3s}.logo-icon-small{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 4px 12px #4f46e54d}.sidebar-header h2{color:#fff;letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.close-sidebar-btn{color:var(--color-sidebar-text-muted);cursor:pointer;background:0 0;border:none;margin-left:auto;display:none}.sidebar-content{flex:1;padding:1.5rem 1.25rem;overflow:hidden auto}.sidebar.collapsed .sidebar-content{padding:1.5rem .5rem}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}.sidebar-nav{flex-direction:column;gap:.5rem;display:flex}.menu-section-wrapper{margin-bottom:.25rem}.menu-section{text-transform:uppercase;color:var(--color-sidebar-text-muted);letter-spacing:.06em;padding:.5rem 1rem;font-size:.75rem;font-weight:700}.menu-section.collapsed{justify-content:center;padding:1rem 0;display:flex}.menu-section.collapsed:hover{background-color:var(--color-sidebar-hover);color:#fff;border-radius:var(--radius-md)}.menu-section-children{flex-direction:column;gap:.25rem;display:flex}.menu-item{border-radius:var(--radius-md);color:var(--color-sidebar-text-muted);cursor:pointer;white-space:nowrap;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.875rem;font-weight:500;transition:all .25s cubic-bezier(.16,1,.3,1);display:flex;position:relative}.menu-item.collapsed{justify-content:center;padding:.75rem}.menu-item.collapsed svg{margin:0}.menu-item svg{color:var(--color-sidebar-text-muted);transition:color .25s}.menu-item:hover{background-color:var(--color-sidebar-hover);color:#fff;transform:translate(4px)}.menu-item.collapsed:hover{transform:translateY(-2px)}.menu-item:hover svg{color:#fff}.menu-item.active{background-color:var(--color-sidebar-active);color:#fff;font-weight:600}.menu-item.active:before{content:"";background-color:var(--color-primary);border-radius:0 4px 4px 0;width:4px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.menu-item.active svg{color:#fff}.menu-item-wrapper{flex-direction:column;display:flex}.menu-children{border-left:1px solid #ffffff0d;flex-direction:column;gap:.25rem;margin-top:.25rem;margin-left:1.5rem;padding-left:2.75rem;display:flex}.menu-loading,.menu-empty{color:var(--color-sidebar-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 0;font-size:.875rem;display:flex}.badge{border-radius:var(--radius-full);white-space:nowrap;justify-content:center;align-items:center;gap:.35rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-none{display:none}.badge-danger{color:#dc2626;background-color:#ef444426;border:1px solid #ef44444d}.badge-primary{color:#4f46e5;background-color:#6366f126;border:1px solid #6366f14d}.badge-warning{color:#d97706;background-color:#f59e0b26;border:1px solid #f59e0b4d}.badge-success{color:#059669;background-color:#10b98126;border:1px solid #10b9814d}.main-content-wrapper{flex-direction:column;flex:1;width:calc(100% - 280px);min-height:100vh;margin-left:280px;transition:margin-left .3s cubic-bezier(.16,1,.3,1),width .3s cubic-bezier(.16,1,.3,1);display:flex}.layout-wrapper.sidebar-collapsed .main-content-wrapper{width:calc(100% - 80px);margin-left:80px}.header{z-index:30;background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;height:76px;padding:0 2rem;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:1.25rem;display:flex}.menu-toggle-btn{color:var(--color-text-main);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.5rem;transition:background-color .2s;display:block}.menu-toggle-btn:hover{background-color:var(--color-border)}.header-title h1{color:var(--color-text-main);letter-spacing:-.01em;font-size:1rem;font-weight:700}.header-right{align-items:center;gap:1.5rem;display:flex}.icon-btn{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;padding:.6rem;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex}.icon-btn:hover{color:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.notification-badge{background-color:var(--color-danger);color:#fff;border:2px solid var(--color-bg-card);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 4px #ef44444d}.profile-menu-container{position:relative}.profile-btn{background:var(--color-bg-card);border:1px solid var(--color-border);cursor:pointer;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);align-items:center;gap:.875rem;padding:.35rem 1rem .35rem .35rem;transition:all .25s cubic-bezier(.16,1,.3,1);display:flex}.profile-btn:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:700;display:flex;box-shadow:0 2px 8px #4f46e54d}.user-info{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.user-name{color:var(--color-text-main);font-size:.9rem;font-weight:700;line-height:1.2}.user-role{color:var(--color-text-muted);margin-top:2px;font-size:.75rem;font-weight:500}.profile-dropdown{z-index:50;transform-origin:100% 0;background:var(--color-bg-card);border:1px solid var(--color-border);width:240px;box-shadow:var(--shadow-lg);border-radius:var(--radius-lg);padding:.5rem;position:absolute;top:calc(100% + .75rem);right:0}.dropdown-header{border-bottom:1px solid var(--color-border);background-color:var(--color-bg-main);border-radius:calc(var(--radius-lg) - 4px) calc(var(--radius-lg) - 4px) 0 0;margin-bottom:.5rem;padding:1rem}.dropdown-header p{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.dropdown-list{flex-direction:column;gap:.25rem;list-style:none;display:flex}.dropdown-list a,.dropdown-list button{border-radius:var(--radius-sm);width:100%;color:var(--color-text-main);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.dropdown-list a:hover,.dropdown-list button:hover{background-color:var(--color-bg-main);color:var(--color-primary);transform:translate(4px)}.dropdown-divider{background-color:var(--color-border);height:1px;margin:.5rem 0}.text-danger:hover{color:var(--color-danger)!important;background-color:#ef44440d!important}.main-content{flex:1;padding:2.5rem;overflow-x:hidden}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:35;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172a99;position:fixed;inset:0}.close-sidebar-btn{color:#fff;display:block}.main-content-wrapper{width:100%;margin-left:0}.menu-toggle-btn{display:block}.user-info{display:none}.main-content{padding:1.5rem}}.notification-dropdown-container{position:relative}.notification-dropdown{z-index:50;transform-origin:100% 0;background:var(--color-bg-card);border:1px solid var(--color-border);width:320px;max-height:400px;box-shadow:var(--shadow-lg);border-radius:var(--radius-lg);flex-direction:column;display:flex;position:absolute;top:calc(100% + .75rem);right:0;overflow:hidden}.notification-header{justify-content:justify-between;border-bottom:1px solid var(--color-border);background-color:var(--color-bg-main);align-items:center;padding:1rem;display:flex}.notification-header h3{color:var(--color-text-main);font-size:.9rem;font-weight:700}.notification-header button{color:var(--color-primary);cursor:pointer;background:0 0;border:none;font-size:.75rem;font-weight:600}.notification-header button:hover{text-decoration:underline}.notification-list{flex-direction:column;max-height:300px;list-style:none;display:flex;overflow-y:auto}.notification-item{border-bottom:1px solid var(--color-border);cursor:pointer;color:inherit;flex-direction:column;padding:.85rem 1rem;text-decoration:none;transition:background-color .15s;display:flex}.notification-item:hover{background-color:var(--color-bg-main)}.notification-item.unread{border-left:3px solid var(--color-primary);background-color:#6366f10a}.notification-item-title{color:var(--color-text-main);font-size:.85rem;font-weight:700}.notification-item-message{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem;line-height:1.3}.notification-item-time{color:var(--color-text-muted);text-align:right;margin-top:.35rem;font-size:.65rem}.notification-empty{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:2.5rem 1rem;font-size:.8rem;display:flex}.app-footer{border-top:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-muted);justify-content:space-between;align-items:center;padding:12px 24px;font-size:.75rem;display:flex}.footer-right{align-items:center;gap:12px;display:flex}.footer-version{border-radius:var(--radius-full);background:#0000000a;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.7rem}.onboarding-overlay{z-index:999;background:#0000004d;position:fixed;inset:0}.onboarding-center{z-index:1000;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding-tooltip{z-index:1000;pointer-events:none;position:fixed}.onboarding-card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:auto;max-width:380px;padding:24px}.onboarding-step-indicator{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:8px;font-size:.75rem;font-weight:600}.onboarding-title{color:var(--color-text-main);margin:0 0 8px;font-size:1.1rem}.onboarding-content{color:var(--color-text-secondary);margin:0 0 16px;font-size:.9rem;line-height:1.5}.onboarding-actions{align-items:center;gap:8px;display:flex}.kbd-help{width:100%;max-width:500px}.kbd-table{border-collapse:collapse;width:100%;font-size:.9rem}.kbd-table th,.kbd-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:10px 12px}.kbd-table th{color:var(--color-text-muted);text-transform:uppercase;font-size:.8rem;font-weight:600}.kbd-table kbd{font-family:var(--font-mono);background:var(--color-bg-subtle);border:1px solid var(--color-border);box-shadow:0 1px 0 var(--color-border);text-align:center;border-radius:4px;min-width:60px;padding:3px 8px;font-size:.8rem;display:inline-block}.kbd-note{color:var(--color-text-muted);text-align:center;margin-top:16px;font-size:.8rem}.not-found-page{background-color:var(--color-bg-main);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.not-found-bg-circle{pointer-events:none;border-radius:50%;position:absolute}.not-found-bg-circle-1{background:radial-gradient(circle,#4f46e514 0%,#0000 70%);width:600px;height:600px;top:-200px;left:-200px}.not-found-bg-circle-2{background:radial-gradient(circle,#ef44440f 0%,#0000 70%);width:500px;height:500px;bottom:-150px;right:-150px}.not-found-content{z-index:1;text-align:center;max-width:520px;position:relative}.not-found-code{letter-spacing:-.05em;background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-danger) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:8rem;font-weight:800;line-height:1;animation:3s ease-in-out infinite notFoundFloat}@keyframes notFoundFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.not-found-icon{margin-bottom:1rem;font-size:3rem;display:block}.not-found-title{color:var(--color-text-main);margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.not-found-description{color:var(--color-text-muted);margin-bottom:2rem;font-size:.95rem;line-height:1.6}.not-found-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.not-found-glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-xl);transition:box-shadow var(--transition-normal);padding:3rem 2.5rem}.not-found-glass-card:hover{box-shadow:var(--shadow-lg)}.btn-home{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 4px 6px -1px #4f46e533}.btn-home:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 8px 20px #4f46e54d}.btn-back{color:var(--color-text-main);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background-color:#0000;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-back:hover{border-color:var(--color-text-muted);background-color:#00000008}.not-found-footer{text-align:center;color:var(--color-text-muted);opacity:.6;font-size:.8rem;position:absolute;bottom:2rem}@media (width<=480px){.not-found-page{padding:1rem}.not-found-glass-card{padding:2rem 1.5rem}.not-found-code{font-size:5rem}.not-found-title{font-size:1.25rem}}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:8px;width:100%;max-width:420px;display:flex;position:fixed}.toast-top-right{top:16px;right:16px}.toast-top-left{top:16px;left:16px}.toast-bottom-right{bottom:16px;right:16px}.toast-bottom-left{bottom:16px;left:16px}.toast-top-center{top:16px;left:50%;transform:translate(-50%)}.toast-bottom-center{bottom:16px;left:50%;transform:translate(-50%)}.toast-item{border-radius:var(--radius-md);background:var(--color-bg-card);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);pointer-events:auto;align-items:flex-start;gap:10px;padding:12px 14px;animation:.3s ease-out toastSlideIn;display:flex;position:relative}.toast-enter{animation:.3s ease-out toastSlideIn}.toast-exit{animation:.3s ease-in forwards toastSlideOut}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-primary)}.toast-icon{flex-shrink:0;margin-top:1px}.toast-success .toast-icon{color:var(--color-success)}.toast-error .toast-icon{color:var(--color-danger)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info .toast-icon{color:var(--color-primary)}.toast-content{flex:1;min-width:0}.toast-title{color:var(--color-text-main);margin-bottom:2px;font-size:.875rem;font-weight:600}.toast-message{color:var(--color-text-muted);font-size:.8rem;line-height:1.4}.toast-close{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:2px}.toast-close:hover{color:var(--color-text-main);background:#0000000d}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}:root{--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-secondary:#0f172a;--color-accent:#0ea5e9;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-bg-main:#f4f7f9;--color-bg-card:#fff;--color-text-main:#0f172a;--color-text-muted:#64748b;--color-border:#e2e8f0;--color-sidebar-bg:#0f172a;--color-sidebar-text:#f1f5f9;--color-sidebar-text-muted:#94a3b8;--color-sidebar-hover:#ffffff0d;--color-sidebar-active:#ffffff1a;--color-sidebar-border:#1e293b;--glass-bg:#ffffffd9;--glass-border:#ffffff80;--glass-shadow:0 10px 40px -10px #0000000d;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #00000008;--shadow-md:0 4px 12px #0000000d;--shadow-lg:0 12px 24px -4px #00000014;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-primary:#6366f1;--color-primary-hover:#818cf8;--color-secondary:#f8fafc;--color-bg-main:#0b0f19;--color-bg-card:#151c2c;--color-text-main:#f8fafc;--color-text-muted:#94a3b8;--color-border:#1e293b;--color-sidebar-bg:#0b0f19;--color-sidebar-text:#f1f5f9;--color-sidebar-text-muted:#94a3b8;--color-sidebar-hover:#ffffff0d;--color-sidebar-active:#6366f126;--color-sidebar-border:#1e293b;--glass-bg:#151c2cbf;--glass-border:#ffffff0d;--glass-shadow:0 10px 40px -10px #00000080}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg-main);color:var(--color-text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal), color var(--transition-normal);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.glass-panel:hover{box-shadow:var(--shadow-lg)}.animate-fade-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeIn}@keyframes slideDown{0%{opacity:0;height:0;transform:translateY(-10px)}to{opacity:1;height:auto;transform:translateY(0)}}.animate-slide-down{animation:.3s cubic-bezier(.16,1,.3,1) forwards slideDown}.container{width:100%;max-width:1440px;margin:0 auto;padding:0 2rem}.w-full{width:100%}.h-screen{height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media print{@page{size:A4 portrait;margin:1.5cm}.sidebar,.page-header button,.tab-btn,.btn-icon,.btn-primary,.btn-secondary,.modal-overlay,.no-print{display:none!important}.main-content-wrapper{width:100%!important;margin-left:0!important;padding:0!important}.page-container{max-width:100%!important;margin:0!important;padding:0!important}.glass-panel{break-inside:avoid;box-shadow:none!important;background:0 0!important;border:1px solid #888!important;border-radius:4px!important;margin-bottom:1.5rem!important;padding:1.5rem!important}body{color:#000!important;background-color:#fff!important;font-size:11pt!important}.print-grid{display:block!important}.print-grid>div{width:100%!important;margin-bottom:1.5rem!important}.text-muted{color:#444!important}h1,h2,h3,h4,h5,h6,strong,p{color:#000!important}.badge{color:#000!important;box-shadow:none!important;background:0 0!important;border:1px solid #000!important}a{color:#000!important;text-decoration:none!important}}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.grid{display:grid}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.col-span-1{grid-column:span 1/span 1}.col-span-2{grid-column:span 2/span 2}.col-span-3{grid-column:span 3/span 3}.col-span-4{grid-column:span 4/span 4}.col-span-5{grid-column:span 5/span 5}.col-span-6{grid-column:span 6/span 6}.col-span-7{grid-column:span 7/span 7}.col-span-8{grid-column:span 8/span 8}.col-span-9{grid-column:span 9/span 9}.col-span-10{grid-column:span 10/span 10}.col-span-11{grid-column:span 11/span 11}.col-span-12{grid-column:span 12/span 12}@media (width>=640px){.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:col-span-1{grid-column:span 1/span 1}.sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-span-3{grid-column:span 3/span 3}.sm\:col-span-4{grid-column:span 4/span 4}.sm\:col-span-5{grid-column:span 5/span 5}.sm\:col-span-6{grid-column:span 6/span 6}.sm\:col-span-7{grid-column:span 7/span 7}.sm\:col-span-8{grid-column:span 8/span 8}.sm\:col-span-9{grid-column:span 9/span 9}.sm\:col-span-10{grid-column:span 10/span 10}.sm\:col-span-11{grid-column:span 11/span 11}.sm\:col-span-12{grid-column:span 12/span 12}}@media (width>=768px){.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:col-span-4{grid-column:span 4/span 4}.md\:col-span-5{grid-column:span 5/span 5}.md\:col-span-6{grid-column:span 6/span 6}.md\:col-span-7{grid-column:span 7/span 7}.md\:col-span-8{grid-column:span 8/span 8}.md\:col-span-9{grid-column:span 9/span 9}.md\:col-span-10{grid-column:span 10/span 10}.md\:col-span-11{grid-column:span 11/span 11}.md\:col-span-12{grid-column:span 12/span 12}}@media (width>=1024px){.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-3{grid-column:span 3/span 3}.lg\:col-span-4{grid-column:span 4/span 4}.lg\:col-span-5{grid-column:span 5/span 5}.lg\:col-span-6{grid-column:span 6/span 6}.lg\:col-span-7{grid-column:span 7/span 7}.lg\:col-span-8{grid-column:span 8/span 8}.lg\:col-span-9{grid-column:span 9/span 9}.lg\:col-span-10{grid-column:span 10/span 10}.lg\:col-span-11{grid-column:span 11/span 11}.lg\:col-span-12{grid-column:span 12/span 12}}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-x-4{column-gap:1rem}.gap-x-6{column-gap:1.5rem}.gap-y-2{row-gap:.5rem}.gap-y-4{row-gap:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-6{margin-top:1.5rem}.my-4{margin-top:1rem;margin-bottom:1rem}.self-start{align-self:flex-start}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.pt-4{padding-top:1rem}.py-20{padding-top:5rem;padding-bottom:5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.border{border:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-border{border-color:var(--color-border)}.rounded-lg{border-radius:var(--radius-md)}.rounded-full{border-radius:var(--radius-full)}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.text-left{text-align:left}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-white{color:#fff}.text-text-main{color:var(--color-text-main)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.bg-primary{background-color:var(--color-primary)}.bg-bg-secondary{background-color:var(--color-bg-main)}.bg-bg-secondary\/20{background-color:#f4f7f933}[data-theme=dark] .bg-bg-secondary\/20{background-color:#0b0f1933}.bg-bg-secondary\/30{background-color:#f4f7f94d}[data-theme=dark] .bg-bg-secondary\/30{background-color:#0b0f194d}.bg-bg-secondary\/50{background-color:#f4f7f980}[data-theme=dark] .bg-bg-secondary\/50{background-color:#0b0f1980}.hover\:text-primary:hover{color:var(--color-primary)}.hover\:bg-bg-secondary:hover{background-color:var(--color-bg-main)}.hover\:bg-bg-secondary\/20:hover{background-color:#f4f7f933}[data-theme=dark] .hover\:bg-bg-secondary\/20:hover{background-color:#0b0f1933}.hover\:border-success\/50:hover{border-color:#10b98180}.hover\:border-danger\/50:hover{border-color:#ef444480}.transition-all{transition:all var(--transition-fast)}.transition-colors{transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast)}.animate-spin{animation:1s linear infinite spin}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-primary\/25{box-shadow:0 10px 15px -3px #4f46e540}.overflow-x-auto{overflow-x:auto}.form-group{flex-direction:column;gap:.25rem;margin-bottom:.875rem;display:flex}.form-group label{color:var(--color-text-main);margin:0;font-size:.8rem;font-weight:600}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-card);width:100%;color:var(--color-text-main);transition:all var(--transition-fast);padding:.5rem .75rem;font-family:inherit;font-size:.85rem}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4f46e526}.form-input:disabled{cursor:not-allowed;color:var(--color-text-muted);background-color:#00000005}.text-danger{color:var(--color-danger)}.checkbox-group{flex-direction:row;align-items:center;gap:.5rem;display:flex}.checkbox-group label{color:var(--color-text-main);cursor:pointer;margin:0;font-size:.875rem;font-weight:600}.checkbox-group input[type=checkbox]{cursor:pointer;width:1.1rem;height:1.1rem;accent-color:var(--color-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0f172a99;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--color-bg-card);border-radius:var(--radius-xl);width:100%;max-width:600px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);flex-direction:column;max-height:90vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--color-border);background-color:#00000003;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{color:var(--color-text-main);align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;display:flex}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);background-color:#00000003;justify-content:flex-end;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.btn-primary{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex;box-shadow:0 4px 6px -1px #4f46e533}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 6px 8px -1px #4f46e54d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{color:var(--color-text-main);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background-color:#0000;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex}.btn-secondary:hover:not(:disabled){border-color:var(--color-text-muted);background-color:#00000008}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-icon{cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);color:var(--color-text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:.4rem;display:inline-flex}.btn-icon:hover{color:var(--color-text-main);background-color:#0000000d}[data-theme=dark] .rbc-calendar{color:var(--color-text-main)}[data-theme=dark] .rbc-toolbar button{color:var(--color-text-main);border-color:var(--color-border)}[data-theme=dark] .rbc-toolbar button:active,[data-theme=dark] .rbc-toolbar button.rbc-active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}[data-theme=dark] .rbc-toolbar button:hover{background-color:#ffffff0d}[data-theme=dark] .rbc-month-view,[data-theme=dark] .rbc-time-view,[data-theme=dark] .rbc-agenda-view,[data-theme=dark] .rbc-month-row,[data-theme=dark] .rbc-day-bg,[data-theme=dark] .rbc-header,[data-theme=dark] .rbc-time-content,[data-theme=dark] .rbc-time-header{border-color:var(--color-border)}[data-theme=dark] .rbc-off-range-bg{background-color:#0003}[data-theme=dark] .rbc-today{background-color:#6366f11a}[data-theme=dark] .rbc-agenda-date-cell,[data-theme=dark] .rbc-agenda-time-cell,[data-theme=dark] .rbc-agenda-event-cell,[data-theme=dark] .rbc-time-slot{border-color:var(--color-border)}
