.landing-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.landing-header{background:#fffffffa;padding:2rem;text-align:center;box-shadow:0 4px 20px #0000001a}.logo-section .logo{font-size:3rem;font-weight:800;color:#667eea;margin-bottom:.5rem}.tagline{color:#666;font-size:1.2rem}.landing-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:3rem 2rem}.hero-section{text-align:center;margin-bottom:4rem;color:#fff}.hero-section h1{font-size:3rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.hero-description{font-size:1.3rem;opacity:.95}.features-section{background:#fff;border-radius:16px;padding:3rem;margin-bottom:3rem;box-shadow:0 8px 30px #00000026}.features-section h2{text-align:center;color:#667eea;font-size:2rem;margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.feature-card{text-align:center;padding:2rem;border-radius:12px;background:#f8f9fa;transition:transform .3s}.feature-card:hover{transform:translateY(-5px);box-shadow:0 6px 20px #667eea33}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#667eea;margin-bottom:.5rem}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.info-box{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 15px #0000001a}.info-box h3{color:#667eea;margin-bottom:1rem;font-size:1.3rem}.info-box ul{list-style:none;padding:0}.info-box li{padding:.5rem 0 .5rem 1.5rem;position:relative}.info-box li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700}.cta-section{background:#fff;border-radius:16px;padding:3rem;text-align:center;box-shadow:0 8px 30px #00000026}.cta-section h2{color:#667eea;font-size:2rem;margin-bottom:2rem}.cta-buttons{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.btn-cta{display:flex;align-items:center;gap:1.5rem;padding:2rem 3rem;border:none;border-radius:12px;font-size:1rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #0000001a;min-width:300px}.btn-cta:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.btn-user{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-admin{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-icon{font-size:3rem}.btn-text{text-align:left;display:flex;flex-direction:column;gap:.3rem}.btn-text strong{font-size:1.3rem}.btn-text span{font-size:.9rem;opacity:.9}.landing-footer{background:#fffffff2;padding:2rem;text-align:center;color:#666;margin-top:auto}@media (max-width: 768px){.hero-section h1{font-size:2rem}.features-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column}.btn-cta{min-width:100%}}.admin-login-page{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{width:100%;max-width:500px;position:relative}.back-button{background:#fff3;color:#fff;border:2px solid white;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;margin-bottom:2rem;transition:all .3s}.back-button:hover{background:#fff;color:#f5576c}.login-card{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 10px 40px #0003}.login-header{text-align:center;margin-bottom:2rem}.admin-icon{font-size:4rem;margin-bottom:1rem}.login-header h2{color:#333;margin-bottom:.5rem}.login-header p{color:#666;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;border:1px solid #fcc;display:flex;align-items:center;gap:.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#555}.form-group input{padding:.875rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#f5576c}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.btn-login{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f5576c66}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:2rem;text-align:center}.security-note{color:#999;font-size:.85rem}.admin-dashboard{min-height:100vh;background:#f5f7fa}.admin-header{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:2rem;box-shadow:0 4px 20px #0000001a}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-left h1{margin-bottom:.5rem}.header-left p{opacity:.9}.btn-logout{background:#fff3;color:#fff;border:2px solid white;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-logout:hover{background:#fff;color:#f5576c}.admin-nav{margin-top:1.5rem;display:flex;gap:.5rem}.nav-tab{background:#ffffff1a;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;transition:all .3s;font-weight:500}.nav-tab:hover{background:#fff3}.nav-tab.active{background:#fff;color:#f5576c}.admin-main{max-width:1400px;margin:0 auto;padding:2rem}.stats-section{margin-bottom:3rem}.stats-section h2{color:#333;margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.stat-card{background:#fff;border-radius:12px;padding:2rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 4px 15px #00000014;transition:transform .3s}.stat-card:hover{transform:translateY(-5px);box-shadow:0 6px 20px #0000001f}.stat-icon{font-size:3rem}.stat-content h3{color:#666;font-size:.9rem;margin-bottom:.5rem;font-weight:500}.stat-number{font-size:2.5rem;font-weight:700;color:#333;margin:0}.reservations-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 15px #00000014}.reservations-section h2{color:#333;margin-bottom:1.5rem}.reservations-table-container{overflow-x:auto}.reservations-table{width:100%;border-collapse:collapse}.reservations-table thead{background:#f8f9fa}.reservations-table th{padding:1rem;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #e0e0e0}.reservations-table td{padding:1rem;border-bottom:1px solid #f0f0f0}.reservations-table tbody tr:hover{background:#f8f9fa}.slot-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.btn-delete-small{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .3s}.btn-delete-small:hover{background:#c0392b;transform:scale(1.05)}.parking-slots-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 15px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h2{color:#333;margin:0}.btn-add{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-add:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.add-slot-form{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:2rem;border-left:4px solid #667eea}.add-slot-form h3{color:#333;margin-bottom:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:600;color:#555}.form-group input,.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{display:flex;gap:1rem}.btn-submit{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s}.btn-submit:hover{background:#218838;transform:translateY(-1px)}.btn-cancel{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s}.btn-cancel:hover{background:#5a6268}.slots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.day-slots{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.day-slots h4{background:#f8f9fa;margin:0;padding:1rem;color:#333;border-bottom:1px solid #e0e0e0}.slots{padding:1rem}.no-slots{text-align:center;color:#666;font-style:italic;margin:0}.slot-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;margin-bottom:.5rem;background:#f0f8ff;border-radius:6px;border-left:3px solid #667eea}.slot-item:last-child{margin-bottom:0}.slot-number{font-weight:600;color:#333}.btn-delete-slot{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .3s}.btn-delete-slot:hover{background:#ffebee;transform:scale(1.1)}.alert{padding:1rem;margin-bottom:1.5rem;border-radius:6px;font-weight:500}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.admin-nav{justify-content:center}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.form-row,.slots-grid,.stats-grid{grid-template-columns:1fr}.reservations-table{font-size:.85rem}.reservations-table th,.reservations-table td{padding:.75rem .5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fffffff2;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{color:#667eea;font-size:2.5rem;font-weight:700}.app-main{flex:1;max-width:1200px;width:100%;margin:2rem auto;padding:0 1rem}.section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000001a}.section h2{color:#667eea;margin-bottom:1.5rem;font-size:1.8rem;border-bottom:3px solid #667eea;padding-bottom:.5rem}.alert{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;font-weight:500}.alert-error{background:#fee;color:#c33;border:1px solid #fcc}.alert-success{background:#efe;color:#3c3;border:1px solid #cfc}.alert-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;opacity:.7}.alert-close:hover{opacity:1}.reservation-form{max-width:600px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.required{color:#e74c3c}.form-group input,.form-group select{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.form-hint{display:block;margin-top:.25rem;font-size:.875rem;color:#777}.form-error{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f0f0f0;color:#555}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-danger{background:#e74c3c;color:#fff;font-size:.875rem;padding:.5rem 1rem}.btn-danger:hover:not(:disabled){background:#c0392b}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.list-header h3{color:#555;font-size:1.2rem}.date-group{margin-bottom:2rem}.date-header{color:#667eea;font-size:1.3rem;margin-bottom:1rem;display:flex;align-items:center;gap:1rem}.day-badge{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500}.reservation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.reservation-card{border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:all .3s}.reservation-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:.75rem}.slot-badge{color:#fff;font-weight:600;font-size:1rem}.card-body{padding:1rem}.foodtruck-name{font-size:1.2rem;color:#333;margin-bottom:.5rem}.reservation-date{color:#666;font-size:.95rem;margin-bottom:.25rem}.created-at{color:#999;font-size:.8rem}.card-footer{padding:.75rem 1rem;background:#f9f9f9;border-top:1px solid #e0e0e0}.empty-state{text-align:center;padding:3rem;color:#999}.empty-state p{font-size:1.2rem;margin-bottom:.5rem}.empty-state-subtitle{font-size:1rem;color:#bbb}.loading{text-align:center;padding:2rem;color:#999}.app-footer{background:#fffffff2;padding:1.5rem;text-align:center;color:#666;margin-top:auto}@media (max-width: 768px){.app-header h1{font-size:1.8rem}.section{padding:1.5rem}.reservation-grid{grid-template-columns:1fr}.list-header{flex-direction:column;gap:1rem;align-items:flex-start}}.back-to-home-btn{position:fixed;top:1rem;left:1rem;padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;z-index:1000;transition:all .3s;box-shadow:0 2px 10px #667eea4d}.back-to-home-btn:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}html{scroll-behavior:smooth}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
