.app{display:flex;flex-direction:column;height:100vh}.app-main{flex:1;overflow-y:auto;padding:2rem 1rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6)}@media (max-width: 768px){.app-main{padding:1rem .5rem}}.header{background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff;padding:1rem 0;box-shadow:0 4px 12px #1e88e533;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:#fff;color:#333;font-weight:600}.header .btn:hover{background:#f3f4f6;box-shadow:0 4px 8px #00000026}.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:#333;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(--gray-200);border-top-color:#333;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}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #333333;--secondary-color: #555555;--accent-color: #0066cc;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--gray-50);color:var(--gray-900)}html,body,#root{width:100%;height:100%}button,input,textarea,select{font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;padding:.6rem 1.2rem;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:#1a1a1a;box-shadow:0 4px 12px #3333334d;transform:translateY(-2px)}.btn-secondary{background:var(--gray-200);color:var(--gray-800)}.btn-secondary:hover{background:var(--gray-300)}.btn-accent{background:var(--accent-color);color:#fff}.btn-accent:hover{background:#0052a3;box-shadow:0 4px 12px #0066cc4d;transform:translateY(-2px)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover{background:#059669;transform:translateY(-2px)}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:1.5rem;transition:all .3s ease;border:1px solid var(--gray-100)}.card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.card h3{color:var(--primary-color);margin-bottom:.5rem;font-size:1.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--gray-700)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3333331a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px #00000026}.modal-header{padding:1.5rem;border-bottom:2px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#f9fafb,#f3f4f6)}.modal-header h2{font-size:1.5rem;color:var(--primary-color);margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-500);transition:color .3s}.close-btn:hover{color:var(--gray-700)}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:1rem;background:var(--gray-50)}.alert{padding:1rem;border-radius:6px;margin-bottom:1rem}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.text-center{text-align:center}.text-muted{color:var(--gray-500);font-size:.95rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-active{background:#dcfce7;color:#166534}.status-pending{background:#fef3c7;color:#92400e}.status-completed{background:#dbeafe;color:#1e40af}.status-on-hold{background:#fee2e2;color:#991b1b}@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}.modal-footer{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--gray-200);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{flex-direction:column;align-items:stretch!important;gap:.5rem!important}.sharepoint-bar>a:first-of-type{text-align:center}.sharepoint-buttons{display:flex;gap:.5rem;justify-content:stretch}.sharepoint-buttons>*{flex:1;justify-content:center;text-align:center}.wifi-item{flex-direction:column;align-items:stretch!important;gap:.5rem!important}.wifi-item-buttons{display:flex;gap:.5rem}.wifi-item-buttons>*{flex:1}.tabs-container{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style: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}.device-card{padding:.75rem}.device-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.device-card-actions{width:100%;display:flex;gap:.5rem}.device-card-actions .btn{flex:1;justify-content:center}.credential-row{flex-direction:column;align-items:flex-start!important;gap:.25rem}.credential-value{width:100%;word-break:break-all}.input-group{flex-direction:column}.input-group input,.input-group select,.input-group button{width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem}.stat-card{padding:.75rem}.stat-card h3{font-size:1.25rem}.stat-card p{font-size:.75rem}}@media (max-width: 380px){.stats-grid{grid-template-columns:1fr!important}.btn{padding:.4rem .6rem;font-size:.85rem}.header h1{font-size:1rem}.user-info{font-size:.8rem}.user-role{padding:.2rem .5rem;font-size:.7rem}}@media (max-width: 600px){.hide-mobile,.auto-refresh-text{display:none!important}}@media (min-width: 601px){.show-mobile-only{display:none!important}}html,body{overflow-x:hidden}html{scroll-behavior:smooth}.modal-body,.tabs-container{-webkit-overflow-scrolling:touch}
