/* Embodied Tea — page-level layout & section styles
   Builds on src/tokens.css
*/

/* Container */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* Site nav — extremely quiet, blends into paper */
.site-nav {
  padding: var(--s-6) 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-6);
  position: relative;
}
.site-nav__brand {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.site-nav__brand .amp { color: var(--moss); font-style: normal; }
.site-nav__links {
  display: flex;
  gap: var(--s-7);
  font-size: var(--t-sm);
  color: var(--ink-3);
}
.site-nav__links a { text-decoration: none; }
.site-nav__links a:hover { color: var(--ink); }
.site-nav__rsvp {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 2px;
}

/* --- Hero --- */
.hero {
  padding-top: var(--s-9);
  padding-bottom: var(--s-11);
  position: relative;
}
.hero__lead-meta {
  display: flex;
  gap: var(--s-5);
  margin-bottom: var(--s-7);
  align-items: center;
}
.hero__lead-meta .dot {
  width: 6px; height: 6px;
  background: var(--moss);
  border-radius: 999px;
  display: inline-block;
  flex: 0 0 auto;
}
.hero__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(3.25rem, 8vw, 6.5rem);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin: 0;
  max-width: 14ch;
}
.hero__title em {
  font-style: italic;
  color: var(--moss-dark);
  font-weight: 400;
}
.hero__sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
  color: var(--ink-2);
  margin-top: var(--s-6);
  max-width: 38ch;
  line-height: 1.35;
}
.hero__cta-row {
  margin-top: var(--s-9);
  display: flex;
  gap: var(--s-7);
  align-items: center;
  flex-wrap: wrap;
}

/* Hero grid — title on left, image slot + next-gathering on right (desktop) */
.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--s-10);
  align-items: end;
}
.hero__right {
  display: flex;
  flex-direction: column;
  gap: var(--s-7);
}
.hero__image {
  width: 100%;
  aspect-ratio: 4 / 5;
  background: var(--paper-2);
  border: var(--rule-hair);
  overflow: hidden;
}

/* --- Section frame --- */
.section {
  padding-block: var(--s-11);
  position: relative;
}
.section + .section { border-top: var(--rule-hair); }

.section__index {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--s-7);
  display: flex;
  align-items: center;
  gap: var(--s-3);
}
.section__index::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 1px;
  background: var(--ink-3);
}
.section__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  max-width: 18ch;
  margin: 0 0 var(--s-7) 0;
}
.section__lead {
  font-family: var(--font-serif);
  font-size: clamp(1.25rem, 1.8vw, 1.5rem);
  font-style: italic;
  color: var(--ink-2);
  line-height: 1.4;
  max-width: 32ch;
}

/* Two-column reading layout */
.cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: var(--s-10);
  align-items: start;
}
.cols--reverse { grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }
.cols__head { position: sticky; top: var(--s-8); }
.cols__body p + p { margin-top: 1.1em; }
.cols__body p {
  font-size: var(--t-md);
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 56ch;
}

/* --- Event card (next gathering) --- */
.event-card {
  background: var(--card);
  border: var(--rule-strong);
  padding: var(--s-7);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}
.event-card__kicker {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--moss-dark);
  display: flex;
  align-items: center;
  gap: 10px;
}
.event-card__kicker .pulse {
  width: 7px; height: 7px;
  background: var(--moss);
  border-radius: 999px;
  display: inline-block;
  position: relative;
}
.event-card__kicker .pulse::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 999px;
  border: 1px solid var(--moss);
  opacity: 0.6;
  animation: pulse 2.2s var(--ease) infinite;
}
@keyframes pulse {
  0%   { transform: scale(0.6); opacity: 0.7; }
  100% { transform: scale(1.8); opacity: 0; }
}
.event-card__date {
  font-family: var(--font-serif);
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.event-card__date em { font-style: italic; color: var(--ink-3); font-weight: 400; }

.event-card__rows {
  display: grid;
  grid-template-columns: 6em 1fr;
  row-gap: var(--s-3);
  column-gap: var(--s-5);
  align-items: baseline;
  font-size: var(--t-sm);
}
.event-card__rows dt {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.event-card__rows dd {
  margin: 0;
  color: var(--ink);
  font-size: var(--t-base);
}
.event-card__rows dd .muted { color: var(--ink-3); }

.gathering-map {
  margin: var(--s-6) 0 0;
  border: var(--rule-hair);
  background: var(--card);
}
.gathering-map iframe {
  width: 100%;
  height: 360px;
  border: 0;
  display: block;
  filter: grayscale(0.2);
}
.gathering-map__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-top: var(--rule-hair);
}
.gathering-map__place {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--t-base);
  color: var(--ink-2);
}
.gathering-map__place svg { fill: var(--moss); flex: none; }
.gathering-map__bar a {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
  transition: color var(--ease) 0.2s;
}
.gathering-map__bar a:hover { color: var(--ink); }

.event-card__foot {
  border-top: var(--rule-hair);
  padding-top: var(--s-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  flex-wrap: wrap;
}
.event-card__weather {
  font-size: var(--t-sm);
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* --- Practice container list --- */
.practice-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
.practice-list li {
  display: grid;
  grid-template-columns: 3em 1fr;
  gap: var(--s-5);
  align-items: baseline;
  padding: var(--s-5) 0;
  border-bottom: var(--rule-hair);
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  color: var(--ink);
}
.practice-list li:first-child { border-top: var(--rule-hair); }
.practice-list .num {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  color: var(--ink-3);
}

/* --- Bring list (small, two columns on desktop) --- */
.bring-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-4) var(--s-7);
  list-style: none;
  margin: 0;
  padding: 0;
}
.bring-list li {
  display: flex;
  align-items: baseline;
  gap: var(--s-4);
  padding: var(--s-3) 0;
  border-bottom: var(--rule-hair);
  font-size: var(--t-base);
  color: var(--ink-2);
}
.bring-list li::before {
  content: attr(data-tag);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-4);
  flex: 0 0 4em;
}
.bring-list li.optional::before { color: var(--ink-4); }

/* --- FAQ --- */
.faq {
  display: flex;
  flex-direction: column;
  border-top: var(--rule-hair);
}
.faq-item {
  border-bottom: var(--rule-hair);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-6) 0;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-6);
  font-family: var(--font-serif);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item .toggle {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-3);
  flex: 0 0 auto;
}
.faq-item[open] .toggle::before { content: '−'; }
.faq-item:not([open]) .toggle::before { content: '+'; }
.faq-item .answer {
  padding: 0 0 var(--s-7) 0;
  font-size: var(--t-base);
  color: var(--ink-2);
  max-width: 64ch;
  line-height: 1.6;
}

/* --- Tea section --- */
.tea {
  background: var(--paper-2);
  margin: 0;
}
.tea .container { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr); gap: var(--s-10); align-items: center; }
.tea__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.35;
  color: var(--ink);
  text-wrap: pretty;
  max-width: 30ch;
}
.tea__quote::before {
  content: '“';
  font-size: 2em;
  line-height: 0;
  vertical-align: -0.3em;
  margin-right: 0.05em;
  color: var(--ink-3);
}
.tea__image {
  width: 100%;
  aspect-ratio: 5 / 4;
  background: var(--paper-3);
  border: var(--rule-hair);
  overflow: hidden;
}

/* --- Join CTA panel --- */
.join {
  background: var(--ink);
  color: var(--paper);
  padding: var(--s-11) 0;
}
.join .container { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--s-10); align-items: center; }
.join h2 { color: var(--paper); font-size: clamp(2rem, 4vw, 3.25rem); }
.join .section__index { color: var(--paper-3); }
.join .section__index::before { background: var(--paper-3); }
.join__actions {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.join__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-5);
  align-items: baseline;
  padding: var(--s-5) 0;
  border-top: 1px solid rgba(255,255,255,0.18);
  font-size: var(--t-base);
}
.join__row:last-child { border-bottom: 1px solid rgba(255,255,255,0.18); }
.join__row .label { color: rgba(255,255,255,0.55); font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.08em; text-transform: uppercase; }
.join__row a {
  color: var(--paper);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0.4);
  padding-bottom: 1px;
}
.join__row a:hover { border-color: var(--paper); }

/* Left intro column */
.join__lead {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.2rem, 1.7vw, 1.5rem);
  line-height: 1.4;
  color: rgba(255,255,255,0.72);
  max-width: 30ch;
  margin-top: var(--s-6);
}
/* Ruled Telegram link row with long arrow */
.join__telegram {
  margin-top: var(--s-9);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-6);
  padding: var(--s-5) 0;
  border-top: 1px solid rgba(255,255,255,0.18);
  border-bottom: 1px solid rgba(255,255,255,0.18);
  color: var(--paper);
  text-decoration: none;
}
.join__telegram-label {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.join__telegram-handle {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 2.4vw, 1.95rem);
  letter-spacing: -0.01em;
  color: var(--paper);
}
.join__telegram-arrow {
  font-family: var(--font-serif);
  font-size: 1.7rem;
  line-height: 1;
  color: var(--paper);
  transition: transform var(--dur-fast) var(--ease);
}
.join__telegram:hover .join__telegram-arrow { transform: translateX(8px); }

/* QR card (right column) */
.qr-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  background: var(--card);
  padding: var(--s-8);
  color: var(--ink);
  text-decoration: none;
  border: 0;
  justify-self: stretch;
}
.qr-card::before,
.qr-card::after {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  border: 1.5px solid var(--ink-rule-strong);
  pointer-events: none;
}
.qr-card::before { top: 12px; left: 12px; border-right: 0; border-bottom: 0; }
.qr-card::after  { bottom: 12px; right: 12px; border-left: 0; border-top: 0; }
.qr-card__head,
.qr-card__foot {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-5);
}
.qr-card__head { border-bottom: 1px solid var(--ink-rule); padding-bottom: var(--s-4); }
.qr-card__foot { border-top: 1px solid var(--ink-rule); padding-top: var(--s-4); }
.qr-card__brand {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--ink);
}
.qr-card__tag,
.qr-card__url {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
}
.qr-card__code { display: block; background: #fff; }
.qr-card__code img { display: block; width: 100%; height: auto; }
.qr-card__hint {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--t-sm);
  color: var(--ink-3);
}

/* Event card: stacked actions (RSVP + calendar) */
.event-card__actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--s-3);
  text-align: right;
}
.event-card__ical {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  border-bottom: 1px solid var(--ink-rule);
  padding-bottom: 1px;
  text-decoration: none;
}
.event-card__ical:hover { color: var(--ink); border-color: var(--ink); }

/* --- Footer --- */
.site-footer {
  padding: var(--s-9) 0 var(--s-7) 0;
  border-top: var(--rule-hair);
  background: var(--paper);
}
.site-footer .container {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--s-6);
  align-items: end;
}
.site-footer__brand {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--ink);
}
.site-footer__meta {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
  text-align: right;
}
.site-footer__legal {
  margin-top: var(--s-6);
  border-top: var(--rule-hair);
  padding-top: var(--s-4);
  font-size: var(--t-xs);
  color: var(--ink-4);
  display: flex;
  justify-content: space-between;
  gap: var(--s-5);
}

/* --- Marginalia (small "field note" annotations) --- */
.margin-note {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--t-sm);
  color: var(--ink-3);
  line-height: 1.4;
  border-left: 1px solid var(--ink-rule-strong);
  padding-left: var(--s-4);
  margin-top: var(--s-6);
  max-width: 30ch;
}

/* --- Responsive --- */
@media (max-width: 880px) {
  :root { --content-max: 700px; }
  .site-nav__links { display: none; }
  .hero { padding-top: var(--s-7); padding-bottom: var(--s-9); }
  .hero__grid { grid-template-columns: 1fr; gap: var(--s-9); }
  .hero__title { font-size: clamp(2.75rem, 12vw, 4rem); }
  .hero__image { aspect-ratio: 4 / 3; }
  .section { padding-block: var(--s-9); }
  .cols, .cols--reverse { grid-template-columns: 1fr; gap: var(--s-7); }
  .cols__head { position: static; }
  .tea .container { grid-template-columns: 1fr; gap: var(--s-7); }
  .join .container { grid-template-columns: 1fr; gap: var(--s-7); }
  .site-footer .container { grid-template-columns: 1fr; }
  .site-footer__meta { text-align: left; }
  .bring-list { grid-template-columns: 1fr; }
  .event-card { padding: var(--s-6); }
  .event-card__rows { grid-template-columns: 5em 1fr; }
  .practice-list li { grid-template-columns: 2em 1fr; gap: var(--s-3); }
}

@media (max-width: 480px) {
  .hero__cta-row { flex-direction: column; align-items: flex-start; gap: var(--s-4); }
  .site-footer__legal { flex-direction: column; gap: var(--s-2); }
}
