/* ==========================================================================
   ROWA STUDIO — egendefinert lag (det Tailwind ikke dekker)
   Brandfarger/fonter settes i Tailwind-konfigen i <head> på hver side.
   ========================================================================== */

html { scroll-behavior: smooth; }
h1, h2, h3, h4 { letter-spacing: 0.005em; }

/* ---------- Logo: la kremfargen smelte inn i lyse flater ---------- */
.logo-blend { mix-blend-mode: multiply; }

/* ==========================================================================
   Gjenbrukbare komponent-klasser
   ========================================================================== */
.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  border-radius: 9999px; background: #8A5A44; padding: .875rem 1.75rem;
  font-size: .875rem; font-weight: 600; letter-spacing: .02em; color: #FAF7F1;
  box-shadow: 0 14px 28px -16px rgba(138,90,68,.8);
  transition: background .3s ease, transform .3s ease; cursor: pointer; border: 0;
}
.btn-primary:hover { background: #6f4634; transform: translateY(-2px); }

.btn-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  border-radius: 9999px; border: 1px solid rgba(138,90,68,.55); padding: .875rem 1.75rem;
  font-size: .875rem; font-weight: 600; letter-spacing: .02em; color: #8A5A44;
  background: transparent; transition: all .3s ease; cursor: pointer;
}
.btn-ghost:hover { background: #8A5A44; color: #FAF7F1; transform: translateY(-2px); }

.btn-soldout {
  display: inline-flex; align-items: center; justify-content: center; width: 100%;
  border-radius: 9999px; border: 1px solid rgba(46,33,27,.15); padding: .875rem 1.75rem;
  font-size: .875rem; font-weight: 600; letter-spacing: .02em; color: rgba(46,33,27,.4);
  background: transparent; cursor: not-allowed;
}

.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .72rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .24em; color: #8A5A44;
}
.nav-link {
  position: relative; font-size: .9rem; font-weight: 500;
  color: rgba(46,33,27,.75); transition: color .2s ease;
}
.nav-link:hover, .nav-link[aria-current="page"] { color: #2E211B; }
.nav-link[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; bottom: -6px;
  width: 100%; height: 1.5px; background: #8A5A44;
}
.divider { display: flex; align-items: center; justify-content: center; gap: .75rem; color: #8A5A44; }
.divider::before, .divider::after { content: ""; height: 1px; width: 2.5rem; background: rgba(138,90,68,.35); }

/* ==========================================================================
   Handlekurv
   ========================================================================== */
.cart-link { position: relative; display: inline-grid; place-items: center; color: #2E211B; transition: color .2s ease; }
.cart-link:hover { color: #8A5A44; }
.cart-badge {
  position: absolute; top: -7px; right: -9px; min-width: 18px; height: 18px;
  padding: 0 4px; border-radius: 9999px; background: #8A5A44; color: #FAF7F1;
  font-size: 11px; font-weight: 600; display: grid; place-items: center;
  line-height: 1; transform: scale(0); transition: transform .25s ease;
}
.cart-badge.show { transform: scale(1); }
.cart-badge.bump { animation: badge-bump .4s ease; }
@keyframes badge-bump { 0%,100%{ transform: scale(1);} 40%{ transform: scale(1.35);} }

.qty {
  display: inline-flex; align-items: center; gap: .25rem;
  border: 1px solid rgba(46,33,27,.15); border-radius: 9999px; padding: 2px;
}
.qty button {
  width: 30px; height: 30px; border-radius: 9999px; border: 0; background: transparent;
  color: #8A5A44; font-size: 1.1rem; cursor: pointer; line-height: 1;
  transition: background .2s ease;
}
.qty button:hover { background: rgba(138,90,68,.12); }
.qty span { min-width: 24px; text-align: center; font-weight: 600; font-size: .95rem; }

/* ==========================================================================
   Papirkorn-tekstur
   ========================================================================== */
.grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 9999;
  opacity: 0.05; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Spire-ikon ---------- */
.sprout {
  display: inline-block; width: 14px; height: 14px; background-color: currentColor;
  -webkit-mask: var(--sprout-svg) center / contain no-repeat;
  mask: var(--sprout-svg) center / contain no-repeat;
  --sprout-svg: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 22V11' stroke='%23000' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3Cpath d='M12 13C7 12 4 14 4.5 18C9 18.5 12 16 12 13Z'/%3E%3Cpath d='M12.5 9C17 7.5 20 9.5 19.5 13.5C15 14 12 12 12.5 9Z'/%3E%3C/svg%3E");
}
.sprout-lg { width: 26px; height: 26px; }

/* ==========================================================================
   Roterende håndverks-segl
   ========================================================================== */
.seal-text { font-family: "Inter", sans-serif; font-size: 13px; font-weight: 600; letter-spacing: 3.5px; text-transform: uppercase; }
.seal-ring { transform-box: fill-box; transform-origin: center; animation: seal-spin 32s linear infinite; }
@keyframes seal-spin { to { transform: rotate(360deg); } }

/* ==========================================================================
   Marquee
   ========================================================================== */
.marquee { overflow: hidden; }
.marquee-track { display: inline-flex; align-items: center; gap: 2.75rem; white-space: nowrap; animation: marquee 34s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Flyt-animasjon ---------- */
.float { animation: float 13s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }

/* ==========================================================================
   Scroll-reveal
   ========================================================================== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
.reveal[data-delay="1"] { transition-delay: .1s; }
.reveal[data-delay="2"] { transition-delay: .2s; }
.reveal[data-delay="3"] { transition-delay: .3s; }
.reveal[data-delay="4"] { transition-delay: .4s; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Fokus ---------- */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
  outline: 2px solid #8A5A44; outline-offset: 3px; border-radius: 4px;
}

/* ==========================================================================
   Redusert bevegelse
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important; animation-iteration-count: 1 !important;
    transition-duration: .001ms !important; scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
}
