:root{--bp-mobile: 320px;--bp-mobile-lg: 480px;--bp-tablet: 768px;--bp-tablet-lg: 1024px;--bp-desktop: 1200px;--bp-desktop-lg: 1440px;--bp-ultra-wide: 1920px;--space-xs: clamp(.25rem, 1vw, .5rem);--space-sm: clamp(.5rem, 2vw, 1rem);--space-md: clamp(1rem, 3vw, 1.5rem);--space-lg: clamp(1.5rem, 4vw, 2rem);--space-xl: clamp(2rem, 5vw, 3rem);--space-xxl: clamp(3rem, 6vw, 4rem);--text-xs: clamp(.75rem, 1.5vw, .875rem);--text-sm: clamp(.875rem, 2vw, 1rem);--text-base: clamp(1rem, 2.5vw, 1.125rem);--text-lg: clamp(1.125rem, 3vw, 1.25rem);--text-xl: clamp(1.25rem, 3.5vw, 1.5rem);--text-2xl: clamp(1.5rem, 4vw, 2rem);--text-3xl: clamp(2rem, 5vw, 2.5rem);--text-4xl: clamp(2.5rem, 6vw, 3rem);--touch-min: 44px;--touch-comfortable: 48px;--touch-large: 56px;--container-mobile: 100%;--container-tablet: 768px;--container-desktop: 1200px;--container-wide: 1440px;--grid-columns: 12;--grid-gap-mobile: 1rem;--grid-gap-tablet: 1.5rem;--grid-gap-desktop: 2rem}.container{width:100%;max-width:var(--container-wide);margin:0 auto;padding:0 var(--space-md)}.container-mobile{max-width:var(--container-mobile)}.container-tablet{max-width:var(--container-tablet)}.container-desktop{max-width:var(--container-desktop)}.grid{display:grid;gap:var(--grid-gap-mobile);width:100%}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}@media (min-width: 480px){.grid{gap:var(--grid-gap-tablet)}.grid-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.grid-3{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.grid{gap:var(--grid-gap-desktop)}.grid-4{grid-template-columns:repeat(4,1fr)}}.text-responsive{font-size:var(--text-base);line-height:1.5}.heading-responsive{font-size:var(--text-2xl);line-height:1.2;font-weight:700}.subheading-responsive{font-size:var(--text-lg);line-height:1.3;font-weight:600}.touch-target{min-height:var(--touch-min);min-width:var(--touch-min);display:flex;align-items:center;justify-content:center;padding:var(--space-sm)}.touch-comfortable{min-height:var(--touch-comfortable);min-width:var(--touch-comfortable)}.touch-large{min-height:var(--touch-large);min-width:var(--touch-large)}.mobile-nav-toggle{display:none;background:none;border:none;padding:var(--space-sm);cursor:pointer;color:var(--text-primary);font-size:var(--text-lg);border-radius:var(--radius-md);transition:all .2s ease;min-height:var(--touch-comfortable);min-width:var(--touch-comfortable)}.mobile-nav-toggle:hover{background:var(--bg-light)}.mobile-nav-toggle:focus{outline:2px solid var(--primary-blue);outline-offset:2px}.mobile-nav-menu{position:fixed;top:0;left:0;width:100%;height:100vh;background:#00000080;display:none;z-index:1000}.mobile-nav-panel{position:absolute;top:0;right:0;width:80%;max-width:320px;height:100vh;background:var(--bg-white);padding:var(--space-lg);box-shadow:-4px 0 16px #0000001a;transform:translate(100%);transition:transform .3s ease}.mobile-nav-menu.open{display:block}.mobile-nav-menu.open .mobile-nav-panel{transform:translate(0)}@media (min-width: 480px){.container{padding:0 var(--space-lg)}.admin-section{padding:var(--space-lg)}}@media (min-width: 768px){.mobile-nav-toggle{display:none}.admin-section{padding:var(--space-xl)}.section-header h2{font-size:var(--text-3xl)}}@media (min-width: 1024px){.admin-section{padding:var(--space-xxl)}}@media (min-width: 1200px){.container{padding:0 var(--space-xl)}}@media (max-width: 767px){.mobile-nav-toggle{display:flex}.nav-section-buttons{display:none}.form-row{flex-direction:column;gap:var(--space-sm)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.item-card{padding:var(--space-md);margin-bottom:var(--space-sm)}.btn{min-height:var(--touch-comfortable);padding:var(--space-sm) var(--space-md);font-size:var(--text-base)}.modal-content{width:95%;max-height:90vh;overflow-y:auto}}@media (prefers-contrast: high){.btn{border-width:2px}.nav-link{border-bottom:2px solid transparent}.nav-link.active{border-bottom-color:currentColor}}@media (prefers-reduced-motion: reduce){.mobile-nav-panel{transition:none}.loading-spinner{animation:spin 1s linear infinite;animation-duration:3s}.btn{transition:none}}@media (prefers-color-scheme: dark){:root{--bg-white: #1a1a1a;--text-primary: #ffffff;--text-secondary: #a1a1aa;--border-light: #374151}}@media (display-mode: standalone){.admin-nav{padding-top:env(safe-area-inset-top)}.admin-content{padding-bottom:env(safe-area-inset-bottom)}}.pwa-install-prompt{position:fixed;bottom:20px;left:20px;right:20px;background:var(--primary-blue);color:#fff;padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:1000;transform:translateY(100%);transition:transform .3s ease}.pwa-install-prompt.show{transform:translateY(0)}.pwa-install-prompt .install-btn{background:#fff;color:var(--primary-blue);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:600;cursor:pointer;margin-top:var(--space-sm)}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e40af;background-color:snow;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#3b82f6;text-decoration:inherit}a:hover{color:#1e40af}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid #3b82f6;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:snow;color:#1e40af;cursor:pointer;transition:border-color .25s}button:hover{border-color:#1e40af}button:focus,button:focus-visible{outline:4px auto #3b82f6}@media (prefers-color-scheme: light){:root{color:#1e40af;background-color:snow}a:hover{color:#1e40af}button{background-color:snow;border-color:#3b82f6;color:#1e40af}}.auth-container{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:snow;padding:16px;box-sizing:border-box;position:relative}.auth-card{background:snow;border-radius:12px;padding:32px;box-shadow:0 20px 40px #1e40af33;width:100%;max-width:500px;text-align:center;border:2px solid #3b82f6;box-sizing:border-box}.auth-card h1{color:#1e40af;margin-bottom:8px;font-size:28px;font-weight:600}.auth-card p{color:#1e40af;margin-bottom:30px;font-size:16px}.auth-form{text-align:left}.form-group label{display:block;margin-bottom:8px;color:#1e40af;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #3b82f6;border-radius:8px;font-size:16px;transition:border-color .2s ease;box-sizing:border-box;background:snow;color:#1e40af}.form-group input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #3b82f61a}.error-message{background:#ef44441a;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid rgba(239,68,68,.3)}.login-btn,.magic-link-btn{width:100%;padding:14px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:snow;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login-btn:hover:not(:disabled),.magic-link-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #1e40af66}.login-btn:disabled,.magic-link-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{margin-top:30px;padding-top:20px;border-top:1px solid #3b82f6}.auth-footer p{color:#1e40af;font-size:12px;margin:0}.magic-link-sent{text-align:center}.magic-link-sent h1{color:#1e40af;margin-bottom:16px;font-size:24px;font-weight:600}.magic-link-sent p{color:#1e40af;margin-bottom:16px;font-size:16px;line-height:1.5}.magic-link-sent strong{color:#3b82f6;font-weight:600}.magic-link-info{margin-top:30px;padding-top:20px;border-top:1px solid #3b82f6}.magic-link-info p{font-size:14px;margin-bottom:16px;color:#1e40af;opacity:.8}.try-again-btn{padding:10px 20px;background:transparent;color:#3b82f6;border:2px solid #3b82f6;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.try-again-btn:hover{background:#3b82f6;color:snow}.auth-footer .magic-link-info{margin-top:10px;padding-top:0;border-top:none}.auth-footer .magic-link-info p{font-size:11px;opacity:.7}@media (min-width: 1200px){.auth-container{padding:24px}.auth-card{max-width:700px;padding:60px}.auth-card h1{font-size:36px;margin-bottom:16px}.auth-card p{font-size:20px;margin-bottom:40px}.form-group input{padding:18px 24px;font-size:18px;border-radius:10px}.login-btn,.magic-link-btn{padding:18px;font-size:18px;border-radius:10px}}@media (min-width: 992px) and (max-width: 1199px){.auth-container{padding:20px}.auth-card{max-width:600px;padding:50px}.auth-card h1{font-size:32px;margin-bottom:12px}.auth-card p{font-size:18px;margin-bottom:35px}.form-group input{padding:16px 20px;font-size:17px}.login-btn,.magic-link-btn{padding:16px;font-size:17px}}@media (min-width: 769px) and (max-width: 991px){.auth-container{padding:18px}.auth-card{max-width:550px;padding:45px}.auth-card h1{font-size:30px}.auth-card p{font-size:17px}}@media (max-width: 768px){.auth-container{padding:16px}.auth-card{padding:40px;max-width:500px}.auth-card h1{font-size:26px}.auth-card p{font-size:15px}}@media (max-width: 767px){.auth-container{padding:60px 12px 12px;align-items:flex-start}.auth-card{padding:24px;max-width:100%;margin:0;border-radius:8px}.auth-card h1{font-size:22px;margin-bottom:6px}.auth-card p{font-size:14px;margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{font-size:13px;margin-bottom:6px}.form-group input{padding:12px 14px;font-size:16px}.magic-link-btn,.try-again-btn{padding:14px;font-size:16px;width:100%;min-height:48px}.error-message{padding:12px;font-size:14px;margin-bottom:16px}.magic-link-sent h1{font-size:20px}.magic-link-sent p{font-size:14px;margin-bottom:16px}.magic-link-info{margin-top:16px}.magic-link-info p{font-size:13px;margin-bottom:12px}.auth-footer{margin-top:20px;padding-top:16px}.auth-footer p{font-size:11px}}@media (max-width: 480px){.auth-container{padding:40px 8px 8px}.auth-card{padding:20px;border-radius:6px}.auth-card h1{font-size:20px}.auth-card p{font-size:13px;margin-bottom:20px}.form-group input{padding:10px 12px}.magic-link-btn,.try-again-btn{padding:12px;font-size:15px;min-height:44px}.magic-link-sent h1{font-size:18px}.magic-link-sent p{font-size:13px}.magic-link-info p{font-size:12px}}@media (max-width: 767px) and (orientation: landscape){.auth-container{padding-top:20px;align-items:center}.auth-card{padding:16px 24px}.auth-card h1{font-size:18px;margin-bottom:4px}.auth-card p{font-size:12px;margin-bottom:16px}.form-group{margin-bottom:12px}.magic-link-btn,.try-again-btn{padding:10px;font-size:14px;min-height:40px}.magic-link-info{margin-top:12px}.auth-footer{margin-top:12px;padding-top:12px}}@media (hover: none) and (pointer: coarse){.form-group input{min-height:48px;padding:12px 16px;font-size:16px}.magic-link-btn,.try-again-btn{min-height:48px;padding:12px 16px;font-size:16px;touch-action:manipulation}.magic-link-btn:hover,.try-again-btn:hover{transform:none;box-shadow:none}.magic-link-btn:active,.try-again-btn:active{transform:scale(.98)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.auth-card{box-shadow:0 20px 40px #1e40af26}}@media (prefers-reduced-motion: reduce){.magic-link-btn,.try-again-btn,.form-group input{transition:none}.magic-link-btn:hover,.try-again-btn:hover{transform:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#000;line-height:1.6}.admin-dashboard{min-height:100vh;display:flex;flex-direction:column;background:#fff}.admin-nav{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d;flex-shrink:0}.nav-section-buttons{display:flex;gap:4px}.nav-section-buttons button{background:none;border:1px solid transparent;color:#374151;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:8px;position:relative}.nav-section-buttons button:hover{background:#f9fafb;color:#111827;border-color:#d1d5db}.nav-section-buttons button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.nav-section-buttons button:first-child:before{content:"🏠";margin-right:6px;font-size:12px}.nav-user-section{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center}.user-name{color:#6b7280;font-size:14px;font-weight:500}.logout-btn{padding:8px 16px;background:transparent;color:#dc2626;border:1px solid #dc2626;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#dc2626;color:#fff}.logout-btn:active{transform:scale(.98)}.admin-content{flex:1;background:#fff;min-height:calc(100vh - 64px)}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;background:#fff;color:#374151}.admin-loading .loading-spinner{width:32px;height:32px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-loading p{font-size:14px;font-weight:500;color:#6b7280}@media (max-width: 768px){.admin-nav{padding:12px 16px;flex-wrap:wrap;gap:12px}.nav-section-buttons{flex-wrap:wrap;gap:8px}.nav-section-buttons button{padding:8px 12px;font-size:13px}.nav-user-section{gap:12px}.user-name{font-size:13px}.logout-btn{padding:6px 12px;font-size:13px}.admin-content{min-height:calc(100vh - 80px)}}@media (max-width: 480px){.admin-nav{padding:8px 12px}.nav-section-buttons button{padding:6px 10px;font-size:12px}.user-name{display:none}.logout-btn{padding:6px 10px}}.nav-section-buttons button:focus,.logout-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation-duration:2s!important;animation-iteration-count:infinite!important}}@media (prefers-contrast: high){.admin-nav{border-bottom-width:2px;border-bottom-color:#000}.nav-section-buttons button{border-width:2px}.nav-section-buttons button.active{background:#000;border-color:#000}.logout-btn{border-width:2px}}.settings-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:8px;border-radius:4px;color:#666;transition:all .2s ease;margin-right:8px}.settings-btn:hover{background-color:#f0f0f0;color:#333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e5e5}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:all .2s ease}.modal-close:hover{background-color:#f0f0f0;color:#333}.admin-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.role-description{margin-top:12px;padding:12px;background-color:#f8f9fa;border-radius:4px;border-left:3px solid #007bff}.role-description p{margin:0;font-size:13px;color:#555;line-height:1.4}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid #e5e5e5}.btn-secondary{background:#f8f9fa;color:#666;border:1px solid #ddd;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.btn-secondary:hover{background:#e9ecef;color:#333}.btn-primary{background:#007bff;color:#fff;border:1px solid #007bff;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:#0056b3;border-color:#0056b3}.btn-primary:disabled{opacity:.6;cursor:not-allowed}
