/* =============================================================================
 * theme.css — Love Compatibility funnel — "love-coded" mystical theme
 * Deep aubergine/indigo base, rose-gold + champagne accents, soft glow.
 * Mobile-first, single-column, fast. Self-contained (system + 2 webfonts).
 * ===========================================================================*/

:root {
  --bg-0:        #0d0a1a;   /* near-black indigo */
  --bg-1:        #1a1130;   /* deep aubergine */
  --bg-2:        #2a1844;   /* raised panel */
  --rose:        #e7a6b8;   /* rose-gold tint */
  --rose-strong: #d97c95;
  --gold:        #e9c98c;   /* champagne gold */
  --gold-strong: #f4d9a0;
  --ink:         #f5eef7;   /* primary text */
  --ink-soft:    #c9bcd8;   /* secondary text */
  --ink-faint:   #9a89b4;
  --line:        rgba(233, 201, 140, 0.18);
  --glow-rose:   rgba(217, 124, 149, 0.45);
  --glow-gold:   rgba(244, 217, 160, 0.35);
  --radius:      18px;
  --maxw:        560px;     /* mobile-first reading column */
  --font-head:   "Cinzel", "Marcellus", Georgia, serif;
  --font-body:   "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
:root { --ink-faint: #9a89b4; }

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(217,124,149,0.18), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(124,92,196,0.16), transparent 55%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg-0) 100%);
  background-attachment: fixed;
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}

/* starfield overlay (cheap, GPU-friendly) */
.stars {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,0.7), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1.5px 1.5px at 40% 80%, rgba(244,217,160,0.6), transparent),
    radial-gradient(1px 1px at 85% 25%, rgba(255,255,255,0.6), transparent),
    radial-gradient(1px 1px at 12% 70%, rgba(231,166,184,0.6), transparent);
  background-repeat: repeat;
  opacity: 0.5;
  animation: twinkle 6s ease-in-out infinite alternate;
}
@keyframes twinkle { from { opacity: 0.35; } to { opacity: 0.6; } }

.wrap { position: relative; z-index: 1; max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }
.wrap-wide { max-width: 720px; }

h1, h2, h3 { font-family: var(--font-head); font-weight: 600; line-height: 1.2; letter-spacing: 0.3px; }
h1 { font-size: clamp(1.9rem, 6vw, 2.8rem); }
h2 { font-size: clamp(1.4rem, 5vw, 2rem); }
.serif { font-family: var(--font-head); }

/* gradient/glow text accents */
.glow-text {
  background: linear-gradient(90deg, var(--gold-strong), var(--rose), var(--gold-strong));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 26px var(--glow-gold);
}
.rose { color: var(--rose); }
.gold { color: var(--gold); }
.soft { color: var(--ink-soft); }
.faint { color: var(--ink-faint); }
.center { text-align: center; }

/* --- panels / cards --- */
.card {
  background: linear-gradient(180deg, rgba(42,24,68,0.85), rgba(26,17,48,0.85));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 26px 22px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter: blur(6px);
}
.divider { height: 1px; background: linear-gradient(90deg, transparent, var(--line), transparent); margin: 28px 0; border: 0; }

/* Raster product mockups shot on near-black: mix-blend-mode:screen drops the
   dark background into the dark page (no transparency editing needed). If a
   faint box ever shows, switch 'screen' to 'lighten'. */
.mockup-img { display:block; width:100%; max-width:560px; height:auto; margin:0 auto; mix-blend-mode:screen; }

/* --- form --- */
.field { margin: 0 0 18px; }
.field label {
  display: block; font-family: var(--font-head); font-size: 0.95rem;
  color: var(--gold); margin-bottom: 7px; letter-spacing: 0.4px;
}
.field .hint { font-size: 0.8rem; color: var(--ink-faint); margin-top: 4px; }
.input, input[type="text"], input[type="email"], input[type="date"] {
  width: 100%; padding: 14px 16px; font-size: 16px; color: var(--ink);
  background: rgba(13,10,26,0.7); border: 1px solid var(--line);
  border-radius: 12px; font-family: var(--font-body); transition: border-color .2s, box-shadow .2s;
}
.input:focus, input:focus {
  outline: none; border-color: var(--rose-strong);
  box-shadow: 0 0 0 3px rgba(217,124,149,0.18), 0 0 22px var(--glow-rose);
}
input::placeholder { color: var(--ink-faint); }
/* dark date-picker icon */
input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(0.85) sepia(0.4) hue-rotate(300deg); cursor: pointer; }

.partner-row { display: grid; gap: 14px; }
@media (min-width: 480px) { .partner-row { grid-template-columns: 1fr 1fr; } }

.person-tag {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-head);
  font-size: 0.78rem; letter-spacing: 1px; text-transform: uppercase;
  color: var(--rose); margin-bottom: 6px;
}
.person-tag::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--rose-strong); box-shadow: 0 0 10px var(--glow-rose); }
.person-tag.you::before { background: var(--gold); box-shadow: 0 0 10px var(--glow-gold); }

.err { color: #ff9db1; font-size: 0.82rem; margin-top: 6px; display: none; }

/* --- CTA button --- */
.cta {
  display: block; width: 100%; cursor: pointer; border: 0;
  padding: 17px 22px; border-radius: 14px;
  font-family: var(--font-head); font-size: 1.12rem; font-weight: 600; letter-spacing: 0.5px;
  color: #2a0f1c;
  background: linear-gradient(135deg, var(--gold-strong), var(--rose), var(--gold));
  box-shadow: 0 10px 30px var(--glow-rose), 0 0 0 1px rgba(244,217,160,0.4) inset;
  transition: transform .12s ease, box-shadow .2s ease;
  text-align: center; text-decoration: none;
}
.cta:hover { transform: translateY(-2px); box-shadow: 0 16px 44px var(--glow-rose); }
.cta:active { transform: translateY(0); }
.cta-sub { text-align: center; font-size: 0.8rem; color: var(--ink-faint); margin-top: 10px; }

/* heart pulse on CTA */
.cta .heart { display: inline-block; animation: beat 1.4s ease-in-out infinite; }
@keyframes beat { 0%,100%{transform:scale(1);} 15%{transform:scale(1.18);} 30%{transform:scale(1);} 45%{transform:scale(1.12);} }

/* --- trust badges --- */
.trust { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 18px; color: var(--ink-faint); font-size: 0.78rem; }
.trust span { display: inline-flex; align-items: center; gap: 6px; }

/* --- harmony hero (reading page) --- */
.harmony-hero { text-align: center; padding: 10px 0 6px; }
.harmony-ring {
  --size: 210px; width: var(--size); height: var(--size); margin: 6px auto 10px; position: relative;
  border-radius: 50%;
  background:
    radial-gradient(closest-side, var(--bg-1) 78%, transparent 79% 100%),
    conic-gradient(var(--gold-strong) var(--pct, 0%), rgba(255,255,255,0.07) 0);
  display: grid; place-items: center;
  box-shadow: 0 0 50px var(--glow-gold);
}
.harmony-ring .num { font-family: var(--font-head); font-size: 3.2rem; line-height: 1; }
.harmony-ring .pct-label { font-size: 0.8rem; color: var(--ink-soft); letter-spacing: 1px; text-transform: uppercase; }
.harmony-verdict { font-family: var(--font-head); font-size: 1.35rem; }

/* mini matrix grid of paired numbers */
.score-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 18px; }
.score-cell { background: rgba(13,10,26,0.55); border: 1px solid var(--line); border-radius: 12px; padding: 14px; text-align: center; }
.score-cell .v { font-family: var(--font-head); font-size: 1.7rem; color: var(--gold-strong); }
.score-cell .k { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 1px; color: var(--ink-faint); margin-top: 4px; }

/* --- the 22-point Destiny Matrix octagram diagram --- */
.matrix-wrap { width: 100%; margin: 4px auto 0; }
.matrix-wrap svg { width: 100%; height: auto; display: block; overflow: visible; }
.mx-frame { fill: none; stroke: rgba(233,201,140,0.22); stroke-width: 1.2; }
.mx-axis  { fill: none; stroke: rgba(231,166,184,0.22); stroke-width: 1; }
.mx-heart { fill: var(--rose-strong); opacity: 0.28; }

.mx-pt circle { fill: #150e29; stroke-width: 2; }
.mx-pt text {
  font-family: var(--font-head); font-weight: 600; text-anchor: middle;
  dominant-baseline: central; fill: var(--gold-strong);
  opacity: 0; transform: scale(0.4); transform-origin: center; transform-box: fill-box;
  transition: opacity .45s ease, transform .45s cubic-bezier(.2,1.4,.4,1);
}
.matrix-wrap.lit .mx-pt text { opacity: 1; transform: scale(1); }

.mx-big circle { stroke: var(--gold); }
.mx-big text   { font-size: 30px; }
.mx-med circle { stroke: var(--rose); }
.mx-med text   { font-size: 25px; fill: var(--rose); }
.mx-sm  circle { stroke: rgba(233,201,140,0.55); }
.mx-sm  text   { font-size: 21px; }
.mx-center circle {
  fill: #2a1844; stroke: var(--gold-strong); stroke-width: 3;
  filter: drop-shadow(0 0 10px var(--glow-gold));
}
.mx-center text { font-size: 32px; fill: var(--gold-strong); }

.mx-legend { display: flex; justify-content: center; gap: 18px; flex-wrap: wrap; margin-top: 14px; }
.mx-legend span { display: inline-flex; align-items: center; gap: 7px; font-size: 0.74rem; color: var(--ink-faint); }
.mx-legend i { width: 11px; height: 11px; border-radius: 50%; border: 2px solid; display: inline-block; }

/* --- CSS 3D product mockups (no image files needed) --- */
.mk { perspective: 1100px; display: flex; justify-content: center; padding: 18px 0; }
.mk-cover {
  position: relative; width: var(--w, 220px); aspect-ratio: 3 / 4;
  border-radius: 3px 9px 9px 3px;
  background:
    radial-gradient(120% 75% at 72% 8%, rgba(244,217,160,0.28), transparent 60%),
    radial-gradient(90% 60% at 30% 100%, rgba(217,124,149,0.22), transparent 60%),
    linear-gradient(150deg, #2c1a48 0%, #14102b 72%);
  border: 1px solid rgba(233,201,140,0.38);
  box-shadow: 0 34px 64px rgba(0,0,0,0.55), 0 0 54px var(--glow-rose);
  transform: rotateY(-23deg) rotateX(3deg);
  transform-style: preserve-3d;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 24px 18px; overflow: hidden;
}
/* spine shadow on the left */
.mk-cover::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 16px;
  background: linear-gradient(90deg, rgba(0,0,0,0.5), rgba(255,255,255,0.05));
  border-right: 1px solid rgba(0,0,0,0.45);
}
/* page edges on the right */
.mk-cover::after {
  content: ""; position: absolute; right: -5px; top: 4%; height: 92%; width: 6px;
  background: repeating-linear-gradient(180deg,#e7dcc9,#e7dcc9 1px,#b9ad9b 2px,#b9ad9b 3px);
  border-radius: 0 3px 3px 0; transform: rotateY(34deg); transform-origin: left center;
}
.mk-cover .mk-octa {
  position: absolute; inset: 0; opacity: 0.10; pointer-events: none;
  background:
    radial-gradient(circle at 50% 46%, transparent 30%, rgba(233,201,140,0.5) 31%, transparent 33%),
    conic-gradient(from 0deg at 50% 46%, transparent 0 10%, rgba(231,166,184,0.4) 11% 12%, transparent 13% 35%,
       rgba(231,166,184,0.4) 36% 37%, transparent 38% 60%, rgba(231,166,184,0.4) 61% 62%, transparent 63% 85%,
       rgba(231,166,184,0.4) 86% 87%, transparent 88%);
}
.mk-cover .mk-kicker { font-family: var(--font-head); letter-spacing: 2px; text-transform: uppercase;
  color: var(--rose); font-size: 0.58rem; position: relative; }
.mk-cover .mk-glyph { font-size: 2.5rem; margin: 8px 0 6px; line-height: 1;
  filter: drop-shadow(0 0 12px var(--glow-gold)); position: relative; }
.mk-cover .mk-title { font-family: var(--font-head); color: var(--ink); font-size: 1.02rem;
  line-height: 1.18; position: relative; text-shadow: 0 1px 8px rgba(0,0,0,0.5); }
.mk-cover .mk-foot { font-size: 0.52rem; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--ink-faint); margin-top: 12px; position: relative; }

/* fanned bundle of covers (product + bonuses together) */
.mk-bundle { perspective: 1300px; display: flex; justify-content: center; align-items: center;
  padding: 30px 0 24px; }
.mk-bundle .mk { padding: 0; perspective: none; }
.mk-bundle .mk-cover { width: 150px; margin: 0 -26px; box-shadow: 0 26px 46px rgba(0,0,0,0.55), 0 0 36px var(--glow-rose); }
.mk-bundle .mk:nth-child(1) .mk-cover { transform: rotateY(-24deg) translateY(16px) scale(0.84); }
.mk-bundle .mk:nth-child(2) .mk-cover { transform: rotateY(-18deg) translateY(4px) scale(0.95); z-index: 2; }
.mk-bundle .mk:nth-child(3) .mk-cover { transform: rotateY(-12deg) scale(1.08); z-index: 4; }
.mk-bundle .mk:nth-child(4) .mk-cover { transform: rotateY(-4deg) translateY(12px) scale(0.9); z-index: 3; }
.mk-illus-note { text-align: center; font-size: 0.7rem; color: var(--ink-faint); margin-top: 4px; }

@media (max-width: 480px) {
  .mk-bundle .mk-cover { width: 108px; margin: 0 -22px; }
}

/* --- reading prose --- */
.reading p { color: var(--ink-soft); }
.reading h2 { color: var(--ink); margin-top: 30px; }
.locked {
  position: relative; border-radius: var(--radius); overflow: hidden;
}
.locked .blur { filter: blur(6px); opacity: 0.5; user-select: none; pointer-events: none; }
.locked .lock-overlay {
  position: absolute; inset: 0; display: grid; place-items: center; text-align: center;
  background: linear-gradient(180deg, transparent, rgba(13,10,26,0.95));
}

/* --- value stack / pricing --- */
.stack-item { display: flex; gap: 12px; align-items: flex-start; padding: 12px 0; border-bottom: 1px solid var(--line); }
.stack-item .tick { color: var(--gold-strong); flex: 0 0 auto; }
.stack-item .val { margin-left: auto; color: var(--ink-faint); white-space: nowrap; }
.price-row { display: flex; align-items: baseline; gap: 12px; justify-content: center; margin: 14px 0; }
.price-was { color: var(--ink-faint); text-decoration: line-through; }
.price-now { font-family: var(--font-head); font-size: 2.4rem; color: var(--gold-strong); }

/* --- guarantee badge --- */
.guarantee { text-align: center; border: 1px dashed var(--line); border-radius: var(--radius); padding: 18px; margin-top: 22px; }

/* --- buffer / loader screen --- */
.buffer-screen {
  position: fixed; inset: 0; z-index: 50; display: grid; place-items: center;
  background:
    radial-gradient(800px 500px at 50% 30%, rgba(217,124,149,0.22), transparent 60%),
    linear-gradient(180deg, var(--bg-1), var(--bg-0));
}
.buffer-inner { text-align: center; max-width: 460px; padding: 0 24px; }
.buffer-orbit { width: 130px; height: 130px; margin: 0 auto 26px; position: relative; }
.buffer-orbit .core {
  position: absolute; inset: 36%; border-radius: 50%;
  background: radial-gradient(circle, var(--gold-strong), var(--rose-strong));
  box-shadow: 0 0 40px var(--glow-rose); animation: beat 1.6s ease-in-out infinite;
}
.buffer-orbit .ring1, .buffer-orbit .ring2 {
  position: absolute; inset: 0; border-radius: 50%; border: 1px solid var(--line);
  border-top-color: var(--gold-strong); animation: spin 2.4s linear infinite;
}
.buffer-orbit .ring2 { inset: 16%; border-top-color: var(--rose); animation-duration: 1.6s; animation-direction: reverse; }
@keyframes spin { to { transform: rotate(360deg); } }
.buffer-msg { font-family: var(--font-head); font-size: 1.3rem; min-height: 1.6em; transition: opacity .4s; }
.buffer-bar { height: 6px; border-radius: 99px; background: rgba(255,255,255,0.08); margin-top: 22px; overflow: hidden; }
.buffer-bar > i { display: block; height: 100%; width: 0; border-radius: 99px;
  background: linear-gradient(90deg, var(--gold-strong), var(--rose)); transition: width .5s ease; }

/* utility */
.display-none { display: none !important; }
.mt-s { margin-top: 12px; } .mt-m { margin-top: 24px; } .mt-l { margin-top: 40px; }
.tiny { font-size: 0.76rem; } .small { font-size: 0.86rem; }
footer { text-align: center; color: var(--ink-faint); font-size: 0.76rem; padding: 40px 20px 60px; position: relative; z-index: 1; }
footer a { color: var(--ink-soft); text-decoration: none; }

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
