*,:after,:before{box-sizing:border-box}html{color-scheme:light;background:#fff}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#0f172a}.login-page,body{min-height:100vh;background:#fff}.login-page{position:relative;overflow:hidden}.login-bg{position:absolute;inset:-40%;background:radial-gradient(ellipse 80% 60% at 50% 0,rgba(15,23,42,.08),transparent 55%),radial-gradient(ellipse 60% 50% at 100% 100%,rgba(15,23,42,.05),transparent 50%),radial-gradient(ellipse 50% 40% at 0 80%,rgba(15,23,42,.04),transparent 45%);animation:login-bg-drift 28s ease-in-out infinite alternate}.login-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,.04) 1px,transparent 0),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 0);background-size:64px 64px;-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 45%,black 20%,transparent 70%);mask-image:radial-gradient(ellipse 70% 70% at 50% 45%,black 20%,transparent 70%);pointer-events:none;animation:login-grid-fade 1.2s ease-out forwards;opacity:0}.login-main{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem;background:transparent}.login-card{width:100%;max-width:400px;padding:2.25rem 2rem 2rem;background:rgba(255,255,255,.86);border:1px solid rgba(15,23,42,.14);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.45),0 24px 80px rgba(15,23,42,.2);animation:login-card-in .85s cubic-bezier(.22,1,.36,1) forwards;opacity:0;transform:translateY(16px);transition:border-color .35s ease,box-shadow .35s ease,background .35s ease}.login-card:focus-within{border-color:rgba(15,23,42,.22);box-shadow:inset 0 0 0 1px rgba(255,255,255,.45),0 24px 80px rgba(15,23,42,.2),0 0 0 3px rgba(15,23,42,.12)}.login-brand{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.login-mark{width:44px;height:44px;border-radius:10px;flex-shrink:0;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .3s ease;animation:login-mark-in .7s cubic-bezier(.22,1,.36,1) .15s backwards}.login-card:hover .login-mark{transform:scale(1.04)}.login-title{margin:0;font-size:1.375rem;font-weight:600;letter-spacing:-.02em;color:#0f172a}.login-subtitle{margin:.2rem 0 0;font-size:.875rem;color:rgba(15,23,42,.62);transition:color .3s ease}.login-card:hover .login-subtitle{color:rgba(15,23,42,.74)}.login-form{display:flex;flex-direction:column;gap:.35rem}.login-label{margin-top:.65rem;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:rgba(15,23,42,.58);transition:color .25s ease}.login-form:focus-within .login-label{color:rgba(15,23,42,.72)}.login-input{width:100%;margin-bottom:.15rem;padding:.75rem .9rem;font-size:1rem;color:#0f172a;background:rgba(248,250,252,.95);border:1px solid rgba(15,23,42,.16);border-radius:10px;outline:none;transition:border-color .25s ease,background .25s ease,box-shadow .25s ease,transform .2s ease}.login-input::placeholder{color:rgba(15,23,42,.36);transition:opacity .2s ease}.login-input:hover{border-color:rgba(15,23,42,.26);background:#fff}.login-input:focus{border-color:rgba(15,23,42,.45);background:#fff;box-shadow:0 0 0 3px rgba(15,23,42,.14)}.login-input:focus::placeholder{opacity:.55}.login-row{justify-content:space-between;gap:1rem;margin-top:1rem;margin-bottom:.25rem;flex-wrap:wrap}.login-check,.login-row{display:flex;align-items:center}.login-check{gap:.5rem;font-size:.8125rem;color:rgba(15,23,42,.65);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.login-check input{width:1rem;height:1rem;accent-color:#0f172a;cursor:pointer;transition:transform .2s ease}.login-check input:hover{transform:scale(1.06)}.login-link{font-size:.8125rem;color:#0f172a;text-decoration:none;border-bottom:1px solid transparent;transition:color .25s ease,border-color .25s ease,opacity .25s ease}.login-link:hover{border-bottom-color:rgba(15,23,42,.4);opacity:.9}.login-submit{margin-top:1.35rem;width:100%;padding:.85rem 1.25rem;font-size:.9375rem;font-weight:600;letter-spacing:.02em;color:#fff;background:#0f172a;border:none;border-radius:10px;cursor:pointer;transition:background .3s ease,color .3s ease,transform .2s ease,box-shadow .3s ease}.login-submit:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 12px 32px rgba(15,23,42,.2)}.login-submit:active{transform:translateY(0);transition-duration:.1s}.login-foot{margin:1.75rem 0 0;padding-top:1.5rem;border-top:1px solid rgba(15,23,42,.14);font-size:.75rem;text-align:center;color:rgba(15,23,42,.52);transition:color .35s ease}.login-foot p{margin:0}.login-foot-logo{width:78px;height:auto;display:block;margin:0 auto .65rem}.login-card:hover .login-foot{color:rgba(15,23,42,.64)}.login-foot-muted{color:rgba(15,23,42,.74)}.auth-check-card{width:100%;max-width:320px;padding:2rem 1.75rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;background:rgba(255,255,255,.86);border:1px solid rgba(15,23,42,.14);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.45),0 24px 80px rgba(15,23,42,.2);animation:login-card-in .85s cubic-bezier(.22,1,.36,1) forwards;opacity:0;transform:translateY(16px)}.auth-check-spinner{width:40px;height:40px;border:3px solid rgba(15,23,42,.12);border-top-color:#0f172a;border-radius:50%;animation:auth-check-spin .95s cubic-bezier(.22,1,.36,1) infinite}.auth-check-text{margin:0;font-size:.875rem;color:rgba(15,23,42,.62)}@keyframes auth-check-spin{to{transform:rotate(1turn)}}@keyframes login-bg-drift{0%{transform:translate(0) scale(1)}to{transform:translate(2%,3%) scale(1.05)}}@keyframes login-grid-fade{to{opacity:1}}@keyframes login-card-in{to{opacity:1;transform:translateY(0)}}@keyframes login-mark-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.auth-check-card,.auth-check-spinner,.login-bg,.login-card,.login-check input,.login-grid,.login-input,.login-link,.login-mark,.login-submit{animation:none!important;transition:none!important}.login-card{opacity:1;transform:none}.login-grid{opacity:1}.auth-check-card{opacity:1;transform:none}}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:#f1f5f9;position:relative}.app-sidebar{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 1rem;background:#0f172a;color:#e2e8f0;position:relative;z-index:30}.app-mobile-nav-backdrop,.app-mobile-nav-btn{display:none}.app-sidebar-brand,.app-sidebar-tenant{border-bottom:1px solid rgba(148,163,184,.25);padding-bottom:1rem}.app-sidebar-tenant{display:flex;flex-direction:column;gap:.35rem}.app-tenant-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8}.app-tenant-select{width:100%;padding:.5rem .55rem;font-size:.8125rem;color:#e2e8f0;background:rgba(15,23,42,.55);border:1px solid rgba(148,163,184,.35);border-radius:8px;outline:none;cursor:pointer}.app-tenant-select:focus-visible{border-color:rgba(96,165,250,.65);box-shadow:0 0 0 2px rgba(59,130,246,.25)}.app-tenant-select:disabled{opacity:.65;cursor:not-allowed}.app-tenant-select option{color:#0f172a;background:#fff}.app-tenant-error{margin:0;font-size:.75rem;color:#fecaca}.app-sidebar-brand-head{display:flex;align-items:center;gap:.7rem}.app-sidebar-logo{width:36px;height:36px;border-radius:8px;object-fit:contain;background-color:rgb(15,23,42);padding:.2rem}.app-sidebar-title{margin:0;font-weight:700}.app-sidebar-subtitle{margin:.3rem 0 0;color:#94a3b8;font-size:.85rem}.app-nav{display:flex;flex-direction:column;gap:.35rem}.app-nav-link{border-radius:8px;padding:.55rem .75rem;color:#cbd5e1;text-decoration:none}.app-nav-link:hover{background:rgba(148,163,184,.15);color:#fff}.app-nav-link-active{background:rgba(59,130,246,.28);color:#fff}.app-signout{margin-top:auto;border:1px solid rgba(148,163,184,.35);background:transparent;color:#e2e8f0;padding:.6rem .75rem;border-radius:8px;cursor:pointer}.app-signout:hover{background:rgba(148,163,184,.16)}.app-content-wrap{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1 1;min-height:0;display:flex;flex-direction:column;padding:1.5rem}.app-footer{display:flex;align-items:center;gap:.6rem;padding:.8rem 1.5rem;border-top:1px solid #cbd5e1;font-size:.875rem;color:#475569;background:#fff}.app-footer-logo{width:30px;height:30px;object-fit:contain}.dashboard-header{margin-bottom:1.1rem}.dashboard-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.dashboard-header-text{flex:1 1;min-width:0}.dashboard-refresh-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;margin-top:.05rem;padding:0;border:1px solid #cbd5e1;border-radius:10px;background:#fff;color:#475569;cursor:pointer}.dashboard-refresh-btn:hover:not(:disabled){background:#f8fafc;color:#0f172a;border-color:#94a3b8}.dashboard-refresh-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.dashboard-refresh-btn:disabled{opacity:.45;cursor:not-allowed}.dashboard-refresh-icon{width:1.2rem;height:1.2rem}@keyframes dashboard-refresh-spin{to{transform:rotate(1turn)}}.dashboard-refresh-icon--spinning{animation:dashboard-refresh-spin .75s linear infinite}.dashboard-title{margin:0;font-size:1.5rem}.dashboard-subtitle{margin:.35rem 0 0;color:#64748b}.dashboard-inline-error{margin:.65rem 0 0;font-size:.875rem;color:#b91c1c}.dashboard-cards{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.info-card{border:1px solid #dbe3ef;border-radius:12px;background:#fff;padding:1rem;display:flex;align-items:center;gap:.75rem}.info-card-head{flex-shrink:0}.info-card-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:10px;background:#eef2ff;color:#334155}.info-card-icon svg{width:1.1rem;height:1.1rem}.info-card-content{min-width:0}.info-card-label{margin:0;color:#64748b;font-size:.9rem}.info-card-value{margin:.35rem 0 0;font-size:1.6rem;font-weight:700;line-height:1.1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:-.01em}.dashboard-panels{display:grid;grid-template-columns:2fr 1fr;grid-gap:1rem;gap:1rem;align-items:start}.panel-map{min-width:0}.panel-stack{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem;min-width:0}.panel{border:1px solid #dbe3ef;border-radius:12px;background:#fff;padding:1rem}.panel-title{margin:0 0 .75rem;font-size:1.05rem}.charger-map{position:relative;height:320px;border-radius:12px;border:1px solid #cbd5e1;background:#f8fafc;overflow:hidden}.charger-map-square{width:100%;aspect-ratio:1/1;height:auto}.charger-map-loading{height:100%;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.9rem}.charger-map-leaflet{height:100%;width:100%}.charger-map .leaflet-container{font-family:inherit}.charger-map .leaflet-div-icon{background:transparent;border:none}.charger-marker{position:relative;width:14px;height:14px;border-radius:999px;background:#16a34a;border:2px solid #fff;box-shadow:0 2px 8px rgba(15,23,42,.25)}.charger-marker-live{background:#2563eb}.charger-marker-offline{background:#dc2626}.charger-marker-in-use{background:#ca8a04}.charger-marker span{position:absolute;left:16px;top:-6px;font-size:.65rem;font-weight:600;letter-spacing:.02em;color:#0f172a;white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.85)}.energy-value{margin:0 0 .65rem;font-size:1.35rem;font-weight:700}.energy-bar{width:100%;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}.energy-bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#0ea5e9)}.energy-breakdown{margin:.85rem 0 0;padding-left:1rem;color:#334155}.utilization-panel{display:flex;flex-direction:column;align-items:center;gap:.55rem;text-align:center}.utilization-panel .panel-title{width:100%;margin-bottom:0}.utilization-box-value{margin:0;font-size:1.2rem;font-weight:700;line-height:1.1}.utilization-gauge{width:100%;max-width:210px;margin-top:0}.utilization-gauge svg{width:100%;height:auto;display:block}.utilization-gauge-track{fill:none;stroke:#dbe3ef;stroke-width:10;stroke-linecap:round}.utilization-gauge-progress{fill:none;stroke:#2563eb;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .35s ease}.utilization-gauge-needle{stroke:#0f172a;stroke-width:2.5;stroke-linecap:round}.utilization-gauge-center{fill:#0f172a}.chargers-page{display:flex;flex-direction:column;flex:1 1;min-height:0;width:100%;max-width:none}.chargers-page-main{flex:1 1;min-height:0;display:flex;flex-direction:column}.chargers-header{margin-bottom:1.25rem}.chargers-title{margin:0;font-size:1.5rem}.chargers-subtitle{margin:.35rem 0 0;color:#64748b;font-size:.95rem}.chargers-subtitle strong{font-weight:600;color:#475569}.chargers-muted{margin:0;color:#64748b}.chargers-error{margin:0;color:#b91c1c}.chargers-table-wrap{flex:1 1;min-height:0;border:1px solid #dbe3ef;border-radius:12px;background:#fff;overflow:auto}.chargers-table{width:100%;border-collapse:collapse;font-size:.875rem}.chargers-table td,.chargers-table th{padding:.65rem .85rem;text-align:left;border-bottom:1px solid #e2e8f0}.chargers-table th{background:#f8fafc;font-weight:600;color:#475569}.chargers-table tbody tr:last-child td{border-bottom:none}.chargers-table tbody tr:hover td{background:#f8fafc}.chargers-connector-row-charge-point td:first-child{font-weight:600;color:#334155}.chargers-name-link{color:#0f172a;font-weight:600;text-decoration:none}.chargers-name-link:focus-visible,.chargers-name-link:hover{text-decoration:underline}.chargers-status-badge{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;line-height:1.25;border:1px solid transparent}.chargers-status-badge-offline{color:#991b1b;background:#fef2f2;border-color:#fecaca}.chargers-status-badge-idle{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.chargers-td-actions,.chargers-th-actions{width:1%;white-space:nowrap;vertical-align:middle}.chargers-actions{display:flex;flex-wrap:nowrap;align-items:center;gap:.35rem}.chargers-action-btn{flex-shrink:0;padding:.35rem .6rem;font-size:.8125rem;font-weight:500;color:#0f172a;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;cursor:pointer}.chargers-action-btn:hover:not(:disabled){background:#e2e8f0}.chargers-action-btn:disabled{opacity:.55;cursor:not-allowed}.chargers-action-btn-danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.chargers-action-btn-danger:hover:not(:disabled){background:#fee2e2}.chargers-code{font-size:.8rem;color:#334155}.chargers-toolbar{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.chargers-toolbar .chargers-header{margin-bottom:0;flex:1 1;min-width:200px}.chargers-add-btn{flex-shrink:0;margin-top:.15rem;padding:.55rem 1rem;font-size:.875rem;font-weight:600;color:#fff;background:#0f172a;border:none;border-radius:8px;cursor:pointer}.chargers-add-btn:hover:not(:disabled){background:#1e293b}.chargers-add-btn:disabled{opacity:.55;cursor:not-allowed}.chargers-back-link{text-decoration:none}.chargers-search-bar{flex-shrink:0;display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem;width:100%;max-width:min(28rem,100%)}.chargers-search-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.chargers-search-input{width:100%;padding:.5rem .65rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;background:#fff}.chargers-search-input:focus{outline:none;border-color:#64748b;box-shadow:0 0 0 2px rgba(15,23,42,.1)}.chargers-search-input::placeholder{color:#94a3b8}.chargers-connector-legend{margin:.15rem 0 0;font-size:.72rem;color:#64748b;line-height:1.35}.chargers-connector-dots{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.35rem}.chargers-connector-dots-empty{font-size:.8125rem;color:#94a3b8}.chargers-connector-dot{width:.55rem;height:.55rem;border-radius:999px;flex-shrink:0;box-shadow:0 0 0 1px rgba(15,23,42,.12);cursor:default}.chargers-connector-dot--available{background:#16a34a}.chargers-connector-dot--in-use{background:#eab308}.chargers-connector-dot--faulted{background:#dc2626}.sessions-filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:0}.sessions-filter-field{display:flex;flex-direction:column;gap:.35rem;width:100%;max-width:15rem}.sessions-export-actions{display:flex;align-items:center;gap:.5rem}.sessions-table-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:.9rem;flex-wrap:wrap;margin-bottom:.85rem}.sessions-table-toolbar .sessions-filters{flex:1 1;min-width:16rem}.sessions-export-btn{display:inline-flex;align-items:center;gap:.4rem}.sessions-export-btn-primary{margin-top:0}.sessions-export-icon{width:.95rem;height:.95rem;flex-shrink:0}.chargers-detail-grid{margin:0;padding:1rem;border:1px solid #dbe3ef;border-radius:12px;background:#fff;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:.9rem 1.1rem;gap:.9rem 1.1rem}.chargers-detail-grid dt{margin:0;font-size:.75rem;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.chargers-detail-grid dd{margin:.25rem 0 0;font-size:.95rem;color:#0f172a;word-break:break-word}.chargers-detail-copy-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.chargers-detail-copy-btn{margin-top:0;padding:.35rem .65rem;font-size:.75rem}.chargers-detail-title{margin:0 0 .6rem;font-size:1rem;color:#0f172a}.chargers-detail-title:not(:first-child){margin-top:1.15rem}.chargers-detail-top-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem;align-items:start}@media (max-width:980px){.chargers-detail-top-grid{grid-template-columns:1fr}}.modal-root{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-backdrop{position:absolute;inset:0;border:none;padding:0;margin:0;background:rgba(15,23,42,.45);cursor:pointer}.modal-panel{position:relative;z-index:1;width:100%;max-width:420px;background:#fff;border-radius:12px;box-shadow:0 0 0 1px rgba(15,23,42,.08),0 24px 80px rgba(15,23,42,.22)}.modal-panel--wide{max-width:520px}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1rem .75rem;border-bottom:1px solid #e2e8f0}.modal-title{margin:0;font-size:1.125rem;font-weight:600}.modal-close{line-height:1;width:2rem;height:2rem;border:none;border-radius:8px;background:transparent;font-size:1.35rem;color:#64748b;cursor:pointer}.modal-close:hover:not(:disabled){background:#f1f5f9;color:#0f172a}.modal-body,.modal-form{display:flex;flex-direction:column}.modal-body{padding:1rem;gap:.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem 1rem;border-top:1px solid #e2e8f0}.modal-label{margin:0;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.modal-input{width:100%;padding:.55rem .65rem;font-size:.9375rem;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;background:#fff}.modal-input:focus{outline:none;border-color:#64748b;box-shadow:0 0 0 2px rgba(15,23,42,.12)}.modal-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.modal-field{display:flex;flex-direction:column;gap:.35rem}.modal-error{margin:0 0 .35rem;padding:.5rem .65rem;background:#fef2f2;color:#b91c1c}.modal-btn,.modal-error{border-radius:8px;font-size:.875rem}.modal-btn{padding:.5rem 1rem;font-weight:600;cursor:pointer;border:none}.modal-btn-primary{color:#fff;background:#0f172a}.modal-btn-primary:hover:not(:disabled){background:#1e293b}.modal-btn-secondary{color:#334155;background:#f1f5f9;border:1px solid #cbd5e1}.modal-btn-secondary:hover:not(:disabled){background:#e2e8f0}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.modal-map-wrap{height:260px;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden;background:#f8fafc}.modal-map-wrap-disabled{pointer-events:none;opacity:.65}.modal-map-wrap .leaflet-container{font-family:inherit}.modal-map-wrap .leaflet-div-icon{background:transparent;border:none}.modal-map-leaflet{height:100%;width:100%;cursor:crosshair}.modal-map-hint{margin:0 0 .35rem;font-size:.8125rem;color:#64748b;line-height:1.45}.modal-coords{color:#334155}.modal-coords,.modal-coords-muted{margin:.35rem 0 0;font-size:.8125rem}.modal-coords-muted{color:#94a3b8}.location-picker-marker{width:16px;height:16px;border-radius:999px;background:#ea580c;border:2px solid #fff;box-shadow:0 2px 8px rgba(15,23,42,.35)}@media (max-width:1024px){.app-shell{grid-template-columns:1fr}.app-mobile-nav-btn{position:fixed;top:.8rem;left:.8rem;z-index:50;width:2.5rem;height:2.5rem;padding:.45rem;border:none;border-radius:8px;background:#0f172a;cursor:pointer;display:inline-flex;flex-direction:column;justify-content:center;gap:.25rem;box-shadow:0 6px 20px rgba(15,23,42,.22)}.app-mobile-nav-btn span{display:block;width:100%;height:2px;border-radius:999px;background:#e2e8f0}.app-mobile-nav-backdrop{display:block;position:fixed;inset:0;z-index:35;border:none;margin:0;padding:0;background:rgba(15,23,42,.42);opacity:0;pointer-events:none;transition:opacity .2s ease}.app-mobile-nav-backdrop-open{opacity:1;pointer-events:auto}.app-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:40;width:min(85vw,320px);max-width:100%;overflow-y:auto;gap:1rem;transform:translateX(-100%);transition:transform .22s ease;box-shadow:12px 0 30px rgba(2,6,23,.24)}.app-sidebar-open{transform:translateX(0)}.app-main{padding-top:4rem}.app-signout{margin-top:0}.dashboard-cards,.dashboard-panels,.modal-row{grid-template-columns:1fr}}