/* ===========================================================
   Antesdefirma — Plataforma multi-rol (capa compartida)
   Cliente · Arquitecto · Admin — sobre el sistema base.
   =========================================================== */

/* ---------- ROLE CHOOSER (login) ---------- */
.role-pick{display:flex;flex-direction:column;gap:10px;margin:24px 0 8px;}
.role-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 16px;cursor:pointer;text-decoration:none;transition:.15s;text-align:left;}
.role-card:hover{border-color:var(--sage);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.role-card .ic{width:44px;height:44px;border-radius:12px;background:var(--tint);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.role-card .ic svg{width:22px;height:22px;stroke:var(--sage);}
.role-card .t{font-family:'Outfit',sans-serif;font-weight:700;font-size:15.5px;color:var(--ink);}
.role-card .d{font-size:13px;color:var(--muted);margin-top:1px;}
.role-card .arr{margin-left:auto;color:var(--muted);}
.role-card .arr svg{width:18px;height:18px;stroke:currentColor;}
.demo-tag{display:inline-flex;align-items:center;gap:6px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);padding:5px 10px;border-radius:var(--r-pill);}

/* role badge en topbar + switcher */
.role-switch{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:6px 8px 6px 14px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-2);white-space:nowrap;}
.role-switch span{white-space:nowrap;}
.role-switch b{color:var(--ink);}
.role-switch svg{width:15px;height:15px;stroke:var(--muted);}

/* ---------- STEPPER HORIZONTAL (cliente resumen) ---------- */
.stepper{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px 26px;margin-bottom:24px;}
.stepper-row{display:flex;align-items:flex-start;gap:0;}
.stp{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;min-width:0;}
.stp .bub{width:42px;height:42px;border-radius:50%;background:#fff;border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;z-index:2;transition:.2s;}
.stp .bub svg{width:19px;height:19px;stroke:var(--muted);}
.stp .bub .nn{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;color:var(--muted);}
.stp .lab{font-size:12.5px;font-weight:600;color:var(--ink-2);margin-top:10px;line-height:1.25;max-width:13ch;}
.stp .ln{position:absolute;top:21px;left:50%;width:100%;height:2.5px;background:var(--line);z-index:1;}
.stp:last-child .ln{display:none;}
.stp.done .bub{background:var(--sage);border-color:var(--sage);}
.stp.done .bub svg{stroke:#fff;}
.stp.done .ln{background:var(--sage);}
.stp.current .bub{border-color:var(--sage);box-shadow:0 0 0 5px rgba(74,124,89,.16);}
.stp.current .bub .nn{color:var(--sage);}
.stp.current .lab{color:var(--sage-d);}
.stepper .cap{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;}
@media(max-width:680px){
  .stepper-row{flex-direction:column;gap:0;align-items:stretch;}
  .stp{flex-direction:row;align-items:center;text-align:left;gap:14px;padding:8px 0;}
  .stp .lab{max-width:none;margin-top:0;}
  .stp .ln{top:42px;left:20px;width:2.5px;height:100%;}
}

/* ---------- TABLAS / LISTAS (admin) ---------- */
.adm-grid{display:grid;gap:18px;}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
@media(max-width:900px){.kpi-row{grid-template-columns:1fr 1fr;}}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;}
.kpi .lab{font-family:'Space Grotesk',sans-serif;font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.kpi .val{font-family:'Outfit',sans-serif;font-weight:700;font-size:32px;color:var(--ink);letter-spacing:-0.02em;margin-top:6px;line-height:1;}
.kpi .delta{font-size:12.5px;font-weight:600;margin-top:8px;display:inline-flex;align-items:center;gap:4px;}
.kpi .delta.up{color:var(--sage-d);}
.kpi .delta.flat{color:var(--muted);}

.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:22px;}
.panel-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line);}
.panel-h h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:var(--ink);}
.panel-h .sub{font-size:13px;color:var(--muted);margin-top:2px;}

.tbl{width:100%;border-collapse:collapse;}
.tbl th{text-align:left;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:12px 22px;border-bottom:1px solid var(--line);}
.tbl td{padding:15px 22px;border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-2);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr.click{cursor:pointer;transition:.12s;}
.tbl tr.click:hover{background:var(--bg-2);}
.tbl .who{display:flex;align-items:center;gap:11px;}
.tbl .av{width:34px;height:34px;border-radius:50%;background:var(--sage);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:13px;flex-shrink:0;}
.tbl .nm{font-weight:600;color:var(--ink);}
.tbl .mut{color:var(--muted);font-size:12.5px;}
@media(max-width:760px){.tbl thead{display:none;}.tbl td{display:flex;justify-content:space-between;gap:14px;padding:10px 18px;border:none;}.tbl tr{display:block;border-bottom:1px solid var(--line);padding:8px 0;}.tbl td::before{content:attr(data-l);font-family:'Space Grotesk',sans-serif;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);}}

/* badges de estado */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;padding:6px 11px;border-radius:var(--r-pill);white-space:nowrap;}
.pill.gray{background:var(--bg-2);color:var(--muted);}
.pill.green{background:var(--tint);color:var(--sage-d);}
.pill.amber{background:#f7ecdc;color:#9a6520;}
.pill.red{background:#f6e3e0;color:#a8463c;}
.pill.blue{background:#e4ecf4;color:#3a6491;}
.pill.dot::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;}

/* ---------- ARQUITECTO: shell móvil-first ---------- */
.ar-body{background:var(--bg-2);min-height:100vh;}
.ar-top{position:sticky;top:0;z-index:40;background:var(--forest-2);color:#fff;padding:14px 18px;display:flex;align-items:center;gap:12px;}
.ar-top .brand .wm{font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;color:#fff;letter-spacing:-0.03em;}
.ar-top .brand .wm b{color:var(--sage-soft);}
.ar-top .role-switch{margin-left:auto;background:rgba(255,255,255,.1);border-color:transparent;color:#cfe0d6;}
.ar-top .role-switch b{color:#fff;}
.ar-top .role-switch svg{stroke:#9fb6a8;}
.ar-wrap{max-width:760px;margin:0 auto;padding:20px 16px 90px;}
.ar-h{font-family:'Outfit',sans-serif;font-weight:700;font-size:22px;color:var(--ink);letter-spacing:-0.02em;margin:0 0 4px;}
.ar-sub{color:var(--ink-2);font-size:14px;margin:0 0 20px;}

/* tabbar inferior (móvil) */
.ar-tabbar{position:fixed;bottom:0;left:0;right:0;z-index:50;background:#fff;border-top:1px solid var(--line);display:flex;justify-content:space-around;padding:8px 6px calc(8px + env(safe-area-inset-bottom));}
.ar-tabbar a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:600;color:var(--muted);cursor:pointer;padding:4px 12px;border-radius:10px;}
.ar-tabbar a svg{width:22px;height:22px;stroke:currentColor;}
.ar-tabbar a.active{color:var(--sage);}

/* encargo card */
.enc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:14px;display:block;text-decoration:none;color:inherit;transition:.15s;cursor:pointer;}
.enc-card:hover{border-color:var(--sage);box-shadow:var(--shadow-sm);}
.enc-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.enc-card .addr{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:var(--ink);}
.enc-card .ref{font-size:12.5px;color:var(--muted);margin-top:2px;font-family:'Space Grotesk',sans-serif;}
.enc-card .row{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap;}
.enc-card .row .it{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-2);}
.enc-card .row .it svg{width:15px;height:15px;stroke:var(--sage);flex-shrink:0;}

/* ---------- ITE: formulario por secciones ---------- */
.ite-sec{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:14px;overflow:hidden;}
.ite-head{display:flex;align-items:center;gap:13px;padding:16px 18px;cursor:pointer;}
.ite-head .ico{width:38px;height:38px;border-radius:10px;background:var(--tint);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ite-head .ico svg{width:20px;height:20px;stroke:var(--sage);}
.ite-head .t{flex:1;font-family:'Outfit',sans-serif;font-weight:700;font-size:15.5px;color:var(--ink);}
.ite-head .sev{display:flex;gap:5px;}
.ite-head .chev{width:20px;height:20px;stroke:var(--muted);transition:.2s;}
.ite-sec.open .ite-head .chev{transform:rotate(180deg);}
.ite-body{display:none;padding:4px 18px 20px;}
.ite-sec.open .ite-body{display:block;}

/* selector de severidad (semáforo) */
.sev-pick{display:flex;gap:8px;margin:6px 0 16px;}
.sev-pick button{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border-radius:11px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:'Manrope',sans-serif;font-weight:600;font-size:13px;color:var(--ink-2);transition:.12s;}
.sev-pick button .d{width:11px;height:11px;border-radius:50%;}
.sev-pick button .d.ok{background:var(--ok);}
.sev-pick button .d.warn{background:var(--warn);}
.sev-pick button .d.risk{background:var(--risk);}
.sev-pick button.sel.ok{border-color:var(--ok);background:var(--tint);color:var(--sage-d);}
.sev-pick button.sel.warn{border-color:var(--warn);background:#f7ecdc;color:#9a6520;}
.sev-pick button.sel.risk{border-color:var(--risk);background:#f6e3e0;color:#a8463c;}
.sev-dot{width:9px;height:9px;border-radius:50%;display:inline-block;}
.sev-dot.ok{background:var(--ok);}.sev-dot.warn{background:var(--warn);}.sev-dot.risk{background:var(--risk);}.sev-dot.none{background:var(--line-2);}

.fld-lab{font-size:13px;font-weight:600;color:var(--ink);margin:0 0 8px;display:block;}
textarea.ite-obs{width:100%;border:1px solid var(--line-2);border-radius:11px;padding:12px 14px;font-family:'Manrope',sans-serif;font-size:14px;color:var(--ink);resize:vertical;min-height:84px;outline:none;background:var(--cream);}
textarea.ite-obs:focus{border-color:var(--sage);}

/* nota de voz */
.voice{display:flex;align-items:center;gap:12px;margin:14px 0;padding:12px 14px;border-radius:12px;background:var(--bg-2);border:1px solid var(--line);}
.voice .rec{width:44px;height:44px;border-radius:50%;background:var(--sage);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s;}
.voice .rec svg{width:20px;height:20px;stroke:#fff;fill:none;}
.voice .rec.recording{background:var(--risk);animation:pulse 1.3s infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(180,85,75,.5);}50%{box-shadow:0 0 0 8px rgba(180,85,75,0);}}
.voice .info{flex:1;font-size:13px;color:var(--ink-2);}
.voice .info b{color:var(--ink);font-family:'Outfit',sans-serif;}
.transcript{margin-top:12px;padding:14px;border-radius:11px;background:#fff;border:1px dashed var(--sage-soft);font-size:13.5px;color:var(--ink-2);line-height:1.5;display:none;}
.transcript.show{display:block;}
.transcript .lab{font-family:'Space Grotesk',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--sage);margin-bottom:7px;display:flex;align-items:center;gap:6px;}
.transcript .ai-btn{margin-top:12px;}

/* fotos */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:10px;margin:10px 0 4px;}
.photo-add{aspect-ratio:1;border:2px dashed var(--line-2);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;color:var(--muted);font-size:11px;font-weight:600;background:var(--cream);transition:.12s;}
.photo-add:hover{border-color:var(--sage);color:var(--sage);}
.photo-add svg{width:22px;height:22px;stroke:currentColor;}
.photo-thumb{aspect-ratio:1;border-radius:12px;overflow:hidden;position:relative;background:var(--tint);display:flex;align-items:center;justify-content:center;}
.photo-thumb svg{width:26px;height:26px;stroke:var(--sage);opacity:.6;}
.photo-thumb .x{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(16,40,56,.7);color:#fff;border:none;cursor:pointer;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;}
.photo-thumb .nm{position:absolute;bottom:0;left:0;right:0;background:rgba(16,40,56,.6);color:#fff;font-size:9px;padding:3px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* firma */
.sign-box{border:1.5px solid var(--line-2);border-radius:12px;background:#fff;position:relative;overflow:hidden;}
.sign-box canvas{display:block;width:100%;height:160px;touch-action:none;cursor:crosshair;}
.sign-box .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--line-2);font-size:14px;pointer-events:none;font-family:'Outfit',sans-serif;}
.sign-box.signed .ph{display:none;}
.sign-actions{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
.sign-clear{background:none;border:none;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;}

/* barra de progreso ITE + submit fijo */
.ite-progress{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 20px;margin-bottom:16px;display:flex;align-items:center;gap:16px;}
.ite-progress .bar{flex:1;height:8px;border-radius:var(--r-pill);background:var(--line);overflow:hidden;}
.ite-progress .bar i{display:block;height:100%;background:var(--sage);border-radius:var(--r-pill);transition:.3s;}
.ite-progress .n{font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;color:var(--ink);white-space:nowrap;}

/* mapa de zonas (perfil arquitecto) */
.zone-map{background:linear-gradient(135deg,#e9efe9,#dfeadf);border:1px solid var(--line);border-radius:var(--r-lg);height:200px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.zone-map .pin{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--sage);border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.2);}
.zone-map .radius{position:absolute;border-radius:50%;border:2px dashed var(--sage);background:rgba(74,124,89,.08);}
.chips-in{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.chip-z{display:inline-flex;align-items:center;gap:7px;background:var(--tint);color:var(--sage-d);border:1px solid var(--tint-2);border-radius:var(--r-pill);padding:7px 12px;font-size:13px;font-weight:600;}
.chip-z button{background:none;border:none;color:var(--sage-d);cursor:pointer;font-size:14px;line-height:1;opacity:.7;}

/* calendario disponibilidad */
.cal{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.cal-head h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:var(--ink);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-dow{text-align:center;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;color:var(--muted);padding-bottom:6px;}
.cal-day{aspect-ratio:1;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:13.5px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:.1s;}
.cal-day:hover{border-color:var(--sage);}
.cal-day.off{color:var(--line-2);cursor:default;border-color:transparent;}
.cal-day.avail{background:var(--tint);border-color:var(--tint-2);color:var(--sage-d);}
.cal-day.booked{background:var(--forest);color:#fff;border-color:transparent;}
.cal-day.blocked{background:#f6e3e0;border-color:#eccfca;color:#a8463c;text-decoration:line-through;}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:16px;font-size:12.5px;color:var(--ink-2);}
.cal-legend .lg{display:flex;align-items:center;gap:7px;}
.cal-legend .sw{width:14px;height:14px;border-radius:4px;}

/* perfil form genérico */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 28px;margin-bottom:18px;}
.form-card h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:var(--ink);margin:0 0 18px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:620px){.form-grid{grid-template-columns:1fr;}}
.fg-full{grid-column:1/-1;}
.fld label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:7px;}
.fld input,.fld select{width:100%;border:1px solid var(--line-2);border-radius:11px;padding:12px 14px;font-family:'Manrope',sans-serif;font-size:14.5px;color:var(--ink);background:var(--cream);outline:none;}
.fld input:focus,.fld select:focus{border-color:var(--sage);}

/* facturas */
.inv-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);}
.inv-row:last-child{border-bottom:none;}
.inv-row .ic{width:40px;height:40px;border-radius:10px;background:var(--tint);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.inv-row .ic svg{width:19px;height:19px;stroke:var(--sage);}
.inv-row .meta{flex:1;}
.inv-row .meta .n{font-weight:700;color:var(--ink);font-size:14.5px;font-family:'Outfit',sans-serif;}
.inv-row .meta .d{font-size:12.5px;color:var(--muted);}
.inv-row .amt{font-family:'Outfit',sans-serif;font-weight:700;color:var(--ink);font-size:15px;}

/* consolidación de informe (admin) */
.merge{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
@media(max-width:760px){.merge{grid-template-columns:1fr;}}
.merge .src{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;}
.merge .src h4{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;color:var(--ink);margin:0 0 4px;display:flex;align-items:center;gap:8px;}
.merge .src .by{font-size:12px;color:var(--muted);margin-bottom:14px;}
.verdict-pick{display:flex;gap:10px;margin:8px 0 4px;}
.verdict-pick button{flex:1;padding:14px;border-radius:12px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;color:var(--ink-2);transition:.12s;}
.verdict-pick button.sel.buy{border-color:var(--ok);background:var(--tint);color:var(--sage-d);}
.verdict-pick button.sel.neg{border-color:var(--warn);background:#f7ecdc;color:#9a6520;}
.verdict-pick button.sel.no{border-color:var(--risk);background:#f6e3e0;color:#a8463c;}

.hidden{display:none !important;}

/* ---------- MODAL ---------- */
.modal-ov{position:fixed;inset:0;z-index:90;background:rgba(16,40,56,.46);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:.2s;}
.modal-ov.open{opacity:1;pointer-events:auto;}
.modal{background:var(--bg);border-radius:var(--r-lg);width:min(520px,100%);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translateY(14px) scale(.98);transition:.22s;}
.modal-ov.open .modal{transform:none;}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 0;}
.modal-h h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:20px;color:var(--ink);}
.modal-h .x{width:38px;height:38px;border:none;background:#fff;border:1px solid var(--line);border-radius:11px;cursor:pointer;font-size:20px;color:var(--muted);display:flex;align-items:center;justify-content:center;}
.modal-b{padding:18px 26px 26px;}
.modal-b .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.modal-b .fg-full{grid-column:1/-1;}
.modal-b .fld label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:7px;}
.modal-b .fld input,.modal-b .fld select{width:100%;box-sizing:border-box;border:1px solid var(--line-2);border-radius:11px;padding:11px 14px;font-family:'Manrope',sans-serif;font-size:14.5px;color:var(--ink);background:var(--cream);outline:none;}
.modal-b .fld input:focus,.modal-b .fld select:focus{border-color:var(--sage);}
.star-rate{display:flex;gap:6px;font-size:34px;color:var(--line-2);cursor:pointer;}
.star-rate span{transition:.1s;}
.star-rate span.on,.star-rate span.hover{color:var(--warn);}

/* ---------- COMPLETAR ENCARGO (onboarding cliente) ---------- */
.complete-banner{display:flex;gap:16px;align-items:flex-start;background:var(--tint);border:1px solid var(--tint-2);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:22px;}
.complete-banner .ic{width:44px;height:44px;border-radius:12px;background:var(--sage);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.complete-banner .ic svg{width:24px;height:24px;stroke:#fff;}
.complete-banner h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;color:var(--ink);margin:0 0 5px;}
.complete-banner p{font-size:14px;color:var(--ink-2);margin:0;line-height:1.55;}
.onboard-steps{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap;}
.onboard-steps .ob{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 16px;}
.onboard-steps .ob .n{width:22px;height:22px;border-radius:50%;background:var(--bg-2);color:var(--muted);display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:12px;}
.onboard-steps .ob.current{border-color:var(--sage);color:var(--sage-d);}
.onboard-steps .ob.current .n{background:var(--sage);color:#fff;}
.onboard-steps .ob.done .n{background:var(--sage);color:#fff;}
.ob-err{color:var(--risk);font-size:13px;font-weight:600;margin:14px 0 0;display:none;}
.ob-err.show{display:block;}
.mandato{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:20px 22px;max-height:230px;overflow-y:auto;font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.mandato p{margin:0 0 12px;}
.mandato ul{margin:0 0 12px;padding-left:20px;}
.mandato li{margin-bottom:6px;}
.mand-check{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;}
.mand-check input{width:18px;height:18px;accent-color:var(--sage);flex-shrink:0;}

/* badge estados del pedido */
.pt-order .badge.pagado{background:#e4ecf4;color:#3a6491;}
.pt-order .badge.pendiente{background:#f7ecdc;color:#9a6520;}

/* ---------- FIRMA CERTIFICADA (letrado) ---------- */
.cert-card{border:1px solid var(--sage-soft) !important;background:linear-gradient(180deg,#fff,#f7fbf8) !important;}
.cert-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px;}
.cert-ic{width:46px;height:46px;border-radius:12px;background:var(--sage);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cert-ic svg{width:24px;height:24px;stroke:#fff;}
.cert-signer{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
@media(max-width:620px){.cert-signer{grid-template-columns:1fr;}}
.cert-pick select{width:100%;box-sizing:border-box;border:1px solid var(--line-2);border-radius:11px;padding:12px 14px;font-family:'Manrope',sans-serif;font-size:14px;color:var(--ink);background:var(--cream);outline:none;}
.cert-pick select:focus{border-color:var(--sage);}
.cert-methods{display:flex;gap:8px;}
.cert-methods .cm{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border-radius:11px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:'Manrope',sans-serif;font-weight:600;font-size:13px;color:var(--ink-2);transition:.12s;}
.cert-methods .cm.sel{border-color:var(--sage);background:var(--tint);color:var(--sage-d);}
.cert-doc{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:9px;}
.cert-doc-row{display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:13px;color:var(--ink-2);}
.cert-doc-row span{color:var(--muted);}
.cert-doc-row b{color:var(--ink);font-family:'Outfit',sans-serif;font-weight:600;}
.cert-doc-row code{font-family:'Space Grotesk',sans-serif;font-size:12.5px;color:var(--sage-d);background:var(--tint);padding:3px 8px;border-radius:6px;}
.cert-done{display:none;margin-top:16px;border-radius:12px;overflow:hidden;border:1px solid var(--sage);}
.cert-done.show{display:block;}
.cert-done-h{background:var(--sage);color:#fff;padding:12px 16px;font-family:'Outfit',sans-serif;font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:9px;}
.cert-done-b{background:#fff;padding:14px 16px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--ink-2);}
.cert-done-b .r{display:flex;justify-content:space-between;gap:12px;}
.cert-done-b .r span{color:var(--muted);}
.cert-done-b .r b{color:var(--ink);font-weight:600;text-align:right;word-break:break-all;}
.cert-done-b .seal{display:inline-flex;align-items:center;gap:6px;color:var(--sage-d);font-weight:600;font-family:'Space Grotesk',sans-serif;font-size:11px;letter-spacing:.04em;text-transform:uppercase;}
