/* ATP Brand System - ABC Services Co. Staff AI Command Center (DEMO) */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;900&family=Inter:wght@400;500;600&display=swap');

:root {
  --atp-black: #0A0A0A;
  --atp-charcoal: #1A1A1A;
  --atp-gray-dark: #2A2A2A;
  --atp-gray-light: #B8B8B8;
  --atp-white: #FFFFFF;
  --atp-gold: #C9A84C;
  --atp-gold-bright: #E8C547;
  --atp-gold-dark: #A08030;
  --accent-rgb: 201, 168, 76;
  --atp-gold-glow: rgba(var(--accent-rgb), 0.4);
  --atp-blue: #0693E3;
  --atp-text-body: #B8B8B8;
  --atp-text-muted: #666666;
  --atp-border: #2A2A2A;
  --ok: #5F8F6B;
  --warn: #C9A84C;
  --bad: #B4553F;
}

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

html, body { height: 100%; }
body {
  font-family: 'Inter', -apple-system, sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--atp-text-body);
  background: var(--atp-black);
  background-image:
    linear-gradient(rgba(var(--accent-rgb),0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--accent-rgb),0.03) 1px, transparent 1px);
  background-size: 48px 48px;
}

h1, h2, h3, h4 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: var(--atp-white);
  text-transform: uppercase;
  letter-spacing: 2px;
}

a { color: var(--atp-gold); text-decoration: none; }
a:hover { color: var(--atp-gold-bright); }

.label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--atp-gold);
}

/* ---------- shimmer ---------- */
.shimmer {
  background: linear-gradient(110deg, var(--atp-gold) 20%, var(--atp-gold-bright) 40%, #fff8dd 50%, var(--atp-gold-bright) 60%, var(--atp-gold) 80%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: shimmer 4s linear infinite;
}
@keyframes shimmer { to { background-position: -200% center; } }

/* ---------- login ---------- */
#login-screen {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  background: var(--atp-black);
  background-image: radial-gradient(ellipse at 50% 30%, rgba(var(--accent-rgb),0.07), transparent 60%),
    linear-gradient(rgba(var(--accent-rgb),0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--accent-rgb),0.03) 1px, transparent 1px);
  background-size: auto, 48px 48px, 48px 48px;
  transition: opacity .5s ease;
}
#login-screen.fade-out { opacity: 0; pointer-events: none; }
.login-card {
  width: min(440px, 92vw);
  background: var(--atp-charcoal);
  border: 1px solid var(--atp-border);
  border-top: 2px solid var(--atp-gold);
  padding: 48px 44px 36px;
  box-shadow: 0 4px 60px rgba(0,0,0,.6);
  text-align: center;
}
.login-logo { width: min(250px, 72%); height: auto; display: block; margin: 0 auto 22px; }
.login-card h1 { font-size: 22px; letter-spacing: 3px; margin-bottom: 4px; }
.login-sub { font-size: 12px; letter-spacing: 2px; color: var(--atp-text-muted); text-transform: uppercase; margin-bottom: 30px; }
.login-field { text-align: left; margin-bottom: 16px; }
.login-field label { display: block; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--atp-text-muted); margin-bottom: 6px; }
.login-field input {
  width: 100%; padding: 13px 14px;
  background: var(--atp-black); border: 1px solid var(--atp-border);
  color: var(--atp-white); font-family: 'Inter', sans-serif; font-size: 15px;
  outline: none; transition: border-color .3s;
}
.login-field input:focus { border-color: var(--atp-gold); }
.demo-note {
  margin-top: 18px; padding: 10px 12px;
  border: 1px dashed var(--atp-gold-dark);
  font-size: 12.5px; color: var(--atp-gray-light);
}
.demo-note strong { color: var(--atp-gold); }
.login-foot { margin-top: 26px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--atp-text-muted); }

/* ---------- buttons ---------- */
.btn-gold, .btn-ghost {
  font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 2px;
  padding: 13px 28px; cursor: pointer; border: none;
  transition: all .3s ease; display: inline-block;
}
.btn-gold { background: var(--atp-gold); color: var(--atp-black); }
.btn-gold:hover { background: var(--atp-gold-bright); box-shadow: 0 0 20px var(--atp-gold-glow); }
.btn-ghost { background: transparent; color: var(--atp-gold); border: 1px solid var(--atp-gold); }
.btn-ghost:hover { background: rgba(var(--accent-rgb),.1); box-shadow: 0 0 20px var(--atp-gold-glow); }
.btn-gold.full { width: 100%; }

/* ---------- app shell ---------- */
#app { display: none; min-height: 100vh; }
#app.visible { display: block; }

#brandbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 18px;
  padding: 0 22px; height: 60px;
  background: rgba(10,10,10,.88);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--atp-border);
}
#brand-logo { height: 36px; width: auto; flex: 0 0 auto; display: block; }
.brand-name { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 2px; color: var(--atp-white); text-transform: uppercase; white-space: nowrap; }
.brand-name span { color: var(--atp-gold); }
.demo-badge {
  font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px;
  color: var(--atp-black); background: var(--atp-gold); padding: 3px 9px; white-space: nowrap;
}
.bar-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.persona-wrap { display: flex; align-items: center; gap: 8px; }
.persona-wrap .label { font-size: 10px; }
select#persona {
  background: var(--atp-charcoal); color: var(--atp-white);
  border: 1px solid var(--atp-border); padding: 8px 10px;
  font-family: 'Inter', sans-serif; font-size: 13px; outline: none; cursor: pointer;
}
select#persona:hover { border-color: var(--atp-gold); }
.btn-tour {
  font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px;
  text-transform: uppercase; color: var(--atp-gold); background: transparent;
  border: 1px solid var(--atp-gold); padding: 8px 16px; cursor: pointer; transition: all .3s;
}
.btn-tour:hover { background: rgba(var(--accent-rgb),.1); box-shadow: 0 0 16px var(--atp-gold-glow); }

#layout { display: flex; min-height: calc(100vh - 60px); }

/* ---------- sidebar ---------- */
#sidebar {
  width: 232px; flex: 0 0 232px;
  border-right: 1px solid var(--atp-border);
  background: rgba(16,16,16,.6);
  padding: 26px 0 90px;
}
.nav-group { margin-bottom: 26px; }
.nav-group .label { display: block; padding: 0 22px 8px; color: var(--atp-text-muted); }
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 22px; cursor: pointer;
  font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--atp-gray-light);
  border-left: 2px solid transparent; transition: all .25s;
}
.nav-item:hover { color: var(--atp-white); background: rgba(var(--accent-rgb),.05); }
.nav-item.active { color: var(--atp-gold); border-left-color: var(--atp-gold); background: rgba(var(--accent-rgb),.07); }
.nav-item .dot { width: 5px; height: 5px; background: currentColor; flex: 0 0 auto; }
.sidebar-cta { margin: 10px 18px 0; padding: 16px; border: 1px solid var(--atp-gold-dark); }
.sidebar-cta p { font-size: 12px; color: var(--atp-gray-light); margin: 8px 0 12px; }

/* ---------- main ---------- */
#main { flex: 1; min-width: 0; padding: 34px 34px 80px; }
.page-head { margin-bottom: 26px; }
.page-head h2 { font-size: clamp(20px, 2.6vw, 28px); letter-spacing: 3px; }
.page-head .sub { color: var(--atp-text-muted); font-size: 13.5px; margin-top: 4px; }
.gold-rule { width: 60px; height: 2px; background: var(--atp-gold); border: none; margin: 14px 0 0; }

/* ---------- cards & grids ---------- */
.card {
  background: var(--atp-charcoal);
  border: 1px solid var(--atp-border);
  padding: 26px;
  box-shadow: 0 4px 30px rgba(0,0,0,.3);
  transition: border-color .3s;
}
.card:hover { border-color: rgba(var(--accent-rgb),.45); }
.card h3 { font-size: 14px; letter-spacing: 2px; margin-bottom: 4px; }
.card .card-sub { font-size: 12.5px; color: var(--atp-text-muted); margin-bottom: 16px; }

.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; margin-bottom: 22px; }
.kpi { background: var(--atp-charcoal); border: 1px solid var(--atp-border); border-top: 2px solid var(--atp-gold); padding: 18px 20px; }
.kpi .k-label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--atp-text-muted); }
.kpi .k-value { font-family: 'Montserrat', sans-serif; font-weight: 900; font-size: 30px; color: var(--atp-white); margin-top: 2px; }
.kpi .k-note { font-size: 12px; color: var(--atp-gold); margin-top: 2px; }

.two-col { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 20px; align-items: start; }
.stack > * + * { margin-top: 20px; }

/* ---------- AI action buttons ---------- */
.ai-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 12px; }
.ai-btn {
  display: flex; align-items: center; gap: 12px; text-align: left;
  background: linear-gradient(180deg, rgba(var(--accent-rgb),.14), rgba(var(--accent-rgb),.05));
  border: 1px solid var(--atp-gold-dark);
  color: var(--atp-white); padding: 15px 16px; cursor: pointer;
  font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase;
  transition: all .3s ease; position: relative;
}
.ai-btn:hover { border-color: var(--atp-gold-bright); box-shadow: 0 0 22px var(--atp-gold-glow); transform: translateY(-1px); }
.ai-btn .ic {
  width: 34px; height: 34px; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--atp-gold); color: var(--atp-gold); font-size: 15px; font-family: 'Inter', sans-serif;
}
.ai-btn.busy { pointer-events: none; opacity: .75; }
.ai-btn .spin {
  width: 14px; height: 14px; margin-left: auto; flex: 0 0 auto;
  border: 2px solid var(--atp-gold-dark); border-top-color: var(--atp-gold-bright);
  animation: rot .7s linear infinite;
}
@keyframes rot { to { transform: rotate(360deg); } }

/* ---------- tables ---------- */
.table-tools { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 14px; }
.chip {
  font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 7px 14px; border: 1px solid var(--atp-border); color: var(--atp-gray-light);
  background: transparent; cursor: pointer; transition: all .25s;
}
.chip:hover { border-color: var(--atp-gold); color: var(--atp-gold); }
.chip.active { border-color: var(--atp-gold); color: var(--atp-black); background: var(--atp-gold); }
.search-box {
  margin-left: auto; background: var(--atp-black); border: 1px solid var(--atp-border);
  color: var(--atp-white); padding: 9px 12px; font-family: 'Inter', sans-serif; font-size: 13px;
  min-width: 210px; outline: none; transition: border-color .3s;
}
.search-box:focus { border-color: var(--atp-gold); }

.tbl-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13.5px; white-space: nowrap; }
thead th {
  font-family: 'Montserrat', sans-serif; font-size: 10.5px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--atp-text-muted); text-align: left;
  padding: 10px 12px; border-bottom: 1px solid var(--atp-gold-dark);
  position: sticky; top: 0; background: var(--atp-charcoal);
}
thead th.sortable { cursor: pointer; }
thead th.sortable:hover { color: var(--atp-gold); }
tbody td { padding: 11px 12px; border-bottom: 1px solid var(--atp-border); color: var(--atp-gray-light); }
tbody tr { transition: background .2s; }
tbody tr:hover { background: rgba(var(--accent-rgb),.05); }
td.cust { color: var(--atp-white); font-weight: 500; }
td.num { font-variant-numeric: tabular-nums; }
.mono { color: var(--atp-text-muted); font-size: 12.5px; }
.link-out { color: var(--atp-blue); font-size: 12.5px; cursor: pointer; }

.status {
  display: inline-block; font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 600;
  letter-spacing: 1.2px; text-transform: uppercase; padding: 3px 9px; border: 1px solid;
}
.st-ok { color: #8FBF9B; border-color: #3E5D47; background: rgba(95,143,107,.12); }
.st-warn { color: var(--atp-gold-bright); border-color: var(--atp-gold-dark); background: rgba(var(--accent-rgb),.1); }
.st-bad { color: #D98B77; border-color: #6E3527; background: rgba(180,85,63,.13); }
.st-neutral { color: var(--atp-gray-light); border-color: var(--atp-gray-dark); background: rgba(255,255,255,.03); }

.row-ai {
  font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--atp-gold); background: transparent;
  border: 1px solid var(--atp-gold-dark); padding: 5px 11px; cursor: pointer; transition: all .25s;
}
.row-ai:hover { background: var(--atp-gold); color: var(--atp-black); }

/* ---------- SLA watch ---------- */
.sla-item { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--atp-border); font-size: 13px; }
.sla-item:last-child { border-bottom: none; }
.sla-chip { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 12px; padding: 5px 10px; min-width: 74px; text-align: center; border: 1px solid; }
.sla-red { color: #D98B77; border-color: #6E3527; }
.sla-amber { color: var(--atp-gold-bright); border-color: var(--atp-gold-dark); }
.sla-green { color: #8FBF9B; border-color: #3E5D47; }

/* ---------- activity feed ---------- */
.feed-item { display: flex; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--atp-border); font-size: 13px; }
.feed-item:last-child { border-bottom: none; }
.feed-time { color: var(--atp-gold); font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1px; min-width: 64px; padding-top: 2px; }
.feed-text { color: var(--atp-gray-light); }

/* ---------- lists (front desk etc) ---------- */
.list-item { display: flex; gap: 14px; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--atp-border); font-size: 13.5px; }
.list-item:last-child { border-bottom: none; }
.li-time { color: var(--atp-gold); font-family: 'Montserrat', sans-serif; font-size: 11.5px; font-weight: 600; min-width: 74px; }
.li-main { color: var(--atp-white); }
.li-sub { color: var(--atp-text-muted); font-size: 12.5px; }
.li-right { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.kind-tag { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--atp-text-muted); border: 1px solid var(--atp-border); padding: 2px 8px; }

/* ---------- pipeline ---------- */
.pipe-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 14px; }
.pipe-stage { border: 1px solid var(--atp-border); border-top: 2px solid var(--atp-gold); padding: 16px 18px; background: var(--atp-black); }
.pipe-stage .p-count { font-family: 'Montserrat', sans-serif; font-weight: 900; font-size: 26px; color: var(--atp-white); }
.pipe-stage .p-stage { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--atp-text-muted); }
.pipe-stage .p-val { font-size: 13px; color: var(--atp-gold); margin-top: 3px; }

/* ---------- team ---------- */
.team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 14px; }
.person { background: var(--atp-charcoal); border: 1px solid var(--atp-border); padding: 18px; display: flex; gap: 14px; transition: border-color .3s; }
.person:hover { border-color: var(--atp-gold); }
.avatar {
  width: 44px; height: 44px; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--atp-gold); color: var(--atp-gold);
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
}
.person .p-name { color: var(--atp-white); font-weight: 600; font-size: 14px; }
.person .p-role { font-size: 12px; color: var(--atp-text-muted); }
.person .p-ai { font-size: 12px; color: var(--atp-gray-light); margin-top: 7px; padding-top: 7px; border-top: 1px solid var(--atp-border); }
.person .p-ai b { color: var(--atp-gold); font-weight: 600; }

/* ---------- why page ---------- */
.why-hero { text-align: center; padding: 46px 20px 40px; }
.why-hero h2 { font-size: clamp(24px, 3.4vw, 40px); letter-spacing: 4px; }
.why-hero p { max-width: 640px; margin: 18px auto 0; font-size: 16px; }
.ladder { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; margin-top: 26px; }
.ladder .card.feature { border: 2px solid var(--atp-gold); position: relative; }
.ladder .tag {
  position: absolute; top: -11px; left: 20px; background: var(--atp-gold); color: var(--atp-black);
  font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; padding: 3px 10px;
}
.ladder p { font-size: 13.5px; }
.why-points { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.why-points .card p { font-size: 13.5px; }
.guarantee { border: 1px dashed var(--atp-gold); padding: 26px; text-align: center; }
.guarantee .big { font-family: 'Montserrat', sans-serif; color: var(--atp-white); font-size: 19px; letter-spacing: 1px; text-transform: uppercase; }

/* ---------- modal ---------- */
#modal-overlay {
  position: fixed; inset: 0; z-index: 300; display: none;
  align-items: center; justify-content: center;
  background: rgba(0,0,0,.75); backdrop-filter: blur(4px);
}
#modal-overlay.open { display: flex; }
.modal {
  width: min(560px, 92vw); max-height: 86vh; overflow-y: auto;
  background: var(--atp-charcoal); border: 1px solid var(--atp-gold);
  padding: 36px 38px; box-shadow: 0 0 60px rgba(var(--accent-rgb),.25);
  animation: pop .28s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes pop { from { transform: scale(.94) translateY(10px); opacity: 0; } }
.modal .m-eyebrow { margin-bottom: 10px; }
.modal h3 { font-size: 19px; letter-spacing: 2px; margin-bottom: 14px; }
.modal .m-body { font-size: 14.5px; color: var(--atp-gray-light); }
.m-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 20px 0; }
.m-stat { border: 1px solid var(--atp-border); padding: 12px 14px; background: var(--atp-black); }
.m-stat .s-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--atp-text-muted); }
.m-stat .s-val { color: var(--atp-gold); font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px; margin-top: 2px; }
.m-pitch { border-left: 2px solid var(--atp-gold); padding: 14px 16px; background: rgba(var(--accent-rgb),.06); font-size: 13.5px; margin-bottom: 22px; }
.m-pitch b { color: var(--atp-gold); }
.m-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.m-close { position: sticky; top: 0; float: right; background: none; border: none; color: var(--atp-text-muted); font-size: 22px; cursor: pointer; line-height: 1; }
.m-close:hover { color: var(--atp-gold); }

/* ---------- tour ---------- */
.tour-glow { position: relative; z-index: 260; box-shadow: 0 0 0 2px var(--atp-gold), 0 0 40px var(--atp-gold-glow) !important; }
#tour-veil { position: fixed; inset: 0; z-index: 250; background: rgba(0,0,0,.6); display: none; }
#tour-veil.open { display: block; }
#tour-card {
  position: fixed; z-index: 390; bottom: 28px; left: 50%; transform: translateX(-50%);
  width: min(480px, 92vw); background: var(--atp-charcoal); border: 1px solid var(--atp-gold);
  padding: 26px 28px; box-shadow: 0 0 50px rgba(var(--accent-rgb),.3); display: none;
}
#tour-card.open { display: block; }
#tour-card h4 { font-size: 14px; letter-spacing: 2px; margin: 6px 0 8px; }
#tour-card p { font-size: 13.5px; color: var(--atp-gray-light); }
.tour-foot { display: flex; align-items: center; gap: 10px; margin-top: 18px; }
.tour-step-count { font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: 2px; color: var(--atp-text-muted); margin-right: auto; }
.tour-btn { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; padding: 9px 18px; cursor: pointer; border: 1px solid var(--atp-gold); background: transparent; color: var(--atp-gold); transition: all .25s; }
.tour-btn.primary { background: var(--atp-gold); color: var(--atp-black); }
.tour-btn:hover { box-shadow: 0 0 16px var(--atp-gold-glow); }

/* ---------- toast ---------- */
#toast {
  position: fixed; bottom: 104px; right: 26px; z-index: 400;
  background: var(--atp-charcoal); border: 1px solid var(--atp-gold);
  color: var(--atp-white); padding: 14px 20px; font-size: 13.5px;
  box-shadow: 0 0 30px rgba(var(--accent-rgb),.25);
  opacity: 0; transform: translateY(12px); transition: all .35s ease; pointer-events: none;
  max-width: 360px;
}
#toast.show { opacity: 1; transform: translateY(0); }
#toast b { color: var(--atp-gold); }

/* ---------- footer ---------- */
#app-footer {
  border-top: 1px solid var(--atp-border); padding: 22px 34px;
  font-size: 12px; color: var(--atp-text-muted); display: flex; gap: 18px; flex-wrap: wrap;
}
#app-footer .right { margin-left: auto; }

/* ---------- reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(14px); animation: rise .5s ease forwards; }
@keyframes rise { to { opacity: 1; transform: none; } }

/* ---------- responsive ---------- */
@media (max-width: 980px) {
  #layout { flex-direction: column; }
  #sidebar { width: 100%; flex: none; display: flex; overflow-x: auto; padding: 10px 8px; border-right: none; border-bottom: 1px solid var(--atp-border); }
  .nav-group { margin: 0 10px; display: flex; align-items: center; }
  .nav-group .label { display: none; }
  .nav-item { border-left: none; border-bottom: 2px solid transparent; padding: 9px 12px; white-space: nowrap; }
  .nav-item.active { border-bottom-color: var(--atp-gold); }
  .sidebar-cta { display: none; }
  .two-col { grid-template-columns: 1fr; }
  #main { padding: 22px 16px 60px; }
  .brand-name { display: none; }
}

/* =====================================================
   ROUNDED CONTROLS (buttons + pills only - cards stay sharp)
   ===================================================== */
.btn-gold, .btn-ghost, .btn-tour, .tour-btn, #login-btn { border-radius: 999px; }
.chip, .row-ai, .demo-badge, .status, .kind-tag, .sla-chip { border-radius: 999px; }
.ai-btn { border-radius: 12px; }
.ai-btn .ic { border-radius: 8px; }
select#persona { border-radius: 8px; }

/* =====================================================
   BRAND THEMES - same dashboard, reskinned per client
   ===================================================== */
body, #brandbar, #sidebar, .card, .kpi, .pipe-stage, .person, .modal, #toast, .login-card {
  transition: background-color .35s ease, border-color .35s ease, color .35s ease;
}

/* - Arctic (light) - */
body[data-theme='arctic'] {
  --atp-black: #F2F4F8; --atp-charcoal: #FFFFFF; --atp-gray-dark: #D8DCE4;
  --atp-gray-light: #3D4451; --atp-white: #12151C;
  --atp-gold: #1F5EDD; --atp-gold-bright: #3B78F2; --atp-gold-dark: #1747A8;
  --accent-rgb: 31, 94, 221;
  --atp-text-body: #3D4451; --atp-text-muted: #7A8291; --atp-border: #DFE3EA;
}
body.light #brandbar { background: rgba(255,255,255,.9); }
body.light #sidebar { background: rgba(255,255,255,.65); }
body.light .card, body.light .kpi { box-shadow: 0 4px 18px rgba(16,24,40,.06); }
body.light .modal { box-shadow: 0 10px 50px rgba(16,24,40,.18); }
body.light h2, body.light h3, body.light h4 { text-transform: none; letter-spacing: .4px; }
body.light .st-ok { color: #22703C; border-color: #A9D4B6; background: rgba(46,125,70,.08); }
body.light .st-warn { color: #8A6410; border-color: #E3C98A; background: rgba(196,148,26,.1); }
body.light .st-bad { color: #A93A20; border-color: #E5B0A2; background: rgba(180,85,63,.09); }
body.light .st-neutral { color: #4A5160; border-color: #C9CDD6; background: rgba(16,24,40,.04); }
body.light .sla-red { color: #A93A20; border-color: #E5B0A2; }
body.light .sla-amber { color: #8A6410; border-color: #E3C98A; }
body.light .sla-green { color: #22703C; border-color: #A9D4B6; }
body.light thead th { background: var(--atp-charcoal); }

/* - Emerald - */
body[data-theme='emerald'] {
  --atp-black: #07130D; --atp-charcoal: #0D1F16; --atp-gray-dark: #1C3327;
  --atp-gold: #3FBF8F; --atp-gold-bright: #5CD9A8; --atp-gold-dark: #2A8A66;
  --accent-rgb: 63, 191, 143;
  --atp-text-body: #A9BFB4; --atp-gray-light: #A9BFB4; --atp-text-muted: #5C7368; --atp-border: #1C3327;
}

/* - Royal - */
body[data-theme='royal'] {
  --atp-black: #0B0E1E; --atp-charcoal: #141830; --atp-gray-dark: #232A4D;
  --atp-gold: #7C8CFF; --atp-gold-bright: #9AA8FF; --atp-gold-dark: #5866CC;
  --accent-rgb: 124, 140, 255;
  --atp-text-body: #AEB6D9; --atp-gray-light: #AEB6D9; --atp-text-muted: #666F99; --atp-border: #232A4D;
}

/* - Ember - */
body[data-theme='ember'] {
  --atp-black: #141416; --atp-charcoal: #1E1F23; --atp-gray-dark: #2E3036;
  --atp-gold: #E8734A; --atp-gold-bright: #FF8A5E; --atp-gold-dark: #B4532F;
  --accent-rgb: 232, 115, 74;
  --atp-text-body: #B9BCC4; --atp-gray-light: #B9BCC4; --atp-text-muted: #6E7178; --atp-border: #2E3036;
}

/* =====================================================
   LAYOUT VARIANTS - each theme organizes a little differently
   ===================================================== */

/* Arctic: KPIs carry a left accent instead of a top bar */
body.layout-left-accent .kpi { border-top: 1px solid var(--atp-border); border-left: 3px solid var(--atp-gold); }
body.layout-left-accent .login-card { border-top: 1px solid var(--atp-border); border-left: 3px solid var(--atp-gold); }

/* Emerald: navigation runs horizontally under the header */
body.layout-topnav #layout { flex-direction: column; }
body.layout-topnav #sidebar {
  width: 100%; flex: none; display: flex; overflow-x: auto;
  padding: 8px 10px; border-right: none; border-bottom: 1px solid var(--atp-border);
}
body.layout-topnav .nav-group { margin: 0 8px; display: flex; align-items: center; }
body.layout-topnav .nav-group .label { display: none; }
body.layout-topnav .nav-item { border-left: none; border-bottom: 2px solid transparent; padding: 9px 14px; white-space: nowrap; }
body.layout-topnav .nav-item.active { border-bottom-color: var(--atp-gold); background: transparent; }
body.layout-topnav .sidebar-cta { display: none; }

/* Royal: soft SaaS - everything rounds off */
body.layout-soft .card, body.layout-soft .kpi, body.layout-soft .pipe-stage,
body.layout-soft .person, body.layout-soft .modal, body.layout-soft .login-card,
body.layout-soft #tour-card, body.layout-soft #toast, body.layout-soft .m-stat,
body.layout-soft .sidebar-cta, body.layout-soft .demo-note { border-radius: 16px; }
body.layout-soft .login-field input, body.layout-soft .search-box, body.layout-soft .m-pitch { border-radius: 10px; }
body.layout-soft .nav-item { border-left: none; margin: 0 10px; border-radius: 999px; padding: 10px 16px; }
body.layout-soft .nav-item.active { background: rgba(var(--accent-rgb), .14); }

/* Ember: compact operator density + striped tables */
body.layout-compact #main { padding: 22px 22px 60px; }
body.layout-compact .card { padding: 18px; }
body.layout-compact .kpi { padding: 12px 16px; }
body.layout-compact .kpi .k-value { font-size: 24px; }
body.layout-compact table { font-size: 12.5px; }
body.layout-compact tbody td { padding: 7px 10px; }
body.layout-compact tbody tr:nth-child(even) { background: rgba(255,255,255,.025); }
body.layout-compact .ai-btn { padding: 11px 12px; }
body.layout-compact .stack > * + * { margin-top: 14px; }
body.layout-compact .two-col { gap: 14px; }

/* =====================================================
   THEME DOCK - tucked bottom-right, expands upward
   ===================================================== */
/* bottom-right belongs to the live GHL chat bubble - the dock lives bottom-left.
   z-index sits BELOW the tour veil (250) and modal overlay (300) so it dims
   and locks while a modal or the guided tour is open. */
#theme-dock { position: fixed; left: 20px; bottom: 18px; z-index: 240; display: flex; flex-direction: column; align-items: center; gap: 10px; }
#dock-toggle {
  width: 32px; height: 32px; border-radius: 999px; cursor: pointer;
  border: 1px solid rgba(255,255,255,.25);
  background: conic-gradient(#C9A84C 0 72deg, #1F5EDD 72deg 144deg, #3FBF8F 144deg 216deg, #7C8CFF 216deg 288deg, #E8734A 288deg 360deg);
  opacity: .35; transition: opacity .3s, transform .3s, box-shadow .3s;
}
#dock-toggle:hover, #theme-dock.open #dock-toggle { opacity: 1; transform: scale(1.08); box-shadow: 0 0 18px rgba(0,0,0,.5); }
body.light #dock-toggle { border-color: rgba(0,0,0,.25); }
#dock-swatches {
  display: flex; flex-direction: column; gap: 9px; align-items: center;
  opacity: 0; pointer-events: none; transform: translateY(10px); transition: all .3s ease;
}
#theme-dock.open #dock-swatches { opacity: 1; pointer-events: auto; transform: none; }
.swatch {
  width: 26px; height: 26px; border-radius: 999px; cursor: pointer;
  border: 2px solid transparent; transition: all .25s; padding: 0;
}
.swatch:hover { transform: scale(1.18); }
.swatch.active { border-color: var(--atp-white); box-shadow: 0 0 12px rgba(var(--accent-rgb), .6); }

/* =====================================================
   THREE-OFFER LAYER: chooser, xp views, chat, embeds
   ===================================================== */
.hidden { display: none !important; }

/* ---------- chooser ---------- */
#chooser {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 60px 20px;
  background-image: radial-gradient(ellipse at 50% 20%, rgba(var(--accent-rgb),0.08), transparent 60%);
}
.chooser-inner { max-width: 1080px; text-align: center; }
.chooser-logo { width: min(300px, 60%); height: auto; margin: 0 auto 26px; display: block; }
.chooser-inner h1 { font-size: clamp(28px, 4.4vw, 52px); letter-spacing: 4px; margin: 14px 0 16px; }
.chooser-sub { max-width: 640px; margin: 0 auto 40px; font-size: 15.5px; }
.chooser-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }
.choice {
  position: relative; text-align: left; cursor: pointer; padding: 30px 28px 26px;
  background: linear-gradient(180deg, rgba(var(--accent-rgb),.1), rgba(var(--accent-rgb),.03));
  border: 1px solid var(--atp-gold-dark); color: var(--atp-text-body);
  font-family: 'Inter', sans-serif; transition: all .3s ease;
  display: flex; flex-direction: column; gap: 10px;
}
.choice:hover { border-color: var(--atp-gold-bright); box-shadow: 0 0 30px var(--atp-gold-glow); transform: translateY(-3px); }
.choice h3 { font-size: 17px; letter-spacing: 2px; }
.choice p { font-size: 13.5px; }
.choice-go {
  font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--atp-gold); margin-top: auto;
}
.choice:hover .choice-go { color: var(--atp-gold-bright); }
.choice-tag {
  position: absolute; top: -11px; right: 18px; background: var(--atp-gold); color: var(--atp-black);
  font-family: 'Montserrat', sans-serif; font-size: 9.5px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 3px 10px; border-radius: 999px;
}
.chooser-links { margin-top: 32px; font-size: 13px; color: var(--atp-text-muted); }
.chooser-links a { margin: 0 4px; }
.chooser-foot { margin-top: 12px; font-size: 12px; color: var(--atp-text-muted); }

/* ---------- xp views ---------- */
.xp { min-height: 100vh; }
.xp-bar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 14px;
  padding: 0 22px; height: 60px;
  background: rgba(10,10,10,.88);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--atp-border);
  transition: background-color .35s ease, border-color .35s ease;
}
body.light .xp-bar { background: rgba(255,255,255,.9); }
.xp-logo { height: 32px; width: auto; display: block; }
.xp-title {
  font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--atp-gold); white-space: nowrap;
}
.xp-cta { margin-left: auto; padding: 10px 20px; font-size: 11px; }
.xp-main { max-width: 1040px; margin: 0 auto; padding: 30px 22px 90px; }
.xp-hero { text-align: center; padding: 48px 10px 42px; }
.xp-hero h1 { font-size: clamp(26px, 3.6vw, 44px); letter-spacing: 3px; margin: 12px 0 18px; }
.xp-hero p { max-width: 680px; margin: 0 auto; font-size: 15.5px; }
.xp-hero-btns { margin-top: 26px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---------- chat demo ---------- */
.chat-box {
  min-height: 300px; max-height: 420px; overflow-y: auto;
  background: var(--atp-black); border: 1px solid var(--atp-border);
  padding: 20px; display: flex; flex-direction: column; gap: 12px;
  scroll-behavior: smooth;
}
.chat-hint { margin: auto; color: var(--atp-text-muted); font-size: 13px; text-align: center; }
.msg { max-width: 82%; padding: 12px 16px; font-size: 14px; line-height: 1.55; border: 1px solid var(--atp-border); color: var(--atp-gray-light); }
.msg.m-user { align-self: flex-end; background: rgba(var(--accent-rgb),.1); border-color: var(--atp-gold-dark); color: var(--atp-white); }
.msg.m-ai { align-self: flex-start; background: var(--atp-charcoal); }
.chat-flip .msg.m-user { align-self: flex-start; background: var(--atp-charcoal); border-color: var(--atp-border); color: var(--atp-gray-light); }
.chat-flip .msg.m-ai { align-self: flex-end; background: rgba(var(--accent-rgb),.1); border-color: var(--atp-gold-dark); color: var(--atp-white); }
.msg .did { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--atp-gold-dark); font-size: 11.5px; color: var(--atp-gold); }
.msg.typing { display: flex; gap: 5px; align-items: center; min-width: 64px; }
.tdot { width: 7px; height: 7px; border-radius: 999px; background: var(--atp-gold); opacity: .4; animation: blink 1.2s infinite; }
.tdot:nth-child(2) { animation-delay: .2s; } .tdot:nth-child(3) { animation-delay: .4s; }
@keyframes blink { 0%,80%,100% { opacity: .25; } 40% { opacity: 1; } }
.qchips { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 14px; }
.qchip {
  font-family: 'Inter', sans-serif; font-size: 12.5px; padding: 8px 15px; cursor: pointer;
  background: transparent; border: 1px solid var(--atp-gold-dark); color: var(--atp-gold);
  border-radius: 999px; transition: all .25s;
}
.qchip:hover { background: var(--atp-gold); color: var(--atp-black); box-shadow: 0 0 14px var(--atp-gold-glow); }

/* ---------- capability grid (owner) ---------- */
.cap-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.cap-btn {
  display: flex; flex-direction: column; gap: 8px; text-align: left; cursor: pointer;
  background: linear-gradient(180deg, rgba(var(--accent-rgb),.1), rgba(var(--accent-rgb),.03));
  border: 1px solid var(--atp-gold-dark); padding: 22px; color: var(--atp-text-body);
  font-family: 'Inter', sans-serif; border-radius: 12px; transition: all .3s ease;
}
.cap-btn:hover { border-color: var(--atp-gold-bright); box-shadow: 0 0 22px var(--atp-gold-glow); transform: translateY(-2px); }
.cap-btn .ic {
  width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--atp-gold); color: var(--atp-gold); font-size: 17px; border-radius: 8px;
}
.cap-title { font-family: 'Montserrat', sans-serif; font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--atp-white); }
.cap-blurb { font-size: 13px; }

/* ---------- channels diagram (customers) ---------- */
.chan-row { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.chan-chip {
  display: flex; align-items: center; gap: 9px; cursor: pointer;
  font-family: 'Montserrat', sans-serif; font-size: 11.5px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--atp-white);
  background: rgba(var(--accent-rgb),.07); border: 1px solid var(--atp-gold-dark);
  padding: 11px 16px; border-radius: 999px; transition: all .25s;
}
.chan-chip .ic { color: var(--atp-gold); font-family: 'Inter', sans-serif; }
.chan-chip:hover { border-color: var(--atp-gold-bright); box-shadow: 0 0 16px var(--atp-gold-glow); }
.converge { text-align: center; color: var(--atp-gold); margin: 14px 0; letter-spacing: 14px; animation: sink 2.2s ease-in-out infinite; }
@keyframes sink { 0%,100% { opacity: .35; transform: translateY(-2px); } 50% { opacity: 1; transform: translateY(2px); } }
.hub {
  text-align: center; font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
  letter-spacing: 2px; text-transform: uppercase; color: var(--atp-black);
  background: var(--atp-gold); padding: 16px 20px;
}
.hub-sub { font-family: 'Inter', sans-serif; font-weight: 500; font-size: 12px; letter-spacing: .3px; text-transform: none; margin-top: 3px; opacity: .8; }
.hub-out { background: transparent; color: var(--atp-white); border: 1px solid var(--atp-gold); }
.hub-out .hub-sub { color: var(--atp-gray-light); }

/* ---------- stepper (customers) ---------- */
.stepper { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; margin-bottom: 14px; }
.step-btn {
  display: flex; align-items: center; gap: 10px; cursor: pointer; text-align: left;
  font-family: 'Montserrat', sans-serif; font-size: 11.5px; font-weight: 600; letter-spacing: 1px;
  text-transform: uppercase; color: var(--atp-gray-light);
  background: var(--atp-charcoal); border: 1px solid var(--atp-border); padding: 14px 16px; transition: all .25s;
}
.step-btn .step-n { font-size: 16px; font-weight: 900; color: var(--atp-text-muted); }
.step-btn.active { border-color: var(--atp-gold); color: var(--atp-white); }
.step-btn.active .step-n { color: var(--atp-gold); }
.step-detail p { font-size: 14.5px; }

/* ---------- live embeds ---------- */
.grid-embeds { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 18px; }
.embed-card iframe { width: 100%; height: 780px; border: 0; background: #fff; margin-top: 14px; }
.embed-card iframe.iframe-form { height: 700px; }
.live-badge {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 12px;
  font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--atp-gold-bright);
  border: 1px solid var(--atp-gold-dark); padding: 5px 12px; border-radius: 999px;
}
.pulse { width: 8px; height: 8px; border-radius: 999px; background: var(--atp-gold-bright); animation: pulse 1.6s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(var(--accent-rgb), .6); } 70% { box-shadow: 0 0 0 9px rgba(var(--accent-rgb), 0); } 100% { box-shadow: 0 0 0 0 rgba(var(--accent-rgb), 0); } }

/* ladder cards clickable */
.xp-link { cursor: pointer; }
.xp-link .choice-go { display: block; margin-top: 10px; }
.xp-link:hover { border-color: var(--atp-gold-bright); }

@media (max-width: 700px) {
  .xp-title { display: none; }
  .xp-main { padding: 20px 14px 70px; }
  .embed-card iframe { height: 640px; }
  /* lift the tour card clear of the GHL chat bubble (right) and theme dock (left) */
  #tour-card { bottom: 110px; }
}

/* light theme: the shimmer's near-white glint stop vanishes on white - use a darker glint */
body.light .shimmer {
  background-image: linear-gradient(110deg, var(--atp-gold) 20%, var(--atp-gold-bright) 40%, #6E93EE 50%, var(--atp-gold-bright) 60%, var(--atp-gold) 80%);
}
