/* ============================================================
   Bluebird Event Rentals
   Layout cloned from renderevents.co (editorial luxury) in a
   light "bluebird-sky" palette. Rebrand everything from :root.
   ============================================================ */
:root {
  /* Bluebird light-sky palette */
  --bg:        #eef4fb;   /* airy sky-tinted white (page base) */
  --bg-alt:    #dde9f5;   /* soft powder blue (alt sections) */
  --bg-nav:    #f7f2e7;   /* warm cream (nav bar) */
  --bg-deep:   #16344f;   /* deep navy (dark anchor bands / footer) */
  --ink:       #1b3a57;   /* primary text, deep bluebird navy */
  --muted-c:   #607a93;   /* muted slate-blue text */
  --accent:    #4f7196;   /* dusty slate bluebird-blue (buttons / links) */
  --accent-dp: #3a5878;   /* deeper slate (hover) */
  --gold:      #e2a13f;   /* warm amber pop (sparing accent) */
  --line:      #cfdcea;   /* hairline rules on light */
  --line-d:    rgba(255,255,255,0.22); /* hairline on dark */
  --white:     #ffffff;
  --maxw:      1180px;
  --ease:      cubic-bezier(0.22, 0.61, 0.36, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 96px; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ---------- Type system ---------- */
.display {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: 0.01em;
  color: var(--ink);
}
.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--accent);
  margin-bottom: 22px;
}
.eyebrow--light { color: var(--gold); }
.lede { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; line-height: 1.45; color: var(--ink); font-weight: 500; margin-bottom: 18px; }
.muted { color: var(--muted-c); font-size: 1.02rem; }
a { color: inherit; text-decoration: none; }

/* ---------- Reveal ---------- */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
[data-reveal].is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 16px 30px;
  border-radius: 2px;
  transition: background 0.3s var(--ease), transform 0.25s var(--ease), box-shadow 0.3s var(--ease);
}
.btn:hover { background: var(--accent-dp); transform: translateY(-2px); box-shadow: 0 12px 26px rgba(40,94,146,0.25); }
.btn--light { background: #fff; color: var(--ink); }
.btn--light:hover { background: #fff; color: var(--accent-dp); box-shadow: 0 12px 26px rgba(0,0,0,0.18); }
.btn--ghost-dark { background: transparent; color: var(--ink); border: 1px solid var(--accent); }
.btn--ghost-dark:hover { background: var(--accent); color: #fff; }

/* ---------- Nav (centered logo, split links) ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  background: var(--bg-nav);
  transition: background 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
  border-bottom: 1px solid var(--line);
}
.nav__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 32px;
  height: 86px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
}
.nav__group { display: flex; gap: 30px; align-items: center; }
.nav__group--right { justify-content: flex-end; }
.nav__group a { font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.18em; color: var(--accent-dp); font-weight: 500; transition: color 0.25s var(--ease); }
.nav__group a:hover { color: var(--gold); }
.nav__cta { color: #fff !important; background: var(--gold); border-radius: 999px; padding: 10px 22px; transition: background 0.25s var(--ease), transform 0.25s var(--ease), box-shadow 0.3s var(--ease); }
.nav__cta:hover { background: #c8862c; transform: translateY(-1px); box-shadow: 0 8px 18px rgba(200,134,44,0.30); }
.brand {
  text-align: center; line-height: 1; color: var(--accent-dp);
  font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.55rem; letter-spacing: 0.04em;
  transition: color 0.4s var(--ease);
}
.brand span { display: block; font-family: 'Inter', sans-serif; font-size: 0.58rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.3em; margin-top: 5px; opacity: 0.85; }
/* Solid cream at all times; scroll just deepens the shadow for separation */
.nav.is-solid { background: var(--bg-nav); border-bottom-color: var(--line); box-shadow: 0 6px 20px rgba(22,52,79,0.10); }
/* Hamburger (mobile only) */
.nav__toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 30px; height: 24px; background: none; border: 0; padding: 0; cursor: pointer; }
.nav__toggle span { display: block; height: 2px; width: 100%; background: var(--ink); border-radius: 2px; transition: transform 0.3s var(--ease), opacity 0.25s var(--ease); }
.nav.is-open .nav__toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2) { opacity: 0; }
.nav.is-open .nav__toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; justify-content: center; color: #fff; overflow: hidden; text-align: center; }
.hero__media { position: absolute; inset: 0; background: url('assets/img/ballroom-tables.jpg') center/cover no-repeat; transform: scale(1.06); animation: heroZoom 20s var(--ease) forwards; }
@keyframes heroZoom { to { transform: scale(1); } }
.hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,52,79,0.46), rgba(22,52,79,0.58)), radial-gradient(60% 50% at 50% 48%, rgba(22,52,79,0.45), rgba(22,52,79,0) 70%); }
.hero__lockup { position: relative; padding: 54px 60px; text-shadow: 0 2px 20px rgba(16,34,55,0.55); }
.hero__lockup h1 { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: clamp(3.4rem, 9vw, 7rem); line-height: 1; color: #fff; margin: 18px 0 14px; letter-spacing: 0.02em; }
.hero__tag { text-transform: uppercase; letter-spacing: 0.42em; font-size: clamp(0.72rem, 1.4vw, 0.95rem); font-weight: 500; }
.hero__promise { margin-top: 14px; display: flex; align-items: center; justify-content: center; gap: 14px; text-transform: uppercase; letter-spacing: 0.24em; font-size: 0.66rem; font-weight: 500; color: #fff; }
.hero__promise::before, .hero__promise::after { content: ""; width: 26px; height: 1px; background: var(--gold); opacity: 0.85; }
.hero__loc { margin-top: 12px; text-transform: uppercase; letter-spacing: 0.28em; font-size: 0.68rem; color: rgba(255,255,255,0.92); }
.hero__rino { margin-top: 16px; display: inline-block; text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.6rem; color: rgba(255,255,255,0.9); border: 1px solid rgba(255,255,255,0.35); border-radius: 999px; padding: 7px 16px; }
.hero__pin { color: var(--gold); font-size: 0.9em; }
.hero__rule { display: block; width: 64px; height: 1px; background: rgba(255,255,255,0.7); margin: 0 auto; }
.hero__mark { display: block; width: 104px; height: auto; margin: 0 auto 10px; filter: drop-shadow(0 2px 10px rgba(16,34,55,0.45)); }
.hero__scroll { position: absolute; left: 50%; bottom: 32px; transform: translateX(-50%); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.3em; color: rgba(255,255,255,0.85); }
.hero__scroll::after { content: ""; display: block; width: 1px; height: 34px; margin: 12px auto 0; background: rgba(255,255,255,0.6); animation: pulse 2s var(--ease) infinite; }
@keyframes pulse { 0%,100% { opacity: 0.3; transform: scaleY(0.6); } 50% { opacity: 1; transform: scaleY(1); } }

/* ---------- Memorable moments (split) ---------- */
.moments { padding: 82px 0; }
.moments__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.moments__text .display { font-size: clamp(2.4rem, 4.6vw, 3.6rem); margin-bottom: 26px; }
.moments__text .btn { margin-top: 16px; }
.moments__media { position: relative; min-height: 460px; }
.moments__img { position: absolute; background: var(--img) center/cover no-repeat; border-radius: 3px; box-shadow: 0 24px 50px rgba(22,52,79,0.18); }
.moments__img--back { width: 70%; height: 70%; top: 0; right: 0; }
.moments__img--front { width: 62%; height: 66%; bottom: 0; left: 0; border: 8px solid var(--bg); }

/* ---------- Featured / trusted ---------- */
.featured { padding: 56px 0 64px; background: var(--bg-alt); text-align: center; }
.featured__label { text-transform: uppercase; letter-spacing: 0.34em; font-size: 0.68rem; color: var(--muted-c); margin-bottom: 26px; }
.featured__row { display: flex; flex-wrap: wrap; justify-content: center; gap: 18px 52px; max-width: 980px; margin: 0 auto; padding: 0 24px; }
.featured__row span { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; letter-spacing: 0.04em; color: var(--ink); opacity: 0.62; }

/* ---------- Shape / inventory two-card ---------- */
.shape { padding: 82px 0; text-align: center; }
.section--alt { background: var(--bg-alt); }
.shape__head { max-width: 720px; margin: 0 auto 64px; padding: 0 32px; }
.shape__head .display { font-size: clamp(2.2rem, 4.6vw, 3.6rem); margin-bottom: 24px; }
.shape__sub { max-width: 560px; margin: 0 auto; }
.cards { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.bigcard { position: relative; min-height: 460px; border-radius: 3px; overflow: hidden; display: flex; align-items: flex-end; isolation: isolate; color: #fff; }
.bigcard::before { content: ""; position: absolute; inset: 0; z-index: -2; background: var(--img) center/cover no-repeat; transition: transform 0.8s var(--ease); }
.bigcard::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(22,52,79,0.52) 0%, rgba(22,52,79,0.55) 42%, rgba(22,52,79,0.88) 100%); }
.bigcard:hover::before { transform: scale(1.06); }
.bigcard__inner { padding: 44px 42px; text-align: left; text-shadow: 0 1px 14px rgba(16,34,55,0.5); }
.bigcard__kicker { font-family: 'Cormorant Garamond', serif; font-size: 1.9rem; margin-bottom: 12px; }
.bigcard__copy { font-size: 0.98rem; color: rgba(255,255,255,0.9); max-width: 42ch; margin-bottom: 24px; }

/* ---------- Quote bands ---------- */
.quote { position: relative; padding: 94px 32px; text-align: center; color: #fff; background: var(--img) center/cover no-repeat fixed; }
.quote__scrim { position: absolute; inset: 0; background: linear-gradient(rgba(22,52,79,0.66), rgba(22,52,79,0.74)); }
.quote__inner { position: relative; max-width: 800px; margin: 0 auto; }
.quote__inner p { font-family: 'Cormorant Garamond', serif; font-weight: 500; font-size: clamp(1.6rem, 3.4vw, 2.6rem); line-height: 1.3; }
.quote__inner cite { display: block; margin-top: 24px; font-style: normal; text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.72rem; color: var(--gold); }

/* ---------- Props (3 column) ---------- */
.props { padding: 82px 0; text-align: center; }
.props__head { max-width: 760px; margin: 0 auto 66px; padding: 0 32px; }
.props__head .display { font-size: clamp(2rem, 4.2vw, 3.2rem); margin-bottom: 22px; }
.props__grid { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; text-align: center; }
.prop { padding-top: 30px; border-top: 1px solid var(--line); }
.prop__num { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; color: var(--gold); display: block; margin-bottom: 14px; letter-spacing: 0.1em; }
.prop h3 { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.55rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink); margin-bottom: 14px; }
.prop p { color: var(--muted-c); font-size: 0.96rem; }
.props__cta { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 60px; }

/* ---------- About ---------- */
.about { padding: 82px 0; }
.about__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr 1.1fr; gap: 72px; align-items: center; }
.about__media { min-height: 520px; background: var(--img) center/cover no-repeat; border-radius: 3px; box-shadow: 0 24px 54px rgba(22,52,79,0.18); }
.about__text .display { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 24px; }
.about__text .display em { font-style: italic; color: var(--accent); }
.about__text .btn { margin-top: 26px; }

/* ---------- Big centered quote ---------- */
.bigquote { padding: 90px 32px; text-align: center; background: var(--bg-alt); }
.bigquote blockquote { max-width: 880px; margin: 0 auto; }
.bigquote .display { font-size: clamp(1.9rem, 4vw, 3.1rem); line-height: 1.25; }
.bigquote cite { display: block; margin-top: 26px; font-style: normal; text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.72rem; color: var(--accent); }

/* ---------- Finale ---------- */
.finale { position: relative; padding: 100px 32px; text-align: center; color: #fff; background: var(--img) center/cover no-repeat; overflow: hidden; }
.finale__scrim { position: absolute; inset: 0; background: linear-gradient(rgba(22,52,79,0.5), rgba(22,52,79,0.66)); }
.finale__inner { position: relative; max-width: 820px; margin: 0 auto; }
.finale__inner .display { color: #fff; font-size: clamp(2.4rem, 5.5vw, 4.4rem); margin-bottom: 34px; }

/* ---------- Booqable booking ---------- */
.book { padding: 78px 0; text-align: center; }
.book__inner { max-width: 860px; margin: 0 auto; padding: 0 32px; }
.book__inner .display { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 18px; }
.book__sub { max-width: 520px; margin: 0 auto; }
.embed-placeholder { border: 1px dashed var(--accent); border-radius: 3px; background: var(--white); padding: 56px 28px; text-align: center; color: var(--muted-c); margin-top: 40px; }
.embed-placeholder strong { color: var(--ink); font-size: 1.05rem; }
.embed-placeholder code { background: var(--bg-alt); padding: 2px 6px; border-radius: 4px; font-size: 0.88em; }
/* Booqable embeds (booking widget + live catalog) */
.book__embed { margin-top: 40px; min-height: 140px; text-align: left; }
.book__embed .booqable-datepicker { margin-bottom: 24px; }
.catalog__live { margin-top: 8px; min-height: 240px; }

/* ---------- Sub-page hero ---------- */
.pagehero { position: relative; min-height: 52vh; display: flex; align-items: center; justify-content: center; text-align: center; color: #fff; overflow: hidden; }
.pagehero__media { position: absolute; inset: 0; background: var(--img) center/cover no-repeat; }
.pagehero__scrim { position: absolute; inset: 0; background: linear-gradient(rgba(22,52,79,0.45), rgba(22,52,79,0.6)); }
.pagehero__inner { position: relative; padding: 130px 32px 70px; }
.pagehero h1 { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: clamp(2.6rem, 6vw, 4.6rem); color: #fff; margin: 14px 0 10px; }
.pagehero p { text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.72rem; color: rgba(255,255,255,0.85); }

/* ---------- Category subnav ---------- */
.catnav { position: sticky; top: 86px; z-index: 40; background: var(--bg); border-bottom: 1px solid var(--line); }
.catnav__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: flex; gap: 8px 30px; flex-wrap: wrap; justify-content: center; height: auto; min-height: 60px; align-items: center; }
.catnav a { text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.72rem; color: var(--muted-c); padding: 20px 0; font-weight: 500; transition: color 0.25s var(--ease); }
.catnav a:hover, .catnav a.is-active { color: var(--accent); }

/* ---------- Catalog embed ---------- */
.catalog { padding: 90px 0 130px; }
.catalog__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ---------- Portfolio gallery ---------- */
.gallery { padding: 90px 0 130px; }
.gallery__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; columns: 3; column-gap: 18px; }
.gallery figure { break-inside: avoid; margin: 0 0 18px; border-radius: 3px; overflow: hidden; box-shadow: 0 14px 34px rgba(22,52,79,0.12); }
.gallery img { width: 100%; display: block; transition: transform 0.7s var(--ease); }
.gallery figure:hover img { transform: scale(1.05); }
@media (max-width: 900px) { .gallery__inner { columns: 2; } }
@media (max-width: 560px) { .gallery__inner { columns: 1; } .catnav { top: 64px; } }

/* ---------- Inquire form ---------- */
.inquire { padding: 100px 0; }
.inquire__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 0.85fr 1.05fr; gap: 64px; align-items: start; }
.inquire__intro .display { font-size: clamp(2.2rem, 4.4vw, 3.4rem); margin-bottom: 22px; }
.inquire__intro { position: sticky; top: 120px; }
.inline-link { color: var(--accent); border-bottom: 1px solid var(--accent); }
.inline-link--light { color: #fff; border-bottom-color: rgba(255,255,255,0.6); }

/* ---------- Category SEO blocks (inventory) ---------- */
.catseo { padding: 64px 0 8px; background: var(--bg); }
.catseo__inner { max-width: 880px; margin: 0 auto; padding: 0 32px; }
.catseo__block { padding: 22px 0; border-bottom: 1px solid var(--line); }
.catseo__block h2 { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: clamp(1.5rem, 3vw, 2rem); color: var(--ink); margin-bottom: 10px; }
.catseo__block p { color: var(--muted-c); font-size: 1.02rem; }
.catseo__block strong { color: var(--ink); font-weight: 600; }
.catseo__cta { margin-top: 26px; color: var(--muted-c); font-size: 1.02rem; }
/* offset anchor jumps so headings clear the fixed nav */
#chairs, #tables, #linens { scroll-margin-top: 110px; }

/* Contact list (modern labeled rows) */
.contactlist { list-style: none; margin-top: 34px; border-top: 1px solid var(--line); }
.contactlist li { display: flex; gap: 20px; align-items: baseline; padding: 15px 2px; border-bottom: 1px solid var(--line); }
.contactlist__k { flex: 0 0 46px; text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.6rem; font-weight: 600; color: var(--accent); }
.contactlist a, .contactlist li > span:last-child { color: var(--ink); font-size: 0.98rem; }
.contactlist a { transition: color 0.2s var(--ease); }
.contactlist a:hover { color: var(--accent); }

/* Form card */
.inquire__form {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
  background: #fff; border: 1px solid var(--line); border-radius: 20px;
  padding: 40px 38px; box-shadow: 0 30px 70px -28px rgba(22,52,79,0.32);
}
.field--full { grid-column: 1 / -1; }
.field { display: flex; flex-direction: column; }
.field label { font-size: 0.82rem; font-weight: 500; color: var(--ink); margin-bottom: 9px; letter-spacing: 0.005em; }
.field input, .field select, .field textarea {
  width: 100%; padding: 14px 16px; background: #f6f9fc;
  border: 1px solid #dbe6f2; border-radius: 12px; font: inherit; font-size: 0.95rem;
  color: var(--ink); outline: none; appearance: none; -webkit-appearance: none;
  transition: border-color 0.2s var(--ease), background 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.field input::placeholder, .field textarea::placeholder { color: #9fb1c4; }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--accent); background: #fff; box-shadow: 0 0 0 4px rgba(58,124,184,0.14);
}
.field select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23607a93' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; cursor: pointer; }
.field textarea { resize: vertical; min-height: 120px; }
.inquire__form .btn { grid-column: 1 / -1; justify-self: stretch; text-align: center; border: 0; border-radius: 12px; padding: 17px 30px; cursor: pointer; }
.inquire__note { grid-column: 1 / -1; font-size: 0.8rem; color: var(--muted-c); margin-top: -4px; text-align: center; }
.subscribe__msg { margin-top: 10px; font-size: 0.82rem; color: rgba(255,255,255,0.85); min-height: 1em; }

/* ---------- Footer ---------- */
.footer { background: var(--bg-deep); color: #fff; padding: 70px 0 36px; }
.footer__top { text-align: center; padding-bottom: 48px; border-bottom: 1px solid var(--line-d); margin-bottom: 48px; }
.footer .brand--footer { color: #fff; font-size: 2rem; }
.footer__cols { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 44px; }
.footer__col h4 { font-family: 'Inter', sans-serif; text-transform: uppercase; letter-spacing: 0.22em; font-size: 0.7rem; font-weight: 500; color: var(--gold); margin-bottom: 18px; }
.footer__col p { color: rgba(255,255,255,0.78); font-size: 0.92rem; margin-bottom: 14px; }
.footer__col a { color: rgba(255,255,255,0.78); transition: color 0.25s var(--ease); }
.footer__col a:hover { color: #fff; }
.footer__nav { display: flex; flex-direction: column; gap: 9px; }
.footer__nav a { text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.78rem; }
.subscribe { display: flex; border: 1px solid var(--line-d); border-radius: 2px; overflow: hidden; max-width: 240px; }
.subscribe input { flex: 1; background: transparent; border: 0; padding: 11px 14px; color: #fff; font-size: 0.9rem; outline: none; }
.subscribe input::placeholder { color: rgba(255,255,255,0.5); }
.subscribe button { background: var(--accent); border: 0; color: #fff; padding: 0 16px; font-size: 1.1rem; cursor: pointer; transition: background 0.25s var(--ease); }
.subscribe button:hover { background: var(--accent-dp); }
.footer__bar { max-width: var(--maxw); margin: 48px auto 0; padding: 24px 32px 0; border-top: 1px solid var(--line-d); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; color: rgba(255,255,255,0.6); font-size: 0.8rem; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .moments__inner, .about__inner, .inquire__inner { grid-template-columns: 1fr; gap: 48px; }
  .inquire__intro { position: static; }
  .moments__media { min-height: 380px; }
  .cards { grid-template-columns: 1fr; }
  .props__grid { grid-template-columns: 1fr; gap: 0; }
  .prop { margin-top: 30px; }
  .footer__cols { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media (max-width: 620px) {
  /* Collapsing mobile nav with hamburger menu */
  .nav__inner { display: flex; flex-wrap: wrap; align-items: center; height: 64px; padding: 0 24px; }
  .brand { order: 1; }
  .nav__toggle { display: flex; order: 2; margin-left: auto; }
  .nav__group { display: none; order: 3; width: 100%; flex-direction: column; gap: 0; }
  .nav__group--right { order: 4; }
  .nav.is-open .nav__group { display: flex; }
  .nav.is-open .nav__inner { height: auto; padding-bottom: 14px; }
  .nav__group a { padding: 13px 0; width: 100%; text-align: center; }
  .nav__cta { border-bottom: none; }
  .catnav { top: 64px; }
  .moments, .shape, .props, .about, .book, .inquire { padding: 72px 0; }
  .inquire__form { grid-template-columns: 1fr; }
  .quote, .finale { padding: 84px 24px; }
  .quote { background-attachment: scroll; }
  .footer__cols { grid-template-columns: 1fr; }
  .footer__bar { flex-direction: column; }
}

/* ---------- Product catalog grid (inventory.html) ---------- */
.catalog__count { text-align: center; color: var(--muted-c); font-size: 0.9rem; letter-spacing: 0.04em; margin: -18px 0 46px; }
.catnav__n { color: var(--accent); font-size: 0.66rem; opacity: 0.8; }
.catgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.pcard { background: var(--white); border: 1px solid var(--line); border-radius: 3px; overflow: hidden; display: flex; flex-direction: column; transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease); }
.pcard:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(22,52,79,0.14); }
.pcard__media { aspect-ratio: 1 / 1; background: #fff; border-bottom: 1px solid var(--line); overflow: hidden; }
.pcard__media img { width: 100%; height: 100%; object-fit: contain; padding: 7%; transition: transform 0.6s var(--ease); }
.pcard:hover .pcard__media img { transform: scale(1.05); }
.pcard__body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 5px; flex: 1; }
.pcard__cat { text-transform: uppercase; letter-spacing: 0.18em; font-size: 0.6rem; color: var(--accent); font-weight: 500; }
.pcard__name { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.28rem; color: var(--ink); line-height: 1.15; }
.pcard__brand { font-size: 0.64rem; color: var(--muted-c); text-transform: uppercase; letter-spacing: 0.14em; }
.pcard__foot { margin-top: auto; padding-top: 13px; display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--line); }
.pcard__price { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; font-weight: 600; color: var(--ink); }
.pcard__price span { font-family: 'Inter', sans-serif; font-size: 0.68rem; font-weight: 400; color: var(--muted-c); margin-left: 1px; }
.pcard__stock { font-size: 0.64rem; color: var(--muted-c); text-transform: uppercase; letter-spacing: 0.1em; }
.pcard.is-hidden { display: none; }
.catalog__empty { text-align: center; color: var(--muted-c); padding: 60px 0; }
@media (max-width: 1000px) { .catgrid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .catgrid { grid-template-columns: repeat(2, 1fr); gap: 18px; } }
@media (max-width: 440px)  { .catgrid { grid-template-columns: 1fr 1fr; gap: 12px; } .pcard__name { font-size: 1.1rem; } }

/* ===== How it works ===== */
.howto { padding: 82px 0; text-align: center; }
.howto__head { max-width: 720px; margin: 0 auto 54px; padding: 0 32px; }
.howto__head .display { font-size: clamp(2rem, 4vw, 3rem); }
.howto__grid { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: repeat(4,1fr); gap: 34px; }
.howstep { text-align: left; padding-top: 22px; border-top: 2px solid var(--accent); }
.howstep__n { font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; color: var(--gold); letter-spacing: 0.1em; }
.howstep h3 { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.35rem; color: var(--ink); margin: 8px 0 10px; }
.howstep p { color: var(--muted-c); font-size: 0.95rem; }
@media (max-width: 860px){ .howto__grid { grid-template-columns: 1fr 1fr; gap: 26px; } }
@media (max-width: 460px){ .howto__grid { grid-template-columns: 1fr; } }

/* ===== FAQ ===== */
.faq { padding: 82px 0; }
.faq__head { max-width: 720px; margin: 0 auto 40px; padding: 0 32px; text-align: center; }
.faq__head .display { font-size: clamp(2rem, 4vw, 3rem); }
.faq__list { max-width: 780px; margin: 0 auto; padding: 0 32px; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__item summary { list-style: none; cursor: pointer; padding: 20px 40px 20px 0; position: relative; font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; font-weight: 600; color: var(--ink); }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__icon { position: absolute; right: 4px; top: 50%; width: 14px; height: 14px; transform: translateY(-50%); }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--accent); transition: transform 0.25s var(--ease); }
.faq__icon::before { left: 0; top: 6px; width: 14px; height: 2px; }
.faq__icon::after { left: 6px; top: 0; width: 2px; height: 14px; }
.faq__item[open] .faq__icon::after { transform: scaleY(0); }
.faq__item p { color: var(--muted-c); font-size: 0.98rem; padding: 0 40px 22px 0; margin-top: -4px; }

/* ===== Inquire contact list ===== */
.contactlist { margin-top: 28px; display: grid; gap: 12px; }
.contactlist li { display: flex; gap: 16px; align-items: baseline; }
.contactlist__k { text-transform: uppercase; letter-spacing: 0.18em; font-size: 0.62rem; color: var(--accent); min-width: 44px; }
.contactlist a:hover { color: var(--accent); }
.footer__social a:hover { color: var(--gold); }

/* ===== Inventory tools (search + sort) ===== */
.cattools { max-width: var(--maxw); margin: 0 auto 30px; padding: 0 32px; display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.cattools__search { flex: 1; min-width: 220px; max-width: 460px; padding: 13px 16px; border: 1px solid var(--line); border-radius: 2px; font: inherit; color: var(--ink); background: var(--white); outline: none; }
.cattools__search:focus { border-color: var(--accent); }
.cattools__sort { padding: 13px 16px; border: 1px solid var(--line); border-radius: 2px; font: inherit; color: var(--ink); background: var(--white); cursor: pointer; }

/* ===== Add-to-quote button ===== */
.pcard__add { margin-top: 14px; width: 100%; border: 1px solid var(--accent); background: transparent; color: var(--accent); font-size: 0.66rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; padding: 11px; border-radius: 2px; cursor: pointer; transition: background 0.2s var(--ease), color 0.2s var(--ease); }
.pcard__add:hover { background: var(--accent); color: #fff; }
.pcard__add.is-added { background: var(--bg-deep); border-color: var(--bg-deep); color: #fff; }

/* ===== Quote bar + drawer ===== */
.quotebar { position: fixed; right: 22px; bottom: 22px; z-index: 70; background: var(--bg-deep); color: #fff; border: 0; border-radius: 999px; padding: 15px 26px; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; cursor: pointer; box-shadow: 0 10px 30px rgba(22,52,79,0.34); }
.quotebar:hover { background: var(--accent-dp); }
.qscrim { position: fixed; inset: 0; background: rgba(22,52,79,0.5); z-index: 80; }
.qdrawer { position: fixed; top: 0; right: 0; width: min(400px, 90vw); height: 100%; background: var(--bg); z-index: 90; transform: translateX(100%); transition: transform 0.35s var(--ease); display: flex; flex-direction: column; box-shadow: -10px 0 40px rgba(22,52,79,0.2); }
.qdrawer.is-open { transform: none; }
.qdrawer__head { display: flex; justify-content: space-between; align-items: center; padding: 24px 24px 18px; border-bottom: 1px solid var(--line); }
.qdrawer__head h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: var(--ink); }
.qdrawer__close { background: none; border: 0; font-size: 1.8rem; line-height: 1; color: var(--muted-c); cursor: pointer; }
.qdrawer__items { flex: 1; overflow-y: auto; padding: 8px 24px; }
.qdrawer__empty { color: var(--muted-c); text-align: center; padding: 40px 0; }
.qitem { display: grid; grid-template-columns: 1fr auto; gap: 4px 12px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.qitem__name { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; color: var(--ink); line-height: 1.2; }
.qitem__rate { font-size: 0.74rem; color: var(--muted-c); }
.qitem__qty { display: flex; align-items: center; gap: 8px; }
.qitem__qty button { width: 26px; height: 26px; border: 1px solid var(--line); background: var(--white); border-radius: 2px; cursor: pointer; color: var(--ink); font-size: 1rem; line-height: 1; }
.qitem__qty span { min-width: 22px; text-align: center; font-size: 0.85rem; }
.qitem__rm { background: none; border: 0; color: var(--muted-c); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; cursor: pointer; justify-self: end; }
.qitem__rm:hover { color: var(--accent-dp); }
.qdrawer__foot { padding: 20px 24px; border-top: 1px solid var(--line); }
.qdrawer__total { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; color: var(--ink); display: flex; justify-content: space-between; align-items: baseline; }
.qdrawer__total small { font-size: 0.7rem; color: var(--muted-c); font-family: 'Inter', sans-serif; }
.qdrawer__note { font-size: 0.74rem; color: var(--muted-c); margin: 8px 0 16px; }
.qdrawer__foot .btn { width: 100%; text-align: center; }
.qdrawer__clear { width: 100%; margin-top: 10px; background: none; border: 0; color: var(--muted-c); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.14em; cursor: pointer; }

/* ===== Lightbox ===== */
.lightbox { position: fixed; inset: 0; z-index: 95; background: rgba(22,52,79,0.92); display: flex; align-items: center; justify-content: center; padding: 40px; }
.lightbox__fig { max-width: 760px; text-align: center; }
.lightbox__fig img { max-width: 100%; max-height: 78vh; border-radius: 3px; background: #fff; }
.lightbox__fig figcaption { color: #fff; margin-top: 16px; font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; }
.lightbox__close { position: absolute; top: 22px; right: 28px; background: none; border: 0; color: #fff; font-size: 2.4rem; line-height: 1; cursor: pointer; }

/* ============================================================
   Legal / policy pages (Rental Agreement, etc.)
   ============================================================ */
.legal { padding: 64px 0 96px; }
.legal__inner { max-width: 820px; margin: 0 auto; padding: 0 32px; }
.legal__meta { text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.7rem; color: var(--muted-c); margin-bottom: 28px; }
.legal__intro { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; line-height: 1.5; color: var(--ink); margin-bottom: 14px; }
.legal p { color: var(--ink); font-size: 1rem; line-height: 1.7; margin-bottom: 14px; }
.legal h2 {
  font-family: 'Cormorant Garamond', serif; font-weight: 600;
  font-size: 1.7rem; color: var(--ink);
  margin: 46px 0 6px; padding-top: 22px; border-top: 1px solid var(--line);
}
.legal h2 .legal__num { color: var(--accent); margin-right: 10px; }
.legal h3 { font-size: 1.02rem; font-weight: 600; color: var(--ink); margin: 22px 0 6px; }
.legal ul { margin: 8px 0 16px; padding-left: 22px; }
.legal li { color: var(--ink); font-size: 1rem; line-height: 1.7; margin-bottom: 8px; }
.legal a { color: var(--accent); text-decoration: underline; }
.legal a:hover { color: var(--accent-dp); }
.legal strong { color: var(--ink); }
.legal__tldr {
  background: var(--bg-alt); border: 1px solid var(--line);
  border-radius: 6px; padding: 26px 30px; margin: 0 0 18px;
}
.legal__tldr h2 { border: 0; padding: 0; margin: 0 0 12px; font-size: 1.45rem; }
.legal__tldr ul { margin-bottom: 0; }
.legal__contactcard {
  background: var(--bg-deep); color: #fff; border-radius: 6px;
  padding: 28px 32px; margin-top: 40px;
}
.legal__contactcard h3 { color: #fff; margin-top: 0; }
.legal__contactcard p { color: rgba(255,255,255,0.88); }
.legal__contactcard a { color: #fff; }
@media print {
  .nav, .footer, .pagehero, .legal__tldr a { display: none !important; }
  .legal { padding: 0; }
  .legal p, .legal li, .legal h2, .legal h3 { color: #000; }
}
