/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:#0d0d0d;
  color:#f5f5f0;
  min-height:100dvh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  transition:background-color .8s ease;
}
body.quiz-active{background:#0a1628}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4{font-family:'Outfit',system-ui,sans-serif;font-weight:700;line-height:1.1}
a{color:#4ecdc4;text-decoration:none;transition:color .2s}
a:hover{color:#6fe8df}

/* ===== LAYOUT ===== */
.container{width:100%;max-width:640px;margin:0 auto;padding:0 24px}
.screen{display:none;min-height:100dvh;position:relative}
.screen.active{display:flex;align-items:center;justify-content:center}

/* ===== LANDING ===== */
.landing-content{text-align:center;padding:60px 0 40px}

.hero-title{
  font-size:clamp(3rem,12vw,5.5rem);
  font-weight:900;
  letter-spacing:-0.03em;
  margin-bottom:20px;
  line-height:1;
}
.hero-title .accent{
  color:#ff6b6b;
  display:inline-block;
  position:relative;
}
.hero-title .accent::after{
  content:'';
  position:absolute;
  bottom:-4px;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,#ff6b6b,transparent);
  border-radius:2px;
}

.hero-sub{
  font-size:clamp(1.05rem,3vw,1.3rem);
  color:rgba(245,245,240,.7);
  margin-bottom:28px;
  line-height:1.5;
}
.hero-meta{margin-bottom:36px}
.hero-meta p{
  font-size:.875rem;
  color:rgba(245,245,240,.45);
  line-height:1.6;
}

/* Dropdowns */
.dropdowns{
  display:flex;flex-direction:column;gap:16px;
  max-width:340px;margin:0 auto 32px;
  text-align:left;
}
.dropdown-group label{
  display:block;
  font-size:.8rem;
  color:rgba(245,245,240,.5);
  margin-bottom:6px;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-weight:500;
}
.dropdown-group select{
  width:100%;
  padding:14px 16px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  color:#f5f5f0;
  font-family:'DM Sans',sans-serif;
  font-size:.95rem;
  appearance:none;
  cursor:pointer;
  transition:border-color .2s,background .2s;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23f5f5f0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
}
.dropdown-group select:hover{border-color:rgba(255,255,255,.25)}
.dropdown-group select:focus{outline:none;border-color:#ff6b6b;background:rgba(255,107,107,.06)}
.dropdown-group select option{background:#1a1a2e;color:#f5f5f0}

/* CTA */
.cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 40px;
  background:linear-gradient(135deg,#ff6b6b,#ee5a5a);
  color:#fff;
  font-family:'Outfit',sans-serif;
  font-size:1.1rem;
  font-weight:700;
  border:none;border-radius:60px;
  cursor:pointer;
  transition:transform .2s,box-shadow .2s,background .2s;
  box-shadow:0 4px 24px rgba(255,107,107,.25);
  min-height:56px;
  position:relative;
  overflow:hidden;
}
.cta-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0;transition:opacity .2s;
}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(255,107,107,.35)}
.cta-btn:hover::before{opacity:1}
.cta-btn:active{transform:translateY(0);box-shadow:0 2px 12px rgba(255,107,107,.2)}

.cta-btn--secondary{
  background:rgba(255,255,255,.08);
  box-shadow:none;
  border:1px solid rgba(255,255,255,.12);
}
.cta-btn--secondary:hover{background:rgba(255,255,255,.12);box-shadow:none;transform:translateY(-1px)}

.cta-btn--outline{
  background:transparent;
  border:2px solid rgba(255,255,255,.15);
  box-shadow:none;
  margin-bottom:24px;
}
.cta-btn--outline:hover{border-color:rgba(255,255,255,.3);box-shadow:none;background:rgba(255,255,255,.04)}

/* ===== QUIZ ===== */
.quiz-header{
  padding-top:32px;
  margin-bottom:32px;
}
.q-counter{
  display:block;
  font-family:'Outfit',sans-serif;
  font-size:.9rem;
  font-weight:600;
  color:rgba(245,245,240,.5);
  margin-bottom:12px;
  letter-spacing:.06em;
}
.progress-track{
  width:100%;height:3px;
  background:rgba(255,255,255,.08);
  border-radius:3px;
  overflow:hidden;
}
.progress-fill{
  height:100%;
  background:linear-gradient(90deg,#ff6b6b,#4ecdc4);
  border-radius:3px;
  transition:width .5s cubic-bezier(.4,0,.2,1);
  width:0%;
}

/* Question area */
.question-area{padding-bottom:60px}

.question-card{
  animation:slideIn .4s cubic-bezier(.16,1,.3,1) forwards;
  opacity:0;
}
@keyframes slideIn{
  from{opacity:0;transform:translateX(40px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes slideOut{
  from{opacity:1;transform:translateX(0)}
  to{opacity:0;transform:translateX(-40px)}
}
.question-card.exiting{
  animation:slideOut .25s cubic-bezier(.4,0,1,1) forwards;
}

.q-scenario{
  font-family:'Outfit',sans-serif;
  font-size:clamp(1.25rem,4vw,1.6rem);
  font-weight:700;
  line-height:1.3;
  margin-bottom:32px;
  color:#f5f5f0;
}

.q-options{display:flex;flex-direction:column;gap:12px}

.q-option{
  display:block;width:100%;
  padding:18px 20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  color:rgba(245,245,240,.85);
  font-family:'DM Sans',sans-serif;
  font-size:.95rem;
  line-height:1.5;
  text-align:left;
  cursor:pointer;
  transition:all .2s ease;
  min-height:56px;
}
.q-option:hover{
  background:rgba(255,107,107,.08);
  border-color:rgba(255,107,107,.3);
  color:#f5f5f0;
  transform:translateX(4px);
}
.q-option:active{
  background:rgba(255,107,107,.14);
  transform:translateX(2px);
}
.q-option.selected{
  background:rgba(255,107,107,.12);
  border-color:#ff6b6b;
  color:#f5f5f0;
}

/* ===== INTERSTITIAL ===== */
.interstitial-container{
  text-align:center;
  padding:60px 0;
}
.interstitial-text{
  font-size:1.1rem;
  color:rgba(245,245,240,.6);
  margin-bottom:32px;
}

/* ===== PROCESSING ===== */
.processing-container{
  text-align:center;
  padding:80px 0;
}
.processing-spinner{
  width:80px;height:80px;
  margin:0 auto 32px;
}
.spinner-svg{width:100%;height:100%}
.spinner-arc{
  animation:spin 1.2s linear infinite;
  transform-origin:50% 50%;
}
@keyframes spin{to{transform:rotate(360deg)}}

.processing-text{
  font-size:1.05rem;
  color:rgba(245,245,240,.6);
  transition:opacity .3s;
  min-height:1.6em;
}

/* ===== RESULTS ===== */
.results-content{
  text-align:center;
  padding:48px 0 40px;
}

/* Gauge */
.gauge-wrapper{
  width:220px;height:220px;
  margin:0 auto 32px;
  position:relative;
}
.gauge-svg{width:100%;height:100%}
.gauge-number{
  font-family:'Outfit',sans-serif;
  font-size:3rem;
  font-weight:900;
  fill:#f5f5f0;
}
.gauge-label{
  font-family:'DM Sans',sans-serif;
  font-size:.8rem;
  fill:rgba(245,245,240,.5);
  letter-spacing:.06em;
}

.result-headline{
  font-size:clamp(1.2rem,4vw,1.6rem);
  font-weight:700;
  margin-bottom:8px;
  line-height:1.3;
  color:rgba(245,245,240,.85);
}
.result-range-label{
  font-size:.95rem;
  color:#ff6b6b;
  font-weight:600;
  margin-bottom:32px;
  font-family:'Outfit',sans-serif;
}
.result-card--range{
  border-color:rgba(255,255,255,.06);
  margin-bottom:28px;
}
.result-card--range .card-body{
  white-space:pre-line;
}

/* Cards */
.result-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:28px 24px;
  margin-bottom:20px;
  text-align:left;
}
.result-card--good{
  border-color:rgba(78,205,196,.2);
  background:rgba(78,205,196,.04);
}
.card-label{
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:#ff6b6b;
  margin-bottom:12px;
  font-weight:600;
}
.card-label--good{color:#4ecdc4}
.pattern-name{
  font-size:1.4rem;
  margin-bottom:14px;
  color:#f5f5f0;
}
.card-body{
  font-size:.95rem;
  line-height:1.7;
  color:rgba(245,245,240,.75);
}

/* Share */
.share-section{margin:36px 0}
.share-label{
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(245,245,240,.4);
  margin-bottom:16px;
  font-weight:500;
}
.share-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 20px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:40px;
  background:rgba(255,255,255,.04);
  color:#f5f5f0;
  font-family:'DM Sans',sans-serif;
  font-size:.85rem;
  cursor:pointer;
  transition:all .2s;
  min-height:44px;
}
.share-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.share-btn--wa:hover{border-color:#25d366;color:#25d366}
.share-btn--tw:hover{border-color:#1da1f2;color:#1da1f2}
.share-btn--copy:hover{border-color:#4ecdc4;color:#4ecdc4}

/* Breakdown */
.breakdown{margin-top:12px;margin-bottom:32px}
.breakdown.hidden{display:none}
.breakdown-title{
  font-size:1.1rem;
  margin-bottom:28px;
  color:rgba(245,245,240,.85);
}

.horseman-bars{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}
.horseman-bar-row{display:flex;align-items:center;gap:12px}
.horseman-label{
  width:110px;flex-shrink:0;
  font-size:.85rem;
  color:rgba(245,245,240,.6);
  text-align:right;
}
.bar-track{
  flex:1;height:10px;
  background:rgba(255,255,255,.06);
  border-radius:10px;
  overflow:hidden;
}
.bar-fill{
  height:100%;border-radius:10px;
  transition:width 1.2s cubic-bezier(.16,1,.3,1);
}
.bar-fill--criticism{background:linear-gradient(90deg,#ff6b6b,#ff8e8e)}
.bar-fill--contempt{background:linear-gradient(90deg,#e056a0,#f078b8)}
.bar-fill--defensiveness{background:linear-gradient(90deg,#ffa94d,#ffc078)}
.bar-fill--stonewalling{background:linear-gradient(90deg,#748ffc,#91a7ff)}
.bar-val{
  width:28px;flex-shrink:0;
  font-family:'Outfit',sans-serif;
  font-size:.9rem;
  font-weight:700;
  color:rgba(245,245,240,.7);
}

.horseman-advice{text-align:left}
.horseman-advice .advice-block{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px;
  padding:22px 20px;
  margin-bottom:14px;
}
.horseman-advice .advice-block h4{
  font-size:.95rem;
  margin-bottom:8px;
  color:#ff6b6b;
}
.horseman-advice .advice-block p{
  font-size:.9rem;
  line-height:1.6;
  color:rgba(245,245,240,.65);
}

/* Footer */
.site-footer{
  margin-top:40px;
  padding:24px 0;
  font-size:.85rem;
  color:rgba(245,245,240,.35);
}
.footer-dot{margin:0 8px}

/* ===== ADS ===== */
.ad-slot{
  margin:24px 0;
  min-height:0;
  transition:min-height .3s;
}
.ad-slot.active{
  min-height:100px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.02);
  border:1px dashed rgba(255,255,255,.06);
  border-radius:12px;
  padding:12px;
}

/* ===== RESPONSIVE ===== */
@media(max-width:480px){
  .container{padding:0 18px}
  .hero-title{font-size:clamp(2.6rem,11vw,4rem)}
  .q-option{padding:16px 18px;font-size:.9rem}
  .gauge-wrapper{width:190px;height:190px}
  .gauge-number{font-size:2.5rem}
  .horseman-label{width:90px;font-size:.8rem}
  .share-buttons{flex-direction:column;align-items:center}
}

/* ===== ACCESSIBILITY ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    transition-duration:0.01ms!important;
  }
}

:focus-visible{
  outline:2px solid #4ecdc4;
  outline-offset:3px;
  border-radius:4px;
}
