*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2563eb;--primary-dark: #1d4ed8;--secondary-color: #64748b;--success-color: #059669;--error-color: #dc2626;--warning-color: #d97706;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--card-shadow-hover: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--card-shadow-subtle: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--border-radius: 8px;--border-radius-small: 6px;--text-primary: #111827;--text-secondary: #6b7280;--text-light: #9ca3af;--background-primary: #f8fafc;--background-card: #ffffff;--border-color: #e5e7eb;--border-color-light: #f3f4f6}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--background-primary);min-height:100vh;padding:15px;color:var(--text-primary);line-height:1.5;overflow-x:hidden;font-weight:400}@media (min-width: 768px){body{padding:20px}}.container{background:var(--background-card);border-radius:var(--border-radius);padding:25px;max-width:1200px;width:100%;margin:0 auto;box-shadow:var(--card-shadow);text-align:center;border:1px solid var(--border-color);position:relative}@media (min-width: 480px){.container{padding:35px}}@media (min-width: 768px){.container{padding:50px}}@media (min-width: 1024px){.container{padding:60px}}.header{margin-bottom:50px;position:relative}.title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:15px;letter-spacing:-.025em;line-height:1.2}@media (min-width: 480px){.title{font-size:2.5rem}}@media (min-width: 768px){.title{font-size:3rem}}@media (min-width: 1024px){.title{font-size:3.5rem}}.subtitle{font-size:1.1rem;color:var(--text-secondary);font-weight:400}.location-card{background:var(--background-card);border-radius:var(--border-radius);padding:32px;margin-bottom:32px;box-shadow:var(--card-shadow);position:relative;border:1px solid var(--border-color)}.location-card:hover{box-shadow:var(--card-shadow-hover)}.location-icon{font-size:3rem;margin-bottom:20px;color:var(--primary-color)}.current-location{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.last-updated{font-size:.9rem;color:var(--text-secondary);font-weight:400}.refresh-btn{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:var(--border-radius-small);background:var(--background-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);box-shadow:var(--card-shadow-subtle);border:1px solid var(--border-color)}.refresh-btn:hover{background:var(--primary-color);color:#fff;transform:rotate(180deg);box-shadow:var(--card-shadow)}.public-map-section,.admin-section{background:var(--background-card);border-radius:var(--border-radius);padding:32px;margin-bottom:32px;box-shadow:var(--card-shadow);border:1px solid var(--border-color)}.public-map-section:hover,.admin-section:hover{box-shadow:var(--card-shadow-hover)}.public-map-section h2,.admin-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:24px;text-align:center}.form-group{margin-bottom:25px;text-align:left}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:10px;font-size:1rem}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-small);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background:var(--background-card)}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.update-btn,.login-submit-btn{background:var(--primary-color);color:#fff;border:none;padding:12px 24px;border-radius:var(--border-radius-small);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;width:100%}.update-btn:hover,.login-submit-btn:hover{background:var(--primary-dark)}.login-btn,.logout-btn{background:transparent;color:var(--primary-color);border:1px solid var(--primary-color);padding:10px 20px;border-radius:var(--border-radius-small);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.login-btn:hover,.logout-btn:hover{background:var(--primary-color);color:#fff}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--background-card);margin:15% auto;padding:24px;border-radius:var(--border-radius);width:90%;max-width:400px;position:relative;box-shadow:var(--card-shadow-hover);border:1px solid var(--border-color)}.close{position:absolute;right:20px;top:15px;color:#aaa;font-size:28px;font-weight:700;cursor:pointer}.close:hover{color:#333}.login-form h2{text-align:center;margin-bottom:20px;color:#2d3748}@media (max-width: 768px){.container{margin:5px;max-width:calc(100% - 10px);border-radius:15px}.location-card,.public-map-section,.admin-section{padding:25px;border-radius:15px}.current-location{font-size:1.4rem}.public-map,.map{height:280px}.public-map-section h2,.admin-section h2{font-size:1.5rem}.form-group input{padding:14px 18px;font-size:16px}}@media (max-width: 480px){.container{border-radius:12px}.location-card,.public-map-section,.admin-section{padding:20px;border-radius:12px}.current-location{font-size:1.2rem}.refresh-btn{width:42px;height:42px;top:18px;right:18px}.public-map,.map{height:220px}.gps-btn,.update-btn,.login-submit-btn{padding:14px 20px;font-size:1rem}.public-map-section h2,.admin-section h2{font-size:1.3rem}.subtitle{font-size:1rem}}@media (max-width: 360px){.container,.location-card,.public-map-section,.admin-section{padding:15px}.public-map,.map{height:200px}}.loading{opacity:.6;pointer-events:none}.loading .refresh-btn svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:500}.message.success{background-color:#f0fdf4;color:var(--success-color);border:1px solid #bbf7d0}.message.error{background-color:#fef2f2;color:var(--error-color);border:1px solid #fecaca}.gps-section{margin-bottom:24px;text-align:center;padding:20px;background:var(--border-color-light);border-radius:var(--border-radius-small);border:1px solid var(--border-color)}.gps-btn{background:var(--success-color);color:#fff;border:none;padding:12px 24px;border-radius:var(--border-radius-small);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-bottom:12px}.gps-btn:hover{background:#047857}.gps-btn:disabled{background:var(--text-light);cursor:not-allowed;transform:none;box-shadow:none}.gps-status{font-size:1rem;color:var(--text-secondary);min-height:24px;font-weight:500}.gps-status.loading{color:#3182ce;animation:pulse 1.5s infinite}.gps-status.success{color:#38a169}.gps-status.error{color:#e53e3e}.map-container,.public-map-container{margin-top:20px;border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--card-shadow-subtle);border:1px solid var(--border-color)}.map,.public-map{height:350px;width:100%}.public-map{height:400px}.form-group input[readonly]{background-color:#f7fafc;color:#4a5568}.footer{margin-top:30px;padding-top:30px;border-top:1px solid rgba(255,255,255,.2);text-align:center}.location-info{position:relative;z-index:1}html{scroll-behavior:smooth}button:focus,input:focus{outline:2px solid #667eea;outline-offset:2px}.loading .location-icon{animation:pulse 1s infinite}.status-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success-color);margin-right:8px}.status-indicator.offline{background:var(--error-color)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.container{animation:fadeIn .6s ease-out}.header{animation:fadeInUp .8s ease-out}.location-card{animation:fadeInUp .8s ease-out .1s backwards}.public-map-section{animation:fadeInUp .8s ease-out .2s backwards}.admin-section{animation:fadeInUp .8s ease-out .3s backwards}.footer{animation:fadeInUp .8s ease-out .4s backwards}.modal{animation:fadeIn .3s ease-out}.modal-content{animation:fadeInUp .4s ease-out}.message{animation:fadeInUp .4s ease-out;font-weight:600;display:flex;align-items:center;gap:10px}.message:before{content:"";width:20px;height:20px;border-radius:50%;flex-shrink:0}.message.success:before{content:"✓";background:#38a169;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.message.error:before{content:"✕";background:#e53e3e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}button:active{transform:scale(.98)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:rgba(255,255,255,.1)}::-webkit-scrollbar-thumb{background:var(--primary-gradient);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2 0%,#667eea 100%)}.leaflet-popup-content-wrapper{border-radius:var(--border-radius-small);box-shadow:var(--card-shadow)}.leaflet-popup-content{font-family:Inter,sans-serif;font-size:1rem;font-weight:500}.main-grid{display:grid;gap:30px;grid-template-columns:1fr}@media (min-width: 1024px){.main-grid{grid-template-columns:1fr 1fr;gap:40px;align-items:start}.location-card{grid-column:1 / -1}.public-map-section{grid-column:1}.admin-section{grid-column:2}}@media (min-width: 1200px){.main-grid{gap:50px}}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:10}.loading-spinner{width:40px;height:40px;border:3px solid rgba(102,126,234,.2);border-top:3px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.section-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:25px}.section-icon{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:600;background:rgba(56,161,105,.1);color:#38a169;border:1px solid rgba(56,161,105,.2)}.status-badge.offline{background:rgba(229,62,62,.1);color:#e53e3e;border-color:#e53e3e33}.form-section{background:var(--border-color-light);border-radius:var(--border-radius-small);padding:20px;margin-bottom:20px;border:1px solid var(--border-color)}.form-section h3{margin:0 0 20px;font-size:1.1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.btn-secondary{background:rgba(255,255,255,.9);color:var(--accent-color);border:2px solid rgba(102,126,234,.3);padding:12px 24px;border-radius:var(--border-radius-small);font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-1px);box-shadow:0 6px 20px #667eea4d}.map-wrapper{position:relative;overflow:hidden;border-radius:var(--border-radius)}.map-overlay{position:absolute;top:15px;left:15px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 12px;border-radius:8px;font-size:.9rem;font-weight:600;color:var(--text-primary);z-index:1000;box-shadow:0 4px 12px #0000001a}.tooltip{position:relative;cursor:help}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:rgba(0,0,0,.9);color:#fff;padding:6px 10px;border-radius:6px;font-size:.8rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s;z-index:1000}.tooltip:hover:after{opacity:1}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--card-shadow: 0 0 0 2px #000;--background-overlay: rgba(255, 255, 255, 1);--background-card: rgba(255, 255, 255, 1)}}@media print{.refresh-btn,.admin-section,.footer{display:none!important}.container{box-shadow:none;background:white}}
