/* Gogo Originals — main theme styles */

:root {
  --color-bg: #FBF8F3;
  --color-bg-soft: #F5EFE3;
  --color-bg-warm: #EFE4D0;
  --color-cream: #FFF9EE;
  --color-ink: #1F1A15;
  --color-ink-soft: #6E6356;
  --color-ink-faint: #A89B89;
  --color-border: #E6DDCC;
  --color-orange: #E85D2A;
  --color-orange-soft: #FF7B3D;
  --color-orange-deep: #C84A1B;
  --color-orange-tint: #FFE9DC;
  --font-serif: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --font-sans: "Inter", system-ui, -apple-system, sans-serif;
  --font-script: "Caveat", "Kalam", cursive;
}

html, body {
  background: var(--color-bg);
  color: var(--color-ink);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
}
body { position: relative; }

h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 400;
  letter-spacing: -0.015em;
}

.serif { font-family: var(--font-serif); }
.script { font-family: var(--font-script); }
.orange { color: var(--color-orange); }

.kicker {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}

.stitch { position: relative; display: inline-block; }
.stitch::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.18em;
  height: 2px;
  background-image: linear-gradient(to right, var(--color-orange) 0 10px, transparent 10px 16px);
  background-size: 16px 2px;
  background-repeat: repeat-x;
}

.btn-orange {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  background: var(--color-orange);
  color: white;
  padding: 0.95rem 1.8rem;
  border-radius: 9999px;
  font-weight: 500;
  font-size: 0.95rem;
  text-decoration: none;
  transition: transform .2s ease, background .2s ease;
}
.btn-orange:hover { background: var(--color-orange-deep); transform: translateY(-1px); color: white; }

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  background: transparent;
  color: var(--color-ink);
  padding: 0.9rem 1.6rem;
  border-radius: 9999px;
  border: 1.5px solid var(--color-ink);
  font-weight: 500;
  font-size: 0.95rem;
  text-decoration: none;
  transition: background .2s ease, color .2s ease;
}
.btn-outline:hover { background: var(--color-ink); color: var(--color-bg); }

.card-hover { transition: transform .35s ease, box-shadow .35s ease; }
.card-hover:hover { transform: translateY(-6px); box-shadow: 0 28px 56px -28px rgba(31,26,21,0.2); }

.one-of-one {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--color-orange);
}

.tag-orange {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--color-orange);
  color: white;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
}

/* Make sure images render above the scroll thread so it visually
   passes behind every photo on the page. */
main img, main picture { position: relative; z-index: 2; }

/* SCROLL THREAD ANIMATION — flowey multi-frequency sine wave down the
   whole page. Multiply blend + low z-index keeps it behind imagery. */
.scroll-thread {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
  clip-path: inset(0 0 var(--thread-cutoff, 100%) 0);
  mix-blend-mode: multiply;
  will-change: clip-path;
}
.scroll-thread svg { position: absolute; top: 0; left: 0; display: block; }
.scroll-thread svg path {
  fill: none;
  stroke: #E85D2A;
  stroke-width: 2.6;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 11 8;
  opacity: 0.9;
  animation: thread-flow 1.8s linear infinite;
}
.scroll-thread svg .knot { fill: #E85D2A; stroke: none; opacity: 0.9; }
.scroll-thread .needle {
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 9999px;
  background: var(--color-orange);
  box-shadow: 0 0 0 3px rgba(232,93,42,0.18), 0 0 14px 2px rgba(232,93,42,0.55);
  left: var(--needle-x, 50%);
  top: var(--needle-y, 0px);
  transform: translate(-50%, -50%);
  transition: top 30ms linear;
  opacity: var(--needle-opacity, 0);
  mix-blend-mode: normal;
}
@keyframes thread-flow { to { stroke-dashoffset: -19; } }

/* Language toggle */
.lang-toggle { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-sans); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; }
.lang-btn { background: none; border: none; padding: 0.2rem 0.1rem; color: var(--color-ink-soft); cursor: pointer; font: inherit; letter-spacing: inherit; text-transform: inherit; transition: color 0.15s ease; }
.lang-btn:hover { color: var(--color-orange); }
.lang-btn.is-active { color: var(--color-ink); font-weight: 600; }
.lang-sep { color: var(--color-ink-faint); opacity: 0.5; }
.lang-dialog { border: none; padding: 0; background: transparent; max-width: 28rem; width: calc(100% - 2rem); border-radius: 1rem; margin: auto; inset: 0; }
.lang-dialog::backdrop { background: rgba(31,26,21,0.45); backdrop-filter: blur(2px); }
.lang-dialog[open] .lang-dialog__inner { background: var(--color-bg); padding: 1.75rem 1.5rem; border-radius: 1rem; border: 1px solid var(--color-border); box-shadow: 0 30px 60px -20px rgba(31,26,21,0.3); position: relative; }
.lang-dialog[open] .lang-dialog__inner::before { content: ""; position: absolute; top: 0; left: 1.5rem; right: 1.5rem; height: 2px; background-image: linear-gradient(to right, var(--color-orange) 0 10px, transparent 10px 16px); background-size: 16px 2px; background-repeat: repeat-x; }
