:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#ffffffde;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9;color:#213547}}.app-loading{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center}.app-loading h2{margin:1rem 0 .5rem;font-size:1.5rem}.app-loading p{margin:0;opacity:.9}.main-portal{min-height:100vh;background:#f8fafc}.portal-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.header-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.portal-header h1{color:#1e293b;font-size:1.8rem;font-weight:700;margin:0}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#64748b;font-size:.9rem}.location-name{background:#3b82f6;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-weight:600;font-size:.8rem!important}.logout-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.logout-button:hover{background:#dc2626}.portal-main{max-width:1200px;margin:0 auto;padding:2rem}.portal-content{background:#fff;border-radius:.5rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.dashboard-placeholder{text-align:center;padding:3rem 2rem}.dashboard-placeholder h2{color:#1e293b;font-size:2rem;margin-bottom:1rem}.dashboard-placeholder>p{color:#64748b;font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.coming-soon{margin-top:3rem;background:#f1f5f9;padding:2rem;border-radius:.5rem;border:1px solid #e2e8f0}.coming-soon h3{color:#1e293b;margin-bottom:1.5rem;font-size:1.3rem}.coming-soon ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.coming-soon li{background:#fff;padding:1rem;border-radius:.375rem;border:1px solid #e2e8f0;color:#475569;font-weight:500;transition:all .2s}.coming-soon li:hover{background:#f8fafc;border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center;padding:1rem}.portal-header h1{font-size:1.5rem}.user-info{flex-direction:column;gap:.5rem}.portal-main{padding:1rem}.portal-content{padding:1.5rem}.dashboard-placeholder{padding:2rem 1rem}.dashboard-placeholder h2{font-size:1.5rem}.coming-soon ul{grid-template-columns:1fr}}#root{margin:0;padding:0;text-align:left}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.auth-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem;width:100vw;background:#f5f5f5}.auth-content{background:#fff;border-radius:16px;padding:4rem;box-shadow:0 4px 6px -1px #0000001a;width:50vw;max-width:none}.qr-code-container{width:100%}.qr-code-content{display:flex;align-items:center;justify-content:space-between;gap:2rem;min-height:300px}.qr-code-text{flex:1;text-align:left;max-width:60%}.qr-code-text h2{color:#1f2937;font-size:clamp(1.5rem,4vw,3rem);line-height:1.4;margin:0;font-weight:600}.qr-code-image{flex-shrink:0;display:flex;justify-content:center;align-items:center}.qr-code{width:clamp(180px,20vw,280px);height:clamp(180px,20vw,280px);border-radius:12px;box-shadow:0 4px 8px #0000001a;display:flex;align-items:center;justify-content:center}.qr-code svg{width:100%;height:100%;border-radius:12px}.qr-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;width:clamp(180px,20vw,280px);height:clamp(180px,20vw,280px);border:2px dashed #e5e7eb;border-radius:12px;background:#f9fafb;text-align:center}.qr-loading p{margin-top:1rem;color:#6b7280;font-size:.9rem}.qr-error{display:flex;flex-direction:column;align-items:center;justify-content:center;width:clamp(180px,20vw,280px);height:clamp(180px,20vw,280px);border:2px dashed #fca5a5;border-radius:12px;background:#fef2f2;text-align:center;padding:1rem}.qr-error p{color:#dc2626;font-size:.9rem;margin-bottom:1rem}.retry-qr-btn{background:#dc2626;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;transition:background-color .2s}.retry-qr-btn:hover{background:#b91c1c}.mobile-auth-container{text-align:center}.mobile-auth-header{margin-bottom:2rem}.mobile-icon{color:#3b82f6;margin-bottom:1rem}.mobile-auth-header h2{color:#1f2937;margin-bottom:.5rem}.mobile-auth-header p{color:#6b7280}.mobile-auth-content{margin:2rem 0}.auth-info{margin-bottom:2rem}.auth-info h3{color:#1f2937;margin-bottom:1rem}.auth-info p{color:#6b7280;line-height:1.6}.login-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;background:#3b82f6;color:#fff;border:none;padding:1rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1.1rem;font-weight:600;transition:all .2s;margin-bottom:2rem}.login-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.security-note{background:#f3f4f6;padding:1rem;border-radius:6px;margin-bottom:2rem}.security-note p{margin:0;font-size:.9rem;color:#4b5563;line-height:1.5}.mobile-instructions{text-align:left;padding-top:1rem;border-top:1px solid #e5e7eb}.mobile-instructions h3{color:#1f2937;margin-bottom:1rem;font-size:1rem}.mobile-instructions ol{color:#6b7280;line-height:1.6}.mobile-instructions ol li{margin-bottom:.5rem}.auth-success{text-align:center;padding:2rem}.success-icon{color:#10b981;margin-bottom:1rem}.auth-success h2{color:#1f2937;margin-bottom:1rem}.auth-success p{color:#6b7280;margin-bottom:.5rem}.loading-dots{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-dots span{color:#6b7280;font-size:.9rem}.dots{display:flex;gap:.25rem}.dots div{width:8px;height:8px;border-radius:50%;background:#3b82f6;animation:loading-bounce 1.4s ease-in-out infinite both}.dots div:nth-child(1){animation-delay:-.32s}.dots div:nth-child(2){animation-delay:-.16s}@keyframes loading-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.auth-error{text-align:center;padding:2rem}.error-icon{color:#ef4444;margin-bottom:1rem}.auth-error h2{color:#1f2937;margin-bottom:1rem}.error-message{color:#ef4444;background:#fef2f2;padding:1rem;border-radius:6px;margin-bottom:2rem;border:1px solid #fecaca}.retry-button{background:#ef4444;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:background-color .2s}.retry-button:hover{background:#dc2626}.auth-loading{text-align:center;padding:3rem}.auth-loading h2{margin:1rem 0 .5rem;color:#1f2937}.auth-loading p{color:#6b7280}.device-detection-loading{text-align:center;padding:3rem}.device-detection-loading p{margin-top:1rem;color:#6b7280}.spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.spinner.small{width:16px;height:16px;border-width:2px}.spinner.large{width:48px;height:48px;border-width:4px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.auth-container{padding:1rem}.auth-content{padding:2rem}.qr-code-content{flex-direction:column;gap:2rem;text-align:center}.qr-code-text{text-align:center}.qr-code-text h2{font-size:1.5rem}}.dashboard{min-height:100vh;background:#f8fafc}.dashboard-nav{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.05);padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.nav-brand h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0;margin-bottom:.25rem}.location-name{font-size:.875rem;color:#6b7280;font-weight:500}.nav-tabs{display:flex;gap:.5rem;background:#0000000d;padding:.25rem;border-radius:12px}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;color:#6b7280;font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.nav-tab:hover{color:#374151;background:#ffffff80}.nav-tab.active{background:#fff;color:#1f2937;box-shadow:0 1px 3px #0000001a}.nav-user{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem;font-weight:500}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:none;background:#ef44441a;color:#dc2626;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#ef444426}.dashboard-main{padding:2rem;max-width:1400px;margin:0 auto}.page-content{animation:fadeIn .3s ease}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.page-header p{color:#6b7280;font-size:1rem;margin:0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid rgba(0,0,0,.05)}.dashboard-card h3{font-size:.875rem;font-weight:600;color:#6b7280;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.metric{font-size:2rem;font-weight:700;color:#1f2937}.placeholder-content{background:#fff;border-radius:12px;padding:3rem;text-align:center;box-shadow:0 1px 3px #0000001a;border:1px solid rgba(0,0,0,.05)}.placeholder-content p{color:#6b7280;font-size:1rem;margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.dashboard-nav{padding:.75rem 1rem}.nav-tabs{gap:.25rem}.nav-tab{padding:.5rem .75rem;font-size:.8rem}.nav-tab span{display:none}.dashboard-main{padding:1.5rem}}@media (max-width: 768px){.dashboard-nav{flex-direction:column;gap:1rem;padding:1rem}.nav-tabs{order:-1;width:100%;justify-content:center}.nav-user{width:100%;justify-content:space-between}.dashboard-main{padding:1rem}.dashboard-grid{grid-template-columns:1fr;gap:1rem}.page-header h1{font-size:1.5rem}}
