:root{
  --bg:#ffffff;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e5e7eb;
  --primary:#f0b129;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Arial, Helvetica, sans-serif;background:var(--bg);color:var(--ink);}
.wrap{max-width:980px;margin:0 auto;padding:14px 14px 28px;}
.top{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:10px;}
.brand{font-weight:900;font-size:18px;letter-spacing:.2px}
.hint{color:var(--muted);font-size:12px}
.panel{padding:14px 0 4px;display:flex;flex-direction:column;gap:10px;}
.names{display:flex;gap:10px;flex-wrap:wrap;}
.name-btn{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:14px;padding:10px 12px;font-weight:800;cursor:pointer;}
.name-btn.active{border-color:#111827;box-shadow:0 0 0 2px rgba(17,24,39,.08) inset;}
.actions{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.picked{color:var(--muted);font-size:13px}
.primary{border:none;background:var(--primary);color:#111;border-radius:14px;padding:10px 14px;font-weight:900;cursor:pointer;}
.primary:disabled{opacity:.45;cursor:not-allowed;}
.ghost{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:14px;padding:10px 14px;font-weight:900;cursor:pointer;}
.stage{margin-top:10px;border:1px solid var(--line);border-radius:18px;overflow:hidden;position:relative;}
#cv{display:block;width:100%;height:auto;background:#fff;}
.stage{max-height: calc(100vh - 220px);} /* cabe en móviles */


/* Modal foto */
.modal{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  z-index:9999;
}
.hidden{display:none !important;}
.modal-card{
  width:min(760px, 100%);
  background:#fff;
  border:1px solid rgba(229,231,235,1);
  border-radius:18px;
  box-shadow: 0 18px 60px rgba(0,0,0,0.25);
  padding:16px;
}
.modal-title{
  font-weight:900;
  font-size:18px;
  margin-bottom:10px;
}
.modal-actions, .camera-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.camera{
  margin-top:14px;
  border-top:1px solid rgba(229,231,235,1);
  padding-top:14px;
}
#cameraVideo{
  width:100%;
  height:auto;
  background:#000;
  border-radius:14px;
}
.camera-note{
  margin-top:10px;
  color:rgba(100,116,139,0.95);
  font-size:12px;
}
.result{
  margin-top:14px;
  border-top:1px solid rgba(229,231,235,1);
  padding-top:14px;
}
#resultCanvas{
  width:100%;
  height:auto;
  background:#fff;
  border:1px solid rgba(229,231,235,1);
  border-radius:14px;
}
.linkbtn{
  display:inline-block;
  text-decoration:none;
  line-height:normal;
}
