/* ── TOKENS ── */
:root {
  /* Surfaces */
  --navy:       #0f0f11;
  --navy2:      #1a1a1e;
  --navy3:      #222228;
  --navy4:      #2a2a32;
  --slate:      #38383f;

  /* Accent */
  --amber:      #f5a623;
  --amber2:     #ffbe4f;
  --amber-dim:  #5c3d0a;

  /* Semantic */
  --cyan:       #32ade6;
  --green:      #30d158;
  --red:        #ff453a;
  --purple:     #bf5af2;
  --indigo:     #5e5ce6;

  /* Type */
  --text:       #f2f2f7;
  --text2:      #aeaeb2;
  --text3:      #636366;

  /* Borders */
  --border:     rgba(255,255,255,0.08);
  --border2:    rgba(255,255,255,0.13);

  /* Inputs */
  --input-bg:   rgba(255,255,255,0.05);

  /* Surface aliases */
  --surface:    var(--navy2);
  --surface2:   var(--navy3);

  /* Category */
  --c-params:   #32ade6;
  --c-occ:      #f5a623;
  --c-ts:       #bf5af2;
  --c-day:      #30d158;
  --c-man:      #ff453a;
  --c-add:      #ffd60a;
  --c-int:      #5e5ce6;
  --c-notes:    #8e8e93;

  --r:    10px;
  --r-sm:  7px;
  --r-lg: 16px;
  --mono:  'Electrolize', 'SF Mono', ui-monospace, monospace;
  --sans:  'Electrolize', -apple-system, sans-serif;
  --base-size: 13px;
  --ls-ui: 0.02em;      /* subtle letter spacing for Electrolize */
  --fs: 1;         /* font scale multiplier — controlled by settings */

  --glass:         rgba(255,255,255,0.04);
  --glass2:        rgba(255,255,255,0.07);
  --glass-border:  rgba(255,255,255,0.10);
  --shadow-sm:     0 1px 3px rgba(0,0,0,0.45), 0 1px 2px rgba(0,0,0,0.3);
  --shadow-md:     0 4px 16px rgba(0,0,0,0.55), 0 2px 6px rgba(0,0,0,0.3);
  --shadow-lg:     0 12px 40px rgba(0,0,0,0.65), 0 4px 16px rgba(0,0,0,0.4);
}

[data-theme="light"] {
  --navy:       #f5f5f7;
  --navy2:      #ffffff;
  --navy3:      #f2f2f4;
  --navy4:      #e8e8ed;
  --slate:      #d8d8df;
  --amber:      #d4810a;
  --amber2:     #b86a00;
  --amber-dim:  #fdecc8;
  --cyan:       #007aff;
  --green:      #1a8a3a;
  --red:        #d70015;
  --purple:     #8944ab;
  --indigo:     #3634a3;
  --text:       #1c1c1e;
  --text2:      #48484a;
  --text3:      #8e8e93;
  --border:     rgba(0,0,0,0.09);
  --border2:    rgba(0,0,0,0.14);
  --input-bg:   rgba(0,0,0,0.04);
  --glass:      rgba(255,255,255,0.65);
  --glass2:     rgba(255,255,255,0.85);
  --glass-border: rgba(0,0,0,0.09);
  --shadow-sm:  0 1px 3px rgba(0,0,0,0.10), 0 1px 2px rgba(0,0,0,0.07);
  --shadow-md:  0 4px 16px rgba(0,0,0,0.11), 0 2px 6px rgba(0,0,0,0.07);
  --shadow-lg:  0 12px 40px rgba(0,0,0,0.16), 0 4px 16px rgba(0,0,0,0.09);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  background: var(--navy);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
  font-size: var(--base-size);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background 0.25s, color 0.25s;
}

/* Subtle noise grain */
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 9999; opacity: 0.6;
}

/* ── HEADER ── */
.header {
  background: rgba(20,20,24,0.88);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  border-bottom: 1px solid var(--glass-border);
  padding: 0 20px;
  height: 52px;
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 200;
  box-shadow: 0 1px 0 var(--glass-border);
}
[data-theme="light"] .header { background: rgba(249,249,251,0.88); }

.header-brand { display: flex; align-items: center; gap: 10px; }
.header-brand .wordmark {
  font-family: var(--sans);
  font-size: calc(22px * var(--fs, 1)); font-weight: 700;
  color: var(--text); letter-spacing: -0.5px;
}
.header-brand .wordmark em { color: var(--amber); font-style: normal; }
.header-brand .wordmark .wm-ver { color: var(--text); font-style: normal; }
.wm-release {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1));
  color: var(--text3); letter-spacing: 0.5px;
  align-self: center; margin-left: 6px; white-space: nowrap;
}
.header-brand .sub {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3);
  letter-spacing: 0.3px; padding: 2px 8px;
  background: var(--glass); border: 1px solid var(--glass-border); border-radius: 20px;
}
.header-brand .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--border2); }
.header-actions { display: flex; gap: 5px; align-items: center; }

/* Header dropdown menu */
.hdr-menu-wrap { position: relative; }
.hdr-menu {
  display: none;
  position: absolute; top: calc(100% + 6px); right: 0;
  background: var(--navy2);
  border: 1px solid var(--border2);
  border-radius: var(--r);
  box-shadow: var(--shadow-lg);
  min-width: 170px;
  z-index: 400;
  overflow: hidden;
  animation: menuFadeIn 0.12s ease;
}
.hdr-menu.open { display: block; }
@keyframes menuFadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hdr-menu-item {
  display: block; width: 100%;
  padding: 9px 14px;
  background: none; border: none;
  font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); font-weight: 500;
  color: var(--text2); text-align: left; cursor: pointer;
  transition: background 0.12s, color 0.12s;
  white-space: nowrap;
}
.hdr-menu-item:hover { background: var(--glass2); color: var(--text); }
.hdr-menu-item + .hdr-menu-item { border-top: 1px solid var(--border); }

/* Global select option dark-mode fix */
select option { background: var(--navy3); color: var(--text); }

/* ── BUTTONS ── */
.btn { letter-spacing: var(--ls-ui);
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 14px; border-radius: 20px; border: 1px solid transparent;
  font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); font-weight: 500;
  letter-spacing: -0.1px; cursor: pointer;
  transition: all 0.18s cubic-bezier(0.34,1.56,0.64,1);
  white-space: nowrap; -webkit-font-smoothing: antialiased;
}
.btn:active { transform: scale(0.96) !important; }
.btn-amber {
  background: var(--amber); color: #000; border-color: var(--amber);
  font-weight: 600; box-shadow: 0 1px 4px rgba(245,166,35,0.3);
}
.btn-amber:hover { background: var(--amber2); box-shadow: 0 2px 10px rgba(245,166,35,0.45); }
.btn-ghost {
  background: var(--glass); color: var(--text2); border-color: var(--glass-border);
}
.btn-ghost:hover { background: var(--glass2); color: var(--text); border-color: var(--border2); }
.btn-danger { background: rgba(255,69,58,0.10); color: var(--red); border-color: rgba(255,69,58,0.22); }
.btn-danger:hover { background: rgba(255,69,58,0.2); }
.btn-cyan { background: rgba(50,173,230,0.10); color: var(--cyan); border-color: rgba(50,173,230,0.22); }
.btn-cyan:hover { background: rgba(50,173,230,0.2); }
.btn-sm { padding: 4px 11px; font-size: clamp(10px, calc(11px * var(--fs, 1)), 13px); border-radius: 16px; min-width: 0; white-space: nowrap; }
.btn:disabled { opacity: 0.35; cursor: not-allowed; transform: none !important; }

/* ── LAYOUT ── */
.layout { display: grid; grid-template-columns: 252px 1fr; min-height: calc(100vh - 52px); }

/* ── SIDEBAR ── */
.sidebar {
  background: var(--navy2); border-right: 1px solid var(--border);
  position: sticky; top: 52px; height: calc(100vh - 52px);
  display: flex; flex-direction: column; overflow: hidden;
}
.sidebar-top {
  padding: 14px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.sidebar-label {
  font-family: var(--sans); font-size: calc(10px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 0.5px; color: var(--text3); text-transform: uppercase; margin-bottom: 8px;
}
.sb-select {
  width: 100%; padding: 7px 10px;
  background: var(--navy3); border: 1px solid var(--border2);
  border-radius: var(--r-sm); color: var(--text);
  font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); margin-bottom: 6px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238e8e93'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.sb-select option { background: var(--navy3); color: var(--text); }
.sb-select:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px rgba(245,166,35,0.14); }
.sb-btn-row { display: flex; gap: 5px; flex-wrap: wrap; }
.sidebar-scroll { flex: 1; overflow-y: auto; padding: 6px 6px; }
.sidebar-scroll::-webkit-scrollbar { width: 3px; }
.sidebar-scroll::-webkit-scrollbar-thumb { background: var(--slate); border-radius: 3px; }

.zone-group { margin-bottom: 4px; border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.zone-header {
  display: flex; align-items: center; gap: 6px; padding: 7px 10px;
  background: var(--glass); cursor: pointer; user-select: none; transition: background 0.14s;
}
.zone-header:hover { background: var(--glass2); }
.zone-name-edit {
  flex: 1; font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 600;
  color: var(--cyan); background: none; border: none; outline: none; cursor: text; min-width: 0;
}
.zone-name-edit::placeholder { color: var(--text3); }
.zone-toggle { font-size: calc(9px * var(--fs, 1)); color: var(--text3); transition: transform 0.2s; }
.zone-toggle.closed { transform: rotate(-90deg); }
.zone-rooms { padding: 4px; display: flex; flex-direction: column; gap: 2px; }
.zone-rooms.hidden { display: none; }
.zone-add { padding: 4px 6px; }

.room-item {
  display: flex; align-items: center; gap: 6px; padding: 6px 8px;
  border-radius: var(--r-sm); cursor: pointer; transition: all 0.14s; border: 1px solid transparent;
}
.room-item:hover { background: var(--glass); }
.room-item.active { background: rgba(245,166,35,0.09); border-color: rgba(245,166,35,0.28); }
.room-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.room-label { flex: 1; font-size: calc(11px * var(--fs, 1)); font-family: var(--sans); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.room-label .rname { color: var(--text); font-weight: 500; }
.room-label .rtype { color: var(--text3); font-size: calc(9px * var(--fs, 1)); display: block; }
.room-acts { display: flex; gap: 1px; opacity: 0; transition: opacity 0.14s; }
.room-item:hover .room-acts { opacity: 1; }
.room-acts button {
  background: none; border: none; cursor: pointer; color: var(--text3);
  font-size: calc(10px * var(--fs, 1)); padding: 2px 5px; border-radius: var(--r-sm); transition: all 0.12s;
}
.room-acts button:hover { background: var(--glass2); color: var(--text); }
.room-acts button.del:hover { color: var(--red); }

/* ── MAIN ── */
.main { padding: 22px 26px; overflow-y: auto; }

/* ── CARD ── */
.card {
  background: var(--navy2); border: 1px solid var(--border);
  border-radius: var(--r-lg); margin-bottom: 12px;
  box-shadow: var(--shadow-sm); overflow: hidden; transition: box-shadow 0.2s;
}
.card:hover { box-shadow: var(--shadow-md); }
.card-header {
  padding: 12px 18px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px; background: var(--glass);
}
.card-header h2 {
  font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 0.4px; text-transform: uppercase; color: var(--text3); flex: 1;
}
.card-body { padding: 18px; }

/* ── PROJECT INFO GRID ── */
.proj-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 12px; }
.proj-grid.full { grid-template-columns: 1fr; }

.fg { display: flex; flex-direction: column; gap: 4px; }
.fg label {
  font-family: var(--sans); font-size: calc(10px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 0.3px; text-transform: uppercase; color: var(--text3);
}
.fg input, .fg select, .fg textarea {
  padding: 8px 11px; background: var(--navy3); border: 1px solid var(--border2);
  border-radius: var(--r-sm); color: var(--text); font-family: var(--sans);
  font-size: calc(13px * var(--fs, 1)); line-height: 1.5; width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.fg select option { background: var(--navy3); color: var(--text); }
.fg input:focus, .fg select:focus, .fg textarea:focus {
  outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px rgba(245,166,35,0.14);
}
.fg textarea { resize: vertical; min-height: 72px; line-height: 1.65; }
.fg select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238e8e93'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; cursor: pointer;
}

/* ── TOGGLE PILLS ── */
.pill-group { display: flex; gap: 5px; flex-wrap: wrap; }
.pill {
  padding: 5px 13px; border-radius: 20px; border: 1px solid var(--border2);
  background: var(--glass); font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 500;
  cursor: pointer; transition: all 0.15s cubic-bezier(0.34,1.56,0.64,1); color: var(--text2);
}
.pill:hover { border-color: rgba(245,166,35,0.4); color: var(--amber); background: var(--glass2); }
.pill.on { background: rgba(245,166,35,0.13); border-color: var(--amber); color: var(--amber); }

/* ── DIVIDER ── */
.hr { border: none; border-top: 1px solid var(--border); margin: 14px 0; }

/* ── CAT SECTIONS ── */
.cat-section { border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 8px; overflow: hidden; }
.cat-hdr {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  cursor: pointer; user-select: none; transition: filter 0.1s;
}
.cat-hdr:hover { filter: brightness(1.07); }
.cat-pip { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.cat-title { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 600; letter-spacing: 0.2px; text-transform: uppercase; flex: 1; color: var(--text); }
.cat-sup { font-size: calc(9px * var(--fs, 1)); font-family: var(--mono); opacity: 0.55; font-style: italic; }
.cat-arr { font-size: calc(10px * var(--fs, 1)); color: var(--text3); transition: transform 0.2s; }
.cat-arr.open { transform: rotate(180deg); }
.cat-body { padding: 14px; border-top: 1px solid var(--border); background: var(--navy3); display: none; }
.cat-body.open { display: block; }
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 10px; align-items: start; }
.cat-grid.two { grid-template-columns: 1fr 1fr; align-items: start; }
.cat-grid.one { grid-template-columns: 1fr; }

.cat-alert { padding: 8px 12px; border-radius: var(--r-sm); font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); margin-bottom: 10px; }

.chk-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; }
.chk-row input[type=checkbox] { width: 15px; height: 15px; cursor: pointer; accent-color: var(--amber); flex-shrink: 0; }
.chk-row label { font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); cursor: pointer; color: var(--text2); line-height: 1.5; }

/* ── ROOM EDITOR HEADER ── */
.room-editor-top { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.re-name {
  font-family: var(--sans); font-size: calc(20px * var(--fs, 1)); font-weight: 700; color: var(--text);
  background: none; border: none; border-bottom: 2px solid var(--border2); outline: none;
  padding: 2px 4px; transition: border-color 0.15s; min-width: 200px; letter-spacing: -0.3px;
}
.re-name:focus { border-bottom-color: var(--amber); }
.re-tag { font-family: var(--sans); font-size: calc(10px * var(--fs, 1)); font-weight: 600; letter-spacing: 0.2px; text-transform: uppercase; padding: 3px 10px; border-radius: 20px; border: 1px solid; }

/* ── EMPTY STATE ── */
.empty { text-align: center; padding: 80px 20px; }
.empty .e-title { font-family: var(--sans); font-size: calc(22px * var(--fs, 1)); font-weight: 700; color: var(--text); letter-spacing: -0.5px; margin-bottom: 8px; }
.empty .e-sub { font-size: calc(14px * var(--fs, 1)); color: var(--text3); margin-bottom: 32px; }

/* Onboarding */
.onboard-hero { margin-bottom: 36px; }
.onboard-logo { font-family: var(--sans); font-size: calc(32px * var(--fs, 1)); font-weight: 700; color: var(--text); letter-spacing: -0.5px; margin-bottom: 6px; }
.onboard-logo em { color: var(--amber); font-style: normal; }
.onboard-logo .wm-ver { color: var(--text); font-style: normal; }
.onboard-tagline { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--amber); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 12px; }
.onboard-desc { font-size: calc(14px * var(--fs, 1)); color: var(--text3); max-width: 540px; margin: 0 auto; line-height: 1.6; }
.onboard-steps { display: flex; align-items: stretch; justify-content: center; gap: 0; flex-wrap: wrap; margin-bottom: 40px; max-width: 860px; margin-left: auto; margin-right: auto; }
.onboard-step { background: var(--glass); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 20px 18px; flex: 1; min-width: 160px; max-width: 200px; text-align: left; display: flex; flex-direction: column; cursor: pointer; transition: border-color 0.15s, background 0.15s, transform 0.1s; user-select: none; }
.onboard-step:hover { border-color: var(--amber); background: rgba(255,175,50,0.07); transform: translateY(-2px); }
.onboard-step:active { transform: translateY(0); background: rgba(255,175,50,0.12); }
.onboard-step-arrow { align-self: center; color: var(--text3); font-size: calc(18px * var(--fs, 1)); padding: 0 8px; flex-shrink: 0; }
.onboard-step-num { width: 26px; height: 26px; border-radius: 50%; background: var(--amber); color: #000; font-family: var(--sans); font-size: calc(13px * var(--fs, 1)); font-weight: 700; display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }
.onboard-step-title { font-family: var(--sans); font-size: calc(13px * var(--fs, 1)); font-weight: 700; color: var(--text); margin-bottom: 6px; }
.onboard-step-sub { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); color: var(--text3); line-height: 1.5; }
.onboard-step-sub strong { color: var(--text2); font-weight: 600; }
.onboard-divider { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; color: var(--text3); font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); letter-spacing: 0.5px; text-transform: uppercase; }
.onboard-divider::before, .onboard-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.onboard-hint { margin-top: 28px; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); background: var(--glass); border: 1px solid var(--border); border-radius: var(--r); padding: 8px 16px; display: inline-block; }
kbd { display: inline-block; background: var(--glass2); border: 1px solid var(--border2); border-radius: 4px; padding: 1px 6px; font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text2); }

.version-badge {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight: 500;
  color: var(--text3); letter-spacing: 0.3px;
  padding: 2px 6px; border-radius: 20px;
  background: var(--glass); border: 1px solid var(--glass-border);
  align-self: center; margin-left: 2px;
}

/* Save indicator */
.save-indicator { width: 7px; height: 7px; border-radius: 50%; background: transparent; border: 1.5px solid transparent; transition: all 0.3s; flex-shrink: 0; }
.save-indicator.unsaved { background: var(--amber); border-color: var(--amber); box-shadow: 0 0 6px rgba(245,166,35,0.5); animation: savePulse 1.2s ease infinite; }
@keyframes savePulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
.preset-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; max-width: 680px; margin: 0 auto; }
.preset-tile {
  background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r);
  padding: 16px 10px; cursor: pointer; text-align: center; box-shadow: var(--shadow-sm);
  transition: all 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
.preset-tile:hover { border-color: var(--amber); transform: translateY(-3px) scale(1.02); box-shadow: var(--shadow-md); }
.preset-tile .pt-icon { font-size: calc(24px * var(--fs, 1)); margin-bottom: 6px; }
.preset-tile .pt-name { font-family: var(--sans); font-size: calc(10px * var(--fs, 1)); font-weight: 600; letter-spacing: 0.3px; color: var(--text2); text-transform: uppercase; }

/* ── OUTPUT SECTION ── */
.output-card { background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r-lg); margin-top: 16px; margin-bottom: 32px; overflow: hidden; box-shadow: var(--shadow-md); }
.output-card-header { padding: 13px 20px; background: var(--glass); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
.output-card-header h2 { font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); font-weight: 700; letter-spacing: 0.2px; text-transform: uppercase; color: var(--amber); flex: 1; }
.out-tabs { display: flex; border-bottom: 1px solid var(--border); overflow-x: auto; scrollbar-width: none; padding: 0 6px; background: var(--glass); }
.out-tabs::-webkit-scrollbar { display: none; }
.out-tab { letter-spacing: var(--ls-ui); padding: 11px 16px; background: none; border: none; font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 500; text-transform: uppercase; cursor: pointer; color: var(--text3); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 0.15s; white-space: nowrap; }
.out-tab:hover { color: var(--text2); }
.out-tab.active { color: var(--amber); border-bottom-color: var(--amber); font-weight: 600; }
.out-tab-divider { width: 1px; background: var(--border); margin: 8px 4px; flex-shrink: 0; align-self: stretch; }
.help-nav-btn { display:block; width:100%; text-align:left; background:none; border:none; padding:6px 16px; font-family:var(--mono); font-size:11px; color:var(--text3); cursor:pointer; transition:all 0.12s; white-space:nowrap; }
.help-nav-btn:hover { color:var(--text); background:var(--glass); }
.help-nav-btn.active { color:var(--amber); background:rgba(245,166,35,0.08); border-left:2px solid var(--amber); padding-left:14px; }
.help-h1 { font-family:var(--sans); font-size:18px; font-weight:700; color:var(--text); margin:0 0 6px; letter-spacing:-0.3px; }
.help-h2 { font-family:var(--mono); font-size:11px; font-weight:700; color:var(--amber); letter-spacing:1.5px; text-transform:uppercase; margin:22px 0 10px; padding-bottom:5px; border-bottom:1px solid var(--border); }
.help-p  { margin:0 0 12px; color:var(--text2); font-size:13px; line-height:1.65; }
.help-tip { background:rgba(78,184,200,0.08); border-left:3px solid var(--cyan); padding:10px 14px; border-radius:0 4px 4px 0; margin:12px 0; font-size:12px; color:var(--text2); }
.help-warn { background:rgba(245,166,35,0.08); border-left:3px solid var(--amber); padding:10px 14px; border-radius:0 4px 4px 0; margin:12px 0; font-size:12px; color:var(--text2); }
.help-kbd { display:inline-block; background:var(--navy3); border:1px solid var(--border2); border-radius:3px; padding:1px 6px; font-family:var(--mono); font-size:11px; color:var(--text); margin:0 2px; }
.help-table { width:100%; border-collapse:collapse; margin:12px 0; font-size:12px; }
.help-table th { text-align:left; padding:6px 10px; background:var(--navy3); color:var(--text3); font-family:var(--mono); font-size:10px; letter-spacing:0.5px; text-transform:uppercase; border:1px solid var(--border2); }
.help-table td { padding:7px 10px; border:1px solid var(--border2); color:var(--text2); vertical-align:top; }
.help-table tr:nth-child(even) td { background:var(--glass); }
.help-li { padding:3px 0 3px 0; color:var(--text2); font-size:13px; }
.out-pane { display: none; }
.out-pane.active { display: block; }

/* ── One-line diagram tab — screen styles ── */
.old-wrap { padding: 16px 20px; }
.old-tab-controls { display: flex; align-items: center; gap: 6px; padding: 0 0 14px; flex-wrap: wrap; }
.old-filter-btn {
  font-family: var(--mono); font-size: calc(10px * var(--fs,1));
  background: var(--navy3); border: 1px solid var(--border2);
  color: var(--text3); padding: 4px 12px; border-radius: 20px;
  cursor: pointer; transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.old-filter-btn:hover { border-color: var(--amber); color: var(--text); }
.old-filter-btn.active { background: var(--amber); color: #000; border-color: var(--amber); font-weight: 700; }
.old-export-btn {
  margin-left: auto;
  font-family: var(--mono); font-size: calc(10px * var(--fs,1));
  background: var(--amber); border: 1px solid var(--amber);
  color: #000; font-weight: 700; padding: 4px 12px; border-radius: 20px;
  cursor: pointer; transition: background 0.15s, border-color 0.15s;
}
.old-export-btn:hover { background: var(--amber2); border-color: var(--amber2); }
.old-room-block { margin-bottom: 20px; background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.old-svg-wrap { background: var(--navy); border-radius: 0 0 var(--r) var(--r); }
.old-room-hdr { display: flex; align-items: center; gap: 10px; padding: 10px 16px; background: var(--navy3); border-bottom: 1px solid var(--border); font-family: var(--mono); font-size: calc(11px * var(--fs,1)); color: var(--text2); }
.old-room-hdr .old-room-name { font-weight: 700; font-size: calc(12px * var(--fs,1)); color: var(--amber); }
.old-room-hdr .old-room-zone { color: var(--text3); font-size: calc(10px * var(--fs,1)); margin-left: auto; }
.old-svg-wrap { padding: 16px 20px; overflow-x: auto; }

.narrative-wrap { padding: 20px; }
.narrative-doc { background: var(--navy); border: 1px solid var(--border); border-radius: var(--r); padding: 24px; font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); line-height: 1.85; color: var(--text); white-space: pre-wrap; min-height: 200px; max-height: 70vh; overflow-y: auto; }
.narrative-doc .nd-placeholder { color: var(--text3); font-style: italic; }

.table-wrap { overflow-x: auto; }
.ctable { width: 100%; border-collapse: collapse; font-size: calc(10px * var(--fs, 1)); font-family: var(--mono); min-width: 1000px; }
.ctable th { padding: 8px 10px; font-size: calc(9px * var(--fs, 1)); font-weight: 600; letter-spacing: 0.8px; text-transform: uppercase; border: 1px solid var(--border); white-space: nowrap; text-align: left; }
.ctable td { padding: 7px 10px; border: 1px solid var(--border); vertical-align: top; font-size: calc(10px * var(--fs, 1)); line-height: 1.4; background: var(--navy2); }
.ctable tr:nth-child(even) td { background: var(--navy3); }
.ctable .zone-row td { background: var(--navy4) !important; font-weight: 600; color: var(--cyan); letter-spacing: 1px; font-size: calc(10px * var(--fs, 1)); }

/* Category header colours */
.th-p  { background: rgba(50,173,230,0.15);  color: var(--c-params); }
.th-o  { background: rgba(245,166,35,0.15);  color: var(--c-occ); }
.th-t  { background: rgba(191,90,242,0.15);  color: var(--c-ts); }
.th-d  { background: rgba(48,209,88,0.15);   color: var(--c-day); }
.th-m  { background: rgba(255,69,58,0.15);   color: var(--c-man); }
.th-a  { background: rgba(255,214,10,0.15);  color: var(--c-add); }
.th-i  { background: rgba(94,92,230,0.15);   color: var(--c-int); }
.th-n  { background: rgba(142,142,147,0.12); color: var(--c-notes); }

/* Badges */
.b { display: inline-block; padding: 2px 7px; border-radius: 20px; font-size: calc(9px * var(--fs, 1)); font-weight: 600; letter-spacing: 0.3px; }
.b-y  { background: rgba(48,209,88,0.15);   color: var(--green); }
.b-n  { background: rgba(255,69,58,0.15);   color: var(--red); }
.b-a  { background: rgba(50,173,230,0.15);  color: var(--cyan); }
.b-m  { background: rgba(245,166,35,0.18);  color: var(--amber); }

/* ── TOAST ── */
#toast {
  position: fixed; bottom: 24px; right: 24px;
  background: var(--amber); color: var(--navy);
  padding: 10px 18px; border-radius: 6px;
  font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 0.5px;
  transform: translateY(60px); opacity: 0;
  transition: all 0.2s; z-index: 9999;
}
#toast.show { transform: none; opacity: 1; }

/* ── MODAL ── */
.modal-bg {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.7); z-index: 500;
  align-items: center; justify-content: center;
}
.modal-bg.open { display: flex; }
.modal {
  background: var(--surface); border: 1px solid var(--border2);
  border-top: 2px solid var(--amber);
  border-radius: 8px; padding: 24px; width: 460px; max-width: 90vw;
}
.modal h3 { font-family: var(--mono); font-size: calc(13px * var(--fs, 1)); font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--amber); margin-bottom: 16px; }
.modal-footer { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }

/* scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--navy); }
::-webkit-scrollbar-thumb { background: var(--slate); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--amber-dim); }

/* ══ COMPLIANCE ENGINE ══ */
.comp-bar { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:6px; border:1px solid; margin-bottom:12px; cursor:pointer; transition:filter 0.15s; user-select:none; }
.comp-bar:hover { filter:brightness(1.08); }
.comp-bar.pass { background:rgba(82,201,122,0.07); border-color:rgba(82,201,122,0.35); }
.comp-bar.warn { background:rgba(232,164,48,0.07); border-color:rgba(232,164,48,0.35); }
.comp-bar.fail { background:rgba(224,82,82,0.07);  border-color:rgba(224,82,82,0.35); }
.comp-bar .cb-ico  { font-size: calc(15px * var(--fs, 1)); flex-shrink:0; }
.comp-bar .cb-lbl  { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight:600; letter-spacing:1px; text-transform:uppercase; flex:1; }
.comp-bar.pass .cb-lbl { color:var(--green); }
.comp-bar.warn .cb-lbl { color:var(--amber); }
.comp-bar.fail .cb-lbl { color:var(--red); }
.comp-bar .cb-cnt  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.comp-bar .cb-arr  { font-size: calc(10px * var(--fs, 1)); color:var(--text3); transition:transform 0.2s; }
.comp-bar .cb-arr.open { transform:rotate(180deg); }
.comp-panel { display:none; flex-direction:column; gap:5px; margin-bottom:14px; padding:10px; background:rgba(0,0,0,0.2); border:1px solid var(--border); border-radius:6px; }
.comp-panel.open { display:flex; }
.ci { display:flex; gap:8px; align-items:flex-start; padding:8px 10px; border-radius:5px; border-left:3px solid; background:rgba(0,0,0,0.12); }
.ci.fail { border-left-color:var(--red); }
.ci.warn { border-left-color:var(--amber); }
.ci.pass { border-left-color:var(--green); }
.ci-ico  { font-size: calc(12px * var(--fs, 1)); flex-shrink:0; margin-top:2px; }
.ci-body { flex:1; }
.ci-rule { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight:600; margin-bottom:3px; }
.ci.fail .ci-rule { color:var(--red); }
.ci.warn .ci-rule { color:var(--amber); }
.ci.pass .ci-rule { color:var(--green); }
.ci-desc { font-size: calc(11px * var(--fs, 1)); color:var(--text2); line-height:1.5; }
.ci-fix  { margin-top:5px; padding:5px 8px; background:rgba(255,255,255,0.04); border-radius:4px; font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); line-height:1.5; }
.ci-fix strong { color:var(--amber); }
.ci-ref  { margin-top:4px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); letter-spacing:0.5px; }
.rdot-wrap { position:relative; width:10px; height:10px; flex-shrink:0; }
.rdot-main { width:8px; height:8px; border-radius:50%; position:absolute; top:1px; left:1px; }
.rdot-comp { position:absolute; top:-2px; right:-2px; width:6px; height:6px; border-radius:50%; border:1px solid var(--navy2); }
.rdot-comp.pass { background:var(--green); }
.rdot-comp.warn { background:var(--amber); }
.rdot-comp.fail { background:var(--red); }
.comp-sum { padding:20px; }
.comp-scorecard { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.score-tile { flex:1; min-width:90px; background:rgba(0,0,0,0.2); border:1px solid var(--border); border-radius:6px; padding:14px; text-align:center; }
.score-tile .stn { font-family:var(--mono); font-size: calc(30px * var(--fs, 1)); font-weight:700; line-height:1; }
.score-tile .stl { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); margin-top:4px; }
.score-tile.stf .stn { color:var(--red); }
.score-tile.stw .stn { color:var(--amber); }
.score-tile.stp .stn { color:var(--green); }
.score-tile.stt .stn { color:var(--text2); }
.crr { background:rgba(0,0,0,0.15); border:1px solid var(--border); border-radius:6px; margin-bottom:8px; overflow:hidden; }
.crr-hdr { display:flex; align-items:center; gap:8px; padding:10px 14px; cursor:pointer; transition:background 0.1s; }
.crr-hdr:hover { background:rgba(255,255,255,0.03); }
.crr-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.crr-nm  { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; flex:1; }
.crr-zn  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.crr-badges { display:flex; gap:6px; }
.crr-badge { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); padding:2px 7px; border-radius:10px; }
.crr-badge.f { background:rgba(224,82,82,0.2); color:var(--red); }
.crr-badge.w { background:rgba(232,164,48,0.2); color:var(--amber); }
.crr-badge.p { background:rgba(82,201,122,0.2); color:var(--green); }
.crr-body { padding:0 14px 10px; display:none; }
.crr-body.open { display:block; }


/* ── ROOM STATUS BADGES ── */
.status-dot { display:inline-flex; align-items:center; gap:4px; padding:2px 7px; border-radius:10px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight:600; letter-spacing:0.5px; cursor:pointer; user-select:none; border:1px solid; transition:opacity 0.15s; }
.status-dot:hover { opacity:0.8; }
.status-dot.ns  { background:rgba(80,96,112,0.2); border-color:rgba(80,96,112,0.4); color:var(--text3); }
.status-dot.ip  { background:rgba(78,184,200,0.15); border-color:rgba(78,184,200,0.4); color:var(--cyan); }
.status-dot.done{ background:rgba(232,164,48,0.15); border-color:rgba(232,164,48,0.4); color:var(--amber); }
.status-dot.appr{ background:rgba(82,201,122,0.15); border-color:rgba(82,201,122,0.4); color:var(--green); }
.progress-bar-wrap { display:flex; align-items:center; gap:8px; padding:4px 0; }
.progress-bar { flex:1; height:3px; background:var(--navy3); border-radius:2px; overflow:hidden; }
.progress-bar-fill { height:100%; background:linear-gradient(90deg,var(--cyan),var(--green)); border-radius:2px; transition:width 0.4s; }

/* ── CX CHECKLIST ── */
.cx-room-hdr { display:flex; align-items:center; gap:10px; padding:12px 16px; background:var(--navy3); border:1px solid var(--border); border-radius:6px; margin-bottom:8px; cursor:pointer; }
.cx-room-hdr:hover { background:var(--navy4); }
.cx-room-body { padding:0 4px 16px; }
.cx-section { margin-bottom:14px; }
.cx-sec-title { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); padding:6px 0 8px; border-bottom:1px solid var(--border); margin-bottom:8px; }
.cx-item { display:grid; grid-template-columns:24px 1fr 90px 90px 100px; gap:8px; align-items:start; padding:8px 10px; border-radius:5px; background:rgba(0,0,0,0.12); margin-bottom:5px; }
.cx-item:nth-child(even) { background:var(--navy4); }
.cx-chk { width:16px; height:16px; accent-color:var(--green); cursor:pointer; margin-top:2px; }
.cx-label { font-size: calc(11px * var(--fs, 1)); color:var(--text2); line-height:1.5; }
.cx-label strong { color:var(--text); font-weight:500; }
.cx-input-sm { background:var(--navy3); border:1px solid var(--border); border-radius:4px; color:var(--text); font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); padding:4px 6px; width:100%; }
.cx-input-sm:focus { outline:none; border-color:var(--amber); }
.cx-status-sel { background:var(--navy3); border:1px solid var(--border); border-radius:4px; color:var(--text); font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); padding:4px 5px; width:100%; }
.cx-signoff { background:var(--surface2); border:1px solid var(--border2); border-radius:6px; padding:18px; margin-top:20px; }
.cx-signoff-title { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--amber); margin-bottom:14px; }
.cx-signoff-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.cx-sig-block { border:1px solid var(--border2); border-radius:4px; padding:12px; }
.cx-sig-label { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); letter-spacing:1px; margin-bottom:8px; }
.cx-sig-line { border-bottom:1px solid var(--border2); margin-bottom:6px; height:28px; }
.cx-scorecard { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.cx-tile { flex:1; min-width:70px; background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:10px 12px; text-align:center; }
.cx-tile .ctn { font-family:var(--mono); font-size: calc(24px * var(--fs, 1)); font-weight:700; line-height:1; }
.cx-tile .ctl { font-family:var(--mono); font-size: calc(8px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); margin-top:3px; }
.cx-tile.ctf .ctn { color:var(--red); } .cx-tile.ctw .ctn { color:var(--amber); } .cx-tile.ctp .ctn { color:var(--green); } .cx-tile.ctt .ctn { color:var(--text2); }

/* ── REVISION HISTORY ── */
.rev-entry { display:grid; grid-template-columns:110px 60px 1fr auto; gap:10px; align-items:center; padding:10px 12px; border-radius:5px; background:rgba(0,0,0,0.12); margin-bottom:6px; }
.rev-entry:nth-child(even) { background:rgba(0,0,0,0.06); }
.rev-date { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.rev-ver  { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight:600; color:var(--amber); }
.rev-desc { font-size: calc(11px * var(--fs, 1)); color:var(--text2); }
.rev-del  { background:none; border:none; color:var(--text3); cursor:pointer; font-size: calc(12px * var(--fs, 1)); padding:2px 5px; border-radius:3px; }
.rev-del:hover { color:var(--red); background:rgba(224,82,82,0.1); }
.rev-add-row { display:flex; gap:8px; align-items:center; margin-top:10px; padding-top:10px; border-top:1px solid var(--border); }
.rev-add-row input { flex:1; }


/* ════════════════════════════════════════════════════════════
   PRINT / PDF STYLESHEET
   Triggered by window.print() or browser Ctrl+P
   Hides UI chrome, renders a clean document layout
   ════════════════════════════════════════════════════════════ */
@media print {
  /* ── Reset for print ── */
  *, *::before, *::after { box-sizing: border-box; }

  body {
    background: #fff !important;
    color: #111 !important;
    font-family: 'IBM Plex Sans', Arial, sans-serif !important;
    font-size: 9pt !important;
    margin: 0; padding: 0;
  }
  body::before { display: none !important; }   /* kill scanline */

  /* ── ONE-LINE DIAGRAM ── */
  .old-wrap {
    padding: 16px 0;
  }
  .old-room-block {
    margin-bottom: 28px;
    background: var(--navy2, #12121a);
    border: 1px solid var(--border, rgba(255,255,255,0.08));
    border-radius: 10px;
    overflow: hidden;
  }
  .old-room-hdr {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 16px;
    background: var(--navy3, #1a1a24);
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.08));
    font-family: var(--mono); font-size: 11px; color: var(--text);
  }
  .old-room-hdr .old-room-name { font-weight: 700; font-size: 12px; color: var(--amber); }
  .old-room-hdr .old-room-zone { color: var(--text3); font-size: 10px; margin-left: auto; }
  .old-svg-wrap {
    padding: 20px 24px;
    overflow-x: auto;
  }
  .old-svg-wrap svg {
    display: block;
    min-width: 100%;
  }
  /* mini preview inside room editor */
  .old-preview-wrap {
    margin-top: 14px;
    background: var(--navy3, #1a1a24);
    border: 1px solid var(--border, rgba(255,255,255,0.08));
    border-radius: 8px;
    overflow: hidden;
  }
  .old-preview-hdr {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.08));
    font-family: var(--mono); font-size: 10px; color: var(--text3);
    letter-spacing: 1px; text-transform: uppercase;
  }
  .old-preview-hdr span { color: var(--amber); }
  .old-preview-svg { padding: 14px 18px; overflow-x: auto; }
  .old-tab-controls {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 0 4px;
    flex-wrap: wrap;
  }
  .old-filter-btn {
    font-family: var(--mono); font-size: 10px;
    background: var(--navy3); border: 1px solid var(--border);
    color: var(--text3); padding: 4px 12px; border-radius: 20px; cursor: pointer;
  }
  .old-filter-btn.active { background: var(--amber); color: #000; border-color: var(--amber); font-weight: 700; }
  .old-export-btn {
    margin-left: auto;
    font-family: var(--mono); font-size: 10px;
    background: none; border: 1px solid var(--border);
    color: var(--text3); padding: 4px 12px; border-radius: 20px; cursor: pointer;
  }
  .old-export-btn:hover { border-color: var(--amber); color: var(--amber); }

  /* ── Hide everything except the print container ── */
  .header, .sidebar, #editorArea, .out-tabs,
  .output-card-header, .btn, button,
  .modal-bg, #toast, .sidebar-top,
  .out-pane:not(.active),
  #pane-cin .narrative-wrap,
  #pane-soo .narrative-wrap,
  .nd-placeholder { display: none !important; }

  /* ── Layout: single column ── */
  .layout { display: block !important; }
  .main   { padding: 0 !important; overflow: visible !important; }
  .card, .output-card { box-shadow: none !important; border: none !important; background: #fff !important; }
  .card-header { display: none !important; }
  .card-body { padding: 0 !important; }

  /* ── Print container is injected dynamically ── */
  #printDoc {
    display: block !important;
    font-family: 'IBM Plex Sans', Arial, sans-serif;
    color: #111;
    font-size: 9pt;
    line-height: 1.5;
  }

  /* ── Cover page ── */
  .p-cover {
    page-break-after: always;
    padding: 60px 50px;
    border-bottom: 3px solid #0d1b2a;
  }
  .p-firm { font-size: 10pt; color: #444; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 40px; }
  .p-title { font-size: 22pt; font-weight: 700; color: #0d1b2a; margin-bottom: 6px; line-height: 1.2; }
  .p-subtitle { font-size: 12pt; color: #555; margin-bottom: 40px; }
  .p-meta-grid { display: grid; grid-template-columns: 140px 1fr; gap: 8px 16px; font-size: 9pt; margin-bottom: 40px; }
  .p-meta-label { color: #888; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; font-size: 8pt; }
  .p-meta-value { color: #111; }
  .p-rev-block { border-top: 1px solid #ccc; padding-top: 16px; }
  .p-rev-table { width: 100%; border-collapse: collapse; font-size: 8pt; }
  .p-rev-table th { background: #f0f0f0; padding: 5px 8px; text-align: left; border: 1px solid #ccc; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; font-size: 7pt; }
  .p-rev-table td { padding: 5px 8px; border: 1px solid #ddd; }

  /* ── Section headers ── */
  .p-section { page-break-before: always; padding: 30px 50px; }
  .p-section:first-child { page-break-before: avoid; }
  .p-sec-title {
    font-size: 13pt; font-weight: 700; color: #0d1b2a;
    border-bottom: 2px solid #0d1b2a;
    padding-bottom: 6px; margin-bottom: 16px;
    text-transform: uppercase; letter-spacing: 1px;
  }
  .p-sec-sub { font-size: 8pt; color: #666; margin-top: -12px; margin-bottom: 16px; text-transform: uppercase; letter-spacing: 1px; }

  /* ── CIN narrative ── */
  .p-cin-block { margin-bottom: 20px; break-inside: avoid; }
  .p-zone-hdr { background: #f0f0f0; padding: 6px 10px; font-weight: 700; font-size: 9pt; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; border-left: 4px solid #0d1b2a; }
  .p-room-hdr { font-weight: 700; font-size: 9pt; margin-bottom: 4px; color: #0d1b2a; }
  .p-room-type { font-size: 8pt; color: #666; margin-bottom: 6px; }
  .p-room-text { font-size: 9pt; line-height: 1.6; margin-bottom: 8px; }
  .p-room-note { font-size: 8pt; color: #555; font-style: italic; border-left: 2px solid #ccc; padding-left: 8px; }

  /* ── SOO ── */
  .p-soo-room { break-inside: avoid; margin-bottom: 20px; border: 1px solid #ccc; border-radius: 4px; overflow: hidden; }
  .p-soo-room-hdr { background: #0d1b2a; color: #fff; padding: 8px 12px; font-weight: 700; font-size: 9pt; }
  .p-soo-room-hdr span { font-size: 8pt; font-weight: 400; color: #aaa; margin-left: 8px; }
  .p-soo-table { width: 100%; border-collapse: collapse; font-size: 8pt; }
  .p-soo-table tr:nth-child(even) td { background: #f9f9f9; }
  .p-soo-table td { padding: 5px 10px; border-bottom: 1px solid #eee; vertical-align: top; }
  .p-soo-table td:first-child { font-weight: 600; color: #333; width: 160px; white-space: nowrap; }
  .p-soo-cat { background: #f0f0f0; font-size: 7pt; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #666; padding: 4px 10px; }

  /* ── Matrix table ── */
  .p-matrix { page-break-before: always; padding: 20px 15px; }
  .p-matrix table { width: 100%; border-collapse: collapse; font-size: 6.5pt; }
  .p-matrix th { background: #0d1b2a; color: #fff; padding: 4px 4px; text-align: center; font-size: 6pt; font-weight: 600; border: 1px solid #444; }
  .p-matrix td { padding: 4px 4px; border: 1px solid #ccc; text-align: center; }
  .p-matrix tr:nth-child(even) td { background: #f9f9f9; }
  .p-matrix .zone-row td { background: #0d1b2a; color: #fff; font-weight: 700; text-align: left; font-size: 7pt; }

  /* ── Cx checklist ── */
  .p-cx-item { display: grid; grid-template-columns: 16px 1fr 100px 100px 80px; gap: 6px; align-items: start; padding: 5px 8px; border-bottom: 1px solid #eee; font-size: 8pt; break-inside: avoid; }
  .p-cx-chk { width: 12px; height: 12px; border: 1px solid #999; border-radius: 2px; margin-top: 2px; background: #fff; flex-shrink: 0; }
  .p-cx-chk.done { background: #0d1b2a; border-color: #0d1b2a; }
  .p-cx-col-hdr { font-weight: 700; font-size: 7pt; color: #888; text-align: center; }
  .p-cx-val { font-size: 8pt; color: #333; text-align: center; border-bottom: 1px dotted #ccc; min-height: 14px; }
  .p-cx-notes { font-size: 7pt; color: #666; font-style: italic; }
  .p-signoff { page-break-before: always; padding: 40px 50px; }
  .p-sig-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px 50px; margin-top: 20px; }
  .p-sig-block { border-bottom: 1px solid #000; padding-bottom: 2px; margin-bottom: 4px; height: 36px; display:flex; align-items:flex-end; }
  .p-sig-label { font-size: 8pt; color: #666; }
  .p-sig-val { font-size: 9pt; }

  /* ── Compliance section ── */
  .p-comp-room { break-inside: avoid; margin-bottom: 12px; border: 1px solid #ccc; border-radius: 3px; }
  .p-comp-room-hdr { padding: 6px 10px; font-weight: 700; font-size: 9pt; background: #f0f0f0; }
  .p-comp-issue { display: flex; gap: 8px; padding: 5px 10px; border-bottom: 1px solid #eee; font-size: 8pt; }
  .p-comp-ico { font-size: 10pt; flex-shrink: 0; }
  .p-comp-rule { font-weight: 600; }
  .p-comp-desc { color: #444; }
  .p-comp-fail .p-comp-rule { color: #c0392b; }
  .p-comp-warn .p-comp-rule { color: #d35400; }
  .p-comp-pass .p-comp-rule { color: #27ae60; }

  /* ── Page numbers via CSS counter ── */
  @page { margin: 15mm 15mm 20mm; size: letter; }
  @page { @bottom-center { content: counter(page) ' / ' counter(pages); font-size: 8pt; color: #999; } }

  /* ── Live matrix table print styles ── */
  #pane-matrix.active { display: block !important; }
  #matrixTable { font-size: 6pt !important; min-width: unset !important; }
  #matrixTable th, #matrixTable td { padding: 3px 4px !important; font-size: 6pt !important; white-space: normal !important; }
  /* Hide lower-priority columns in print: Color, Suppl, ADR, Emg Lvl, Fade↑, Fade↓, OccTS */
  #matrixTable th:nth-child(16),
  #matrixTable th:nth-child(17),
  #matrixTable th:nth-child(18),
  #matrixTable th:nth-child(19),
  #matrixTable th:nth-child(20),
  #matrixTable th:nth-child(21),
  #matrixTable th:nth-child(23),
  #matrixTable td:nth-child(16),
  #matrixTable td:nth-child(17),
  #matrixTable td:nth-child(18),
  #matrixTable td:nth-child(19),
  #matrixTable td:nth-child(20),
  #matrixTable td:nth-child(21),
  #matrixTable td:nth-child(23) { display: none !important; }
  .ctable .zone-row td { background: #0d1b2a !important; color: #fff !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}


/* ── ROOM TEMPLATES ── */
.tmpl-bar { display:flex; flex-direction:column; gap:4px; padding:8px 10px; background:var(--navy3); border-top:1px solid var(--border); }
.tmpl-label { font-family:var(--mono); font-size:clamp(8px, calc(9px * var(--fs, 1)), 11px); letter-spacing:1px; text-transform:uppercase; color:var(--text3); flex-shrink:0; }
.tmpl-list { display:flex; gap:5px; flex-wrap:wrap; flex:1 1 80px; min-width:80px; overflow:visible; }
.tmpl-chip { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; background:var(--navy4); border:1px solid var(--border2); border-radius:10px; font-family:var(--mono); font-size:clamp(8px, calc(9px * var(--fs, 1)), 11px); color:var(--cyan); cursor:pointer; white-space:nowrap; }
.tmpl-chip:hover { border-color:var(--cyan); background:rgba(78,184,200,0.1); }
.tmpl-chip .tc-del { color:var(--text3); margin-left:2px; font-size:clamp(9px, calc(10px * var(--fs, 1)), 12px); cursor:pointer; }
.tmpl-chip .tc-del:hover { color:var(--red); }
.tmpl-save-btn { font-family:var(--mono); font-size:clamp(8px, calc(9px * var(--fs, 1)), 11px); color:var(--amber); background:none; border:1px solid var(--amber-dim); border-radius:4px; padding:3px 8px; cursor:pointer; white-space:nowrap; flex-shrink:0; }
.tmpl-save-btn:hover { background:rgba(232,164,48,0.1); }


/* ── SETPOINTS TABLE ── */
.sp-wrap { padding: 20px; }
.sp-header { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.sp-header h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.sp-table { width:100%; border-collapse:collapse; font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); }
.sp-table thead th { padding:7px 10px; text-align:left; font-size: calc(8px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); border-bottom:2px solid var(--border2); background:var(--navy3); white-space:nowrap; }
.sp-table thead th.sp-cat { color:var(--amber); border-bottom-color:var(--amber-dim); }
.sp-table tbody td { padding:6px 10px; border-bottom:1px solid var(--border); color:var(--text2); vertical-align:top; }
.sp-table tbody tr:hover td { background:rgba(255,255,255,0.02); }
.sp-table tbody tr.sp-zone td { background:var(--navy3); color:var(--text3); font-size: calc(9px * var(--fs, 1)); letter-spacing:1px; text-transform:uppercase; padding:4px 10px; border-bottom:1px solid var(--border2); }
.sp-room { font-weight:600; color:var(--text); white-space:nowrap; }
.sp-type { font-size: calc(9px * var(--fs, 1)); color:var(--text3); }
.sp-val { color:var(--text); font-weight:500; }
.sp-adj { color:var(--cyan); font-size: calc(9px * var(--fs, 1)); }   /* adj = field-adjustable */
.sp-tbd { color:var(--amber); }                  /* TBD = needs entry */
.sp-na  { color:var(--text3); }                  /* N/A */
.sp-range { font-size: calc(9px * var(--fs, 1)); color:var(--text3); display:block; margin-top:1px; }

/* Print: setpoints */
.p-sp-table { width:100%; border-collapse:collapse; font-size:7.5pt; }
.p-sp-table th { background:#0d1b2a; color:#fff; padding:4px 7px; text-align:left; font-size:6.5pt; font-weight:600; border:1px solid #333; white-space:nowrap; }
.p-sp-table td { padding:4px 7px; border:1px solid #ccc; vertical-align:top; }
.p-sp-table tr:nth-child(even) td { background:#f9f9f9; }
.p-sp-table .sp-zone-row td { background:#0d1b2a; color:#fff; font-weight:700; font-size:7pt; }
.p-sp-adj { color:#1a6fa3; font-size:7pt; }
.p-sp-tbd { color:#c0392b; font-weight:600; }


/* ── THEME TOGGLE ── */
[data-theme="light"] .header {
  background: #ffffff;
  border-bottom-color: var(--amber);
  box-shadow: 0 1px 8px rgba(0,0,0,0.08);
}
[data-theme="light"] .sidebar {
  background: #f8fafc;
  border-right-color: var(--border);
}
[data-theme="light"] .card,
[data-theme="light"] .output-card {
  background: #ffffff;
  border-color: var(--border);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
[data-theme="light"] .zone-header { background: var(--navy3); }
[data-theme="light"] .zone-header:hover { background: var(--navy4); }
[data-theme="light"] .room-item:hover { background: var(--navy4); }
[data-theme="light"] .room-item.active { background: rgba(192,122,16,0.10); border-color: rgba(192,122,16,0.4); }
[data-theme="light"] .output-card-header { background: var(--navy3); }
[data-theme="light"] .out-tab { letter-spacing: var(--ls-ui); background: var(--navy3); color: var(--text2); border-color: var(--border); }
[data-theme="light"] .out-tab.active { background: #ffffff; color: var(--amber); }
[data-theme="light"] .out-tab:hover { background: var(--navy4); }
[data-theme="light"] .narrative-doc { color: var(--text2); }
[data-theme="light"] .ctable th { background: #1a2633; }
[data-theme="light"] .zone-row td { background: #1a2633; color: #fff; }
[data-theme="light"] .cat-section { border-color: var(--border); }
[data-theme="light"] .cat-hdr { border-bottom-color: var(--border); }
[data-theme="light"] .comp-bar-pass { background: rgba(30,122,68,0.12); border-color: rgba(30,122,68,0.4); }
[data-theme="light"] .comp-bar-warn { background: rgba(192,122,16,0.12); border-color: rgba(192,122,16,0.4); }
[data-theme="light"] .comp-bar-fail { background: rgba(192,57,43,0.12); border-color: rgba(192,57,43,0.4); }
[data-theme="light"] .pill { background: var(--navy3); border-color: var(--border2); color: var(--text2); }
[data-theme="light"] .pill.on { background: rgba(192,122,16,0.15); border-color: var(--amber); color: var(--amber); }
[data-theme="light"] .modal { background: #ffffff; border-color: var(--border); box-shadow: 0 8px 40px rgba(0,0,0,0.15); }
[data-theme="light"] .modal-bg { background: rgba(0,0,0,0.3); }
[data-theme="light"] .tmpl-bar { background: var(--navy3); border-top-color: var(--border); }
[data-theme="light"] .tmpl-chip { background: var(--navy4); border-color: var(--border2); color: var(--cyan); }
[data-theme="light"] .rev-entry:nth-child(even),
[data-theme="light"] .cx-item:nth-child(even) { background: var(--navy3); }
[data-theme="light"] .cx-room-hdr { background: var(--navy3); border-color: var(--border); }
[data-theme="light"] .cx-signoff { background: var(--navy3); border-color: var(--border); }
[data-theme="light"] .sp-table thead th { background: var(--navy3); }
[data-theme="light"] .sp-table tbody tr.sp-zone td { background: #1a2633; color: #fff; }
[data-theme="light"] body::before { display: none; }  /* no scanline in light mode */
[data-theme="light"] #themeToggle { color: var(--amber); border-color: var(--amber-dim); }


/* ── SIDEBAR SEARCH ── */
.sb-search-wrap {
  padding: 8px 10px 0;
  position: relative;
}
.sb-search {
  width: 100%;
  padding: 5px 28px 5px 9px;
  background: var(--input-bg);
  border: 1px solid var(--border2);
  border-radius: var(--r);
  color: var(--text);
  font-family: var(--mono);
  font-size: calc(11px * var(--fs, 1));
  transition: border-color 0.15s;
}
.sb-search:focus { outline: none; border-color: var(--amber); }
.sb-search::placeholder { color: var(--text3); }
.sb-search-clear {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--text3); cursor: pointer;
  font-size: calc(13px * var(--fs, 1)); padding: 0; line-height: 1;
  display: none;
}
.sb-search-clear.visible { display: block; }
.sb-search-count {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3);
  padding: 3px 10px 6px; text-align: right;
}

/* ── INCOMPLETE INDICATOR ── */
.rdot-inc {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--amber); flex-shrink: 0;
  display: none;
}
.rdot-inc.visible { display: block; }
.room-item .inc-badge {
  font-family: var(--mono); font-size: calc(8px * var(--fs, 1)); color: var(--amber);
  background: rgba(232,164,48,0.12); border: 1px solid rgba(232,164,48,0.3);
  border-radius: 3px; padding: 0 4px; white-space: nowrap; line-height: 1.6;
  display: none;
}
.room-item .inc-badge.visible { display: inline-block; }

/* ── BULK EDIT MODAL ── */
.bulk-modal { max-width: 520px; }
.bulk-field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.bulk-scope {
  background: var(--navy4); border: 1px solid var(--border2);
  border-radius: var(--r); padding: 10px 12px; margin-bottom: 14px;
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2);
}
.bulk-scope strong { color: var(--amber); }
.bulk-field-row { display: flex; align-items: center; gap: 8px; padding: 7px 0; border-bottom: 1px solid var(--border); }
.bulk-field-row:last-child { border-bottom: none; }
.bulk-chk { width: 14px; height: 14px; cursor: pointer; accent-color: var(--amber); flex-shrink: 0; }
.bulk-field-label { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2); flex: 1; }
.bulk-field-input { flex: 1; }
.bulk-preview { background: var(--navy3); border: 1px solid var(--border); border-radius: 4px; padding: 8px 12px; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); margin-top: 8px; line-height: 1.7; }
.bulk-preview strong { color: var(--cyan); }

[data-theme="light"] .sb-search { background: var(--input-bg); }
[data-theme="light"] .bulk-scope { background: var(--navy4); }
[data-theme="light"] .bulk-preview { background: var(--navy3); }


/* ── TOOLTIPS ── */
.tip-wrap { display:inline-flex; align-items:center; gap:4px; }
.tip-icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:14px; border-radius:50%;
  background:var(--navy4); border:1px solid var(--border2);
  font-family:var(--mono); font-size: calc(8px * var(--fs, 1)); font-weight:700;
  color:var(--text3); cursor:help; flex-shrink:0;
  transition:all 0.15s; position:relative;
}
.tip-icon:hover { background:var(--slate); border-color:var(--amber); color:var(--amber); }
.tip-icon::after {
  content: attr(data-tip);
  position:absolute; bottom:calc(100% + 6px); left:50%; transform:translateX(-50%);
  background:#0a1520; color:#eef2f7; border:1px solid var(--border2);
  border-radius:5px; padding:6px 10px; font-size: calc(10px * var(--fs, 1)); font-weight:400;
  font-family:var(--sans); line-height:1.5; white-space:normal;
  width:220px; text-align:left; z-index:9000; pointer-events:none;
  opacity:0; transition:opacity 0.15s;
  box-shadow:0 4px 16px rgba(0,0,0,0.4);
}
.tip-icon:hover::after { opacity:1; }
[data-theme="light"] .tip-icon::after { background:#fff; color:#1a2633; box-shadow:0 4px 16px rgba(0,0,0,0.15); }

/* ── DEFAULTS MODAL ── */
.def-modal { max-width: 480px; }
.def-section { margin-bottom:16px; }
.def-section-title { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:2px; text-transform:uppercase; color:var(--text3); margin-bottom:10px; padding-bottom:5px; border-bottom:1px solid var(--border); }
.def-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.def-reset { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); cursor:pointer; background:none; border:none; padding:0; text-decoration:underline; }
.def-reset:hover { color:var(--red); }

/* ── COLLAPSE ALL button in sidebar ── */
.zone-collapse-row { display:flex; gap:5px; justify-content:flex-end; padding:4px 10px 0; }
.zone-collapse-btn { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); background:none; border:none; cursor:pointer; padding:2px 5px; border-radius:3px; transition:all 0.1s; }
.zone-collapse-btn:hover { background:var(--navy4); color:var(--text2); }

/* ── NOTES CALLOUT in print ── */
.p-note-callout { border-left:3px solid #0d1b2a; background:#f5f7fa; padding:7px 12px; margin-top:8px; border-radius:0 4px 4px 0; font-size:8.5pt; color:#333; font-style:italic; }
.p-note-label { font-size:7pt; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:#888; margin-bottom:3px; }

[data-theme="light"] .tip-icon { background:var(--navy4); border-color:var(--border2); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .layout { grid-template-columns: 220px 1fr; }
  .header-actions .btn-ghost { display: none; }
  .header-actions .btn-amber,
  .header-actions .hdr-menu-wrap { display: flex; }
  #themeToggle { display: flex !important; }
}
@media (max-width: 700px) {
  .layout { grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
  .sidebar { width: 100%; max-height: 220px; border-right: none; border-bottom: 1px solid var(--border); overflow-y: auto; }
  .main { padding: 12px; }
  .header { padding: 0 12px; }
  .header-brand .wordmark { font-size: calc(18px * var(--fs, 1)); }
  .onboard-steps { flex-direction: column; align-items: center; }
  .onboard-step-arrow { transform: rotate(90deg); }
  .out-tabs { gap: 2px; }
  .out-tab { letter-spacing: var(--ls-ui); padding: 7px 8px; font-size: calc(9px * var(--fs, 1)); }
}


/* ── DRAG AND DROP ── */
.room-item[draggable="true"] { cursor: default; }
.room-item[draggable="true"]:active { cursor: grabbing; }
.drag-handle { cursor: grab; }
.room-item.dragging {
  opacity: 0.4;
  background: rgba(232,164,48,0.08) !important;
  border: 1px dashed var(--amber) !important;
}
.zone-rooms.drag-over {
  background: rgba(78,184,200,0.06);
  outline: 2px dashed var(--cyan);
  outline-offset: -2px;
  border-radius: 4px;
}
/* Drop indicator line between rooms */
.room-item.drop-above { border-top: 2px solid var(--cyan) !important; }
.room-item.drop-below { border-bottom: 2px solid var(--cyan) !important; }
/* Drag handle — subtle grip dots on left edge */
.drag-handle {
  display: flex; flex-direction: column; gap: 2px;
  padding: 0 2px; opacity: 0; transition: opacity 0.1s;
  cursor: grab; flex-shrink: 0;
}
.room-item:hover .drag-handle { opacity: 0.5; }
.room-item.dragging .drag-handle { opacity: 0; }
.drag-handle span {
  display: flex; gap: 2px;
}
.drag-handle span::before,
.drag-handle span::after {
  content: ''; width: 2px; height: 2px;
  border-radius: 50%; background: var(--text3);
}


/* ══ PUNCH LIST ══════════════════════════════════════════════ */
.pl-wrap { padding: 20px; }

/* toolbar */
.pl-toolbar { display:flex; align-items:center; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.pl-toolbar h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.pl-filter-group { display:flex; gap:5px; }
.pl-filter { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); padding:3px 10px; border-radius:12px; border:1px solid var(--border2); background:var(--navy4); color:var(--text3); cursor:pointer; white-space:nowrap; transition:all 0.15s; }
.pl-filter.on { background:rgba(232,164,48,0.15); border-color:var(--amber); color:var(--amber); }
.pl-filter:hover { border-color:var(--amber); }

/* scorecard */
.pl-scorecard { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.pl-tile { flex:1; min-width:80px; background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:10px 12px; text-align:center; }
.pl-tile .ptn { font-family:var(--mono); font-size: calc(20px * var(--fs, 1)); font-weight:700; }
.pl-tile .ptl { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }
.pl-tile.pt-open .ptn  { color:var(--red); }
.pl-tile.pt-prog .ptn  { color:var(--amber); }
.pl-tile.pt-done .ptn  { color:var(--green); }
.pl-tile.pt-total .ptn { color:var(--text2); }

/* priority sort header */
.pl-sort-bar { display:flex; align-items:center; gap:12px; padding:6px 12px; background:var(--navy3); border:1px solid var(--border); border-radius:6px 6px 0 0; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); text-transform:uppercase; letter-spacing:1px; }
.pl-sort-btn { cursor:pointer; padding:2px 6px; border-radius:3px; transition:background 0.1s; }
.pl-sort-btn:hover { background:var(--navy4); color:var(--text2); }
.pl-sort-btn.active { color:var(--amber); }

/* deficiency cards */
.pl-list { border:1px solid var(--border); border-top:none; border-radius:0 0 6px 6px; overflow:hidden; }
.pl-item { padding:12px 14px; border-bottom:1px solid var(--border); background:var(--navy2); transition:background 0.1s; }
.pl-item:last-child { border-bottom:none; }
.pl-item:hover { background:var(--navy3); }
.pl-item.pl-closed { opacity:0.55; }

/* item header row */
.pl-item-hdr { display:flex; align-items:flex-start; gap:10px; margin-bottom:8px; }
.pl-num { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); flex-shrink:0; min-width:28px; padding-top:1px; }
.pl-priority { display:inline-flex; align-items:center; gap:3px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight:700; padding:2px 7px; border-radius:3px; flex-shrink:0; white-space:nowrap; }
.pl-priority.P1 { background:rgba(224,82,82,0.15);   color:var(--red);   border:1px solid rgba(224,82,82,0.3); }
.pl-priority.P2 { background:rgba(232,164,48,0.15);  color:var(--amber); border:1px solid rgba(232,164,48,0.3); }
.pl-priority.P3 { background:rgba(146,168,187,0.12); color:var(--text2); border:1px solid var(--border2); }
.pl-title-wrap { flex:1; min-width:0; }
.pl-item-title { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; color:var(--text); margin-bottom:2px; }
.pl-item-meta  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.pl-status-badge { display:inline-flex; align-items:center; gap:3px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight:600; padding:2px 8px; border-radius:3px; flex-shrink:0; white-space:nowrap; }
.pl-status-badge.open     { background:rgba(224,82,82,0.12);  color:var(--red);   border:1px solid rgba(224,82,82,0.25); }
.pl-status-badge.progress { background:rgba(232,164,48,0.12); color:var(--amber); border:1px solid rgba(232,164,48,0.25); }
.pl-status-badge.resolved { background:rgba(82,201,122,0.12); color:var(--green); border:1px solid rgba(82,201,122,0.25); }
.pl-status-badge.closed   { background:rgba(146,168,187,0.10);color:var(--text3); border:1px solid var(--border2); }

/* item detail row */
.pl-item-detail { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:8px; }
.pl-detail-field { display:flex; flex-direction:column; gap:3px; }
.pl-detail-label { font-family:var(--mono); font-size: calc(8px * var(--fs, 1)); letter-spacing:1px; text-transform:uppercase; color:var(--text3); }
.pl-detail-val   { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); color:var(--text2); }

/* notes and actions */
.pl-item-notes { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); color:var(--text2); line-height:1.6; padding:6px 10px; background:var(--navy4); border-radius:4px; margin-bottom:8px; white-space:pre-wrap; }
.pl-item-actions { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.pl-action-btn { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); padding:3px 9px; border-radius:4px; border:1px solid var(--border2); background:none; color:var(--text3); cursor:pointer; transition:all 0.12s; white-space:nowrap; }
.pl-action-btn:hover { border-color:var(--amber); color:var(--amber); }
.pl-action-btn.danger:hover { border-color:var(--red); color:var(--red); }
.pl-action-btn.primary { border-color:var(--amber); color:var(--amber); }

/* add deficiency form */
.pl-add-card { background:var(--navy3); border:1px solid var(--border2); border-radius:8px; padding:16px; margin-bottom:16px; }
.pl-add-title { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:2px; text-transform:uppercase; color:var(--amber); margin-bottom:12px; }
.pl-add-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:10px; }
.pl-add-grid.full { grid-template-columns:1fr; }
.pl-add-row { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:10px; margin-bottom:10px; }

/* print punch list */
.p-pl-table { width:100%; border-collapse:collapse; font-size:7.5pt; }
.p-pl-table th { background:#0d1b2a; color:#fff; padding:4px 8px; text-align:left; font-size:7pt; border:1px solid #333; }
.p-pl-table td { padding:5px 8px; border:1px solid #ccc; vertical-align:top; font-size:7.5pt; }
.p-pl-table tr:nth-child(even) td { background:#f9f9f9; }
.p-pl-p1 { color:#c0392b; font-weight:700; }
.p-pl-p2 { color:#d35400; font-weight:700; }
.p-pl-p3 { color:#555; }
.p-pl-open     { color:#c0392b; font-weight:600; }
.p-pl-progress { color:#d35400; font-weight:600; }
.p-pl-resolved { color:#1e7a44; font-weight:600; }
.p-pl-closed   { color:#888; }

[data-theme="light"] .pl-item { background:#fff; }
[data-theme="light"] .pl-item:hover { background:#f8fafc; }
[data-theme="light"] .pl-add-card { background:var(--navy3); }
[data-theme="light"] .pl-sort-bar { background:var(--navy3); }


/* ── CONTROLS SCHEDULE & BUDGET ESTIMATE ── */
.sched-wrap { padding: 16px; }
.sched-scorecard { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.sched-score-card { background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r); padding: 12px 18px; flex: 1; min-width: 130px; }
.sched-score-card .sc-label { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.sched-score-card .sc-val { font-family: var(--mono); font-size: calc(22px * var(--fs, 1)); font-weight: 600; color: var(--amber); }
.catalog-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.catalog-header .ch-title { font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600; color: var(--text2); }
.catalog-table { width: 100%; border-collapse: collapse; margin-bottom: 20px; }
.catalog-table th { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--border2); }
.catalog-table td { padding: 4px 6px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.catalog-table input[type=text], .catalog-table input[type=number] { background: var(--input-bg); border: 1px solid var(--border); border-radius: 3px; color: var(--text); font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 3px 6px; width: 100%; }
.catalog-table input:focus { outline: none; border-color: var(--amber); }
.catalog-table .del-btn { background: none; border: none; cursor: pointer; color: var(--text3); font-size: calc(11px * var(--fs, 1)); padding: 2px 5px; border-radius: 3px; font-family: var(--mono); }
.catalog-table .del-btn:hover { color: var(--red); background: rgba(224,82,82,.12); }
.room-qty-block { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 12px; overflow: hidden; }
.room-qty-header { display: flex; align-items: center; justify-content: space-between; padding: 8px 14px; background: var(--surface2); cursor: pointer; border-bottom: 1px solid var(--border); }
.room-qty-header .rqh-name { font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600; color: var(--text); }
.room-qty-header .rqh-sub { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); }
.room-qty-header .rqh-total { font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600; color: var(--amber); }
.room-qty-body { display: block; }
.room-qty-body.hidden { display: none; }
.qty-table { width: 100%; border-collapse: collapse; }
.qty-table th { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); text-transform: uppercase; padding: 5px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.qty-table td { padding: 4px 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.qty-table .qt-tag { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600; color: var(--cyan); white-space: nowrap; }
.qty-table .qt-desc { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); color: var(--text); }
.qty-table .qt-unit { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); }
.qty-table .qt-cost { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2); text-align: right; }
.qty-table .qt-total { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--text); text-align: right; }
.qty-table .qty-input { background: var(--input-bg); border: 1px solid var(--border); border-radius: 3px; color: var(--text); font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 2px 6px; width: 58px; text-align: right; }
.qty-table .qty-input:focus { outline: none; border-color: var(--amber); }
.qty-table tr.room-subtotal td { background: var(--surface2); font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--amber); border-top: 1px solid var(--border2); padding: 6px 10px; }
.suggested-badge { display: inline-block; font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight: 600; color: var(--green); background: rgba(82,201,122,.13); border: 1px solid rgba(82,201,122,.3); border-radius: 3px; padding: 1px 5px; margin-left: 5px; vertical-align: middle; }
.budget-wrap { padding: 16px; }
.budget-controls { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.budget-controls label { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2); }
.contingency-input { background: var(--input-bg); border: 1px solid var(--border2); border-radius: var(--r); color: var(--amber); font-family: var(--mono); font-size: calc(13px * var(--fs, 1)); font-weight: 600; padding: 5px 10px; width: 80px; text-align: right; }
.contingency-input:focus { outline: none; border-color: var(--amber); }
.budget-room-block { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 10px; overflow: hidden; }
.budget-room-header { display: flex; align-items: center; justify-content: space-between; padding: 8px 14px; background: var(--surface2); cursor: pointer; border-bottom: 1px solid var(--border); }
.budget-room-header .brh-name { font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600; color: var(--text); }
.budget-room-header .brh-sub { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); }
.budget-room-header .brh-total { font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600; color: var(--amber); }
.budget-room-body { display: block; }
.budget-room-body.hidden { display: none; }
.budget-cat-label { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; padding: 4px 10px; background: var(--navy3); border-bottom: 1px solid var(--border); }
.budget-line-table { width: 100%; border-collapse: collapse; }
.budget-line-table th { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); text-transform: uppercase; padding: 5px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.budget-line-table td { padding: 4px 10px; border-bottom: 1px solid var(--border); }
.budget-line-table td:last-child { text-align: right; }
.budget-line-table .bl-tag { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--cyan); }
.budget-line-table .bl-desc { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); color: var(--text); }
.budget-line-table .bl-num { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2); text-align: right; }
.budget-line-table .bl-total { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--text); text-align: right; }
.budget-cat-sub { background: var(--surface2); font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--cyan); padding: 5px 10px; border-bottom: 1px solid var(--border2); text-align: right; }
.budget-grand-total-row { background: var(--navy4); font-family: var(--mono); font-size: calc(13px * var(--fs, 1)); font-weight: 700; color: var(--amber); padding: 10px 14px; display: flex; justify-content: space-between; align-items: center; border-top: 2px solid var(--amber-dim); border-radius: 0 0 var(--r) var(--r); }
.budget-contingency-row { background: var(--surface2); font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text2); padding: 6px 14px; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--border); }


/* ══ RFI MANAGER ════════════════════════════════════════════ */
.rfi-wrap { padding: 20px; }

.rfi-toolbar { display:flex; align-items:center; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.rfi-toolbar h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.rfi-filter-group { display:flex; gap:5px; flex-wrap:wrap; }
.rfi-filter { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); padding:3px 10px; border-radius:12px; border:1px solid var(--border2); background:var(--navy4); color:var(--text3); cursor:pointer; white-space:nowrap; transition:all 0.15s; }
.rfi-filter.on { background:rgba(232,164,48,0.15); border-color:var(--amber); color:var(--amber); }
.rfi-filter:hover { border-color:var(--amber); }

.rfi-scorecard { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.rfi-tile { flex:1; min-width:80px; background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:10px 12px; text-align:center; }
.rfi-tile .rtn { font-family:var(--mono); font-size: calc(20px * var(--fs, 1)); font-weight:700; line-height:1; }
.rfi-tile .rtl { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }
.rfi-tile.rt-open     .rtn { color:var(--red); }
.rfi-tile.rt-pending  .rtn { color:var(--amber); }
.rfi-tile.rt-answered .rtn { color:var(--cyan); }
.rfi-tile.rt-closed   .rtn { color:var(--green); }
.rfi-tile.rt-total    .rtn { color:var(--text2); }

.rfi-sort-bar { display:flex; align-items:center; gap:12px; padding:6px 12px; background:var(--navy3); border:1px solid var(--border); border-radius:6px 6px 0 0; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); text-transform:uppercase; letter-spacing:1px; }
.rfi-sort-btn { cursor:pointer; padding:2px 6px; border-radius:3px; transition:background 0.1s; }
.rfi-sort-btn:hover { background:var(--navy4); color:var(--text2); }
.rfi-sort-btn.active { color:var(--amber); }

.rfi-add-card { background:var(--navy3); border:1px solid var(--border2); border-radius:8px; padding:16px; margin-bottom:16px; }
.rfi-add-title { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:2px; text-transform:uppercase; color:var(--amber); margin-bottom:12px; }
.rfi-add-grid  { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:10px; }
.rfi-add-grid.two  { grid-template-columns:1fr 1fr; }
.rfi-add-grid.full { grid-template-columns:1fr; }

.rfi-status { display:inline-flex; align-items:center; gap:3px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight:600; padding:2px 8px; border-radius:3px; white-space:nowrap; }
.rfi-status.open     { background:rgba(224,82,82,0.12);  color:var(--red);   border:1px solid rgba(224,82,82,0.25); }
.rfi-status.pending  { background:rgba(232,164,48,0.12); color:var(--amber); border:1px solid rgba(232,164,48,0.25); }
.rfi-status.answered { background:rgba(78,184,200,0.12); color:var(--cyan);  border:1px solid rgba(78,184,200,0.25); }
.rfi-status.closed   { background:rgba(82,201,122,0.12); color:var(--green); border:1px solid rgba(82,201,122,0.25); }

.rfi-list { border:1px solid var(--border); border-top:none; border-radius:0 0 6px 6px; overflow:hidden; }
.rfi-item { padding:14px 16px; border-bottom:1px solid var(--border); background:var(--navy2); transition:background 0.1s; }
.rfi-item:last-child { border-bottom:none; }
.rfi-item:hover { background:var(--navy3); }

.rfi-item-hdr { display:flex; align-items:flex-start; gap:10px; margin-bottom:8px; }
.rfi-num { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); flex-shrink:0; min-width:42px; padding-top:2px; }
.rfi-title-wrap { flex:1; min-width:0; }
.rfi-item-title { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; color:var(--text); margin-bottom:3px; }
.rfi-item-meta  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); display:flex; gap:12px; flex-wrap:wrap; }
.rfi-meta-chip .mc-label { color:var(--text3); }
.rfi-meta-chip .mc-val   { color:var(--text2); }

.rfi-refs-row { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:6px; }
.rfi-ref-item { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.rfi-ref-item strong { color:var(--text2); }

.rfi-q-block { background:rgba(0,0,0,0.18); border-left:3px solid var(--border2); border-radius:0 4px 4px 0; padding:8px 12px; margin-bottom:8px; font-size: calc(11px * var(--fs, 1)); line-height:1.6; color:var(--text2); white-space:pre-wrap; }
.rfi-q-block .qb-label { font-family:var(--mono); font-size: calc(8px * var(--fs, 1)); letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); margin-bottom:4px; }

.rfi-item-actions { display:flex; gap:6px; align-items:center; flex-wrap:wrap; margin-top:8px; }
.rfi-action-btn { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); padding:3px 9px; border-radius:4px; border:1px solid var(--border2); background:none; color:var(--text3); cursor:pointer; transition:all 0.12s; white-space:nowrap; }
.rfi-action-btn:hover { border-color:var(--amber); color:var(--amber); }
.rfi-action-btn.danger:hover { border-color:var(--red); color:var(--red); }
.rfi-action-btn.primary { border-color:var(--amber); color:var(--amber); }

[data-theme="light"] .rfi-item { background:#fff; }
[data-theme="light"] .rfi-item:hover { background:#f8fafc; }
[data-theme="light"] .rfi-add-card { background:var(--navy3); }
[data-theme="light"] .rfi-sort-bar { background:var(--navy3); }
[data-theme="light"] .rfi-q-block  { background:rgba(0,0,0,0.04); }


/* ══ DRAWING TAKEOFF MODAL ══════════════════════════════════ */
#takeoutModal {
  display: none; position: fixed; inset: 0; z-index: 800;
  background: var(--navy); flex-direction: column;
}
#takeoutModal.open { display: flex; }

/* ── top bar ── */
.to-topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 0 16px; height: 48px; flex-shrink: 0;
  background: var(--navy2); border-bottom: 2px solid var(--amber);
}
.to-topbar h2 {
  font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--amber); flex: 1;
}
.to-tool-group { display: flex; gap: 4px; }
.to-tool-btn {
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 4px 10px;
  border-radius: var(--r); border: 1px solid var(--border2);
  background: var(--navy3); color: var(--text2); cursor: pointer;
  transition: all 0.12s; white-space: nowrap;
}
.to-tool-btn:hover { border-color: var(--amber); color: var(--amber); }
.to-tool-btn.active { background: rgba(232,164,48,0.15); border-color: var(--amber); color: var(--amber); }
#toToolEgress.active { background: rgba(82,201,122,0.15); border-color: #52c97a; color: #52c97a; }
.to-tool-btn.danger:hover { border-color: var(--red); color: var(--red); }

/* ── body layout ── */
.to-body {
  display: grid;
  grid-template-columns: 180px 1fr 280px;
  flex: 1; min-height: 0; overflow: hidden;
}

/* ── page strip (left) ── */
.to-page-strip {
  background: var(--navy2); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; overflow-y: auto; padding: 8px;
  gap: 6px;
}
.to-page-strip h3 {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 2px;
  text-transform: uppercase; color: var(--text3); padding: 4px 2px;
  flex-shrink: 0;
}
.to-page-thumb {
  border: 2px solid var(--border2); border-radius: 4px;
  cursor: pointer; overflow: hidden; background: #fff;
  transition: border-color 0.12s; flex-shrink: 0;
}
.to-page-thumb:hover  { border-color: var(--amber2); }
.to-page-thumb.active { border-color: var(--amber); }
.to-page-thumb canvas { display: block; width: 100%; height: auto; }
.to-page-label {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3);
  text-align: center; padding: 3px 0;
}
.to-upload-btn {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; padding: 10px; border: 1px dashed var(--border2);
  border-radius: var(--r); cursor: pointer; color: var(--text3);
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); transition: all 0.12s;
  flex-shrink: 0;
}
.to-upload-btn:hover { border-color: var(--amber); color: var(--amber); }

/* ── canvas area (center) ── */
.to-canvas-wrap {
  position: relative; overflow: hidden; background: #2a2a2a;
  cursor: crosshair;
}
.to-canvas-wrap.tool-pan    { cursor: grab; }
.to-canvas-wrap.tool-pan.panning { cursor: grabbing; }
.to-canvas-wrap.tool-select { cursor: default; }
#toCanvas  { position: absolute; top: 0; left: 0; pointer-events: none; }
#toOverlay { position: absolute; top: 0; left: 0; pointer-events: none; }

/* zoom indicator */
.to-zoom-bar {
  position: absolute; bottom: 12px; left: 12px;
  display: flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,0.6); border-radius: 20px; padding: 4px 10px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: #ccc;
}
.to-zoom-bar button {
  background: none; border: none; color: #ccc; cursor: pointer;
  font-size: calc(14px * var(--fs, 1)); padding: 0 3px; line-height: 1;
}
.to-zoom-bar button:hover { color: var(--amber); }

/* status bar */
.to-status {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(0,0,0,0.6); border-radius: 4px; padding: 4px 10px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: #ccc;
}

/* vertex hint */
.to-hint {
  position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
  background: rgba(232,164,48,0.9); border-radius: 4px; padding: 4px 12px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--navy);
  font-weight: 600; pointer-events: none;
}

/* ── right panel ── */
.to-right {
  background: var(--navy2); border-left: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
}
.to-right-tabs {
  display: flex; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.to-rtab {
  flex: 1; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 8px 0;
  background: none; border: none; cursor: pointer; color: var(--text3);
  letter-spacing: 1px; text-transform: uppercase;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.to-rtab.active { color: var(--amber); border-bottom-color: var(--amber); }
.to-rpane { display: none; flex: 1; overflow-y: auto; padding: 10px; }
.to-rpane.active { display: block; }

/* palette */
.to-palette-section { margin-bottom: 12px; }
.to-palette-label {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text3); padding: 4px 0 6px;
  border-bottom: 1px solid var(--border); margin-bottom: 6px;
}
.to-palette-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.to-device-chip {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 7px; border: 1px solid var(--border2);
  border-radius: 4px; background: var(--navy3);
  cursor: grab; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text2);
  user-select: none; transition: all 0.1s;
}
.to-device-chip:hover { border-color: var(--amber); color: var(--amber); background: rgba(232,164,48,0.08); }
.to-device-chip .dc-icon { font-size: calc(13px * var(--fs, 1)); flex-shrink: 0; }
.to-device-chip .dc-tag  { font-weight: 600; color: var(--cyan); }

/* room list in right panel */
.to-room-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 8px; border: 1px solid var(--border);
  border-radius: 4px; margin-bottom: 5px; background: var(--navy3);
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); cursor: pointer;
  transition: border-color 0.1s;
}
.to-room-row:hover { border-color: var(--amber); }
.to-room-row.active { border-color: var(--amber); background: rgba(232,164,48,0.08); }
.to-room-row .tr-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.to-room-row .tr-name { flex: 1; color: var(--text); }
.to-room-row .tr-count { color: var(--text3); font-size: calc(9px * var(--fs, 1)); }
.to-room-del { background: none; border: none; color: var(--text3); cursor: pointer; font-size: calc(11px * var(--fs, 1)); padding: 1px 4px; }
.to-room-del:hover { color: var(--red); }

/* BOM panel */
.to-bom-header {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600;
  color: var(--cyan); padding: 6px 0; border-bottom: 1px solid var(--border);
  margin-bottom: 8px; letter-spacing: 1px; text-transform: uppercase;
}
.to-bom-row {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 6px; border-bottom: 1px solid var(--border);
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
}
.to-bom-row .tb-tag  { color: var(--cyan); width: 50px; flex-shrink: 0; }
.to-bom-row .tb-desc { flex: 1; color: var(--text2); font-size: calc(9px * var(--fs, 1)); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.to-bom-row .tb-qty  { color: var(--amber); font-weight: 600; width: 28px; text-align: right; flex-shrink: 0; }
.to-bom-total {
  display: flex; justify-content: space-between;
  padding: 6px 6px; font-family: var(--mono); font-size: calc(11px * var(--fs, 1));
  font-weight: 600; color: var(--amber); border-top: 1px solid var(--border2);
  margin-top: 4px;
}

/* link/create dialog */
#toRoomDialog {
  display: none; position: fixed; z-index: 1100;
  background: var(--navy2); border: 1px solid var(--amber);
  border-radius: 8px; padding: 16px; width: 300px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
#toRoomDialog h4 {
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 600;
  color: var(--amber); letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 12px;
}
.to-dialog-input {
  width: 100%; background: var(--navy3); border: 1px solid var(--border2);
  border-radius: var(--r); color: var(--text); font-family: var(--mono);
  font-size: calc(12px * var(--fs, 1)); padding: 6px 10px; margin-bottom: 8px;
}
.to-dialog-input:focus { outline: none; border-color: var(--amber); }
.to-dialog-row { display: flex; gap: 6px; margin-top: 10px; }


/* ── Scale calibration ── */
.to-scale-bar {
  position: absolute; top: 12px; right: 12px;
  background: rgba(0,0,0,0.72); border: 1px solid var(--border2);
  border-radius: 6px; padding: 6px 10px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: #ccc;
  display: flex; align-items: center; gap: 8px; z-index: 10;
}
.to-scale-bar input {
  background: rgba(255,255,255,0.1); border: 1px solid var(--border2);
  border-radius: 3px; color: #eee; font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
  padding: 2px 5px; width: 64px; text-align: right;
}
.to-scale-bar input:focus { outline: none; border-color: var(--amber); }
.to-scale-bar select {
  background: rgba(255,255,255,0.1); border: 1px solid var(--border2);
  border-radius: 3px; color: #eee; font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
  padding: 2px 4px;
}
.to-scale-btn {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); padding: 2px 7px;
  border-radius: 3px; border: 1px solid var(--border2);
  background: none; color: #ccc; cursor: pointer;
}
.to-scale-btn:hover { border-color: var(--amber); color: var(--amber); }
.to-scale-btn.active { border-color: var(--amber); color: var(--amber); background: rgba(232,164,48,0.15); }

/* ── Undo/redo toolbar buttons ── */
.to-undo-btn {
  font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); padding: 4px 10px;
  border-radius: var(--r); border: 1px solid var(--border2);
  background: var(--navy3); color: var(--text2); cursor: pointer;
  transition: all 0.12s;
}
.to-undo-btn:hover:not(:disabled) { border-color: var(--amber); color: var(--amber); }
.to-undo-btn:disabled { opacity: 0.3; cursor: not-allowed; }

/* ── Inline room editor in dialog ── */
#toRoomDialog { width: 360px; max-height: 80vh; overflow-y: auto; }
.to-room-editor { margin-top: 12px; border-top: 1px solid var(--border); padding-top: 12px; }
.to-room-editor-title {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--amber); margin-bottom: 10px;
}
.to-re-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.to-re-grid.full { grid-template-columns: 1fr; }
.to-re-field { display: flex; flex-direction: column; gap: 3px; }
.to-re-field label {
  font-family: var(--mono); font-size: calc(8px * var(--fs, 1)); letter-spacing: 1px;
  text-transform: uppercase; color: var(--text3);
}
.to-re-field select, .to-re-field input {
  background: var(--navy4); border: 1px solid var(--border2);
  border-radius: 3px; color: var(--text); font-family: var(--mono);
  font-size: calc(11px * var(--fs, 1)); padding: 5px 8px; width: 100%;
}
.to-re-field select:focus, .to-re-field input:focus {
  outline: none; border-color: var(--amber);
}
.to-re-pill-row { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 2px; }
.to-re-pill {
  padding: 3px 9px; border-radius: 12px; border: 1px solid var(--border2);
  background: var(--navy3); font-family: var(--mono); font-size: calc(9px * var(--fs, 1));
  color: var(--text3); cursor: pointer; transition: all 0.12s;
}
.to-re-pill.on { background: rgba(232,164,48,0.18); border-color: var(--amber); color: var(--amber); }

/* ── Area label on room ── */
/* (rendered on canvas, no CSS needed) */

/* ── Export progress overlay ── */
#toExportOverlay {
  display: none; position: absolute; inset: 0;
  background: rgba(0,0,0,0.6); z-index: 50;
  align-items: center; justify-content: center;
  font-family: var(--mono); font-size: calc(13px * var(--fs, 1)); color: var(--amber);
}
#toExportOverlay.show { display: flex; }


/* ── Full inline room editor in takeout dialog ── */
#toRoomDialog {
  width: 520px;
  max-width: 95vw;
  max-height: 82vh;
  overflow-y: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
/* Backdrop for dialog */
#toRoomDialogBackdrop {
  display: none; position: fixed; inset: 0; z-index: 1090;
  background: rgba(0,0,0,0.5);
}
#toRoomDialogBackdrop.open { display: block; }
.to-re-section {
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-bottom: 8px;
  overflow: hidden;
}
.to-re-hdr {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; cursor: pointer;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  user-select: none;
}
.to-re-hdr .re-pip {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.to-re-hdr .re-arr { margin-left: auto; font-size: calc(9px * var(--fs, 1)); color: var(--text3); transition: transform 0.15s; }
.to-re-hdr .re-arr.open { transform: rotate(0deg); }
.to-re-hdr .re-arr:not(.open) { transform: rotate(-90deg); }
.to-re-body { padding: 10px; border-top: 1px solid var(--border); }
.to-re-body.hidden { display: none; }

.to-re-grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 7px; margin-bottom: 7px; }
.to-re-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-bottom: 7px; }
.to-re-grid1 { display: grid; grid-template-columns: 1fr; gap: 7px; margin-bottom: 7px; }
.to-re-chk-row {
  display: flex; align-items: center; gap: 7px;
  padding: 4px 0; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text2);
}
.to-re-chk-row input[type=checkbox] { width: 13px; height: 13px; accent-color: var(--amber); flex-shrink: 0; }
.to-re-alert {
  padding: 5px 8px; border-radius: 4px; margin-bottom: 7px;
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); line-height: 1.5;
}
.to-re-textarea {
  width: 100%; background: var(--navy4); border: 1px solid var(--border2);
  border-radius: 3px; color: var(--text); font-family: var(--mono);
  font-size: calc(10px * var(--fs, 1)); padding: 5px 8px; resize: vertical;
  min-height: 48px; line-height: 1.6;
}
.to-re-textarea:focus { outline: none; border-color: var(--amber); }


/* ── PDF reload banner ── */
.to-reload-banner {
  position: absolute; top: 0; left: 0; right: 0; z-index: 30;
  background: rgba(232,164,48,0.92); padding: 7px 14px;
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--navy);
  font-weight: 600;
}
.to-reload-banner label {
  display: flex; align-items: center; gap: 6px; cursor: pointer;
  padding: 3px 10px; border-radius: 4px;
  background: rgba(0,0,0,0.15); color: var(--navy);
  transition: background 0.1s;
}
.to-reload-banner label:hover { background: rgba(0,0,0,0.25); }
.to-reload-banner .dismiss {
  margin-left: auto; background: none; border: none;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--navy);
  cursor: pointer; opacity: 0.7;
}
.to-reload-banner .dismiss:hover { opacity: 1; }

/* ── Palette search ── */
.to-palette-search {
  width: 100%; background: var(--navy4);
  border: 1px solid var(--border2); border-radius: var(--r);
  color: var(--text); font-family: var(--mono); font-size: calc(11px * var(--fs, 1));
  padding: 6px 10px; margin-bottom: 10px;
}
.to-palette-search:focus { outline: none; border-color: var(--amber); }
.to-palette-empty {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3);
  text-align: center; padding: 16px 8px;
}

/* ── Room edit popover ── */
.to-room-edit-btn {
  background: none; border: none; color: var(--text3);
  cursor: pointer; font-size: calc(11px * var(--fs, 1)); padding: 1px 5px;
  border-radius: 3px; transition: all 0.1s;
}
.to-room-edit-btn:hover { color: var(--amber); background: rgba(232,164,48,0.1); }

#toRoomEditPopover {
  display: none; position: absolute; z-index: 910;
  background: var(--navy2); border: 1px solid var(--border2);
  border-radius: 8px; padding: 14px; width: 260px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.5);
}
#toRoomEditPopover h5 {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 2px;
  text-transform: uppercase; color: var(--amber); margin-bottom: 10px;
}
.to-swatches { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.to-swatch {
  width: 22px; height: 22px; border-radius: 4px; cursor: pointer;
  border: 2px solid transparent; transition: border-color 0.1s; flex-shrink: 0;
}
.to-swatch:hover, .to-swatch.active { border-color: #fff; }

/* ── Sync diff modal ── */
#toSyncModal {
  display: none; position: fixed; inset: 0; z-index: 950;
  background: rgba(0,0,0,0.65); align-items: center; justify-content: center;
}
#toSyncModal.open { display: flex; }
.to-sync-box {
  background: var(--navy2); border: 1px solid var(--border);
  border-radius: 10px; padding: 20px; width: 580px; max-width: 94vw;
  max-height: 80vh; display: flex; flex-direction: column;
  box-shadow: 0 12px 48px rgba(0,0,0,0.5);
}
.to-sync-box h3 {
  font-family: var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--amber);
  margin-bottom: 4px;
}
.to-sync-sub {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3);
  margin-bottom: 14px;
}
.to-sync-scroll { flex: 1; overflow-y: auto; margin-bottom: 14px; }
.to-sync-room-hdr {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; background: var(--navy3);
  border: 1px solid var(--border); border-radius: 5px 5px 0 0;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); font-weight: 600;
  color: var(--text); margin-top: 10px;
}
.to-sync-room-hdr:first-child { margin-top: 0; }
.to-sync-room-hdr input[type=checkbox] { accent-color: var(--amber); width: 13px; height: 13px; }
.to-sync-diff-table {
  width: 100%; border-collapse: collapse;
  border: 1px solid var(--border); border-top: none;
  border-radius: 0 0 5px 5px; margin-bottom: 2px;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
}
.to-sync-diff-table th {
  background: var(--navy4); color: var(--text3); font-weight: 600;
  padding: 4px 8px; text-align: left; border-bottom: 1px solid var(--border);
  font-size: calc(9px * var(--fs, 1)); text-transform: uppercase; letter-spacing: 1px;
}
.to-sync-diff-table td {
  padding: 4px 8px; border-bottom: 1px solid var(--border); color: var(--text2);
}
.to-sync-diff-table tr:last-child td { border-bottom: none; }
.to-sync-new  { color: var(--green) !important; font-weight: 600; }
.to-sync-chg  { color: var(--amber) !important; font-weight: 600; }
.to-sync-same { color: var(--text3) !important; }
.to-sync-footer { display: flex; gap: 8px; justify-content: flex-end; }
.to-sync-legend {
  display: flex; gap: 12px; font-family: var(--mono); font-size: calc(9px * var(--fs, 1));
  color: var(--text3); margin-bottom: 8px;
}


/* ══ SUBMITTAL LOG ════════════════════════════════════════════ */
.sub-wrap { padding: 20px; }
.sub-scorecard { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.sub-tile { flex:1; min-width:80px; background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:10px 12px; text-align:center; }
.sub-tile .stn { font-family:var(--mono); font-size: calc(20px * var(--fs, 1)); font-weight:700; }
.sub-tile .stl { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }
.sub-tile.st-submitted .stn { color:var(--amber); }
.sub-tile.st-review    .stn { color:var(--cyan); }
.sub-tile.st-approved  .stn { color:var(--green); }
.sub-tile.st-rejected  .stn { color:var(--red); }
.sub-tile.st-rr        .stn { color:#9b7fe8; }
.sub-tile.st-total     .stn { color:var(--text2); }

.sub-add-card { background:var(--navy3); border:1px solid var(--border2); border-radius:8px; padding:16px; margin-bottom:16px; }
.sub-add-title { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:2px; text-transform:uppercase; color:var(--amber); margin-bottom:12px; }
.sub-grid3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:10px; }
.sub-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:10px; }

.sub-status { display:inline-flex; align-items:center; gap:3px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight:600; padding:2px 8px; border-radius:3px; white-space:nowrap; }
.sub-status.submitted  { background:rgba(232,164,48,0.12); color:var(--amber); border:1px solid rgba(232,164,48,0.25); }
.sub-status.review     { background:rgba(78,184,200,0.12);  color:var(--cyan);  border:1px solid rgba(78,184,200,0.25); }
.sub-status.approved   { background:rgba(82,201,122,0.12);  color:var(--green); border:1px solid rgba(82,201,122,0.25); }
.sub-status.rejected   { background:rgba(224,82,82,0.12);   color:var(--red);   border:1px solid rgba(224,82,82,0.25); }
.sub-status.rr         { background:rgba(155,127,232,0.12); color:#9b7fe8;      border:1px solid rgba(155,127,232,0.25); }

.sub-list { border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.sub-item { padding:12px 16px; border-bottom:1px solid var(--border); background:var(--navy2); }
.sub-item:last-child { border-bottom:none; }
.sub-item-hdr { display:flex; align-items:flex-start; gap:10px; margin-bottom:6px; }
.sub-num  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); flex-shrink:0; min-width:48px; }
.sub-title-wrap { flex:1; }
.sub-item-title { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; color:var(--text); margin-bottom:2px; }
.sub-item-meta  { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); display:flex; gap:12px; flex-wrap:wrap; }
.sub-action-btn { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); padding:3px 9px; border-radius:4px; border:1px solid var(--border2); background:none; color:var(--text3); cursor:pointer; transition:all 0.12s; }
.sub-action-btn:hover { border-color:var(--amber); color:var(--amber); }
.sub-action-btn.danger:hover { border-color:var(--red); color:var(--red); }

/* ══ VOLTAGE DROP ═════════════════════════════════════════════ */
.vd-wrap { padding: 20px; }
.vd-card { background:var(--navy3); border:1px solid var(--border2); border-radius:8px; padding:16px; margin-bottom:16px; }
.vd-card-title { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing:2px; text-transform:uppercase; color:var(--cyan); margin-bottom:12px; }
.vd-grid4 { display:grid; grid-template-columns:1fr 1fr 1fr 1fr; gap:10px; margin-bottom:10px; }
.vd-grid3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:10px; }
.vd-result-box { background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:14px; margin-top:10px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.vd-result-val { font-family:var(--mono); font-size: calc(28px * var(--fs, 1)); font-weight:700; }
.vd-result-val.pass { color:var(--green); }
.vd-result-val.warn { color:var(--amber); }
.vd-result-val.fail { color:var(--red); }
.vd-result-label { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); color:var(--text3); }
.vd-result-detail { font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); color:var(--text2); }
.vd-saved-list { border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.vd-saved-row { display:flex; align-items:center; gap:10px; padding:8px 14px; border-bottom:1px solid var(--border); font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); background:var(--navy2); }
.vd-saved-row:last-child { border-bottom:none; }
.vd-saved-row .vr-name { flex:1; color:var(--text2); }
.vd-saved-row .vr-drop { font-weight:700; }
.vd-saved-row .vr-drop.pass { color:var(--green); }
.vd-saved-row .vr-drop.warn { color:var(--amber); }
.vd-saved-row .vr-drop.fail { color:var(--red); }
.vd-warn-badge { display:inline-flex; align-items:center; gap:3px; font-family:var(--mono); font-size: calc(8px * var(--fs, 1)); font-weight:700; padding:1px 5px; border-radius:3px; background:rgba(232,164,48,0.15); color:var(--amber); border:1px solid rgba(232,164,48,0.3); margin-left:4px; }

/* ══ COMMISSIONING REPORT ═════════════════════════════════════ */
.cx-rep-wrap { padding: 20px; }
.cx-rep-controls { display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.cx-rep-controls h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.cx-report-doc { background:var(--navy3); border:1px solid var(--border); border-radius:6px; padding:24px; font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); line-height:1.8; color:var(--text2); max-height:65vh; overflow-y:auto; white-space:pre-wrap; }
.cx-report-doc h1 { font-size: calc(14px * var(--fs, 1)); font-weight:700; color:var(--amber); letter-spacing:2px; text-transform:uppercase; margin-bottom:4px; }
.cx-report-doc h2 { font-size: calc(12px * var(--fs, 1)); font-weight:600; color:var(--cyan); letter-spacing:1px; margin:12px 0 4px; border-bottom:1px solid var(--border); padding-bottom:4px; }
.cx-report-doc h3 { font-size: calc(11px * var(--fs, 1)); font-weight:600; color:var(--text); margin:8px 0 2px; }
.cx-report-doc .pass { color:var(--green); }
.cx-report-doc .fail { color:var(--red); }
.cx-report-doc .warn { color:var(--amber); }

/* ══ AS-BUILT LAYER ═══════════════════════════════════════════ */
.to-layer-toggle { display:flex; align-items:center; gap:4px; background:var(--navy3); border:1px solid var(--border2); border-radius:6px; padding:2px; }
.to-layer-btn { font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); padding:3px 10px; border-radius:4px; border:none; cursor:pointer; background:none; color:var(--text3); transition:all 0.12s; }
.to-layer-btn.active { background:var(--amber); color:var(--navy); font-weight:600; }
.to-asbuilt-legend { display:flex; gap:10px; font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); align-items:center; }
.to-abl-dot { width:8px; height:8px; border-radius:50%; display:inline-block; margin-right:3px; }

/* ══ SPEC WRITER ══════════════════════════════════════════════ */
.spec-wrap { padding: 20px; }
.spec-controls { display:flex; align-items:center; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.spec-controls h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.spec-doc { background:var(--navy3); border:1px solid var(--border); border-radius:6px; padding:24px; font-family:var(--mono); font-size: calc(11px * var(--fs, 1)); line-height:1.8; color:var(--text2); max-height:65vh; overflow-y:auto; white-space:pre-wrap; }

/* ══ CODE COMPARISON ══════════════════════════════════════════ */
.cc-wrap { padding: 20px; }
.cc-controls { display:flex; align-items:center; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.cc-controls h2 { font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--amber); flex:1; }
.cc-room-sel { background:var(--navy4); border:1px solid var(--border2); border-radius:var(--r); color:var(--text); font-family:var(--mono); font-size: calc(12px * var(--fs, 1)); padding:6px 10px; }
.cc-table-wrap { overflow-x:auto; }
.cc-table { width:100%; border-collapse:collapse; font-family:var(--mono); font-size: calc(10px * var(--fs, 1)); }
.cc-table th { background:var(--navy3); color:var(--text3); font-weight:600; padding:7px 12px; text-align:left; border:1px solid var(--border); font-size: calc(9px * var(--fs, 1)); text-transform:uppercase; letter-spacing:1px; position:sticky; top:0; }
.cc-table th.code-col { color:var(--amber); background:rgba(232,164,48,0.08); }
.cc-table td { padding:6px 12px; border:1px solid var(--border); color:var(--text2); vertical-align:top; }
.cc-table tr:nth-child(even) td { background:rgba(0,0,0,0.06); }
.cc-pass { color:var(--green); font-weight:600; }
.cc-fail { color:var(--red); font-weight:600; }
.cc-warn { color:var(--amber); font-weight:600; }
.cc-na   { color:var(--text3); }
.cc-summary { display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.cc-sum-tile { flex:1; min-width:100px; background:var(--navy4); border:1px solid var(--border); border-radius:6px; padding:10px; text-align:center; }
.cc-sum-tile .cst-code { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--amber); text-transform:uppercase; letter-spacing:1px; margin-bottom:4px; }
.cc-sum-tile .cst-score { font-family:var(--mono); font-size: calc(18px * var(--fs, 1)); font-weight:700; }
.cc-sum-tile .cst-label { font-family:var(--mono); font-size: calc(9px * var(--fs, 1)); color:var(--text3); }

/* ══════════════════════════════════════════════════════════════
   PHOTOMETRICS MODULE
   ══════════════════════════════════════════════════════════════ */

/* Tab inside takeoff topbar */
.to-photo-tab-btn {
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 4px 14px;
  border-radius: var(--r); border: 1px solid var(--border2);
  background: var(--navy3); color: var(--text2); cursor: pointer;
  transition: all 0.12s; white-space: nowrap; margin-left: 12px;
}
.to-photo-tab-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.to-photo-tab-btn.active { background: rgba(50,173,230,0.15); border-color: var(--cyan); color: var(--cyan); }

/* Full-screen photometrics panel inside takeout modal */
#photoPanel {
  display: none; position: absolute; inset: 48px 0 0 0;
  background: var(--navy); z-index: 10; flex-direction: column;
  overflow: hidden;
}
#photoPanel.open { display: flex; }

.photo-layout {
  display: grid;
  grid-template-columns: 260px 1fr 300px;
  flex: 1; min-height: 0;
}

/* Left: fixture library */
.photo-lib {
  background: var(--navy2); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
}
.photo-lib-hdr {
  padding: 10px 12px 8px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.photo-lib-title {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 2px;
  text-transform: uppercase; color: var(--cyan); margin-bottom: 8px;
}
.photo-lib-actions { display: flex; gap: 5px; flex-wrap: wrap; }
.photo-lib-btn {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 4px 9px;
  border-radius: var(--r-sm); border: 1px solid var(--border2);
  background: var(--navy3); color: var(--text2); cursor: pointer;
  transition: all 0.12s; white-space: nowrap;
}
.photo-lib-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.photo-lib-scroll { flex: 1; overflow-y: auto; padding: 8px; }
.photo-fixture-card {
  border: 1px solid var(--border); border-radius: var(--r);
  background: var(--navy3); margin-bottom: 6px; overflow: hidden;
  transition: border-color 0.12s;
}
.photo-fixture-card:hover { border-color: var(--border2); }
.photo-fixture-card.selected { border-color: var(--cyan); background: rgba(50,173,230,0.06); }
.photo-fx-hdr {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  cursor: pointer;
}
.photo-fx-icon { font-size: calc(16px * var(--fs, 1)); flex-shrink: 0; }
.photo-fx-name { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--text); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.photo-fx-generic { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3); padding: 1px 5px; background: var(--glass); border-radius: 8px; flex-shrink: 0; }
.photo-fx-actions { display: flex; gap: 4px; flex-shrink: 0; }
.photo-fx-btn {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 2px 7px;
  border-radius: 4px; border: 1px solid var(--border2);
  background: none; color: var(--text3); cursor: pointer; transition: all 0.1s;
}
.photo-fx-btn:hover { color: var(--text); border-color: var(--text3); }
.photo-fx-btn.danger:hover { color: var(--red); border-color: var(--red); }
.photo-fx-detail {
  padding: 0 10px 8px; display: none;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
}
.photo-fx-detail.open { display: block; }
.photo-fx-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 10px; }
.photo-fx-row { display: flex; justify-content: space-between; }
.photo-fx-lbl { color: var(--text3); }
.photo-fx-val { color: var(--text2); font-weight: 600; }
.photo-fx-ies-badge {
  display: inline-flex; align-items: center; gap: 4px; margin-top: 6px;
  font-size: calc(9px * var(--fs, 1)); padding: 2px 7px; border-radius: 8px;
  background: rgba(48,209,88,0.12); color: var(--green); border: 1px solid rgba(48,209,88,0.2);
}

/* Center: room calc area */
.photo-center {
  display: flex; flex-direction: column; overflow: hidden; background: var(--navy);
}
.photo-center-tabs {
  display: flex; border-bottom: 1px solid var(--border); flex-shrink: 0;
  background: var(--navy2); padding: 0 12px;
}
.photo-ctab {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 9px 14px;
  background: none; border: none; cursor: pointer; color: var(--text3);
  letter-spacing: 0.5px; border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color 0.12s;
}
.photo-ctab:hover { color: var(--text2); }
.photo-ctab.active { color: var(--cyan); border-bottom-color: var(--cyan); }
.photo-cpane { display: none; flex: 1; overflow-y: auto; padding: 16px; }
.photo-cpane.active { display: flex; flex-direction: column; gap: 14px; }

/* Room selector + params */
.photo-room-bar {
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
  padding: 10px 16px; background: var(--navy2); border-bottom: 1px solid var(--border);
}
.photo-room-bar select {
  font-family: var(--sans); font-size: calc(12px * var(--fs, 1)); padding: 5px 10px;
  background: var(--navy3); border: 1px solid var(--border2); border-radius: var(--r-sm);
  color: var(--text); flex: 1;
}
.photo-room-bar select option { background: var(--navy3); color: var(--text); }
.photo-calc-btn {
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 6px 16px;
  border-radius: 20px; border: 1px solid var(--cyan);
  background: rgba(50,173,230,0.12); color: var(--cyan); cursor: pointer;
  transition: all 0.15s; white-space: nowrap; font-weight: 600;
}
.photo-calc-btn:hover { background: rgba(50,173,230,0.22); }

/* Params card */
.photo-params-card {
  background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r);
  padding: 12px 14px;
}
.photo-params-title {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text3); margin-bottom: 10px;
}
.photo-params-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.photo-param-field { display: flex; flex-direction: column; gap: 4px; }
.photo-param-field label {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3);
  letter-spacing: 0.3px; text-transform: uppercase;
}
.photo-param-field input, .photo-param-field select {
  padding: 6px 9px; background: var(--navy3); border: 1px solid var(--border2);
  border-radius: var(--r-sm); color: var(--text); font-family: var(--mono);
  font-size: calc(11px * var(--fs, 1)); transition: border-color 0.12s;
}
.photo-param-field input:focus, .photo-param-field select:focus {
  outline: none; border-color: var(--cyan);
}
.photo-param-field select option { background: var(--navy3); }

/* Fixture assignment table */
.photo-assign-card {
  background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r);
  overflow: hidden;
}
.photo-assign-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; background: var(--glass); border-bottom: 1px solid var(--border);
}
.photo-assign-hdr-title { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 1.5px; text-transform: uppercase; color: var(--text3); }
.photo-add-row-btn {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 3px 10px;
  border-radius: var(--r-sm); border: 1px solid var(--border2);
  background: none; color: var(--text3); cursor: pointer; transition: all 0.1s;
}
.photo-add-row-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.photo-assign-table { width: 100%; border-collapse: collapse; font-size: calc(10px * var(--fs, 1)); }
.photo-assign-table th {
  padding: 6px 10px; font-family: var(--mono); font-size: calc(8px * var(--fs, 1)); font-weight: 600;
  letter-spacing: 0.8px; text-transform: uppercase; color: var(--text3);
  border-bottom: 1px solid var(--border); text-align: left; background: var(--glass);
}
.photo-assign-table td {
  padding: 5px 8px; border-bottom: 1px solid var(--border); vertical-align: middle;
}
.photo-assign-table tr:last-child td { border-bottom: none; }
.photo-assign-table select, .photo-assign-table input[type=number] {
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); padding: 3px 6px;
  background: var(--navy3); border: 1px solid var(--border2); border-radius: 4px;
  color: var(--text); width: 100%;
}
.photo-assign-table select option { background: var(--navy3); }
.photo-del-row { background: none; border: none; color: var(--text3); cursor: pointer; font-size: calc(12px * var(--fs, 1)); padding: 2px 4px; }
.photo-del-row:hover { color: var(--red); }

/* Results */
.photo-results-card {
  background: var(--navy2); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden;
}
.photo-results-hdr {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-bottom: 1px solid var(--border); background: var(--glass);
}
.photo-results-title { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 1.5px; text-transform: uppercase; color: var(--text3); flex: 1; }
.photo-view-toggle {
  display: flex; gap: 3px; background: var(--navy4); border-radius: 6px; padding: 2px;
}
.photo-view-btn {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); padding: 3px 9px;
  border-radius: 4px; border: none; background: none; color: var(--text3); cursor: pointer; transition: all 0.1s;
}
.photo-view-btn.active { background: var(--navy2); color: var(--cyan); }

/* Metrics scorecard */
.photo-metrics-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--border);
}
.photo-metric {
  padding: 12px; text-align: center; border-right: 1px solid var(--border);
}
.photo-metric:last-child { border-right: none; }
.photo-metric-val { font-family: var(--mono); font-size: calc(20px * var(--fs, 1)); font-weight: 700; color: var(--text); line-height: 1; margin-bottom: 4px; }
.photo-metric-lbl { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; }
.photo-metric-val.pass { color: var(--green); }
.photo-metric-val.warn { color: var(--amber); }
.photo-metric-val.fail { color: var(--red); }

/* Heat map canvas */
.photo-heatmap-wrap {
  padding: 14px; display: flex; justify-content: center; align-items: flex-start;
}
#photoHeatmapCanvas {
  border-radius: var(--r); border: 1px solid var(--border);
  display: block; max-width: 100%;
}

/* Tabular grid */
.photo-grid-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--mono); font-size: calc(10px * var(--fs, 1));
  margin: 0;
}
.photo-grid-table th {
  padding: 5px 8px; font-size: calc(8px * var(--fs, 1)); font-weight: 700; letter-spacing: 0.5px;
  text-transform: uppercase; color: var(--text3); border-bottom: 1px solid var(--border);
  background: var(--glass); text-align: center;
}
.photo-grid-table td {
  padding: 4px 8px; border: 1px solid var(--border); text-align: center;
  font-size: calc(10px * var(--fs, 1)); font-weight: 600;
}
.photo-cell-pass { background: rgba(48,209,88,0.12); color: var(--green); }
.photo-cell-warn { background: rgba(245,166,35,0.12); color: var(--amber); }
.photo-cell-fail { background: rgba(255,69,58,0.12); color: var(--red); }

/* Compliance band */
.photo-compliance-band {
  display: flex; align-items: stretch; gap: 0; border-top: 1px solid var(--border);
}
.photo-comp-item {
  flex: 1; padding: 10px 12px; border-right: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 3px;
}
.photo-comp-item:last-child { border-right: none; }
.photo-comp-label { font-family: var(--mono); font-size: calc(8px * var(--fs, 1)); text-transform: uppercase; letter-spacing: 0.5px; color: var(--text3); }
.photo-comp-status { font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); font-weight: 700; }
.photo-comp-status.pass { color: var(--green); }
.photo-comp-status.warn { color: var(--amber); }
.photo-comp-status.fail { color: var(--red); }
.photo-comp-detail { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3); }

/* Right panel: project summary */
.photo-right {
  background: var(--navy2); border-left: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
}
.photo-right-hdr {
  padding: 10px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.photo-right-title { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); letter-spacing: 2px; text-transform: uppercase; color: var(--cyan); margin-bottom: 4px; }
.photo-right-scroll { flex: 1; overflow-y: auto; padding: 8px; }
.photo-summary-room {
  border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 6px;
  background: var(--navy3); overflow: hidden; cursor: pointer; transition: border-color 0.12s;
}
.photo-summary-room:hover { border-color: var(--border2); }
.photo-summary-room.active { border-color: var(--cyan); }
.photo-sum-hdr {
  display: flex; align-items: center; gap: 8px; padding: 7px 10px;
}
.photo-sum-name { font-family: var(--sans); font-size: calc(11px * var(--fs, 1)); font-weight: 600; color: var(--text); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.photo-sum-badge {
  font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); font-weight: 700; padding: 1px 7px;
  border-radius: 8px;
}
.photo-sum-badge.pass { background: rgba(48,209,88,0.15); color: var(--green); }
.photo-sum-badge.warn { background: rgba(245,166,35,0.15); color: var(--amber); }
.photo-sum-badge.fail { background: rgba(255,69,58,0.15); color: var(--red); }
.photo-sum-badge.none { background: var(--glass); color: var(--text3); }
.photo-sum-fc { font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--text3); padding: 0 10px 7px; }
.photo-right-export-btn {
  margin: 10px; font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); padding: 8px;
  border-radius: var(--r); border: 1px solid var(--cyan);
  background: rgba(50,173,230,0.1); color: var(--cyan); cursor: pointer;
  transition: all 0.15s; text-align: center; font-weight: 600;
}
.photo-right-export-btn:hover { background: rgba(50,173,230,0.2); }

/* Fixture edit modal */
#photoFxModal {
  display: none; position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(6px);
  align-items: center; justify-content: center;
}
#photoFxModal.open { display: flex; }
.photo-fx-modal-card {
  background: var(--navy2); border: 1px solid var(--border2); border-radius: var(--r-lg);
  padding: 24px; width: 540px; max-width: 96vw; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-lg);
}
.photo-fx-modal-title {
  font-family: var(--sans); font-size: calc(16px * var(--fs, 1)); font-weight: 700; color: var(--text);
  margin-bottom: 16px; letter-spacing: -0.3px;
}
.photo-fx-modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.photo-fx-modal-grid .fg { display: flex; flex-direction: column; gap: 5px; }
.photo-fx-modal-grid label { font-family: var(--mono); font-size: calc(9px * var(--fs, 1)); color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; }
.photo-fx-modal-grid input, .photo-fx-modal-grid select, .photo-fx-modal-grid textarea {
  padding: 7px 10px; background: var(--navy3); border: 1px solid var(--border2);
  border-radius: var(--r-sm); color: var(--text); font-family: var(--mono); font-size: calc(12px * var(--fs, 1));
}
.photo-fx-modal-grid select option { background: var(--navy3); }
.photo-fx-modal-grid textarea { resize: vertical; min-height: 60px; }
.photo-ies-upload-area {
  border: 1px dashed var(--border2); border-radius: var(--r);
  padding: 14px; text-align: center; cursor: pointer; transition: all 0.12s;
  font-family: var(--mono); font-size: calc(11px * var(--fs, 1)); color: var(--text3); margin-bottom: 16px;
}
.photo-ies-upload-area:hover { border-color: var(--cyan); color: var(--cyan); }
.photo-ies-parsed { background: rgba(48,209,88,0.08); border: 1px solid rgba(48,209,88,0.2); border-radius: var(--r); padding: 10px 12px; font-family: var(--mono); font-size: calc(10px * var(--fs, 1)); color: var(--green); margin-bottom: 16px; }
.photo-fx-modal-footer { display: flex; gap: 8px; justify-content: flex-end; }

/* ═══════════════════════════════════════════════════════════════
   PROJECT WIZARD
   ═══════════════════════════════════════════════════════════════ */
.wizard-shell {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  width: min(600px, 94vw);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 24px 64px rgba(0,0,0,0.6);
  display: flex;
  flex-direction: column;
}
.wizard-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.wizard-logo {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.wizard-logo em { color: var(--amber); font-style: normal; }
.wizard-logo .wm-ver { color: var(--cyan); }
.wizard-step-indicator {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 0.5px;
  flex: 1;
}
.wizard-skip {
  background: none;
  border: none;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--r);
  transition: color 0.15s;
}
.wizard-skip:hover { color: var(--text2); }
.wizard-step { padding: 28px 28px 20px; }
.wizard-step-title {
  font-family: var(--sans);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
  letter-spacing: -0.3px;
}
.wizard-step-sub {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--text3);
  margin-bottom: 24px;
  line-height: 1.5;
}
.wizard-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 28px;
}
.wizard-options-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.wizard-option {
  background: var(--navy3);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px 18px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
  display: flex;
  align-items: center;
  gap: 14px;
}
.wizard-option:hover {
  border-color: var(--amber);
  background: rgba(245,166,35,0.06);
  transform: translateY(-1px);
}
.wizard-option.selected {
  border-color: var(--amber);
  background: rgba(245,166,35,0.10);
}
.wizard-option-sm {
  padding: 14px 16px;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}
.wizard-option-icon {
  font-size: 22px;
  flex-shrink: 0;
  line-height: 1;
}
.wizard-option-sm .wizard-option-icon { font-size: 20px; }
.wizard-option-label {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.wizard-option-sm .wizard-option-label { font-size: 12px; }
.wizard-option-desc {
  font-family: var(--sans);
  font-size: 12px;
  color: var(--text3);
  line-height: 1.4;
}
.wizard-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}
.wizard-fields { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.wizard-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.wizard-field { display: flex; flex-direction: column; gap: 5px; }
.wizard-field label {
  font-family: var(--mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
}
.wizard-field input,
.wizard-field select {
  background: var(--navy4);
  border: 1px solid var(--border2);
  border-radius: var(--r);
  color: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  padding: 8px 10px;
  width: 100%;
  outline: none;
  transition: border-color 0.15s;
}
.wizard-field input:focus,
.wizard-field select:focus { border-color: var(--amber); }
@media (max-width: 480px) {
  .wizard-field-row { grid-template-columns: 1fr; }
  .wizard-options-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   AUTH — Login / Signup / User Menu
   ═══════════════════════════════════════════════════════════════ */
.auth-shell {
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  width: min(420px, 94vw);
  box-shadow: 0 24px 64px rgba(0,0,0,0.6);
  overflow: hidden;
}
.auth-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
}
.auth-tab {
  flex: 1;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.5px;
  color: var(--text3);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  text-transform: uppercase;
}
.auth-tab:hover { color: var(--text); }
.auth-tab.active { color: var(--amber); border-bottom-color: var(--amber); }
.auth-pane { padding: 24px 24px 20px; }
.auth-pane-title {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 16px;
}
.auth-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 14px;
}
.auth-field label {
  font-family: var(--mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
}
.auth-field input {
  background: var(--navy4);
  border: 1px solid var(--border2);
  border-radius: var(--r);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13px;
  padding: 9px 11px;
  outline: none;
  transition: border-color 0.15s;
  width: 100%;
}
.auth-field input:focus { border-color: var(--amber); }
.auth-error-msg {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--red, #ff6b6b);
  min-height: 16px;
  margin-bottom: 10px;
  line-height: 1.4;
}
.auth-submit {
  width: 100%;
  padding: 11px;
  font-size: 13px;
  margin-bottom: 12px;
}
.auth-footer-link { text-align: center; }
.auth-link {
  background: none;
  border: none;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
  padding: 4px;
}
.auth-link:hover { color: var(--amber); }

/* User avatar button */
.auth-user-menu-wrap { position: relative; }
.auth-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--amber);
  color: #000;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.15s;
  flex-shrink: 0;
}
.auth-avatar:hover { opacity: 0.85; }

/* User dropdown menu */
.auth-user-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--navy2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  min-width: 220px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  z-index: 500;
  overflow: hidden;
}
.auth-user-menu.open { display: block; }
.auth-menu-name {
  padding: 12px 14px 2px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.auth-menu-role {
  padding: 0 14px 10px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--amber);
  letter-spacing: 0.3px;
  text-transform: capitalize;
}
.auth-menu-divider {
  height: 1px;
  background: var(--border2);
  margin: 2px 0;
}

/* Project list */
.project-list-item {
  padding: 12px 16px;
  cursor: pointer;
  border-radius: var(--r);
  margin: 2px 4px;
  transition: background 0.12s;
}
.project-list-item:hover { background: var(--glass); }
.pli-name {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 3px;
}
.pli-meta {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
}
.auth-loading, .auth-empty, .auth-error {
  padding: 28px 20px;
  text-align: center;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
}
.auth-error { color: var(--red, #ff6b6b); }

/* ── Storage meter ───────────────────────────────────────────── */
.auth-storage-meter {
  padding: 8px 14px 10px;
  border-bottom: 1px solid var(--border2);
}
.auth-storage-bar-wrap {
  height: 4px;
  background: var(--navy4);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 5px;
}
.auth-storage-bar {
  height: 100%;
  border-radius: 2px;
  width: 0%;
  transition: width 0.4s ease, background 0.3s;
}
.auth-storage-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
}

/* ── Avatar menu row ─────────────────────────────────────────── */
.auth-menu-avatar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px 10px;
}
.auth-menu-avatar-thumb {
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--amber);
  color: #000;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  overflow: hidden;
}
.auth-menu-avatar-edit {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 14px;
  opacity: 0;
  transition: opacity 0.15s;
  border-radius: 50%;
}
.auth-menu-avatar-thumb:hover .auth-menu-avatar-edit { opacity: 1; }

/* ── Project list delete button ──────────────────────────────── */
.project-list-item {
  display: flex;
  align-items: center;
  gap: 0;
}
.pli-main {
  flex: 1;
  padding: 12px 16px;
  cursor: pointer;
  border-radius: var(--r);
  transition: background 0.12s;
}
.pli-main:hover { background: var(--glass); }
.pli-delete {
  background: none;
  border: none;
  color: var(--text3);
  font-size: 12px;
  padding: 8px 12px;
  cursor: pointer;
  border-radius: var(--r);
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
  flex-shrink: 0;
}
.project-list-item:hover .pli-delete { opacity: 1; }
.pli-delete:hover { color: var(--red, #e05252); }

/* ── Subscribe modal tier/period buttons ─────────────────────── */
.sub-tier-btn.selected,
.sub-period-btn.selected {
  border-color: var(--amber) !important;
  background: rgba(245,166,35,0.1) !important;
  color: var(--text) !important;
}

/* ── Validation banner ───────────────────────────────────────── */
#validationBanner {
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.vb-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  font-family: var(--mono);
  font-size: 11px;
  border-left: 3px solid transparent;
  transition: background 0.15s;
}
.vb-item + .vb-item { border-top: 1px solid var(--border); }
.vb-item[onclick]:hover { background: var(--glass); }
.vb-fail  { border-left-color: var(--red);   background: rgba(255,69,58,0.06); }
.vb-warn  { border-left-color: var(--amber); background: rgba(245,166,35,0.06); }
.vb-info  { border-left-color: var(--cyan);  background: rgba(50,173,230,0.04); }
.vb-pass  { border-left-color: var(--green); background: rgba(48,209,88,0.05); }
.vb-icon  { font-size: 12px; flex-shrink: 0; }
.vb-fail  .vb-icon { color: var(--red); }
.vb-warn  .vb-icon { color: var(--amber); }
.vb-info  .vb-icon { color: var(--cyan); }
.vb-pass  .vb-icon { color: var(--green); }
.vb-msg   { flex: 1; color: var(--text2); }
.vb-rooms { color: var(--text3); }
.vb-link  { color: var(--amber); font-size: 10px; flex-shrink: 0; }

/* ── Accessibility ───────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  background: var(--amber);
  color: #000;
  padding: 8px 16px;
  border-radius: 0 0 var(--r) var(--r);
  font-weight: 700;
  font-size: 13px;
  z-index: 9999;
  text-decoration: none;
  transition: top 0.15s;
}
.skip-link:focus { top: 0; }

/* Ensure focus indicators are visible */
:focus-visible {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}

/* ── Auth gate (full screen login) ──────────────────────────── */
#authGate {
  position: fixed;
  inset: 0;
  background: var(--navy);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.auth-gate-inner {
  width: 100%;
  max-width: 380px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.auth-gate-logo {
  font-family: var(--sans);
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -1px;
  margin-bottom: 6px;
}
.auth-gate-o { color: var(--amber); }
.auth-gate-v { color: var(--cyan); }
.auth-gate-tag {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 40px;
  text-align: center;
}
