/* ============================================================
   Renterra admin + Website Builder styles (shared).
   Builds on renterra.css design tokens.
   ============================================================ */
.admin-shell{min-height:100vh;display:flex;flex-direction:column}
.admin-header{position:sticky;top:0;z-index:50;background:rgba(247,248,250,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.admin-header .nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.admin-id{display:flex;align-items:center;gap:.7rem;min-width:0}
.admin-id .tenant-name{font-family:var(--font-head);font-weight:600;font-size:1.02rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
.admin-actions{display:flex;align-items:center;gap:.6rem}
.who{font-size:.82rem;color:var(--slate);max-width:30vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:640px){.who{display:none}}

.admin-main{flex:1;max-width:var(--maxw);margin:0 auto;width:100%;padding:26px 22px 70px}

/* forms / panels */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}
.panel + .panel{margin-top:20px}
.panel h3{margin:0 0 14px}
.field textarea{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);min-height:70px;resize:vertical}
.field select{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink)}

.note{background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--teal);border-radius:var(--radius-sm);padding:12px 14px;font-size:.88rem;color:var(--ink);margin:6px 0 14px}
.empty{text-align:center;color:var(--slate);padding:46px 16px;font-size:.95rem}
.spin{display:inline-block;width:18px;height:18px;border:2.5px solid var(--line);border-top-color:var(--teal);border-radius:50%;animation:sp .7s linear infinite;vertical-align:middle}
@keyframes sp{to{transform:rotate(360deg)}}

/* sign-in */
.signin-wrap{max-width:420px;margin:9vh auto;padding:0 20px}
.signin-wrap .brand{justify-content:center;margin-bottom:18px}
.msg{font-size:.9rem;margin-top:12px;min-height:1.2em}
.msg.err{color:var(--warn)}
.msg.ok{color:var(--teal)}
.msg.info{color:var(--slate)}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:.7rem 1.2rem;border-radius:999px;font-size:.9rem;opacity:0;visibility:hidden;transition:.25s;z-index:120;box-shadow:var(--shadow)}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.linkish{background:none;border:none;color:var(--teal);text-decoration:underline;font:inherit;padding:0;cursor:pointer}

/* ============================================================
   WEBSITE BUILDER — drag-drop + property panel + AI
   ============================================================ */
.bld-status{font-size:.78rem;font-weight:600;border-radius:999px;padding:.28rem .8rem}
.bld-status.ok{background:var(--teal-soft);color:var(--teal)}
.bld-status.dirty{background:#fff4e5;color:#b06a16}
.bld-gen{background:linear-gradient(120deg,var(--ink),var(--navy));color:#fff;border-radius:var(--radius);padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.bld-gen h3{color:#fff;margin:0 0 .4rem;font-size:1.1rem}
.bld-gen .bld-hint{color:#c7cedb}
.bld-gen .bld-input{margin-bottom:10px}
.bld-gen-acts{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:6px}
.bld-ai-msg{font-size:.88rem;margin:.6rem 0 0;min-height:1.1em;color:#c7cedb}
.bld-ai-msg.err{color:#ffb4a2}.bld-ai-msg.ok{color:#7fe7c4}.bld-ai-msg.info{color:#c7cedb}
.bld-link{background:none;border:none;color:var(--teal-bright);text-decoration:underline;font:inherit;padding:0;cursor:pointer}
.bld-bar{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.bld-bar .bld-bar-sp{flex:1}
.bld-bar .btn{padding:.5rem 1.1rem;font-size:.9rem}
.bld-grid{display:grid;grid-template-columns:255px 1fr 320px;gap:16px;align-items:start}
.bld-rail{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow-sm);position:sticky;top:78px;max-height:calc(100vh - 96px);overflow:auto}
.bld-center{min-width:0}
.bld-prev-head{font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--ink);margin:0 0 8px}
.bld-preview{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;min-height:420px;box-shadow:var(--shadow-sm)}
.bld-preview-frame{font-size:14px}
.bld-rail-h{font-family:var(--font-head);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);margin-bottom:8px}
.bld-count{background:var(--surface-2);color:var(--slate);border-radius:999px;padding:.05rem .5rem;font-size:.72rem;margin-left:.3rem}
.bld-add-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.bld-add-btn{appearance:none;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.5rem .4rem;font-size:.78rem;font-weight:600;color:var(--ink);cursor:pointer;text-align:left}
.bld-add-btn:hover{border-color:var(--teal);color:var(--teal)}
.bld-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.bld-item{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.45rem .5rem;cursor:grab}
.bld-item.sel{border-color:var(--teal);background:var(--teal-soft)}
.bld-item.dragging{opacity:.5}
.bld-item.drop-above{border-top:2px solid var(--teal)}
.bld-grip{color:var(--slate);font-size:.85rem;cursor:grab;user-select:none}
.bld-item-name{flex:1;background:none;border:none;text-align:left;font:inherit;font-weight:600;font-size:.84rem;color:var(--ink);cursor:pointer;padding:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bld-item.sel .bld-item-name{color:var(--teal)}
.bld-req{font-size:.66rem;color:var(--slate);text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.bld-del{appearance:none;background:none;border:none;color:var(--slate);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .2rem;border-radius:6px}
.bld-del:hover{color:var(--warn)}
.bld-del.sm{font-size:1rem}
.bld-panel{border:1px solid var(--line);border-radius:8px;padding:12px;margin-bottom:12px;background:var(--surface)}
.bld-panel-h{font-family:var(--font-head);font-weight:700;font-size:.92rem;color:var(--ink);margin-bottom:6px}
.bld-sub-h{font-family:var(--font-head);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);margin:12px 0 6px}
.bld-hint{font-size:.78rem;color:var(--slate);margin:0 0 10px}
.bld-empty-panel{color:var(--slate);font-size:.86rem}
.bld-f{display:block;margin-bottom:10px}
.bld-f.sm{margin-bottom:7px}
.bld-flabel{display:flex;justify-content:space-between;align-items:baseline;font-size:.74rem;font-weight:600;color:var(--slate);margin-bottom:.2rem}
.bld-counter{font-size:.66rem;color:var(--slate);font-weight:500}
.bld-input{width:100%;box-sizing:border-box;padding:.5rem .6rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.86rem;background:#fff;color:var(--ink)}
.bld-input:focus{outline:none;border-color:var(--teal)}
.bld-area{resize:vertical;min-height:54px}
.bld-area.big{min-height:90px}
.bld-ferr{display:block;font-size:.72rem;color:var(--warn);margin-top:.2rem;min-height:.9em}
.bld-bgrow{display:flex;gap:6px;align-items:center}
.bld-bgsel{flex:1}
.bld-bgurl{flex:1}
.bld-color{width:38px;height:32px;padding:0;border:1px solid var(--line);border-radius:6px;background:#fff;flex:0 0 auto;cursor:pointer}
.bld-color-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.bld-clabel{font-size:.78rem;font-weight:600;color:var(--slate);min-width:78px}
.bld-chex{flex:1;font-family:monospace;font-size:.78rem;padding:.35rem .5rem}
.bld-clear{appearance:none;background:none;border:none;color:var(--slate);font-size:1rem;cursor:pointer}
.bld-clear:hover{color:var(--warn)}
.bld-items{border:1px dashed var(--line);border-radius:8px;padding:10px;margin-bottom:10px}
.bld-itemrow{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin:6px 0}
.bld-itemrow-h{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;font-weight:700;color:var(--slate);margin-bottom:6px}
.bld-add-item{appearance:none;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.4rem .7rem;font-size:.78rem;font-weight:600;color:var(--teal);cursor:pointer;width:100%;margin-top:4px}
.bld-add-item:hover{border-color:var(--teal)}
.bld-prev-availbar{display:flex;gap:8px;flex-wrap:wrap;padding:14px 20px;background:rgba(0,0,0,.03);margin:0 0 4px;align-items:center}
.bld-prev-pill{background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:.35rem .8rem;font-size:.78rem;color:#444}
.bld-prev-pill-go{background:var(--sr-accent,#0f766e);color:#fff;border-color:transparent;font-weight:600}
.bld-prev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;padding:6px 20px 12px}
.bld-prev-card{border:1px solid rgba(0,0,0,.1);border-radius:10px;overflow:hidden;background:#fff}
.bld-prev-thumb{aspect-ratio:4/3;background:linear-gradient(135deg,rgba(0,0,0,.06),rgba(0,0,0,.12))}
.bld-prev-cbody{padding:8px 10px}
.bld-prev-pname{font-weight:600;font-size:.84rem;color:#1a1a2e}
.bld-prev-pdesc{font-size:.72rem;color:#666;margin:.1rem 0}
.bld-prev-pprice{font-weight:700;font-size:.84rem;color:var(--sr-accent,#0f766e);margin-top:.25rem}
.bld-prev-add{margin-top:6px;width:100%;background:var(--sr-accent,#0f766e);color:#fff;border:none;border-radius:8px;padding:.35rem;font-size:.78rem;font-weight:600;cursor:default}
.bld-prev-note{font-size:.74rem;color:#888;text-align:center;padding:0 20px 14px}
.bld-offer{text-align:center;padding:48px 24px}
.bld-offer h3{margin:0 0 .4rem}
.bld-offer p{color:var(--slate);max-width:46ch;margin:0 auto 1.1rem}
@media(max-width:1080px){
  .bld-grid{grid-template-columns:1fr}
  .bld-rail{position:static;max-height:none}
  .bld-rail-right{order:3}
}
