:root{
  --bg:#f5f1e8;
  --paper:#fffaf0;
  --ink:#1f2a24;
  --muted:#66736b;
  --accent:#0f6b4f;
  --accent2:#d6a64f;
  --line:#e4dccb;
  --danger:#9e3f34;
  --shadow:0 18px 55px rgba(31,42,36,.12);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink);
  background:radial-gradient(circle at top left,#fff7df 0,#f5f1e8 38%,#edf3ee 100%);
}
.hero{
  max-width:1180px;
  margin:0 auto;
  padding:28px 20px 34px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:32px;
}
.brand-mark{
  width:56px;height:56px;border-radius:18px;
  display:grid;place-items:center;
  color:white;background:linear-gradient(135deg,var(--accent),#12392d);
  font-weight:800;letter-spacing:.5px;
  box-shadow:var(--shadow);
}
.brand-title{font-weight:800;font-size:1.18rem}
.brand-subtitle{color:var(--muted);font-size:.95rem}
.hero-card{
  padding:44px;
  border:1px solid rgba(15,107,79,.18);
  border-radius:32px;
  background:linear-gradient(135deg,rgba(255,250,240,.96),rgba(255,255,255,.82));
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}
.hero-card:after{
  content:"";
  position:absolute;right:-90px;top:-120px;
  width:330px;height:330px;border-radius:50%;
  background:rgba(214,166,79,.18);
}
.eyebrow{
  color:var(--accent);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.76rem;
  margin:0 0 10px;
}
h1{font-size:clamp(2.2rem,5vw,4.8rem);line-height:.96;margin:0 0 18px;max-width:850px}
h2{font-size:clamp(1.6rem,3vw,2.5rem);margin:0 0 12px}
h3{font-size:1.35rem;margin:0 0 16px}
.lead{max-width:720px;font-size:1.22rem;color:var(--muted);line-height:1.5}
.hero-actions,.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.button{
  appearance:none;border:0;border-radius:999px;
  padding:14px 20px;
  font-weight:800;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
}
.primary{background:var(--accent);color:white}
.ghost{background:white;color:var(--accent);border:1px solid rgba(15,107,79,.25)}
main{max-width:1180px;margin:0 auto;padding:0 20px 44px}
.info-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px
}
.info-grid article,.panel{
  background:rgba(255,250,240,.9);
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:0 10px 30px rgba(31,42,36,.07);
}
.info-grid article{padding:22px;display:grid;gap:8px}
.info-grid span{color:var(--muted);line-height:1.45}
.panel{padding:30px;margin:18px 0}
.form-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px
}
label{display:grid;gap:7px;font-weight:700;color:var(--ink)}
input,select{
  width:100%;
  border:1px solid #d8d0bf;
  border-radius:14px;
  padding:13px 14px;
  background:white;
  color:var(--ink);
  font-size:1rem;
}
.privacy-box{background:#fff;border:1px dashed #d8d0bf;border-radius:18px;padding:16px;margin:18px 0}
.check{display:flex;gap:12px;align-items:flex-start;font-weight:500;color:var(--muted)}
.check input{width:auto;margin-top:3px}
.progress-wrap{margin:20px 0 26px}
.progress-label{display:flex;justify-content:space-between;font-weight:800;margin-bottom:8px}
.progress{height:12px;background:white;border-radius:999px;overflow:hidden;border:1px solid var(--line)}
#progressBar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:.25s}
.area{
  margin:22px 0 28px;
  padding:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.58);
  border-radius:22px;
}
.area h3{display:flex;align-items:center;gap:10px}
.badge{
  background:rgba(15,107,79,.1);color:var(--accent);
  border-radius:999px;padding:6px 10px;font-size:.78rem
}
.question{
  padding:16px 0;
  border-top:1px solid var(--line);
}
.question p{margin:0 0 12px;font-weight:750}
.options{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
}
.option{
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px;
  background:white;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:.92rem;
  cursor:pointer;
}
.option input{width:auto}
.hidden{display:none}
.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.radar-card,.score-card,.protocol-card{
  background:white;border:1px solid var(--line);border-radius:22px;padding:22px
}
canvas{width:100%;height:auto}
.score-row{margin:12px 0}
.score-row .top{display:flex;justify-content:space-between;font-weight:800;margin-bottom:6px}
.meter{height:12px;background:#f0eadc;border-radius:999px;overflow:hidden}
.meter div{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.protocol-table{width:100%;border-collapse:collapse;margin:10px 0 16px}
.protocol-table td,.protocol-table th{border-bottom:1px solid var(--line);padding:10px;text-align:left}
.protocol-table td:last-child,.protocol-table th:last-child{text-align:right}
.total{font-size:1.5rem;font-weight:900;color:var(--accent)}
.small p{color:var(--muted);line-height:1.55}
footer{max-width:1180px;margin:0 auto;padding:28px 20px;color:var(--muted)}
@media(max-width:850px){
  .hero-card{padding:28px}
  .info-grid,.form-grid,.results-grid{grid-template-columns:1fr}
  .options{grid-template-columns:1fr}
}
@media print{
  body{background:white}
  .hero-actions,.no-print,.progress-wrap,footer{display:none!important}
  .hero,.panel,main{padding:0;margin:0;max-width:none}
  .hero-card,.panel,.info-grid article{box-shadow:none;border:1px solid #ddd}
  .info-grid,#questionario{display:none}
  #results{display:block!important}
}

.recommended-box{
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  margin:16px 0;
  background:#fffaf0;
}
.recommended-box.combined{
  background:linear-gradient(135deg,rgba(15,107,79,.08),rgba(214,166,79,.11));
  border-color:rgba(15,107,79,.22);
}
.subhead{margin-top:26px}
.module-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin:16px 0 20px;
}
.module-card{
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  background:white;
}
.module-card h5{
  font-size:1.05rem;
  margin:6px 0 8px;
}
.module-card p{
  color:var(--muted);
  line-height:1.42;
  margin:0 0 10px;
}
.module-reason{
  display:inline-flex;
  border-radius:999px;
  padding:5px 9px;
  background:rgba(15,107,79,.1);
  color:var(--accent);
  font-size:.78rem;
  font-weight:800;
}
.mini-table{
  width:100%;
  border-collapse:collapse;
  font-size:.92rem;
  margin:8px 0 10px;
}
.mini-table td{
  border-bottom:1px solid var(--line);
  padding:7px 0;
}
.mini-table td:last-child{text-align:right;font-weight:700}
@media(max-width:850px){
  .module-grid{grid-template-columns:1fr}
}
