/* ==========================================================================
   Concierge Pilot — Shared Floor Designer Engine CSS
   Structural / layout styles. Colors, fonts, accents come from tenant skin.
   --------------------------------------------------------------------------
   Each tenant's index.html sets these CSS variables in :root, then this
   stylesheet renders the universal Floor Designer UI in their brand.

   Required CSS variables (tenant supplies):
     --bg, --surface, --rule, --ink, --ink-dim, --ink-faint
     --accent, --accent-deep, --accent-glow, --accent-soft
     --brand-heading-font, --brand-heading-style, --brand-mono-font
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Sensible fallbacks — every tenant should override */
  --bg:#0e0d0c;
  --surface:#1c1a17;
  --surface-2:#25221d;
  --rule:rgba(184,149,76,0.18);
  --rule-strong:rgba(184,149,76,0.32);
  --ink:#e8dfd0;
  --ink-dim:#c7b9a8;
  --ink-faint:#8b8275;
  --accent:#b8954c;
  --accent-deep:#8a6e34;
  --accent-glow:#e8a73a;
  --accent-soft:rgba(184,149,76,0.14);
  --danger:#ef4444;
  --warn:#f59e0b;
  --success:#22c55e;
  --brand-body-font:'Inter',sans-serif;
  --brand-heading-font:'Cormorant Garamond',serif;
  --brand-mono-font:'JetBrains Mono',monospace;
  --brand-heading-style:italic;
  --brand-heading-weight:700;
}

html,body{background:var(--bg);color:var(--ink);font-family:var(--brand-body-font);height:100vh;overflow:hidden}
.fd-shell{display:grid;grid-template-rows:auto 1fr;height:100vh}

/* ── Top bar ─────────────────────────────────────────────────────────── */
.fd-topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--rule);background:var(--surface);position:sticky;top:0;z-index:20;flex-wrap:wrap}
.fd-topbar .fd-brand{font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:1.4rem;font-weight:var(--brand-heading-weight);color:var(--accent-glow);margin-right:6px}
.fd-topbar .fd-crumb{font-family:var(--brand-mono-font);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}
.fd-topbar .fd-grow{flex:1}
.fd-topbar .fd-lay-pick{display:flex;align-items:center;gap:8px}
.fd-topbar select,.fd-topbar button{padding:9px 14px;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid var(--rule);color:var(--ink);font-family:var(--brand-mono-font);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-weight:600}
.fd-topbar select:hover,.fd-topbar button:hover{border-color:var(--accent-glow);color:var(--accent-glow)}
.fd-topbar button.primary{background:linear-gradient(180deg,var(--accent-glow) 0%,var(--accent) 100%);color:var(--bg);border-color:var(--accent);box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}
.fd-topbar button.primary:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 8px 18px -8px var(--accent-soft);color:var(--bg)}
.fd-topbar button.danger{color:var(--danger);border-color:rgba(239,68,68,.32)}
.fd-topbar button.danger:hover{background:rgba(239,68,68,.12);color:var(--danger);border-color:var(--danger)}
.fd-topbar input[type=number]{width:74px;padding:9px 8px;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid var(--rule);color:var(--ink);font-family:var(--brand-mono-font);font-size:.74rem}
.fd-size-label{font-family:var(--brand-mono-font);font-size:.6rem;letter-spacing:.18em;color:var(--ink-dim);text-transform:uppercase}
.fd-size-x{color:var(--ink-faint)}

.fd-pill{padding:5px 12px;border-radius:999px;font-family:var(--brand-mono-font);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.fd-pill.active{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.5);color:#86efac}
.fd-pill.draft{background:var(--accent-soft);border:1px solid var(--rule-strong);color:var(--accent-glow)}
.fd-pill.dirty{background:rgba(245,158,11,.14);border:1px solid rgba(245,158,11,.5);color:#fbbf24}
.fd-pill.peer{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.4);color:#86efac;display:inline-flex;gap:6px;align-items:center}
.fd-pill.peer .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.7);animation:fdPeerPulse 1.6s ease-out infinite}
@keyframes fdPeerPulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.7)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

/* ── Work area ───────────────────────────────────────────────────────── */
.fd-work{display:grid;grid-template-columns:200px 1fr;height:100%;overflow:hidden;position:relative}
@media(max-width:980px){.fd-work{grid-template-columns:1fr}.fd-palette{display:none}}

/* ── Palette ─────────────────────────────────────────────────────────── */
.fd-palette{border-right:1px solid var(--rule);background:var(--surface);overflow-y:auto;padding:18px 16px}
.fd-palette h3{font-family:var(--brand-mono-font);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 10px;font-weight:600}
.fd-palette h3:not(:first-child){margin-top:18px}
.fd-grid-tools{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.fd-tool{padding:11px 8px;border:1px solid var(--rule);border-radius:8px;background:rgba(255,255,255,.025);color:var(--ink-dim);font-family:var(--brand-mono-font);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .15s;text-align:center}
.fd-tool:hover{border-color:var(--accent-glow);color:var(--accent-glow);transform:translateY(-1px)}
.fd-tool .swatch{width:34px;height:34px;background:var(--surface-2);border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent-glow);font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-size:.78rem;font-weight:var(--brand-heading-weight)}
.fd-tool .swatch.round{border-radius:50%}
.fd-tool .swatch.square{border-radius:4px}
.fd-tool .swatch.booth{border-radius:14px 14px 4px 4px}
.fd-tool .swatch.high{border-radius:50%;width:24px;height:24px}
.fd-tool .swatch.bar{width:42px;height:18px;border-radius:10px;background:linear-gradient(180deg,var(--surface-2),var(--bg))}
.fd-tool .swatch.stage{width:42px;height:22px;background:linear-gradient(180deg,var(--accent-deep),var(--bg));border-color:var(--accent-glow);color:var(--accent-glow)}
.fd-tool .swatch.dj{width:30px;height:18px;background:linear-gradient(180deg,#3a1a3c,#1a0a1c);border-color:#a855f7;color:#d8b4fe}
.fd-tool .swatch.dance{width:42px;height:24px;background:repeating-linear-gradient(45deg,var(--accent-soft),var(--accent-soft) 4px,rgba(0,0,0,.3) 4px,rgba(0,0,0,.3) 8px);border-color:var(--accent)}
.fd-tool .swatch.door{width:24px;height:32px;background:linear-gradient(180deg,var(--surface-2),var(--bg));border-color:var(--ink-dim);border-left-width:3px;border-left-color:var(--accent-glow)}
.fd-tool .swatch.restroom{width:30px;height:30px;background:rgba(255,255,255,.04);border-color:var(--ink-dim);color:var(--ink-dim);font-size:.74rem;letter-spacing:.04em}
.fd-tool .swatch.plant{background:radial-gradient(circle,rgba(34,197,94,.4) 30%,transparent 70%);border-color:rgba(34,197,94,.4);color:#86efac}
.fd-tool .swatch.patio{width:42px;height:6px;background:repeating-linear-gradient(90deg,var(--accent),var(--accent) 8px,transparent 8px,transparent 14px);border:0}
.fd-help{margin-top:18px;padding:12px 11px;background:var(--accent-soft);border:1px solid var(--rule);border-radius:8px;font-size:.72rem;color:var(--ink-dim);line-height:1.5}
.fd-help strong{color:var(--accent-glow)}
.fd-help kbd{font-family:var(--brand-mono-font);font-size:.66rem;background:rgba(0,0,0,.4);border:1px solid var(--rule);border-radius:4px;padding:1px 5px;color:var(--accent-glow)}

/* ── Canvas ──────────────────────────────────────────────────────────── */
.fd-canvas-wrap{position:relative;overflow:auto;background:linear-gradient(180deg,var(--bg) 0%,var(--surface-2) 100%);padding:20px}
.fd-canvas{position:relative;background:var(--bg);border:1px solid var(--rule);border-radius:8px;background-image:linear-gradient(var(--accent-soft) 1px,transparent 1px),linear-gradient(90deg,var(--accent-soft) 1px,transparent 1px);background-size:20px 20px;box-shadow:inset 0 0 0 1px var(--accent-soft),0 24px 60px rgba(0,0,0,.5);margin:0 auto}
.fd-canvas.dropping{outline:2px dashed var(--accent-glow);outline-offset:-6px}
.fd-marquee-box{position:absolute;border:1px dashed var(--accent-glow);background:var(--accent-soft);pointer-events:none;z-index:50;border-radius:2px}

/* ── Floor objects ──────────────────────────────────────────────────── */
.fd-fobj{position:absolute;cursor:grab;user-select:none;display:flex;align-items:center;justify-content:center;color:var(--accent-glow);font-family:var(--brand-heading-font);font-style:var(--brand-heading-style);font-weight:var(--brand-heading-weight);background:var(--surface-2);border:1.5px solid var(--accent);transition:box-shadow .12s,border-color .12s;font-size:.86rem;letter-spacing:.02em;text-align:center;line-height:1.05;box-shadow:0 4px 14px rgba(0,0,0,.6),inset 0 0 0 1px var(--accent-soft)}
.fd-fobj.dragging{cursor:grabbing;opacity:.85;z-index:10}
.fd-fobj.selected{border-color:var(--accent-glow);box-shadow:0 0 0 2px var(--accent-glow),0 4px 14px rgba(0,0,0,.6)}
.fd-fobj.kind-round-2,.fd-fobj.kind-round-4,.fd-fobj.kind-round-6,.fd-fobj.kind-round-8{border-radius:50%}
.fd-fobj.kind-square-2,.fd-fobj.kind-square-4,.fd-fobj.kind-square-6{border-radius:6px}
.fd-fobj.kind-booth-4,.fd-fobj.kind-booth-6{border-radius:18px 18px 4px 4px}
.fd-fobj.kind-high-top-2,.fd-fobj.kind-high-top-4{border-radius:50%;background:radial-gradient(circle,var(--surface-2),var(--bg))}
.fd-fobj.kind-bar{border-radius:10px;background:linear-gradient(180deg,var(--surface-2),var(--bg));color:var(--accent-glow);font-family:var(--brand-mono-font);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;font-style:normal}
.fd-fobj.kind-stage{background:linear-gradient(180deg,var(--accent-deep) 0%,var(--bg) 100%);border-color:var(--accent-glow);border-radius:6px;color:var(--accent-glow);font-family:var(--brand-mono-font);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-style:normal}
.fd-fobj.kind-dj-booth{background:linear-gradient(180deg,#3a1a3c,#1a0a1c);border-color:#a855f7;border-radius:8px;color:#d8b4fe;font-family:var(--brand-mono-font);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-style:normal}
.fd-fobj.kind-dance-floor{background:repeating-linear-gradient(45deg,var(--accent-soft),var(--accent-soft) 6px,rgba(0,0,0,.3) 6px,rgba(0,0,0,.3) 12px);border-color:var(--accent);border-radius:6px;color:var(--accent-glow);font-family:var(--brand-mono-font);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-style:normal}
.fd-fobj.kind-door{background:linear-gradient(180deg,var(--surface-2),var(--bg));border-color:var(--ink-dim);border-left:4px solid var(--accent-glow);border-radius:0;color:var(--ink-dim);font-family:var(--brand-mono-font);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-style:normal}
.fd-fobj.kind-restroom{border-radius:6px;background:rgba(255,255,255,.03);border-color:var(--ink-dim);color:var(--ink-dim);font-family:var(--brand-mono-font);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-style:normal}
.fd-fobj.kind-plant{background:radial-gradient(circle,rgba(34,197,94,.32) 30%,rgba(34,197,94,.04) 70%);border-color:rgba(34,197,94,.4);border-radius:50%;color:#86efac;font-size:1.2rem}
.fd-fobj.kind-bar-stool{border-radius:50%;background:radial-gradient(circle,var(--surface-2),var(--bg));font-size:.6rem;color:var(--ink-dim)}
.fd-fobj.kind-patio-edge,.fd-fobj.kind-wall{background:linear-gradient(180deg,var(--accent),var(--accent-deep));border:0;border-radius:0;color:transparent}
.fd-fobj.premium{box-shadow:0 0 0 2px var(--accent-soft),0 4px 14px rgba(0,0,0,.6)}
.fd-fobj .pricetag{position:absolute;top:-9px;right:-6px;background:var(--accent-glow);color:var(--bg);font-family:var(--brand-mono-font);font-size:.62rem;font-weight:700;letter-spacing:.04em;padding:2px 6px;border-radius:100px;border:1px solid var(--bg);line-height:1}
.fd-fobj .label{pointer-events:none}

/* ── Resize / rotate handles ─────────────────────────────────────────── */
.fd-handle{position:absolute;width:11px;height:11px;background:var(--accent-glow);border:1px solid var(--bg);border-radius:2px;display:none}
.fd-fobj.selected .fd-handle{display:block}
.fd-handle.h-se{right:-6px;bottom:-6px;cursor:nwse-resize}
.fd-handle.h-rot{top:-22px;left:50%;transform:translateX(-50%);border-radius:50%;cursor:grab;background:var(--accent-glow)}

/* ── Properties panel ────────────────────────────────────────────────── */
.fd-props{position:absolute;top:0;right:0;bottom:0;width:300px;background:var(--surface);border-left:1px solid var(--rule-strong);overflow-y:auto;padding:18px 16px;transform:translateX(100%);transition:transform .18s ease-out;z-index:30;box-shadow:-12px 0 32px rgba(0,0,0,.35)}
.fd-props.open{transform:translateX(0)}
.fd-props .close-x{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:6px;border:1px solid var(--rule);background:rgba(255,255,255,.04);color:var(--ink-dim);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;font-family:var(--brand-mono-font)}
.fd-props .close-x:hover{color:var(--accent-glow);border-color:var(--accent-glow)}
.fd-props h3{font-family:var(--brand-mono-font);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 10px;font-weight:600}
.fd-props .empty{color:var(--ink-faint);font-size:.86rem;font-style:italic;line-height:1.5}
.fd-props label{display:block;font-family:var(--brand-mono-font);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);font-weight:600;margin:14px 0 5px}
.fd-props input[type=text],.fd-props input[type=number],.fd-props select{width:100%;padding:9px 11px;background:rgba(0,0,0,.32);border:1px solid var(--rule);border-radius:6px;color:var(--ink);font-family:var(--brand-mono-font);font-size:.84rem;outline:none}
.fd-props input:focus,.fd-props select:focus{border-color:var(--accent-glow);box-shadow:0 0 0 3px var(--accent-soft)}
.fd-props .row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.fd-props .check{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--ink-dim);margin-top:14px;cursor:pointer}
.fd-props .check input{accent-color:var(--accent-glow)}
.fd-props .actions{margin-top:20px;display:flex;gap:8px}
.fd-props .actions button{flex:1;padding:9px;background:rgba(255,255,255,.04);border:1px solid var(--rule);border-radius:6px;color:var(--ink-dim);font-family:var(--brand-mono-font);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;font-weight:600}
.fd-props .actions button:hover{border-color:var(--accent-glow);color:var(--accent-glow)}
.fd-props .actions button.del{color:var(--danger);border-color:rgba(239,68,68,.3)}
.fd-props .actions button.del:hover{background:rgba(239,68,68,.12);border-color:var(--danger);color:var(--danger)}
.fd-props .combine-list{margin-top:8px;display:flex;flex-direction:column;gap:5px}
.fd-props .combine-list .ci{display:flex;align-items:center;gap:8px;padding:6px 9px;background:rgba(0,0,0,.32);border:1px solid var(--rule);border-radius:6px;font-family:var(--brand-mono-font);font-size:.74rem}
.fd-props .combine-list .ci input{accent-color:var(--accent-glow)}
.fd-props .help-foot{margin-top:6px;font-size:.66rem;color:var(--ink-faint);font-family:var(--brand-mono-font);letter-spacing:.04em;line-height:1.45}
.fd-props .combine-note{margin-top:6px;font-size:.7rem;color:var(--ink-faint);font-family:var(--brand-mono-font)}

/* ── Combined-price popover ─────────────────────────────────────────── */
.fd-combined-edit-pop{position:absolute;background:var(--bg);border:1px solid var(--rule-strong);border-radius:10px;padding:12px 14px;z-index:60;min-width:240px;box-shadow:0 12px 28px rgba(0,0,0,0.6);color:var(--ink);font-family:var(--brand-mono-font)}
.fd-combined-edit-pop .cpe-eyebrow{font-size:.6rem;letter-spacing:.16em;color:var(--accent-glow);text-transform:uppercase;margin-bottom:4px}
.fd-combined-edit-pop .cpe-members{font-size:.7rem;color:var(--ink-dim);margin-bottom:10px;line-height:1.4}
.fd-combined-edit-pop label{font-size:.65rem;letter-spacing:.1em;color:var(--ink-dim);text-transform:uppercase}
.fd-combined-edit-pop input{width:100%;padding:8px 10px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid var(--rule-strong);color:var(--ink);font-family:inherit;font-size:.95rem;margin-top:4px}
.fd-combined-edit-pop .cpe-auto{font-size:.62rem;color:var(--ink-faint);margin-top:6px}
.fd-combined-edit-pop .cpe-actions{display:flex;gap:6px;margin-top:12px}
.fd-combined-edit-pop button{font-family:inherit;cursor:pointer;border-radius:6px;font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase}
.fd-combined-edit-pop .cpe-save{flex:1;padding:8px;background:linear-gradient(180deg,var(--accent-glow),var(--accent));color:var(--bg);border:0}
.fd-combined-edit-pop .cpe-reset{padding:8px 10px;background:rgba(255,255,255,.04);color:var(--ink-dim);border:1px solid var(--rule);font-size:.65rem}
.fd-combined-edit-pop .cpe-cancel{padding:8px 10px;background:transparent;color:var(--ink-dim);border:1px solid var(--rule);font-size:.65rem}

/* ── Toast ───────────────────────────────────────────────────────────── */
.fd-toast{position:fixed;bottom:22px;right:22px;padding:11px 18px;background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);border:1px solid var(--accent-glow);color:var(--accent-glow);font-family:var(--brand-mono-font);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;border-radius:8px;box-shadow:0 14px 32px rgba(0,0,0,.6);z-index:50;animation:fdToastIn .18s ease-out}
@keyframes fdToastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
