
:root{
  --bg-deep:#050615;
  --bg-1:#0b0e1f;
  --bg-2:#0d132f;
  --card:rgba(255,255,255,.05);
  --glass:rgba(18,22,46,.55);
  --stroke:rgba(255,255,255,.14);
  --accent:#9b5cff;
  --accent-2:#2ee6d5;
  --text:#e9edff;
  --muted:#b9c2dc;
  }

#map {
  height: 100%;
  width: 100%;
}

.contact-right {
  position: relative;
}

* { box-sizing: border-box; }

body.site{
  background:
    radial-gradient(1200px 800px at 10% -10%, #1f1140 0%, transparent 55%),
    radial-gradient(800px 600px at 110% 120%, #13354a 0%, transparent 60%),
    var(--bg-deep);
  color: var(--text);
  font-family: "Manrope","Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Noto Sans","Noto Sans SC",sans-serif;
  line-height: 1.6;
}


a{ color:#fff; text-decoration:none; }
a:hover{ color:#fff; text-decoration:underline; }

.loading-overlay{position:fixed;z-index:999;inset:0;display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.8)}

.py-6{ padding-top:72px; padding-bottom:72px; }


.site-lang-fixed {
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 1050;
}
.site-lang-fixed .pay-lang-btn {
  background: rgba(18, 22, 46, .85);
  backdrop-filter: blur(8px);
}
.navbar{ background: transparent; }
.navbar .navbar-brand{ letter-spacing:.4px; }
.brand-dot{ width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:inline-block;box-shadow:0 0 16px var(--accent);}


.navbar .nav-link{ color:rgba(255,255,255,.9); padding:.5rem .75rem; font-weight:600; }
.navbar .nav-link:hover{ color:var(--accent); }


.hero{
  position:relative;
  color:#fff;
  padding-bottom:0;
}
.hero--compact{ padding-bottom:0; }
.orbit-bg{
  background:
    linear-gradient(180deg, rgba(0,0,0,.7), rgba(0,0,0,.35)),
    url("/static/cinema/rooms/room6.6f39e6c393e6.jpg") top center/cover no-repeat;
}
.hero-title{
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
  background:linear-gradient(90deg,#ffffff 0%,#c6d4ff 40%,#9b5cff 60%,#2ee6d5 85%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-size: clamp(42px,7vw,92px);
  margin: 0;
}
.hero-tagline{
  font-size: clamp(20px,3.2vw,32px);
  margin: .75rem auto;
  font-weight:700;
  text-shadow: 0 8px 22px rgba(0,0,0,.55);
}
.hero-desc{
  max-width: 850px;
  color: var(--muted);
}
.cta-glow{
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#000; font-weight:800; padding:14px 24px; border-radius:999px;
  box-shadow:0 8px 30px rgba(155,92,255,.45);
}
.cta-glow:hover{ text-decoration:none; filter:saturate(1.1); }

.hero-features{
  display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
  margin-top:28px;
}
.hf{
  display:flex; align-items:center; gap:8px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius:999px; padding:8px 12px;
  backdrop-filter: blur(6px);
  font-weight:600;
}


.brand-strip{ background:linear-gradient(0deg,rgba(0,0,0,.6),rgba(0,0,0,.3)); padding:18px 0; margin-top:32px; }
.brand-logo{ opacity:.9; filter:grayscale(1) contrast(1.2); }
.shadow-top{ box-shadow: inset 0 1px 0 rgba(255,255,255,.05); }


.contact-wrap{ background: radial-gradient(1200px 600px at -10% -10%,#1a1f37 20%,transparent 60%), radial-gradient(800px 500px at 110% 110%,#14253b 20%,transparent 60%); box-shadow: 0 20px 40px rgba(0,0,0,.35); }
.contact-left{ background: linear-gradient(140deg,rgba(108,168,255,.12),rgba(196,224,63,.078)); padding: clamp(24px,4vw,48px); height: 100%; display:flex; flex-direction:column; justify-content:center; gap:18px; }
.contact-eyebrow{ letter-spacing:.12em; text-transform:uppercase; font-weight:800; opacity:.7 }
.contact-title{ font-size: clamp(32px,3.6vw,44px); font-weight:800; line-height:1.1; margin:0; }
.contact-address{ font-size: clamp(20px,2.5vw,29px); color:#d7def2; }
.map-shell{ height:100%; min-height:320px; border:1px dashed rgba(255,255,255,.08); border-radius:0; overflow:hidden; background:#0b0e1a }
#map{ height:100%; width:100%; filter:saturate(1.05) contrast(1.02); }
.map-badge{ position:absolute; top:18px; right:18px; background:rgba(15,18,32,.6); color:#fff; border:1px solid rgba(255,255,255,.18); border-radius:12px; padding:10px 12px; backdrop-filter:blur(8px); font-size:14px; display:flex; align-items:center; gap:8px;}
.ping{ width:10px;height:10px;border-radius:50%;background:var(--accent); box-shadow:0 0 0 0 rgba(108,168,255,.6); animation: ping 1.8s infinite; }
@keyframes ping{ 0%{box-shadow:0 0 0 0 rgba(108,168,255,.6);} 70%{box-shadow:0 0 0 12px rgba(108,168,255,0);} 100%{box-shadow:0 0 0 0 rgba(108,168,255,0);} }
.chips{ display:flex; flex-wrap:wrap; gap:.45rem; }
.chip{ display:inline-flex; align-items:center; padding:.35rem .6rem; border-radius:999px; background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02)); border:1px solid rgba(255,255,255,.12); font-size:.85rem; color:#e9efff; white-space:nowrap; }


.section-header h2{ font-weight:800; margin:0 0 .25rem; }
.section-header .muted{ color:var(--muted); margin:0 0 1.25rem; }

.section-gradient-1 {
  position: relative;
  background:
    radial-gradient(30% 50% at 100% 50%, rgba(217, 208, 26, 0.2), transparent 100%),
    radial-gradient(30% 50% at 0% 50%, rgba(26, 217, 184, 0.2), transparent 100%)
}

.section-gradient-2 {
  background:
    radial-gradient(50% 50% at 100% 50%, rgb(26, 144, 217, 0.2), transparent 100%),
    radial-gradient(50% 50% at 0% 50%, rgb(217, 26, 64, 0.2), transparent 100%)
}



.pink{ color:#ff70e7; } .blue{ color:#7db8ff; }


.hall-card{
  background: var(--glass);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  overflow:hidden;
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
  display:flex; flex-direction:column;
  transition: transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  backdrop-filter: blur(6px);
}
.hall-card:hover{ transform: translateY(-4px); box-shadow:0 18px 48px rgba(0,0,0,.45); border-color:rgba(255,255,255,.16); }

.hall-media{ position:relative; aspect-ratio:16/9; background:#0b0e1a; }
.hall-media img{ width:100%; height:100%; object-fit:cover; display:block; }

.hall-body{ padding:18px 18px 20px; flex:1 1 auto; display:flex; flex-direction:column; }
.hall-title{ font-size:1.25rem; margin:0 0 .35rem; font-weight:800; letter-spacing:.2px; }
.hall-desc{ color:#c8d0e6; margin-bottom:.9rem; --desc-lines:3; line-height:1.5; min-height:calc(var(--desc-lines)*1.5em); display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:var(--desc-lines); overflow:hidden; }
.hall-subtitle{ margin-top:.25rem; margin-bottom:.35rem; font-weight:800; font-size:.95rem; color:#eaefff; opacity:.9; }
.icon-list{ list-style:none; padding:0; margin:0 0 .75rem; display:grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap:.5rem .9rem; }
.icon-list li{ display:flex; align-items:flex-start; gap:.5rem; min-width:0; word-break:break-word; overflow-wrap:anywhere; }
.icon-list .bi{ flex:0 0 auto; font-size:1rem; opacity:.9; }

.button-booking{ display:block; font-size:18px; color:#000; text-decoration:none; background:linear-gradient(135deg,var(--accent),var(--accent-2)); width:auto; height:57px; font-weight:800; position:relative; margin-left:15px!important; margin-top:auto; border-radius:14px; box-shadow: 0 8px 30px rgba(155,92,255,.35); }
.button-booking:hover{ text-decoration:none; color:#000; filter:saturate(1.05); }


.section-steps{ background: radial-gradient(700px 400px at 20% -10%, #1a1f37 0%, transparent 60%), radial-gradient(600px 360px at 120% 120%, #162b3f 0%, transparent 60%); }
.step-card{ background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:18px; height:100%; box-shadow:0 12px 24px rgba(0,0,0,.25); }
.step-num{ font-weight:800; font-size:1.1rem; letter-spacing:.08em; margin-bottom:.25rem; color:#cfe4ff; }


#faq {
  position: relative;
  background: radial-gradient(900px 600px at 50% 0%, rgba(155, 92, 255, 0.2), transparent 70%),
              linear-gradient(180deg, rgba(0, 0, 0, 0.9) 0%, rgba(10, 12, 24, 0.95) 100%);
  color: var(--text);
  overflow: hidden;
}

#faq::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(46, 230, 213, 0.15), transparent 60%);
  opacity: 0.4;
  pointer-events: none;
}

.faq-card {
  background: var(--glass);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 24px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(8px);
  overflow: hidden;
}

.accordion-item {
  background: transparent;
  border: none;
  margin-bottom: 10px;
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.3s ease;
}

.accordion-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(155, 92, 255, 0.25);
}

.accordion-button {
  position: relative;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
  color: var(--text);
  font-weight: 700;
  font-size: 1.05rem;
  border: none;
  padding: 1rem 1.25rem 1rem 3rem; 
  transition: background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

#faq .accordion-item:first-of-type .accordion-button {
  border-top-left-radius: 16px !important;
  border-top-right-radius: 16px !important;
}

#faq .accordion-item:last-of-type .accordion-button.collapsed {
  border-bottom-left-radius: 16px !important;
  border-bottom-right-radius: 16px !important;
}

#faq .accordion-item {
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 8px;
}

#faq .accordion-button {
  border-radius: inherit;
  background: rgba(255, 255, 255, 0.02);
  transition: all 0.25s ease;
}

#faq .accordion-button:not(.collapsed) {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

#faq .accordion-collapse.show .accordion-body {
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

.accordion-button::before {
  content: attr(data-icon);
  position: absolute;
  left: 1rem;
  font-family: "bootstrap-icons";
  font-size: 1.2rem;
  color: var(--accent);
  text-shadow: 0 0 6px rgba(155, 92, 255, 0.4);
  transition: transform 0.3s ease, color 0.3s ease;
}

.accordion-button:not(.collapsed)::before {
  color: #fff;
  transform: rotate(180deg);
}

.accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
}

.accordion-body {
  background: rgba(255, 255, 255, 0.03);
  color: var(--muted);
  font-size: 1rem;
  padding: 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  line-height: 1.6;
  animation: fadeIn 0.4s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

#faq .fs-1 {
  text-align: center;
  margin-bottom: 1.5rem;
  background: linear-gradient(90deg, #fff, #9b5cff, #2ee6d5);
  -webkit-background-clip: text;
  color: transparent;
  font-weight: 800;
  text-transform: uppercase;
}


.addon{ --right-width: 160px; display:grid; grid-template-columns: 72px minmax(0,1fr) var(--right-width); grid-template-areas:"img content right"; align-items:center; gap:14px; padding:10px; border-radius:16px; border:1px solid rgba(255,255,255,.08); transition: transform .15s ease, border-color .2s ease; }
.addon:hover{ transform: translateY(-2px); border-color:rgba(255,255,255,.2); }
.addon img,.addon .addon-img{ grid-area: img; width:72px; height:72px; object-fit:cover; border-radius:12px; }
.addon .content{ grid-area: content; min-width:0; overflow-wrap: break-word; word-break: break-word; display:flex; flex-direction:column; justify-content:center; }
.addon .right{ grid-area: right; width:var(--right-width); white-space:nowrap; }
.addon .price{ display:inline-flex; align-items:baseline; gap:4px; white-space:nowrap; }
.btn-qty{ width:28px; height:28px; border:none; border-radius:8px; background:rgba(255,255,255,0.08); color:#fff; font-size:18px; cursor:pointer; transition: background .2s; }
.btn-qty:hover{ background:rgba(255,255,255,0.01); }
.addon-count,.hours{ width:36px; padding:0; background:transparent; color:#fff; border:none; font-weight:700; text-align:center; appearance:textfield; -moz-appearance:textfield; }
.addon-count::-webkit-outer-spin-button,.addon-count::-webkit-inner-spin-button,.hours::-webkit-outer-spin-button,.hours::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.addon-check-right .form-check-input{ width:18px; height:18px; cursor:pointer; }

.total-box{ position:sticky; top:16px; }
.glass{ background: var(--glass); border: 1px solid rgba(255,255,255,.1); border-radius: 24px; backdrop-filter: blur(6px); box-shadow: 0 12px 32px rgba(0,0,0,.35); }


.footer{ border-top: 1px solid rgba(255,255,255,.08); }


.block-shadow{ position:relative; }
.block-shadow-bottom::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -40px;
	height: 40px;
	background: linear-gradient(to bottom,rgba(0,0,0,.6),rgba(0,0,0,0));
	pointer-events: none;
	z-index: 5;
}

.block-shadow-top::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: -40px;
	height: 40px;
	background: linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,0));
	pointer-events: none;
	z-index: 5;
}

@media (max-width: 576px){
  .addon{ grid-template-columns:56px 1fr; grid-template-areas:"img content" "img controls"; align-items:start; gap:10px 12px; }
  .addon img,.addon .addon-img{ width:56px; height:56px; }
  .addon .right{ grid-area:controls; width:100%; white-space:nowrap;}
  .btn-qty{ width:26px; height:26px; font-size:16px; }
  .addon-count{ width:34px; }
}

/* Mobile site layout */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 1040;
  background: rgba(5, 6, 21, 0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 8px 0;
}
.site-nav-toggler {
  border-color: rgba(255,255,255,.25);
  padding: 6px 10px;
}
.site-nav-toggler .navbar-toggler-icon {
  filter: invert(1);
}

@media (max-width: 991px) {
  .py-6 { padding-top: 48px; padding-bottom: 48px; }
  .hero .container { padding-top: 24px !important; padding-bottom: 24px !important; }
  .hero-title { font-size: clamp(32px, 10vw, 56px); line-height: 1.05; }
  .hero-tagline { font-size: clamp(18px, 5vw, 24px); }
  .hero-desc { font-size: 15px; padding: 0 8px; }
  .hero-features { gap: 8px; margin-top: 20px; padding: 0 8px; }
  .hf { font-size: 13px; padding: 6px 10px; }
  .brand-strip .container { gap: 20px !important; padding: 12px 16px; }
  .brand-logo { max-height: 28px; width: auto; }
  .contact-wrap .row { flex-direction: column; }
  .contact-left { min-height: auto; padding: 24px 20px; }
  .map-shell { min-height: 240px; }
  .map-badge { top: 12px; right: 12px; font-size: 12px; padding: 8px 10px; }
  .section-header h2 { font-size: clamp(22px, 6vw, 32px); }
  .hall-card { margin-bottom: 4px; }
  .hall-body { padding: 14px 14px 16px; }
  .hall-title { font-size: 1.1rem; }
  .hall-desc { --desc-lines: 4; min-height: auto; font-size: 14px; }
  .icon-list { grid-template-columns: 1fr; gap: .35rem; }
  .button-booking { height: 50px; font-size: 16px; margin-left: 0 !important; border-radius: 12px; }
  .step-card { padding: 14px; }
  .footer .container { flex-direction: column; text-align: center; gap: 12px !important; }
  #faq .fs-1 { font-size: clamp(24px, 7vw, 36px) !important; }
  .accordion-button { font-size: .95rem; padding: .85rem 1rem .85rem 2.75rem; }
  .navbar .nav-link { padding: .65rem .5rem; font-size: 15px; }
  .navbar-nav { padding: 8px 0 12px; }
  .cta-glow { padding: 12px 20px; font-size: 15px; width: 100%; max-width: 320px; justify-content: center; }
}

@media (max-width: 576px) {
  .display-2 { font-size: 2rem; }
  .col-lg-6.col-xl-4 { padding-left: 12px; padding-right: 12px; }
  .glass { border-radius: 18px; }
  .total-box { position: static; margin-top: 16px; }
}

.booking-error-overlay {
  position: fixed;
  inset: 0;
  z-index: 10050;
  background: rgba(0, 0, 0, 0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.booking-error-card {
  max-width: 480px;
  width: 100%;
  background: #1a1f2e;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  padding: 24px;
  color: #e9edff;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  position: relative;
  z-index: 2;
}
.booking-error-title {
  margin: 0 0 12px;
  font-size: 1.35rem;
  font-weight: 700;
  color: #f87171;
}
.booking-error-text {
  margin: 0 0 20px;
  line-height: 1.55;
  font-size: 15px;
  color: #cbd5e1;
}
.booking-error-close {
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(90deg, #7c3aed, #a855f7);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
}
.booking-error-arrow {
  position: fixed;
  right: 72px;
  bottom: 88px;
  z-index: 10051;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: none;
  animation: booking-arrow-bounce 1.2s ease-in-out infinite;
}
.booking-error-arrow-line {
  width: 2px;
  height: 48px;
  background: #fbbf24;
}
.booking-error-arrow-head {
  color: #fbbf24;
  font-size: 22px;
  line-height: 1;
  margin-top: -4px;
}
@keyframes booking-arrow-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(8px); }
}
@media (max-width: 576px) {
  .booking-error-arrow { right: 24px; bottom: 72px; }
}
