
:root {
  --bg: #0b0c10;
  --panel: #111318;
  --card: #141821;
  --muted: #9ea7b8;
  --text: #f3f4f6;
  --line: rgba(255,255,255,.08);
  --gold: #f3f4f6;
  --gold-soft: rgba(255,255,255,.12);
  --surface: #f7f5f0;
  --surface-text: #1b1d22;
  --surface-muted: #606773;
  --surface-line: rgba(20,24,33,.1);
  --max: 1180px;
  --radius: 20px;
  --shadow: 0 30px 60px rgba(0,0,0,.18);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #06070a 0%, #0b0c10 45%, #0e1015 100%);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
.site-header {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: blur(18px);
  background: rgba(8,10,14,.72);
  border-bottom: 1px solid var(--line);
}
.header-row { display:flex; align-items:center; gap:20px; justify-content:space-between; min-height:76px; }
.brand { letter-spacing:.16em; font-size:.88rem; text-transform:uppercase; white-space:nowrap; }
.brand strong { font-weight:600; }
.nav { display:flex; align-items:center; gap:4px; flex-wrap:wrap; }
.nav > .item { position:relative; }
.nav a.top, .nav button.top {
  color:#ecedf0; background:none; border:none; font:inherit; padding:12px 14px; border-radius:999px; cursor:pointer;
}
.nav a.top:hover, .nav button.top:hover { background: rgba(255,255,255,.06); }
.dropdown {
  position:absolute; left:0; top:calc(100% + 10px); min-width:260px; background:#0f1217; border:1px solid var(--line); border-radius:16px; padding:10px; box-shadow:var(--shadow); display:none;
}
.item:hover .dropdown, .item:focus-within .dropdown { display:block; }
.dropdown a { display:block; padding:10px 12px; border-radius:12px; color:#d8dde6; }
.dropdown a:hover { background:rgba(255,255,255,.05); }
.header-cta { padding:12px 18px; border-radius:999px; background:#f2f5f8; color:#0a0d12; font-weight:600; white-space:nowrap; }
.mobile-toggle { display:none; }
.hero {
  position:relative; min-height:72svh; display:flex; align-items:flex-end; overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero::after {
  content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(5,6,8,.18) 0%, rgba(8,10,14,.42) 44%, rgba(8,10,14,.92) 100%);
}
.hero-media { position:absolute; inset:0; }
.hero-media img { width:100%; height:100%; object-fit:cover; }
.hero-content { position:relative; z-index:1; padding:120px 0 56px; }
.eyebrow { display:inline-block; padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.08); border:1px solid var(--line); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:#e8e8ea; }
.hero h1 { margin:18px 0 16px; max-width:900px; font-size: clamp(2.4rem, 5.5vw, 4.75rem); line-height:1.03; letter-spacing:-.04em; }
.hero .lede { max-width:780px; font-size:1.12rem; line-height:1.75; color:#e0e4ea; }
.actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:50px; padding:0 18px; border-radius:999px; font-weight:600; }
.btn-primary { background:#f2f5f8; color:#0a0d12; }
.btn-secondary { border:1px solid rgba(255,255,255,.14); color:#eff1f4; background:rgba(255,255,255,.03); }
main { background: var(--surface); color: var(--surface-text); }
.section { padding: 82px 0; border-bottom:1px solid var(--surface-line); }
.section-dark { background:#0f1318; color:#edf0f4; }
.kicker { font-size:.8rem; text-transform:uppercase; letter-spacing:.14em; color:#ffffff; font-weight:700; }
.section h2 { font-size: clamp(1.9rem,4vw,3.1rem); line-height:1.08; letter-spacing:-.04em; margin:12px 0 18px; }
.section .intro { max-width:780px; font-size:1.05rem; line-height:1.8; color:var(--surface-muted); }
.grid { display:grid; gap:24px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.card { background:#fff; border:1px solid var(--surface-line); border-radius:var(--radius); overflow:hidden; box-shadow:0 18px 50px rgba(21,24,31,.06); }
.card-media { aspect-ratio: 16 / 10; overflow:hidden; }
.card-media img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.card:hover .card-media img { transform:scale(1.03); }
.card-body { padding:22px; }
.card-title { font-size:1.28rem; line-height:1.2; margin:0 0 10px; letter-spacing:-.02em; }
.card p { margin:0; color:var(--surface-muted); line-height:1.72; }
.card .link { display:inline-flex; margin-top:16px; font-weight:700; color:#ffffff; }
.info-grid { display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:18px; margin-top:28px; }
.info-card { background:#fff; border:1px solid var(--surface-line); border-radius:18px; padding:22px; }
.info-card h3 { margin:0 0 8px; font-size:1rem; text-transform:uppercase; letter-spacing:.08em; color:#ffffff; }
.info-card p { margin:0; line-height:1.7; color:var(--surface-muted); }
.columns { display:grid; grid-template-columns: 1.2fr .8fr; gap:36px; align-items:start; }
.list-card { background:#fff; border:1px solid var(--surface-line); border-radius:18px; padding:26px; }
.list-card h3 { margin:0 0 12px; font-size:1.1rem; }
ul.clean { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
ul.clean li { padding-left:18px; position:relative; line-height:1.7; color:var(--surface-muted); }
ul.clean li::before { content:''; width:8px; height:8px; border-radius:50%; background:#ffffff; position:absolute; left:0; top:.68em; }
.prose { line-height:1.85; color:var(--surface-muted); }
.cta-band { background:linear-gradient(180deg,#10141a 0%, #0b0d12 100%); color:#edf1f5; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cta-wrap { display:flex; justify-content:space-between; gap:24px; align-items:center; }
.cta-wrap p { color:#cfd6df; max-width:720px; line-height:1.8; }
.footer { background:#090b0f; color:#d7dde6; padding:38px 0 58px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:28px; }
.footer h4 { margin:0 0 10px; letter-spacing:.08em; text-transform:uppercase; font-size:.76rem; color:#ffffff; }
.footer p, .footer a { color:#d7dde6; line-height:1.8; }
.mini { font-size:.95rem; color:#dde2eb; }
.placeholder { min-height:60vh; display:grid; place-items:center; text-align:center; }
.placeholder .panel { width:min(760px, calc(100% - 32px)); background:#fff; color:#14161a; padding:42px; border-radius:24px; box-shadow:var(--shadow); }
.page-intro { margin-bottom:36px; }
.caption { color:var(--surface-muted); font-size:.95rem; margin-top:10px; }
@media (max-width: 1040px) {
  .grid-3 { grid-template-columns:1fr 1fr; }
  .info-grid { grid-template-columns:1fr 1fr; }
  .columns { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width: 820px) {
  .header-row { min-height:70px; }
  .mobile-toggle { display:block; background:none; border:none; color:#fff; font-size:1rem; }
  .nav-shell { display:none; width:100%; }
  .site-header.open .nav-shell { display:block; padding-bottom:16px; }
  .nav { display:block; }
  .nav > .item { display:block; }
  .nav a.top, .nav button.top { width:100%; text-align:left; padding:12px 0; border-radius:0; }
  .dropdown { position:static; display:block; background:transparent; border:none; padding:0 0 12px 14px; box-shadow:none; min-width:0; }
  .dropdown a { padding:8px 0; }
  .header-cta { display:inline-flex; margin-top:8px; }
  .hero { min-height:64svh; }
  .grid-2, .grid-3, .info-grid, .footer-grid { grid-template-columns:1fr; }
  .cta-wrap { display:block; }
}


/* mobile rescue pass 2 add-on */
@media (max-width: 980px) {
  .feature-media-row,
  .media-row,
  .design-application-grid,
  .rooms-grid,
  .post-grid,
  .style-grid,
  .review-grid,
  .review-lead,
  .gallery-rail,
  .split-stack {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }
  .gallery-rail { overflow: visible !important; grid-auto-flow: row !important; grid-auto-columns: auto !important; }
  .card-media.tall,
  .feature-media-row .card-media,
  .feature-media-row .card-media.tall,
  .media-row .card-media,
  .media-row .card-media.tall {
    height: 260px !important;
    min-height: 0 !important;
  }
  .site-footer .footer-grid,
  .site-footer .footer-compact,
  .site-footer .footer-links,
  .site-footer .footer-group-inline {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .site-footer .footer-group-inline a { display:block !important; margin:6px 0 0 !important; }
}


/* Black Label Alpha Patch — dark/white guardrail + desktop header no-wrap */
:root {
  --gold: #f3f4f6;
  --gold-soft: rgba(255,255,255,.12);
  --surface: #070a0e;
  --surface-text: #f3f4f6;
  --surface-muted: #c9d1dc;
  --surface-line: rgba(255,255,255,.10);
}
main,
.section,
.section:nth-of-type(even) {
  background: #070a0e !important;
  color: #f3f4f6 !important;
}
.card,
.info-card,
.list-card {
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.028)) !important;
  color: #f3f4f6 !important;
  border-color: rgba(255,255,255,.10) !important;
}
.card p,
.info-card p,
.list-card li,
.prose,
.section .intro,
p {
  color: #c9d1dc;
}
.kicker,
.card .link,
.info-card h3,
.footer h4,
ul.clean li::before {
  color: #ffffff !important;
}
ul.clean li::before { background: #ffffff !important; }
.header-cta,
.btn-primary {
  background: #f2f5f8 !important;
  color: #0a0d12 !important;
  border-color: #f2f5f8 !important;
}
@media (min-width: 981px) {
  .site-header,
  .site-header .header-row,
  .site-header .nav-shell,
  .site-header .nav,
  .site-header .nav .item { overflow: visible !important; }
  .site-header .header-row {
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:14px !important;
    flex-wrap:nowrap !important;
    min-width:0 !important;
  }
  .site-header .brand {
    flex:0 1 auto !important;
    min-width:0 !important;
    max-width:330px !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
  }
  .site-header .nav-shell {
    margin-left:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:10px !important;
    flex:1 1 auto !important;
    min-width:0 !important;
  }
  .site-header .nav {
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:1px !important;
    flex-wrap:nowrap !important;
    min-width:0 !important;
    flex:0 1 auto !important;
  }
  .site-header .nav > .item,
  .site-header .header-cta {
    flex:0 0 auto !important;
    white-space:nowrap !important;
  }
  .site-header .nav a.top,
  .site-header .nav button.top {
    padding:10px 8px !important;
    white-space:nowrap !important;
    font-size:clamp(.78rem,.76vw,.94rem) !important;
    line-height:1.2 !important;
  }
  .site-header .header-cta {
    padding:10px 12px !important;
    font-size:clamp(.78rem,.76vw,.94rem) !important;
    line-height:1.2 !important;
    min-height:44px !important;
  }
  .site-header .dropdown {
    top:calc(100% - 1px) !important;
    margin-top:0 !important;
    z-index:3000 !important;
  }
  .site-header .dropdown::before {
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:-18px;
    height:18px;
    display:block;
  }
  .site-header .nav .item:hover > .dropdown,
  .site-header .nav .item:focus-within > .dropdown,
  .site-header .nav .item.is-open > .dropdown,
  .site-header .nav .item > .dropdown:hover {
    display:block !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }
}
@media (max-width: 1100px) and (min-width: 981px) {
  .site-header .brand { max-width:255px !important; font-size:.76rem !important; letter-spacing:.1em !important; }
  .site-header .nav a.top,
  .site-header .nav button.top { padding-left:6px !important; padding-right:6px !important; }
  .site-header .header-cta { padding-left:10px !important; padding-right:10px !important; }
}
@media (max-width: 820px) {
  .site-header .nav .item > .dropdown { display:none !important; }
  .site-header .nav .item.is-open > .dropdown { display:block !important; }
  .site-header .nav a.top,
  .site-header .nav button.top,
  .site-header .dropdown a,
  .site-header .header-cta { color:#ffffff !important; }
}

/* Black Label Header Brand Polish Patch — May 1, 2026
   Purpose: prevent the desktop header brand name from being clipped while preserving the one-line nav. */
@media (min-width: 981px) {
  .site-header .container.header-row,
  .site-header .header-row {
    width: min(1480px, calc(100% - 48px)) !important;
    max-width: 1480px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .site-header .brand {
    flex: 0 0 auto !important;
    max-width: none !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
    font-size: clamp(.76rem, .72vw, .88rem) !important;
    letter-spacing: clamp(.09em, .13vw, .16em) !important;
  }

  .site-header .nav-shell {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }

  .site-header .nav {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    flex-wrap: nowrap !important;
  }
}

@media (max-width: 1180px) and (min-width: 981px) {
  .site-header .container.header-row,
  .site-header .header-row {
    width: min(100% - 32px, 1480px) !important;
    gap: 10px !important;
  }

  .site-header .brand {
    font-size: .72rem !important;
    letter-spacing: .075em !important;
  }

  .site-header .nav a.top,
  .site-header .nav button.top {
    padding-left: 5px !important;
    padding-right: 5px !important;
    font-size: .76rem !important;
  }

  .site-header .header-cta {
    padding-left: 9px !important;
    padding-right: 9px !important;
    font-size: .76rem !important;
  }
}

@media (max-width: 1040px) and (min-width: 981px) {
  .site-header .brand {
    font-size: .68rem !important;
    letter-spacing: .055em !important;
  }
}

/* Black Label performance polish — no image or copy changes */
html, body { max-width: 100%; overflow-x: hidden; }
img { max-width: 100%; height: auto; }
@media (max-width: 980px) {
  main > .section, main > section.section, .site-footer, .footer {
    content-visibility: auto;
    contain-intrinsic-size: 1px 900px;
  }
  .hero-slide img { animation: none !important; }
  .js-reveal, .reveal-up { transition: none !important; transform: none !important; opacity: 1 !important; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}

/* Black Label final header spacing normalization
   Purpose: make the desktop header brand/nav horizontal spacing match page-to-page without changing page content, images, or hero layout. */
@media (min-width: 981px) {
  .site-header > .container.header-row,
  .site-header > .container.header-inner,
  .site-header .container.header-row,
  .site-header .container.header-inner,
  body.site-polish-page .site-header > .container,
  body.materials-page .site-header > .container {
    width: min(1320px, calc(100% - 48px)) !important;
    max-width: 1320px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    min-height: 76px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 24px !important;
  }

  .site-header .brand {
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }

  .site-header .nav-shell,
  .site-header .site-nav {
    margin-left: auto !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 16px !important;
  }

  .site-header .nav,
  body.site-polish-page .site-header .nav,
  body.materials-page .site-header .nav {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 10px !important;
    min-width: 0 !important;
  }

  .site-header .nav > .item,
  .site-header .site-nav > a,
  .site-header .site-nav > .nav-dropdown,
  .site-header .header-cta,
  .site-header .site-nav .nav-cta {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }
}

@media (min-width: 981px) and (max-width: 1180px) {
  .site-header > .container.header-row,
  .site-header > .container.header-inner,
  .site-header .container.header-row,
  .site-header .container.header-inner,
  body.site-polish-page .site-header > .container,
  body.materials-page .site-header > .container {
    width: min(100% - 32px, 1320px) !important;
    gap: 14px !important;
  }
  .site-header .brand {
    font-size: .78rem !important;
    letter-spacing: .09em !important;
  }
  .site-header .nav-shell,
  .site-header .site-nav,
  .site-header .nav {
    gap: 6px !important;
  }
  .site-header .nav a.top,
  .site-header .nav button.top,
  .site-header .site-nav a,
  .site-header .site-nav .nav-top,
  .site-header .header-cta,
  .site-header .site-nav .nav-cta {
    padding-left: 9px !important;
    padding-right: 9px !important;
  }
}
