/* HEIMKEY — estilos del flujo de activación (compartidos por producto) */

    body { background: #F6F8FB; min-height: 100vh; }
    .ob-top { display:flex; align-items:center; justify-content:space-between; padding: 24px 0; }
    .ob-wrap { max-width: 560px; margin: 0 auto; padding: 8px 24px 80px; }
    .ob-steps-ind { display:flex; gap:8px; justify-content:center; margin: 8px 0 28px; }
    .ob-dot { width: 30px; height: 4px; border-radius: 999px; background: var(--line); transition: background .3s; }
    .ob-dot.done, .ob-dot.active { background: var(--amber-500); }
    .ob-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 40px 36px; box-shadow: 0 10px 28px -16px rgba(14,25,41,.16); }
    /* Selector visual de plantilla (activación Anfitriones) */
    .ob-tpl-hint { font-weight:600; font-size:11px; color:var(--muted); text-transform:none; letter-spacing:0; margin-left:6px; }
    .ob-tpl-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(94px,1fr)); gap:9px; max-height:300px; overflow-y:auto; padding:4px; margin-top:3px; }
    .ob-tpl { display:block; text-align:left; padding:0; background:var(--surface); border:1.5px solid var(--line); border-radius:10px; overflow:hidden; cursor:pointer; font:inherit; transition:border-color .15s, box-shadow .15s; }
    .ob-tpl img { display:block; width:100%; aspect-ratio:4/3; object-fit:cover; background:var(--soft); }
    .ob-tpl-n { display:block; font-family:var(--font-display,'Plus Jakarta Sans'),sans-serif; font-weight:700; font-size:11.5px; color:var(--ink); margin:6px 8px 0; }
    .ob-tpl-t { display:block; font-size:10px; color:var(--muted); margin:1px 8px 8px; line-height:1.25; }
    .ob-tpl:hover { border-color:var(--amber-400); }
    .ob-tpl.sel { border-color:var(--amber-500); box-shadow:0 0 0 3px rgba(22,80,160,.16); }
    .ob-panel { display: none; }
    .ob-panel.active { display: block; animation: obIn .35s ease; }
    @keyframes obIn { from { opacity:0; transform: translateY(8px);} to {opacity:1; transform:none;} }
    .ob-eyebrow { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--amber-600); margin-bottom: 12px; }
    .ob-h { font-family: var(--font-display); font-size: 1.7rem; font-weight: 800; letter-spacing: -.02em; line-height: 1.1; margin-bottom: 12px; }
    .ob-p { color: var(--muted); font-size: 15px; line-height: 1.6; margin-bottom: 26px; }
    .ob-piece { display:flex; align-items:center; gap:16px; background: var(--bg); border:1px solid var(--line); border-radius: var(--r-md); padding: 16px; margin-bottom: 26px; }
    .ob-piece .px { width: 52px; height: 52px; border-radius: 12px; background: var(--choco-800); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
    .ob-piece b { font-family: var(--font-display); font-size: 15px; display:block; margin-bottom:2px; }
    .ob-piece small { color: var(--muted); font-size: 12.5px; }
    .ob-btn-full { width: 100%; justify-content: center; }
    .ob-tabs { display:flex; gap:4px; padding:4px; background: var(--bg); border:1px solid var(--line); border-radius: var(--r-pill); margin-bottom: 24px; }
    .ob-tab { flex:1; border:none; background:none; cursor:pointer; padding: 11px; border-radius: var(--r-pill); font-family: var(--font-display); font-size: 13px; font-weight: 700; color: var(--muted); transition: all .2s; }
    .ob-tab.active { background: var(--ink); color: #fff; }
    .ob-mode { display:none; }
    .ob-mode.active { display:block; animation: obIn .3s ease; }
    .ob-forgot { display:block; text-align:right; font-size:12.5px; color: var(--amber-600); font-weight:600; margin: -6px 0 14px; }
    .ob-oauth { width:100%; display:flex; align-items:center; justify-content:center; gap:12px; padding: 15px; border-radius: var(--r-sm); border: 1.5px solid var(--line); background: var(--surface); font-family: var(--font-display); font-weight: 700; font-size: 14px; cursor: pointer; transition: all .2s; margin-bottom: 12px; }
    .ob-oauth:hover { border-color: var(--ink); }
    .ob-oauth.disabled { opacity: .5; cursor: not-allowed; }
    .ob-oauth .soon { margin-left:auto; font-size:9px; letter-spacing:.12em; text-transform:uppercase; background: var(--soft); color: var(--muted); padding: 3px 8px; border-radius:999px; }
    .ob-divider { display:flex; align-items:center; gap:14px; color: var(--muted-2); font-size: 12px; margin: 18px 0; font-family: var(--font-display); letter-spacing:.1em; text-transform:uppercase; }
    .ob-divider::before, .ob-divider::after { content:''; flex:1; height:1px; background: var(--line); }
    .ob-field { margin-bottom: 16px; }
    .ob-field label { display:block; font-family: var(--font-display); font-size: 12px; font-weight: 700; letter-spacing: .04em; color: var(--ink-2); margin-bottom: 7px; }
    .ob-field input, .ob-field select { width: 100%; padding: 13px 14px; border: 1.5px solid var(--line); border-radius: var(--r-sm); font-family: var(--font-body); font-size: 15px; color: var(--ink); background: var(--surface); transition: border-color .2s; }
    .ob-field input:focus, .ob-field select:focus { outline: none; border-color: var(--amber-500); }
    .ob-row2 { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .ob-note { font-size: 12.5px; color: var(--muted); background: var(--amber-100); border-radius: var(--r-sm); padding: 12px 14px; margin-bottom: 22px; display:flex; gap:10px; }
    .ob-note svg { color: var(--amber-600); flex-shrink:0; }
    .ob-success-ic { width: 76px; height: 76px; border-radius: 50%; background: rgba(47,158,107,.12); color: var(--ok); display:flex; align-items:center; justify-content:center; margin: 0 auto 24px; }
    .ob-back { background:none; border:none; color: var(--muted); font-family: var(--font-display); font-weight:600; font-size:13px; cursor:pointer; padding:8px 0; }
    .ob-actions { display:flex; gap:12px; margin-top: 8px; }
    @media (max-width:520px){ .ob-card{padding:28px 22px;} .ob-row2{grid-template-columns:1fr;} }
  
    /* extras para formularios por producto */
    .ob-field textarea { width:100%; padding:13px 14px; border:1.5px solid var(--line); border-radius: var(--r-sm); font-family: var(--font-body); font-size:15px; color: var(--ink); background: var(--surface); min-height:88px; resize:vertical; transition: border-color .2s; }
    .ob-field textarea:focus { outline:none; border-color: var(--amber-500); }
    .ob-cat { font-family: var(--font-display); font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color: var(--amber-600); background: var(--amber-100); padding:3px 9px; border-radius:999px; margin-left:8px; }

/* ── Foto de la propiedad (Smart Welcome + panel) ── */
.ob-photo { display:flex; align-items:center; gap:12px; padding:16px; border:1.5px dashed var(--line); border-radius: var(--r-sm); cursor:pointer; color: var(--muted); background: var(--surface); background-size: cover; background-position: center; transition: border-color .2s, color .2s; }
.ob-photo:hover { border-color: var(--amber-400); color: var(--amber-600); }
.ob-photo-ic { flex-shrink:0; }
.ob-photo-txt { font-size: 13px; line-height: 1.45; }
.ob-photo.has { min-height: 130px; align-items: flex-end; border-style: solid; border-color: transparent; color:#fff; }
.ob-photo.has .ob-photo-ic { display:none; }
.ob-photo.has .ob-photo-txt { background: rgba(14,25,41,.6); padding: 5px 10px; border-radius: 6px; font-size: 12px; font-weight:600; }
