/* ═══════════════════════════════════════════════════════════════
   Event Bucket — Dynamic City Template
   Shared by every city served via the /:slug Vercel rewrite.
   Brand colors are CSS variables overridden per-city by app.js after
   the city profile loads from /api/city/[slug].
═══════════════════════════════════════════════════════════════ */

:root{
  --primary:#1a237e;
  --accent:#f2b035;
  --gold:#f2b035;
  --navy:#09131e;
  --bg:#0b1628;
  --bg-card:#142340;
  --bg-elevated:#1a2b4d;
  --bg-input:rgba(255,255,255,.06);
  --text:#f1f0eb;
  --text-primary:#f1f0eb;
  --text-secondary:rgba(241,240,235,.85);
  --text-muted:rgba(241,240,235,.6);
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.18);
  --green:#34d399;
  --red:#ef4444;
  --blue:#60a5fa;
  --r-sm:6px;
  --r-md:10px;
  --r-lg:16px;
  --sp-xs:6px;
  --sp-sm:12px;
  --sp-md:18px;
  --sp-lg:28px;
  --sp-xl:40px;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  --font-display:'Manrope','Inter',system-ui,sans-serif;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;}
body{min-height:100vh;display:flex;flex-direction:column;}
img{max-width:100%;display:block;}
a{color:var(--gold);text-decoration:none;}
a:hover{text-decoration:underline;}
button{font-family:inherit;cursor:pointer;}

/* ── Loading state ── */
#tplLoading{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;text-align:center;padding:40px;}
.spinner{width:38px;height:38px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.spinner-sm{width:18px;height:18px;border-width:2px;display:inline-block;vertical-align:middle;margin-right:8px;}

/* ── Not-found state ── */
#tplNotFound{flex:1;display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;gap:16px;max-width:560px;margin:0 auto;}
#tplNotFound h1{font-family:var(--font-display);font-weight:900;font-size:2rem;margin:0;}
#tplNotFound p{font-size:1rem;color:var(--text-muted);line-height:1.6;margin:0;}
.slug-pill{display:inline-block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:6px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9rem;color:var(--gold);}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:8px;}
.cta-primary{background:var(--gold);color:var(--navy);padding:12px 22px;border-radius:var(--r-md);font-weight:700;font-size:.9rem;border:none;}
.cta-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:12px 22px;border-radius:var(--r-md);font-weight:600;font-size:.9rem;}

/* ── Header ── */
#tplApp{display:none;flex:1;flex-direction:column;}
.tpl-header{display:flex;align-items:center;gap:14px;padding:16px 24px;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;}
.tpl-header-logo{height:40px;width:auto;border-radius:6px;background:#fff;padding:4px;flex-shrink:0;}
.tpl-header-title{font-family:var(--font-display);font-weight:900;font-size:1.1rem;color:var(--text);line-height:1.1;}
.tpl-header-state{font-size:.7rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;}
.tpl-header-spacer{flex:1;}
.tpl-header-nav{display:flex;gap:8px;align-items:center;}
.tpl-nav-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:8px 16px;border-radius:var(--r-md);font-size:.85rem;font-weight:600;}
.tpl-nav-btn:hover{background:var(--bg-input);color:var(--text);}
.tpl-nav-btn.primary{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.tpl-nav-btn.primary:hover{opacity:.92;}

/* ── Main layout ── */
.tpl-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:28px 24px;}

/* ── Filter bar ── */
.tpl-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:24px;}
.tpl-filter-btn{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);padding:8px 14px;border-radius:var(--r-md);font-size:.82rem;font-weight:600;}
.tpl-filter-btn:hover{background:var(--bg-elevated);color:var(--text);}
.tpl-filter-btn.active{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.tpl-search{flex:1;min-width:220px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);padding:9px 14px;color:var(--text);font-size:.85rem;}
.tpl-search:focus{outline:none;border-color:var(--gold);}

/* ── Event grid ── */
.tpl-events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;}
.tpl-event-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s;display:flex;flex-direction:column;}
.tpl-event-card:hover{transform:translateY(-2px);border-color:var(--gold);}
.tpl-event-flyer{width:100%;aspect-ratio:4/3;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.tpl-event-flyer img{width:100%;height:100%;object-fit:cover;}
.tpl-event-flyer-empty{font-size:2rem;color:var(--text-muted);}
.tpl-event-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1;}
.tpl-event-type{font-size:.65rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;font-weight:700;}
.tpl-event-name{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:var(--text);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.tpl-event-meta{font-size:.78rem;color:var(--text-muted);line-height:1.4;display:flex;flex-direction:column;gap:2px;margin-top:2px;}
.tpl-event-meta span{display:flex;align-items:center;gap:6px;}
.tpl-empty{text-align:center;padding:60px 24px;color:var(--text-muted);}
.tpl-empty h3{color:var(--text);font-family:var(--font-display);font-weight:800;margin:0 0 8px;}

/* ── Modal ── */
.tpl-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(4px);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;}
.tpl-modal-bg.visible{display:flex;}
.tpl-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);max-width:640px;width:100%;padding:28px;position:relative;}
.tpl-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--text-muted);font-size:1.6rem;line-height:1;}
.tpl-modal-close:hover{color:var(--text);}
.tpl-modal h2{font-family:var(--font-display);font-weight:900;font-size:1.4rem;margin:0 0 6px;color:var(--text);padding-right:30px;}
.tpl-modal-sub{font-size:.85rem;color:var(--text-muted);margin:0 0 20px;}
.tpl-modal-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:18px;}
.tpl-modal-meta .cell{background:var(--bg-input);border-radius:var(--r-sm);padding:9px 13px;}
.tpl-modal-meta .cell .k{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;}
.tpl-modal-meta .cell .v{font-size:.9rem;color:var(--text);font-weight:600;margin-top:3px;line-height:1.3;}
.tpl-modal-desc{background:rgba(255,255,255,.04);border-left:3px solid var(--gold);border-radius:var(--r-sm);padding:14px 18px;color:var(--text-secondary);line-height:1.55;font-size:.95rem;margin-bottom:18px;white-space:pre-line;}
.tpl-modal-flyer{width:100%;border-radius:var(--r-md);margin-bottom:18px;}

/* ── Form ── */
.tpl-form{display:flex;flex-direction:column;gap:14px;}
.tpl-form-group{display:flex;flex-direction:column;gap:5px;}
.tpl-form-label{font-size:.78rem;color:var(--text-secondary);font-weight:600;letter-spacing:.02em;}
.tpl-form-label .req{color:var(--red);}
.tpl-form-input,.tpl-form-textarea,.tpl-form-select{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;color:var(--text);font-size:.9rem;font-family:inherit;}
.tpl-form-input:focus,.tpl-form-textarea:focus,.tpl-form-select:focus{outline:none;border-color:var(--gold);}
.tpl-form-textarea{resize:vertical;min-height:90px;}
.tpl-form-hint{font-size:.72rem;color:var(--text-muted);}
.tpl-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.tpl-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px;}
.tpl-form-msg{padding:10px 14px;border-radius:var(--r-sm);font-size:.85rem;}
.tpl-form-msg.success{background:rgba(52,211,153,.12);color:var(--green);border:1px solid rgba(52,211,153,.3);}
.tpl-form-msg.error{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.3);}

/* ── Location gate (asked before the submit form renders) ── */
.tpl-gate-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media (max-width:600px){.tpl-gate-grid{grid-template-columns:1fr;}}
.tpl-gate-card{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:22px 20px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-align:left;font:inherit;color:var(--text);transition:border-color .15s ease,background .15s ease,transform .1s ease;width:100%;min-height:120px;}
.tpl-gate-card:hover{border-color:var(--gold);background:rgba(212,165,116,.08);}
.tpl-gate-card:active{transform:scale(.99);}
.tpl-gate-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.tpl-gate-check{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:2px solid var(--border);color:transparent;font-weight:900;font-size:1rem;flex-shrink:0;transition:all .15s ease;}
.tpl-gate-card:hover .tpl-gate-check{border-color:var(--gold);color:var(--gold);}
.tpl-gate-title{font-weight:700;color:var(--text);font-size:1rem;line-height:1.35;}

/* ── Admin layout ── */
.tpl-admin-tabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:24px;padding:0;}
.tpl-admin-tab{background:transparent;color:var(--text-muted);border:none;padding:12px 18px;font-size:.85rem;font-weight:600;border-bottom:2px solid transparent;margin-bottom:-1px;}
.tpl-admin-tab:hover{color:var(--text);}
.tpl-admin-tab.active{color:var(--gold);border-bottom-color:var(--gold);}

.tpl-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px;}
.tpl-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center;}
.tpl-stat-val{font-family:var(--font-display);font-weight:900;font-size:1.6rem;color:var(--gold);}
.tpl-stat-lbl{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;}

.tpl-admin-event{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;margin-bottom:12px;display:flex;gap:14px;align-items:flex-start;}
.tpl-admin-event-thumb{width:80px;height:80px;border-radius:var(--r-sm);background:var(--bg-input);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.tpl-admin-event-thumb img{width:100%;height:100%;object-fit:cover;}
.tpl-admin-event-body{flex:1;min-width:0;}
.tpl-admin-event-name{font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--text);margin:0 0 4px;}
.tpl-admin-event-meta{font-size:.78rem;color:var(--text-muted);line-height:1.45;}
.tpl-admin-event-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0;}
.tpl-btn-approve{background:var(--green);color:var(--navy);border:none;padding:7px 14px;border-radius:var(--r-sm);font-size:.78rem;font-weight:700;}
.tpl-btn-reject{background:transparent;color:var(--red);border:1px solid var(--red);padding:7px 14px;border-radius:var(--r-sm);font-size:.78rem;font-weight:700;}
.tpl-btn-view{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:7px 14px;border-radius:var(--r-sm);font-size:.78rem;font-weight:600;}
.tpl-status-badge{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:999px;}
.tpl-status-pending{background:rgba(242,176,53,.18);color:var(--gold);}
.tpl-status-approved{background:rgba(52,211,153,.18);color:var(--green);}
.tpl-status-rejected{background:rgba(239,68,68,.18);color:var(--red);}
.tpl-status-expired{background:rgba(255,255,255,.1);color:var(--text-muted);}

/* ── Analytics ── */
.tpl-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:760px){.tpl-charts-grid{grid-template-columns:1fr;}}
.tpl-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:18px;}
.tpl-chart-card h3{font-size:.9rem;font-weight:700;color:var(--gold);margin:0 0 14px;}
.tpl-chart-canvas{position:relative;height:280px;width:100%;}

/* ── Footer ── */
.tpl-footer{padding:18px 24px;border-top:1px solid var(--border);text-align:center;font-size:.75rem;color:var(--text-muted);margin-top:auto;}

/* ── Responsive ── */
@media(max-width:640px){
  .tpl-header{padding:12px 16px;}
  .tpl-main{padding:18px 16px;}
  .tpl-events-grid{grid-template-columns:1fr;}
  .tpl-form-row{grid-template-columns:1fr;}
  .tpl-modal{padding:20px;}
  .tpl-admin-event{flex-direction:column;align-items:stretch;}
  .tpl-admin-event-thumb{width:100%;height:160px;}
  .tpl-admin-event-actions{flex-direction:row;}
}
