*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#07080C;--bg2:#0D0F16;--surface:#121520;--surface2:#181C28;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);
  --BN:#E8603A;--ED:#1BA8D4;--DR:#6C5FE6;--PE:#2EC4A0;
  --accent:#7000FF;--text:#E8E6F0;--muted:#6B6980;--muted2:#353448;
  --mono:'Space Mono',monospace;--sans:'Outfit',system-ui,sans-serif;
}

/* MODO CLARO — override mínimo (accents mantidos) */
:root[data-theme="light"]{
  --bg:#F4F2F8;--bg2:#EAE7F0;--surface:#EBE8F0;--surface2:#E0DCEA;
  --border:rgba(20,15,35,0.10);--border2:rgba(20,15,35,0.18);
  --text:#1A1525;--muted:#6A6478;--muted2:#8B8298;
}
:root[data-theme="light"] body{color-scheme:light;}

html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(112,0,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(112,0,255,0.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0;}
.orb{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0;}
.orb-1{width:600px;height:600px;background:var(--accent);opacity:0.06;top:-200px;right:-100px;}
.orb-2{width:400px;height:400px;background:var(--ED);opacity:0.04;bottom:-100px;left:-100px;}

.page{display:none;position:relative;z-index:1;}
.page.active{display:flex;flex-direction:column;min-height:100vh;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── INTRO ── */
.intro-page{align-items:center;justify-content:center;text-align:center;padding:5rem 2rem;}
.intro-badge{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(112,0,255,0.1);border:1px solid rgba(112,0,255,0.25);color:#9B5CF6;font-family:var(--mono);font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.35rem 0.9rem;border-radius:4px;margin-bottom:2rem;animation:fadeUp 0.6s ease both;}
.intro-page h1{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;line-height:1.08;letter-spacing:-0.03em;max-width:700px;margin:0 auto 1.25rem;animation:fadeUp 0.6s 0.1s ease both;}
.intro-page h1 .accent{background:linear-gradient(135deg,var(--accent),var(--ED));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.intro-sub{color:var(--muted);font-size:0.95rem;max-width:560px;margin:0 auto 2.5rem;line-height:1.75;animation:fadeUp 0.6s 0.2s ease both;}
.intro-meta{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin:0 auto 2.5rem;max-width:420px;animation:fadeUp 0.6s 0.3s ease both;}
.meta-item{padding:1rem 1.5rem;text-align:center;border-right:1px solid var(--border);background:var(--surface);flex:1;}
.meta-item:last-child{border-right:none;}
.meta-val{font-family:var(--mono);font-size:1.2rem;font-weight:700;display:block;letter-spacing:-0.02em;color:var(--text);}
.meta-label{font-size:0.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:0.2rem;display:block;}
.btn-start{display:inline-flex;align-items:center;gap:0.5rem;background:var(--accent);color:#fff;border:none;padding:0.9rem 2.25rem;border-radius:7px;font-size:0.9rem;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all 0.2s;animation:fadeUp 0.6s 0.4s ease both;}
.btn-start:hover{opacity:0.88;transform:translateY(-2px);}
.intro-note{margin-top:1.25rem;font-family:var(--mono);font-size:0.62rem;color:var(--muted2);animation:fadeUp 0.6s 0.5s ease both;}
.dim-pills{display:flex;gap:0.5rem;justify-content:center;flex-wrap:wrap;margin:0 auto 2.5rem;max-width:600px;animation:fadeUp 0.6s 0.25s ease both;}
.dim-pill{padding:0.3rem 0.9rem;border-radius:100px;font-family:var(--mono);font-size:0.6rem;letter-spacing:0.08em;font-weight:700;}

/* ── QUIZ NAV ── */
.quiz-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1rem 5%;background:rgba(7,8,12,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);}
.quiz-logo{font-size:0.9rem;font-weight:700;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:0.4rem;}
.quiz-logo-mark{width:22px;height:22px;background:var(--accent);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:0.6rem;font-weight:800;color:#fff;}
.quiz-logo span{color:#9B5CF6;}
.prog-wrap{flex:1;max-width:360px;margin:0 1.5rem;}
.prog-track{height:3px;background:var(--surface2);border-radius:100px;overflow:hidden;}
.prog-fill{height:100%;border-radius:100px;background:var(--accent);transition:width 0.5s cubic-bezier(0.34,1.56,0.64,1);}
.prog-label{font-family:var(--mono);font-size:0.6rem;color:var(--muted);text-align:center;margin-top:0.3rem;}
.btn-back{background:transparent;border:1px solid var(--border2);color:var(--muted);padding:0.45rem 0.9rem;border-radius:5px;font-family:var(--mono);font-size:0.7rem;cursor:pointer;transition:all 0.2s;}
.btn-back:hover{border-color:var(--accent);color:var(--text);}

/* ── QUIZ BODY ── */
.quiz-body{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem 5%;min-height:calc(100vh - 70px);}
.q-card{max-width:680px;width:100%;animation:slideIn 0.35s ease both;}
.q-dim-tag{display:inline-flex;align-items:center;gap:0.4rem;font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;border:1px solid;padding:0.28rem 0.75rem;border-radius:3px;margin-bottom:1.5rem;}
.q-text{font-size:clamp(1.15rem,2.8vw,1.5rem);font-weight:700;line-height:1.45;letter-spacing:-0.02em;margin-bottom:2.5rem;max-width:580px;}
.scale-row{display:flex;align-items:center;gap:0.75rem;justify-content:center;margin-bottom:1rem;}
.scale-pole{font-family:var(--mono);font-size:0.6rem;color:var(--muted);text-align:center;max-width:80px;line-height:1.4;}
.scale-btns{display:flex;gap:0.6rem;align-items:center;}
.scale-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border2);background:transparent;cursor:pointer;transition:all 0.18s;position:relative;flex-shrink:0;}
.scale-btn::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--muted2);transition:all 0.18s;}
.scale-btn:hover{border-color:currentColor;background:rgba(255,255,255,0.04);}
.scale-btn:hover::after{background:currentColor;width:10px;height:10px;}
.scale-btn.selected{border-color:currentColor;background:rgba(255,255,255,0.06);}
.scale-btn.selected::after{background:currentColor;box-shadow:0 0 10px currentColor;width:45%;height:45%;}
.scale-hint{font-family:var(--mono);font-size:0.62rem;color:var(--muted2);text-align:center;min-height:1.2em;transition:all 0.2s;margin-bottom:2rem;}
.quiz-actions{display:flex;justify-content:center;}
.btn-next{display:inline-flex;align-items:center;gap:0.4rem;background:var(--accent);color:#fff;border:none;padding:0.8rem 1.75rem;border-radius:7px;font-size:0.9rem;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all 0.2s;opacity:0.3;pointer-events:none;}
.btn-next.ready{opacity:1;pointer-events:all;}
.btn-next.ready:hover{opacity:0.88;transform:translateY(-1px);}

/* ── LOADING ── */
.loading-page{align-items:center;justify-content:center;padding:4rem 2rem;gap:2rem;}
.loading-spinner{width:48px;height:48px;border:3px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-family:var(--mono);font-size:0.72rem;color:var(--muted);letter-spacing:0.06em;}

/* ── RESULTADO ── */
.result-page{align-items:center;padding:4rem 5% 6rem;flex-direction:column;}
.result-eyebrow{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:0.6rem;animation:fadeUp 0.5s ease both;}
.result-title{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-0.03em;text-align:center;margin-bottom:0.5rem;animation:fadeUp 0.5s 0.1s ease both;}
.result-sub{color:var(--muted);font-size:0.88rem;text-align:center;margin-bottom:2.5rem;max-width:560px;line-height:1.7;animation:fadeUp 0.5s 0.15s ease both;}

/* Dim cards 2×2 */
.dims-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:12px;overflow:hidden;width:100%;max-width:760px;margin-bottom:1.5rem;animation:fadeUp 0.5s 0.2s ease both;}
.dim-card{background:var(--surface);padding:1.75rem 2rem;position:relative;overflow:hidden;}
.dim-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.dc-BN::before{background:var(--BN);}
.dc-ED::before{background:var(--ED);}
.dc-DR::before{background:var(--DR);}
.dc-PE::before{background:var(--PE);}
.dim-label{font-family:var(--mono);font-size:0.52rem;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:0.4rem;}
.dim-name{font-size:1rem;font-weight:800;margin-bottom:0.75rem;letter-spacing:-0.01em;}
.dim-bar-track{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;margin-bottom:0.4rem;}
.dim-bar-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(0.34,1.56,0.64,1);}
.dim-score-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:0.75rem;}
.dim-score-num{font-family:var(--mono);font-size:1.4rem;font-weight:700;}
.dim-score-label{font-family:var(--mono);font-size:0.6rem;color:var(--muted);letter-spacing:0.06em;}
.dim-desc{font-size:0.78rem;color:rgba(232,230,240,0.7);line-height:1.65;}

/* AI section */
.ai-block{width:100%;max-width:760px;background:var(--surface2);border:1px solid rgba(112,0,255,0.2);border-radius:12px;padding:1.75rem 2rem;margin-bottom:1.5rem;position:relative;overflow:hidden;animation:fadeUp 0.5s 0.3s ease both;}
.ai-block::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--ED),transparent);}
.ai-eyebrow{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.14em;text-transform:uppercase;color:#9B5CF6;margin-bottom:0.75rem;display:flex;align-items:center;gap:0.5rem;}
.ai-eyebrow::before{content:'◆';font-size:0.5rem;}
.ai-content{font-size:0.88rem;line-height:1.8;color:var(--text);}
.ai-content strong{color:#C4A5FA;}
.ai-loading{display:flex;align-items:center;gap:0.75rem;font-family:var(--mono);font-size:0.7rem;color:var(--muted);}
.ai-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:aiPulse 1.2s ease-in-out infinite;}
.ai-dot:nth-child(2){animation-delay:0.2s;}
.ai-dot:nth-child(3){animation-delay:0.4s;}
@keyframes aiPulse{0%,100%{opacity:0.3;transform:scale(0.8)}50%{opacity:1;transform:scale(1.2)}}

/* Actions */
.result-actions{display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;animation:fadeUp 0.5s 0.4s ease both;}
.btn-dashboard{background:#6C5FE6;color:#fff;border:none;padding:0.85rem 2rem;border-radius:7px;font-size:0.88rem;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all 0.2s;text-decoration:none;display:inline-flex;align-items:center;}
.btn-dashboard:hover{opacity:0.88;}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border2);padding:0.85rem 2rem;border-radius:7px;font-size:0.88rem;font-weight:600;font-family:var(--sans);cursor:pointer;transition:all 0.2s;}
.btn-outline:hover{border-color:var(--accent);color:#9B5CF6;}

@media(max-width:768px){
  .dims-grid{grid-template-columns:1fr;}
  .prog-wrap{max-width:140px;margin:0 0.5rem;}
  .scale-btn{width:38px;height:38px;}
}

/* ─── block 2 ─── */

  html.gnosis-has-result #page-intro,
  html.gnosis-has-result #page-quiz { display: none !important; }
  html.gnosis-has-result body::before {
    content: ''; position: fixed; inset: 0;
    background: var(--bg, #0A0A0F);
    z-index: 99998;
    transition: opacity 0.3s ease;
  }
  html.gnosis-has-result body::after {
    content: ''; position: fixed;
    top: 50%; left: 50%;
    width: 38px; height: 38px;
    margin: -19px 0 0 -19px;
    border: 3px solid rgba(124,111,247,0.18);
    border-top-color: var(--accent, #7C6FF7);
    border-radius: 50%;
    animation: gnosis-spin 0.8s linear infinite;
    z-index: 99999;
    transition: opacity 0.3s ease;
  }
  @keyframes gnosis-spin { to { transform: rotate(360deg); } }
  html.gnosis-has-result.gnosis-ready body::before,
  html.gnosis-has-result.gnosis-ready body::after { opacity: 0; pointer-events: none; }
