:root{
  --bg:#07050a;
  --panel:#0f0b14;
  --panel2:#120c18;
  --text:#f6efe2;
  --muted:#d8cdb8;
  --accent:#d7b46a;   /* art deco gold */
  --accent2:#8b1e2d;  /* deep cinema red */
  --danger:#ff6b6b;
  --border:#2a1d2f;
  --shadow: 0 18px 55px rgba(0,0,0,.45);
}

/* Past film nights appear muted */
tr.past td { opacity: .55; }

/* Keep the "Previous" tag readable */
tr.past .tag.previous { opacity: 1; }


.thumb-wrap{ position: relative; }

.thumb-delete-form{
  position:absolute;
  top:6px;
  right:6px;
  margin:0;
}

.thumb-delete{
  width:26px;
  height:26px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.60);
  color:#fff;
  font-size:18px;
  line-height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
}

.thumb-delete:hover{
  background:rgba(200,0,0,.75);
}

.brand{
  display:flex;
  gap:14px;
  align-items:center;
  text-decoration:none;
}

.brand-logo{
  width:64px;
  height:64px;
  border-radius:10px;
  object-fit:cover;
  box-shadow: 0 10px 22px rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.08);
}

.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-name{ font-weight:800; letter-spacing:.02em; }
.brand-tagline{ font-size:.9rem; opacity:.85; margin-top:4px; }

.nav{ display:flex; flex-direction:column; gap:10px; }
.nav-row{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.nav-top{ gap:16px; }
.nav-actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

.nav-links{
  padding-top:10px;
  border-top: 1px solid rgba(255,255,255,.12);
}

.wrap.wide{ max-width: 1200px; }
.admin-single{ display:block; }

/* Match page section titles to header link/title colour */
.card h1,
.card h2{
  color: rgb(215, 180, 106);
}

/* If your theme uses a different variable, swap --ink for it. Common ones: --text, --fg, --gold, --brand, --accent */
header a,
header .brand-name{
  /* matching header palette */
}

/* Reduce section title sizes */
.card h1{
  font-size: 1.55rem;
  margin-bottom: .4rem;
}

.card h2{
  font-size: 1.1rem;
  margin-top: 1.1rem;
  margin-bottom: .55rem;
  letter-spacing: .02em;
  text-transform: none;
}

/* Reduce table title/header font size */
.table thead th,
table thead th{
  font-size: .9rem;
  letter-spacing: .02em;
}

/* Optional: slightly reduce table body text too */
.table td,
table td{
  font-size: .95rem;
}

/* Optional “poster print” treatment */
.brand-logo{
  filter: contrast(1.08) saturate(1.05);
}

@media (max-width: 720px){
  .brand-logo{ width:46px; height:46px; }
  .brand-tagline{ display:none; }
}

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: "Fraunces", Georgia, "Times New Roman", serif;
  background:
    radial-gradient(1200px 900px at 20% -10%, rgba(215,180,106,0.14) 0%, rgba(7,5,10,0) 60%),
    radial-gradient(900px 700px at 110% 20%, rgba(139,30,45,0.16) 0%, rgba(7,5,10,0) 55%),
    linear-gradient(180deg, rgba(7,5,10,1) 0%, rgba(6,4,8,1) 100%);
  color:var(--text);
  line-height:1.55;
}

/* Subtle Art Deco pattern overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(45deg,
      rgba(215,180,106,0.05) 0px,
      rgba(215,180,106,0.05) 1px,
      rgba(0,0,0,0) 1px,
      rgba(0,0,0,0) 14px),
    radial-gradient(circle at 30% 10%, rgba(215,180,106,0.06), rgba(0,0,0,0) 35%),
    radial-gradient(circle at 80% 60%, rgba(139,30,45,0.05), rgba(0,0,0,0) 40%);
  opacity:0.9;
}

a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }

header{
  position:sticky;
  top:0;
  background: rgba(7,5,10,0.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(215,180,106,0.22);
  z-index:10;
}

.wrap{ max-width:1100px; margin:0 auto; padding:16px; }

nav{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}

nav .brand{
  font-family:"Cinzel", Georgia, serif;
  font-weight:800;
  letter-spacing:0.8px;
  margin-right:10px;
}

nav .spacer{ flex:1; }

.btn{
  display:inline-block;
  padding:10px 12px;
  border:1px solid rgba(215,180,106,0.35);
  border-radius:14px;
  background: rgba(15,11,20,0.65);
  color:var(--text);
  cursor:pointer;
  box-shadow: 0 0 0 1px rgba(0,0,0,.2) inset;
}

.btn:hover{ border-color: rgba(215,180,106,0.65); }

.btn.primary{
  background: linear-gradient(180deg, rgba(215,180,106,0.25), rgba(215,180,106,0.12));
  border-color: rgba(215,180,106,0.85);
}

.btn.danger{ border-color: rgba(255,107,107,0.55); }

.grid{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap:18px;
}
@media(max-width:900px){ .grid{ grid-template-columns:1fr; } }

.card{
  background: linear-gradient(180deg, rgba(18,12,24,0.72), rgba(15,11,20,0.72));
  border:1px solid rgba(215,180,106,0.22);
  border-radius:18px;
  padding:18px;
  box-shadow: var(--shadow);
  position:relative;
}

/* Deco border corners */
.card::after{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:14px;
  border:1px solid rgba(215,180,106,0.10);
  pointer-events:none;
}

h1,h2,h3{
  margin:0 0 10px;
  font-family:"Cinzel", Georgia, serif;
  letter-spacing:0.4px;
}

p{ margin:0 0 10px; color:var(--muted); }

.hero{ padding:26px 0 10px; }

.marquee{
  font-family:"Cinzel", Georgia, serif;
  letter-spacing:2px;
  font-weight:800;
  color:rgba(215,180,106,0.95);
  border:1px solid rgba(215,180,106,0.28);
  border-radius:999px;
  display:inline-block;
  padding:8px 12px;
  background: rgba(0,0,0,0.25);
  margin-bottom:14px;
}

.pill-row{ display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 14px; }

.pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(215,180,106,0.22);
  background: rgba(0,0,0,0.18);
  color:var(--muted);
  font-size: 0.95rem;
}

.social-icons{ display:flex; gap:12px; align-items:center; }
.social-icon svg{ display:block; }

.social-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(215,180,106,0.35);
  background: rgba(0,0,0,0.18);
  box-shadow: 0 10px 24px rgba(0,0,0,.22);
}

.social-btn svg{ fill: rgba(215,180,106,0.95); }

.social-btn:hover{ transform: translateY(-1px); }

.cta-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }

.tag{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(215,180,106,0.20);
  background: rgba(0,0,0,0.18);
  color:var(--muted);
  font-size: 0.9rem;
}

table{
  width:100%;
  border-collapse: collapse;
  overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(215,180,106,0.20);
  background: rgba(0,0,0,0.12);
}

th, td{
  padding:10px;
  border-bottom:1px solid rgba(215,180,106,0.14);
  vertical-align:top;
}

th{
  text-align:left;
  color: var(--text);
  background: rgba(0,0,0,0.22);
  font-family:"Cinzel", Georgia, serif;
  letter-spacing:0.4px;
}

tr:last-child td{ border-bottom:none; }

.muted{ color:var(--muted); }
.error{ color:var(--danger); }

input, textarea, select{
  width:100%;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(215,180,106,0.22);
  background: rgba(0,0,0,0.22);
  color:var(--text);
  outline:none;
}

textarea{ min-height:90px; }

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
@media(max-width:700px){ .form-row{ grid-template-columns:1fr; } }

.list{
  margin:0 0 14px;
  padding-left:18px;
  color:var(--muted);
}

.divider{
  height:1px;
  background: rgba(215,180,106,0.18);
  margin:14px 0;
}

footer{ padding:30px 0; color:var(--muted); }

.footer-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
@media(max-width:800px){ .footer-grid{ grid-template-columns:1fr; } }

/* --- Poster-style What's On --- */
.poster{ overflow:hidden; }

.poster::before{
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(circle at 20% 10%, rgba(215,180,106,0.16), rgba(0,0,0,0) 40%),
    radial-gradient(circle at 80% 30%, rgba(139,30,45,0.18), rgba(0,0,0,0) 45%),
    repeating-linear-gradient(90deg, rgba(215,180,106,0.06) 0px, rgba(215,180,106,0.06) 1px, rgba(0,0,0,0) 1px, rgba(0,0,0,0) 18px);
  opacity:0.8;
  pointer-events:none;
}

.poster-top{ position:relative; text-align:center; padding:10px 0 2px; }

.poster-badge{
  display:inline-block;
  font-family:"Cinzel", Georgia, serif;
  font-weight:800;
  letter-spacing:3px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(215,180,106,0.35);
  background: rgba(0,0,0,0.18);
}

.poster-sub{
  margin-top:8px;
  color:var(--muted);
  letter-spacing:1px;
}

.poster-title{
  position:relative;
  text-align:center;
  margin-top:10px;
  margin-bottom:8px;
  font-size: 2.2rem;
}

.poster-note{
  position:relative;
  text-align:center;
  max-width:820px;
  margin:0 auto 14px;
}

.poster-grid{
  position:relative;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top:10px;
}
@media(max-width:950px){ .poster-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width:650px){ .poster-grid{ grid-template-columns: 1fr; } }

.poster-item{
  border:1px solid rgba(215,180,106,0.22);
  border-radius:16px;
  background: rgba(0,0,0,0.18);
  padding:14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

.poster-date{
  font-family:"Cinzel", Georgia, serif;
  letter-spacing:1px;
  font-weight:800;
}

.poster-time{ color:var(--muted); margin-top:4px; }
.poster-film{ margin-top:10px; }
.poster-meta{ margin-top:10px; }

.poster-bottom{
  position:relative;
  margin-top:16px;
  text-align:center;
}

.poster-line{
  height:1px;
  background: rgba(215,180,106,0.22);
  margin: 8px auto 10px;
  width: 70%;
}

.poster-small{ color:var(--muted); }

/* --- Member news --- */
.news-post{
  border:1px solid rgba(215,180,106,0.16);
  border-radius:16px;
  padding:14px;
  background: rgba(0,0,0,0.14);
  margin-bottom:12px;
}

/* --- Gallery --- */
.thumb-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}

.thumb{
  padding:0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  overflow:hidden;
  background: rgba(0,0,0,.12);
  cursor:pointer;
}

.thumb img{
  width:100%;
  height:110px;
  object-fit:cover;
  display:block;
  transition: transform .15s ease;
}

.thumb:hover img{ transform: scale(1.03); }

.section-title{
  color: rgb(215, 180, 106);
  font-size: 1.15rem;
  margin-top: 0;
}

.lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index: 9999;
}

.lightbox.open{ display:block; }

.lightbox-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.72);
}

.lightbox-panel{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%, -50%);
  width:min(980px, 92vw);
  background: rgba(15, 12, 10, .96);
  border:1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 20px 80px rgba(0,0,0,.55);
}

.lightbox-body{ text-align:center; }

.lightbox-body img{
  width:100%;
  height:auto;
  max-height: 72vh;
  object-fit: contain;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
}

.lightbox-close{
  position:absolute;
  top:12px;
  right:12px;
}

.lightbox-prev{
  position:absolute;
  left:12px;
  top:50%;
  transform: translateY(-50%);
}

.lightbox-next{
  position:absolute;
  right:12px;
  top:50%;
  transform: translateY(-50%);
}

.no-scroll{ overflow:hidden; }

/* =========================================================
   Cinema seat legend — match actual seat colours
   ========================================================= */

.legend{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}

.dot{
  width:10px;
  height:10px;
  border-radius:999px;
  display:inline-block;
  margin:0 6px;
}

/* Match .seat available */
.dot.available{
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.35);
}

/* Match .seat booked */
.dot.booked{
  background: rgba(160,0,0,.55);
  border: 1px solid rgba(255,255,255,.35);
}

/* Optional: if you add “mine” later */
.dot.mine{
  background: rgba(255,255,255,.25);
  border: 1px solid rgba(255,255,255,.65);
}
