/* DAR AYLA OPS V2 — CSS additions for toasts, suites editor, calendar prices, view switchers, etc. */

/* ---------- TOASTS ---------- */
.toast-host {
  position: fixed; right: 22px; bottom: 22px; z-index: 9999;
  display: flex; flex-direction: column; gap: 10px; pointer-events: none;
  max-width: 420px;
}
.toast {
  display: grid; grid-template-columns: 32px 1fr; gap: 10px;
  background: var(--surface); border: 1px solid var(--border-strong);
  padding: 12px 14px; border-radius: 12px;
  box-shadow: var(--shadow-3);
  pointer-events: auto;
  animation: toast-in .3s cubic-bezier(.2,.7,.3,1.4);
  border-left: 3px solid var(--accent);
}
.toast-ok    { border-left-color: var(--ok); }
.toast-warn  { border-left-color: var(--warn); }
.toast-info  { border-left-color: var(--info); }
.toast-icon { width: 28px; height: 28px; border-radius: 7px;
  background: var(--accent-soft); color: var(--accent);
  display: grid; place-items: center; }
.toast-ok .toast-icon  { background: var(--ok-soft); color: var(--ok); }
.toast-warn .toast-icon{ background: var(--warn-soft); color: var(--warn); }
.toast-info .toast-icon{ background: var(--info-soft); color: var(--info); }
.toast-title { font-size: 13px; font-weight: 600; color: var(--text); }
.toast-detail { font-size: 12px; color: var(--text-soft); margin-top: 2px; }
.toast-endpoint { font-size: 10px; color: var(--muted); margin-top: 6px;
  letter-spacing: .02em; word-break: break-all; }
@keyframes toast-in {
  from { opacity: 0; transform: translateX(20px) translateY(10px); }
  to   { opacity: 1; transform: none; }
}

/* ---------- ITALIQUES TOGGLE ---------- */
:root[data-italics="off"] .brand-name,
:root[data-italics="off"] h1,
:root[data-italics="off"] h2,
:root[data-italics="off"] h3,
:root[data-italics="off"] .guest-portrait .nm,
:root[data-italics="off"] em,
:root[data-italics="off"] [style*="italic"] {
  font-style: normal !important;
  font-family: 'DM Sans', sans-serif !important;
  letter-spacing: -.01em;
}

/* ---------- KPI DRAG ---------- */
.kpi { cursor: grab; user-select: none; transition: transform .14s, box-shadow .14s; }
.kpi:active { cursor: grabbing; }
.kpi.kpi-dragging { opacity: .4; transform: scale(.98); }
.kpi.kpi-drop-target { box-shadow: 0 0 0 2px var(--accent), var(--shadow-2); }
.kpi-drag-handle { position: absolute; top: 6px; right: 6px;
  font-size: 10px; color: var(--muted); opacity: 0;
  transition: opacity .14s; font-family: 'JetBrains Mono', monospace; }
.kpi:hover .kpi-drag-handle { opacity: .6; }

/* ---------- SUITES PAGE (catalogue + editor) ---------- */
.suites-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.suite-tile {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 14px; padding: 16px 16px 14px;
  cursor: pointer; transition: transform .14s, box-shadow .14s, border-color .14s;
  position: relative; overflow: hidden;
}
.suite-tile:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.suite-tile-cover {
  height: 96px; margin: -16px -16px 14px; position: relative;
  display: grid; place-items: end start; padding: 12px;
  color: #fff; font-family:'Cormorant Garamond',serif; font-style: italic; font-size: 22px;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.suite-tile-cover::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.55));
}
.suite-tile-cover > * { position: relative; }
.suite-meta-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px;
  font-size: 11px; color: var(--muted); font-family:'JetBrains Mono',monospace;
  margin: 8px 0;
}
.suite-meta-grid b { color: var(--text); font-weight: 500; }
.suite-tile-price {
  font-family:'Cormorant Garamond',serif; font-style: italic; font-size: 20px;
  color: var(--accent); margin-top: 8px;
}
.suite-tile-price small { font-size: 11px; color: var(--muted); font-style: normal;
  font-family:'JetBrains Mono',monospace; }
.amenity-chip { display: inline-flex; padding: 2px 8px; background: var(--surface-2);
  border: 1px solid var(--border); border-radius: 99px; font-size: 10px;
  color: var(--text-soft); margin: 2px 4px 2px 0; font-family:'JetBrains Mono',monospace; }

/* ---------- CALENDAR PRICES ---------- */
.cal-price {
  position: absolute; bottom: 4px; left: 4px; right: 4px;
  font-size: 9px; color: var(--muted); font-family:'JetBrains Mono',monospace;
  letter-spacing: .02em; text-align: center; opacity: .85;
  pointer-events: none;
}
.cal-price.is-weekend { color: var(--accent); font-weight: 600; }
.cal-price-edit:hover { opacity: 1; cursor: pointer; }

/* ---------- VIEW SWITCHER (inventory) ---------- */
.view-switcher { display: inline-flex; background: var(--surface-2);
  border: 1px solid var(--border); border-radius: 8px; padding: 2px; gap: 2px; }
.view-switcher button {
  background: transparent; border: 0; padding: 5px 10px; border-radius: 6px;
  font-size: 11px; color: var(--muted); cursor: pointer; font-weight: 600;
  font-family:'JetBrains Mono',monospace; letter-spacing: .04em; text-transform: uppercase;
}
.view-switcher button.on { background: var(--surface); color: var(--text); box-shadow: var(--shadow-1); }

/* ---------- ACTION BAR (inline actions) ---------- */
.action-bar { display: inline-flex; gap: 4px; }
.action-bar button {
  width: 26px; height: 26px; border-radius: 6px;
  background: var(--surface-2); border: 1px solid var(--border);
  display: grid; place-items: center; cursor: pointer; color: var(--text-soft);
}
.action-bar button:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-line); }

/* ---------- INTEGRATION BADGES ---------- */
.integration-badge { display: inline-flex; gap: 5px; align-items: center;
  padding: 2px 7px; border-radius: 99px; font-size: 10px;
  font-family:'JetBrains Mono',monospace; letter-spacing: .04em; cursor: pointer;
  transition: background .14s; }
.integration-badge.notion   { background: rgba(180,180,180,.10); color: var(--text-soft); border: 1px solid var(--border); }
.integration-badge.notion:hover { background: rgba(180,180,180,.18); }
.integration-badge.lodgify  { background: var(--info-soft); color: var(--info); }
.integration-badge.whatsapp { background: var(--ok-soft); color: var(--ok); }
.integration-badge.drive    { background: var(--gold-soft); color: var(--gold); }

/* ---------- COMING SOON BANNER ---------- */
.coming-soon {
  background: linear-gradient(90deg, var(--accent-soft), transparent);
  border: 1px dashed var(--accent-line);
  padding: 10px 14px; border-radius: 10px;
  font-size: 12px; color: var(--text-soft);
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px;
}
.coming-soon strong { color: var(--accent); font-family:'JetBrains Mono',monospace;
  font-size: 10px; letter-spacing: .15em; text-transform: uppercase; }

/* ---------- INVENTORY TABLE EDITABLE ---------- */
.inv-stock-edit {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 7px;
  padding: 2px 4px;
}
.inv-stock-edit button {
  width: 18px; height: 18px; border: 0; background: transparent; color: var(--muted);
  cursor: pointer; font-weight: 700; font-family:'JetBrains Mono',monospace; font-size: 12px;
}
.inv-stock-edit button:hover { color: var(--accent); }
.inv-stock-edit input { width: 38px; border: 0; background: transparent;
  font-family:'JetBrains Mono',monospace; text-align: center; color: var(--text); font-size: 12px;
  padding: 2px; }

/* ---------- BACKEND SPEC PILL (visible toggle in toolbar) ---------- */
.spec-pill {
  position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%);
  background: var(--surface); border: 1px solid var(--border-strong);
  padding: 6px 14px; border-radius: 99px; z-index: 80;
  font-size: 11px; color: var(--muted); font-family:'JetBrains Mono',monospace;
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  box-shadow: var(--shadow-2); letter-spacing: .04em;
}
.spec-pill:hover { color: var(--accent); border-color: var(--accent-line); }
.spec-pill .ping { width: 6px; height: 6px; border-radius: 50%; background: var(--ok);
  box-shadow: 0 0 0 4px var(--ok-soft); animation: ping-pulse 2s infinite; }
@keyframes ping-pulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }

/* ---------- BACKEND SPEC MODAL ---------- */
.spec-modal-bd { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 200;
  backdrop-filter: blur(4px); }
.spec-modal { position: fixed; inset: 5% 8%; background: var(--bg); z-index: 201;
  border: 1px solid var(--border-strong); border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column; box-shadow: var(--shadow-3); }
.spec-modal-h { padding: 18px 22px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px; }
.spec-modal-b { flex: 1; overflow-y: auto; padding: 22px; }
.spec-svc { background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px; margin-bottom: 12px; }
.spec-svc-h { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.spec-ep { font-family:'JetBrains Mono',monospace; font-size: 11px;
  padding: 4px 0; color: var(--text-soft); border-top: 1px dashed var(--border-soft); }
.spec-ep:first-of-type { border-top: 0; }
.spec-ep .verb { display: inline-block; width: 50px; font-weight: 700; }
.spec-ep .verb.GET   { color: var(--info); }
.spec-ep .verb.POST  { color: var(--ok); }
.spec-ep .verb.PATCH { color: var(--warn); }
.spec-ep .verb.PUT   { color: var(--accent); }

/* ---------- DENSITY ---------- */
:root[data-density="compact"] .kpi { padding: 12px 14px; }
:root[data-density="compact"] .card { padding: 14px 16px; }
:root[data-density="compact"] .task-row { padding: 10px 12px; }
:root[data-density="compact"] .nav-item { padding: 7px 12px; font-size: 12px; }

/* ---------- LIGHT MODE PRINT POLISH ---------- */
:root[data-theme="light"] .suite-tile-cover { color: #fff; }
:root[data-theme="light"] .nav-item.active { background: var(--accent-soft); }


/* ---------- KPI DRAG WRAP ---------- */
.kpi-drag-wrap { cursor: grab; transition: transform .14s, opacity .14s; }
.kpi-drag-wrap:active { cursor: grabbing; }
.kpi-drag-wrap.dragging { opacity: .35; }
.kpi-drag-wrap .kpi-grip {
  position: absolute; top: 8px; right: 28px; font-family:'JetBrains Mono',monospace;
  font-size: 9px; color: var(--muted); opacity: 0; letter-spacing: -1px;
  transition: opacity .14s; pointer-events: none;
}
.kpi-drag-wrap:hover .kpi-grip { opacity: .55; }
.kpi-remove {
  position: absolute; top: 6px; right: 8px; width: 18px; height: 18px;
  border-radius: 50%; border: 0; background: transparent; color: var(--muted);
  cursor: pointer; opacity: 0; transition: opacity .14s, background .14s;
  font-size: 13px; line-height: 1;
}
.kpi-drag-wrap:hover .kpi-remove { opacity: .8; }
.kpi-remove:hover { background: var(--warn-soft); color: var(--warn); opacity: 1; }

/* ---------- SPEC FAB ---------- */
.spec-fab {
  position: fixed; bottom: 14px; left: 50%; transform: translateX(-50%);
  background: var(--accent); color: #fff; border: 0;
  padding: 8px 16px; border-radius: 99px; font-family:'JetBrains Mono',monospace;
  font-size: 11px; cursor: pointer; box-shadow: var(--shadow-2);
  z-index: 90; letter-spacing: .04em;
}
.spec-fab:hover { background: var(--accent-strong, #a86539); }

/* ---------- TABS ---------- */
.tabs { display: inline-flex; gap: 2px; margin-bottom: 16px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 9px; padding: 3px; }
.tabs .tab { padding: 6px 14px; background: transparent; border: 0; color: var(--muted);
  cursor: pointer; font-size: 12px; font-weight: 500; border-radius: 6px;
  display: inline-flex; gap: 7px; align-items: center; }
.tabs .tab.on { background: var(--surface); color: var(--text); box-shadow: var(--shadow-1); }
.tabs .tab .count { font-family:'JetBrains Mono',monospace; font-size: 10px;
  background: var(--surface-3); padding: 1px 5px; border-radius: 99px; color: var(--muted); }
.tabs .tab.on .count { background: var(--accent-soft); color: var(--accent); }

/* ---------- INPUT ROW ---------- */
.input-row { display: flex; flex-direction: column; gap: 5px; }
.input-row label { font-size: 10px; color: var(--muted);
  font-family:'JetBrains Mono',monospace; letter-spacing: .08em; text-transform: uppercase; }
.input { background: var(--surface-2); border: 1px solid var(--border); border-radius: 7px;
  padding: 8px 10px; color: var(--text); font-size: 13px; font-family: inherit; outline: none;
  transition: border-color .14s; }
.input:focus { border-color: var(--accent); }
.hr-label { font-size: 10px; color: var(--muted); font-family:'JetBrains Mono',monospace;
  letter-spacing: .12em; text-transform: uppercase; margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px; }
.hr-label::after { content:''; flex: 1; height: 1px; background: var(--border-soft); }

/* ---------- ITALIC TOGGLE ---------- */
:root[data-italics="off"] .eyebrow,
:root[data-italics="off"] h1,
:root[data-italics="off"] h2,
:root[data-italics="off"] h3 { font-style: normal; font-family: 'DM Sans', system-ui, sans-serif; }
:root[data-italics="off"] .brand-name { font-style: normal; font-family: 'DM Sans', system-ui, sans-serif; font-weight: 600; }
:root[data-italics="off"] [style*="Cormorant"] { font-family: 'DM Sans', system-ui, sans-serif !important; font-style: normal !important; }

/* ---------- LIGHT MODE ENHANCEMENTS ---------- */
:root[data-theme="light"] {
  --bg: #faf8f3;
  --surface: #ffffff;
  --surface-2: #f4f0e8;
  --surface-3: #ebe6dc;
  --border: rgba(60,40,25,.10);
  --border-soft: rgba(60,40,25,.06);
  --border-strong: rgba(60,40,25,.18);
  --text: #2a1d12;
  --text-soft: #5a4a3a;
  --muted: #8a7a6a;
  --shadow-1: 0 1px 2px rgba(60,40,25,.05);
  --shadow-2: 0 2px 12px rgba(60,40,25,.08);
  --shadow-3: 0 12px 40px rgba(60,40,25,.16);
}
:root[data-theme="light"] .topbar,
:root[data-theme="light"] .sidebar { background: #ffffff; }
:root[data-theme="light"] .pulse-dot,
:root[data-theme="light"] .ping { box-shadow: 0 0 0 0 var(--accent); }
