/* =========================================================
   01. Design Tokens / Variables
   ========================================================= */

   :root {
  --paper: #f6f2e8;
  --ink: #111;
  --muted: #555;
  --accent: #c89b3c;
  --border: #1a1a1a;
}
/* =========================================================
   02. Reset & Base
   ========================================================= */

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
}


/* =========================================================
   03. Typography
   ========================================================= */



h1 {
  font-size: clamp(2.4rem, 5vw, 3.2rem);
  font-weight: 500;
  margin-bottom: 18px;
}

h2 {
  font-size: 2.25rem;
  font-weight: 500;
  margin: 48px 0 12px;
}

p {
  max-width: 720px;
  margin-bottom: 18px;
  font-size: 1.15rem;
  line-height: 1.65;
}

ul {
  max-width: 760px;
  margin: 0.6em 0 0.6em 1.2em;
}

li {
  margin: 0.3em 0;
}


/* =========================================================
   04. Layout Primitives
   ========================================================= */
 *{box-sizing:border-box}
    body{
      margin:0;font-family:Georgia,"Times New Roman",serif;
      background:var(--paper);color:var(--ink);line-height:1.55
    }
 .page{max-width:960px;margin:0 auto;padding:64px 24px 96px}
    h1{font-size:clamp(2.4rem,5vw,3.2rem);font-weight:500;margin-bottom:18px}
    h2 {
      font-size: 2.25rem;
      font-weight: 500;
      margin: 48px 0 12px;
    }
        p{max-width:760px;margin-bottom:14px}
    ul{max-width:760px;margin:12px 0 0 18px}
    li{margin-bottom:6px}
    .label{display:inline-block;border:1px solid var(--border);
      padding:4px 10px;font-size:.75rem;letter-spacing:.12em;margin-bottom:18px}
    .section{border-top:1px solid var(--border);padding-top:32px;margin-top:48px}


.article {
  max-width: 960px;
  margin: 0 auto;
  padding: 64px 24px 96px;
}


.container {
  max-width: 960px;
  margin: 0 auto;
  padding: 64px 24px 96px;
}


.section {
  border-top: 1px solid var(--border);
  padding-top: 32px;
  margin-top: 48px;
}


/* =========================================================
   05. Components
   ========================================================= */

.label {
  display: inline-block;
  border: 1px solid var(--border);
  padding: 4px 10px;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  margin-bottom: 14px;
}


.cta-strip {
  padding: 22px;
  margin: 64px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.cta {
  border: 2px solid var(--border);
  padding: 10px 18px;
  text-decoration: none;
  color: var(--ink);
  font-weight: 600;
}

.cta.primary {
  background: var(--accent);
  color: #000;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 18px;
  font-size: 0.95rem;
}

th, td {
  border: 1px solid var(--border);
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}

th {
  background: rgba(0,0,0,0.04);
}



.quote {
  font-family: Georgia, serif;
  font-style: italic;
  font-size: 1.4rem;
  color: var(--muted);
  margin: 22px 0 32px;
  border-left: 2px solid var(--accent);
  padding-left: 1.15rem;
  letter-spacing: 0.01em;
  line-height: 1.45;
}
 
/* =========================================================
   06. Page Sections
   ========================================================= */

.areas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 24px;
}

.area {
  border: 1px solid var(--border);
  padding: 22px;
  background: #fffdf7;
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
  display: flex;
  flex-direction: column;
}

.area:hover {
  transform: translateY(-2px);
  box-shadow: 2px 3px 0 var(--border);
}

.area small {
  display: block;
  color: var(--muted);
  letter-spacing: 0.08em;
  font-size: 0.8rem;
  margin-bottom: 10px;
}

.poster {
  border: 2px solid var(--border);
  padding: 28px;
  margin-bottom: 64px;
}

.price {
  font-size: 1.2rem;
  font-weight: 600;
  margin-top: 18px;
}

.price span {
  display: block;
  margin-top: 4px;
  color: var(--accent);
}

.concept-wall {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.concept {
  display: block;
  border: 1px solid var(--border);
  padding: 14px 16px;
  font-size: 0.95rem;
  text-decoration: none;
  color: var(--ink);
  background: transparent;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.concept:hover {
  transform: translateY(-2px);
  box-shadow: 2px 3px 0 var(--border);
  background: rgba(200, 155, 60, 0.05);
}

.booking-container {
  display: none;
  max-width: 680px;
  margin: 0 auto;
  padding-bottom: 96px;
}

.booking-container.active {
  display: block;
}

.concepts-container.hidden {
  display: none;
}

.back {
  display: inline-block;
  margin-bottom: 20px;
  color: var(--muted);
  text-decoration: none;
  font-size: 0.9rem;
  cursor: pointer;
}

.back:hover {
  color: var(--ink);
  text-decoration: underline;
}

.category-tag {
  display: inline-block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 4px 10px;
  margin-bottom: 20px;
}

.concept-meta {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 20px;
}

.summary {
  font-size: 1.1rem;
  line-height: 1.6;
  max-width: 60ch;
  margin-bottom: 40px;
}

.links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
  margin-top: 24px;
}

.link-card {
  border: 1px solid var(--border);
  padding: 22px;
  background: #fffdf7;
  text-decoration: none;
  color: var(--ink);
}

.link-card small {
  display: block;
  color: var(--muted);
  letter-spacing: 0.08em;
  font-size: 0.8rem;
  margin-bottom: 10px;
}


.qr-img {
  position: fixed;
  top: 10px;
  left: 10px;
  z-index: 60;
  background: #2986ffc8;
  border: 1px solid var(--border);
  width: 5rem;
  max-height: 5rem;
  aspect-ratio: 11 / 11;
  display: flex;
  opacity: 0.8;
  transition: opacity 1s, background 1s;
}

.image-holder {
  height: 250px;
  width: 200px;
  opacity: 0.5;
  transition: opacity 1s, background 1s;
}

.image-holder:hover {
  opacity: 1;
  background: #EBEFF7;
}



/* =========================================================
   07. Forms
   ========================================================= */

footer {
  margin-top: 16px;
  padding-top: 14px;
  font-size: 0.85rem;
  color: var(--muted);
}

.contact {
  max-width: 960px;
  margin: 0 auto;
  padding: 64px 24px 96px;
}

.form-section {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 2px solid var(--border);
  display: none;
}

.form-section.is-visible {
  display: block;
}

.journey-form {
  display: none;
}

.journey-form.is-visible {
  display: block;
}

.booking-form {
  display: block;
}

label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  text-transform: uppercase;
}

input, select, textarea {
  width: 100%;
  background: #fffdf7;
  border: 1px solid var(--border);
  padding: 12px;
  font-family: inherit;
  font-size: 1.1rem;
  margin-bottom: 24px;
  color: var(--ink);
  border-radius: 0;
}

input:focus, select:focus, textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.inline-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

button {
  top: 3 px;
  background: var(--ink);
  color: var(--paper);
  border: 2px solid var(--ink);
  padding: 14px 32px;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s ease;
  font-color: var(--paper)
}

button:hover {
  background: transparent;
  color: var(--ink);
}

.notice {
  background: rgba(200, 155, 60, 0.1);
  border: 1px solid var(--accent);
  padding: 16px;
  margin-top: 24px;
  font-size: 0.9rem;
  font-style: italic;
}

.confirmation {
  display: none;
  margin-top: 32px;
  padding: 24px;
  border: 2px solid var(--accent);
  background: rgba(200, 155, 60, 0.05);
}

.confirmation pre {
  background: #fff;
  padding: 16px;
  border: 1px solid var(--border);
  overflow-x: auto;
  font-size: 0.85rem;
  white-space: pre-wrap;
}

.error-state {
  text-align: center;
  padding: 60px 20px;
}

.error-state h1 {
  color: var(--error);
}

/* =========================================================
   08. Utilities & States
   ========================================================= */

.editorial-header.is-hidden {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}
.editorial-header {
  position: sticky;
  top: 0;
  z-index: 100;
min-height:7rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;

  background: var(--paper);
  border-bottom: 1px solid var(--border);
  padding: 16px 24px;

  transition:
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.45s ease;

  will-change: transform, opacity;
}



.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.4rem;
  cursor: pointer;
  margin-left: auto;
}


.header-qr {
  width: 5rem;        /* hard ownership */
  flex-shrink: 0;
  display: flex;
  align-items: center;
}


.qr-img {
  display: block;
  width: 5rem;
  aspect-ratio: 1 / 1;
  background: #2986ffc8;
  border: 1px solid var(--border);
  opacity: 0.85;
  transition: opacity 0.3s ease, background 0.3s ease;
}

.qr-img:hover {.header-qr {
  width: 5rem;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.qr-img {
  display: block;
  width: 5rem;
  aspect-ratio: 1 / 1;
  background: #2986ffc8;
  border: 1px solid var(--border);
  opacity: 0.85;
  transition: opacity 0.3s ease, background 0.3s ease;
}

.qr-img img {
  width: 100%;
  display: block;
}

  opacity: 1;
  background: #EBEFF7;
}

.qr-img img {
  width: 100%;
  height: auto;
  display: block;
}



.path-nav {
  flex: 1 1 auto;
  max-width: 960px;
}

.path-links {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  font-size: 0.95rem;
}

.path-nav small {
  display: block;
  margin-bottom: 14px;
  color: var(--muted);
  letter-spacing: 0.12em;
  font-size: 0.7rem;
}


.path-links a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.path-links a:hover {
  border-bottom-color: var(--ink);
}




.index-image {
  margin-top: 96px;
}

.index-image img {
  width: 100%;
  height: auto;
  aspect-ratio: 17 / 11;
  object-fit: cover;
  border: 2px solid var(--border);
  display: block;
  opacity: 0.87;
}



.index-image-qr {
  margin-top: 96px;
}

.index-image-qr img {
  width: 10rem;
  height: auto;
  aspect-ratio: 11 / 11;
  object-fit: fit;
  border: 0px solid var(--border);
  display: block;
  opacity: 0.87;
}


.hint {
  color: var(--muted);
  font-size: 0.9rem;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 24px;
}
.card-base {
  border: 1px solid var(--border);
  background: #fffdf7;
  color: var(--ink);
  text-decoration: none;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.card-base:hover {
  transform: translateY(-2px);
  box-shadow: 2px 3px 0 var(--border);
}

.card {
  border: 2px solid var(--border);
  padding: 18px 16px;
  text-decoration: none;
  color: var(--ink);
  background: #fffdf7;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 2px 3px 0 var(--border);
}

.card-title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 6px;
}

.card-meta {
  font-size: 0.85rem;
  color: var(--muted);
}

/* Article stream */

.article-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.article h2 {
  font-size: 2rem;
  font-weight: 500;
  margin: 0;
  max-width: 720px;
}

.meta {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.status {
  border: 1px solid var(--border);
  padding: 4px 10px;
}

.tags {
  margin-top: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.tag {
  font-size: 0.75rem;
  color: var(--muted);
}

.content {
  margin-top: 24px;
  max-width: 760px;
}

.content h3 {
  margin-top: 32px;
  font-size: 1.25rem;
  font-weight: 600;
}

.content p {
  margin-bottom: 14px;
}

.article:hover {
  transform: none;
  box-shadow: none;
}





/* =========================================================
   09. Responsive Overrides
   ========================================================= */
   
   

/* ---------- Burger Menu ---------- */
.hamburger{display:none; flex-direction:column; gap:4px; width:28px; height:22px; background:transparent; border:none; cursor:pointer}
.hamburger span{display:block; height:3px; width:100%; background:#fff; border-radius:2px; transition:all .3s ease}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
@media(max-width:900px){
  .nav ul{display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--nav); padding:1rem; border-radius:0 0 12px 12px}
  .nav ul.active{display:flex}
  .hamburger{display:flex}
}

 
@media (max-width: 1024px) {
  .menu-toggle {
    display: block;

  }

  .path-links {
    display: none;
    flex-direction: column;
    gap: 16px;
    margin-top: 16px;
  }

  .editorial-header.is-open .path-links {
    display: flex;
  }
}


@media (max-width: 900px) {
  .areas { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .inline-fields { grid-template-columns: 1fr; gap: 0; }
}

@media (max-width: 480px) {
  .inline-fields {
    grid-template-columns: 1fr;
  }
}




/* nely added */

.media-image img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 2rem auto;
}

.media-video iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
}

.media-link {
  border: 1px solid var(--border, #ddd);
  padding: 1rem;
  margin: 2rem 0;
  font-size: 0.9rem;
}


.doc-switcher {
  position: fixed;
  bottom: 12px;
  right: 12px;
  display: flex;
  gap: 6px;
  opacity: 0.15;
  transition: opacity 0.2s;
  z-index: 999;
}

.doc-switcher:hover {
  opacity: 0.9;
}

.doc-switcher input {
  width: 140px;
  padding: 4px 6px;
  font-size: 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #fff;
}

.doc-switcher button {
  padding: 4px 8px;
  font-size: 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #eee;
  cursor: pointer;
}




        /* The special rotating link */
        .rotating-nav-item {
            position: relative;
            display: inline-block;
            min-width: 100px; /* Prevents layout shift */
            text-align: left;
            color: #2580e2 !important;
            font-weight: 500;
            text-decoration: none
        }

        .rotating-nav-item span {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            opacity: 0;
            transform: translateY(4px);
            transition: all 0.4s ease;
            pointer-events: none;
        }

        .rotating-nav-item span.active {
            opacity: 1;
            transform: translateY(0);
            position: relative;
            pointer-events: auto;
        }

        /* Hover pause */
        .rotating-nav-item:hover span {
            transition-duration: 0.2s;
        }


            .red-font {
            position: relative;
            display: inline-block;
            min-width: 100px; /* Prevents layout shift */
            text-align: left;
            color: #970f00 !important;
            font-weight: 500;
            text-decoration: none
        }


        .red-font-nav-item span {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            opacity: 0;
            transform: translateY(4px);
            transition: all 0.4s ease;
            pointer-events: none;
        }