*{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#f6f1e8;--paper:#fffcf5;--forest:#063328;--forest2:#0b4636;
  --gold:#c9a84c;--gold2:#e6c66b;--ink:#10231c;
  --muted:rgba(16,35,28,.52);--line:rgba(6,51,40,.1);
}
html,body{min-height:100%;font-family:'Inter','Segoe UI',Arial,sans-serif;background:var(--cream);color:var(--ink)}
body{background:radial-gradient(ellipse 70% 40% at 0% 0%,rgba(6,51,40,.06),transparent 55%),var(--cream)}
a{color:inherit;text-decoration:none}

/* ── TOPBAR ── */
.flow-topbar{
  position:sticky;top:0;z-index:20;height:68px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(20px,5vw,64px);
  background:rgba(246,241,232,.92);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.brand{display:flex;align-items:center;gap:10px;color:var(--forest);font-size:18px;font-weight:900;letter-spacing:.04em;text-decoration:none}
.brand-icon{
  width:34px;height:34px;display:grid;place-items:center;flex-shrink:0;
  border:1.5px solid rgba(201,168,76,.5);border-radius:9px;
  color:var(--gold2);
  background:linear-gradient(135deg,var(--forest),var(--forest2));
  box-shadow:0 4px 12px rgba(6,51,40,.2);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-size:18px;font-weight:900;letter-spacing:.03em;color:var(--forest);line-height:1}
.brand-sub{font-size:7.5px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:3px;display:flex;align-items:center;gap:4px}
.brand-sub-dot{color:rgba(6,51,40,.28);font-size:10px;line-height:0}
.brand em{font-style:normal;color:var(--gold)}.brand b{color:var(--gold);font-size:23px}
.flow-nav{display:flex;align-items:center;gap:4px}
.flow-nav a{
  color:rgba(6,51,40,.55);font-size:13px;font-weight:700;
  padding:6px 13px;border-radius:8px;transition:all .2s;
}
.flow-nav a:hover{color:var(--forest);background:rgba(6,51,40,.06)}
.flow-nav a.active{color:var(--forest);font-weight:900}

/* user pill reutilizado via supabase-client.js */
.nav-user-btn{
  display:flex;align-items:center;gap:8px;
  background:rgba(6,51,40,.07);border:1px solid var(--line);border-radius:20px;
  padding:4px 12px 4px 4px;cursor:pointer;color:var(--forest);
  font-size:13px;font-weight:700;transition:all .2s;
}
.nav-user-btn:hover{background:rgba(6,51,40,.11);border-color:rgba(6,51,40,.18)}
.nav-user-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover}
.nav-user-initials{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--forest),var(--forest2));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;color:var(--cream);
}
.nav-dropdown{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--paper);
  border:1px solid var(--line);border-radius:14px;
  box-shadow:0 20px 60px rgba(6,51,40,.14),0 4px 12px rgba(6,51,40,.08);
  padding:14px;min-width:220px;z-index:9999;
}
.nav-dropdown .nd-user{padding-bottom:12px;margin-bottom:10px;border-bottom:1px solid var(--line)}
.nav-dropdown .nd-user strong{display:block;color:var(--forest);font-size:14px;font-weight:900}
.nav-dropdown .nd-user span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.nav-dropdown .nd-credits{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 10px;border-radius:8px;background:rgba(6,51,40,.05);
  margin-bottom:8px;
}
.nav-dropdown .nd-credits span{color:var(--muted);font-size:12px;font-weight:800}
.nav-dropdown .nd-credits strong{color:var(--forest);font-size:14px;font-weight:900}
.nav-dropdown a,.nav-dropdown button{
  display:block;width:100%;padding:9px 10px;border-radius:8px;
  font:inherit;font-size:13px;font-weight:700;cursor:pointer;
  text-align:left;background:none;border:none;color:var(--forest);transition:background .15s;
}
.nav-dropdown a:hover,.nav-dropdown button:hover{background:rgba(6,51,40,.06)}
.nav-dropdown .nd-logout{color:#c53030!important}
.nav-dropdown .nd-cta{
  display:block;text-align:center;
  background:linear-gradient(135deg,var(--forest),var(--forest2));
  color:var(--cream)!important;border-radius:8px;padding:10px!important;
  font-weight:900!important;box-shadow:0 4px 14px rgba(6,51,40,.18);margin-bottom:6px;
}

/* ── PAGE ── */
.flow-page{width:min(1120px,calc(100% - 44px));margin:0 auto;padding:54px 0 80px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 370px;gap:36px;align-items:start}
.eyebrow{color:var(--gold);font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}
h1{margin:12px 0 14px;color:var(--forest);font-size:clamp(38px,5.2vw,64px);line-height:.97;letter-spacing:-.055em}
.lead{max-width:650px;color:var(--muted);font-size:16px;line-height:1.7}

/* ── CARDS & PANELS ── */
.panel,.card{
  border:1px solid var(--line);border-radius:14px;background:var(--paper);
  box-shadow:0 8px 32px rgba(6,51,40,.06),0 2px 6px rgba(6,51,40,.04);
}
.panel{padding:26px}
.address{
  margin-top:20px;padding:16px;
  border:1px solid var(--line);border-radius:10px;background:#fff;
}
.address span{display:block;color:rgba(16,35,28,.45);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}
.address strong{display:block;color:var(--forest);font-size:16px;line-height:1.35}

/* ── METRICS ── */
.metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:28px}
.metric{
  padding:20px;border:1px solid var(--line);border-radius:12px;background:#fff;
  box-shadow:0 4px 16px rgba(6,51,40,.04);transition:box-shadow .2s;
}
.metric:hover{box-shadow:0 8px 28px rgba(6,51,40,.09)}
.metric span{display:block;color:rgba(16,35,28,.48);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.metric strong{display:block;margin-top:8px;color:var(--forest);font-size:28px;letter-spacing:-.04em;font-weight:900}
.metric small{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.4}

/* ── LOCKED BLOCKS ── */
.locked-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:20px}
.locked{
  position:relative;min-height:140px;padding:20px;
  border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden;
}
.locked h3{color:var(--forest);font-size:16px;margin-bottom:8px;font-weight:800}
.locked p{color:var(--muted);font-size:13px;line-height:1.55}
.locked::after{
  content:"Bloqueado";position:absolute;right:14px;bottom:14px;
  padding:6px 10px;border-radius:999px;
  background:rgba(6,51,40,.07);color:var(--forest);
  font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
}

/* ── BUTTONS ── */
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.btn{
  min-height:46px;display:inline-flex;align-items:center;justify-content:center;
  padding:0 20px;border-radius:10px;text-decoration:none;
  border:1.5px solid var(--line);font:inherit;font-size:13px;font-weight:900;
  cursor:pointer;transition:all .2s;
}
.btn.primary{
  background:linear-gradient(135deg,var(--forest),var(--forest2));
  color:var(--cream);border-color:var(--forest);
  box-shadow:0 6px 20px rgba(6,51,40,.22);
}
.btn.primary:hover{box-shadow:0 10px 28px rgba(6,51,40,.3);transform:translateY(-1px)}
.btn.secondary{background:#fff;color:var(--forest)}
.btn.secondary:hover{background:var(--cream);border-color:rgba(6,51,40,.18)}
.btn.gold{
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:var(--forest);border-color:var(--gold);
  box-shadow:0 6px 20px rgba(201,168,76,.25);
}
.btn.gold:hover{box-shadow:0 10px 28px rgba(201,168,76,.35);transform:translateY(-1px)}

/* ── CHECKOUT CARD ── */
.checkout-card{width:min(560px,100%);margin:0 auto;padding:32px}
.plans{display:grid;gap:10px;margin:22px 0}
.plan-option{
  display:flex;justify-content:space-between;gap:16px;align-items:center;
  padding:16px;border:1.5px solid var(--line);border-radius:10px;
  background:#fff;cursor:pointer;transition:all .2s;
}
.plan-option:has(input:checked){border-color:var(--forest);background:rgba(6,51,40,.03)}
.plan-option input{accent-color:var(--forest)}
.plan-option strong{color:var(--forest);font-size:14px;font-weight:900}
.plan-option span{color:var(--muted);font-size:12px;font-weight:700}

/* ── LOADING ── */
.loading-wrap{min-height:calc(100vh - 68px);display:grid;place-items:center;text-align:center;padding:34px}
.loader{
  width:72px;height:72px;border-radius:50%;
  border:4px solid rgba(6,51,40,.1);border-top-color:var(--gold);
  animation:spin 1s linear infinite;margin:0 auto 24px;
}
@keyframes spin{to{transform:rotate(360deg)}}
.steps{display:flex;flex-direction:column;gap:8px;margin-top:22px;color:var(--muted);font-size:13px;font-weight:750}

/* ── REPORT SHELL ── */
.report-shell{display:grid;grid-template-columns:310px minmax(0,1fr);gap:22px}
.side-card{padding:24px}
.report-preview{min-height:520px;padding:28px}
.report-preview h2{color:var(--forest);font-size:30px;letter-spacing:-.04em;margin-bottom:14px}
.report-row{
  display:flex;justify-content:space-between;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--line);font-size:13px;
}
.report-row span{color:var(--muted);font-weight:800}
.report-row strong{color:var(--forest);text-align:right}

/* ── DASHBOARD ── */
.dashboard-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:20px}
.credit-big{
  font-size:64px;color:var(--forest);letter-spacing:-.07em;line-height:1;
  font-weight:900;
}
.credit-big+span{display:block;color:var(--muted);font-size:12px;font-weight:800;margin-top:6px;text-transform:uppercase;letter-spacing:.1em}

/* ── HISTORY ── */
.history{display:grid;gap:10px}
.history-item{
  display:flex;justify-content:space-between;gap:16px;align-items:center;
  padding:18px;border:1px solid var(--line);border-radius:12px;background:#fff;
  box-shadow:0 2px 8px rgba(6,51,40,.04);transition:all .2s;
}
.history-item:hover{box-shadow:0 6px 20px rgba(6,51,40,.08);border-color:rgba(6,51,40,.16)}
.history-item strong{color:var(--forest);font-size:14px;font-weight:800}
.history-item span{color:var(--muted);font-size:12px;font-weight:700}

/* ── FORM FIELDS ── */
input[type="email"],input[type="text"],input[type="password"],select,textarea{
  width:100%;min-height:46px;
  border:1.5px solid var(--line);border-radius:10px;
  background:#fff;color:var(--forest);
  font:inherit;font-size:14px;font-weight:600;
  padding:0 14px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.12);
}
label{
  display:block;margin-bottom:6px;
  color:rgba(16,35,28,.55);font-size:11px;font-weight:900;
  letter-spacing:.08em;text-transform:uppercase;
}
.form-group{margin-bottom:16px}

@media(max-width:860px){
  .hero-grid,.report-shell,.dashboard-grid{grid-template-columns:1fr}
  .metrics,.locked-grid{grid-template-columns:1fr}
  .flow-topbar{height:auto;align-items:flex-start;gap:16px;flex-direction:column;padding:18px 22px}
  .flow-page{width:min(100% - 32px,1120px);padding-top:34px}
}
