/* EDGY ROOT · Plants With Attitude · Grow Outside the Pot · Misfit Plants
   Palette + type pulled from the brand logo: bone-cream + olive on near-black, distressed gothic. */

@import url('https://fonts.googleapis.com/css2?family=Pirata+One&family=Cinzel:wght@400;600;700;900&family=IM+Fell+English:ital@0;1&family=Special+Elite&display=swap');

:root {
  /* surfaces */
  --bg-night: #0a0a08;
  --bg-deep:  #0e0e0b;
  --bg-base:  #131310;
  --bg-elev:  #1a1a16;
  --bg-card:  #1f1f1a;
  --hairline: #2e2e26;
  --hairline-soft: #1f1f1a;

  /* ink */
  --bone:        #d4c89a;
  --bone-bright: #ece0b3;
  --bone-soft:   #b8ab83;
  --olive:       #7a8c4f;
  --olive-bright:#92a560;
  --olive-deep:  #515f33;
  --rust:        #a85d39;
  --muted:       #807865;
  --dim:         #4d4a40;

  /* type */
  --font-display: 'Pirata One', 'UnifrakturMaguntia', serif;
  --font-title:   'Cinzel', 'Trajan Pro', serif;
  --font-body:    'IM Fell English', 'EB Garamond', 'Garamond', serif;
  --font-tw:      'Special Elite', 'Courier New', monospace;

  /* layout */
  --max-w: 1240px;
  --pad-x: clamp(1.25rem, 5vw, 3.5rem);

  /* motion */
  --t-fast: 200ms;
  --t-med: 400ms;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { background: var(--bg-night); color: var(--bone); font-family: var(--font-body); font-size: 18px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { min-height: 100dvh; background:
  radial-gradient(ellipse 80% 50% at 50% -10%, rgba(122, 140, 79, 0.06), transparent 70%),
  var(--bg-night);
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--bone); text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--olive-bright); }

/* type */
.display { font-family: var(--font-display); font-weight: 400; line-height: 1.05; letter-spacing: 0.005em; text-transform: uppercase; color: var(--bone); }
.display em { color: var(--olive); font-style: normal; }
.title-cap { font-family: var(--font-title); font-weight: 700; text-transform: uppercase; letter-spacing: 0.16em; }
.eyebrow { font-family: var(--font-tw); font-size: 0.78rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--olive); display: inline-flex; align-items: center; gap: 0.8rem; }
.eyebrow::before { content: '✦'; font-size: 0.7em; color: var(--olive); }
.eyebrow::after { content: '✦'; font-size: 0.7em; color: var(--olive); }
.eyebrow.right::after { display: none; }
.eyebrow.left::before { display: none; }
p { color: var(--bone-soft); line-height: 1.7; font-size: 1.05rem; }
em { font-style: italic; color: var(--bone-bright); }
strong { color: var(--bone-bright); font-weight: 600; }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 400; line-height: 1.05; letter-spacing: 0.005em; text-transform: uppercase; }

/* layout */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x); }
.section { padding: clamp(4rem, 7vw, 7rem) var(--pad-x); }

/* nav */
.topbar { position: sticky; top: 0; z-index: 60; background: rgba(10,10,8,0.88); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--hairline-soft); }
.topbar__inner { max-width: var(--max-w); margin: 0 auto; padding: 0.8rem var(--pad-x); display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.topbar__brand { display: flex; align-items: center; gap: 0.7rem; color: var(--bone-bright); }
.topbar__brand img { height: 46px; width: 46px; border-radius: 50%; object-fit: cover; border: 1px solid var(--hairline); }
.topbar__brand-name { display: flex; flex-direction: column; line-height: 1.05; }
.topbar__brand-name span:first-child { font-family: var(--font-display); font-size: 1.5rem; color: var(--bone-bright); letter-spacing: 0.02em; }
.topbar__brand-name span:last-child { font-family: var(--font-tw); font-size: 0.6rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--olive); }
.topbar__nav { display: flex; align-items: center; gap: 1.8rem; }
.topbar__nav a { font-family: var(--font-title); font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--bone-soft); }
.topbar__nav a:hover { color: var(--olive-bright); }
@media (max-width: 760px) { .topbar__nav a:not(.cta) { display: none; } .topbar__brand-name { display: none; } }

/* buttons */
.btn { display: inline-flex; align-items: center; gap: 0.6rem; padding: 0.95rem 1.75rem; font-family: var(--font-title); font-weight: 700; font-size: 0.84rem; letter-spacing: 0.22em; text-transform: uppercase; border: 1px solid transparent; cursor: pointer; transition: all var(--t-fast) var(--ease); border-radius: 0; white-space: nowrap; }
.btn--primary { background: var(--olive); color: var(--bg-night); border-color: var(--olive); }
.btn--primary:hover { background: var(--olive-bright); border-color: var(--olive-bright); color: var(--bg-night); transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--bone); border-color: var(--bone-soft); }
.btn--ghost:hover { background: var(--bone); color: var(--bg-night); border-color: var(--bone); }
.btn .arrow { transition: transform var(--t-fast) var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

/* hero */
.hero { position: relative; padding: clamp(4rem, 9vw, 8rem) var(--pad-x) clamp(3rem, 7vw, 6rem); overflow: hidden; min-height: 80vh; display: flex; align-items: center; }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.42; filter: contrast(1.05) saturate(0.85); }
.hero__overlay { position: absolute; inset: 0; z-index: -1; background:
  radial-gradient(ellipse 70% 60% at 50% 50%, transparent 0%, rgba(10,10,8,0.85) 75%, rgba(10,10,8,0.98) 100%),
  linear-gradient(to bottom, rgba(10,10,8,0.5) 0%, rgba(10,10,8,0.85) 100%);
}
.hero__inner { max-width: var(--max-w); margin: 0 auto; text-align: center; position: relative; z-index: 1; }
.hero__logo { width: clamp(180px, 24vw, 280px); height: auto; margin: 0 auto 2rem; border-radius: 50%; filter: drop-shadow(0 8px 40px rgba(122,140,79,0.15)); }
.hero__title { font-size: clamp(3rem, 9vw, 7rem); margin-bottom: 1rem; color: var(--bone-bright); text-shadow: 0 4px 30px rgba(0,0,0,0.6); }
.hero__title em { color: var(--olive-bright); font-style: normal; }
.hero__lede { font-family: var(--font-body); font-style: italic; font-size: clamp(1.05rem, 1.6vw, 1.4rem); color: var(--bone); margin: 0 auto 1.8rem; max-width: 56ch; line-height: 1.55; }
.hero__est { font-family: var(--font-tw); font-size: 0.75rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--olive); margin-bottom: 1.8rem; display: inline-block; padding: 0.3rem 1.2rem; border-top: 1px solid var(--olive); border-bottom: 1px solid var(--olive); }
.hero__cta { display: flex; gap: 0.9rem; justify-content: center; flex-wrap: wrap; margin-top: 1.5rem; }

/* manifesto / story */
.split { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split--reverse > :first-child { order: 2; }
.split--reverse > :last-child  { order: 1; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; gap: 2rem; } .split--reverse > :first-child { order: 1; } .split--reverse > :last-child { order: 2; } }
.split__img { position: relative; overflow: hidden; aspect-ratio: 4/5; border: 1px solid var(--hairline); }
.split__img img { width: 100%; height: 100%; object-fit: cover; }

/* section header */
.section__head { max-width: 60ch; margin: 0 auto clamp(2.5rem, 5vw, 4rem); text-align: center; }
.section__head .eyebrow { margin-bottom: 1.2rem; }
.section__head h2 { font-size: clamp(2.2rem, 5vw, 4rem); margin-bottom: 1rem; }
.section__head p { font-style: italic; font-size: 1.1rem; max-width: 56ch; margin-left: auto; margin-right: auto; }

/* product grid */
.products { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.product { background: var(--bg-elev); border: 1px solid var(--hairline-soft); overflow: hidden; transition: transform var(--t-med) var(--ease), border-color var(--t-fast) var(--ease); position: relative; }
.product:hover { transform: translateY(-3px); border-color: var(--olive); }
.product__img { aspect-ratio: 4/5; overflow: hidden; background: var(--bg-deep); }
.product__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 800ms var(--ease); }
.product:hover .product__img img { transform: scale(1.04); }
.product__body { padding: 1.4rem 1.5rem 1.8rem; border-top: 1px solid var(--hairline-soft); }
.product__sku { font-family: var(--font-tw); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--olive); margin-bottom: 0.6rem; }
.product__name { font-family: var(--font-display); font-size: 1.5rem; color: var(--bone-bright); letter-spacing: 0.02em; margin-bottom: 0.4rem; line-height: 1.1; }
.product__plant { font-family: var(--font-body); font-style: italic; font-size: 0.95rem; color: var(--bone-soft); margin-bottom: 0.9rem; }
.product__row { display: flex; justify-content: space-between; align-items: end; margin-top: 0.6rem; padding-top: 0.9rem; border-top: 1px solid var(--hairline-soft); }
.product__price { font-family: var(--font-title); font-weight: 700; color: var(--bone-bright); font-size: 1rem; letter-spacing: 0.06em; }
.product__price small { font-family: var(--font-body); font-weight: 400; color: var(--muted); font-size: 0.75rem; letter-spacing: 0; margin-left: 0.3rem; }
.product__cta { font-family: var(--font-tw); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--olive); }
.product__sold-out { position: absolute; top: 1rem; right: 1rem; background: var(--bg-night); color: var(--bone); font-family: var(--font-tw); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 0.3rem 0.7rem; border: 1px solid var(--bone-soft); z-index: 2; }
.product__sold-out--rust { color: var(--rust); border-color: var(--rust); }

/* manifesto block */
.manifesto { background: var(--bg-deep); border-top: 1px solid var(--hairline-soft); border-bottom: 1px solid var(--hairline-soft); padding: clamp(4rem,8vw,8rem) var(--pad-x); }
.manifesto__inner { max-width: 800px; margin: 0 auto; text-align: center; }
.manifesto blockquote { font-family: var(--font-body); font-style: italic; font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1.4; color: var(--bone-bright); margin-bottom: 2rem; }
.manifesto blockquote::before { content: '«'; font-family: var(--font-display); color: var(--olive); font-size: 2em; line-height: 0.4; margin-right: 0.3em; vertical-align: -0.2em; }
.manifesto blockquote::after { content: '»'; font-family: var(--font-display); color: var(--olive); font-size: 2em; line-height: 0.4; margin-left: 0.2em; vertical-align: -0.2em; }
.manifesto__sig { font-family: var(--font-tw); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }

/* process / detail */
.process-grid { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; margin-top: 2.5rem; }
.process-step { background: var(--bg-elev); border: 1px solid var(--hairline-soft); padding: 1.8rem 1.6rem 2rem; }
.process-step__num { font-family: var(--font-display); font-size: 2.4rem; color: var(--olive); line-height: 1; margin-bottom: 0.5rem; }
.process-step__title { font-family: var(--font-display); font-size: 1.3rem; color: var(--bone-bright); margin-bottom: 0.6rem; }
.process-step p { font-size: 0.96rem; }

/* waitlist / cta block */
.waitlist { padding: clamp(3.5rem, 7vw, 7rem) var(--pad-x); background:
  linear-gradient(135deg, rgba(122,140,79,0.08) 0%, rgba(10,10,8,1) 70%),
  var(--bg-night);
  border-top: 1px solid var(--olive-deep);
  border-bottom: 1px solid var(--olive-deep);
  text-align: center;
}
.waitlist__inner { max-width: 580px; margin: 0 auto; }
.waitlist h2 { font-size: clamp(2.4rem, 5vw, 3.6rem); margin-bottom: 1rem; }
.waitlist p { font-style: italic; max-width: 50ch; margin: 0 auto 2rem; }
.waitlist form { display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: center; }
.waitlist input { flex: 1 1 240px; min-width: 0; padding: 0.95rem 1.2rem; background: var(--bg-elev); border: 1px solid var(--hairline); color: var(--bone); font-family: var(--font-body); font-size: 1rem; border-radius: 0; }
.waitlist input:focus { outline: 2px solid var(--olive); border-color: var(--olive); }
.waitlist__notice { margin-top: 1.5rem; font-family: var(--font-tw); font-size: 0.78rem; letter-spacing: 0.06em; color: var(--muted); }

/* footer */
.footer { padding: 4rem var(--pad-x) 1.5rem; background: var(--bg-deep); border-top: 1px solid var(--hairline-soft); }
.footer__grid { max-width: var(--max-w); margin: 0 auto 2.5rem; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2.5rem; }
@media (max-width: 760px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: 1.5rem; } }
.footer h5 { font-family: var(--font-title); font-weight: 700; font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--olive); margin-bottom: 1rem; }
.footer p, .footer ul { font-family: var(--font-body); font-size: 0.94rem; line-height: 1.65; }
.footer ul { list-style: none; padding: 0; display: grid; gap: 0.3rem; }
.footer a { color: var(--bone-soft); }
.footer a:hover { color: var(--olive-bright); }
.footer__brand { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 1rem; }
.footer__brand img { width: 50px; height: 50px; border-radius: 50%; }
.footer__copy { max-width: var(--max-w); margin: 0 auto; padding-top: 1.5rem; border-top: 1px solid var(--hairline-soft); font-family: var(--font-tw); font-size: 0.72rem; letter-spacing: 0.14em; color: var(--dim); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.6rem; text-transform: uppercase; }

/* utilities */
.divider { display: flex; align-items: center; gap: 1rem; max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad-x); }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right, transparent, var(--olive-deep), transparent); }
.divider span { font-family: var(--font-tw); font-size: 0.72rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--olive); white-space: nowrap; }
.center { text-align: center; }
