/* Niran website — extracted from index.html <style> block */

:root {
    /* Palette — defaults match Tweak palette 'Ink' */
    --bg: #0e0e0c;
    --fg: #e8e2d5;
    --fg-soft: rgba(232, 226, 213, 0.62);
    --fg-dim: rgba(232, 226, 213, 0.36);
    --tan: #a89678;
    --green: #0f3a32;
    --gold: #c9a86b;
    --rule: rgba(232, 226, 213, 0.14);

    /* Type defaults */
    --font-display: "Cormorant Garamond", serif;
    --font-body: "IBM Plex Sans", system-ui, sans-serif;
    --font-mono: "IBM Plex Mono", ui-monospace, monospace;
    --font-thai: "Arimo", system-ui, sans-serif;

    /* Density */
    --gutter: clamp(20px, 4vw, 56px);
    --section-pad: clamp(80px, 12vw, 180px);
  }

  * { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg); }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-body);
    font-weight: 300;
    font-size: 15px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }
  img { display: block; max-width: 100%; }
  a { color: inherit; text-decoration: none; }
  button { font: inherit; color: inherit; background: none; border: 0; cursor: default; }

  /* Reveal on scroll */
  .reveal { opacity: 0; transform: translateY(14px); transition: opacity 1.2s ease, transform 1.2s cubic-bezier(.2,.7,.2,1); }
  .reveal.in { opacity: 1; transform: translateY(0); }

  /* Mono label */
  .label {
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--fg-soft);
  }

  /* Section structure */
  section { padding-left: var(--gutter); padding-right: var(--gutter); }

  /* Hide tweak panel chrome behind splash on first paint */
  #root { opacity: 0; transition: opacity .6s ease .2s; }
  #root.ready { opacity: 1; }

  /* 2×2 "Made by hand" step grid */
  .step-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
  }
  .step-cell {
    padding: clamp(40px, 4.4vw, 72px) clamp(28px, 2.8vw, 52px);
    display: flex; flex-direction: column;
    gap: clamp(16px, 1.4vw, 22px);
  }
  .step-cell:nth-child(odd) { padding-left: 0; }
  .step-cell:nth-child(even) { padding-right: 0; border-left: 1px solid var(--rule); }
  .step-cell:nth-child(-n+2) { padding-top: 0; }
  .step-cell:nth-child(n+3) { padding-bottom: 0; border-top: 1px solid var(--rule); }

  @media (max-width: 760px) {
    .step-grid { grid-template-columns: 1fr; }
    .step-cell {
      padding: clamp(28px, 5vw, 44px) 0 !important;
      border-left: 0 !important;
      border-top: 0;
    }
    .step-cell + .step-cell { border-top: 1px solid var(--rule); }
  }

  /* ─── Mobile responsive overrides ─────────────────────────── */
  @media (max-width: 820px) {

    /* Nav: desktop links hidden via .nav-desktop class at 640px */

    /* Hero — stack text above image; cap image height */
    .hero-grid {
      grid-template-columns: 1fr !important;
      min-height: auto !important;
      padding-top: clamp(96px, 18vh, 140px) !important;
      padding-bottom: clamp(48px, 8vh, 80px) !important;
      gap: clamp(28px, 6vw, 48px) !important;
    }
    /* The hero image container is the 2nd direct child div */
    .hero-grid > div:nth-of-type(2) {
      height: clamp(360px, 75vw, 560px) !important;
      width: 100%;
    }
    /* Scroll hint: hide on mobile (gets in the way) */
    .hero-grid > div:last-child { display: none !important; }

    /* Story / Manifesto — stack image + thai + english */
    .story-grid {
      grid-template-columns: 1fr !important;
      gap: clamp(28px, 6vw, 44px) !important;
    }
    /* Image was 3/4 aspect — keep but unbreak sticky on mobile */
    .story-grid > figure { position: static !important; }

    /* Atelier founder block — stack portrait above message */
    .founder-grid {
      grid-template-columns: 1fr !important;
      gap: clamp(28px, 6vw, 40px) !important;
    }
    .founder-grid > figure { position: static !important; max-width: 280px; }

    /* Collection main header — stack title and meta */
    .coll-section-header {
      grid-template-columns: 1fr !important;
      gap: 18px !important;
      padding-bottom: 18px !important;
    }
    .coll-section-header > div:last-child { text-align: left !important; }

    /* Collection subsection headers — stack their three pieces */
    .coll-sub-header {
      grid-template-columns: 1fr !important;
      gap: 10px !important;
    }
    .coll-sub-header > div:last-child { text-align: left !important; }

    /* Collection cards — 2 columns on tablet, 1 column on phones */
    .coll-cards {
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
      gap: clamp(20px, 4vw, 32px) !important;
    }

    /* Process section — stack image above text */
    .process-grid {
      grid-template-columns: 1fr !important;
      gap: clamp(24px, 5vw, 40px) !important;
    }

    /* Distributors region header — stack pieces */
    .region-header {
      grid-template-columns: 1fr !important;
      gap: 6px !important;
    }
    /* Distributors cards — 2 then 1 column */
    .dist-cards {
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
      gap: clamp(20px, 4vw, 32px) !important;
    }

    /* Afterlife — stack label above flows; flows go vertical */
    .afterlife-block {
      grid-template-columns: 1fr !important;
      gap: clamp(28px, 6vw, 40px) !important;
    }
    .afterlife-flow {
      flex-direction: column !important;
      align-items: center !important;
      gap: clamp(8px, 2vw, 14px) !important;
    }
    .afterlife-flow .flow-arrow {
      margin-top: 0 !important;
      transform: rotate(90deg);
    }
    .afterlife-flow .flow-step {
      width: 100%;
    }

    /* Footer — stack columns */
    .footer-grid {
      grid-template-columns: 1fr !important;
      gap: 32px !important;
    }

    /* Reduce section vertical padding so the page isn't endless */
    main > section,
    main > footer,
    footer {
      padding-left: var(--gutter) !important;
      padding-right: var(--gutter) !important;
    }
    main > section {
      padding-top: clamp(60px, 12vw, 100px) !important;
      padding-bottom: clamp(60px, 12vw, 100px) !important;
    }

    /* Tighten gutter on narrow screens */
    :root { --gutter: clamp(18px, 5vw, 28px); }
  }

  /* Phones */
  @media (max-width: 520px) {
    .coll-cards {
      grid-template-columns: 1fr !important;
    }
    .dist-cards {
      grid-template-columns: 1fr !important;
    }
    /* Big display headlines were sized for big screens — bring them in */
    .hero-grid h1 {
      font-size: clamp(34px, 9.6vw, 52px) !important;
    }
  }

/* ─────────────────────────────────────────────────────────────
   Shared dark-theme nav & footer (base_dark.html)
   ───────────────────────────────────────────────────────────── */

/* Nav */
.niran-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; flex-direction: column;
  padding: 14px var(--gutter);
  background: color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
  transition: padding .35s ease, background .35s ease;
}
.niran-nav-row {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
}
.niran-nav.scrolled {
  padding-top: 10px; padding-bottom: 10px;
  background: color-mix(in oklab, var(--bg) 94%, transparent);
}
.niran-nav a { color: var(--fg-soft); text-decoration: none; transition: color .25s; }
.niran-nav a:hover { color: var(--fg); }
.niran-nav-links {
  display: flex; gap: 24px; align-items: center;
}
.niran-nav-links a {
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: .18em; text-transform: uppercase;
}
.niran-nav-contact { display: flex; align-items: center; gap: 6px; }
.niran-nav-contact a { text-decoration: none; }

/* Hamburger button */
.niran-hamburger {
  display: none;
  flex-direction: column; justify-content: center; gap: 5px;
  width: 36px; height: 36px; padding: 6px;
  background: none; border: none; cursor: pointer;
}
.niran-hamburger span {
  display: block; height: 1.5px; background: var(--fg);
  transition: transform .25s ease, opacity .25s ease, width .25s ease;
}
.niran-hamburger span:nth-child(3) { width: 14px; }
.niran-nav.nav-open .niran-hamburger span:nth-child(1) { transform: rotate(45deg) translate(4.5px, 4.5px); }
.niran-nav.nav-open .niran-hamburger span:nth-child(2) { transform: rotate(-45deg); }
.niran-nav.nav-open .niran-hamburger span:nth-child(3) { opacity: 0; }

/* Mobile drawer */
.niran-nav-drawer {
  display: none; flex-direction: column;
  border-top: 1px solid var(--rule);
  margin-top: 12px; padding-bottom: 8px;
}
.niran-nav.nav-open .niran-nav-drawer { display: flex; }
.niran-nav-drawer a {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--fg-soft);
  padding: 13px 0; border-bottom: 1px solid var(--rule);
  text-decoration: none; transition: color .2s;
}
.niran-nav-drawer a:hover { color: var(--fg); }
.niran-drawer-contact {
  display: flex; flex-direction: column; gap: 8px;
  padding: 16px 0 4px;
  font-family: var(--font-thai); font-size: 13px;
}
.niran-drawer-contact a { border-bottom: 0; text-transform: none; letter-spacing: 0; font-family: var(--font-thai); font-size: 13px; }

/* Page-header band (used by most inner pages) */
.page-header {
  padding: clamp(64px, 10vw, 120px) var(--gutter) clamp(32px, 5vw, 64px);
  border-bottom: 1px solid var(--rule);
  max-width: 1280px; margin-inline: auto;
}
.page-header .label { margin-bottom: 18px; }
.page-header h1 {
  margin: 0;
  font-family: var(--font-display); font-style: italic; font-weight: 300;
  font-size: clamp(34px, 5vw, 72px); line-height: 1.08; letter-spacing: -.01em;
  color: var(--fg);
}
.page-header .notice {
  margin-top: 22px;
  font-family: var(--font-thai); font-size: clamp(13px, 1.1vw, 15px);
  line-height: 1.7; color: var(--fg-soft); max-width: 760px;
}

/* Shared footer */
.niran-footer {
  border-top: 1px solid var(--rule);
  padding: clamp(40px, 6vw, 80px) var(--gutter);
}
.niran-footer-inner {
  max-width: 1280px; margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(28px, 4vw, 64px);
}
.niran-footer-brand img {
  width: 38px; height: 38px; border-radius: 50%; object-fit: cover;
}
.niran-footer-brand p {
  margin: 12px 0 0; font-family: var(--font-thai); font-size: 14px;
  color: var(--fg-soft);
}
.niran-footer-socials {
  display: flex; gap: 16px; margin-top: 16px; align-items: center;
}
.niran-footer-socials a { color: var(--fg-soft); transition: color .25s; }
.niran-footer-socials a:hover { color: var(--fg); }
.niran-footer-socials img { opacity: .75; transition: opacity .25s; }
.niran-footer-socials a:hover img { opacity: 1; }

/* Bootstrap form overrides for dark theme */
.dark-form .form-control,
.dark-form select.form-control,
.dark-form textarea.form-control {
  background: rgba(232,226,213,.06);
  border: 1px solid var(--rule);
  color: var(--fg);
  border-radius: 2px;
}
.dark-form .form-control:focus,
.dark-form select.form-control:focus,
.dark-form textarea.form-control:focus {
  background: rgba(232,226,213,.1);
  border-color: var(--gold);
  box-shadow: none;
  color: var(--fg);
  outline: none;
}
.dark-form label {
  color: var(--fg-soft);
  font-family: var(--font-thai);
  font-size: 13px;
}
.dark-form .form-check-label { color: var(--fg-soft); font-family: var(--font-thai); }
.dark-form small { color: var(--fg-dim); font-family: var(--font-thai); font-size: 12px; }

/* Index React nav hamburger — hidden by default on desktop */
.nav-hamburger { display: none !important; }

/* Mobile contact bar */
.mobile-contact-bar {
  display: none;
  align-items: center; justify-content: center; gap: 14px;
  font-family: var(--font-thai); font-size: 13px;
  width: 100%;
}
.mobile-contact-bar a {
  display: flex; align-items: center; gap: 6px;
  color: #F2D789; text-decoration: none;
}
.mobile-contact-bar a img { width: 1.5rem; }
.mobile-contact-bar .mcb-sep { color: var(--fg-soft); }

@media (max-width: 640px) {
  /* base_dark nav */
  .niran-nav-links { display: none; }
  .niran-nav-contact { display: none; }
  .niran-hamburger { display: flex !important; }
  /* Index React nav */
  .nav-desktop { display: none !important; }
  .nav-hamburger { display: flex !important; }
  /* Show mobile contact bar */
  .mobile-contact-bar { display: flex; }
  /* Extra top padding on hero to clear taller fixed header (nav + contact bar ~38px) */
  .hero-grid { padding-top: clamp(140px, 22vh, 200px) !important; }
}
