/* Trash Talk Tour — Coming Soon
   Scoped under .tt-root so tokens never leak into the rest of the site. */

.tt-root {
  /* Brand palette */
  --tt-green-deep: #0D8346;
  --tt-green-deep-2: #0a6b3a;
  --tt-green-deep-3: #084d2a;
  --tt-green: #37B649;
  --tt-green-2: #2c9c3c;
  --tt-yellow: #EBCB1D;
  --tt-yellow-2: #d4b30f;

  /* Warm neutrals */
  --tt-cream:  #FBF7E8;
  --tt-cream-2: #f3edd1;
  --tt-paper:  #FFFCF1;
  --tt-ink:    #15281a;
  --tt-ink-2:  #324236;
  --tt-ink-3:  #5a6a5e;
  --tt-line:   #d8d2b8;
  --tt-line-2: #e9e3c6;

  /* Type families */
  --tt-font-display: "Poppins", system-ui, sans-serif;
  --tt-font-sans:    "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --tt-font-mono:    "JetBrains Mono", ui-monospace, Menlo, monospace;

  /* Motion */
  --tt-ease-out: cubic-bezier(0.2, 0.8, 0.2, 1);

  font-family: var(--tt-font-sans);
  background: var(--tt-green-deep);
  color: var(--tt-cream);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.tt-root *, .tt-root *::before, .tt-root *::after { box-sizing: border-box; }
.tt-root h1, .tt-root h2, .tt-root h3 {
  margin: 0;
  font-family: var(--tt-font-display);
}
.tt-root p { margin: 0; line-height: 1.6; }
.tt-root a { color: inherit; }
.tt-root img { max-width: 100%; display: block; }

/* Layout */
.tt-page {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.tt-container {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) {
  .tt-container { padding: 0 20px; }
}

.tt-topbar {
  position: relative;
  z-index: 2;
}
.tt-topbar-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 96px; padding-top: 16px;
}
.tt-logo-chip {
  background: var(--tt-cream);
  border-radius: 14px;
  padding: 10px 16px;
  box-shadow: 0 1px 2px rgba(20,40,26,0.07), 0 1px 3px rgba(20,40,26,0.05);
  display: inline-flex; align-items: center;
}
.tt-logo-chip img { height: 68px; width: auto; }

/* Decorative background shapes */
.tt-bg-circle, .tt-bg-star {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
.tt-bg-circle {
  top: -15%; right: -10%;
  width: 55vw; max-width: 700px;
  opacity: 0.08;
}
.tt-bg-star {
  bottom: -20%; left: -15%;
  width: 50vw; max-width: 600px;
  opacity: 0.06;
}

/* Hero */
.tt-hero {
  flex: 1;
  position: relative; z-index: 2;
  padding: clamp(40px, 6vw, 80px) 32px clamp(60px, 8vw, 120px);
}
.tt-hero-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 880px) {
  .tt-hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .tt-hero-right { align-items: center !important; }
}

.tt-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--tt-font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tt-yellow);
  font-weight: 600;
  margin-bottom: 28px;
}
.tt-pulse-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--tt-yellow);
  box-shadow: 0 0 0 4px rgba(235,203,29,0.25);
  animation: tt-pulse 1.8s ease-in-out infinite;
}
@keyframes tt-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(235,203,29,0.25); }
  50%      { box-shadow: 0 0 0 8px rgba(235,203,29,0); }
}

.tt-headline {
  font-weight: 900;
  font-size: clamp(44px, 6.4vw, 104px);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--tt-cream);
  margin-bottom: 28px;
}
.tt-accent-yellow { color: var(--tt-yellow); }

.tt-root .tt-lede {
  font-size: 19px;
  line-height: 1.55;
  color: rgba(251,247,232,0.85);
  max-width: 44ch;
  margin-bottom: 72px;
}

.tt-finep {
  margin-top: 22px;
  font-family: var(--tt-font-mono);
  font-size: 12px;
  color: rgba(251,247,232,0.55);
  display: flex; gap: 18px; flex-wrap: wrap;
}

.tt-hero-right {
  display: flex; flex-direction: column;
  gap: 40px;
  align-items: flex-start;
}

/* Date stamp — rotated yellow tag with ink shadow */
.tt-date-stamp {
  display: inline-flex; align-items: stretch;
  background: var(--tt-yellow);
  color: var(--tt-ink);
  border-radius: 18px;
  border: 3px solid var(--tt-ink);
  overflow: hidden;
  font-family: var(--tt-font-display);
  font-weight: 900;
  transform: rotate(-2deg);
  box-shadow: 8px 8px 0 var(--tt-green-deep);
}
.tt-date-stamp-left,
.tt-date-stamp-right {
  padding: 10px 18px;
  display: flex; flex-direction: column;
  justify-content: center;
  line-height: 1.1;
}
.tt-date-stamp-left {
  align-items: center;
  border-right: 3px solid var(--tt-ink);
  line-height: 1;
}
.tt-date-stamp-label {
  font-family: var(--tt-font-mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.16em;
  margin-bottom: 4px;
}
.tt-date-stamp-day {
  font-size: 44px;
  letter-spacing: -0.04em;
}
.tt-date-stamp-day-dash { font-size: 22px; }
.tt-date-stamp-year { font-size: 22px; letter-spacing: -0.02em; }
.tt-date-stamp-when {
  font-family: var(--tt-font-mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.16em;
  margin-top: 4px;
}

/* Countdown */
.tt-countdown { width: 100%; }
.tt-countdown-label {
  font-family: var(--tt-font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(251,247,232,0.7);
  font-weight: 600;
  margin-bottom: 14px;
}
.tt-countdown-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  max-width: 520px;
}
.tt-countdown-cell {
  background: rgba(251,247,232,0.08);
  border: 1px solid rgba(251,247,232,0.18);
  border-radius: 14px;
  padding: 16px 8px;
  text-align: center;
}
.tt-countdown-num {
  font-family: var(--tt-font-display);
  font-weight: 900;
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--tt-yellow);
  font-variant-numeric: tabular-nums;
}
.tt-countdown-unit {
  font-family: var(--tt-font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(251,247,232,0.7);
  margin-top: 8px;
}

/* Signup form — paper card with deep-green pill button */
.tt-signup {
  background: var(--tt-paper);
  color: var(--tt-ink);
  border-radius: 18px;
  padding: 22px 22px 18px;
  display: grid; gap: 14px;
  max-width: 560px;
  box-shadow: 0 6px 18px rgba(20,40,26,0.10), 0 2px 6px rgba(20,40,26,0.05);
}
.tt-signup label {
  display: block;
  font-family: var(--tt-font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--tt-ink-3);
  margin-bottom: 6px;
}
.tt-signup input[type="text"]:not([style*="display:none"]),
.tt-signup input[type="email"] {
  width: 100%;
  font-family: var(--tt-font-sans);
  font-size: 16px;
  color: var(--tt-ink);
  background: var(--tt-cream);
  border: 1px solid var(--tt-line);
  border-radius: 10px;
  padding: 12px 14px;
  outline: none;
  transition: border-color 200ms var(--tt-ease-out), box-shadow 200ms var(--tt-ease-out);
}
.tt-signup input[type="text"]:not([style*="display:none"]):focus,
.tt-signup input[type="email"]:focus {
  border-color: var(--tt-green-deep);
  box-shadow: 0 0 0 3px rgba(13,131,70,0.15);
}
.tt-signup .tt-signup-actions {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; flex-wrap: wrap;
}
.tt-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--tt-font-sans);
  font-weight: 700;
  font-size: 16px;
  padding: 14px 22px;
  border-radius: 999px;
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform 120ms var(--tt-ease-out), background 200ms var(--tt-ease-out);
}
.tt-btn:active { transform: scale(0.98); }
.tt-btn-primary {
  background: var(--tt-green-deep);
  color: var(--tt-cream);
}
.tt-btn-primary:hover { background: var(--tt-green-deep-2); color: var(--tt-cream); }
.tt-signup-error {
  background: rgba(220,38,38,0.08);
  border: 1px solid rgba(220,38,38,0.25);
  color: #991b1b;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 14px;
}

/* Signup success card */
.tt-signup-success {
  background: var(--tt-yellow);
  border-radius: 18px;
  padding: 28px;
  display: flex; align-items: center; gap: 18px;
  max-width: 560px;
  box-shadow: 0 6px 18px rgba(20,40,26,0.10), 0 2px 6px rgba(20,40,26,0.05);
}
.tt-signup-success-check {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--tt-green-deep);
  display: flex; align-items: center; justify-content: center;
  color: var(--tt-cream); flex-shrink: 0;
}
.tt-signup-success-title {
  font-family: var(--tt-font-display);
  font-weight: 800;
  font-size: 19px;
  color: var(--tt-ink);
  margin-bottom: 4px;
}
.tt-signup-success-body { font-size: 14px; color: var(--tt-ink-2); }

/* Marquee — yellow strip with star separators */
.tt-marquee {
  background: var(--tt-yellow);
  color: var(--tt-ink);
  border-top: 2px solid var(--tt-yellow-2);
  border-bottom: 2px solid var(--tt-yellow-2);
  overflow: hidden;
  padding: 14px 0;
  white-space: nowrap;
  position: relative;
  z-index: 2;
}
.tt-marquee-track {
  display: inline-flex; align-items: center; gap: 32px;
  animation: tt-marquee 36s linear infinite;
}
.tt-marquee-item {
  font-family: var(--tt-font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.tt-marquee-star { flex-shrink: 0; }
@keyframes tt-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-33.333%); }
}

/* Footer */
.tt-footer {
  background: var(--tt-green-deep-3);
  color: rgba(251,247,232,0.6);
  padding: 20px 0;
  font-family: var(--tt-font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  position: relative; z-index: 2;
}
.tt-footer-inner {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
}
.tt-footer a { text-decoration: none; }

/* Flash */
.tt-flash {
  background: var(--tt-cream);
  color: var(--tt-ink);
  border-radius: 14px;
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 14px;
  box-shadow: 0 1px 2px rgba(20,40,26,0.07);
}

@media (max-width: 560px) {
  .tt-signup-actions { flex-direction: column; align-items: stretch; }
  .tt-btn-primary { justify-content: center; }
}
