:root {
  --bg: #fbf9f3;        /* airy ivory */
  --ink: #2c2620;       /* soft warm near-black */
  --muted: #8a8175;
  --line: #ece6d9;
  --card: #ffffff;
  --accent: #8c6a3c;    /* One Hectare bronze */
  --accent-dark: #6f5230;
  --accent-ink: #fff;
  --sage: #7a7d68;
  --chip-bg: #f1ece1;
  --band: #f3eee4;      /* soft tint for alternating sections */
  --radius: 16px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
  font-size: 16px;
  line-height: 1.75;
}
h1, h2, h3 { font-family: "Playfair Display", Georgia, serif; font-weight: 500; letter-spacing: -.005em; line-height: 1.12; }
a { color: inherit; }
.accent { color: var(--accent); }
.muted { color: var(--muted); }
.center { text-align: center; margin-top: 2rem; }
.eyebrow {
  font-family: "Cinzel", serif;
  text-transform: uppercase; letter-spacing: .22em; font-size: .74rem;
  font-weight: 500; color: var(--accent); margin: 0 0 .75rem;
}

/* animated wordmark: "One Hectare · Creative Grounds" -> "One Creative" */
.brand-anim span { display: inline-block; vertical-align: baseline; }
.w-strike, .w-sep {
  position: relative; overflow: hidden; white-space: nowrap;
  animation: oh-collapse 6.5s ease-in-out infinite;
}
.w-strike::after {
  content: ""; position: absolute; left: 0; top: 52%; height: .12em;
  background: currentColor; border-radius: 2px; width: 0;
  animation: oh-strike 6.5s ease-in-out infinite;
}
@keyframes oh-strike {
  0%, 22% { width: 0; }
  38%, 82% { width: 100%; }
  94%, 100% { width: 0; }
}
@keyframes oh-collapse {
  0%, 36% { max-width: 12em; opacity: 1; }
  50%, 80% { max-width: 0; opacity: 0; }
  92%, 100% { max-width: 12em; opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .w-strike, .w-sep { animation: none; max-width: none; opacity: 1; }
  .w-strike::after { animation: none; width: 0; }
}

/* buttons */
.btn {
  display: inline-block; padding: .7rem 1.3rem; border-radius: 999px;
  font-weight: 600; text-decoration: none; cursor: pointer; font-size: .95rem;
  border: 1.5px solid transparent; transition: transform .12s, background .12s, color .12s;
}
.btn-lg { padding: .9rem 1.7rem; font-size: 1rem; }
.btn-primary { background: var(--accent); color: var(--accent-ink); }
.btn-primary:hover { transform: translateY(-2px); background: var(--accent-dark); }
.btn-ghost { border-color: var(--ink); color: var(--ink); background: transparent; }
.btn-ghost:hover { background: var(--ink); color: var(--bg); }

/* nav */
.nav {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; gap: 1.5rem;
  padding: 1rem clamp(1.25rem, 5vw, 4rem);
  background: rgba(247,242,234,.9); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand { font-family: "Poppins", sans-serif; font-weight: 700; font-size: 1.4rem; letter-spacing: -.02em; text-decoration: none; color: var(--accent);
  display: inline-flex; flex-direction: column; line-height: 1; }
.brand-logo { height: 42px; width: auto; display: block; }
@media (max-width: 520px) { .brand-logo { height: 34px; } }
.brand small {
  font-family: "Poppins", sans-serif; font-weight: 600; font-size: .54rem;
  letter-spacing: .26em; text-transform: uppercase; color: var(--muted); margin-top: 5px;
}
.footer-tag {
  font-family: "Poppins", sans-serif; font-weight: 600; font-size: .66rem;
  letter-spacing: .26em; text-transform: uppercase; color: #c9b896; margin: 0 0 .8rem;
}
.nav-links { display: flex; gap: 1.5rem; margin-left: auto; }
.nav-links a { text-decoration: none; color: var(--muted); font-weight: 500; font-size: .95rem; }
.nav-links a:hover { color: var(--ink); }
.nav-cta { display: flex; gap: .6rem; }
.nav-toggle { display: none; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--ink); }

/* hero */
.hero {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items: center;
  padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 4rem);
  max-width: 1200px; margin: 0 auto;
}
.hero h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); margin: 0 0 1.25rem; }
.lede { font-size: 1.15rem; color: var(--muted); max-width: 32rem; margin: 0 0 1.75rem; }
.cta-row { display: flex; gap: .75rem; flex-wrap: wrap; }
.value-strip { list-style: none; display: flex; flex-wrap: nowrap; gap: 1.1rem; padding: 0; margin: 2.25rem 0 0; }
.value-strip li { display: flex; align-items: center; gap: .4rem; font-weight: 500; font-size: .85rem; white-space: nowrap; }
@media (max-width: 520px) { .value-strip { flex-wrap: wrap; } }
.value-strip span { color: var(--accent); }

/* hero art: connecting-dots network */
.hero-art { display: block; }
.hero-art .net { width: 100%; height: auto; aspect-ratio: 480 / 470; display: block; }
.net-init { font-family: "Montserrat", sans-serif; font-size: 11px; font-weight: 700; fill: #fff; text-anchor: middle; }
.net-role { font-family: "Montserrat", sans-serif; font-size: 7px; font-weight: 600; fill: #fff; fill-opacity: .9; text-anchor: middle; }
.tile {
  aspect-ratio: 1; border-radius: var(--radius); display: flex;
  flex-direction: column; align-items: center; justify-content: center; gap: .25rem;
  color: #fff; font-family: "Playfair Display", serif;
}
.tile span { font-size: 1.6rem; font-weight: 600; }
.tile small { font-size: .68rem; opacity: .9; font-family: "Montserrat", sans-serif; letter-spacing: .03em; }
.tile.t1 { background: #8c6a3c; } .tile.t2 { background: #7a7d68; }
.tile.t3 { background: #a98a5e; } .tile.t4 { background: #8a6a5e; }
.tile.t5 { background: #6f6e63; } .tile.t6 { background: #9c7048; }
.tile.t2, .tile.t5 { margin-top: 1.4rem; }

/* sections */
.section { max-width: 1100px; margin: 0 auto; padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 5vw, 4rem); }
.section-head { max-width: 40rem; margin-bottom: 2.5rem; }
.section-head h2, .band h2, .join-head h2 { font-size: clamp(1.6rem, 3.5vw, 2.3rem); margin: 0 0 .5rem; }
.section-sub { color: var(--muted); font-size: 1.05rem; margin: 0; }

/* community cards */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.1rem; }
.creative {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.3rem; transition: transform .12s, box-shadow .12s;
}
.creative:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(33,30,25,.08); }
.creative-top { display: flex; align-items: center; gap: .8rem; margin-bottom: .9rem; }
.avatar {
  width: 3rem; height: 3rem; border-radius: 50%; flex: none; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: "Playfair Display", serif; font-weight: 600;
}
.creative-name { font-weight: 700; }
.creative-role { color: var(--muted); font-size: .85rem; }
.creative .looking { font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; color: var(--accent); margin: .2rem 0 .4rem; font-weight: 600; }
.creative ul { margin: 0 0 .9rem; padding-left: 1.1rem; color: var(--ink); font-size: .92rem; }
.creative ul li { margin: .1rem 0; }
.ig { font-size: .85rem; color: var(--muted); text-decoration: none; }
.ig:hover { color: var(--accent); }

/* network leaders */
.leader-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.leader {
  display: flex; align-items: center; gap: 1.2rem; color: var(--ink);
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 1.4rem 1.5rem;
  transition: transform .12s ease, box-shadow .12s ease;
}
.leader:hover { transform: translateY(-3px); box-shadow: 0 16px 36px rgba(44, 38, 32, .10); }
.leader-photo {
  position: relative; width: 5.25rem; height: 5.25rem; flex: none;
  border-radius: 16px; overflow: hidden;
  background: linear-gradient(135deg, #5c4327, #74552f);
}
.leader-photo img {
  position: absolute; inset: 0; z-index: 1; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 22%; display: block;
  filter: grayscale(.15) contrast(1.02);
}
.leader-initials {
  position: absolute; inset: 0; z-index: 0; display: flex; align-items: center; justify-content: center;
  font-family: "Playfair Display", serif; font-weight: 600; font-size: 1.45rem; color: #fff;
}
.leader-body { display: flex; flex-direction: column; }
.leader-name { font-family: "Playfair Display", serif; font-size: 1.35rem; font-weight: 600; margin: 0; }
.leader-role { text-transform: uppercase; letter-spacing: .1em; font-size: .7rem; font-weight: 600; color: var(--accent); margin: .2rem 0 .35rem; }
.leader-bio { color: var(--ink); margin: 0 0 .55rem; font-size: .92rem; line-height: 1.45; }
.leader-link { font-weight: 600; color: var(--accent); font-size: .9rem; }
.leader-links { display: flex; flex-wrap: wrap; gap: .25rem 1.1rem; margin: 0; }
.leader-links a { font-weight: 600; color: var(--accent); font-size: .9rem; text-decoration: none; }
.leader-links a:hover { text-decoration: underline; }
@media (max-width: 720px) { .leader-grid { grid-template-columns: 1fr; } }

.collab-label { margin-bottom: 1.25rem; }

/* connections list */
.connections { margin-top: 3rem; }
.connections .eyebrow { margin-bottom: 1rem; }
.conn-list { display: flex; flex-wrap: wrap; gap: .6rem; list-style: none; padding: 0; margin: 0; }
.conn-list li {
  border: 1px solid rgba(44, 38, 32, .07); border-radius: 999px;
  padding: .5rem 1.05rem; font-weight: 600; font-size: .9rem; color: var(--ink);
}
.conn-list li:nth-child(18n+1)  { background: #f4e6c6; }
.conn-list li:nth-child(18n+2)  { background: #f1ddc9; }
.conn-list li:nth-child(18n+3)  { background: #f1d6d0; }
.conn-list li:nth-child(18n+4)  { background: #f1d6df; }
.conn-list li:nth-child(18n+5)  { background: #ecd9ee; }
.conn-list li:nth-child(18n+6)  { background: #e2dcf0; }
.conn-list li:nth-child(18n+7)  { background: #d9def0; }
.conn-list li:nth-child(18n+8)  { background: #d6e6f0; }
.conn-list li:nth-child(18n+9)  { background: #d3eae6; }
.conn-list li:nth-child(18n+10) { background: #d6ebd9; }
.conn-list li:nth-child(18n+11) { background: #e0ebcf; }
.conn-list li:nth-child(18n+12) { background: #ece8c6; }
.conn-list li:nth-child(18n+13) { background: #f0e3c0; }
.conn-list li:nth-child(18n+14) { background: #efd9c2; }
.conn-list li:nth-child(18n+15) { background: #f0d3c6; }
.conn-list li:nth-child(18n+16) { background: #efd0d4; }
.conn-list li:nth-child(18n+17) { background: #e6d2ea; }
.conn-list li:nth-child(18n+0)  { background: #d8d6ee; }

/* bubbles drift gently, out of sync */
@keyframes conn-float {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-7px); }
  100% { transform: translateY(0); }
}
@media (prefers-reduced-motion: no-preference) {
  .conn-list li { animation: conn-float 4.5s ease-in-out infinite; will-change: transform; }
  .conn-list li:nth-child(6n+1) { animation-delay: -3.6s; }
  .conn-list li:nth-child(6n+2) { animation-duration: 5.3s; animation-delay: -.8s; }
  .conn-list li:nth-child(6n+3) { animation-duration: 6s;   animation-delay: -1.6s; }
  .conn-list li:nth-child(6n+4) { animation-duration: 4.1s; animation-delay: -2.2s; }
  .conn-list li:nth-child(6n+5) { animation-duration: 5.7s; animation-delay: -3s; }
  .conn-list li:nth-child(6n+6) { animation-duration: 4.8s; animation-delay: -1.1s; }
}

/* bands (alt background, soft tint) */
.band { background: var(--band); color: var(--ink); }
.band .eyebrow { color: var(--accent); }
.band-inner { max-width: 1100px; margin: 0 auto; padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 5vw, 4rem); }
.band .section-sub { color: var(--muted); }

/* matchmaking */
.chips { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.5rem 0; }
.chip {
  border: 1px solid var(--line); background: var(--card); color: var(--ink);
  border-radius: 999px; padding: .5rem 1rem; font-size: .9rem; cursor: pointer;
  font-family: inherit; transition: background .12s, color .12s, border-color .12s;
}
.chip:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.match-form { display: flex; flex-wrap: wrap; align-items: center; gap: .7rem; margin-top: 1.5rem; }
.match-prefix { font-family: "Playfair Display", serif; font-size: 1.2rem; }
.match-form input {
  flex: 1; min-width: 240px; padding: .85rem 1rem; border-radius: 999px;
  border: 1px solid var(--line); background: var(--card); color: var(--ink); font-size: 1rem; font-family: inherit;
}
.match-form input::placeholder { color: var(--muted); }
.match-form input:focus { outline: 2px solid var(--accent); border-color: var(--accent); }

/* opportunities */
.opp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.1rem; }
.opp { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; }
.opp h3 { margin: 0 0 .2rem; font-size: 1.3rem; }
.opp-by { color: var(--muted); font-size: .85rem; margin: 0 0 1rem; }
.opp .looking { font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--accent); font-weight: 600; margin: 0 0 .35rem; }
.opp ul { margin: 0 0 1.1rem; padding-left: 1.1rem; }
.opp-apply { font-weight: 600; color: var(--accent); text-decoration: none; }
.opp-apply:hover { text-decoration: underline; }

/* events */
.event-list { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: .2rem; }
.event-list li { display: flex; align-items: center; gap: 1.2rem; padding: 1rem 0; border-top: 1px solid var(--line); }
.event-list li:last-child { border-bottom: 1px solid var(--line); }
.ev-date {
  font-family: "Playfair Display", serif; font-size: 1rem; font-weight: 600; width: 3.6rem; flex: none;
  color: var(--accent); text-transform: uppercase; letter-spacing: .05em;
}
.event-list strong { display: block; font-size: 1.1rem; }
.event-list strong a { text-decoration: none; color: inherit; }
.event-list strong a:hover { color: var(--accent); }
.event-list small { color: var(--muted); }

/* this-month highlight */
.event-list li.event-now {
  background: linear-gradient(135deg, #5c4327, #74552f); border-radius: 14px;
  border-top-color: transparent; padding: 1.1rem 1.2rem; margin: .35rem 0;
  color: #f3ead9;
}
.event-list li.event-now + li { border-top-color: transparent; }
.event-list li.event-now .ev-date { color: #e7cfa3; }
.event-list li.event-now strong, .event-list li.event-now strong a { color: #fff; }
.event-list li.event-now small { color: #e1d7c6; }
.now-tag {
  display: inline-block; background: #e7cfa3; color: #3a2c18;
  font-family: "Montserrat", sans-serif; font-size: .58rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; padding: .22rem .55rem;
  border-radius: 999px; margin-left: .5rem; vertical-align: middle;
}

/* stories */
.story-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.2rem; }
.story { margin: 0; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; }
.story p { font-family: "Playfair Display", serif; font-size: 1.2rem; line-height: 1.4; margin: 0 0 1rem; }
.story footer { color: var(--muted); font-size: .9rem; font-weight: 600; }

/* join */
.join { background: linear-gradient(180deg, var(--bg), #efe7d8); }
.join-inner { max-width: 720px; margin: 0 auto; padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 5vw, 4rem); }
/* raised "bubble" card so the form pops off the section */
.join-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 26px;
  padding: clamp(1.75rem, 4vw, 3rem);
  box-shadow: 0 26px 60px rgba(44, 38, 32, .13);
}
.join-card input, .join-card textarea { background: #f8f4ec; }
.join-card .check span { background: #f8f4ec; }
.join-head { text-align: center; margin-bottom: 2.5rem; }
.join-head .section-sub { margin: .5rem auto 0; max-width: 30rem; }
.join-form fieldset { border: none; padding: 0; margin: 0 0 2rem; }
.join-form legend { font-family: "Playfair Display", serif; font-size: 1.2rem; font-weight: 600; margin-bottom: .9rem; padding: 0; }
.join-form label { display: block; font-weight: 500; font-size: .9rem; margin-bottom: 1rem; }
.join-form input, .join-form textarea {
  display: block; width: 100%; margin-top: .35rem; padding: .8rem 1rem;
  border: 1px solid var(--line); border-radius: 12px; background: var(--card);
  font-family: inherit; font-size: 1rem; color: var(--ink);
}
.join-form input:focus, .join-form textarea:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.checks { display: flex; flex-wrap: wrap; gap: .6rem; }
.check { margin: 0 !important; }
.check input { position: absolute; opacity: 0; }
.check span {
  display: inline-block; padding: .55rem 1.1rem; border-radius: 999px;
  background: var(--card); border: 1px solid var(--line); cursor: pointer; font-weight: 500;
}
.check input:checked + span { background: var(--accent); color: #fff; border-color: var(--accent); }
.form-note { background: var(--card); border: 1px solid var(--accent); color: var(--accent);
  border-radius: 12px; padding: .9rem 1.1rem; margin-top: 1rem; font-weight: 600; }
.form-note.form-error { background: #fae3dd; border-color: #c0492f; color: #a83a26; }

/* footer */
.footer { background: var(--ink); color: var(--bg); padding: clamp(3rem, 6vw, 4rem) clamp(1.25rem, 5vw, 4rem) 2rem; }
.footer-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.footer .brand { color: var(--bg); font-size: 1.4rem; margin: 0 0 .5rem; }
.footer .muted { color: #c9c1b4; }
.footer-book h3 { margin: 0 0 .4rem; }
.footer-meta { display: flex; flex-direction: column; gap: .5rem; }
.footer-meta a { color: #c9c1b4; text-decoration: none; }
.footer-meta a:hover { color: var(--bg); }
.copyright { text-align: center; color: #8a8377; font-size: .85rem; margin: 3rem 0 0; }

/* ===== Event page ===== */
.ev-hero {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items: center;
  padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 4rem);
  max-width: 1200px; margin: 0 auto;
}
.ev-hero h1 { font-size: clamp(2.4rem, 6vw, 4rem); margin: 0; }
.ev-subtitle { font-family: "Playfair Display", serif; font-size: 1.5rem; color: var(--muted); margin: .25rem 0 1.25rem; }
.ev-meta { display: flex; flex-wrap: wrap; gap: 1.25rem; margin: 0 0 1.5rem; font-weight: 500; }
.ev-meta span { white-space: nowrap; }
.lamp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.bulb-art { width: 100%; }
.bulb-art .bulb-svg { width: 100%; height: auto; aspect-ratio: 420 / 470; display: block; }
.lamp {
  aspect-ratio: 1; border-radius: var(--radius); display: flex; align-items: center; justify-content: center;
  font-size: 2.4rem; background: radial-gradient(circle at 50% 38%, #fbe6c0, #f0dcbf 55%, #e7d6bd);
  box-shadow: inset 0 0 40px rgba(140,106,60,.12);
}
.lamp:nth-child(odd) { background: radial-gradient(circle at 50% 38%, #fdeccb, #efddc0 60%, #e3d2b6); }

.idea-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 1.75rem; }
.idea { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; }
.idea-num {
  display: inline-flex; width: 2rem; height: 2rem; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--accent); color: #fff; font-family: "Playfair Display", serif;
  font-weight: 600; margin-bottom: .8rem;
}
.idea p { margin: 0; }

.detail-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.detail { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; }
.detail-k { display: block; text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; font-weight: 600; color: var(--accent); margin-bottom: .5rem; }
.detail-v { font-family: "Playfair Display", serif; font-size: 1.25rem; line-height: 1.3; }

/* home: featured next-event banner */
.feature {
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
  background: var(--ink); color: var(--bg); border-radius: var(--radius);
  padding: 1.6rem 1.8rem; margin-bottom: 2rem; text-decoration: none;
}
.feature .feature-glow { font-size: 2.2rem; }
.feature-body { flex: 1; min-width: 200px; }
.feature-kicker { text-transform: uppercase; letter-spacing: .14em; font-size: .7rem; font-weight: 600; color: #e3c79a; margin: 0 0 .2rem; }
.feature h3 { color: var(--bg); margin: 0; font-size: 1.5rem; }
.feature .feature-go { color: var(--bg); font-weight: 600; white-space: nowrap; border: 1.5px solid rgba(255,255,255,.4); border-radius: 999px; padding: .55rem 1.1rem; }
.feature:hover .feature-go { background: var(--accent); border-color: var(--accent); }

/* prominent next-event highlight (after hero) */
.next-wrap { max-width: 1100px; margin: 0 auto; padding: clamp(2rem, 4vw, 3rem) clamp(1.25rem, 5vw, 4rem); }
.next-title { text-transform: uppercase; letter-spacing: .18em; font-size: .82rem; font-weight: 700; color: var(--accent); margin: 0 0 1rem; }
.next-card {
  display: flex; align-items: center; gap: 2rem; flex-wrap: wrap;
  background: linear-gradient(135deg, #5c4327, #74552f); color: var(--bg); border-radius: 24px;
  padding: clamp(1.75rem, 4vw, 2.75rem);
}
.next-glow { font-size: clamp(3rem, 7vw, 4.5rem); flex: none; filter: drop-shadow(0 0 26px rgba(240,200,120,.6)); }
.next-body { flex: 1; min-width: 240px; }
.next-kicker { text-transform: uppercase; letter-spacing: .16em; font-size: .74rem; font-weight: 600; color: #e7cfa3; margin: 0 0 .4rem; }
.next-card h2 { color: var(--bg); font-size: clamp(1.7rem, 4vw, 2.5rem); margin: 0 0 .6rem; }
.next-sub { color: #e3d9c9; max-width: 42rem; margin: 0 0 1rem; }
.next-meta { display: flex; flex-wrap: wrap; gap: .4rem 1.4rem; margin: 0 0 1.4rem; font-weight: 500; color: #ece3d4; }
.next-meta span { white-space: nowrap; }
.next-actions { display: flex; gap: .75rem; flex-wrap: wrap; }

/* glowing gradient RSVP button */
.btn-glow {
  color: #3a2c18; border: none;
  background: linear-gradient(120deg, #f3ca72, #e0a23f, #c8832f);
  background-size: 200% 100%;
  box-shadow: 0 0 22px rgba(232,180,90,.5), 0 6px 16px rgba(0,0,0,.22);
  animation: btn-glow 3s ease-in-out infinite alternate;
}
.btn-glow:hover { transform: translateY(-2px); color: #3a2c18; }
@keyframes btn-glow {
  from { box-shadow: 0 0 16px rgba(232,180,90,.4), 0 6px 16px rgba(0,0,0,.22); background-position: 0% 50%; }
  to   { box-shadow: 0 0 36px rgba(245,205,120,.75), 0 6px 18px rgba(0,0,0,.26); background-position: 100% 50%; }
}
@media (prefers-reduced-motion: reduce) { .btn-glow { animation: none; } }

/* light ghost button on the brown card */
.btn-ghost-light { border: 1.5px solid rgba(255,255,255,.5); color: var(--bg); background: transparent; }
.btn-ghost-light:hover { background: var(--bg); color: var(--ink); }

/* responsive */
@media (max-width: 860px) {
  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: block; margin-left: auto; }
  .nav.open .nav-links { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--bg); padding: 1rem 1.5rem; gap: 1rem; border-bottom: 1px solid var(--line); }
  .nav.open .nav-cta { display: flex; position: absolute; top: 100%; left: 0; right: 0; margin-top: 9rem;
    padding: 0 1.5rem 1.25rem; background: var(--bg); }
  .hero { grid-template-columns: 1fr; }
  .hero-art { max-width: 380px; }
  .footer-grid { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .ev-hero { grid-template-columns: 1fr; }
  .lamp-grid, .bulb-art { max-width: 380px; margin-inline: auto; }
  .idea-grid { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) { .detail-grid { grid-template-columns: 1fr; } }
