@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;700&display=swap');
* { margin:0; padding:0; box-sizing:border-box; font-family:'Plus Jakarta Sans', sans-serif; }
body { background-color: #f8fafc; background-image: radial-gradient(at 0% 0%, rgba(0,0,0,0.02) 0, transparent 50%), radial-gradient(at 100% 100%, rgba(0,0,0,0.02) 0, transparent 50%); color: #1e293b; display: flex; flex-direction: column; min-height: 100vh; }
.booking-wrap { flex: 1; display: flex; align-items: center; justify-content: center; padding: 2rem; }
.booking-card { background: #ffffff; padding: 3rem; border-radius: 24px; box-shadow: 0 20px 40px -10px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.05); max-width: 500px; width: 100%; border: 1px solid #f1f5f9; position: relative; overflow: hidden; }
.booking-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 6px; background: var(--brand, #ec4899); }
.booking-card h1 { font-size: 2rem; margin-bottom: 0.5rem; color: #0f172a; letter-spacing: -0.03em; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; margin-bottom: 0.5rem; font-weight: 700; font-size: 0.75rem; color: #64748b; text-transform: uppercase; letter-spacing: 0.05em; }
.form-group input, .form-group select { width: 100%; padding: 0.875rem 1rem; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 12px; outline: none; transition: all 0.2s ease; font-size: 1rem; color: #0f172a; font-family: inherit; font-weight: 500; }
.form-group input:focus, .form-group select:focus { background: #ffffff; border-color: var(--brand, #ec4899); box-shadow: 0 0 0 4px rgba(0,0,0,0.05); }
.btn { background: var(--brand, #ec4899); color: white; border: none; width: 100%; padding: 1rem; border-radius: 12px; font-weight: 700; font-size: 1.05rem; cursor: pointer; transition: all 0.2s ease; font-family: inherit; margin-top: 0.5rem; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 10px 20px -5px rgba(0,0,0,0.15); filter: brightness(1.05); }
/* Admin CSS */
.admin-nav { background: #ffffff; color: #0f172a; padding: 0 2rem; display: flex; justify-content: space-between; align-items: flex-end; border-bottom: 1px solid #e2e8f0; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.02); }
.nav-left { display: flex; align-items: flex-end; gap: 2rem; }
.nav-logo { font-size: 1.25rem; letter-spacing: -0.02em; margin: 0; font-weight: 700; padding-bottom: 1.25rem; padding-top: 1.25rem; }
.nav-links { display: flex; gap: 1.5rem; }
.nav-links a { color: #64748b; font-weight: 700; font-size: 0.95rem; text-decoration: none; padding-bottom: 1.25rem; padding-top: 1.25rem; border-bottom: 3px solid transparent; transition: all 0.2s; }
.nav-links a:hover { color: #0f172a; }
.nav-links a.active { color: #0f172a; border-bottom-color: #0f172a; }
.logout-btn { color: #ef4444; font-weight: 600; font-size: 0.9rem; text-decoration: none; padding-bottom: 1.25rem; padding-top: 1.25rem; transition: color 0.2s; }
.logout-btn:hover { color: #b91c1c; }
.admin-container { width: 100%; max-width: 1100px; margin: 2rem auto; padding: 0 2rem; }
.admin-card { background: #ffffff; padding: 2rem; border-radius: 20px; box-shadow: 0 10px 25px -5px rgba(0,0,0,0.03); border: 1px solid #f1f5f9; margin-bottom: 2rem; }
.admin-card h2 { font-size: 1.25rem; margin-bottom: 1.5rem; color: #0f172a; letter-spacing: -0.02em; }
.data-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.data-table th, .data-table td { padding: 1.25rem 1rem; text-align: left; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.data-table th { font-weight: 700; text-transform: uppercase; font-size: 0.75rem; color: #64748b; letter-spacing: 0.05em; background: #f8fafc; }
.data-table th:first-child { border-top-left-radius: 12px; border-bottom-left-radius: 12px; }
.data-table th:last-child { border-top-right-radius: 12px; border-bottom-right-radius: 12px; }
.badge { padding: 0.35rem 0.85rem; border-radius: 9999px; font-size: 0.8rem; font-weight: 700; display: inline-flex; align-items: center; }
.badge-pending { background: #fef9c3; color: #854d0e; border: 1px solid #fef08a; }
.badge-confirmed { background: #d1fae5; color: #065f46; border: 1px solid #a7f3d0; }
body.admin-page .btn { background: #0f172a; color: white; }
body.admin-page .btn:hover { background: #1e293b; }

/* ========================================= */
/* 📱 Mobile Responsiveness (Auto-Generated) */
/* ========================================= */
@media (max-width: 768px) {
    /* Global Containers */
    .container, .main-container, .board-container, .admin-container, .admin-wrap { padding: 1rem !important; }
    
    /* Hero & Headers */
    .hero { padding: 3rem 1rem !important; margin-bottom: -20px !important; border-radius: 0 0 20px 20px !important; }
    .hero h1, .hero-title, .event-title, .form-card h1, .contact-card h1 { font-size: 2rem !important; }
    
    /* Layouts & Grids */
    .admin-dashboard, .admin-layout, div[style*='grid-template-columns']:not(.calendar-grid) { grid-template-columns: 1fr !important; display: flex !important; flex-direction: column !important; gap: 1.5rem !important; }
    .product-grid { grid-template-columns: 1fr !important; }
    
    /* Cards & Boxes */
    .booking-card, .ticket-card, .form-card, .contact-card, .admin-login, .shortener-box, .suggest-box, .req-item, .admin-panel, .card, .admin-card { width: 100% !important; max-width: 100% !important; padding: 1.5rem !important; flex-direction: column !important; align-items: stretch !important; box-sizing: border-box !important; }
    
    /* Sidebar */
    .sidebar { width: 100% !important; height: auto !important; padding: 1.5rem !important; }
    
    /* Tables */
    .data-table, .roster-table, table { display: block !important; width: 100% !important; overflow-x: auto !important; white-space: nowrap !important; -webkit-overflow-scrolling: touch; }
    
    /* Navigations */
    .navbar, .header, .admin-header { flex-direction: column !important; text-align: center !important; gap: 1rem !important; padding: 1rem !important; }
    .admin-nav { flex-direction: column !important; align-items: center !important; gap: 0 !important; padding: 0 1rem !important; }
    .nav-left { flex-direction: column !important; align-items: center !important; gap: 0 !important; width: 100%; }
    .nav-links { flex-wrap: wrap !important; justify-content: center !important; gap: 1rem !important; }
    .nav-links a { padding: 0.75rem 0 !important; }
    .nav-logo { padding-bottom: 0.5rem !important; padding-top: 1.25rem !important; }
    .logout-btn { padding: 1rem 0 !important; }
    
    /* Form Elements & Buttons */
    .btn, button, input, select, textarea { width: 100% !important; font-size: 1rem !important; box-sizing: border-box !important; }
    .input-group, .suggest-box { flex-direction: column !important; gap: 1rem !important; }
    
    /* Specific Fixes */
    .vote-box { width: 100% !important; padding: 0.5rem !important; flex-direction: row !important; justify-content: center !important; gap: 0.5rem !important; }
    .vote-count { margin-top: 0 !important; }
}
