:root{
  --bg:#f7f8fb;
  --fg:#0f172a;
  --muted:#4b5563;
  --card:#ffffff;
  --border:#e5e7eb;
  --accent:#0b3d91;
  --accent-2:#e8b400;
  --danger:#ef4444;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased}
.container{max-width:1100px;margin:0 auto;padding:clamp(12px,2vw,24px);width:100%}
.table-responsive{width:100%;overflow-x:auto}
.site-header{background:#fff;border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{color:var(--fg);text-decoration:none;font-weight:700}
nav a{color:var(--fg);margin-left:16px;text-decoration:none;font-weight:600;padding:8px 12px;border-radius:10px;transition:background .15s ease, color .15s ease}
nav a:hover{color:#fff;background:var(--accent)}
.auth-links a,
.nav-link{color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:8px;transition:background .15s ease,color .15s ease}
.auth-links a:hover,
.nav-link:hover{color:var(--fg);background:rgba(0,0,0,0.04)}
.site-footer{border-top:1px solid var(--border);margin-top:40px;padding:16px 0;color:var(--muted)}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.card{background:var(--card);padding:16px;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 40px rgba(15,23,42,0.06);transition:transform .12s ease, box-shadow .12s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(15,23,42,0.12)}
.card h2{margin:0 0 8px 0}

.btn{display:inline-block;background:var(--accent);color:white;padding:10px 14px;border-radius:10px;text-decoration:none;border:none;cursor:pointer;transition:transform .12s ease, filter .12s ease, box-shadow .12s ease;box-shadow:0 10px 24px rgba(11,61,145,0.25)}
.btn.secondary{background:var(--accent-2);color:#111;box-shadow:0 10px 24px rgba(232,180,0,0.25)}
.btn:hover{filter:brightness(1.05)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn:active{transform:translateY(1px)}

.form label{display:flex;flex-direction:column;gap:6px;color:var(--fg)}
.form input,.form textarea, .form select{padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--fg);box-shadow:0 6px 18px rgba(15,23,42,0.04)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.actions{display:flex;gap:8px;margin-top:12px}
.info{margin:6px 0;color:var(--muted);font-size:0.95rem}
.info.error{color:var(--danger)}

.flashes{list-style:none;padding:0;margin:12px 0}
.flash{padding:10px;border-radius:10px;margin-bottom:8px;border:1px solid var(--border);background:#fff}
.flash.error{background:#fff5f5;color:#991b1b;border-color:#fecdd3}
.flash.message{background:#f0fdf4;color:#14532d;border-color:#bbf7d0}

.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch}
table.table{width:100%;min-width:600px;border-collapse:collapse;background:var(--card);border-radius:12px;overflow:hidden;border:1px solid var(--border)}
table.table th, table.table td{border-bottom:1px solid var(--border);padding:10px;text-align:left}
table.table th{color:var(--muted);font-weight:700;background:#f3f4f6}
.table-wrap::after{content:"";display:block;height:1px}

/* Ticket and print */
.ticket h2{margin-top:0}
.ticket .qr{margin-top:12px}

.login-hero{background:linear-gradient(135deg,#0b3d91,#0e1a3a);padding:40px;border-radius:16px;color:#fff;margin-bottom:24px}
.login-hero-content{max-width:480px}
.login-hero .eyebrow{text-transform:uppercase;letter-spacing:0.2em;font-size:0.75rem;color:rgba(255,255,255,0.7);margin:0 0 8px 0}
.login-hero h1{margin:0;font-size:2rem}
.login-hero p{margin:8px 0 16px 0;color:rgba(255,255,255,0.8)}
.login-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;align-items:center;box-shadow:0 12px 36px rgba(15,23,42,0.08)}
.login-panel-image img{width:100%;max-width:240px;display:block;margin:0 auto}
.login-panel-form{display:flex;flex-direction:column;gap:16px}
.login-panel-form h2{margin:0}
.stacked-form{display:flex;flex-direction:column;gap:16px}
.stacked-form label{display:flex;flex-direction:column;gap:6px}
.stacked-form input{padding:12px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--fg);box-shadow:0 6px 18px rgba(15,23,42,0.04)}
.btn.full{width:100%;text-align:center}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.6);color:#fff}
.btn.ghost:hover{border-color:#fff}
.support-hero{background:linear-gradient(135deg,#0b3d91,#0e1a3a);padding:36px;border-radius:16px;color:#fff;margin-bottom:20px}
.support-hero-content{max-width:520px}
.support-hero h1{margin:0;font-size:1.8rem}
.support-hero p{margin:10px 0 18px 0;color:rgba(255,255,255,0.8)}
.support-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 12px 36px rgba(15,23,42,0.08)}
.support-panel-info ul{margin:12px 0 0 0;padding-left:18px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.support-panel-form{display:flex;flex-direction:column;gap:16px}
.settings-hero{background:linear-gradient(135deg,#0b3d91,#0e1a3a);padding:32px;border-radius:16px;color:#fff;margin-bottom:20px}
.settings-hero-content{max-width:520px}
.settings-hero h1{margin:0;font-size:1.8rem}
.settings-hero p{margin:8px 0 0 0;color:rgba(255,255,255,0.8)}
.settings-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 12px 36px rgba(15,23,42,0.08)}
.settings-panel-info ul{margin:12px 0 0 0;padding-left:18px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.settings-panel-form{display:flex;flex-direction:column;gap:16px}
.user-form{display:flex;flex-direction:column;gap:14px}
.user-form label{display:flex;flex-direction:column;gap:6px}
.user-form .actions{display:flex;justify-content:flex-end}
.users-actions{min-width:200px}
.inline-form{display:inline}
.muted{color:var(--muted);font-size:0.85rem}
.btn.danger{background:var(--danger)}
.btn.small{padding:6px 10px;font-size:0.85rem}
.user-action-form{display:flex;flex-direction:column;gap:10px}
.user-action-form select{padding:8px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--fg)}
.user-edit-fields{display:none;flex-direction:column;gap:8px;padding:8px;border:1px dashed var(--border);border-radius:8px}
.user-edit-fields input{width:100%}
.checkbox-inline{display:flex;align-items:center;gap:6px}
.checkbox-inline.full-width{grid-column:1/-1;align-items:center;gap:8px}
.lang-switch{display:flex;gap:8px}
.lang-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border:1px solid var(--border);border-radius:20px;text-decoration:none;color:var(--muted);font-weight:600;font-size:0.9rem;background:#fff}
.lang-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.password-field{position:relative;width:100%}
.password-field input{width:100%;padding-right:90px}
.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:1px solid var(--border);color:var(--muted);padding:4px 10px;border-radius:6px;font-size:0.8rem;cursor:pointer}
.password-toggle:hover{color:var(--fg)}
.quick-actions{margin:20px 0}
.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:12px}
.quick-action-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:14px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--fg);text-decoration:none;font-weight:600;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;box-shadow:0 10px 24px rgba(15,23,42,0.06)}
.quick-action-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 14px 32px rgba(15,23,42,0.12)}
.quick-action-card .icon{font-size:1.4rem}
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:20px 0}
.stats-row{display:flex;gap:16px;flex-wrap:wrap}
.stats-row > div{flex:1 1 140px;background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:12px}
.upcoming-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.upcoming-list li{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:10px;background:#fff;flex-wrap:wrap;box-shadow:0 10px 24px rgba(15,23,42,0.04)}
.upcoming-list .badge{background:var(--accent-2);color:#111827;padding:4px 10px;border-radius:999px;font-size:0.85rem;font-weight:600}
.login-hero{background:linear-gradient(135deg,#0b3d91,#0e1a3a);padding:40px;border-radius:16px;color:#fff;margin-bottom:24px}
.login-hero-content{max-width:480px}
.login-hero .eyebrow{text-transform:uppercase;letter-spacing:0.2em;font-size:0.75rem;color:rgba(255,255,255,0.7);margin:0 0 8px 0}
.login-hero h1{margin:0;font-size:2rem}
.login-hero p{margin:8px 0 16px 0;color:rgba(255,255,255,0.8)}
.login-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;align-items:center}
.login-panel-image img{width:100%;max-width:240px;display:block;margin:0 auto}
.login-panel-form{display:flex;flex-direction:column;gap:16px}
.login-panel-form h2{margin:0}
.stacked-form{display:flex;flex-direction:column;gap:16px}
.stacked-form label{display:flex;flex-direction:column;gap:6px}
.stacked-form input{padding:12px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--fg)}
.btn.full{width:100%;text-align:center}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.6);color:#fff}
.btn.ghost:hover{border-color:#fff}
.support-data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:16px}
.support-data-grid .inner-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 24px rgba(15,23,42,0.06)}
.page-heading{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px}
.page-heading h1{margin:0}
.filters-card{margin-bottom:20px}
.reservation-filters{display:flex;flex-direction:column;gap:16px}
.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.filter-grid label{display:flex;flex-direction:column;gap:6px}
.filter-grid input,
.filter-grid select{padding:10px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--fg)}
.filter-actions{flex-wrap:wrap}
.reservation-stats{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;flex:1 1 160px;min-width:160px;display:flex;flex-direction:column;gap:6px}
.stat-label{color:var(--muted);font-size:0.8rem;text-transform:uppercase;letter-spacing:0.08em}
.stat-value{font-size:1.8rem;font-weight:700}
.stat-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.stat-list li{display:flex;justify-content:space-between;gap:12px;font-size:0.95rem}
.stat-list-card{flex:1 1 260px}

@media (max-width:640px){
  table.stack-table thead{display:none}
  table.stack-table,
  table.stack-table tbody,
  table.stack-table tr,
  table.stack-table td{display:block;width:100%}
  table.stack-table tr{margin-bottom:12px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,0.06)}
  table.stack-table td{display:flex;justify-content:space-between;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}
  table.stack-table td::before{content:attr(data-label);font-weight:700;color:var(--muted)}
  table.stack-table td:last-child{border-bottom:none}
}

@media (max-width:1024px){
  .container{padding:20px}
  .cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
}

@media (max-width:768px){
  .header-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .header-inner nav{flex-wrap:wrap}
  nav a{margin-left:0;margin-right:12px}
  .header-utilities{width:100%;flex-direction:column;align-items:flex-start;gap:12px}
  .auth-links{flex-wrap:wrap}
  .cards{grid-template-columns:1fr}
  .card{box-shadow:0 8px 24px rgba(15,23,42,0.12)}
  .user-action-form select,
  .user-edit-fields input,
  .user-form input,
  .user-form textarea{width:100%}
  .filter-grid{grid-template-columns:1fr}
  .auth-page{padding:24px 0}
  .filter-actions{flex-direction:column}
  .filter-actions .btn{width:100%}
  .login-hero,
  .support-hero,
  .settings-hero{padding:24px}
  .login-hero h1,
  .support-hero h1,
  .settings-hero h1{font-size:1.6rem}
  .login-panel,
  .support-panel,
  .settings-panel{padding:16px}
  .quick-action-card{padding:12px}
}

@media (max-width:480px){
  body{font-size:15px}
  .container{padding:16px 12px}
  .brand{font-size:1.2rem}
  .lang-pill{font-size:0.8rem;padding:4px 10px}
  .btn, .btn.small{width:100%;text-align:center}
  .user-action-form{gap:8px}
  .user-edit-fields{padding:6px}
  .login-hero h1,
  .support-hero h1,
  .settings-hero h1{font-size:1.4rem}
  .quick-actions-grid,
  .dashboard-grid,
  .cards{grid-template-columns:1fr}
}
@media print {
  body{background:white;color:black}
  .site-header,.site-footer,.actions,nav{display:none !important}
  .card{border:1px solid #ccc}
}
