/* VenueForge — Bold Editorial Dark Theme */
:root {
  --ink:       #0a0a0f;
  --ink2:      #12121a;
  --ink3:      #1c1c28;
  --surface:   #21212f;
  --border:    #2e2e40;
  --muted:     #6b6b85;
  --text:      #e8e8f0;
  --text2:     #a8a8bf;
  --accent:    #ff5c35;
  --accent2:   #ffb800;
  --teal:      #00d4aa;
  --font-head: 'Syne', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --radius:    10px;
  --shadow:    0 4px 24px rgba(0,0,0,.45);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--ink); color:var(--text);
  font-family:var(--font-body); font-size:16px; line-height:1.6;
  min-height:100vh;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--ink2); }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

/* ── Navbar ── */
.navbar {
  position:sticky; top:0; z-index:100;
  background:rgba(10,10,15,.92); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .2s;
}
.navbar.scrolled { box-shadow:0 2px 20px rgba(0,0,0,.5); }
.nav-inner {
  max-width:1280px; margin:0 auto;
  padding:0 24px; height:64px;
  display:flex; align-items:center; gap:32px;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo-mark {
  width:34px; height:34px; background:var(--accent);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-head); font-weight:800; font-size:18px; color:#fff;
}
.logo-mark.small { width:26px; height:26px; font-size:14px; }
.logo-text { font-family:var(--font-head); font-weight:700; font-size:20px; letter-spacing:-.3px; }
.nav-links { display:flex; gap:4px; margin-left:16px; }
.nav-link {
  padding:6px 14px; border-radius:6px; font-size:14px; font-weight:500;
  color:var(--text2); transition:all .15s;
}
.nav-link:hover { color:var(--text); background:var(--ink3); }
.nav-actions { margin-left:auto; display:flex; align-items:center; gap:10px; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; }

.mobile-menu {
  display:none; flex-direction:column;
  background:var(--ink2); border-bottom:1px solid var(--border);
  padding:12px 24px;
}
.mobile-menu a { padding:10px 0; color:var(--text2); font-size:15px; border-bottom:1px solid var(--border); }
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu.open { display:flex; }

@media(max-width:768px){
  .nav-links,.nav-actions { display:none; }
  .hamburger { display:flex; margin-left:auto; }
}

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; border-radius:8px; font-size:14px; font-weight:500;
  cursor:pointer; border:none; transition:all .15s; font-family:var(--font-body);
}
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:#e04e2a; transform:translateY(-1px); box-shadow:0 4px 16px rgba(255,92,53,.35); }
.btn-outline { background:transparent; color:var(--text); border:1px solid var(--border); }
.btn-outline:hover { border-color:var(--text2); background:var(--ink3); }
.btn-teal { background:var(--teal); color:var(--ink); }
.btn-teal:hover { background:#00c09a; transform:translateY(-1px); }
.btn-sm { padding:6px 14px; font-size:13px; }
.btn-lg { padding:14px 32px; font-size:16px; }
.btn-full { width:100%; justify-content:center; }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none!important; }

/* ── Hero ── */
.hero {
  position:relative; overflow:hidden;
  min-height:88vh; display:flex; align-items:center;
  background:var(--ink);
}
.hero-bg {
  position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 60% 40%, rgba(255,92,53,.12) 0%, transparent 70%),
             radial-gradient(ellipse 50% 80% at 10% 80%, rgba(0,212,170,.08) 0%, transparent 60%);
}
.hero-grid {
  position:absolute; inset:0; opacity:.04;
  background-image:linear-gradient(var(--border) 1px, transparent 1px),
                   linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:40px 40px;
}
.hero-inner {
  position:relative; max-width:1280px; margin:0 auto;
  padding:80px 24px; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; background:rgba(255,92,53,.12); border:1px solid rgba(255,92,53,.3);
  border-radius:999px; font-size:12px; font-weight:600; color:var(--accent);
  text-transform:uppercase; letter-spacing:.8px; margin-bottom:20px;
}
.hero-tag::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--accent); }
.hero h1 {
  font-family:var(--font-head); font-size:clamp(2.4rem,5vw,4rem);
  font-weight:800; line-height:1.1; letter-spacing:-.02em;
  margin-bottom:20px;
}
.hero h1 em { font-style:normal; color:var(--accent); }
.hero p { font-size:18px; color:var(--text2); max-width:480px; margin-bottom:36px; line-height:1.7; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.hero-stats { display:flex; gap:32px; margin-top:40px; }
.hero-stat-val { font-family:var(--font-head); font-size:2rem; font-weight:800; color:var(--text); }
.hero-stat-label { font-size:13px; color:var(--muted); }
.hero-visual {
  display:flex; flex-direction:column; gap:12px;
}
.floor-preview {
  background:var(--ink2); border:1px solid var(--border); border-radius:14px;
  padding:20px; position:relative; overflow:hidden;
}
.floor-preview-label {
  font-size:11px; font-weight:600; color:var(--muted);
  text-transform:uppercase; letter-spacing:.8px; margin-bottom:12px;
}
.floor-grid {
  display:grid; grid-template-columns:repeat(6,1fr); gap:6px;
}
.floor-cell {
  height:36px; border-radius:5px; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:9px; font-weight:600; color:var(--muted);
  transition:all .2s; cursor:default;
}
.floor-cell.available { background:rgba(0,212,170,.12); border-color:rgba(0,212,170,.3); color:var(--teal); }
.floor-cell.booked    { background:rgba(255,92,53,.12);  border-color:rgba(255,92,53,.3);  color:var(--accent); }
.floor-cell.reserved  { background:rgba(255,184,0,.12);  border-color:rgba(255,184,0,.3);  color:var(--accent2); }

@media(max-width:900px){ .hero-inner{grid-template-columns:1fr;} .hero-visual{display:none;} }

/* ── Section ── */
.section { padding:80px 24px; max-width:1280px; margin:0 auto; }
.section-sm { padding:48px 24px; max-width:1280px; margin:0 auto; }
.section-header { margin-bottom:48px; }
.section-tag {
  font-size:11px; font-weight:700; color:var(--accent); text-transform:uppercase;
  letter-spacing:1px; margin-bottom:10px;
}
.section-title {
  font-family:var(--font-head); font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:800; letter-spacing:-.02em; margin-bottom:12px;
}
.section-sub { font-size:16px; color:var(--text2); max-width:560px; line-height:1.7; }

/* ── Cards ── */
.card-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }
.card {
  background:var(--ink2); border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; transition:all .2s; cursor:pointer;
}
.card:hover { border-color:var(--accent); transform:translateY(-3px); box-shadow:var(--shadow); }
.card-img { height:180px; background:var(--surface); overflow:hidden; position:relative; }
.card-img-placeholder {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-size:48px; opacity:.3;
}
.card-body { padding:18px; }
.card-tag {
  display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.5px; margin-bottom:10px;
}
.card-tag.available { background:rgba(0,212,170,.12); color:var(--teal); }
.card-tag.booked    { background:rgba(255,92,53,.12);  color:var(--accent); }
.card-tag.reserved  { background:rgba(255,184,0,.12);  color:var(--accent2); }
.card-tag.maintenance { background:var(--surface); color:var(--muted); }
.card-tag.published { background:rgba(0,212,170,.12); color:var(--teal); }
.card-tag.draft     { background:var(--surface); color:var(--muted); }
.card-title { font-family:var(--font-head); font-size:1.1rem; font-weight:700; margin-bottom:6px; }
.card-sub   { font-size:13px; color:var(--text2); margin-bottom:12px; }
.card-meta  { display:flex; align-items:center; justify-content:space-between; }
.card-price { font-family:var(--font-head); font-size:1.2rem; font-weight:700; color:var(--accent); }
.card-price span { font-size:12px; font-weight:400; color:var(--muted); }
.card-badges { display:flex; gap:6px; flex-wrap:wrap; margin-top:10px; }
.badge { padding:3px 8px; background:var(--surface); border-radius:4px; font-size:11px; color:var(--text2); }

/* ── Search/Filter Bar ── */
.filter-bar {
  background:var(--ink2); border:1px solid var(--border); border-radius:var(--radius);
  padding:20px; margin-bottom:32px; display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end;
}
.filter-group { display:flex; flex-direction:column; gap:6px; flex:1; min-width:140px; }
.filter-group label { font-size:11px; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.5px; }
.filter-group input,
.filter-group select {
  background:var(--ink3); border:1px solid var(--border); border-radius:6px;
  padding:8px 12px; color:var(--text); font-size:14px; font-family:var(--font-body);
  outline:none; transition:border-color .15s;
}
.filter-group input:focus,
.filter-group select:focus { border-color:var(--accent); }
.filter-group select option { background:var(--ink3); }

/* ── Space Detail ── */
.space-detail { display:grid; grid-template-columns:1fr 380px; gap:32px; align-items:start; }
.space-detail-info { }
.space-detail-sidebar {
  background:var(--ink2); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px; position:sticky; top:88px;
}
.space-specs { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:20px 0; }
.spec-item { background:var(--ink3); border-radius:8px; padding:12px 14px; }
.spec-label { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px; margin-bottom:4px; }
.spec-value { font-family:var(--font-head); font-size:1.1rem; font-weight:700; }
.price-breakdown { border-top:1px solid var(--border); margin-top:16px; padding-top:16px; }
.price-row { display:flex; justify-content:space-between; font-size:14px; padding:4px 0; }
.price-row.total { font-weight:700; font-size:16px; border-top:1px solid var(--border); margin-top:8px; padding-top:8px; }
@media(max-width:900px){ .space-detail{grid-template-columns:1fr;} .space-detail-sidebar{position:static;} }

/* ── Floor Plan ── */
.floor-plan {
  background:var(--ink2); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px; margin:24px 0;
}
.floor-plan-title { font-family:var(--font-head); font-size:1rem; font-weight:700; margin-bottom:16px; }
.floor-plan-grid { position:relative; overflow-x:auto; }
.fp-canvas { min-width:600px; height:400px; position:relative; background:var(--ink3); border-radius:8px; }
.fp-space {
  position:absolute; border-radius:4px; display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:700; cursor:pointer; transition:all .15s; border:1px solid transparent;
  flex-direction:column; gap:2px;
}
.fp-space:hover { transform:scale(1.05); z-index:10; }
.fp-space.available { background:rgba(0,212,170,.2); border-color:var(--teal); color:var(--teal); }
.fp-space.booked    { background:rgba(255,92,53,.2);  border-color:var(--accent); color:var(--accent); }
.fp-space.reserved  { background:rgba(255,184,0,.2);  border-color:var(--accent2); color:var(--accent2); }
.fp-space.maintenance { background:var(--surface); border-color:var(--border); color:var(--muted); }
.fp-legend { display:flex; gap:20px; margin-top:12px; flex-wrap:wrap; }
.fp-legend-item { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text2); }
.fp-legend-dot { width:10px; height:10px; border-radius:2px; }

/* ── Booking Form ── */
.booking-form { display:flex; flex-direction:column; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-size:12px; font-weight:600; color:var(--text2); text-transform:uppercase; letter-spacing:.5px; }
.form-group input,
.form-group select,
.form-group textarea {
  background:var(--ink3); border:1px solid var(--border); border-radius:6px;
  padding:10px 14px; color:var(--text); font-size:14px; font-family:var(--font-body);
  outline:none; transition:border-color .15s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--accent); }
.form-error { color:var(--accent); font-size:12px; margin-top:4px; }
.discount-row { display:flex; gap:8px; }
.discount-row input { flex:1; }
.discount-success { color:var(--teal); font-size:13px; font-weight:500; }

/* ── Tabs ── */
.tabs { display:flex; gap:2px; border-bottom:1px solid var(--border); margin-bottom:28px; }
.tab {
  padding:10px 20px; font-size:14px; font-weight:500; cursor:pointer;
  border-bottom:2px solid transparent; color:var(--text2); transition:all .15s; background:none; border-top:none; border-left:none; border-right:none; font-family:var(--font-body);
}
.tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab:hover:not(.active) { color:var(--text); }

/* ── Table ── */
.data-table { width:100%; border-collapse:collapse; font-size:14px; }
.data-table th {
  text-align:left; padding:10px 14px; font-size:11px; font-weight:600;
  color:var(--muted); text-transform:uppercase; letter-spacing:.5px;
  border-bottom:1px solid var(--border); background:var(--ink2);
}
.data-table td { padding:12px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
.data-table tr:hover td { background:var(--ink2); }
.data-table-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius); }

/* ── Status badges ── */
.status {
  display:inline-block; padding:3px 10px; border-radius:999px;
  font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.4px;
}
.status-confirmed { background:rgba(0,212,170,.12); color:var(--teal); }
.status-pending   { background:rgba(255,184,0,.12);  color:var(--accent2); }
.status-cancelled { background:rgba(255,92,53,.12);  color:var(--accent); }
.status-completed { background:rgba(100,200,120,.12);color:#64c878; }
.status-failed    { background:rgba(255,92,53,.12);  color:var(--accent); }

/* ── Empty State ── */
.empty-state {
  text-align:center; padding:60px 20px; color:var(--muted);
}
.empty-state .empty-icon { font-size:48px; margin-bottom:16px; opacity:.4; }
.empty-state h3 { font-family:var(--font-head); font-size:1.2rem; color:var(--text2); margin-bottom:8px; }

/* ── Pagination ── */
.pagination { display:flex; gap:6px; justify-content:center; margin-top:32px; }
.page-btn {
  width:36px; height:36px; border-radius:6px; border:1px solid var(--border);
  background:var(--ink2); color:var(--text2); font-size:14px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-family:var(--font-body);
  transition:all .15s;
}
.page-btn.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.page-btn:hover:not(.active) { border-color:var(--text2); color:var(--text); }

/* ── Modal ── */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.7); backdrop-filter:blur(4px); z-index:200;
}
.modal-overlay.open { display:block; }
.modal {
  display:none; position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  z-index:201; background:var(--ink2); border:1px solid var(--border);
  border-radius:14px; padding:32px; width:min(560px,92vw); max-height:88vh; overflow-y:auto;
}
.modal.open { display:block; }
.modal-close {
  position:absolute; top:16px; right:16px; background:var(--surface);
  border:none; color:var(--text2); width:28px; height:28px; border-radius:6px;
  cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center;
}
.modal-title { font-family:var(--font-head); font-size:1.3rem; font-weight:700; margin-bottom:20px; }

/* ── Toast ── */
#toast-container { position:fixed; bottom:24px; right:24px; z-index:300; display:flex; flex-direction:column; gap:8px; }
.toast {
  padding:12px 18px; border-radius:8px; font-size:14px; font-weight:500;
  box-shadow:var(--shadow); animation:slideIn .2s ease; max-width:320px;
  display:flex; align-items:center; gap:8px;
}
.toast-success { background:#0d2e25; border:1px solid var(--teal); color:var(--teal); }
.toast-error   { background:#2e0d0d; border:1px solid var(--accent); color:var(--accent); }
.toast-info    { background:var(--surface); border:1px solid var(--border); color:var(--text); }
@keyframes slideIn { from{transform:translateX(100%);opacity:0} to{transform:none;opacity:1} }

/* ── Auth forms ── */
.auth-wrap {
  min-height:calc(100vh - 64px); display:flex; align-items:center; justify-content:center; padding:40px 24px;
}
.auth-box {
  background:var(--ink2); border:1px solid var(--border); border-radius:14px;
  padding:40px; width:min(440px,100%);
}
.auth-title { font-family:var(--font-head); font-size:1.8rem; font-weight:800; margin-bottom:6px; }
.auth-sub   { color:var(--text2); font-size:14px; margin-bottom:28px; }
.auth-switch { text-align:center; margin-top:20px; font-size:14px; color:var(--text2); }
.auth-switch a { color:var(--accent); cursor:pointer; }

/* ── Dashboard ── */
.dash-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px; margin-bottom:32px; }
.stat-card {
  background:var(--ink2); border:1px solid var(--border); border-radius:var(--radius);
  padding:20px 22px; position:relative; overflow:hidden;
}
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--accent);
}
.stat-card.teal::before  { background:var(--teal); }
.stat-card.gold::before  { background:var(--accent2); }
.stat-card.green::before { background:#64c878; }
.stat-icon { font-size:22px; margin-bottom:8px; opacity:.6; }
.stat-val  { font-family:var(--font-head); font-size:2rem; font-weight:800; line-height:1; }
.stat-label { font-size:12px; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:.5px; }

/* ── Utilities ── */
.flex { display:flex; }
.flex-between { display:flex; justify-content:space-between; align-items:center; }
.gap-2 { gap:8px; }
.gap-3 { gap:12px; }
.mt-1 { margin-top:4px; }
.mt-2 { margin-top:8px; }
.mt-3 { margin-top:16px; }
.mt-4 { margin-top:24px; }
.mb-2 { margin-bottom:8px; }
.mb-3 { margin-bottom:16px; }
.mb-4 { margin-bottom:24px; }
.text-muted  { color:var(--muted); }
.text-accent { color:var(--accent); }
.text-teal   { color:var(--teal); }
.text-gold   { color:var(--accent2); }
.text-sm { font-size:13px; }
.font-head { font-family:var(--font-head); }
.fw-700 { font-weight:700; }
.text-center { text-align:center; }

/* ── Loader ── */
.loader {
  display:flex; align-items:center; justify-content:center; padding:80px;
}
.spinner {
  width:32px; height:32px; border:3px solid var(--border);
  border-top-color:var(--accent); border-radius:50%; animation:spin .6s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ── Alert ── */
.alert { padding:12px 16px; border-radius:8px; font-size:14px; margin-bottom:16px; }
.alert-error   { background:rgba(255,92,53,.1);  border:1px solid rgba(255,92,53,.3);  color:var(--accent); }
.alert-success { background:rgba(0,212,170,.1);  border:1px solid rgba(0,212,170,.3);  color:var(--teal); }
.alert-info    { background:rgba(100,100,200,.1);border:1px solid rgba(100,100,200,.3);color:var(--text2); }

/* ── Section divider ── */
.divider { border:none; border-top:1px solid var(--border); margin:48px 0; }
