/* ===========================================================================
   Salon Hollywood - shared stylesheet for every page.
   One file controls the whole site's look. Tokens live in :root.
   Identity: classic-cinema glamour for a 1997 Emmaus institution -
   espresso black, champagne gold, warm cream. Cinzel (engraved display caps)
   paired with Jost (clean geometric body). Star + marquee motif throughout.
   Type is an explicit scale in LITERAL rem; spacing follows a 4px base.
   =========================================================================== */
:root {
  --bone: #f6f0e4;          /* warm cream page canvas */
  --ink: #1b1712;           /* primary text on cream (very high contrast) */
  --muted: #5b5147;         /* secondary text (AA on cream) */
  --accent: #855512;        /* antique gold - links/marks, AA as text on cream */
  --accent-soft: #e2c486;   /* champagne - for use ON the espresso bands only */
  --deep: #16120c;          /* espresso-black band background */
  --panel: #fffaf0;         /* slightly lifted card surface */
  --measure: 38rem;
  --gap: 1rem;
  --gap-2: 1.5rem;
  --gap-3: 2rem;
  --gap-4: 3rem;
  --gap-5: 4.5rem;
  --edge: clamp(1.25rem, 5vw, 4rem);
  --rule: 1px solid color-mix(in srgb, var(--ink) 16%, transparent);
  --hair: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  --font-display: 'Cinzel', 'Times New Roman', Georgia, serif;
  --font-body: 'Jost', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background-color: var(--bone);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* ---- type: explicit scale -> 13 / 16 / 18 / 22 / 28 / 32 / 40 / 56 px ---- */
h1 { font-family: var(--font-display); font-weight: 700; font-size: 2.5rem;
     line-height: 1.08; letter-spacing: 0.01em; margin: 0 0 1rem; color: var(--ink); }
h2 { font-family: var(--font-display); font-weight: 600; font-size: 1.75rem;
     line-height: 1.18; letter-spacing: 0.01em; margin: 0 0 0.75rem; color: var(--ink); }
h3 { font-family: var(--font-body); font-weight: 600; font-size: 1.375rem;
     line-height: 1.3; margin: 0 0 0.5rem; color: var(--ink); }
p  { margin: 0 0 1rem; max-width: var(--measure); }
.lede { font-family: var(--font-body); font-size: 1.375rem; line-height: 1.55;
        color: var(--muted); max-width: 34rem; font-weight: 300; }
.kicker { font-family: var(--font-body); text-transform: uppercase;
          letter-spacing: 0.22em; font-size: 0.8125rem; font-weight: 600;
          color: var(--accent); margin: 0 0 0.75rem; display: flex;
          align-items: center; gap: 0.5rem; }
.measure { max-width: var(--measure); }
.lead-in { font-size: 1.375rem; font-weight: 300; color: var(--ink); max-width: 40rem; }

/* ---- star motif (shape-only SVG, set color via currentColor) ---- */
.star { display: inline-block; vertical-align: middle; width: 0.875rem; height: 0.875rem;
        color: var(--accent); flex: none; }
.star svg { display: block; width: 100%; height: 100%; fill: currentColor; }
.star-lg { width: 1.375rem; height: 1.375rem; }

/* ---- links & buttons (hover + focus on everything interactive) ---- */
a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px;
    text-decoration-thickness: 1px; }
a:hover { text-decoration-thickness: 2px; }
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--accent); outline-offset: 2px;
}
.skip { position: absolute; left: -9999px; }
.skip:focus { left: 1rem; top: 1rem; background-color: var(--ink); color: var(--bone);
              padding: 0.5rem 1rem; z-index: 10; text-decoration: none; }

.btn {
  display: inline-block; font-family: var(--font-body); font-weight: 600;
  font-size: 1rem; letter-spacing: 0.04em; text-decoration: none; cursor: pointer;
  background-color: var(--accent); color: var(--bone);
  border: 2px solid var(--accent); border-radius: 2px;
  padding: 0.75rem 1.5rem; transition: transform .12s ease, background-color .12s ease;
}
.btn:hover { transform: translateY(-2px); background-color: var(--ink);
             border-color: var(--ink); color: var(--bone); }
.btn-sm { padding: 0.5rem 1rem; font-size: 1rem; }

/* ---- marquee top strip - espresso band, identical on every page ---- */
.marquee { background-color: var(--deep); padding: 0.5rem var(--edge);
           text-align: center; border-bottom: 2px solid var(--accent); }
.marquee p { color: var(--accent-soft); background-color: var(--deep);
             margin: 0; max-width: none; font-size: 0.8125rem;
             letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500; }
.marquee b { color: var(--bone); background-color: var(--deep); font-weight: 600; }
.marquee .star { color: var(--accent-soft); background-color: var(--deep);
                 width: 0.625rem; height: 0.625rem; margin: 0 0.5rem; }

/* ---- header / nav (byte-identical across pages) ---- */
.site-head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem 1.5rem;
  padding: 1.25rem var(--edge); border-bottom: var(--rule);
}
.wordmark { display: flex; align-items: center; gap: 0.5rem;
            font-family: var(--font-display); font-weight: 700; font-size: 1.375rem;
            color: var(--ink); text-decoration: none; letter-spacing: 0.04em;
            text-transform: uppercase; }
.wordmark:hover { color: var(--accent); }
.site-head nav ul { display: flex; flex-wrap: wrap; align-items: center;
                    gap: 1.25rem; margin: 0; padding: 0; list-style: none; }
.site-head nav a { color: var(--ink); text-decoration: none; font-weight: 500;
                   font-size: 1rem; letter-spacing: 0.04em; }
.site-head nav a:hover { color: var(--accent); }
.site-head .btn { color: var(--bone); background-color: var(--accent); }
.site-head .btn:hover { color: var(--bone); background-color: var(--ink);
                        border-color: var(--ink); }

main { display: block; }
section { padding: var(--gap-5) var(--edge); border-bottom: var(--rule); }

/* ---- asymmetric masthead - deliberately NOT a centered hero ---- */
.masthead { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4);
            align-items: end; }
.masthead-lead { min-width: 0; }
.masthead-lead h1 { font-size: 3.5rem; }
.masthead-aside { min-width: 0; }
.masthead .btn { margin-top: 0.5rem; }

/* the "billing block" - styled like a film credit panel */
.facts { margin: 0; border-top: 2px solid var(--accent);
         border-bottom: 2px solid var(--accent); padding: 1rem 0; }
.facts dt { font-weight: 600; font-size: 0.8125rem; text-transform: uppercase;
            letter-spacing: 0.16em; color: var(--muted); margin-top: 1rem; }
.facts dt:first-child { margin-top: 0; }
.facts dd { margin: 0.25rem 0 0; font-family: var(--font-display);
            font-weight: 600; font-size: 1.375rem; color: var(--ink); }

/* ---- divider with a centered star ---- */
.starline { display: flex; align-items: center; gap: 1rem; margin: 0;
            color: var(--accent); }
.starline::before, .starline::after { content: ""; height: 1px; flex: 1 1 auto;
            background-color: color-mix(in srgb, var(--accent) 45%, transparent); }

/* ---- badges ---- */
.badge { display: inline-block; font-family: var(--font-body); font-size: 0.8125rem;
         letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600;
         color: var(--accent); border: 1px solid var(--accent);
         padding: 0.25rem 0.75rem; border-radius: 2px; }

/* ---- quiet champagne band (rhythm break, light) ---- */
.band-quiet { background-color: color-mix(in srgb, var(--accent) 9%, var(--bone)); }
.band-quiet .measure { max-width: 42rem; }

/* ---- stat strip (light, champagne) - reuses the type scale ---- */
.stat-strip { background-color: color-mix(in srgb, var(--accent) 9%, var(--bone)); }
.stats { list-style: none; margin: 0; padding: 0; display: grid;
         grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr)); gap: var(--gap-3); }
.stats li { border-left: 2px solid var(--accent); padding-left: 1.25rem; }
.stat-num { display: block; font-family: var(--font-display); font-weight: 700;
            font-size: 3.5rem; line-height: 1; color: var(--ink); }
.stat-cap { display: block; margin-top: 0.5rem; font-size: 1rem; color: var(--muted);
            letter-spacing: 0.04em; }

/* ---- reflowing list - auto-fit, unclassed children (never a 3-card grid) ---- */
.listing > h2 { max-width: var(--measure); }
.reflow { list-style: none; margin: var(--gap-3) 0 0; padding: 0; display: grid;
          grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: var(--gap-3); }
.reflow-wide { grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr)); }
.reflow li { padding: 1.5rem; border: var(--rule); border-top: 3px solid var(--accent);
             border-radius: 3px; background-color: var(--panel); }
.reflow li h3 { margin-top: 0.5rem; }
.reflow p { margin-bottom: 0; color: var(--muted); }
.reflow .more { display: inline-block; margin-top: 0.75rem; font-weight: 600;
                font-size: 1rem; }

/* ---- service menu (single column, hairline rules) ---- */
.menu { list-style: none; margin: var(--gap-3) 0 0; padding: 0; max-width: 46rem; }
.menu li { padding: 1.25rem 0; border-bottom: var(--rule); }
.menu li:last-child { border-bottom: none; }
.svc-head { display: flex; justify-content: space-between; align-items: baseline;
            gap: 1rem; flex-wrap: wrap; }
.svc-name { font-family: var(--font-body); font-weight: 600; font-size: 1.375rem;
            color: var(--ink); }
.svc-cat { font-family: var(--font-body); font-size: 0.8125rem; text-transform: uppercase;
           letter-spacing: 0.16em; font-weight: 600; color: var(--accent); }
.menu p { margin: 0.25rem 0 0; max-width: var(--measure); color: var(--muted);
          font-size: 1.125rem; }
.price-note { margin: var(--gap-3) 0 0; max-width: var(--measure);
              font-size: 1rem; color: var(--muted); border-left: 2px solid var(--accent);
              padding-left: 1rem; }

/* ---- split (story + side panel) ---- */
.split { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4); align-items: start; }
.split h2 { margin-top: var(--gap-3); }
.split h2:first-child { margin-top: 0; }
.side-note { border-top: 3px solid var(--accent); padding-top: 1rem; }
.ticks { margin: 0; padding-left: 1.1rem; }
.ticks li { margin-bottom: 0.5rem; color: var(--muted); }

/* ---- team list (auto-fit, unclassed children) ---- */
.roster { list-style: none; margin: var(--gap-3) 0 0; padding: 0; display: grid;
          grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); gap: var(--gap-3); }
.roster li { border: var(--rule); border-top: 3px solid var(--accent); border-radius: 3px;
             padding: 1.5rem; background-color: var(--panel); }
.roster .photo-slot { display: flex; align-items: center; justify-content: center;
            height: 9rem; margin-bottom: 1rem; border: var(--hair); border-radius: 2px;
            background-color: color-mix(in srgb, var(--accent) 8%, var(--bone)); }
.roster .role { font-size: 1rem; letter-spacing: 0.04em; color: var(--accent);
            font-weight: 600; text-transform: uppercase; }
.roster p { margin: 0.5rem 0 0; color: var(--muted); }

/* ---- dark spotlight band - every text child RESTATES the dark background ---- */
.spotlight { background-color: var(--deep); }
.spotlight h2 { color: var(--bone); background-color: var(--deep); }
.spotlight .kicker { color: var(--accent-soft); background-color: var(--deep); }
.spotlight p { color: var(--accent-soft); background-color: var(--deep); max-width: var(--measure); }
.spotlight .lead-in { color: var(--bone); background-color: var(--deep); max-width: 40rem; }
.spotlight .starline { color: var(--accent-soft); background-color: var(--deep); }
.spotlight .starline::before, .spotlight .starline::after {
            background-color: color-mix(in srgb, var(--accent-soft) 40%, transparent); }
.spotlight .star { color: var(--accent-soft); background-color: var(--deep); }

/* ---- dark invitation band - light text RESTATES the dark background ---- */
.invite { background-color: var(--deep); }
.invite h2 { color: var(--bone); background-color: var(--deep); }
.invite p  { color: var(--accent-soft); background-color: var(--deep); max-width: var(--measure); }
.invite .star { color: var(--accent-soft); background-color: var(--deep); }
.btn-on-dark { background-color: var(--accent-soft); color: var(--deep); border-color: var(--accent-soft); }
.btn-on-dark:hover { background-color: var(--bone); border-color: var(--bone); color: var(--deep); }

.page-intro { padding-top: var(--gap-5); }
.page-intro h1 { max-width: 20ch; }

/* ---- contact - fields are unclassed <p> styled via parent>child ---- */
.contact-grid { display: grid; grid-template-columns: 3fr 2fr; gap: var(--gap-4); align-items: start; }
.contact-form { display: grid; gap: var(--gap-2); max-width: 32rem; }
.contact-form p { margin: 0; display: grid; gap: 0.5rem; max-width: none; }
.contact-form label { font-weight: 600; font-size: 1rem; }
.form-note { background-color: color-mix(in srgb, var(--accent) 12%, var(--bone));
             border: var(--rule); border-left: 3px solid var(--accent);
             padding: 0.75rem 1rem; font-size: 1rem; color: var(--ink); }
input, select, textarea {
  font: inherit; color: var(--ink); background-color: #ffffff;
  border: 1px solid color-mix(in srgb, var(--ink) 30%, transparent);
  border-radius: 2px; padding: 0.5rem 0.75rem; width: 100%;
}
.contact-aside { border-left: 3px solid var(--accent); padding-left: 1.25rem; }
.contact-aside h2 { margin-top: var(--gap-3); }
.contact-aside h2:first-child { margin-top: 0; }
.hours { list-style: none; margin: 0.5rem 0 0; padding: 0; }
.hours li { display: flex; justify-content: space-between; gap: 1rem;
            padding: 0.5rem 0; border-bottom: var(--rule); color: var(--muted); }
.hours li:last-child { border-bottom: none; }

/* ---- footer - light text RESTATES the dark background ---- */
.site-foot { background-color: var(--deep); color: var(--bone); padding: var(--gap-4) var(--edge);
             border-bottom: none; }
.site-foot p { color: var(--bone); background-color: var(--deep); max-width: none; margin: 0 0 0.5rem; }
.foot-mark { display: flex; align-items: center; gap: 0.5rem;
             font-family: var(--font-display); font-size: 1.375rem; font-weight: 600;
             letter-spacing: 0.04em; text-transform: uppercase; }
.foot-mark .star { color: var(--accent-soft); background-color: var(--deep); }
.foot-contact { color: var(--accent-soft); background-color: var(--deep); }
.foot-contact a { color: var(--accent-soft); background-color: var(--deep); }
.foot-fine { color: var(--accent-soft); background-color: var(--deep); font-size: 0.8125rem;
             letter-spacing: 0.04em; }

/* ---- responsive ---- */
@media (max-width: 820px) {
  .masthead, .split, .contact-grid { grid-template-columns: 1fr; }
  .masthead { align-items: start; }
  .masthead-lead h1 { font-size: 2.5rem; }
}
@media (max-width: 720px) {
  section { padding-top: var(--gap-4); padding-bottom: var(--gap-4); }
  .site-head { gap: 0.75rem 1rem; }
}
@media (min-width: 1000px) {
  h2 { font-size: 2rem; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}
