/* ======================================================================
   Hustob Clothier · Global Design System (site.css)
   Editorial luxury · 2026 refresh
   ====================================================================== */

/* ── Typography ──────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=Inter+Tight:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── Design Tokens ──────────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --hc-ink:        #0E0E0E;
  --hc-ink-soft:   #1A1A1A;
  --hc-paper:      #F5F2EB;
  --hc-cream:      #FBF8F1;
  --hc-bone:       #EDE7D9;
  --hc-mist:       #DAD3C0;
  --hc-light:      #FFFFFF;

  /* Text */
  --hc-text:       #141413;
  --hc-muted:      #6B6459;
  --hc-faint:      #9C9486;

  /* Brand accents */
  --hc-accent:     #C89B3C;        /* gold */
  --hc-accent-2:   #0F5B4A;        /* forest */
  --hc-clay:       #B85C38;        /* terracotta */
  --hc-gold-soft:  #E1C079;
  --hc-forest-soft:#1F7A65;

  /* Borders & shadows */
  --hc-border:     #E2DACB;
  --hc-border-soft:#EFE9DC;
  --hc-line:       #1F1E1B;
  --hc-shadow-sm:  0 1px 2px rgba(20,16,10,.04), 0 4px 12px rgba(20,16,10,.06);
  --hc-shadow-md:  0 8px 24px rgba(20,16,10,.08), 0 20px 60px rgba(20,16,10,.10);
  --hc-shadow-lg:  0 18px 50px rgba(22,18,12,.18);

  /* Type system */
  --hc-font-display: 'Fraunces', 'Playfair Display', 'Georgia', serif;
  --hc-font-sans:    'Inter Tight', 'Inter', system-ui, sans-serif;
  --hc-font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --hc-font:         var(--hc-font-sans); /* legacy alias */

  /* Layout */
  --hc-max-width:  1320px;
  --hc-gap:        clamp(.75rem, 1.4vw, 1.4rem);

  /* Motion */
  --hc-dur:        .35s;
  --hc-dur-slow:   .65s;
  --hc-ease:       cubic-bezier(.2,.7,.2,1);
  --hc-ease-out:   cubic-bezier(.16,1,.3,1);

  /* Legacy aliases (kept so older CSS keeps working) */
  --accent:        var(--hc-accent);
  --text-color:    var(--hc-text);
  --hc-dark:       var(--hc-ink);
  --hc-shadow:     var(--hc-shadow-md);
}

/* ── Reset / Base ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--hc-font-sans);
  font-size: clamp(.95rem, .55vw + .8rem, 1.02rem);
  line-height: 1.55;
  color: var(--hc-text);
  background: var(--hc-paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01", "cv11";
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; transition: color var(--hc-dur) var(--hc-ease), background var(--hc-dur) var(--hc-ease), border-color var(--hc-dur) var(--hc-ease); }
button { font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
img, svg, video { max-width: 100%; display: block; height: auto; }
body.no-scroll { overflow: hidden; }

::selection { background: var(--hc-ink); color: var(--hc-cream); }

/* Screen-reader utility */
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* Skip link */
.hc-skip-link { position: absolute; left: -999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.hc-skip-link:focus {
  position: fixed; top: 1rem; left: 1rem; z-index: 1100;
  padding: .65rem 1.1rem; background: var(--hc-ink); color: var(--hc-cream);
  border-radius: 999px; font-weight: 600; letter-spacing: .02em;
}

/* ── Announcement bar ───────────────────────────────────────────────── */
.hc-announce {
  position: relative; z-index: 1001;
  width: 100%;
  background: var(--hc-ink);
  color: var(--hc-cream);
  font-family: var(--hc-font-mono);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.hc-announce__track {
  display: flex; gap: 4rem;
  padding: .58rem 0;
  width: max-content;
  animation: hc-marquee 38s linear infinite;
}
.hc-announce__track > span { display: inline-flex; align-items: center; gap: 1rem; opacity: .82; white-space: nowrap; }
.hc-announce__track > span::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--hc-accent);
}
@keyframes hc-marquee { to { transform: translateX(-50%); } }

/* ── Header ─────────────────────────────────────────────────────────── */
.hc-header {
  position: sticky; top: 0; z-index: 1000;
  width: 100%;
  background: rgba(245, 242, 235, .72);
  border-bottom: 1px solid transparent;
  padding: clamp(.7rem, 1.3vw, 1.05rem) 1.1rem;
  backdrop-filter: saturate(140%) blur(18px);
  -webkit-backdrop-filter: saturate(140%) blur(18px);
  transition: padding var(--hc-dur) var(--hc-ease),
              background var(--hc-dur) var(--hc-ease),
              border-color var(--hc-dur) var(--hc-ease),
              box-shadow var(--hc-dur) var(--hc-ease);
}
.hc-header--shrink {
  padding: .45rem 1.1rem;
  background: rgba(251, 248, 241, .92);
  border-bottom-color: var(--hc-border-soft);
  box-shadow: 0 8px 24px rgba(20,16,10,.06);
}
.hc-container {
  max-width: var(--hc-max-width);
  margin-inline: auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--hc-gap);
}

/* Logo */
.hc-logo { display: inline-flex; align-items: center; gap: .65rem; }
.hc-logo img {
  height: clamp(40px, 3.4vw, 50px);
  width: auto;
  border-radius: 50%;
  box-shadow: 0 4px 14px rgba(0,0,0,.08);
  transition: transform var(--hc-dur) var(--hc-ease);
}
.hc-logo:hover img { transform: scale(1.04); }

/* ── Desktop Navigation ─────────────────────────────────────────────── */
.hc-nav { display: flex; }
.hc-nav-list {
  display: flex; align-items: center;
  gap: clamp(1rem, 2vw, 2rem);
  margin: 0; padding: 0; list-style: none;
}

.hc-nav-link,
.dropdown-toggle {
  display: inline-flex; align-items: center; gap: .35rem;
  line-height: 1; vertical-align: middle;
  font-family: var(--hc-font-sans);
  font-weight: 500;
  font-size: .92rem;
  letter-spacing: .01em;
  padding: .55rem .25rem;
  background: none; border: 0; cursor: pointer;
  color: var(--hc-ink);
  position: relative;
  transition: color var(--hc-dur) var(--hc-ease);
}
.hc-nav-link::after,
.dropdown-toggle::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  opacity: 0; transform: scaleX(.2); transform-origin: left;
  transition: opacity var(--hc-dur) var(--hc-ease), transform var(--hc-dur) var(--hc-ease);
}
.hc-nav-link:hover::after,
.hc-nav-link:focus-visible::after,
.dropdown-toggle:hover::after,
.dropdown-toggle:focus-visible::after { opacity: 1; transform: scaleX(1); }
.hc-nav-link:hover, .hc-nav-link:focus-visible,
.dropdown-toggle:hover, .dropdown-toggle:focus-visible { color: var(--hc-ink); outline: none; }

/* Caret */
.nav-dropdown { position: relative; }
.dropdown-toggle .icon-caret-down {
  width: .42rem; height: .42rem; flex: none;
  border: solid currentColor; border-width: 0 1.2px 1.2px 0;
  display: inline-block; padding: 2.5px;
  transform: translateY(-1.5px) rotate(45deg);
  transition: transform var(--hc-dur) var(--hc-ease);
}
.dropdown-toggle[aria-expanded="true"] .icon-caret-down {
  transform: translateY(1px) rotate(-135deg);
}

/* Dropdown menu */
.dropdown-menu {
  position: absolute; left: 0; top: 100%; min-width: 240px;
  background: var(--hc-cream); color: var(--hc-ink);
  border: 1px solid var(--hc-border);
  border-radius: 14px;
  padding: .5rem;
  box-shadow: var(--hc-shadow-md);
  opacity: 0; pointer-events: none;
  transform: translateY(8px);
  transition: opacity var(--hc-dur) var(--hc-ease), transform var(--hc-dur) var(--hc-ease);
  z-index: 50;
  margin-top: .55rem;
}
.dropdown-toggle[aria-expanded="true"] + .dropdown-menu,
.dropdown-menu.open {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.dropdown-menu a, .dropdown-menu li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: .65rem .85rem; font-size: .92rem;
  border-radius: 8px;
  color: var(--hc-ink);
  transition: background var(--hc-dur) var(--hc-ease), color var(--hc-dur) var(--hc-ease);
}
.dropdown-menu a::after { content: "→"; opacity: 0; transform: translateX(-6px); transition: opacity var(--hc-dur) var(--hc-ease), transform var(--hc-dur) var(--hc-ease); font-size: .85rem; }
.dropdown-menu a:hover, .dropdown-menu a:focus-visible { background: var(--hc-paper); color: var(--hc-ink); }
.dropdown-menu a:hover::after, .dropdown-menu a:focus-visible::after { opacity: .85; transform: translateX(0); }
.dropdown-menu li { list-style: none; }
.dropdown-menu ul { padding: 0; margin: 0; list-style: none; }

@media (max-width: 768px) {
  .nav-dropdown { display: none; }
}

/* ── Controls cluster ───────────────────────────────────────────────── */
.hc-controls { display: flex; align-items: center; gap: .55rem; }

/* Search */
.hc-search {
  position: relative;
  width: clamp(150px, 22vw, 280px);
}
.hc-search input {
  width: 100%;
  padding: .65rem 2.5rem .65rem 1rem;
  border: 1px solid var(--hc-border);
  border-radius: 999px;
  background: var(--hc-cream);
  font-family: var(--hc-font-sans);
  font-size: .9rem;
  color: var(--hc-ink);
  transition: border-color var(--hc-dur) var(--hc-ease),
              box-shadow var(--hc-dur) var(--hc-ease),
              background var(--hc-dur) var(--hc-ease),
              width var(--hc-dur) var(--hc-ease);
}
.hc-search input::placeholder { color: var(--hc-faint); }
.hc-search input:focus {
  outline: none;
  border-color: var(--hc-ink);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(14,14,14,.06);
}
.hc-search button {
  position: absolute; top: 50%; right: .35rem; transform: translateY(-50%);
  width: 2rem; height: 2rem;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  color: var(--hc-muted);
  transition: color var(--hc-dur) var(--hc-ease), background var(--hc-dur) var(--hc-ease);
}
.hc-search button:hover { color: var(--hc-ink); background: var(--hc-bone); }

@media (max-width: 600px) {
  .hc-search { width: 2.4rem; }
  .hc-search input { padding-left: 0; padding-right: 0; opacity: 0; }
  .hc-search:focus-within { width: min(70vw, 320px); }
  .hc-search:focus-within input { padding-left: 1rem; padding-right: 2.5rem; opacity: 1; }
}

/* SVG icon helper */
.hc-icon {
  width: 1.2rem; height: 1.2rem; flex: none; vertical-align: -.15rem;
  color: currentColor;
}

/* Auth & cart pills */
.hc-auth-link,
.hc-cart {
  position: relative;
  min-width: 2.55rem; min-height: 2.55rem;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--hc-border);
  border-radius: 999px;
  background: var(--hc-cream);
  color: var(--hc-ink);
  transition: border-color var(--hc-dur) var(--hc-ease),
              background var(--hc-dur) var(--hc-ease),
              transform var(--hc-dur) var(--hc-ease),
              color var(--hc-dur) var(--hc-ease);
}
.hc-auth-link { padding: 0 1.05rem; font-weight: 600; font-size: .88rem; letter-spacing: .01em; }
.hc-auth-link:hover, .hc-cart:hover {
  border-color: var(--hc-ink);
  background: var(--hc-ink);
  color: var(--hc-cream);
  transform: translateY(-1px);
}
.cart-count {
  position: absolute; top: -4px; right: -4px;
  min-width: 1.25rem; height: 1.25rem; padding: 0 .35rem;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  background: var(--hc-accent);
  color: var(--hc-ink);
  font-family: var(--hc-font-mono);
  font-size: .68rem; font-weight: 600;
  box-shadow: 0 2px 6px rgba(200,155,60,.45);
}

/* Hamburger */
.hc-hamburger {
  display: none; flex-direction: column; gap: 5px;
  width: 2.55rem; height: 2.55rem;
  align-items: center; justify-content: center;
  border: 1px solid var(--hc-border);
  border-radius: 999px;
  background: var(--hc-cream);
  transition: border-color var(--hc-dur) var(--hc-ease), background var(--hc-dur) var(--hc-ease);
}
.hc-hamburger span {
  width: 18px; height: 1.5px; background: var(--hc-ink);
  transition: transform var(--hc-dur) var(--hc-ease), opacity var(--hc-dur) var(--hc-ease);
}
.hc-hamburger:hover { border-color: var(--hc-ink); }
.hc-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hc-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hc-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── Mobile drawer ──────────────────────────────────────────────────── */
.hc-mobile-nav {
  position: fixed; left: 0; top: 0;
  width: min(86vw, 360px); height: 100dvh;
  background: var(--hc-cream);
  padding: 4rem 1.5rem 3rem;
  transform: translateX(-100%);
  transition: transform .55s var(--hc-ease-out);
  box-shadow: var(--hc-shadow-lg);
  z-index: 1002;
  overflow-y: auto;
}
.hc-mobile-nav.open { transform: translateX(0); }
.hc-mobile-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: .25rem;
}
.hc-mobile-nav a {
  display: block; padding: .9rem .25rem;
  font-family: var(--hc-font-display);
  font-size: 1.65rem;
  font-weight: 400;
  letter-spacing: -.01em;
  color: var(--hc-ink);
  border-bottom: 1px solid var(--hc-border-soft);
}
.hc-mobile-nav a:hover, .hc-mobile-nav a:focus-visible {
  color: var(--hc-accent-2);
}

/* Overlay */
.hc-overlay {
  position: fixed; inset: 0;
  background: rgba(14,14,14,.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0; visibility: hidden;
  transition: opacity var(--hc-dur) var(--hc-ease), visibility var(--hc-dur) var(--hc-ease);
  z-index: 1001;
}
.hc-overlay.open { opacity: 1; visibility: visible; }

@media (max-width: 992px) {
  .hc-nav { display: none; }
  .hc-hamburger { display: inline-flex; }
}

/* ── Buttons (foundation; section-specific overrides in home.css) ─── */
.btn-primary,
.btn-outline,
.btn-alt,
.btn-cart,
.btn-hero,
.btn-outline-light {
  --btn-h: 3rem;
  min-height: var(--btn-h);
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem;
  padding: .9rem 1.35rem;
  font-family: var(--hc-font-sans);
  font-weight: 600;
  font-size: .92rem;
  letter-spacing: .02em;
  text-align: center;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--hc-dur) var(--hc-ease),
              color var(--hc-dur) var(--hc-ease),
              border-color var(--hc-dur) var(--hc-ease),
              transform var(--hc-dur) var(--hc-ease),
              box-shadow var(--hc-dur) var(--hc-ease);
}

.btn-primary {
  background: var(--hc-ink); color: var(--hc-cream); border-color: var(--hc-ink);
}
.btn-primary:hover, .btn-primary:focus-visible {
  background: var(--hc-accent-2); border-color: var(--hc-accent-2);
  color: #fff; transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(15,91,74,.28);
}

.btn-outline {
  background: transparent; color: var(--hc-ink); border-color: var(--hc-ink);
}
.btn-outline:hover, .btn-outline:focus-visible {
  background: var(--hc-ink); color: var(--hc-cream);
  transform: translateY(-2px);
}

.btn-alt {
  background: var(--hc-cream); color: var(--hc-ink); border-color: var(--hc-cream);
}
.btn-alt:hover, .btn-alt:focus-visible {
  background: var(--hc-accent); border-color: var(--hc-accent); color: var(--hc-ink);
  transform: translateY(-2px);
}

.btn-hero {
  background: var(--hc-cream); color: var(--hc-ink); border-color: var(--hc-cream);
}
.btn-hero:hover, .btn-hero:focus-visible {
  background: var(--hc-accent); border-color: var(--hc-accent); color: var(--hc-ink);
  transform: translateY(-2px);
}

.btn-outline-light {
  background: transparent; color: #fff;
  border-color: rgba(255,255,255,.55);
}
.btn-outline-light:hover, .btn-outline-light:focus-visible {
  background: rgba(255,255,255,.10); border-color: #fff;
}

/* ── Search suggest (legacy enhancement) ────────────────────────────── */
.hc-search-suggest {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  max-height: 280px;
  background: var(--hc-cream); border: 1px solid var(--hc-border);
  box-shadow: var(--hc-shadow-md); border-radius: 14px;
  list-style: none; margin: 0; padding: .35rem; overflow-y: auto;
  font-size: .92rem;
}
.hc-search-suggest li a { display: block; padding: .55rem .7rem; border-radius: 8px; }
.hc-search-suggest li a:hover { background: var(--hc-bone); color: var(--hc-ink); }

/* ── Reduced motion ────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
  .hc-announce__track { animation: none !important; }
}

/* ── Focus rings ────────────────────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--hc-accent-2);
  outline-offset: 3px;
  border-radius: 6px;
}
.btn-primary:focus-visible,
.btn-outline:focus-visible,
.btn-alt:focus-visible,
.btn-hero:focus-visible,
.btn-outline-light:focus-visible {
  outline-offset: 4px;
}
