:root {
  --bg: #EEF2FF;
  --card: #FFFFFF;
  --header: #1B2B47;
  --primary: #2E4E9E;
  --primary-light: #4F6FBE;
  --accent: #E8A020;
  --accent-light: #FFC84A;
  --success: #0F9E72;
  --danger: #D63031;
  --info: #0284C7;
  --text: #1A2340;
  --text-muted: #6B7A9A;
  --border: #D6DDEF;
  --shadow: 0 4px 24px rgba(30,43,71,0.10);
  --shadow-lg: 0 8px 40px rgba(30,43,71,0.16);
  --radius: 14px;
  --radius-sm: 8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Rubik',sans-serif;background:var(--bg);color:var(--text);min-height:auto;font-size:15px;line-height:1.6;overflow-x:hidden}

/* ── HEADER ── */
.header{background:var(--header);color:#fff;padding:16px 32px;position:sticky;top:0;z-index:10;box-shadow:0 2px 20px rgba(0,0,0,.25);will-change:transform}
.header-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563EB,#14B8A6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.brand-text{flex:1}
.brand-text h1{font-family:'Rubik',sans-serif;font-size:1.1rem;font-weight:600;letter-spacing:.01em;line-height:1.2}
.brand-text p{font-size:.7rem;color:#9BB4D0;font-weight:400;margin-top:2px}
.header-top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.step-indicator{background:rgba(255,255,255,.1);border-radius:20px;padding:6px 16px;font-size:.78rem;color:#C8D8F0;font-weight:500}
.timer-badge{background:rgba(232,160,32,.15);border:1px solid rgba(232,160,32,.4);border-radius:20px;padding:5px 14px;font-size:.76rem;color:var(--accent-light);display:flex;align-items:center;gap:6px}

/* ── PROGRESS ── */
.progress-wrap{padding-top:12px}
.progress-labels{display:flex;justify-content:space-between;font-size:.6rem;color:#6A85A0;margin-bottom:5px;padding:0 2px}
.progress-track{height:5px;background:rgba(255,255,255,.12);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--accent));border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1);width:10%}
.progress-dots{display:flex;justify-content:space-between;margin-top:8px}
.pdot{width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.15);font-size:.6rem;font-weight:700;color:rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;transition:all .3s}
.pdot.active{background:var(--primary-light);border-color:var(--primary-light);color:#fff}
.pdot.done{background:var(--success);border-color:var(--success);color:#fff}

/* ── MAIN ── */
.main{max-width:780px;margin:0 auto;padding:clamp(16px, 5vw, 32px) clamp(12px, 4vw, 20px) 80px;min-height:100%}

/* ── SECTIONS ── */
.section{display:none;animation:fadeSlide .4s ease}
.section.active{display:block}
@keyframes fadeSlide{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.section-header{margin-bottom:28px}
.section-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;padding:5px 14px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.section-title{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:700;color:var(--header);line-height:1.2;margin-bottom:6px}
.section-desc{color:var(--text-muted);font-size:.88rem;font-weight:300}
.time-hint{display:inline-flex;align-items:center;gap:5px;background:rgba(232,160,32,.1);color:var(--accent);font-size:.75rem;padding:3px 10px;border-radius:12px;margin-top:8px;font-weight:500}

/* ── CARDS ── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 28px;margin-bottom:16px;border:1px solid var(--border)}
.card-title{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--header);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.required-star{color:var(--danger);font-size:.8rem}
.card-sub{font-size:.8rem;color:var(--text-muted);margin-bottom:16px}

/* ── MICRO-INSIGHT ── */
.insight-card{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border:1px solid #BFDBFE;border-left:4px solid var(--primary);border-radius:var(--radius-sm);padding:14px 18px;margin:4px 0 16px;display:flex;gap:12px;align-items:flex-start}
.insight-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.insight-title{font-size:.72rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.insight-text{font-size:.82rem;color:#1E3A6E;line-height:1.55}
.insight-text strong{font-weight:700;color:var(--primary)}

/* ── FORM FIELDS ── */
.field-group{margin-bottom:20px}
.field-group:last-child{margin-bottom:0}
.field-label{font-size:.85rem;font-weight:500;color:var(--text);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.field-label .req{color:var(--danger)}
input[type="text"],input[type="email"],input[type="number"],select,textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Rubik',sans-serif;font-size:.88rem;color:var(--text);background:#FAFBFF;outline:none;transition:border-color .2s,box-shadow .2s}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:inset 0 0 0 3px rgba(46,78,158,.1);background:#fff}
textarea{resize:vertical;min-height:80px}
select{cursor:pointer}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.two-col{grid-template-columns:1fr}}

/* ── OPTION ITEMS ── */
.options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.options-grid.cols-2{grid-template-columns:1fr 1fr}
.options-grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:480px){.options-grid,.options-grid.cols-2,.options-grid.cols-3{grid-template-columns:1fr}}
.opt-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .18s;background:#FAFBFF;font-size:.84rem;user-select:none}
.opt-item:hover{border-color:var(--primary-light);background:#F0F4FF}
.opt-item input[type="radio"],.opt-item input[type="checkbox"]{width:auto;padding:0;margin-top:2px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.opt-item.selected{border-color:var(--primary);background:linear-gradient(135deg,#EEF2FF,#F0F4FF);color:var(--primary);font-weight:500}

/* ── AUTOEVALUACIÓN SLIDERS ── */
.autoeval-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}
.autoeval-row:last-child{border-bottom:none}
.autoeval-label{font-size:.83rem;color:var(--text);flex:1;min-width:0}
.autoeval-label small{display:block;font-size:.71rem;color:var(--text-muted);font-weight:300;margin-top:1px}
.autoeval-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}
input[type="range"].ae-slider{width:110px;height:4px;accent-color:var(--primary);cursor:pointer;border:none;outline:none;padding:0;background:var(--border);border-radius:2px}
.ae-val{min-width:30px;height:30px;border-radius:7px;background:var(--border);color:var(--text-muted);font-size:.82rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}
.ae-val.low{background:#FECACA;color:var(--danger)}
.ae-val.mid{background:#FEF3C7;color:#92400E}
.ae-val.high{background:#D1FAE5;color:var(--success)}
.imo-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#F0F9FF,#E0F2FE);border:1px solid #BAE6FD;border-radius:10px;padding:8px 16px;font-size:.8rem;color:#075985;font-weight:500;margin-top:12px}
.imo-score{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:700;color:var(--info)}

/* ── TIME TABLE ── */
.time-table{width:100%;border-collapse:collapse}
.time-table th{font-size:.75rem;font-weight:600;color:var(--text-muted);text-align:left;padding:8px 10px;background:#F5F7FF;border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:.06em}
.time-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:.83rem}
.time-table tr:last-child td{border-bottom:none}
.time-table tr:hover td{background:#F9FAFF}
.task-check{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}
.time-input{width:60px!important;padding:6px 8px!important;text-align:center}
.frust-wrap{display:flex;align-items:center;gap:6px}
.frust-wrap input[type="range"]{width:80px}
.frust-num{min-width:22px;height:22px;border-radius:4px;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;background:var(--border);color:var(--text-muted)}
@media(max-width:600px){.time-table{font-size:.75rem;overflow-x:auto;display:block}.time-table thead{display:none}.time-table tbody{display:block;overflow-x:auto}.time-table tr{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;border-bottom:1px solid var(--border)}.time-input{width:48px!important}.frust-wrap input[type="range"]{width:60px}}}

/* ── NAV ── */
.nav-bar{display:flex;justify-content:space-between;align-items:center;margin-top:28px;flex-wrap:wrap;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-family:'Rubik',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 4px 14px rgba(46,78,158,.35)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(46,78,158,.45)}
.btn-ghost{background:transparent;color:var(--text-muted);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:var(--header);box-shadow:0 4px 14px rgba(232,160,32,.35)}
.btn-accent:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,160,32,.45)}
.btn-lg{padding:14px 32px;font-size:1rem}
.btn svg{width:16px;height:16px}

/* ── RESULTS ── */
#section-results{display:none}
.results-header{text-align:center;margin-bottom:24px}
.results-title{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;color:var(--header);line-height:1.2}
.results-subtitle{color:var(--text-muted);font-size:.9rem;margin-top:6px}
.company-tag{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;padding:5px 18px;border-radius:20px;font-size:.82rem;font-weight:600;margin-top:10px}
.scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.score-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;text-align:center;border-top:4px solid var(--primary);transition:transform .2s}
.score-card:hover{transform:translateY(-2px)}
.score-card.accent{border-top-color:var(--accent)}
.score-card.success{border-top-color:var(--success)}
.score-card.danger{border-top-color:var(--danger)}
.score-card.info{border-top-color:var(--info)}
.score-card.purple{border-top-color:#7C3AED}
.score-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.score-value{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:700;line-height:1}
.score-card.accent .score-value{color:var(--accent)}
.score-card.success .score-value{color:var(--success)}
.score-card.danger .score-value{color:var(--danger)}
.score-card.info .score-value{color:var(--info)}
.score-card.purple .score-value{color:#7C3AED}
.score-card>.score-value{color:var(--primary)}
.score-sublabel{font-size:.75rem;color:var(--text-muted);margin-top:4px}
.score-bar{height:5px;background:var(--border);border-radius:3px;margin-top:10px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;transition:width 1.5s cubic-bezier(.4,0,.2,1) .3s;width:0%}
.score-card.accent .score-bar-fill{background:linear-gradient(90deg,var(--accent),var(--accent-light))}
.score-card.success .score-bar-fill{background:linear-gradient(90deg,#0F9E72,#2ED573)}
.score-card.danger .score-bar-fill{background:linear-gradient(90deg,var(--danger),#FF7675)}
.score-card.info .score-bar-fill{background:linear-gradient(90deg,var(--info),#38BDF8)}
.score-card.purple .score-bar-fill{background:linear-gradient(90deg,#7C3AED,#A78BFA)}
.score-card>.score-bar-fill{background:linear-gradient(90deg,var(--primary),var(--primary-light))}
.savings-banner{background:linear-gradient(135deg,var(--header),#2A4570);color:#fff;border-radius:var(--radius);padding:24px 28px;margin-bottom:24px;display:flex;justify-content:space-around;flex-wrap:wrap;gap:20px;box-shadow:var(--shadow-lg)}
.savings-item{text-align:center}
.savings-label{font-size:.72rem;color:#9BB4D0;font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.savings-amount{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;color:var(--accent-light)}
.savings-sub{font-size:.72rem;color:#7A9AB8}
.radar-container{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:24px;text-align:center;border:1px solid var(--border)}
.radar-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:var(--header);margin-bottom:16px}
.opps-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 28px;margin-bottom:24px;border:1px solid var(--border)}
.opps-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--header);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.opp-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border)}
.opp-item:last-child{border-bottom:none}
.opp-num{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.opp-name{font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:2px}
.opp-desc{font-size:.8rem;color:var(--text-muted)}
.opp-roi{margin-left:auto;flex-shrink:0;text-align:right}
.roi-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.72rem;font-weight:700}
.roi-badge.high{background:rgba(15,158,114,.15);color:var(--success)}
.roi-badge.medium{background:rgba(232,160,32,.15);color:#C57F10}
.print-actions{display:flex;gap:12px;justify-content:center;margin-top:28px;flex-wrap:wrap}

/* ── VALIDATION ── */
.field-error{font-size:.76rem;color:var(--danger);margin-top:5px;display:none}
.field-error.visible{display:block}
.invalid-field{border-color:var(--danger)!important}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--header);color:#fff;padding:12px 20px;border-radius:10px;font-size:.85rem;font-weight:500;box-shadow:0 8px 30px rgba(0,0,0,.25);transform:translateY(80px);opacity:0;transition:all .35s cubic-bezier(.4,0,.2,1);z-index:999;display:flex;align-items:center;gap:8px}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:var(--danger)}

/* ── INTRO ── */
#intro{text-align:center;padding:40px 20px}
.intro-logo{width:80px;height:80px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:22px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;font-size:36px;box-shadow:0 8px 30px rgba(46,78,158,.3)}
.intro-title{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:700;color:var(--header);line-height:1.2;margin-bottom:10px}
.intro-sub{font-size:1rem;color:var(--text-muted);max-width:520px;margin:0 auto 28px;font-weight:300}
.intro-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px}
.chip{background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:5px 14px;font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:5px}
.chip strong{color:var(--primary);font-weight:600}
.intro-meta{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.meta-item{text-align:center}
.meta-val{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;color:var(--primary)}
.meta-lbl{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}

@media print{
  .header,.nav-bar,.print-actions,.progress-dots,.progress-wrap{display:none!important}
  body{background:#fff}
  .card,.opps-section,.radar-container{box-shadow:none;break-inside:avoid}
  .section{display:block!important}
  #intro,.btn{display:none!important}
}
