/*
  Wedding Wedge Results UI
  Version: 1.4.0
  Date: 2026-04-25
  Author: Nova, Senior Developer
*/
:root {
  --ww-bg: #fbf7ef;
  --ww-card: #ffffff;
  --ww-text: #241c15;
  --ww-muted: #76695f;
  --ww-border: #eadfce;
  --ww-accent: #9b6a2f;
  --ww-accent-dark: #6f451c;
  --ww-soft: #f4eadb;
  --ww-danger: #9f2d20;
  --ww-warning: #a86e11;
  --ww-good: #246b43;
  --ww-shadow: 0 18px 50px rgba(64, 42, 21, 0.09);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, #fffaf2 0, var(--ww-bg) 45%, #f6ecdc 100%);
  color: var(--ww-text);
}

.ww-page {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 48px 0 72px;
}

.ww-hero {
  text-align: center;
  padding: 22px 0 30px;
}

.ww-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--ww-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--ww-accent-dark);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
}

h1 {
  max-width: 850px;
  margin: 22px auto 14px;
  font-size: clamp(36px, 6vw, 68px);
  line-height: 0.96;
  letter-spacing: -0.06em;
}

.ww-lede {
  max-width: 740px;
  margin: 0 auto;
  color: var(--ww-muted);
  font-size: clamp(17px, 2vw, 21px);
  line-height: 1.55;
}

.ww-card {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--ww-border);
  border-radius: 28px;
  box-shadow: var(--ww-shadow);
}

.ww-form-card { padding: 28px; }

.ww-form-card h2, .ww-summary-card h2, .ww-list-card h3, .ww-recommendation-card h3 {
  margin: 0 0 8px;
  letter-spacing: -0.035em;
}

.ww-muted { color: var(--ww-muted); margin: 0 0 24px; line-height: 1.5; }

.ww-form { display: grid; gap: 18px; }
.ww-grid { display: grid; gap: 18px; }
.ww-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.ww-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.ww-field label {
  display: block;
  font-weight: 800;
  margin-bottom: 8px;
  font-size: 14px;
}

.ww-field input,
.ww-field select {
  width: 100%;
  border: 1px solid var(--ww-border);
  border-radius: 16px;
  padding: 14px 14px;
  background: #fff;
  color: var(--ww-text);
  font-size: 16px;
  outline: none;
}

.ww-field input:focus,
.ww-field select:focus {
  border-color: var(--ww-accent);
  box-shadow: 0 0 0 4px rgba(155, 106, 47, 0.12);
}

.ww-button {
  border: 0;
  border-radius: 18px;
  padding: 16px 22px;
  background: linear-gradient(135deg, var(--ww-accent), var(--ww-accent-dark));
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(111, 69, 28, 0.24);
}

.ww-button:disabled { opacity: 0.6; cursor: wait; }
.ww-status { margin: 0; min-height: 20px; color: var(--ww-muted); font-weight: 700; }

.ww-results { margin-top: 28px; display: grid; gap: 20px; }
.ww-summary-card { padding: 28px; }
.ww-summary-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.ww-pill {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 12px;
  background: var(--ww-soft);
  color: var(--ww-accent-dark);
  font-weight: 900;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.ww-summary-text { margin: 12px 0 0; color: var(--ww-muted); font-size: 18px; line-height: 1.55; }
.ww-overall { text-align: right; }
.ww-overall span { display: block; color: var(--ww-muted); font-size: 13px; font-weight: 800; text-transform: uppercase; }
.ww-overall strong { display: block; font-size: 32px; text-transform: capitalize; }

.ww-score-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.ww-score-card {
  background: #fff;
  border: 1px solid var(--ww-border);
  border-radius: 22px;
  padding: 20px;
}
.ww-score-card span { color: var(--ww-muted); display: block; font-weight: 800; font-size: 13px; text-transform: uppercase; }
.ww-score-card strong { display: block; font-size: 34px; margin: 8px 0 4px; text-transform: capitalize; }
.ww-score-card small { color: var(--ww-muted); line-height: 1.35; display: block; }

.ww-list-card, .ww-recommendation-card { padding: 24px; }
.ww-list-card ul { margin: 14px 0 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.ww-list-card li {
  padding: 14px 14px 14px 40px;
  border-radius: 16px;
  background: var(--ww-soft);
  position: relative;
  line-height: 1.4;
}
.ww-list-card li::before {
  content: "•";
  position: absolute;
  left: 18px;
  top: 12px;
  font-size: 24px;
  color: var(--ww-accent-dark);
}
.ww-recommendation-card p { margin: 12px 0 0; color: var(--ww-muted); font-size: 18px; line-height: 1.55; }

.risk-high { color: var(--ww-danger); }
.risk-medium { color: var(--ww-warning); }
.risk-low { color: var(--ww-good); }

@media (max-width: 860px) {
  .ww-grid-2, .ww-grid-3, .ww-score-grid { grid-template-columns: 1fr; }
  .ww-summary-top { flex-direction: column; }
  .ww-overall { text-align: left; }
  .ww-page { width: min(100% - 22px, 1120px); padding-top: 24px; }
  .ww-form-card, .ww-summary-card { padding: 22px; border-radius: 22px; }
}

/* Wedding Wedge Conversion Layer v1.3.0 */
.ww-shock-card {
  padding: 24px 28px;
  border-color: rgba(159, 45, 32, 0.28);
  background: linear-gradient(135deg, #fff6ef, #ffffff);
}
.ww-shock-label {
  color: var(--ww-danger);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 12px;
  margin-bottom: 8px;
}
.ww-shock-card p {
  margin: 0;
  font-size: clamp(20px, 2.4vw, 30px);
  line-height: 1.18;
  letter-spacing: -0.035em;
  font-weight: 900;
}
.ww-locked-preview {
  position: relative;
  overflow: hidden;
}
.ww-lock-strip {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #241c15;
  color: #fff;
  font-weight: 850;
  font-size: 13px;
  line-height: 1.35;
}
.ww-save-card,
.ww-upgrade-card {
  padding: 28px;
}
.ww-save-card {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 22px;
  align-items: center;
}
.ww-save-card h3,
.ww-upgrade-card h3 {
  margin: 0 0 8px;
  letter-spacing: -0.04em;
}
.ww-save-card p,
.ww-upgrade-card p {
  margin: 0;
  color: var(--ww-muted);
  line-height: 1.55;
}
.ww-lead-form {
  display: flex;
  gap: 12px;
}
.ww-lead-form input {
  flex: 1;
  border: 1px solid var(--ww-border);
  border-radius: 16px;
  padding: 14px;
  font-size: 16px;
}
.ww-button-secondary {
  white-space: nowrap;
  box-shadow: none;
}
.ww-upgrade-card {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 28px;
  align-items: center;
  background: linear-gradient(135deg, #241c15, #4b2e17);
  color: #fff;
  border-color: rgba(255,255,255,0.14);
}
.ww-upgrade-card .ww-pill {
  background: rgba(255,255,255,0.12);
  color: #f7e7ce;
  border: 1px solid rgba(255,255,255,0.18);
}
.ww-upgrade-card p,
.ww-upgrade-card li,
.ww-upgrade-card .ww-status {
  color: rgba(255,255,255,0.78);
}
.ww-upgrade-card ul {
  margin: 16px 0 0;
  padding-left: 20px;
  display: grid;
  gap: 8px;
}
.ww-upgrade-action {
  display: grid;
  gap: 12px;
  justify-items: stretch;
}
.ww-price {
  font-size: 58px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: -0.07em;
  text-align: center;
}
.ww-link-button {
  border: 1px solid rgba(255,255,255,0.26);
  background: rgba(255,255,255,0.08);
  color: #fff;
  border-radius: 16px;
  padding: 13px 16px;
  font-weight: 850;
  cursor: pointer;
}
@media (max-width: 860px) {
  .ww-save-card,
  .ww-upgrade-card {
    grid-template-columns: 1fr;
    padding: 22px;
  }
  .ww-lead-form {
    flex-direction: column;
  }
  .ww-price {
    text-align: left;
  }
}


/* Wedding Wedge Conversion Copy Layer v1.4.0 */
.ww-doubt-card,
.ww-loss-card { padding: 24px 28px; }
.ww-doubt-card { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; border-color: rgba(168, 110, 17, 0.28); background: linear-gradient(135deg, #fff8e7, #ffffff); }
.ww-doubt-icon { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 999px; background: rgba(168, 110, 17, 0.12); font-size: 22px; }
.ww-doubt-card h3, .ww-loss-card h3 { margin: 0 0 8px; letter-spacing: -0.04em; font-size: clamp(22px, 2.3vw, 30px); }
.ww-doubt-card p, .ww-loss-card p { margin: 0; color: var(--ww-muted); font-size: 17px; line-height: 1.55; }
.ww-loss-card { border-color: rgba(159, 45, 32, 0.2); background: linear-gradient(135deg, #fff4f1, #ffffff); }
.ww-loss-card p + p { margin-top: 8px; }
.ww-loss-card strong { color: var(--ww-danger); }
.ww-upgrade-card h3 { font-size: clamp(28px, 3vw, 42px); line-height: 1.02; }
.ww-upgrade-card .ww-button { line-height: 1.2; }
@media (max-width: 860px) { .ww-doubt-card { grid-template-columns: 1fr; } .ww-doubt-card, .ww-loss-card { padding: 22px; } }

/* Wedding Wedge Stripe Success Layer v1.5.0 */
.ww-button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  margin-top: 18px;
}


/* Wedding Wedge v1.7.0 Paid Unlock Experience */
.ww-unlocked-banner {
  border: 1px solid rgba(36, 107, 67, 0.25);
  background: linear-gradient(135deg, rgba(36, 107, 67, 0.08), rgba(255, 255, 255, 0.92));
}

.ww-rule-groups {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.ww-rule-groups h4 {
  margin: 0 0 8px;
  color: var(--ww-accent-dark);
}

.ww-checklist-card {
  border-left: 6px solid var(--ww-good);
}

.ww-red-flag-card {
  border-left: 6px solid var(--ww-danger);
  background: #fff8f6;
}

.ww-share-report {
  text-align: center;
}

.ww-button-link {
  display: inline-flex;
  justify-content: center;
  text-decoration: none;
}

@media (max-width: 760px) {
  .ww-rule-groups {
    grid-template-columns: 1fr;
  }
}
