:root{
  --ey-orange:#f47a20;
  --ey-orange-dark:#c85f14;
  --ey-charcoal:#20242a;
  --ey-charcoal-2:#10141a;
  --ey-text:#27313d;
  --ey-muted:#667085;
  --ey-line:#d8dde6;
  --ey-bg:#f3f5f7;
  --ey-panel:#ffffff;
  --ey-blue:#4eaee8;
  --ey-green:#16834a;
  --ey-green-soft:#e8f6ee;
  --ey-red:#c03221;
  --ey-red-soft:#fdecea;
  --ey-amber:#b76d11;
  --ey-amber-soft:#fff0d8;
  --shadow:0 14px 40px rgba(21,30,41,.12);
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  min-height:100vh;
  font-family:Inter,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--ey-bg);
  color:var(--ey-text);
}

button,input,select,textarea{font:inherit}

button{cursor:pointer}

img{max-width:100%;display:block}

.hidden{display:none!important}

.eyebrow{
  margin:0 0 5px;
  color:var(--ey-orange-dark);
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.btn{
  border:1px solid var(--ey-line);
  background:#fff;
  color:var(--ey-charcoal);
  min-height:42px;
  border-radius:8px;
  padding:10px 14px;
  font-weight:800;
  box-shadow:none;
  transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease;
}

.btn:hover{transform:translateY(-1px);border-color:#aeb7c4}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn.primary{background:var(--ey-orange);border-color:var(--ey-orange);color:#fff}
.btn.primary:hover{background:var(--ey-orange-dark);border-color:var(--ey-orange-dark)}
.btn.ghost{background:#fff}
.btn.full{width:100%}
.btn.small{min-height:34px;padding:7px 10px;font-size:13px}
.btn.danger{color:var(--ey-red);border-color:#efb0a9}

.toast{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1200;
  max-width:min(420px,calc(100vw - 36px));
  padding:12px 14px;
  background:var(--ey-charcoal);
  color:#fff;
  border-radius:8px;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .2s ease,transform .2s ease;
  pointer-events:none;
  box-shadow:var(--shadow);
}

.toast.show{opacity:1;transform:translateY(0)}

.auth-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
  background:linear-gradient(135deg,#20242a,#10141a);
}

.auth-panel{
  width:min(520px,100%);
  background:#fff;
  border:1px solid #ccd3dd;
  border-radius:8px;
  padding:28px;
  box-shadow:var(--shadow);
}

.auth-brand{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:20px;
}

.auth-brand img{width:210px;height:auto}
.auth-brand h1{margin:0;color:var(--ey-charcoal);font-size:30px;line-height:1.05}
.auth-intro{margin:0 0 22px;color:#475467;line-height:1.6}

.auth-form{display:grid;gap:10px}

.auth-note{
  margin-top:16px;
  padding:12px;
  border-radius:8px;
  border:1px solid #ffd2b8;
  background:#fff7f2;
  color:#71370f;
  line-height:1.45;
  font-size:14px;
}

label{
  color:#475467;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

input,select,textarea{
  width:100%;
  min-height:42px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  color:var(--ey-text);
  padding:10px 12px;
  outline:none;
  transition:border-color .18s ease,box-shadow .18s ease;
}

input:focus,select:focus,textarea:focus{
  border-color:var(--ey-orange);
  box-shadow:0 0 0 3px rgba(244,122,32,.15);
}

textarea{resize:vertical}

.hint{
  color:var(--ey-muted);
  line-height:1.4;
}

.app-shell{min-height:100vh}

.app-header{
  position:sticky;
  top:0;
  z-index:100;
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 22px;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--ey-line);
  backdrop-filter:blur(10px);
}

.app-brand{
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}

.app-brand img{width:184px;height:auto}
.app-brand h1{margin:0;color:var(--ey-charcoal);font-size:22px;line-height:1.15}
.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-badge{padding:9px 11px;border:1px solid var(--ey-line);border-radius:8px;background:#fff;color:#475467;font-weight:800}
.sync-badge{
  padding:8px 11px;
  border:1px solid var(--ey-line);
  border-radius:999px;
  background:#fff;
  color:#475467;
  font-size:12px;
  font-weight:900;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.sync-badge.server{
  border-color:#b9e4c7;
  background:#effaf3;
  color:var(--ey-green);
}
.sync-badge.local{
  border-color:#f2d2b9;
  background:#fff4ec;
  color:var(--ey-orange-dark);
}

.app-layout{
  display:grid;
  grid-template-columns:230px minmax(0,1fr);
  min-height:calc(100vh - 78px);
}

.sidebar{
  position:sticky;
  top:78px;
  height:calc(100vh - 78px);
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:18px 14px;
  background:var(--ey-charcoal);
  border-right:1px solid #0f141a;
}

.nav-btn{
  width:100%;
  padding:12px 13px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.1);
  background:transparent;
  color:#d8dde6;
  text-align:left;
  font-weight:800;
  transition:background .18s ease,color .18s ease,border-color .18s ease;
}

.nav-btn:hover,.nav-btn.active{
  background:#fff;
  color:var(--ey-charcoal);
  border-color:#fff;
}

.content{
  padding:22px;
  min-width:0;
}

.view-panel{
  display:none;
  animation:panelIn .24s ease both;
}

.view-panel.active{display:block}

@keyframes panelIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

.landing-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}

.action-tile{
  min-height:170px;
  border-radius:8px;
  border:1px solid #ffc49f;
  background:#fff;
  color:var(--ey-charcoal);
  padding:22px;
  text-align:left;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:10px;
  box-shadow:var(--shadow);
  transition:transform .18s ease,border-color .18s ease;
}

.action-tile:hover{transform:translateY(-3px);border-color:var(--ey-orange)}
.action-tile span{font-size:28px;line-height:1.05;font-weight:900}
.action-tile strong{font-size:15px;color:#475467;line-height:1.45}
.action-tile.dark{background:var(--ey-charcoal);border-color:var(--ey-charcoal);color:#fff}
.action-tile.dark strong{color:#d8dde6}

.panel{
  background:var(--ey-panel);
  border:1px solid var(--ey-line);
  border-radius:8px;
  padding:18px;
  margin-bottom:18px;
  box-shadow:0 8px 26px rgba(21,30,41,.07);
}

.panel-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:16px;
}

.panel-head h2{margin:0;color:var(--ey-charcoal);font-size:24px}
.panel-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.compact-actions{align-items:end}
.compact-label{margin-left:4px}

.metric-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:14px;
  margin-bottom:18px;
}

.metric-card{
  background:#fff;
  border:1px solid var(--ey-line);
  border-radius:8px;
  padding:16px;
}

.metric-card span{display:block;color:var(--ey-orange);font-size:30px;font-weight:900}
.metric-card strong{display:block;margin-top:4px;color:var(--ey-charcoal)}
.metric-card small{display:block;margin-top:6px;color:var(--ey-muted);line-height:1.4}

.overview-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.overview-helper{
  margin:0;
  color:var(--ey-muted);
  line-height:1.5;
}

.overview-range-panel{
  padding:22px 24px;
}

.overview-range-layout{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,420px);
  gap:28px;
  align-items:start;
}

.overview-range-copy{
  display:grid;
  gap:10px;
  align-content:start;
}

.overview-range-copy h2{
  margin:0;
  color:var(--ey-charcoal);
  font-size:22px;
}

.overview-range-controls{
  display:grid;
  gap:14px;
  padding:2px 0;
}

.overview-range-controls .field{
  gap:8px;
}

.overview-range-controls input,
.overview-range-controls select{
  min-height:50px;
}

.overview-card.wide{grid-column:span 2}

.overview-copy{
  margin:0 0 14px;
  color:#475467;
  line-height:1.5;
}

.overview-stack{
  display:grid;
  gap:14px;
}

.overview-stack-track{
  display:flex;
  min-height:18px;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:999px;
  background:#f4f6f9;
}

.overview-stack-segment{display:block;min-width:6px}
.overview-dot.orange,.overview-stack-segment.orange,.overview-bar-fill.orange,.overview-month-fill{background:linear-gradient(180deg,#f8a35d,#f47a20)}
.overview-dot.green,.overview-stack-segment.green,.overview-bar-fill.green{background:linear-gradient(180deg,#2bb56d,#16834a)}
.overview-dot.blue,.overview-bar-fill.blue{background:linear-gradient(180deg,#76c8f0,#4eaee8)}
.overview-dot.amber,.overview-stack-segment.amber,.overview-bar-fill.amber{background:linear-gradient(180deg,#f0bf57,#b76d11)}
.overview-dot.charcoal,.overview-stack-segment.charcoal,.overview-bar-fill.charcoal{background:linear-gradient(180deg,#3b4656,#20242a)}

.overview-legend{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
}

.overview-legend-item{
  display:grid;
  gap:6px;
  padding:12px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.overview-legend-key{
  display:flex;
  align-items:center;
  gap:8px;
}

.overview-legend-key strong{color:var(--ey-charcoal)}
.overview-legend-item span{color:var(--ey-muted);line-height:1.4}

.overview-dot{
  width:12px;
  height:12px;
  border-radius:50%;
  display:inline-block;
}

.overview-bar-list,
.overview-readiness-grid{
  display:grid;
  gap:12px;
}

.overview-bar-row,
.overview-readiness-item{
  display:grid;
  gap:8px;
}

.overview-bar-meta{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}

.overview-bar-meta strong{
  color:var(--ey-charcoal);
  font-size:15px;
}

.overview-bar-meta span{
  color:var(--ey-muted);
  font-weight:800;
  text-align:right;
}

.overview-bar-track{
  height:12px;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:999px;
  background:#f4f6f9;
}

.overview-bar-fill{
  display:block;
  height:100%;
  min-width:8px;
  border-radius:999px;
}

.overview-readiness-item small{
  color:var(--ey-muted);
  line-height:1.4;
}

.overview-month-wrap{
  overflow:auto;
  padding-bottom:4px;
}

.overview-month-chart{
  min-width:620px;
  min-height:240px;
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
  align-items:end;
}

.overview-week-chart{
  min-height:240px;
  display:grid;
  gap:12px;
  align-items:end;
}

.overview-month-col{
  display:grid;
  gap:8px;
  justify-items:center;
}

.overview-month-value{
  color:var(--ey-charcoal);
  font-size:13px;
  font-weight:900;
}

.overview-month-track{
  width:100%;
  max-width:38px;
  height:160px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:linear-gradient(180deg,#f7f9fb,#eef2f7);
}

.overview-month-fill{
  width:100%;
  min-height:0;
  border-radius:6px 6px 0 0;
}

.overview-month-col strong{
  color:var(--ey-charcoal);
  font-size:13px;
  letter-spacing:.04em;
}

.overview-month-col small{
  color:var(--ey-muted);
}

.revenue-forecast{display:grid;gap:12px}
.revenue-row{display:grid;gap:8px}
.revenue-track{
  display:flex;
  width:100%;
  min-height:18px;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:999px;
  background:#eef2f6;
}
.revenue-fill{display:block;min-width:0}
.revenue-fill.booked{background:var(--ey-orange)}
.revenue-fill.loss{background:#98a2b3}
.revenue-row small{color:var(--ey-muted)}

.fact-list,.location-summary,.presentation-list,.reminder-board,.users-list{display:grid;gap:10px}

.fact-item{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:12px;
  align-items:start;
  padding:13px;
  border:1px solid var(--ey-line);
  border-left:4px solid var(--ey-orange);
  border-radius:8px;
  background:#fff;
}

.fact-item.warn{border-left-color:var(--ey-amber);background:var(--ey-amber-soft)}
.fact-item.danger{border-left-color:var(--ey-red);background:var(--ey-red-soft)}
.fact-item.good{border-left-color:var(--ey-green);background:var(--ey-green-soft)}
.fact-icon{width:10px;height:10px;margin-top:5px;border-radius:50%;background:var(--ey-orange)}
.fact-item.warn .fact-icon{background:var(--ey-amber)}
.fact-item.danger .fact-icon{background:var(--ey-red)}
.fact-item.good .fact-icon{background:var(--ey-green)}
.fact-copy strong{display:block;color:var(--ey-charcoal)}
.fact-copy span{display:block;color:#475467;line-height:1.45;margin-top:3px}

.location-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.location-card strong{display:block;color:var(--ey-charcoal);font-size:17px}
.location-card span{display:block;color:var(--ey-muted);margin-top:4px}
.pill{display:inline-flex;align-items:center;gap:6px;border-radius:8px;padding:6px 9px;font-size:12px;font-weight:800;border:1px solid var(--ey-line);background:#fff;color:var(--ey-charcoal)}
.pill.good{background:var(--ey-green-soft);color:var(--ey-green);border-color:#bfe6cf}
.pill.warn{background:var(--ey-amber-soft);color:var(--ey-amber);border-color:#ffd08b}
.pill.danger{background:var(--ey-red-soft);color:var(--ey-red);border-color:#efb0a9}
.pill.dark{background:var(--ey-charcoal);border-color:var(--ey-charcoal);color:#fff}
.pill.muted{background:#eef2f6;color:#667085;border-color:#cfd7e3}

.filters{
  display:grid;
  grid-template-columns:2fr repeat(4,1fr);
  gap:12px;
}

.filters.slim{grid-template-columns:1fr 1fr 2fr;margin-bottom:12px}
.field{display:flex;flex-direction:column;gap:7px}

.billboard-grid{
  display:grid;
  gap:16px;
}

.inventory-province-group{
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(21,30,41,.05);
}

.inventory-province-summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  cursor:pointer;
  background:linear-gradient(180deg,#fbfcfe,#f5f8fc);
  border-bottom:1px solid var(--ey-line);
}

.inventory-province-summary::-webkit-details-marker{display:none}

@keyframes provinceAlertPulse{
  0%,100%{
    box-shadow:0 0 0 0 rgba(244,122,32,.0);
    border-color:#ffd08b;
    background:linear-gradient(180deg,#fff7ed,#ffedd5);
  }
  50%{
    box-shadow:0 0 0 4px rgba(244,122,32,.18);
    border-color:var(--ey-orange);
    background:linear-gradient(180deg,#fff0dc,#ffe0b8);
  }
}

.inventory-province-group.province-alert,
.gantt-province-group.province-alert{
  border-color:#ffd08b;
}

.inventory-province-summary.province-alert,
.gantt-province-summary.province-alert{
  animation:provinceAlertPulse 1.35s ease-in-out infinite;
}

.inventory-province-summary.province-alert .inventory-province-copy strong,
.gantt-province-summary.province-alert .gantt-province-copy strong{
  color:var(--ey-orange-dark);
}

.inventory-province-copy{
  display:grid;
  gap:4px;
}

.inventory-province-copy strong{
  color:var(--ey-charcoal);
  font-size:18px;
}

.inventory-province-copy span{
  color:#667085;
  font-size:13px;
}

.inventory-province-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:14px;
  padding:14px;
}

.billboard-card{
  display:grid;
  gap:12px;
  background:#fff;
  border:1px solid var(--ey-line);
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(21,30,41,.07);
}

.billboard-card figure{margin:0;position:relative;min-height:170px;background:#242a32}
.billboard-card figure img{width:100%;height:210px;object-fit:cover}
.billboard-card .photo-fallback{display:grid;place-items:center;height:210px;color:#fff;font-weight:900;background:linear-gradient(135deg,#242a32,#4a5564)}
.billboard-body{display:grid;gap:10px;padding:14px}
.billboard-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.billboard-title-row h3{margin:0;color:var(--ey-charcoal);font-size:20px;line-height:1.2}
.billboard-meta{display:grid;gap:5px;color:#475467;line-height:1.45}
.billboard-actions{display:flex;gap:8px;flex-wrap:wrap}

.map-link{
  color:var(--ey-orange-dark);
  font-weight:800;
  text-decoration:none;
}

.map-link:hover{text-decoration:underline}

.map-legend{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:12px;
  color:#475467;
  font-weight:800;
}

.map-legend span{display:inline-flex;align-items:center;gap:7px}

.marker-dot{
  width:13px;
  height:13px;
  border-radius:50%;
  display:inline-block;
  border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.18);
}

.marker-dot.booked,.map-marker.booked{background:var(--ey-orange)}
.marker-dot.available,.map-marker.available{background:var(--ey-green)}
.marker-dot.lease,.map-marker.lease{background:var(--ey-amber)}
.marker-dot.missing{background:var(--ey-red)}

.billboard-map{
  position:relative;
  min-height:560px;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#dce7f2;
}

.map-tile-layer{
  position:absolute;
  inset:0;
  overflow:hidden;
}

.map-tile{
  position:absolute;
  width:256px;
  height:256px;
  object-fit:cover;
  user-select:none;
  pointer-events:none;
}

.map-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.12));
}

.billboard-map.satellite .map-overlay{
  background:linear-gradient(180deg,rgba(10,14,18,.08),rgba(10,14,18,.18));
}

.billboard-map.night .map-overlay{
  background:linear-gradient(180deg,rgba(10,14,18,.18),rgba(10,14,18,.3));
}

.map-compass,.map-caption,.map-attribution{
  position:absolute;
  z-index:2;
  border:1px solid rgba(255,255,255,.7);
  border-radius:8px;
  background:rgba(255,255,255,.9);
  color:var(--ey-charcoal);
  font-weight:900;
}

.map-compass{
  top:14px;
  right:14px;
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
}

.map-caption{
  left:14px;
  bottom:14px;
  padding:9px 11px;
}

.map-attribution{
  right:14px;
  bottom:14px;
  padding:7px 9px;
  font-size:11px;
  font-weight:800;
}

.map-marker{
  position:absolute;
  z-index:3;
  transform:translate(-50%,-50%);
  min-width:34px;
  height:34px;
  display:grid;
  place-items:center;
  padding:0 8px;
  border:3px solid #fff;
  border-radius:999px;
  color:#fff;
  text-decoration:none;
  font-size:11px;
  font-weight:900;
  box-shadow:0 10px 22px rgba(16,20,26,.25);
  transition:transform .18s ease,box-shadow .18s ease;
}

.map-marker:hover{
  transform:translate(-50%,-50%) scale(1.12);
  box-shadow:0 14px 30px rgba(16,20,26,.35);
}

.map-empty{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#475467;
  font-weight:900;
  text-align:center;
  padding:22px;
}

.map-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:12px;
  margin-top:14px;
}

.map-list-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.map-list-card h3{margin:0;color:var(--ey-charcoal);font-size:17px}
.map-list-card p{margin:5px 0 0;color:#475467;line-height:1.4}
.map-list-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}

.legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:12px;color:#475467;font-weight:700}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:14px;height:14px;border-radius:4px;display:inline-block;border:1px solid var(--ey-line)}
.legend-open{background:#fff;border-style:dashed}
.legend-booked{background:linear-gradient(90deg,#9be63a,#8cde34)}
.legend-expire{
  border:none!important;
  background:linear-gradient(180deg,var(--ey-orange-dark),var(--ey-orange-dark)) center bottom/2px 100% no-repeat;
  position:relative;
}
.legend-expire::before{
  content:"";
  position:absolute;
  top:1px;
  left:5px;
  width:8px;
  height:6px;
  background:#e53f32;
  clip-path:polygon(0 0,100% 22%,0 100%);
}
.legend-today{
  border:none!important;
  width:4px!important;
  background:var(--ey-charcoal)!important;
  border-radius:999px!important;
}

.gantt-scroll{
  overflow:auto;
  display:grid;
  gap:12px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#eef2f7;
  padding:14px;
}

.gantt-province-group{
  border:1px solid #d8e0ea;
  border-radius:8px;
  background:#f8fbff;
  overflow:hidden;
}

.gantt-province-summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  cursor:pointer;
  background:linear-gradient(180deg,#f9fbff,#eef4fb);
}

.gantt-province-summary::-webkit-details-marker{display:none}

.gantt-province-copy{
  display:grid;
  gap:4px;
}

.gantt-province-copy strong{
  color:var(--ey-charcoal);
  font-size:16px;
}

.gantt-province-copy span{
  color:#667085;
  font-size:13px;
}

.gantt-board{
  min-width:calc(var(--label-width) + var(--timeline-width));
  background:#fff;
  border:1px solid #d4d9e3;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(21,30,41,.08);
}

.gantt-board-title{
  padding:12px 16px 8px;
  text-align:center;
  color:#183d73;
  font-size:16px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:linear-gradient(180deg,#f8fafc,#eef3f8);
  border-bottom:1px solid #d7dde7;
}

.gantt-board-grid{
  display:grid;
  grid-template-columns:var(--label-width) var(--timeline-width);
  align-items:stretch;
}

.gantt-side-head{
  position:sticky;
  left:0;
  z-index:6;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  color:#fff;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  border-right:1px solid #d7dde7;
}

.gantt-side-head.top{
  top:0;
  background:#1b1d21;
  min-height:42px;
}

.gantt-side-head.bottom{
  top:42px;
  background:#243040;
  min-height:38px;
  font-size:11px;
}

.gantt-quarter-row,
.gantt-month-row{
  position:sticky;
  z-index:5;
  display:flex;
  width:var(--timeline-width);
}

.gantt-quarter-row{
  top:0;
  background:#dfe3ef;
  border-bottom:1px solid #c2c8d5;
}

.gantt-month-row{
  top:42px;
  background:#0d0f12;
  border-bottom:1px solid #000;
}

.gantt-quarter-cell,
.gantt-month-cell{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  border-right:1px solid #b8c0cf;
}

.gantt-quarter-cell{
  min-height:42px;
  color:#1d2840;
  font-size:15px;
}

.gantt-month-cell{
  min-height:38px;
  color:#fff;
  font-size:12px;
  letter-spacing:.04em;
}

.gantt-row-label{
  position:sticky;
  left:0;
  z-index:3;
  min-height:58px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  padding:10px 14px;
  color:#fff;
  border-right:1px solid rgba(255,255,255,.24);
  border-bottom:1px solid #dce2eb;
}

.gantt-row-label strong{
  font-size:14px;
  line-height:1.15;
}

.gantt-row-label span{
  font-size:12px;
  line-height:1.25;
  color:rgba(255,255,255,.88);
}

.gantt-row-lane{
  position:relative;
  width:var(--timeline-width);
  min-height:58px;
  border-bottom:1px solid #dce2eb;
  background:#fff;
  overflow:hidden;
}

.gantt-row-grid{
  position:absolute;
  inset:0;
}

.gantt-month-band{
  position:absolute;
  top:0;
  bottom:0;
  border-right:1px solid #d6dde7;
  background:#fff;
}

.gantt-month-band.alt{background:#f9fbfd}

.gantt-bar{
  position:absolute;
  top:14px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 18px 0 14px;
  border:1px solid #7fca2b;
  border-radius:6px;
  background:linear-gradient(90deg,#a8ea41,#97df35);
  clip-path:polygon(0 0,94% 0,100% 50%,94% 100%,0 100%);
  box-shadow:0 3px 8px rgba(61,117,13,.18);
}

.gantt-bar span{
  color:#173200;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.gantt-open-note{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#7a8699;
  font-size:12px;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
}

.gantt-lease-flag{
  position:absolute;
  top:10px;
  width:2px;
  height:34px;
  background:#ff5c45;
}

.gantt-lease-flag span{
  position:absolute;
  top:0;
  left:1px;
  width:12px;
  height:8px;
  background:#e53f32;
  clip-path:polygon(0 0,100% 24%,0 100%);
}

.gantt-today-line{
  position:absolute;
  top:0;
  bottom:0;
  width:3px;
  background:rgba(32,36,42,.9);
  box-shadow:0 0 0 1px rgba(255,255,255,.55);
}

.presentation-card,.reminder-card,.user-card{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:linear-gradient(180deg,var(--deck-soft,#fff),#fff 110px);
  box-shadow:inset 0 4px 0 var(--deck-accent,transparent);
}

.presentation-card.expanded{border-color:#ffc49f;box-shadow:inset 0 4px 0 var(--deck-accent,transparent),0 12px 28px rgba(21,30,41,.08)}
.presentation-summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:start;
}
.presentation-summary-copy{display:grid;gap:10px}
.presentation-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.presentation-chip{max-width:100%}
.presentation-expanded{
  display:grid;
  gap:16px;
  padding-top:10px;
  border-top:1px solid var(--ey-line);
}

.workflow-card{
  gap:14px;
}

.workflow-sublist{
  display:grid;
  gap:10px;
  padding-top:10px;
  border-top:1px solid var(--ey-line);
}

.workflow-item{
  display:grid;
  gap:8px;
  padding:12px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.workflow-item.compact{
  padding:10px 12px;
}

.workflow-item-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}

.workflow-item-head strong{
  display:block;
  color:var(--ey-charcoal);
}

.workflow-item-head span{
  display:block;
  color:#475467;
  line-height:1.5;
}

.workflow-item-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  color:var(--ey-muted);
  font-size:14px;
  line-height:1.5;
}

.workflow-note{
  margin:0;
  color:var(--ey-muted);
  line-height:1.5;
}

.campaign-notice-card{
  display:grid;
  gap:10px;
  margin-top:12px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#f8fafc;
}

.campaign-notice-card.compact{
  margin-top:10px;
  padding:12px;
}

.campaign-notice-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}

.campaign-notice-head strong{
  color:var(--ey-charcoal);
}

.campaign-notice-head small{
  display:block;
  margin-top:4px;
  color:var(--ey-muted);
  line-height:1.45;
}

.campaign-notice-detail{
  margin:0;
  color:var(--ey-charcoal);
  line-height:1.55;
}

.campaign-notice-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 14px;
  color:var(--ey-muted);
  font-size:13px;
  line-height:1.45;
}

.campaign-notice-preview{
  display:grid;
  gap:0;
  padding:0;
  border-radius:8px;
  background:#fff;
  border:1px solid #e5e7eb;
}

.campaign-notice-preview summary{
  list-style:none;
  display:grid;
  gap:6px;
  padding:12px;
  cursor:pointer;
}

.campaign-notice-preview summary::-webkit-details-marker{display:none}

.campaign-notice-preview-label{
  color:#667085;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.campaign-notice-preview strong{
  color:var(--ey-charcoal);
}

.campaign-notice-preview-toggle{
  color:var(--ey-orange-dark);
  font-size:12px;
  font-weight:800;
}

.campaign-notice-preview[open] .campaign-notice-preview-toggle::after{
  content:"Hide";
}

.campaign-notice-preview:not([open]) .campaign-notice-preview-toggle::after{
  content:"Open";
}

.campaign-notice-preview-body{
  padding:0 12px 12px;
  border-top:1px solid #eef2f6;
  color:#475467;
  font-size:13px;
  line-height:1.55;
}

.company-admin-grid{
  display:grid;
  grid-template-columns:minmax(260px,320px) minmax(0,1fr);
  gap:16px;
  align-items:start;
}

.company-stationery-card{
  display:grid;
  gap:14px;
  padding:16px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.company-logo-frame{
  display:grid;
  place-items:center;
  min-height:180px;
  padding:18px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#f8fafc;
}

.company-logo-frame img{
  max-width:220px;
  max-height:120px;
  object-fit:contain;
}

.company-stationery-copy{
  display:grid;
  gap:6px;
  color:var(--ey-muted);
  line-height:1.5;
}

.company-stationery-copy strong{
  color:var(--ey-charcoal);
}

.deck-template-picker{
  display:inline-grid;
  gap:6px;
  color:#475467;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
}

.deck-template-picker span{
  color:#667085;
  letter-spacing:.04em;
}

.deck-template-picker select{
  min-width:220px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  padding:10px 12px;
  background:#fff;
  color:var(--ey-charcoal);
  font-size:14px;
  font-weight:700;
}

.presentation-card.template-light{
  background:linear-gradient(180deg,rgba(78,174,232,.08),#fff 120px);
}

.attention-target{
  border-color:var(--ey-orange)!important;
  box-shadow:0 0 0 3px rgba(244,122,32,.16), 0 12px 28px rgba(21,30,41,.12);
  transition:box-shadow .2s ease,border-color .2s ease;
}

.presentation-card h3,.reminder-card h3,.user-card h3{margin:0;color:var(--ey-charcoal)}
.card-meta{display:flex;flex-wrap:wrap;gap:8px;color:#475467;line-height:1.45}
.card-actions{display:flex;flex-wrap:wrap;gap:8px}

.deck-preview-panel:empty{display:none}
.deck-preview-panel{display:grid;gap:18px}

.deck-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px;
  background:#fff;
  border:1px solid var(--ey-line);
  border-radius:8px;
}

.deck-toolbar h2{margin:0;color:var(--ey-charcoal)}
.deck-meta{margin-top:6px;color:#667085;font-weight:800}
.deck-brief-panel{
  display:grid;
  gap:14px;
  padding:18px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:linear-gradient(135deg,#fff 0%,#f8fbff 100%);
}
.deck-brief-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
}
.deck-brief-head h2{margin:0;color:var(--ey-charcoal)}
.deck-brief-hero{
  padding:10px 12px;
  border-radius:999px;
  background:rgba(244,122,32,.12);
  color:#9a4a0a;
  font-weight:800;
}
.deck-brief-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.deck-brief-card{
  display:grid;
  gap:6px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}
.deck-brief-card span{
  color:#667085;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.deck-brief-card strong{color:var(--ey-charcoal);line-height:1.5}
.deck-brief-note{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border-radius:8px;
  background:#fff7ed;
  border:1px solid #fed7aa;
}
.deck-brief-note-label{
  color:#9a4a0a;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.deck-brief-note p{margin:0;color:#7c2d12;line-height:1.6}

.collapsible-panel{
  overflow:hidden;
}

.collapsible-head{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:2px 0;
  cursor:pointer;
}

.collapsible-head::-webkit-details-marker{display:none}

.collapsible-meta{
  display:flex;
  align-items:center;
  gap:10px;
}

.collapsible-icon{
  color:#667085;
  font-size:13px;
  font-weight:800;
}

.collapsible-icon::before{
  content:"Expand";
}

.collapsible-panel[open] .collapsible-icon::before{
  content:"Collapse";
}

.collapsible-panel:not([open]) .collapsible-icon{
  color:var(--ey-orange);
}

.collapsible-body{
  padding-top:10px;
}

.deck-confirmation-panel{display:grid;gap:14px}
.deck-confirmation-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
}
.deck-confirmation-card{
  display:grid;
  gap:4px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}
.deck-confirmation-card span{
  color:var(--ey-orange);
  font-size:32px;
  font-weight:900;
  line-height:1;
}
.deck-confirmation-card strong{color:var(--ey-charcoal);font-size:18px}
.deck-confirmation-card small{color:#667085;line-height:1.45}
.deck-confirmation-card.booked{border-color:#bfe6cf;background:#effaf3}
.deck-confirmation-card.booked span{color:var(--ey-green)}
.deck-confirmation-card.planned{border-color:#ffd08b;background:#fff8ed}
.deck-confirmation-card.planned span{color:var(--ey-amber)}
.deck-confirmation-card.open{border-color:#d8dde6;background:#f8fafc}
.deck-confirmation-card.open span{color:#4b5565}
.deck-confirmation-card.blocked{border-color:#efb0a9;background:#fff2f0}
.deck-confirmation-card.blocked span{color:var(--ey-red)}

.deck-confirmation-list{display:grid;gap:10px}
.deck-confirmation-row{
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  padding:14px;
}
.deck-confirmation-row.booked{border-left:4px solid var(--ey-green)}
.deck-confirmation-row.planned{border-left:4px solid var(--ey-amber)}
.deck-confirmation-row.open{border-left:4px solid #98a2b3}
.deck-confirmation-row.blocked{border-left:4px solid var(--ey-red)}
.deck-confirmation-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.deck-confirmation-copy{display:grid;gap:6px}
.deck-confirmation-copy strong{color:var(--ey-charcoal)}
.deck-confirmation-copy small{color:#667085}
.deck-confirmation-copy p{
  margin:0;
  color:#475467;
  line-height:1.45;
}

.deck-ops-panel{display:grid;gap:14px}
.deck-ops-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
}
.deck-ops-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.deck-ops-card{
  display:grid;
  gap:12px;
  padding:16px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}
.deck-ops-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.deck-ops-card-head h3{
  margin:0;
  color:var(--ey-charcoal);
  font-size:20px;
}
.deck-ops-card-head small{
  display:block;
  margin-top:4px;
  color:#667085;
  line-height:1.45;
}
.deck-ops-form{display:grid;gap:12px}
.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.commercial-history{
  display:grid;
  gap:10px;
  padding-top:10px;
  border-top:1px dashed var(--ey-line);
}
.deck-invoice-list{
  display:grid;
  gap:12px;
  padding-top:12px;
  border-top:1px solid var(--ey-line);
}
.deck-invoice-card{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#f8fafc;
}

.invoice-register-panel{
  display:grid;
  gap:18px;
}

.invoice-register-head{
  align-items:flex-end;
}

.invoice-register-head .panel-actions{
  min-width:min(360px,100%);
}

.invoice-register-head input{
  min-width:min(360px,100%);
}

.invoice-summary-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:0;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  overflow:hidden;
}

.invoice-summary-card{
  display:grid;
  gap:6px;
  padding:16px 18px;
  border-right:1px solid var(--ey-line);
}

.invoice-summary-card:last-child{
  border-right:none;
}

.invoice-summary-card span{
  color:#667085;
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
}

.invoice-summary-card strong{
  color:var(--ey-charcoal);
  font-size:26px;
  line-height:1;
}

.invoice-summary-card small{
  color:#475467;
  line-height:1.45;
}

.invoice-summary-card.warn strong{color:var(--ey-orange-dark)}
.invoice-summary-card.danger strong{color:var(--ey-red)}
.invoice-summary-card.good strong{color:var(--ey-green)}

.invoice-workspace{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(420px,.9fr);
  gap:18px;
  align-items:start;
}

.invoice-register-table,
.invoice-preview-panel{
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  overflow:hidden;
}

.invoice-register-columns,
.invoice-register-row{
  display:grid;
  grid-template-columns:120px 160px 160px minmax(180px,1.4fr) 150px 120px 130px 130px;
  gap:10px;
  align-items:center;
}

.quote-register-columns,
.quote-register-row{
  grid-template-columns:120px 170px 170px minmax(200px,1.5fr) 150px 120px 130px;
}

.invoice-register-columns{
  padding:12px 16px;
  border-bottom:1px solid var(--ey-line);
  color:#667085;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:#f8fafc;
}

.invoice-register-list{
  display:grid;
}

.invoice-register-row{
  padding:14px 16px;
  border-bottom:1px solid #eef2f6;
  background:#fff;
  transition:background .18s ease, box-shadow .18s ease;
  cursor:pointer;
}

.invoice-register-row:last-child{
  border-bottom:none;
}

.invoice-register-row:hover{
  background:#f8fafc;
}

.invoice-register-row.active{
  background:#fff7f2;
  box-shadow:inset 3px 0 0 var(--ey-orange);
}

.invoice-cell{
  min-width:0;
  color:#27313d;
  font-size:14px;
  line-height:1.4;
}

.invoice-cell strong,
.invoice-cell .invoice-number-link{
  color:#0f62fe;
  font-weight:800;
}

.invoice-cell .invoice-number-link{
  text-decoration:none;
}

.invoice-cell .invoice-subline{
  display:block;
  margin-top:3px;
  color:#667085;
  font-size:12px;
}

.invoice-cell.muted{
  color:#667085;
}

.invoice-status{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:4px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:1px solid var(--ey-line);
  background:#f5f6f8;
  color:#5b6472;
}

.invoice-status.good{
  border-color:#b9e4c7;
  background:#effaf3;
  color:var(--ey-green);
}

.invoice-status.warn{
  border-color:#f2d2b9;
  background:#fff4ec;
  color:var(--ey-orange-dark);
}

.invoice-status.danger{
  border-color:#f0b8b1;
  background:#fff1f0;
  color:var(--ey-red);
}

.invoice-empty-row{
  padding:28px 20px;
  color:#667085;
}

.invoice-preview-panel{
  position:sticky;
  top:96px;
  display:grid;
  gap:0;
  min-height:720px;
}

.invoice-preview-empty{
  display:grid;
  place-items:center;
  gap:8px;
  min-height:720px;
  padding:30px;
  text-align:center;
  color:#667085;
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.invoice-preview-empty strong{
  color:var(--ey-charcoal);
  font-size:22px;
}

.invoice-preview-shell{
  display:grid;
  grid-template-rows:auto auto auto minmax(0,1fr);
  min-height:720px;
}

.invoice-preview-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding:16px 18px;
  border-bottom:1px solid var(--ey-line);
  background:#fff;
}

.invoice-preview-header h3{
  margin:0;
  color:var(--ey-charcoal);
  font-size:26px;
  line-height:1.1;
}

.invoice-preview-header p{
  margin:4px 0 0;
  color:#667085;
  line-height:1.45;
}

.invoice-preview-header .pill-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}

.invoice-preview-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:14px 18px;
  border-bottom:1px solid var(--ey-line);
  background:#f8fafc;
}

.invoice-preview-note{
  display:grid;
  gap:12px;
  padding:16px 18px;
  border-bottom:1px solid var(--ey-line);
  background:#fff;
}

.invoice-preview-note.hidden{
  display:none;
}

.invoice-preview-note-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}

.invoice-preview-note-head strong{
  display:block;
  color:var(--ey-charcoal);
  font-size:16px;
}

.invoice-preview-note-head span{
  display:block;
  margin-top:4px;
  color:var(--ey-muted);
  line-height:1.45;
}

.invoice-preview-note-list{
  display:grid;
  gap:12px;
}

.invoice-preview-frame{
  width:100%;
  min-height:0;
  height:100%;
  border:none;
  background:#eef2f6;
}

@media (max-width:1440px){
  .invoice-summary-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .invoice-summary-card:nth-child(3){
    border-right:none;
  }
  .invoice-summary-card:nth-child(n+4){
    border-top:1px solid var(--ey-line);
  }
}

@media (max-width:1180px){
  .overview-range-layout{
    grid-template-columns:1fr;
    gap:18px;
  }
  .overview-range-controls{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .invoice-workspace{
    grid-template-columns:1fr;
  }
  .invoice-preview-panel{
    position:static;
    min-height:680px;
  }
}

@media (max-width:980px){
  .invoice-summary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .invoice-summary-card:nth-child(2n){
    border-right:none;
  }
  .invoice-summary-card:nth-child(n+3){
    border-top:1px solid var(--ey-line);
  }
  .invoice-register-columns,
  .invoice-register-row{
    grid-template-columns:110px 145px 145px minmax(170px,1fr) 140px 110px 120px 120px;
  }
  .quote-register-columns,
  .quote-register-row{
    grid-template-columns:110px 150px 150px minmax(170px,1fr) 140px 110px 120px;
  }
}

@media (max-width:760px){
  .overview-range-panel{
    padding:18px;
  }
  .overview-range-controls{
    grid-template-columns:1fr;
  }
  .invoice-summary-grid{
    grid-template-columns:1fr;
  }
  .invoice-summary-card{
    border-right:none;
    border-top:1px solid var(--ey-line);
  }
  .invoice-summary-card:first-child{
    border-top:none;
  }
  .invoice-register-columns{
    display:none;
  }
  .invoice-register-row{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px 14px;
  }
}

.deck-booking-form{
  display:grid;
  gap:10px;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--ey-line);
}

.booking-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--ey-charcoal);
  font-weight:800;
}

.booking-toggle input{
  width:18px;
  min-height:18px;
  height:18px;
  margin:0;
  padding:0;
}

.booking-form-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.booking-file-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  color:#475467;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.booking-file-field input{
  min-height:auto;
  padding:0;
  border:none;
  box-shadow:none;
}

.booking-save-meta,
.booking-form-note{
  margin:0;
  color:#667085;
  line-height:1.45;
}

.booking-audit-log{
  display:grid;
  gap:10px;
  margin-top:12px;
  padding-top:12px;
  border-top:1px dashed var(--ey-line);
}

.booking-audit-log > strong{color:var(--ey-charcoal)}

.booking-audit-entry{
  display:grid;
  gap:8px;
  padding:12px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#f8fafc;
}

.booking-audit-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  flex-wrap:wrap;
}

.booking-audit-entry p{
  margin:0;
  color:#475467;
  line-height:1.45;
}

.booking-audit-files{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.booking-file-link{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 10px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  color:var(--ey-orange-dark);
  font-weight:800;
  text-decoration:none;
}

.booking-file-link:hover{text-decoration:underline}

.slide{
  width:min(1200px,100%);
  margin:0 auto;
  border-radius:8px;
  overflow:hidden;
  box-shadow:var(--shadow);
  page-break-after:always;
}
.briefing-slide{
  display:grid;
  gap:18px;
  align-content:start;
  padding:30px 32px;
  min-height:675px;
  background:linear-gradient(135deg,#fff 0%,#f8fbff 55%,#fff7ed 100%);
  color:#181f27;
}
.briefing-slide .deck-brief-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.briefing-slide .deck-brief-card,
.briefing-slide .deck-brief-note{box-shadow:0 10px 24px rgba(21,30,41,.06)}

.dark-slide{
  background:linear-gradient(145deg,#4a4f56 0%,#23282e 42%,#0e1419 100%);
  color:#f5f7fa;
  padding:18px;
  min-height:675px;
}

.dark-slide .slide-top{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:18px;
  align-items:start;
  margin-bottom:22px;
}

.dark-slide h2,.dark-slide h3{margin:0;font-weight:400;line-height:1.1}
.dark-slide h2{font-size:34px;text-transform:uppercase}
.dark-slide h3{font-size:36px;text-align:right}
.campaign-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 20px;
  color:#f5f7fa;
  font-size:13px;
}
.campaign-strip span{
  border:1px solid rgba(255,255,255,.25);
  padding:7px 9px;
  border-radius:8px;
  background:rgba(255,255,255,.08);
}
.campaign-strip.light{
  margin:0 0 16px;
  color:#27313d;
}
.campaign-strip.light span{
  border-color:var(--ey-line);
  background:#f8fafc;
}
.slide-media{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:stretch}
.slide-media > img,.slide-map img,.slide-map iframe,.slide-map .map-fallback{width:100%;height:390px;object-fit:cover;border:0}
.slide-map{background:#f3f5f7}
.map-fallback{display:grid;place-items:center;color:#475467;text-align:center;padding:20px}
.dark-description{font-size:17px;line-height:1.35;margin:12px 0 10px;color:#fff}
.dark-audience-note{
  margin:0 0 12px;
  color:#d8dee7;
  font-size:14px;
  line-height:1.5;
}
.dark-facts{display:grid;grid-template-columns:1.2fr 1fr 1.1fr;gap:16px;align-items:end}
.dark-fact-table{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:17px}
.dark-fact-table span{color:#b9c0c9}
.dark-fact-table strong{font-weight:500;color:#fff}
.slide-logo{justify-self:end;align-self:end;width:160px;filter:drop-shadow(0 6px 12px rgba(0,0,0,.18))}

.light-slide{
  background:#fff;
  color:#181f27;
  padding:26px 28px;
  min-height:675px;
}

.light-head{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:18px;
  margin-bottom:14px;
}

.light-head h2{margin:0;color:var(--ey-blue);font-size:34px;text-transform:uppercase;font-weight:400}
.light-site-no{background:var(--ey-blue);color:#fff;padding:13px 16px;font-size:21px;font-weight:500}
.light-media{display:grid;grid-template-columns:1.2fr .9fr;gap:34px;align-items:center;margin:14px 0 28px}
.light-media img{height:260px;width:100%;object-fit:cover;box-shadow:18px 18px 24px rgba(0,0,0,.2)}
.light-media .slide-map img,.light-media .slide-map iframe,.light-media .slide-map .map-fallback{height:320px;width:100%;border:0;background:#edf2f7}
.site-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:15px}
.site-table td{border:2px solid #2d333b;padding:12px;vertical-align:top}
.site-table strong{color:#181f27}
.site-table .hot{color:#f03b2f}
.site-description-row{height:80px}
.light-footer{display:flex;justify-content:flex-end;margin-top:12px}
.light-footer img{width:145px}

.modal{
  position:fixed;
  inset:0;
  z-index:800;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
  background:rgba(8,13,19,.62);
}

.modal[aria-hidden="false"]{display:flex}

.modal-card{
  width:min(1040px,100%);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border:1px solid var(--ey-line);
  border-radius:8px;
  box-shadow:0 28px 80px rgba(0,0,0,.3);
  padding:20px;
  animation:modalIn .2s ease both;
}

.modal-card.wide{width:min(1180px,100%)}

@keyframes modalIn{
  from{opacity:0;transform:translateY(12px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:16px;
}

.modal-head h2{margin:0;color:var(--ey-charcoal);font-size:26px}

.step-strip{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:8px;
  margin-bottom:18px;
}

.step-pill{
  border:1px solid var(--ey-line);
  border-radius:8px;
  padding:9px 10px;
  color:#667085;
  background:#fff;
  font-size:13px;
  font-weight:900;
}

.step-pill.active{background:var(--ey-charcoal);border-color:var(--ey-charcoal);color:#fff}
.step-pill.complete{background:#fff7f2;border-color:#ffc49f;color:#873d0d}

.wizard-form{display:grid;gap:16px}
.wizard-step-panel{display:none;animation:panelIn .22s ease both}
.wizard-step-panel.active{display:block}
.wizard-step-panel h3{margin:0 0 14px;color:var(--ey-charcoal);font-size:22px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}
.full-span{grid-column:1/-1}
.wizard-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--ey-line)}
.wizard-actions-right{display:flex;gap:10px;flex-wrap:wrap}

.photo-preview{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:10px;
}

.photo-thumb{
  position:relative;
  overflow:hidden;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#f8fafc;
}

.photo-thumb img{width:100%;height:130px;object-fit:cover}
.photo-thumb button{position:absolute;top:6px;right:6px}

.picker-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:12px;
  max-height:52vh;
  overflow:auto;
  padding-right:4px;
}

.picker-card{
  display:grid;
  gap:9px;
  padding:12px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
}

.picker-card.selected{border-color:var(--ey-orange);box-shadow:0 0 0 3px rgba(244,122,32,.12)}
.picker-card h4{margin:0;color:var(--ey-charcoal)}
.picker-card p{margin:0;color:#475467;line-height:1.4}
.picker-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.picker-top input{width:auto;min-height:auto}

.template-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}
.template-option,.check-card{
  display:grid;
  gap:8px;
  padding:14px;
  border:1px solid var(--ey-line);
  border-radius:8px;
  background:#fff;
  cursor:pointer;
}

.template-option input,.check-card input{width:auto;min-height:auto}
.template-option span,.check-card span{font-size:18px;font-weight:900;color:var(--ey-charcoal);letter-spacing:0;text-transform:none}
.template-option strong{color:#475467;line-height:1.45;font-size:14px}
.check-card{grid-template-columns:auto 1fr;align-items:center;margin-bottom:10px}

.review-card{
  border:1px solid var(--ey-line);
  border-radius:8px;
  padding:14px;
  background:#f8fafc;
  color:#475467;
  line-height:1.6;
}

.audience-preview{
  display:grid;
  gap:10px;
}

.audience-profile-card{
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid #d7e4f0;
  border-radius:8px;
  background:linear-gradient(180deg,#f8fbff,#f2f7fc);
}

.audience-profile-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.audience-profile-head strong{
  display:block;
  color:var(--ey-charcoal);
  font-size:15px;
}

.audience-profile-head span{
  color:#667085;
  line-height:1.4;
}

.audience-profile-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.audience-profile-grid div{
  display:grid;
  gap:4px;
  padding:10px 12px;
  border:1px solid #dbe4ed;
  border-radius:8px;
  background:#fff;
}

.audience-profile-grid span{
  color:#667085;
  font-size:11px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.audience-profile-grid strong{
  color:var(--ey-charcoal);
  line-height:1.4;
}

.audience-profile-copy{
  margin:0;
  color:#475467;
  line-height:1.5;
}

.user-admin-grid{display:grid;grid-template-columns:minmax(260px,360px) 1fr;gap:16px}
.stacked-form{display:grid;gap:12px}

.empty-state{
  padding:18px;
  border:1px dashed #aeb7c4;
  border-radius:8px;
  color:#667085;
  background:#fff;
  line-height:1.5;
}

@media (max-width:1100px){
  .app-layout{grid-template-columns:1fr}
  .sidebar{
    position:sticky;
    top:78px;
    z-index:80;
    height:auto;
    flex-direction:row;
    overflow:auto;
  }
  .nav-btn{white-space:nowrap}
  .landing-grid,.metric-grid,.overview-grid,.filters,.filters.slim,.form-grid,.template-choice-grid,.user-admin-grid,.company-admin-grid,.slide-media,.light-media,.dark-slide .slide-top,.dark-facts,.audience-profile-grid,.deck-brief-grid,.briefing-slide .deck-brief-grid{grid-template-columns:1fr}
  .dark-slide .slide-top{margin-bottom:24px}
  .dark-slide h3{text-align:left}
  .overview-card.wide{grid-column:auto}
}

@media (max-width:720px){
  .app-header{align-items:flex-start;flex-direction:column}
  .app-brand{align-items:flex-start;flex-direction:column}
  .app-brand img,.auth-brand img{width:160px}
  .auth-brand{align-items:flex-start;flex-direction:column}
  .content{padding:14px}
  .panel-head{flex-direction:column}
  .map-list-card{grid-template-columns:1fr}
  .map-list-actions{align-items:flex-start}
  .action-tile span{font-size:24px}
  .metric-grid{grid-template-columns:1fr}
  .modal{padding:10px}
  .modal-card{padding:14px}
  .wizard-actions{align-items:stretch;flex-direction:column}
  .wizard-actions .btn{width:100%}
  .wizard-actions-right{width:100%}
  .deck-toolbar,.deck-confirmation-head,.deck-brief-head,.deck-ops-card-head{align-items:flex-start;flex-direction:column}
  .deck-ops-grid,.compact-grid{grid-template-columns:1fr}
  .presentation-summary{grid-template-columns:1fr}
  .booking-form-footer,.booking-audit-head{align-items:flex-start;flex-direction:column}
  .light-head{grid-template-columns:1fr}
}

@media print{
  body{background:#fff}
  body *{visibility:hidden!important}
  #deckPreviewPanel,#deckPreviewPanel *{visibility:visible!important}
  #deckPreviewPanel{
    position:absolute;
    inset:0 auto auto 0;
    display:block!important;
    width:100%;
    margin:0;
    padding:0;
  }
  .deck-toolbar{display:none!important}
  .slide{
    width:100%;
    min-height:100vh;
    margin:0;
    border-radius:0;
    box-shadow:none;
    page-break-after:always;
  }
}
