/* Mycelia — shared styles */

:root {
  --earth: #524d40;
  --earth-2: #3d3a30;
  --earth-soft: #6b6452;
  --orange: #eb6e24;
  --orange-deep: #d05d18;
  --green: #639647;
  --green-deep: #4f7a39;
  --blue: #5787a1;
  --cream: #f1ebde;
  --cream-warm: #ece4d2;
  --cream-card: #fbf7ec;
  --ink: #2a2620;
  --muted: #6b6557;
  --line: rgba(82, 77, 64, 0.16);

  --font-serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

* { -webkit-font-smoothing: antialiased; }

html, body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
}

.font-serif { font-family: var(--font-serif); font-weight: 500; letter-spacing: -0.01em; }
.font-display { font-family: var(--font-serif); font-weight: 500; letter-spacing: -0.02em; line-height: 1; }

.eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--orange);
}

.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.85rem 1.25rem; border-radius: 999px;
  font-weight: 500; font-size: 0.95rem;
  transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
  border: 1px solid transparent;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--green); color: #fff; }
.btn-primary:hover { background: var(--green-deep); }
.btn-ghost { background: transparent; color: var(--earth); border-color: var(--line); }
.btn-ghost:hover { background: rgba(82, 77, 64, 0.05); }

/* Store badges — custom, brand-aware versions */
.store-badge {
  display: inline-flex; align-items: center; gap: 0.7rem;
  padding: 0.7rem 1.1rem 0.7rem 1rem;
  background: #111;
  color: #fff;
  border-radius: 14px;
  border: 1px solid #1a1a1a;
  transition: transform 0.15s ease, background 0.2s ease;
  min-width: 168px;
}
.store-badge:hover { transform: translateY(-1px); background: #1a1a1a; }
.store-badge .small { font-size: 10px; opacity: 0.8; letter-spacing: 0.04em; line-height: 1; margin-bottom: 3px; }
.store-badge .big { font-family: var(--font-sans); font-size: 17px; font-weight: 600; letter-spacing: -0.01em; line-height: 1; }
.store-badge svg { width: 26px; height: 26px; flex-shrink: 0; }

/* Mycelium network decoration */
.myc-net { opacity: 0.5; pointer-events: none; }
.myc-net path { stroke: var(--earth); stroke-width: 1.2; fill: none; stroke-linecap: round; }
.myc-net circle { fill: var(--earth); }

/* Feature card */
.feature-card {
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 2rem 1.75rem;
  position: relative;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.feature-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 40px -28px rgba(82, 77, 64, 0.35);
  border-color: rgba(235, 110, 36, 0.35);
}
.feature-icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: rgba(235, 110, 36, 0.12);
  color: var(--orange);
  display: grid; place-items: center;
  margin-bottom: 1.25rem;
}
.feature-num {
  position: absolute; top: 1.25rem; right: 1.5rem;
  font-family: var(--font-serif); font-size: 1.25rem; color: var(--muted);
  font-style: italic;
}

/* Real iPhone bezel — concentric corners via H/V radius syntax.
   Screen crops are 480x1046 with a 77px screen corner radius.
   Bezel adds 12px padding → 504x1070 outer, outer radius ~89px to stay concentric:
   horizontal % = 89/504 = 17.66%, vertical % = 89/1070 = 8.32% */
.phone-mock {
  display: inline-block;
  position: relative;
  padding: 12px;
  background: #0a0a0a;
  border-radius: 17.66% / 8.32%;
  box-shadow:
    0 50px 100px -30px rgba(20, 15, 5, 0.5),
    0 25px 50px -20px rgba(20, 15, 5, 0.4),
    0 0 0 0.5px rgba(255, 255, 255, 0.08),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
  transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.phone-mock::before {
  /* subtle edge highlight along top — like glass meeting metal */
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.10) 0%, transparent 2%, transparent 98%, rgba(255, 255, 255, 0.05) 100%);
  pointer-events: none;
}
.phone-mock .phone-screen {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
}
/* Side buttons — proper stainless / titanium look */
.phone-mock .btn-power, .phone-mock .btn-vol {
  position: absolute;
  width: 3px;
  border-radius: 2px;
  background: linear-gradient(to right, #2a2a2a 0%, #0a0a0a 50%, #1a1a1a 100%);
  z-index: 0;
}
.phone-mock .btn-power { right: -2px; top: 23%; height: 13%; }
.phone-mock .btn-vol { left: -2px; background: linear-gradient(to left, #2a2a2a 0%, #0a0a0a 50%, #1a1a1a 100%); }
.phone-mock .btn-vol.v1 { top: 10%; height: 3.5%; }
.phone-mock .btn-vol.v2 { top: 17%; height: 8%; }
.phone-mock .btn-vol.v3 { top: 27%; height: 8%; }

/* Angled presentations */
.phone-tilt-hero {
  transform: perspective(2000px) rotateY(-10deg) rotateX(4deg) rotateZ(-1.5deg);
}
.phone-tilt-hero:hover {
  transform: perspective(2000px) rotateY(-4deg) rotateX(1deg) rotateZ(0deg) translateY(-6px);
}
.phone-tilt-left {
  transform: perspective(1800px) rotateY(16deg) rotateZ(-5deg);
}
.phone-tilt-right {
  transform: perspective(1800px) rotateY(-16deg) rotateZ(5deg);
}
.phone-tilt-left:hover, .phone-tilt-right:hover {
  transform: perspective(1800px) rotateY(0deg) rotateZ(0deg) translateY(-6px);
}

/* Soft floating animation on the hero phone */
@keyframes float-soft {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
.float-soft { animation: float-soft 6s ease-in-out infinite; }

/* Drifting network animation */
@keyframes drift {
  0% { transform: translate(0, 0); }
  50% { transform: translate(8px, -6px); }
  100% { transform: translate(0, 0); }
}
.drift-1 { animation: drift 14s ease-in-out infinite; }
.drift-2 { animation: drift 18s ease-in-out infinite reverse; }

/* Nav */
.nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  background: rgba(241, 235, 222, 0.78);
  border-bottom: 1px solid var(--line);
}

/* Footer */
.footer { background: var(--earth); color: var(--cream); }
.footer a { color: rgba(241, 235, 222, 0.78); }
.footer a:hover { color: #fff; }

/* CTA band — orange */
.cta-band {
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-deep) 100%);
  color: #fff;
  border-radius: 32px;
  overflow: hidden;
  position: relative;
}
.cta-band .store-badge { background: rgba(0,0,0,0.85); border-color: rgba(0,0,0,0.2); }
.cta-band .store-badge:hover { background: #000; }

/* Policy page typography */
.prose-policy h1 { font-family: var(--font-serif); font-size: clamp(2.4rem, 5vw, 3.5rem); font-weight: 500; letter-spacing: -0.02em; line-height: 1.05; }
.prose-policy h2 { font-family: var(--font-serif); font-size: 1.65rem; font-weight: 500; margin-top: 2.5rem; margin-bottom: 0.75rem; color: var(--earth); }
.prose-policy h3 { font-family: var(--font-sans); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--orange); margin-top: 2rem; margin-bottom: 0.5rem; font-weight: 600; }
.prose-policy p { color: var(--ink); margin-bottom: 1rem; max-width: 65ch; }
.prose-policy ul { margin: 0.75rem 0 1.25rem 1.25rem; }
.prose-policy ul li { margin-bottom: 0.4rem; color: var(--ink); list-style: disc; }
.prose-policy a { color: var(--orange); text-decoration: underline; text-underline-offset: 3px; }
.prose-policy hr { border: 0; border-top: 1px solid var(--line); margin: 2.5rem 0; }
.prose-policy .meta { color: var(--muted); font-size: 0.9rem; }

/* Small details */
.dot-divider::before { content: "·"; margin: 0 0.5rem; color: var(--muted); }
