/* ─── Joents Barbershop ─────────────────────────────────── */
:root {
  --bg: #0e0e0e;
  --bg-2: #141414;
  --bg-3: #1a1a1a;
  --fg: #f4f1ec;
  --fg-dim: rgba(244, 241, 236, 0.62);
  --fg-faint: rgba(244, 241, 236, 1);
  --line: rgba(244, 241, 236, 0.12);
  --accent: #DC3F34;
  --serif: "Bodoni Moda", "Didot", "Bodoni 72", Georgia, serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --mono: "JetBrains Mono", "SF Mono", Menlo, monospace;
  --container: 1440px;
  --pad: clamp(20px, 4vw, 64px);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { background: none; border: none; color: inherit; cursor: pointer; font: inherit; }

/* ─── Placeholder (striped diagonal) ─── */
.portrait-img {
    position: relative;
    width: 100%;
    aspect-ratio: 3 / 4;        /* maintains portrait shape at any width */
    overflow: hidden;
    background-color: #1a1a1a;  /* shows behind image while loading */
}

.portrait-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;          /* fills the box, crops overflow */
    object-position: center top;/* keeps faces visible when cropped */
    display: block;
    transition: transform 0.4s ease;
}

/* Subtle zoom on hover — optional, feels polished */
.portrait:hover .portrait-photo {
    transform: scale(1.03);
}

/* Hide the placeholder label once real images are in */
.ph-label {
    display: none;
}

/* ─── Eyebrow ─── */
.eyebrow {
  display: inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 24px;
}

/* ─── Nav ─── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  transition: background 0.3s ease, backdrop-filter 0.3s ease, border-color 0.3s ease;
  border-bottom: 1px solid transparent;
}
.nav.nav-scrolled {
  background: rgba(14, 14, 14, 0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom-color: var(--line);
}
.nav-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 18px var(--pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.joents-logo {
    width: 40%;
    height: auto;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--serif);
}
.brand-mark {
  width: 36px; height: 36px;
  border: 1px solid var(--fg);
  border-radius: 50%;
  display: grid; place-items: center;
  font-style: italic;
  font-size: 18px;
  font-weight: 600;
}
.brand-word {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: 0.32em;
  font-size: 13px;
}
.nav-links {
  display: flex;
  gap: 36px;
  align-items: center;
  font-size: 14px;
}
.nav-links a {
  color: var(--fg-dim);
  transition: color 0.2s;
  position: relative;
}
.nav-links a:hover { color: var(--fg); }
.nav-cta {
  border: 1px solid var(--fg);
  color: var(--fg) !important;
  padding: 10px 22px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 11px;
  transition: background 0.2s, color 0.2s;
}
.nav-cta:hover { background: var(--fg); color: var(--bg) !important; }
.burger {
  display: none;
  flex-direction: column;
  gap: 6px;
  width: 32px;
  align-items: flex-end;
}
.burger span {
  display: block;
  height: 1px;
  background: var(--fg);
}
.burger span:nth-child(1) { width: 28px; }
.burger span:nth-child(2) { width: 18px; }

/* ─── Mobile menu ─── */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  padding: 24px var(--pad) 40px;
  transform: translateY(-100%);
  transition: transform 0.5s cubic-bezier(0.7, 0, 0.2, 1);
}
.mobile-menu.is-open { transform: translateY(0); }
.mm-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.mm-close { width: 40px; height: 40px; display: grid; place-items: center; }
.mm-links {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
}
.mm-links li {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s, transform 0.5s;
}
.mobile-menu.is-open .mm-links li {
  opacity: 1;
  transform: translateY(0);
}
.mobile-menu.is-open .mm-links li:nth-child(1) { transition-delay: 0.10s; }
.mobile-menu.is-open .mm-links li:nth-child(2) { transition-delay: 0.16s; }
.mobile-menu.is-open .mm-links li:nth-child(3) { transition-delay: 0.22s; }
.mobile-menu.is-open .mm-links li:nth-child(4) { transition-delay: 0.28s; }
.mobile-menu.is-open .mm-links li:nth-child(5) { transition-delay: 0.34s; }
.mm-links a {
  display: flex;
  align-items: baseline;
  gap: 18px;
  padding: 14px 0;
  font-family: var(--serif);
  font-size: clamp(40px, 10vw, 64px);
  line-height: 1;
  border-bottom: 1px solid var(--line);
}
.mm-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-faint);
  letter-spacing: 0.1em;
}
.mm-foot {
  padding-top: 20px;
  border-top: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--fg-dim);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

/* ─── Hero ─── */
.hero {
  min-height: 100vh;
  padding: 120px var(--pad) 0;
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  position: relative;
}
.hero-grid {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 4vw, 64px);
  align-items: center;
  padding-bottom: 60px;
}
.hero-copy { max-width: 540px; }
.hero-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(48px, 7.5vw, 104px);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin-bottom: 28px;
  text-wrap: balance;
}
.hero-title em {
  font-style: italic;
  color: var(--accent);
  font-weight: 400;
}
.hero-sub {
  color: var(--fg-dim);
  font-size: clamp(15px, 1.4vw, 18px);
  max-width: 380px;
  margin-bottom: 36px;
}
.hero-cta-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.btn-primary {
  background: var(--fg);
  color: var(--bg);
  padding: 16px 32px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition: transform 0.2s, background 0.2s;
}
.btn-primary:hover { background: var(--accent); transform: translateY(-2px); color: var(--fg); }
.btn-primary.big { padding: 22px 48px; font-size: 13px; }
.btn-ghost {
  padding: 16px 8px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--fg-dim);
  border-bottom: 1px solid var(--line);
  transition: color 0.2s, border-color 0.2s;
}
.btn-ghost:hover { color: var(--fg); border-bottom-color: var(--fg); }

.hero-meta {
  display: flex;
  gap: clamp(20px, 4vw, 56px);
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.meta-num {
  font-family: var(--serif);
  font-size: 32px;
  line-height: 1;
}
.meta-lbl {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-dim);
  margin-top: 6px;
}

/* Portraits */
.hero-portraits {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-self: stretch;
  align-items: center;
  max-height: 80vh;
}
.portrait {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--bg-2);
  cursor: pointer;
}
.portrait:nth-child(2) { transform: translateY(40px); }
.portrait-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/4;
}
.portrait-img .ph {
  transition: transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.portrait:hover .portrait-img .ph {
  transform: scale(1.12);
}
.portrait-name {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 18px 20px;
  background: rgba(14, 14, 14, 0.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(244, 241, 236, 0.1);
  transition: background 0.3s;
}
.portrait:hover .portrait-name {
  background: rgba(14, 14, 14, 0.7);
}
.pn-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.pn-name {
  font-family: var(--serif);
  font-size: 24px;
  font-style: italic;
}
.pn-arrow {
  font-size: 16px;
  color: var(--accent);
  transition: transform 0.3s;
}
.portrait:hover .pn-arrow { transform: translateX(6px); }
.pn-role {
  display: block;
  margin-top: 4px;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--fg-dim);
}

/* Marquee */
.hero-marquee {
  margin-top: auto;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 18px 0;
  overflow: hidden;
  white-space: nowrap;
}
.marquee-track {
  display: inline-block;
  animation: marquee 40s linear infinite;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--fg-dim);
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ─── Info strip ─── */
.strip {
  background: var(--bg-2);
  padding: 32px var(--pad);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  border-bottom: 1px solid var(--line);
}
.strip-cell {
  padding: 0 12px;
  border-left: 1px solid var(--line);
}
.strip-cell:first-child { border-left: none; padding-left: 0; }
.strip-k {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-faint);
  margin-bottom: 8px;
}
.strip-v {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.2;
}
.strip-sub {
  margin-top: 4px;
  font-size: 12px;
  color: var(--fg-dim);
}

/* ─── Section ─── */
.section {
  max-width: var(--container);
  margin: 0 auto;
  padding: clamp(80px, 12vw, 160px) var(--pad);
}
.section-head {
  margin-bottom: 64px;
  max-width: 720px;
}
.section-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 6vw, 80px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 20px;
}
.section-title em { font-style: italic; color: var(--accent); }
.section-lede {
  color: var(--fg-dim);
  font-size: clamp(16px, 1.4vw, 18px);
  max-width: 540px;
}

#gallery {
    padding-top: 0px;
}

/* ─── Services ─── */
.svc-list { border-top: 1px solid var(--line); }
.svc-row {
  display: grid;
  grid-template-columns: 60px 1fr auto 100px;
  align-items: baseline;
  gap: 24px;
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
  transition: padding 0.3s;
}
.svc-row:hover { padding-left: 16px; }
.svc-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-faint);
  letter-spacing: 0.1em;
}
.svc-name {
  font-family: var(--serif);
  font-size: clamp(22px, 2.5vw, 32px);
  line-height: 1.1;
}
.svc-name small {
  display: block;
  margin-top: 6px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--fg-dim);
}
.svc-dur {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-dim);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.svc-price {
  font-family: var(--serif);
  font-size: clamp(22px, 2.5vw, 32px);
  text-align: right;
  color: var(--accent);
}

/* ─── Gallery ─── */

.gal-cell {
  background: var(--bg-2);
  overflow: hidden;
  cursor: pointer;
}

/* ─── Gallery ─── */
.gal-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 12px;
    row-gap: 6%;
}
.gal-cell {
    position: relative;
    aspect-ratio: 3 / 4;
    background: var(--bg-2);
    overflow: hidden;
    cursor: pointer;
}
.gal-cell img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.gal-cell:hover img {
    transform: scale(1.08);
}

.gal-cell .ph {
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.gal-cell:hover .ph { transform: scale(1.08); }

/* ─── Visit ─── */
.visit-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: center;
}
.visit-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}
.meta-k {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--fg-faint);
  margin-bottom: 10px;
}
.meta-v {
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.4;
}
.map {
    aspect-ratio: 4/3;
    background: var(--bg-2);
    overflow: hidden;
}
.map iframe {
    width: 100%;
    height: 100%;
    display: block;
    /* Optional: tones the map down to match your dark theme */
    filter: grayscale(40%) contrast(0.95);
}
/* ─── Footer ─── */
.footer {
  background: var(--bg-2);
  border-top: 1px solid var(--line);
}
.foot-cta {
  max-width: var(--container);
  margin: 0 auto;
  padding: clamp(60px, 10vw, 120px) var(--pad);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--line);
}
.foot-cta h2 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1;
  letter-spacing: -0.02em;
}
.foot-cta em { font-style: italic; color: var(--accent); }
.foot-grid {
  max-width: var(--container);
  margin: 0 auto;
  padding: 64px var(--pad);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
}
.foot-brand p {
  margin-top: 16px;
  color: var(--fg-dim);
  font-size: 13px;
  max-width: 280px;
}
.foot-grid > div > a {
  display: block;
  padding: 6px 0;
  color: var(--fg-dim);
  font-size: 14px;
  transition: color 0.2s;
}
.foot-grid > div > a:hover { color: var(--fg); }
.foot-k {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-faint);
  margin-bottom: 14px;
}
.foot-bot {
  max-width: var(--container);
  margin: 0 auto;
  padding: 24px var(--pad);
  display: flex;
  justify-content: space-between;
  border-top: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fg-faint);
}
.mobile {
    display: block;
}

/* ─── Responsive ─── */
@media (max-width: 960px) {
    .gal-grid {
        grid-template-columns: repeat(2, 1fr);
    }
  .nav-links { display: none; }
  .burger { display: flex; }
  .hero { padding-top: 100px; }
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .hero-portraits {
    max-height: none;
    gap: 12px;
  }
  .portrait:nth-child(2) { transform: translateY(20px); }
  .strip {
    grid-template-columns: 1fr 1fr;
    padding: 24px var(--pad);
  }
  .strip-cell { padding-left: 0; padding-right: 0; }
  .strip-cell:nth-child(3) { border-left: none; }
  .visit-grid { grid-template-columns: 1fr; gap: 32px; }
  .gal-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .gal-cell.wide { grid-column: span 2; }
  .gal-cell.tall { grid-row: span 1; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .svc-row {
    grid-template-columns: 32px 1fr auto;
    gap: 16px;
  }
  .svc-dur { display: none; }

  #visit {
      margin-top: 3vh;
  }
}

@media (min-width: 787px) {
    .mobile {
        display: none;
    }

    #visit {
        margin-top: 7vh;
    }
}

@media (max-width: 786px) {
    .desktop {
        display: none;
    }

    .hero-sub {
        margin-bottom: 0px;
    }

    .joents-logo {
        width: 30%;
    }
}


@media (max-width: 540px) {
  .strip { grid-template-columns: 1fr; }
  .strip-cell { border-left: none; padding: 8px 0; border-top: 1px solid var(--line); }
  .strip-cell:first-child { border-top: none; padding-top: 0; }
  .hero-meta { gap: 20px; }
  .meta-num { font-size: 24px; }
  .foot-grid { grid-template-columns: 1fr; }
  .foot-cta { flex-direction: column; align-items: flex-start; }
  .foot-bot { flex-direction: column; gap: 8px; }
    .gal-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
