/**
 * DEKKO · wizard.css
 * Estilos del wizard real · derivados del mockup v5 testado.
 */

:root{
  --ink:#1A232E;
  --ink-60:rgba(26,35,46,.60);
  --ink-30:rgba(26,35,46,.30);
  --ink-12:rgba(26,35,46,.12);
  --cream:#F0F4F8;
  --cream-2:#E5ECF2;
  --paper:#FFFFFF;
  --coral:#FF6B4A;
  --coral-d:#E85531;
  --coral-lt:#FFE4DD;
  --cyan:#9ACDCC;
  --cyan-lt:#DEF0EF;
  --green:#3FA972;
  --amber:#F2B330;
  --red:#E54B3D;
  --f-display:'Inter',system-ui,-apple-system,sans-serif;
  --f-body:'Inter',system-ui,sans-serif;
  --f-mono:'JetBrains Mono','SF Mono',Menlo,monospace;
  --hs-3:3px 3px 0 var(--ink);
  --hs-coral-3:3px 3px 0 var(--coral);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:var(--cream);color:var(--ink);font-family:var(--f-body);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}
body{display:flex;flex-direction:column}
[x-cloak]{display:none!important}

/* Save status */
.save-status{position:fixed;top:14px;right:14px;z-index:100;padding:6px 12px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:999px;font-family:var(--f-mono);font-size:11px;font-weight:600;color:var(--ink-60);box-shadow:var(--hs-3)}
.save-status.saved{color:var(--green);border-color:var(--green)}
.save-status.error{color:var(--red);border-color:var(--red)}

/* Topbar */
.topbar{flex-shrink:0;background:var(--paper);border-bottom:1.5px solid var(--ink-12);padding:12px 28px;display:flex;align-items:center;justify-content:space-between;height:54px}
.topbar .left{display:flex;align-items:center;gap:18px}
.dekko-wm{font-family:var(--f-display);font-weight:700;letter-spacing:-.04em;font-size:22px;color:var(--ink);display:inline-flex;align-items:baseline;line-height:1}
.dekko-wm::after{content:"·";color:var(--coral);font-weight:900;margin-left:.04em}
.breadcrumb{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-60);font-weight:600}
.breadcrumb b{color:var(--ink)}
.topbar .right{display:flex;align-items:center;gap:14px}
.step-meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--ink-60);font-weight:600}
.step-meta b{color:var(--ink)}
.lang-tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:3px 10px;border-radius:999px;background:var(--coral-lt);color:var(--coral);border:1.5px solid var(--coral)}
.close-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--ink-12);color:var(--ink-60);cursor:pointer;background:var(--paper);font-size:14px;font-weight:600}

/* Progress */
.progress-line{flex-shrink:0;height:4px;background:var(--ink-12);position:relative}
.progress-line .bar{position:absolute;top:0;left:0;height:100%;background:var(--coral);transition:width .35s ease;border-right:1.5px solid var(--ink)}

/* Step container */
.step-container{flex:1;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:24px 32px;min-height:0}
.step-container::-webkit-scrollbar{width:8px}
.step-container::-webkit-scrollbar-thumb{background:var(--ink-12);border-radius:4px}

.step-page{width:100%;max-width:780px;margin:0 auto;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.step-head{margin-bottom:20px}
.step-head h1{font-family:var(--f-display);font-weight:800;font-size:34px;letter-spacing:-.03em;line-height:1.05;margin:0;max-width:600px}
.step-head h1 .accent{color:var(--coral)}
.step-head .sub{margin-top:6px;font-size:14px;color:var(--ink-60);max-width:560px;line-height:1.4}

.card{background:var(--paper);border:1.5px solid var(--ink-12);border-radius:14px;padding:20px}
.card.compact{padding:16px}
.card-title{font-weight:700;font-size:13px;color:var(--ink);margin-bottom:5px}
.card-help{font-size:12px;color:var(--ink-60);margin-bottom:10px}
.req{color:var(--red);margin-left:2px}

/* Inputs */
.big-input{width:100%;padding:14px 18px;font-family:var(--f-display);font-weight:600;font-size:22px;letter-spacing:-.01em;color:var(--ink);background:var(--paper);border:1.5px solid var(--ink-12);border-radius:12px;outline:none;transition:all .12s ease}
.big-input:focus{border-color:var(--ink);box-shadow:var(--hs-3);transform:translate(-2px,-2px)}
.big-input::placeholder{color:var(--ink-30);font-weight:400}

input[type=text],input[type=email],input[type=tel],input[type=url],input[type=number],select,textarea{width:100%;padding:11px 14px;font-family:var(--f-body);font-size:14px;color:var(--ink);background:var(--paper);border:1.5px solid var(--ink-12);border-radius:10px;outline:none;transition:all .12s ease}
input:focus,select:focus,textarea:focus{border-color:var(--ink);box-shadow:var(--hs-3);transform:translate(-2px,-2px)}
input::placeholder{color:var(--ink-30)}
textarea{resize:vertical;min-height:80px;line-height:1.45}
label{display:block;font-weight:700;font-size:12px;color:var(--ink);margin-bottom:4px}

.field{margin-bottom:12px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* Choice grid */
.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:9px}
.choice{padding:14px 10px;border:1.5px solid var(--ink-12);border-radius:12px;cursor:pointer;text-align:center;transition:all .12s ease;background:var(--paper);position:relative;font-weight:600;font-size:14px}
.choice:hover{border-color:var(--ink);transform:translate(-2px,-2px);box-shadow:var(--hs-3)}
.choice.on{border-color:var(--ink);background:var(--ink);color:var(--paper);box-shadow:var(--hs-3);transform:translate(-2px,-2px)}
.choice.on::after{content:"✓";position:absolute;top:6px;right:8px;color:var(--coral);font-weight:900;font-size:13px}
.choice .desc{font-size:10px;color:var(--ink-60);margin-top:3px;font-weight:500}
.choice.on .desc{color:rgba(255,255,255,.7)}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{padding:8px 12px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .12s ease}
.chip:hover{border-color:var(--ink)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip.add{border-style:dashed;color:var(--coral);border-color:var(--coral);font-weight:700}

/* Radio chip (idioma principal) */
.radio-row{display:flex;flex-wrap:wrap;gap:7px}
.radio-chip{padding:9px 14px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px}
.radio-chip .ring{width:13px;height:13px;border-radius:50%;border:2px solid var(--ink-30)}
.radio-chip.on{background:var(--coral);color:var(--paper);border-color:var(--coral);box-shadow:var(--hs-3)}
.radio-chip.on .ring{border-color:var(--paper);background:var(--paper)}

/* Buttons */
.btn{font-family:var(--f-body);font-weight:700;font-size:13px;background:var(--coral);color:var(--paper);border:1.5px solid var(--ink);border-radius:999px;padding:10px 20px;cursor:pointer;box-shadow:var(--hs-3);transition:all .12s ease;display:inline-flex;align-items:center;gap:6px}
.btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.btn.ghost{background:var(--paper);color:var(--ink)}
.btn.lg{padding:12px 24px;font-size:14px}
.btn.sm{padding:6px 12px;font-size:11px}
.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}

/* Yes/No big */
.yn-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.yn-card{padding:24px 20px;border:2px solid var(--ink-12);border-radius:16px;cursor:pointer;background:var(--paper);transition:all .12s ease;text-align:center;position:relative}
.yn-card:hover{border-color:var(--ink);transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--ink)}
.yn-card.on{border-color:var(--coral);background:var(--coral-lt);box-shadow:var(--hs-coral-3);transform:translate(-3px,-3px)}
.yn-card .ic{width:48px;height:48px;border-radius:50%;background:var(--ink);color:var(--coral);display:grid;place-items:center;margin:0 auto 10px;font-weight:800;font-size:22px}
.yn-card.on .ic{background:var(--coral);color:var(--paper)}
.yn-card h3{margin:0;font-weight:800;font-size:18px;letter-spacing:-.02em;line-height:1.1}
.yn-card p{margin:5px 0 0;font-size:12px;color:var(--ink-60)}
.yn-card .savings{margin-top:8px;display:inline-block;padding:3px 8px;background:var(--coral);color:var(--paper);border-radius:999px;font-family:var(--f-mono);font-size:9px;letter-spacing:.06em;font-weight:700;text-transform:uppercase;border:1.5px solid var(--ink)}

/* Palettes */
.palettes{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.palette{padding:12px;border:1.5px solid var(--ink-12);border-radius:12px;cursor:pointer;background:var(--paper);transition:all .12s ease;position:relative}
.palette:hover{border-color:var(--ink);transform:translate(-2px,-2px);box-shadow:var(--hs-3)}
.palette.on{border-color:var(--ink);background:var(--cream);box-shadow:var(--hs-3);transform:translate(-2px,-2px)}
.palette.on::after{content:"✓";position:absolute;top:8px;right:12px;width:20px;height:20px;background:var(--coral);color:var(--paper);border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:900;border:1.5px solid var(--ink)}
.palette .name{font-weight:700;font-size:12px;margin-bottom:2px}
.palette .desc{font-size:9px;color:var(--ink-60);margin-bottom:8px;font-family:var(--f-mono)}
.palette .swatches{display:flex;height:26px;border-radius:5px;overflow:hidden;border:1.5px solid var(--ink)}
.palette .sw{flex:1;height:100%}

/* Font pair */
.fonts{display:grid;grid-template-columns:1fr;gap:9px}
.font-pair{padding:14px 18px;border:1.5px solid var(--ink-12);border-radius:12px;cursor:pointer;background:var(--paper);transition:all .12s ease;display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center;position:relative}
.font-pair:hover{border-color:var(--ink);transform:translate(-2px,-2px);box-shadow:var(--hs-3)}
.font-pair.on{border-color:var(--ink);background:var(--cream);box-shadow:var(--hs-3);transform:translate(-2px,-2px)}
.font-pair.on::after{content:"✓";position:absolute;top:12px;right:16px;width:20px;height:20px;background:var(--coral);color:var(--paper);border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:900;border:1.5px solid var(--ink)}
.font-pair .info .lbl{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--coral);font-weight:700;margin-bottom:2px}
.font-pair .info .name{font-weight:700;font-size:12px}
.font-pair .info .desc{font-size:10px;color:var(--ink-60);margin-top:2px}
.font-pair .preview .h{font-size:24px;letter-spacing:-.02em;line-height:1}
.font-pair .preview .b{font-size:11px;color:var(--ink-60);margin-top:4px}

/* Tip box */
.tip{margin-top:12px;padding:12px 14px;background:var(--cyan-lt);border:1.5px solid var(--cyan);border-radius:10px;display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--ink);line-height:1.45}
.tip .ic{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--ink);color:var(--cyan);display:grid;place-items:center;font-weight:800;font-size:10px}

/* Upload zones */
.upload-zone{padding:24px 16px;background:var(--cream);border:2px dashed var(--ink-30);border-radius:12px;text-align:center;cursor:pointer;transition:all .12s ease}
.upload-zone:hover{border-color:var(--coral);background:var(--coral-lt)}
.upload-zone .ic{width:48px;height:48px;border-radius:12px;background:var(--ink);color:var(--coral);display:grid;place-items:center;margin:0 auto 8px;font-size:20px;font-weight:800}
.upload-zone b{display:block;font-weight:700;font-size:16px;margin-bottom:3px}
.upload-zone small{font-size:12px;color:var(--ink-60)}

.uploaded-list{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;margin-top:10px}
.uploaded{aspect-ratio:1;border-radius:8px;border:1.5px solid var(--ink);display:grid;place-items:center;color:var(--paper);font-family:var(--f-mono);font-size:8px;font-weight:600;text-transform:uppercase;position:relative;background:linear-gradient(135deg,#0a3245 0%,#0B2545 100%)}
.uploaded::after{content:"✓";position:absolute;top:3px;right:5px;color:var(--coral);font-weight:900;font-size:10px}

/* List editor (spots, equipo, viajes) */
.list-editor{display:flex;flex-direction:column;gap:6px}
.list-row{display:grid;grid-template-columns:auto 1fr 100px 120px auto;gap:8px;align-items:center;padding:8px 10px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:10px}
.list-row .num{width:24px;height:24px;border-radius:6px;background:var(--coral);color:var(--paper);display:grid;place-items:center;font-weight:800;font-size:12px;border:1.5px solid var(--ink)}
.list-row input,.list-row select{padding:6px 9px;font-size:12px}
.list-row .del{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--ink-12);background:var(--paper);color:var(--ink-60);cursor:pointer;font-size:12px;font-weight:700}
.list-row .del:hover{border-color:var(--red);color:var(--red)}
.add-row-btn{margin-top:6px;padding:8px 14px;background:var(--paper);border:1.5px dashed var(--coral);border-radius:8px;color:var(--coral);font-weight:700;font-size:12px;cursor:pointer;text-align:center;transition:all .12s ease}
.add-row-btn:hover{background:var(--coral-lt)}

/* Course rows */
.course-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.course-row{display:grid;grid-template-columns:24px 1fr 90px;gap:8px;align-items:center;padding:8px 10px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:10px;cursor:pointer}
.course-row:hover{border-color:var(--ink)}
.course-row.on{border-color:var(--coral);background:var(--coral-lt)}
.course-row .check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--ink-30);background:var(--paper);display:grid;place-items:center;color:transparent;font-weight:900}
.course-row.on .check{background:var(--coral);color:var(--paper);border-color:var(--ink)}

/* Schedule modular */
.sched-table{display:flex;flex-direction:column;gap:5px;margin-top:6px}
.sched-row{display:grid;grid-template-columns:42px 78px 1fr 26px;gap:8px;align-items:center;padding:5px 10px;background:var(--paper);border:1.5px solid var(--ink-12);border-radius:8px}
.sched-row.off{opacity:.5;background:var(--cream)}
.sched-day{font-weight:700;font-size:12px}
.sched-toggle{padding:3px 8px;border-radius:999px;font-family:var(--f-mono);font-size:9px;font-weight:700;text-transform:uppercase;background:var(--cream-2);color:var(--ink-60);cursor:pointer;text-align:center;border:1.5px solid var(--ink-12)}
.sched-toggle.on{background:var(--green);color:var(--paper);border-color:var(--green)}
.sched-shifts{display:flex;flex-direction:column;gap:3px}
.sched-shift{display:flex;align-items:center;gap:5px}
.sched-shift input[type=time]{padding:3px 7px;font-family:var(--f-mono);font-size:10px;width:70px}
.sched-shift .dash{color:var(--ink-30)}
.sched-add{width:22px;height:22px;border-radius:50%;border:1.5px dashed var(--coral);background:var(--paper);color:var(--coral);cursor:pointer;font-size:13px;font-weight:700}

/* Approve card */
.approve{padding:24px;background:var(--ink);color:var(--cream);border-radius:14px;box-shadow:var(--hs-coral-3);text-align:center}
.approve h3{margin:0 0 14px;font-weight:800;font-size:24px;letter-spacing:-.02em;line-height:1.15}
.approve p{margin:0 0 20px;color:rgba(240,244,248,.75);font-size:13px;line-height:1.5}

/* Nav foot */
.nav-foot{flex-shrink:0;background:var(--paper);border-top:1.5px solid var(--ink-12);padding:12px 28px;display:flex;justify-content:space-between;align-items:center;height:56px}
.nav-foot .hint{font-family:var(--f-mono);font-size:11px;color:var(--ink-60);font-weight:600}
.nav-foot > div:last-child{display:flex;gap:8px}
