*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#0a2a43;overflow-x:hidden;overflow-y:auto}.app-wrapper{display:flex;height:100vh;width:100%;overflow:hidden;background:#f5f7fb}.sidebar{position:fixed;top:0;left:0;height:100vh;width:250px;background:linear-gradient(180deg,#0a2a43,#0f3a66);color:#fff;display:flex;flex-direction:column;transition:all .3s ease;z-index:1000;border-right:1px solid rgba(255,255,255,.1);box-shadow:2px 0 8px #00000040}.sidebar.collapsed{width:80px}.sidebar.mobile-hidden{left:-250px}.sidebar.mobile-visible{left:0}.sidebar-header{display:flex;align-items:center;gap:10px;padding:16px;height:60px}.sidebar-logo{width:36px;height:36px;object-fit:contain;transition:all .3s ease}.sidebar-title{font-size:1.1rem;font-weight:600;white-space:nowrap}.sidebar.collapsed .sidebar-header{justify-content:center;padding:16px 0}.sidebar.collapsed .sidebar-logo{width:34px;height:34px}.sidebar-nav{flex:1;display:flex;flex-direction:column;margin-top:10px}.nav-item{display:flex;align-items:center;gap:12px;color:#d6e0f5;padding:10px 16px;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .2s,color .2s;border-left:4px solid transparent}.nav-item:hover,.nav-item.active{background:#ffffff1a;color:#fff;border-left:4px solid #4a90e2}.icon{flex-shrink:0;min-width:22px}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.logout{width:100%;text-align:left;background:none;border:none;color:#f55;display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;border-radius:6px;transition:background .2s}.logout:hover{background:#ffffff14}.topbar{position:fixed;top:0;left:250px;right:0;height:60px;background:linear-gradient(90deg,#0f3a66,#007bff);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem;z-index:1200;transition:left .3s ease;border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 2px 8px #00000040}.topbar.collapsed{left:80px}.topbar-left{display:flex;align-items:center;gap:10px}.menu-btn{background:none;border:none;color:#fff;font-size:22px;cursor:pointer}.portal-title{font-size:18px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{display:flex;align-items:center;gap:15px}.logout-btn{background:#fff;color:#007bff;border:none;padding:6px 10px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,box-shadow .2s}.logout-btn:hover{background:#e9ecef;box-shadow:0 2px 6px #0003}.main-section{flex:1;min-height:100vh;margin-left:250px;margin-top:60px;transition:margin-left .3s ease;display:flex;flex-direction:column;background:#f5f7fb;width:calc(100% - 250px)}.main-section.collapsed{margin-left:80px;width:calc(100% - 80px)}.page-body{flex:1;overflow-y:auto;padding:1.5rem;height:calc(100vh - 60px)}.nav-item.active{background:#ffffff1a;color:#fff;position:relative}.nav-item.active:before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background-color:#4a90e2;border-radius:0 4px 4px 0}.nav-item .icon{margin-left:8px}.login-wrapper{display:flex;justify-content:center;align-items:center;height:100vh;background:#f5f7fb;padding:1rem}@media (max-width: 1024px){.main-section.overlay-active{margin-left:0!important}}@media (max-width: 768px){.sidebar{z-index:1100}.topbar{left:0}.main-section{margin-left:0;width:100%}.sidebar.collapsed .nav-item span{display:none}.nav-item.active:hover:after{content:attr(data-tooltip);position:absolute;left:60px;background:#0a2a43;color:#fff;padding:4px 8px;border-radius:4px;white-space:nowrap;font-size:12px}}*/{.nav-item.active:hover:after{content:attr(data-tooltip);position:absolute;left:60px;background:#0a2a43;color:#fff;padding:4px 8px;border-radius:4px;white-space:nowrap;font-size:12px}}html,body{margin:0;padding:0;font-family:Segoe UI,Tahoma,sans-serif;background:#f5f8ff;color:#0f172a}.landing-root{overflow-x:hidden}.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}.reveal.visible{opacity:1;transform:translateY(0)}.login-icon{position:fixed;top:28px;right:36px;width:42px;height:42px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#2563eb;cursor:pointer;box-shadow:0 8px 24px #2563eb40;transition:transform .2s ease,box-shadow .2s ease;z-index:10}.login-icon:hover{transform:translateY(-2px);box-shadow:0 12px 30px #2563eb59}.login-tooltip{position:absolute;top:52px;background:#0f172a;color:#fff;padding:6px 10px;font-size:12px;border-radius:6px;opacity:0;pointer-events:none;transition:opacity .2s ease}.login-icon:hover .login-tooltip{opacity:1}@keyframes popIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.hero{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient(#f5f8ffbf,#f5f8ffbf),url(../iot-fleet.png) center / cover no-repeat;filter:contrast(1.15) saturate(1.1);padding:100px 20px 60px}.hero-inner{max-width:1200px;margin:auto;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}.logo-wrapper{display:flex;justify-content:center}.hero-content{max-width:760px}.hero h1{font-size:42px;font-weight:700;margin-bottom:18px}.hero p{font-size:17px;line-height:1.7;color:#334155}@keyframes logoPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo-wrapper img{height:56px;margin-bottom:32px}.hero-image{height:360px;background:url(../iot-fleet.png) no-repeat center;background-size:contain;animation:floatDevice 4.5s ease-in-out infinite}@keyframes floatDevice{50%{transform:translateY(-14px)}}.features{display:flex;flex-direction:column;gap:22px}.features-wrapper{max-width:1200px;margin:80px auto;padding:0 20px;display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center}.feature{background:linear-gradient(180deg,#fff,#f9fbff);padding:22px 26px;border-radius:16px;box-shadow:0 6px 18px #0000000f;border-left:4px solid #2563eb;transition:transform .35s ease,box-shadow .35s ease}.feature:hover{transform:translateY(-6px);box-shadow:0 14px 36px #2563eb2e}.features-image{height:420px;background:url(../phone.png) no-repeat center;background-size:contain}.how-it-works{max-width:1100px;margin:80px auto;text-align:center;padding:0 20px}.system-flow{height:280px;margin:36px auto;background:url(../system-flow.png) no-repeat center;background-size:contain;animation:zoomFlow 8s ease-in-out infinite}@keyframes zoomFlow{50%{transform:scale(1.03)}}.steps{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.step{background:#fff;padding:26px;border-radius:18px;box-shadow:0 14px 36px #00000014}.benefits{max-width:1200px;margin:90px auto;padding:0 20px;text-align:center}.benefits h2{font-size:20px;font-weight:700;margin-bottom:50px;color:#2563eb}.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}.benefit-card{background:#fff;padding:28px 22px;border-radius:20px;box-shadow:0 12px 32px #00000014;transition:transform .3s ease,box-shadow .3s ease}.benefit-card:hover{transform:translateY(-6px);box-shadow:0 18px 42px #2563eb2e}.benefit-card img{height:54px;margin-bottom:18px}.benefit-card h4{font-size:14px;font-weight:700;margin-bottom:8px;color:#1e293b}.benefit-card p{font-size:14px;color:#1e293b;line-height:1.6}@media (max-width: 900px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.benefits-grid{grid-template-columns:1fr}}.landing-footer{text-align:center;padding:24px;font-size:13px;color:#64748b;background:#fff}.benefits-list{list-style:none;padding:0;margin-top:36px;display:flex;flex-direction:column;gap:20px}.benefits-list li{background:#fff;padding:18px 22px;border-radius:16px;font-size:15px;box-shadow:0 10px 26px #00000014;transition:transform .25s ease,box-shadow .25s ease}.benefits-list li:hover{transform:translateY(-4px);box-shadow:0 16px 36px #2563eb2e}@media (max-width: 900px){.hero-inner,.features-wrapper{grid-template-columns:1fr;text-align:center}}.contact{max-width:900px;margin:100px auto 70px;padding:0 20px;text-align:center}.contact h2{font-size:32px;font-weight:700;margin-bottom:14px;color:#0f172a}.contact-sub{font-size:16px;color:#475569;max-width:640px;margin:0 auto 40px;line-height:1.7}.contact-card{background:linear-gradient(180deg,#fff,#f8fbff);border-radius:22px;padding:38px 34px;box-shadow:0 18px 42px #00000014;display:grid;gap:28px}.contact-item{display:flex;align-items:flex-start;gap:18px;text-align:left}.contact-item span{min-width:44px;height:44px;font-size:22px;background:#e0ebff;color:#2563eb;border-radius:50%;display:flex;align-items:center;justify-content:center}.contact-item strong{font-size:15px;color:#0f172a}.contact-item p{margin-top:4px;font-size:14.5px;color:#475569;line-height:1.6}.contact-card{position:relative}.contact-card-icon{position:absolute;right:20px;bottom:20px;width:64px;height:64px;opacity:.15;pointer-events:none}.dashboard-container{padding:24px;background:#f4f7fb;min-height:100vh;width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-header h1{margin:0;font-size:24px}.dashboard-header p{margin:4px 0 0;color:#666}.header-actions{display:flex;align-items:center;gap:12px}.community-select{padding:6px 10px}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.kpi-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 10px #0000000f}.kpi-card span{color:#666}.kpi-card h2{margin-top:8px;font-size:32px}.kpi-card.success h2{color:#16a34a}.kpi-card.danger h2{color:#dc2626}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}.panel{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 10px #0000000f}.panel h3{margin-bottom:16px}.bar-wrapper{display:flex;align-items:flex-end;gap:40px;height:200px;padding:20px}.bar{width:80px;display:flex;align-items:flex-end;justify-content:center;border-radius:8px 8px 0 0;color:#fff;font-weight:700}.bar.online{background:#22c55e}.bar.offline{background:#ef4444}.device-list{max-height:300px;overflow-y:auto}.device-row{padding:10px 0;border-bottom:1px solid #eee}.device-row span{display:block;font-size:12px;color:#777}.switch{position:relative;width:40px;height:20px}.switch input{opacity:0}.slider{position:absolute;background:#ccc;border-radius:20px;top:0;left:0;right:0;bottom:0}.slider:before{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:.3s}.switch input:checked+.slider{background:#2563eb}.switch input:checked+.slider:before{transform:translate(20px)}.auto-text{font-size:14px}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width: 480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--primary-1: #0b6fbf;--primary-2: #00a4d3;--card-bg: #ffffff;--muted: #6b7280;--sidebar-bg: #052338}*{box-sizing:border-box;font-family:Inter,Arial,sans-serif}html,body,#root{height:100%;margin:0;background:linear-gradient(180deg,#f7fbff,#eef6fb);color:#1e293b;font-size:14px;line-height:1.5}.layout{display:flex;height:100vh;background:var(--sidebar-bg)}.sidebar{background:linear-gradient(180deg,#052338,#041c2d);color:#fff;padding-top:18px;width:250px;flex-shrink:0;transition:width .2s ease;box-shadow:2px 0 8px #00000014}.sidebar.collapsed{width:72px}.sidebar nav{display:flex;flex-direction:column;gap:6px;padding:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;color:#ffffffe6;text-decoration:none;border-radius:8px;margin:6px;transition:all .2s ease}.nav-item .icon{width:20px;height:20px;opacity:.9}.nav-item:hover{background:#ffffff14}.nav-item.active{background:#ffffff1f;border-left:4px solid var(--primary-2)}.sidebar.collapsed .nav-item{justify-content:center;padding:10px;margin:8px 0}.sidebar.collapsed .nav-item span{display:none}.topbar{height:64px;background:linear-gradient(90deg,#052338,#0b6fbf);display:flex;align-items:center;justify-content:space-between;padding:0 16px;color:#fff;box-shadow:0 4px 12px #0000001a;border:none}.topbar-left{display:flex;align-items:center;gap:12px}.top-logo{width:36px;height:36px;border-radius:6px;background:#fff;padding:4px}.app-title{font-weight:700;letter-spacing:.3px}.menu-btn{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer}.topbar-right{display:flex;align-items:center;gap:12px}.user-email{opacity:.9}.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.18);color:#fff;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#ffffff26}.main{flex:1;display:flex;flex-direction:column;background:linear-gradient(180deg,#f7fbff,#eef6fb);margin:0;overflow:auto}.content{padding:24px 28px}.welcome-card{background:var(--card-bg);padding:24px;border-radius:12px;border:1px solid #e9eef2;box-shadow:0 6px 18px #1018280d;transition:box-shadow .2s ease}.welcome-card:hover{box-shadow:0 8px 22px #10182814}h2{letter-spacing:.5px;margin:6px 0 18px;color:var(--primary-1);font-size:20px;font-weight:700}label{display:block;text-align:left;margin:6px 0 4px;color:var(--muted);font-size:13px}input{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #e6eef2;margin-bottom:8px;transition:border-color .2s}input:focus{border-color:var(--primary-1);outline:none}.btn{width:100%;padding:12px 18px;border-radius:6px;border:none;background:linear-gradient(90deg,var(--primary-1),var(--primary-2));color:#fff;font-weight:600;margin-top:10px;cursor:pointer;box-shadow:0 6px 12px #0b6fbf2e;transition:all .2s ease}.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.login-outer{display:flex;align-items:center;justify-content:center;height:100vh}.login-card{width:420px;background:var(--card-bg);border-radius:12px;padding:28px;text-align:center;box-shadow:0 8px 24px #10182814}.logo{width:150px;margin:6px auto 12px;display:block}.row{display:flex;justify-content:space-between;align-items:center;margin:8px 0}.remember{font-size:13px;color:var(--muted)}.footer{font-size:12px;color:var(--muted);margin-top:14px}.error{color:#c53030;margin-top:6px}@media (max-width: 768px){.sidebar{position:fixed;z-index:10;height:100vh;left:0;top:0;transform:translate(-100%)}.sidebar.active{transform:translate(0)}.main{margin-left:0}.topbar{position:sticky;top:0;z-index:9}select{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #e6eef2;margin-bottom:8px;background:#fff;font-size:14px;color:#1e293b;transition:border-color .2s}select:focus{border-color:var(--primary-1);outline:none}}
