@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@400;500;600;700&family=Instrument+Sans:wght@400;500;600&family=Space+Mono:wght@400;700&display=swap";.app{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;overflow-y:auto;padding:1.5rem;background:var(--bg-base)}@media (max-width: 768px){.app-main{padding:1rem .5rem}}.header{background:linear-gradient(135deg,#0c2b2f,#0b1230);color:#fff;padding:1rem 0;box-shadow:0 2px 12px #0006;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.header h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:.5px}.header p{margin:0;font-size:.9rem;opacity:.9}.header-left{display:flex;flex-direction:column;gap:.25rem}.header-right{display:flex;align-items:center;gap:1rem}.header .btn{background:#ffffff1f;color:var(--text-primary);font-weight:600}.header .btn:hover{background:#fff3;box-shadow:0 4px 8px #0000004d}.user-info{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.user-role{background:#fff3;padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.header-right{width:100%;justify-content:space-between}.header h1{font-size:1.25rem}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h2{font-size:1.75rem;color:var(--text-primary);margin:0}.page-header-actions{display:flex;gap:1rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:var(--gray-700);margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem}.loading{display:flex;justify-content:center;align-items:center;padding:2rem;color:var(--gray-500)}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.header h1{font-size:1.1rem}.page-header{flex-direction:column}.page-header-actions{width:100%}.page-header-actions .btn{width:100%;justify-content:center}}.touch-draggable,.touch-draggable *{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}:root{--bg-base: #0e131c;--bg-raised: #1a212e;--bg-panel: rgba(255,255,255,.05);--bg-hover: rgba(255,255,255,.09);--bg-input: #141a26;--text-primary: #eef2f7;--text-muted: #7e8896;--text-faint: #586170;--accent: #4fe3d3;--accent-dim: rgba(79,227,211,.15);--accent-glow: rgba(79,227,211,.25);--accent-2: #8b8bff;--accent-2-dim: rgba(139,139,255,.15);--gradient-signature: linear-gradient(100deg, #4fe3d3, #8b8bff);--border: rgba(255,255,255,.12);--border-subtle: rgba(255,255,255,.08);--success: #4fe3d3;--success-bg: rgba(79,227,211,.12);--danger: #f87171;--danger-bg: rgba(248,113,113,.12);--warning: #fbbf24;--warning-bg: rgba(251,191,36,.12);--info: #8b8bff;--info-bg: rgba(139,139,255,.12);--radius-card: 18px;--radius-input: 10px;--radius-pill: 100px;--radius-sm: 8px;--shadow-card: 0 2px 8px rgba(0,0,0,.3);--shadow-card-hover: 0 8px 24px rgba(0,0,0,.4), 0 0 0 1px var(--accent);--shadow-glow-teal: 0 0 20px rgba(79,227,211,.2);--shadow-glow-violet: 0 0 20px rgba(139,139,255,.15);--font-display: "Bricolage Grotesque", sans-serif;--font-body: "Instrument Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "Space Mono", monospace;--primary-color: var(--accent);--secondary-color: var(--accent-2);--accent-color: var(--accent);--success-color: var(--success);--danger-color: var(--danger);--warning-color: var(--warning);--gray-50: var(--bg-raised);--gray-100: rgba(255,255,255,.05);--gray-200: rgba(255,255,255,.09);--gray-300: rgba(255,255,255,.12);--gray-400: var(--text-faint);--gray-500: var(--text-muted);--gray-600: var(--text-muted);--gray-700: var(--text-primary);--gray-800: var(--text-primary);--gray-900: var(--text-primary)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-base);color:var(--text-primary);font-size:15px;line-height:1.5}html,body,#root{width:100%;height:100%}html,body{overflow-x:hidden}html{scroll-behavior:smooth}button{font-family:inherit;color:inherit}input,textarea,select{font-family:inherit}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;z-index:0}h1,h2,h3{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-weight:600}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.03em}h2{font-size:1.4rem}h3{font-size:1.15rem}h4{font-size:1rem;font-weight:600;color:var(--text-primary)}h5{font-size:.9rem;font-weight:600;color:var(--text-muted)}h6{font-size:.8rem;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}a{color:var(--accent);text-decoration:none}a:hover{color:#6eeee0}code{font-family:var(--font-mono);background:var(--bg-panel);border:1px solid var(--border-subtle);padding:.15rem .4rem;border-radius:4px;font-size:.85em;color:var(--accent)}.btn{border:none;border-radius:var(--radius-pill);font-size:.9rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .25s ease;padding:.6rem 1.4rem;display:inline-flex;align-items:center;gap:.5rem;position:relative}.btn-primary{background:var(--gradient-signature);color:#06110f}.btn-primary:hover{box-shadow:var(--shadow-glow-teal);filter:brightness(1.1);transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-accent{background:var(--accent);color:#06110f}.btn-accent:hover{box-shadow:var(--shadow-glow-teal);filter:brightness(1.1);transform:translateY(-1px)}.btn-success{background:var(--accent);color:#06110f}.btn-success:hover{box-shadow:var(--shadow-glow-teal);filter:brightness(1.1);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#1a0505}.btn-danger:hover{filter:brightness(1.15);transform:translateY(-1px)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:none}.btn-sm{padding:.35rem .85rem;font-size:.8rem}.card{background:linear-gradient(160deg,var(--bg-raised),transparent);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:1.5rem;transition:all .3s ease;border:1px solid var(--border-subtle)}.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-3px);border-color:var(--accent)}.card h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.15rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.4rem;font-weight:500;color:var(--text-muted);font-size:.85rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.7rem .85rem;border:1px solid var(--border);border-radius:var(--radius-input);font-size:.95rem;transition:border-color .25s,box-shadow .25s;background:var(--bg-input);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-faint)}input,textarea,select{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}input::placeholder,textarea::placeholder{color:var(--text-faint)}select option{background:var(--bg-raised);color:var(--text-primary)}input[type=checkbox]{accent-color:var(--accent);width:auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:var(--bg-raised);border-radius:var(--radius-card);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;border:1px solid var(--border)}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;background:var(--bg-panel)}.modal-header h2{font-size:1.3rem;color:var(--text-primary);margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-faint);transition:color .2s}.close-btn:hover{color:var(--accent)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:.75rem;background:var(--bg-panel)}.alert{padding:.85rem 1rem;border-radius:var(--radius-input);margin-bottom:1rem;font-size:.9rem}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(248,113,113,.2)}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(79,227,211,.2)}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(251,191,36,.2)}table{border-collapse:collapse;width:100%}thead tr{background:var(--bg-panel)!important;border-bottom:1px solid var(--border)!important}th{color:var(--text-muted)!important;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-mono)}tr{border-bottom:1px solid var(--border-subtle)!important}tbody tr:hover{background:var(--bg-hover)!important}td{color:var(--text-primary)}.status-badge{display:inline-block;padding:.3rem .75rem;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.status-active{background:var(--success-bg);color:var(--success)}.status-pending{background:var(--warning-bg);color:var(--warning)}.status-completed{background:var(--info-bg);color:var(--info)}.status-on-hold{background:var(--danger-bg);color:var(--danger)}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.text-center{text-align:center}.text-muted{color:var(--text-muted);font-size:.9rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-gradient{background:var(--gradient-signature);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.eyebrow{font-family:var(--font-mono);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}@media (max-width: 1024px){.container{padding:1rem}.modal{width:95%;max-width:none;margin:1rem;max-height:90vh}.modal-body{max-height:60vh}}@media (max-width: 768px){.container{padding:.75rem}.btn{justify-content:center}.modal{width:100%;margin:0;border-radius:0;max-height:100vh;height:100vh}.modal-header{position:sticky;top:0;z-index:10;background:var(--bg-raised)}.modal-footer{position:sticky;bottom:0;background:var(--bg-raised);border-top:1px solid var(--border);z-index:10}.modal-body{max-height:calc(100vh - 140px);padding:1rem}.form-group{margin-bottom:.75rem}input,select,textarea{font-size:16px!important}.card{padding:1rem}table{display:block;overflow-x:auto;white-space:nowrap}th,td{padding:.5rem .75rem;font-size:.85rem}button,.btn,a,select{min-height:44px}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}h4{font-size:1rem}}@media (max-width: 480px){.container{padding:.5rem}.modal-body{padding:.75rem}.btn{padding:.5rem .75rem;font-size:.9rem}.btn-sm{padding:.35rem .5rem;font-size:.8rem}.modal{width:100%;max-width:100%;margin:0;border-radius:0;max-height:100vh;height:100vh}.modal-overlay{padding:0}.modal-footer{flex-direction:column;gap:.5rem}.modal-footer .btn{width:100%;justify-content:center}}@media (hover: none) and (pointer: coarse){button:hover,.btn:hover,.card:hover{transform:none;box-shadow:inherit}.copy-btn,.action-btn{min-width:48px;min-height:48px;padding:.75rem}}@media (max-width: 600px){.project-header-actions{flex-direction:column;width:100%}.project-header-actions .btn{width:100%;justify-content:center}.sharepoint-bar,.wifi-item{flex-direction:column;align-items:stretch!important;gap:.5rem!important}.tabs-container{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs-container::-webkit-scrollbar{display:none}.tabs{display:flex;min-width:max-content}.tab-btn{white-space:nowrap;flex-shrink:0;padding:.75rem 1rem}.device-list-header{flex-direction:column;gap:.75rem}.device-list-controls{width:100%;flex-wrap:wrap}.device-list-controls>*{flex:1;min-width:120px}.form-grid,.form-row{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem}.hide-mobile,.auto-refresh-text{display:none!important}}@media (max-width: 380px){.stats-grid{grid-template-columns:1fr!important}.btn{padding:.4rem .6rem;font-size:.85rem}}@media (min-width: 601px){.show-mobile-only{display:none!important}}.modal-body,.tabs-container{-webkit-overflow-scrolling:touch}
