/* OutreachHub Reputation AI — brand stylesheet
   Tokens lifted from outreachhub.ai/front/css/style.css so visual fidelity is exact. */

:root {
  --oh-black:        #000000;
  --oh-ink:          #313337;
  --oh-white:        #ffffff;

  --oh-primary:      #7B7FFF;
  --oh-primary-dark: #442499;
  --oh-purple:       #9360FE;
  --oh-pink:         #FE60A8;
  --oh-yellow:       #FECA60;

  --oh-navy:         #000F49;
  --oh-navy-dark:    #010D3D;
  --oh-banner-bg:    #0F0B0C;

  --oh-cream:        #F9F9FF;
  --oh-soft-purple:  #E6DDFF;
  --oh-mist:         #F7F7F7;
  --oh-line:         #ECEEF3;

  --oh-success:      #2C7A3C;
  --oh-danger:       #C0282A;

  --oh-radius-sm: 6px;
  --oh-radius:    8px;
  --oh-radius-lg: 12px;
  --oh-radius-xl: 24px;

  --oh-shadow-sm: 0 1px 2px rgba(15, 11, 12, .04), 0 1px 1px rgba(15, 11, 12, .03);
  --oh-shadow:    0 4px 16px rgba(68, 36, 153, .07);
}

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

html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--oh-ink);
  background: var(--oh-cream);
}

a { color: var(--oh-primary-dark); text-decoration: none; }
a:hover { color: var(--oh-primary); }

h1, h2, h3, h4, h5 { color: var(--oh-black); font-weight: 600; margin: 0; }
h1 { font-size: 28px; }
h2 { font-size: 22px; }
h3 { font-size: 18px; }
h4 { font-size: 16px; }
.eyebrow { font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--oh-purple); font-weight: 600; }

/* ---------- App shell ---------- */
.oh-app { display: grid; grid-template-columns: 260px minmax(0, 1fr); min-height: 100vh; }
.oh-sidebar {
  background: linear-gradient(180deg,#000F49 0%,#010D3D 78%,#12092d 100%);
  color: var(--oh-white);
  position: sticky;
  top: 0;
  height: 100vh;
  max-height: 100vh;
  min-width: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 14px 0 40px rgba(1,13,61,.16);
}
.oh-sidebar .oh-logo { flex: 0 0 auto; padding: 22px 20px 18px; }
.oh-sidebar .oh-logo img { display: block; width: 154px; max-width: 100%; }
.sidebar-account { flex: 0 0 auto; padding: 0 20px 14px; min-width: 0; }
.sidebar-account-label { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.5); }
.sidebar-account-name { margin-top: 2px; color: #fff; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar-account-role, .sidebar-tenant { color: rgba(255,255,255,.66); font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar-tenant { margin-top: 8px; font-size: 11px; color: rgba(255,255,255,.62); }
.sidebar-impersonation { margin-top: 8px; padding: 7px 8px; background: #FE60A8; color: #fff; border-radius: 8px; font-size: 11px; line-height: 1.35; overflow-wrap: anywhere; }
.sidebar-impersonation a { color: #fff; text-decoration: underline; }
.oh-sidebar nav { flex: 1 1 auto; min-height: 0; overflow-y: auto; overflow-x: hidden; padding: 4px 0 16px; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.28) transparent; }
.oh-sidebar nav a {
  display: flex; align-items: center; gap: 10px;
  min-height: 38px;
  padding: 9px 18px 9px 20px;
  color: rgba(255, 255, 255, .78);
  border-left: 3px solid transparent;
  font-weight: 500;
  font-size: 13px;
  line-height: 1.25;
  min-width: 0;
  overflow: hidden;
}
.oh-sidebar nav a:hover { color: var(--oh-white); background: rgba(255,255,255,.04); }
.oh-sidebar nav a.active {
  color: var(--oh-white);
  border-left-color: var(--oh-primary);
  background: rgba(123, 127, 255, .12);
}
.oh-sidebar nav a svg { width: 18px; height: 18px; flex-shrink: 0; }
.oh-sidebar nav a .nav-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.nav-section-title{padding:14px 20px 6px;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#FE60A8;color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;flex:0 0 auto}.nav-ai-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;box-shadow:0 0 0 5px rgba(34,197,94,.15);margin-left:auto;flex:0 0 auto}
.sidebar-logout button { width: 100%; min-height: 38px; background: none; border: 0; color: rgba(255,255,255,.72); padding: 9px 18px 9px 23px; cursor: pointer; font: inherit; font-size: 13px; text-align: left; }
.sidebar-logout button:hover { color: #fff; background: rgba(255,255,255,.04); }

.oh-main { padding: 24px 32px 64px; min-width: 0; max-width: 100%; overflow-x: hidden; }

.oh-topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.oh-topbar .crumbs { color: var(--oh-ink); font-size: 13px; }
.oh-topbar .actions { display: flex; gap: 8px; }
.oh-topbar,.oh-card,.oh-panel,.oh-kpi,.benchmark-card,.analytics-card,.feed-card,.ticket-card,.campaign-row,.campaign-run-card{min-width:0}
.oh-topbar h1,.oh-card h3,.oh-panel h3,.benchmark-card h3,.analytics-card h3{overflow-wrap:anywhere}
.oh-panel.pad{padding:18px;overflow-x:auto}

/* ---------- Cards ---------- */
.oh-card { background: var(--oh-white); border: 1px solid var(--oh-line); border-radius: var(--oh-radius-lg); box-shadow: var(--oh-shadow-sm); }
.oh-card.pad { padding: 20px; }
.oh-card + .oh-card { margin-top: 16px; }

.oh-grid { display: grid; gap: 16px; }
.oh-grid.kpis { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.oh-kpi { background: var(--oh-white); border: 1px solid var(--oh-line); border-radius: var(--oh-radius-lg); padding: 18px 20px; }
.oh-kpi .label { font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--oh-ink); opacity: .7; }
.oh-kpi .value { font-size: 28px; font-weight: 600; color: var(--oh-black); margin-top: 6px; }
.oh-kpi .delta  { font-size: 12px; color: var(--oh-success); margin-top: 4px; }
.oh-kpi.warn .value { color: var(--oh-danger); }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 16px; border-radius: var(--oh-radius); font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; border: 1px solid transparent; transition: background .15s, color .15s, border-color .15s; }
.btn-primary { background: var(--oh-primary); color: var(--oh-white); }
.btn-primary:hover { background: var(--oh-primary-dark); }
.btn-secondary { background: transparent; color: var(--oh-primary-dark); border-color: var(--oh-primary); }
.btn-secondary:hover { background: rgba(123,127,255,.08); }
.btn-ghost { background: transparent; color: var(--oh-ink); }
.btn-ghost:hover { background: var(--oh-line); }
.btn-danger { background: var(--oh-danger); color: var(--oh-white); }
.btn-danger:hover { background: #9C2022; }
.btn-sm { height: 32px; padding: 0 12px; font-size: 13px; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---------- Forms ---------- */
.oh-field { display: block; margin-bottom: 12px; }
.oh-field label { display: block; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--oh-ink); margin-bottom: 6px; }
.oh-input, .oh-select, .oh-textarea {
  width: 100%; padding: 10px 12px; font: inherit;
  border: 1px solid var(--oh-line); border-radius: var(--oh-radius);
  background: var(--oh-white); color: var(--oh-black);
  transition: border-color .15s, box-shadow .15s;
}
.oh-input:focus, .oh-select:focus, .oh-textarea:focus {
  outline: 0; border-color: var(--oh-primary);
  box-shadow: 0 0 0 3px rgba(123, 127, 255, .18);
}
.oh-row { display: grid; gap: 12px; grid-template-columns: 1fr 1fr; }
.oh-row.three { grid-template-columns: 1fr 1fr 1fr; }
.error { color: var(--oh-danger); font-size: 12px; margin-top: 4px; }
.checkbox-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 8px; }
.check-tile { display: flex; align-items: center; gap: 8px; min-height: 38px; padding: 8px 10px; border: 1px solid var(--oh-line); border-radius: var(--oh-radius); background: #fff; font-weight: 600; color: var(--oh-ink); }
.check-tile input { width: 16px; height: 16px; accent-color: var(--oh-primary); }

.template-command { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 16px; }
.template-variable-row { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.template-editor-card { margin-bottom: 14px; }
.template-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 12px; }
.editor-toolbar { display: flex; flex-wrap: wrap; gap: 6px; padding: 8px; border: 1px solid var(--oh-line); border-bottom: 0; border-radius: var(--oh-radius) var(--oh-radius) 0 0; background: var(--oh-mist); }
.editor-command, .editor-link-btn, .editor-upload { height: 30px; min-width: 34px; display: inline-flex; align-items: center; justify-content: center; padding: 0 9px; border: 1px solid var(--oh-line); border-radius: var(--oh-radius-sm); background: #fff; color: var(--oh-ink); font: inherit; font-size: 12px; font-weight: 700; cursor: pointer; }
.editor-upload input { display: none; }
.rich-template-editor { min-height: 180px; padding: 14px; border: 1px solid var(--oh-line); border-radius: 0 0 var(--oh-radius) var(--oh-radius); background: #fff; color: var(--oh-black); outline: 0; }
.rich-template-editor:focus { border-color: var(--oh-primary); box-shadow: 0 0 0 3px rgba(123, 127, 255, .18); }
.rich-template-editor img { max-width: 100%; height: auto; border-radius: var(--oh-radius); display: block; margin: 10px 0; }
.ai-recommendations { margin-top: 12px; display: grid; gap: 8px; }
.recommendation { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--oh-line); border-radius: var(--oh-radius); background: var(--oh-cream); }
.recommendation p { margin: 4px 0 0; color: var(--oh-ink); font-size: 12px; }
.provider-catalog { display: grid; gap: 16px; }
.provider-catalog .oh-table{min-width:820px}
.oh-grid[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important}
.oh-grid[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))!important}
.campaign-console { margin-bottom: 16px; }
.campaign-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 16px; }
.campaign-head p { margin: 6px 0 0; max-width: 820px; }
.campaign-form { display: grid; gap: 12px; }
.campaign-form.compact { gap: 10px; }
.campaign-stop-rule { max-width: 520px; }
.campaign-steps { display: grid; gap: 10px; }
.campaign-step {
  display: grid;
  grid-template-columns: 36px minmax(110px,.8fr) minmax(110px,.7fr) minmax(180px,1.4fr) minmax(150px,1fr) 96px;
  align-items: end;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--oh-line);
  border-radius: var(--oh-radius);
  background: #fff;
}
.campaign-step.compact { grid-template-columns: 32px minmax(92px,.8fr) minmax(86px,.6fr) minmax(150px,1.2fr) minmax(130px,1fr) 88px; padding: 10px; }
.step-number { width: 30px; height: 30px; display: grid; place-items: center; border-radius: var(--oh-radius-sm); background: var(--oh-cream); color: var(--oh-primary-dark); font-weight: 800; align-self: center; }
.step-active { min-height: 40px; margin-bottom: 12px; }
.campaign-list { display: grid; gap: 12px; }
.campaign-row { border: 1px solid var(--oh-line); border-radius: var(--oh-radius-lg); background: #fff; padding: 16px; }
.campaign-row,.campaign-step,.campaign-run-box{min-width:0;overflow-wrap:anywhere}
.campaign-row-main { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.campaign-title { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.campaign-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.campaign-actions form { margin: 0; }
.campaign-report-grid { display: grid; grid-template-columns: repeat(6, minmax(90px, 1fr)); gap: 8px; margin-top: 14px; }
.campaign-report-grid div { border: 1px solid var(--oh-line); border-radius: var(--oh-radius); padding: 10px; background: var(--oh-cream); }
.campaign-report-grid span { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--oh-ink); opacity: .66; }
.campaign-report-grid strong { display: block; margin-top: 2px; font-size: 18px; color: var(--oh-black); }
.campaign-step-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.campaign-detail { margin-top: 12px; border-top: 1px solid var(--oh-line); padding-top: 12px; }
.campaign-detail summary { cursor: pointer; font-weight: 700; color: var(--oh-primary-dark); }
.campaign-detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 14px; margin-top: 12px; align-items: start; }
.campaign-run-box { border: 1px solid var(--oh-line); border-radius: var(--oh-radius); padding: 12px; background: var(--oh-cream); }
.campaign-run-box h4 { margin-bottom: 10px; }
.request-pick-list { display: grid; gap: 6px; max-height: 180px; overflow: auto; margin: 8px 0 12px; font-size: 12px; }
.request-pick-list label { display: flex; gap: 6px; align-items: flex-start; }

.survey-product-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.85fr);gap:16px;align-items:start}
.survey-builder-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.survey-builder-form .survey-wide{grid-column:1 / -1}
.survey-list{display:grid;gap:12px}
.survey-card{border:1px solid var(--oh-line);border-radius:var(--oh-radius-lg);background:#fff;padding:14px;box-shadow:var(--oh-shadow-sm);overflow-wrap:anywhere}
.survey-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.survey-distribution-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.survey-distribution-grid div{display:grid;gap:4px;border:1px solid var(--oh-line);border-radius:var(--oh-radius);padding:10px;background:var(--oh-cream)}
.survey-distribution-grid span{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgba(49,51,55,.68)}
.survey-distribution-grid code{font-size:12px;white-space:normal;overflow-wrap:anywhere;color:var(--oh-primary-dark)}
.survey-public-body{display:block;min-height:100vh;background:radial-gradient(circle at 20% 0%,rgba(123,127,255,.18),transparent 32%),linear-gradient(180deg,#f8f9ff,#eef3ff);font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;color:var(--oh-ink)}
.survey-public-wrap{width:min(920px,calc(100% - 32px));margin:0 auto;padding:28px 0 42px}
.survey-public-brand{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px;color:#64748b;font-weight:800}
.survey-public-brand img{width:190px;max-width:56vw;height:auto}
.survey-public-shell{overflow:hidden;min-height:calc(100vh - 132px);border:1px solid rgba(221,228,239,.92);border-radius:32px;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.96));box-shadow:0 28px 80px rgba(7,21,63,.10)}
.typeform-progress{height:6px;background:#edf2ff}.typeform-progress span{display:block;height:100%;border-radius:0 999px 999px 0;background:linear-gradient(90deg,var(--oh-primary),var(--oh-pink));transition:width .18s ease}
.survey-public-step{display:none;min-height:calc(100vh - 238px);padding:clamp(26px,6vw,78px)}.survey-public-step.active{display:grid;align-items:center}
.survey-public-question{width:min(760px,100%);margin:0 auto}.survey-public-question>span{color:var(--oh-purple);font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.survey-public-question h1{margin-top:18px;font-size:clamp(34px,5vw,58px);line-height:1.02;font-weight:800;color:#0f172a}.survey-public-question p{max-width:660px;color:#64748b;font-size:17px;line-height:1.6}.survey-rich{margin-top:16px;border:1px solid var(--oh-line);border-radius:16px;padding:12px;background:#fff}
.nps-scale,.choice-stack{display:grid;gap:10px;margin-top:24px}.nps-scale{grid-template-columns:repeat(11,minmax(40px,1fr))}.nps-scale label,.choice-stack label{cursor:pointer}.nps-scale input,.choice-stack input{position:absolute;opacity:0;pointer-events:none}.nps-scale span,.choice-stack span{display:flex;align-items:center;min-height:54px;border:1px solid #d7e0ef;border-radius:16px;background:#fff;box-shadow:0 12px 30px rgba(7,21,63,.06);font-weight:800;color:#0f172a}.nps-scale span{justify-content:center}.choice-stack span{padding:0 16px}.nps-scale input:checked+span,.choice-stack input:checked+span{border-color:var(--oh-primary);background:rgba(123,127,255,.12);box-shadow:0 18px 44px rgba(123,127,255,.18)}
.survey-public-textarea{margin-top:24px;min-height:180px;font-size:17px}
.survey-public-footer{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:18px 24px;border-top:1px solid var(--oh-line);background:rgba(255,255,255,.88)}.survey-public-footer span{text-align:center;color:#64748b;font-size:13px;font-weight:800}.survey-thanks{display:grid;place-items:center;padding:clamp(28px,6vw,80px);text-align:left}

/* ---------- Tables ---------- */
table.oh-table { width: 100%; min-width: 720px; border-collapse: collapse; background: var(--oh-white); border-radius: var(--oh-radius-lg); overflow: hidden; border: 1px solid var(--oh-line); }
.oh-table th, .oh-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--oh-line); font-size: 13px; }
.oh-table th { background: var(--oh-mist); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--oh-ink); font-weight: 600; }
.oh-table tr:last-child td { border-bottom: 0; }
.oh-table tr:hover td { background: var(--oh-cream); }
.oh-table td{vertical-align:top;overflow-wrap:anywhere}.oh-table code{white-space:normal;overflow-wrap:anywhere}.oh-table-wrap,.table-scroll{width:100%;overflow-x:auto;border-radius:var(--oh-radius-lg)}
.oh-table-empty { padding: 32px; text-align: center; color: var(--oh-ink); opacity: .6; font-style: italic; }

/* ---------- Pills ---------- */
.pill { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.pill.queued, .pill.sent           { background: #E6F0FB; color: var(--oh-primary-dark); }
.pill.clicked, .pill.opened         { background: #E9F5EC; color: var(--oh-success); }
.pill.feedback_submitted,
.pill.public_review_link_clicked    { background: #D8EFE0; color: var(--oh-success); }
.pill.failed, .pill.cancelled,
.pill.high, .pill.critical, .pill.open { background: #FCE4E4; color: var(--oh-danger); }
.pill.medium                        { background: #FFF4D6; color: #8A6300; }
.pill.low                           { background: #ECEEF3; color: var(--oh-ink); }
.pill.resolved, .pill.dismissed,
.pill.assigned                      { background: #ECECEC; color: var(--oh-ink); }
.pill.success                       { background: #D8EFE0; color: var(--oh-success); }

/* ---------- Stars ---------- */
.stars-display { display: inline-flex; gap: 2px; color: var(--oh-yellow); }
.stars-display .empty { color: #D8D8E0; }

/* ---------- Public landing ---------- */
.oh-public-shell {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(circle at 25% 30%, rgba(254, 96, 168, .25) 0%, transparent 55%),
    radial-gradient(circle at 75% 75%, rgba(147, 96, 254, .35) 0%, transparent 55%),
    var(--oh-banner-bg);
  padding: 40px 16px;
}
.oh-public-card {
  background: var(--oh-white);
  border-radius: var(--oh-radius-xl);
  padding: 40px 32px;
  width: 100%; max-width: 520px;
  box-shadow: 0 24px 60px rgba(15, 11, 12, .35);
}
.oh-public-logo { display: block; height: 40px; margin: 0 auto 20px; }
.oh-public-card h1 { text-align: center; color: var(--oh-primary-dark); font-size: 24px; margin-bottom: 8px; }
.oh-public-card .lede { text-align: center; color: var(--oh-ink); margin-bottom: 28px; }

.rating-radiogroup { display: flex; gap: 8px; justify-content: center; margin: 20px 0 24px; }
.rating-radiogroup button {
  background: transparent; border: 0; cursor: pointer;
  font-size: 44px; color: #D8D8E0; padding: 4px;
  transition: transform .12s, color .12s;
}
.rating-radiogroup button:hover { transform: scale(1.08); }
.rating-radiogroup button.on { color: var(--oh-yellow); }
.rating-radiogroup button:focus-visible { outline: 2px solid var(--oh-primary); outline-offset: 2px; border-radius: 4px; }

.oh-public-cta {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 12px 20px; border-radius: 999px;
  background: var(--oh-primary); color: var(--oh-white);
  font-weight: 600; font-size: 14px;
  border: 0;
}
.oh-public-cta:hover { background: var(--oh-primary-dark); }
.oh-public-cta .arrow {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--oh-white); color: var(--oh-primary-dark);
  display: inline-flex; align-items: center; justify-content: center;
  transform: rotate(-45deg); font-size: 16px;
}

.oh-recovery-note {
  background: rgba(254, 96, 168, .1);
  border: 1px solid rgba(254, 96, 168, .35);
  color: var(--oh-ink);
  border-radius: var(--oh-radius);
  padding: 12px 14px;
  font-size: 13px;
  margin-bottom: 16px;
}

/* ---------- Misc ---------- */
.muted { color: var(--oh-ink); opacity: .7; }
.skip-link{position:absolute;left:12px;top:-48px;z-index:9999;background:#111827;color:#fff;padding:10px 14px;border-radius:10px;font-weight:800;transition:top .15s ease}
.skip-link:focus{top:12px;outline:3px solid #FECA60;outline-offset:2px}
.legal-footer{margin-top:24px;border-top:1px solid rgba(226,232,240,.95);padding:18px 0 0;color:#475569;font-size:12px;line-height:1.5}
.legal-footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.legal-footer strong,.legal-footer span{display:block}
.legal-footer nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.legal-footer a{color:#442499;font-weight:800;text-decoration:none}
.legal-footer a:hover,.legal-footer a:focus{text-decoration:underline}
.legal-footer p{margin:10px 0 0;color:#64748b}
.legal-page{min-height:100vh;padding:32px 16px;background:#f8f9ff}
.legal-document{max-width:880px;margin:0 auto;background:#fff;border:1px solid var(--oh-line);border-radius:18px;box-shadow:var(--oh-shadow);padding:28px}
.legal-document h1{font-size:34px;line-height:1.12;margin:6px 0}
.legal-copy{display:grid;gap:14px;margin-top:18px}
.legal-copy h2{font-size:18px;margin:6px 0 0;color:#0f172a}
.legal-copy p,.legal-copy li{color:#334155;line-height:1.65}
.legal-copy ul{margin:0;padding-left:22px}
.row-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; gap: 12px; flex-wrap: wrap; }
.text-right { text-align: right; }
.flex { display: flex; }
.gap-8 { gap: 8px; } .gap-12 { gap: 12px; } .gap-16 { gap: 16px; }
.mt-8 { margin-top: 8px; } .mt-16 { margin-top: 16px; }

@media (max-width: 900px) {
  .oh-app { grid-template-columns: 1fr; }
  .oh-sidebar { position: relative; height: auto; max-height: none; overflow: visible; }
  .oh-sidebar nav { max-height: none; overflow: visible; }
  .oh-row, .oh-row.three { grid-template-columns: 1fr; }
}

@media (max-width:760px){.legal-footer-inner{display:block}.legal-footer nav{justify-content:flex-start;margin-top:10px}.legal-document{padding:20px}.legal-document h1{font-size:28px}}


/* ===== V3 Premium SaaS UI: preserves original onboarding + role model ===== */
:root{
  --oh-blue:#0ea5e9;--oh-teal:#14b8a6;--oh-green:#22c55e;--oh-amber:#f59e0b;--oh-red:#ef4444;--oh-violet:#7c3aed;--oh-slate:#64748b;--oh-deep:#020617;
  --oh-grad-primary:linear-gradient(135deg,#7B7FFF 0%,#9360FE 52%,#FE60A8 100%);
  --oh-grad-blue:linear-gradient(135deg,#0ea5e9 0%,#7c3aed 100%);
  --oh-grad-success:linear-gradient(135deg,#22c55e 0%,#14b8a6 100%);
  --oh-card-glass:rgba(255,255,255,.84);
}
body{background:radial-gradient(circle at 20% 0%,rgba(123,127,255,.16),transparent 28%),radial-gradient(circle at 85% 12%,rgba(254,96,168,.12),transparent 34%),#f8f9ff;}
.oh-main{background:transparent}.oh-topbar{background:rgba(255,255,255,.72);border:1px solid rgba(236,238,243,.8);box-shadow:0 10px 32px rgba(68,36,153,.06);border-radius:22px;padding:18px 20px;backdrop-filter:blur(14px)}
.oh-panel{background:var(--oh-card-glass);border:1px solid rgba(236,238,243,.84);border-radius:24px;box-shadow:0 12px 36px rgba(68,36,153,.08);backdrop-filter:blur(16px)}
.oh-card,.oh-kpi{border-radius:22px;box-shadow:0 12px 36px rgba(68,36,153,.07);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.oh-card:hover,.oh-kpi:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(68,36,153,.11);border-color:rgba(123,127,255,.26)}
.kpi-premium{position:relative;overflow:hidden;padding:18px 18px 16px}.kpi-premium:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(123,127,255,.10),rgba(254,96,168,.04));pointer-events:none}.kpi-premium>*{position:relative}.kpi-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.kpi-icon{width:42px;height:42px;border-radius:15px;background:var(--oh-grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;box-shadow:0 10px 24px rgba(123,127,255,.25)}.kpi-spark{height:34px;margin-top:10px}.trend-up{color:var(--oh-green);font-weight:700}.trend-down{color:var(--oh-red);font-weight:700}.trend-flat{color:var(--oh-slate);font-weight:700}
.ai-banner{background:linear-gradient(135deg,rgba(123,127,255,.12),rgba(254,96,168,.10));border:1px solid rgba(123,127,255,.24);border-radius:24px;padding:18px 20px;display:flex;align-items:flex-start;gap:14px}.ai-orb{width:42px;height:42px;border-radius:18px;background:var(--oh-grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 0 0 8px rgba(123,127,255,.09)}
.analytics-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:16px}.analytics-grid.three{grid-template-columns:1.1fr .9fr .9fr}.chart-card{min-height:260px}.trend-bars{display:flex;align-items:end;gap:10px;min-height:210px;overflow-x:auto;padding:10px 0 0}.trend-bar{min-width:48px;height:180px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px}.trend-bar-fill{display:block;min-height:8px;border-radius:8px 8px 2px 2px;background:var(--oh-grad-primary)}.trend-bar small{font-size:11px;line-height:1.25;color:#64748b}.mini-bar{height:9px;border-radius:999px;background:#edf2ff;overflow:hidden}.mini-bar span{display:block;height:100%;border-radius:inherit;background:var(--oh-grad-primary)}
.score-ring{width:126px;height:126px;border-radius:50%;background:conic-gradient(#22c55e 0 78%,#eef2ff 78% 100%);display:grid;place-items:center}.score-ring>div{width:92px;height:92px;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center;box-shadow:inset 0 0 0 1px #eef2ff}.score-ring b{font-size:30px;color:#000}
.feed-card{display:grid;grid-template-columns:48px 1fr auto;gap:14px;padding:16px;border:1px solid var(--oh-line);border-radius:18px;background:#fff}.avatar{width:48px;height:48px;border-radius:16px;background:var(--oh-grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;background:#f1f5f9;color:#475569}.tag.ai{background:#ede9fe;color:#6d28d9}.tag.good{background:#dcfce7;color:#15803d}.tag.bad{background:#fee2e2;color:#b91c1c}.tag.warn{background:#fef3c7;color:#92400e}
.workflow-canvas{display:flex;align-items:center;gap:12px;overflow-x:auto;padding:18px;border-radius:22px;background:linear-gradient(180deg,#fff,#f8faff);border:1px solid var(--oh-line)}.flow-node{min-width:156px;border:1px solid #e7e8ff;border-radius:18px;background:#fff;padding:14px;box-shadow:0 8px 24px rgba(68,36,153,.07)}.flow-arrow{font-size:24px;color:#9360FE}.flow-node .type{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9360FE;font-weight:800}.flow-node .name{font-weight:800;color:#0f172a;margin-top:4px}.flow-node .meta{font-size:12px;color:#64748b;margin-top:4px}
.pipeline{display:grid;grid-template-columns:repeat(5,minmax(180px,1fr));gap:12px;overflow-x:auto}.pipe-col{background:#f8faff;border:1px solid var(--oh-line);border-radius:20px;padding:12px;min-height:220px}.pipe-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:#475569;margin-bottom:10px}.ticket-card{background:#fff;border:1px solid #eef2ff;border-radius:16px;padding:12px;margin-bottom:10px;box-shadow:0 7px 18px rgba(68,36,153,.05)}
.onboard-shell{display:grid;grid-template-columns:300px 1fr;gap:22px}.onboard-steps{position:sticky;top:24px;align-self:start}.step-item{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:16px;color:#475569}.step-item.active{background:linear-gradient(135deg,rgba(123,127,255,.12),rgba(254,96,168,.08));color:#111827}.step-num{width:28px;height:28px;border-radius:10px;background:#eef2ff;color:#442499;display:grid;place-items:center;font-weight:800}.step-item.done .step-num{background:#dcfce7;color:#15803d}.step-copy b{display:block;color:#111827}.step-copy span{font-size:12px;color:#64748b}
.form-panel{padding:24px}.quick-actions{display:flex;flex-wrap:wrap;gap:8px}.metric-list{display:grid;gap:10px}.metric-line{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--oh-line)}.metric-line:last-child{border-bottom:0}
.analytics-workspace{display:grid;gap:14px}.analytics-hero-card{display:flex;justify-content:space-between;align-items:stretch;gap:18px;padding:18px 20px;border:1px solid rgba(226,232,240,.95);border-radius:20px;background:linear-gradient(135deg,#fff 0%,#f8faff 100%);box-shadow:0 10px 30px rgba(68,36,153,.06)}.analytics-hero-card h2{margin:4px 0;font-size:24px}.analytics-hero-card p{margin:0;color:#64748b;line-height:1.5;max-width:760px}.analytics-score-badge{min-width:150px;border:1px solid #e7e8ff;border-radius:16px;background:#fff;padding:14px;display:grid;place-items:center;text-align:center}.analytics-score-badge span,.analytics-score-badge em{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-style:normal;font-weight:800}.analytics-score-badge strong{font-size:36px;line-height:1;color:#0f172a}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.analytics-widget,.analytics-card{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:16px;padding:14px;box-shadow:0 8px 24px rgba(68,36,153,.06)}.analytics-widget{display:grid;gap:8px;min-height:126px}.analytics-widget span,.event-card span{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}.analytics-widget strong{font-size:30px;line-height:1;color:#0f172a}.analytics-widget em,.event-card em{font-size:12px;color:#64748b;font-style:normal}.progress-track{height:8px;border-radius:999px;background:#eef2ff;overflow:hidden}.progress-track i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7B7FFF,#14b8a6)}.progress-track.amber i{background:linear-gradient(90deg,#f59e0b,#FECA60)}.progress-track.danger i{background:linear-gradient(90deg,#ef4444,#FE60A8)}.progress-track.success i{background:linear-gradient(90deg,#22c55e,#14b8a6)}.analytics-layout{display:grid;grid-template-columns:minmax(360px,1.15fr) minmax(280px,.7fr) minmax(300px,.8fr);gap:12px}.score-history-card{min-height:340px}.score-chart{height:250px;display:flex;align-items:end;gap:10px;overflow-x:auto;padding:12px 2px 0}.score-point{min-width:48px;height:220px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px}.score-point .trend-bar-fill{display:block;min-height:8px;border-radius:8px 8px 2px 2px;background:linear-gradient(180deg,#7B7FFF,#14b8a6)}.score-point small{font-size:11px;color:#64748b;line-height:1.25}.score-point b{display:block;color:#111827}.empty-state-card{min-height:180px;display:grid;place-content:center;text-align:center;gap:5px;border:1px dashed #dbe3f0;border-radius:14px;background:#fbfcff;color:#64748b;padding:18px}.empty-state-card strong{color:#111827}.empty-state-card.compact{min-height:112px}.recommendation-card{display:grid;justify-items:center;text-align:center}.velocity-ring{width:150px;height:150px;border-radius:50%;display:grid;place-items:center;margin:10px auto}.velocity-ring>div{width:106px;height:106px;border-radius:50%;background:#fff;display:grid;place-content:center;border:1px solid #eef2ff}.velocity-ring strong{font-size:28px;color:#0f172a}.velocity-ring span{font-size:12px;color:#64748b}.analytics-note{color:#64748b;line-height:1.5;margin:0;max-width:360px}.platform-list{display:grid;gap:10px}.platform-row{display:grid;grid-template-columns:1fr auto;gap:7px;align-items:center}.platform-row div:first-child{min-width:0}.platform-row strong,.platform-row span{display:block}.platform-row span{color:#64748b;font-size:12px}.platform-row em{font-style:normal;font-weight:800;color:#111827}.platform-row .progress-track{grid-column:1/-1}.event-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.event-card{display:grid;gap:7px;border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:12px}.event-card strong{font-size:26px;color:#111827}
.smart-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:12px}.smart-card{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:16px;padding:14px;box-shadow:0 8px 24px rgba(68,36,153,.06);display:grid;gap:12px;min-width:0}.smart-card h3{font-size:16px}.smart-card p{overflow-wrap:anywhere}.smart-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.smart-metrics div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px;min-width:0}.smart-metrics span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}.smart-metrics strong{display:block;margin-top:3px;color:#0f172a;overflow-wrap:anywhere}.code-block{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;color:#334155;overflow-wrap:anywhere;white-space:normal}.compact-table-wrap{overflow-x:auto;border:1px solid #eef2ff;border-radius:12px}.compact-table{width:100%;border-collapse:collapse;font-size:13px;background:#fff}.compact-table th,.compact-table td{padding:10px 12px;border-bottom:1px solid #eef2ff;text-align:left;vertical-align:top}.compact-table th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;background:#f8faff}.compact-table tr:last-child td{border-bottom:0}.compact-table td{color:#334155;overflow-wrap:anywhere}
.sources-workspace{display:grid;gap:12px}.sources-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,320px);align-items:end;gap:14px;padding:16px 18px;border:1px solid rgba(226,232,240,.95);border-radius:18px;background:#fff;box-shadow:0 8px 24px rgba(68,36,153,.06)}.sources-header h2{margin:2px 0 3px;font-size:22px}.sources-header p{margin:0;color:#64748b;max-width:760px;line-height:1.45}.source-filter{display:grid;gap:6px}.source-filter label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:#64748b}.source-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.source-kpis .analytics-widget{min-height:104px;padding:12px}.source-kpis .analytics-widget strong{font-size:26px}.sources-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:12px;align-items:start}.source-recommendations{display:grid;gap:10px;max-height:680px;overflow:auto;padding-right:3px;scrollbar-width:thin}.source-group-card{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:16px;padding:13px;box-shadow:0 8px 22px rgba(68,36,153,.05);min-width:0}.source-revenue-card{background:linear-gradient(135deg,#fff,#f8faff)}.source-group-card .card-head{margin-bottom:9px}.source-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:8px}.source-card{display:grid;gap:8px;min-height:100px;border:1px solid #eef2ff;border-radius:12px;background:linear-gradient(180deg,#fff,#fbfcff);padding:10px;min-width:0}.source-card strong{display:block;color:#0f172a;font-size:13px;line-height:1.25;overflow-wrap:anywhere}.source-card span{display:block;color:#64748b;font-size:12px;line-height:1.35;overflow-wrap:anywhere}.source-card-foot{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin-top:auto}.source-side{position:sticky;top:72px}.source-form{gap:8px}.source-form label{font-size:10px}.source-form .oh-input,.source-form .oh-select,.source-form .oh-textarea{min-height:34px;padding:7px 9px}.source-form .oh-textarea{resize:vertical}.source-approval{align-items:flex-start;text-transform:none;letter-spacing:0;font-size:12px;color:#334155}.sources-tabs{display:grid;gap:10px}.sources-tabs .benchmark-tabs{position:relative;top:auto}.sources-tabs .smart-card-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.sources-tabs .smart-card{padding:12px}.sources-tabs form{margin:0}
.seo-workspace{display:grid;gap:12px}.seo-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,320px);gap:14px;align-items:end;padding:16px 18px;border:1px solid rgba(226,232,240,.95);border-radius:18px;background:#fff;box-shadow:0 8px 24px rgba(68,36,153,.06)}.seo-hero h2{margin:2px 0 4px;font-size:22px}.seo-hero p{margin:0;color:#64748b;max-width:820px;line-height:1.45}.seo-location-filter{display:grid;gap:6px}.seo-location-filter label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:#64748b}.seo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.seo-grid.pages{grid-template-columns:minmax(320px,.75fr) minmax(320px,1fr)}.seo-score-list{display:grid;gap:11px}.seo-score-list div{min-width:0}.seo-score-list span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}.seo-score-list strong{display:block;color:#0f172a;font-size:22px;margin:2px 0}.seo-public-body{background:var(--lp-surface,#f8f9ff)}.seo-public-page{max-width:1080px;margin:0 auto;padding:34px 18px 80px}.seo-public-hero{padding:32px 0;border-bottom:1px solid rgba(15,23,42,.1)}.seo-public-hero h1{font-size:42px;line-height:1.08;margin:6px 0;max-width:900px}.seo-public-hero p{font-size:17px;color:#475569;max-width:760px}.seo-public-content{display:grid;gap:18px;background:#fff;border:1px solid var(--oh-line);border-radius:18px;margin-top:18px;padding:24px;box-shadow:0 10px 30px rgba(68,36,153,.06)}.seo-public-content h2,.seo-public-content h3{margin:0 0 8px}.seo-public-content p,.seo-public-content li{color:#334155;line-height:1.65}.lp-hero{padding:24px;border-radius:16px;background:linear-gradient(135deg,var(--lp-surface,#f8f9ff),#fff);border:1px solid rgba(15,23,42,.08)}.lp-hero span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--lp-accent,#442499);font-weight:800}.lp-hero h2{font-size:34px;line-height:1.12}.lp-hero a,.lp-conversion a{display:inline-flex;margin-top:12px;min-height:40px;align-items:center;border-radius:10px;background:var(--lp-accent,#442499);color:#fff;padding:0 16px;font-weight:800}.lp-band,.lp-conversion{padding:20px;border-radius:16px;background:#fbfcff;border:1px solid #eef2ff}.lp-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.lp-feature-grid div{border:1px solid #eef2ff;border-radius:12px;padding:12px;background:#fff}.seo-public-content details{border-top:1px solid #eef2ff;padding:12px 0}.seo-public-content summary{cursor:pointer;font-weight:800;color:#0f172a}
.campaign-run-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:12px}.campaign-run-card{display:grid;gap:12px;border:1px solid var(--oh-line);border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 22px rgba(68,36,153,.05)}.campaign-run-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.campaign-report-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.campaign-run-card .quick-actions{display:grid;grid-template-columns:1fr auto;align-items:center}.campaign-run-card .oh-input{height:34px}
.page-stack{display:grid;gap:16px}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.section-head.compact{margin-bottom:8px}.section-head h2,.section-head h3{margin:0 0 4px}.oh-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.oh-form{display:grid;gap:10px}.oh-form label{font-size:12px;font-weight:800;color:#475569;text-transform:uppercase;letter-spacing:.05em}.oh-form input,.oh-form select,.compact-inputs input,.compact-inputs select{width:100%;min-height:38px;border:1px solid var(--oh-line);border-radius:10px;background:#fff;padding:8px 10px;color:#111827}.benchmark-coordinates{display:grid;grid-template-columns:1fr 1fr;gap:10px}.action-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;min-height:26px;border:1px solid #e7e8ff;border-radius:999px;background:#fff;padding:4px 9px;font-size:12px;color:#475569}.benchmark-run{border-top:1px solid var(--oh-line);padding:16px 0}.benchmark-run:first-of-type{border-top:0}.benchmark-run-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.oh-table-wrap{overflow-x:auto}.oh-table.compact-inputs th,.oh-table.compact-inputs td{vertical-align:top}.signal-grid{display:grid;grid-template-columns:repeat(2,minmax(110px,1fr));gap:5px 10px;min-width:240px}.signal-grid label{display:flex;align-items:center;gap:6px;font-size:12px;color:#475569}.signal-grid input{width:auto;min-height:0}.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px}.report-block{border:1px solid var(--oh-line);border-radius:16px;background:#fff;padding:14px}.report-score-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.report-score-row div{border:1px solid #eef2ff;border-radius:12px;padding:10px}.report-score-row span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:800}.report-score-row strong{display:block;font-size:26px;color:#111827}.benchmark-narrative{margin:10px 0 0;color:#334155;line-height:1.55}.positive{color:#15803d!important}.negative{color:#b91c1c!important}.metric-list div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--oh-line);padding:8px 0}.metric-list div:last-child{border-bottom:0}.metric-list strong{color:#111827}.metric-list span{color:#64748b;text-align:right}.opportunity-list{display:grid;gap:8px;margin:12px 0 0;padding:0;list-style:none}.opportunity-list li{border-top:1px solid var(--oh-line);padding-top:8px}.opportunity-list strong,.opportunity-list span,.opportunity-list em{display:block}.opportunity-list span{color:#64748b;font-size:13px;margin-top:3px}.opportunity-list em{color:#334155;font-size:13px;font-style:normal;font-weight:700;margin-top:4px}
.benchmark-workspace{display:grid;gap:14px}.benchmark-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:18px 20px;border:1px solid rgba(236,238,243,.9);border-radius:20px;background:#fff;box-shadow:0 10px 30px rgba(68,36,153,.06)}.benchmark-hero h2{margin:0 0 4px;font-size:24px}.benchmark-hero p{margin:0;color:#64748b;line-height:1.5;max-width:780px}.benchmark-hero-status{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.benchmark-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.benchmark-card{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:16px;padding:14px;box-shadow:0 8px 24px rgba(68,36,153,.06)}.metric-card{min-height:112px;display:flex;flex-direction:column;justify-content:space-between}.metric-card span,.report-mini-grid span,.run-metrics span,.competitor-scoreline span{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}.metric-card strong{font-size:30px;line-height:1;color:#0f172a}.metric-card em{font-size:12px;color:#64748b;font-style:normal}.benchmark-tabs{display:flex;gap:6px;align-items:center;overflow-x:auto;padding:6px;border:1px solid var(--oh-line);border-radius:14px;background:#fff;position:sticky;top:0;z-index:4}.benchmark-tabs button,.benchmark-tab-link{border:0;background:transparent;color:#475569;border-radius:10px;padding:10px 14px;font:inherit;font-size:13px;font-weight:800;cursor:pointer;white-space:nowrap;text-decoration:none}.benchmark-tabs button.active{background:#111827;color:#fff;box-shadow:0 8px 18px rgba(15,23,42,.18)}.benchmark-tab-link{margin-left:auto;border:1px solid #dbe3f0;background:#f8faff}.benchmark-tab-panel{display:none}.benchmark-tab-panel.active{display:block}.benchmark-grid{display:grid;gap:12px}.benchmark-grid.two{grid-template-columns:minmax(360px,.9fr) minmax(320px,.7fr)}.card-grid{display:grid;gap:12px}.runs-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.report-card-grid{grid-template-columns:repeat(auto-fit,minmax(390px,1fr))}.market-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:12px}.market-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.market-toolbar h3{margin:0}.market-toolbar p{margin:4px 0 0;color:#64748b}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.card-head h3{margin:0;font-size:16px}.card-head p{margin:3px 0 0;color:#64748b;font-size:13px;line-height:1.4}.compact-form{gap:9px}.form-grid{display:grid;gap:10px}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:1.15fr .55fr .7fr}.policy-card-list,.compact-opportunities,.opportunity-card-list{display:grid;gap:10px}.policy-card-list div,.compact-opportunities div,.opportunity-card-list div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:11px}.policy-card-list strong,.compact-opportunities strong,.opportunity-card-list strong{display:block;color:#111827}.policy-card-list span,.compact-opportunities span,.opportunity-card-list p{display:block;color:#64748b;font-size:13px;line-height:1.45;margin:4px 0 0}.feature-report{margin-top:12px}.run-card{display:grid;gap:12px}.run-metrics,.competitor-scoreline,.report-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.run-metrics div,.competitor-scoreline div,.report-mini-grid div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px}.run-metrics strong,.competitor-scoreline strong,.report-mini-grid strong{display:block;margin-top:3px;color:#0f172a}.compact-details{border-top:1px solid var(--oh-line);padding-top:10px}.compact-details summary{cursor:pointer;font-weight:800;color:#442499;font-size:13px}.compact-details[open] summary{margin-bottom:10px}.observation-form{display:grid;gap:10px}.observation-card{border:1px solid #eef2ff;border-radius:12px;background:#fbfcff;padding:10px;display:grid;gap:10px}.signal-grid.compact{min-width:0;grid-template-columns:repeat(3,minmax(100px,1fr))}.report-block h3{margin:12px 0 0;font-size:16px}.opportunity-card-list{margin-top:12px}.opportunity-card-list em{display:block;margin-top:6px;color:#334155;font-size:13px;font-style:normal;font-weight:800;line-height:1.4}.competitor-card{display:grid;gap:12px}.signal-scoreline{display:flex;gap:6px;flex-wrap:wrap}.signal-scoreline span{display:inline-flex;padding:5px 8px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:800}.empty-card{color:#64748b;text-align:center;padding:28px}.oh-form input,.oh-form select,.observation-card input,.observation-card select{width:100%;min-height:38px;border:1px solid var(--oh-line);border-radius:10px;background:#fff;padding:8px 10px;color:#111827}.observation-card label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:800;color:#64748b}
@media (max-width:1100px){.analytics-grid,.analytics-grid.three,.analytics-layout,.onboard-shell,.sources-layout,.seo-grid,.seo-grid.pages{grid-template-columns:1fr}.analytics-kpi-grid,.source-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.pipeline{grid-template-columns:repeat(2,minmax(180px,1fr))}.source-side{position:relative;top:auto}.source-recommendations{max-height:none;overflow:visible;padding-right:0}}@media (max-width:760px){.oh-main{padding:16px}.analytics-hero-card,.sources-header,.seo-hero{display:block}.analytics-score-badge{margin-top:12px}.analytics-kpi-grid,.source-kpis{grid-template-columns:1fr}.pipeline{grid-template-columns:1fr}.oh-topbar{display:block}.oh-topbar .actions,.source-filter,.seo-location-filter{margin-top:12px}.feed-card{grid-template-columns:44px 1fr}.feed-card>div:last-child{grid-column:2}.source-card-grid,.sources-tabs .smart-card-grid{grid-template-columns:1fr}.seo-public-hero h1{font-size:30px}.seo-public-content{padding:18px}}
@media (max-width:1100px){.benchmark-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.benchmark-grid.two{grid-template-columns:1fr}.report-card-grid{grid-template-columns:1fr}}@media (max-width:900px){.oh-grid.two{grid-template-columns:1fr}.benchmark-run-top{display:block}.benchmark-run-top .action-row{margin-top:10px}.section-head{display:block}.report-score-row{grid-template-columns:1fr}.benchmark-hero{display:block}.benchmark-hero-status{justify-content:flex-start;margin-top:12px}.runs-grid,.market-card-grid{grid-template-columns:1fr}.form-grid.two,.form-grid.three,.signal-grid.compact{grid-template-columns:1fr}.benchmark-tabs{position:relative}.run-metrics,.competitor-scoreline,.report-mini-grid{grid-template-columns:1fr}}@media (max-width:620px){.benchmark-kpis{grid-template-columns:1fr}.benchmark-card{padding:12px}}
@media (max-width:1100px){.campaign-step,.campaign-step.compact{grid-template-columns:32px 1fr 1fr}.campaign-detail-grid{grid-template-columns:1fr}.campaign-report-grid{grid-template-columns:repeat(3,minmax(90px,1fr))}}@media (max-width:760px){.campaign-head,.campaign-row-main,.market-toolbar{display:block}.campaign-actions{justify-content:flex-start;margin-top:10px}.campaign-step,.campaign-step.compact{grid-template-columns:1fr}.step-number{align-self:start}.campaign-report-grid,.campaign-report-grid.compact{grid-template-columns:repeat(2,minmax(90px,1fr))}.campaign-run-card .quick-actions{grid-template-columns:1fr}.smart-metrics{grid-template-columns:1fr}.smart-card-grid{grid-template-columns:1fr}}

/* Compact global source pattern: no permanent right pane. */
.sources-layout{grid-template-columns:1fr}.source-recommendations{max-height:none;overflow:visible;padding-right:0}.source-side{display:none}.source-command-panel{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:16px;box-shadow:0 8px 24px rgba(68,36,153,.06);overflow:hidden}.source-command-panel summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:58px;padding:12px 14px;cursor:pointer}.source-command-panel summary::-webkit-details-marker{display:none}.source-command-panel summary span{display:grid;gap:3px;min-width:0}.source-command-panel summary strong{color:#0f172a}.source-command-panel summary em{font-style:normal;color:#64748b;font-size:13px;line-height:1.35}.source-command-panel summary b{display:inline-flex;align-items:center;justify-content:center;min-height:34px;border-radius:10px;background:#111827;color:#fff;padding:0 12px;font-size:12px;white-space:nowrap}.source-command-panel[open] summary{border-bottom:1px solid #eef2ff}.source-command-panel[open] summary b{background:#f8faff;color:#442499;border:1px solid #e7e8ff}.source-form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:14px}.source-form-grid label{display:grid;gap:6px;text-transform:uppercase;letter-spacing:.05em}.source-form-grid .span-2{grid-column:span 2}.source-form-actions{display:flex;justify-content:flex-end;align-items:center}.source-card-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.source-card{min-height:92px}.sources-header{grid-template-columns:minmax(0,1fr) minmax(220px,300px)}
@media (max-width:1180px){.source-form-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.source-form-grid .span-2{grid-column:span 3}}
@media (max-width:820px){.source-form-grid{grid-template-columns:1fr}.source-form-grid .span-2{grid-column:span 1}.source-form-actions{justify-content:stretch}.source-form-actions .btn{width:100%;justify-content:center}.source-command-panel summary{align-items:flex-start}.source-command-panel summary b{margin-top:2px}}
.integration-field-panel{background:#f8fbff;border:1px solid #dbeafe;border-radius:14px;padding:12px}.integration-field-panel .card-head{margin-bottom:10px}.source-form-grid.compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:0}.source-form-grid.compact label{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px;text-transform:none;letter-spacing:0}.source-form-grid.compact label span{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#334155;font-weight:800;text-transform:none;letter-spacing:0}.source-form-grid.compact label b{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;background:#f1f5f9;border-radius:999px;padding:3px 7px;white-space:nowrap}.source-form-grid.compact label:has(b:first-child),.source-form-grid.compact label b:first-child{color:#64748b}.source-form-grid.compact small{font-size:12px;line-height:1.35;color:#64748b;text-transform:none;letter-spacing:0}.source-form-grid.compact .oh-input{min-height:42px}@media (max-width:980px){.source-form-grid.compact{grid-template-columns:1fr}}
.inline-policy-note{border:1px solid #e7e8ff;border-radius:12px;background:#f8faff;padding:10px 12px;display:grid;gap:3px;align-content:center;min-height:64px}.inline-policy-note strong{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#442499}.inline-policy-note span{font-size:13px;line-height:1.35;color:#64748b}
.inline-policy-note.ready{border-color:#bbf7d0;background:#f0fdf4}.inline-policy-note.ready strong{color:#15803d}.inline-policy-note.blocked{border-color:#fed7aa;background:#fff7ed}.inline-policy-note.blocked strong{color:#c2410c}

.social-workspace{display:grid;gap:12px}.social-hero{margin-bottom:0}.social-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.social-tabs{position:sticky;top:0}.social-single-column{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.social-panel-card{padding:16px}.social-form{display:grid;gap:10px}.compact-checkbox-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.upload-inline{display:grid;grid-template-columns:160px minmax(160px,1fr) minmax(220px,1.25fr) auto;gap:10px;align-items:end;margin-bottom:12px}.media-asset-list{display:grid;gap:8px}.media-asset-row{display:grid;grid-template-columns:74px minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #eef2ff;border-radius:12px;background:#fbfcff;padding:9px;min-width:0}.media-asset-row strong{display:block;color:#0f172a;overflow-wrap:anywhere}.media-asset-row span:not(.pill){display:block;color:#64748b;font-size:12px;margin-top:2px;overflow-wrap:anywhere}.media-thumb{width:74px;aspect-ratio:1;border:1px solid #eef2ff;border-radius:10px;background:#f8faff;display:grid;place-items:center;overflow:hidden}.media-thumb img{width:100%;height:100%;object-fit:cover;display:block}.media-thumb span{font-size:11px;font-weight:800;color:#64748b}.social-post-card{gap:12px}.social-caption{margin:0}.social-post-image{width:100%;max-height:280px;object-fit:cover;border-radius:12px;border:1px solid var(--oh-line);background:#f8faff}.social-calendar-card{display:grid;gap:12px}
@media (max-width:980px){.social-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.upload-inline{grid-template-columns:1fr}.upload-inline .btn{justify-content:center}.social-tabs{position:relative}}@media (max-width:620px){.social-kpis{grid-template-columns:1fr}.media-asset-row{grid-template-columns:58px minmax(0,1fr)}.media-asset-row>.pill{grid-column:2}.media-thumb{width:58px}}
.studio-workspace{display:grid;gap:12px}.studio-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.studio-tabs{position:sticky;top:0}.studio-single-column{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.studio-panel-card,.studio-record-card{padding:16px}.studio-form{display:grid;gap:10px}.creation-mode-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.creation-mode-option{display:grid;gap:4px;border:1px solid #dbeafe;border-radius:14px;background:linear-gradient(180deg,#fff,#f8faff);padding:12px;cursor:pointer;min-width:0}.creation-mode-option:has(input:checked){border-color:#7b7fff;box-shadow:0 0 0 3px rgba(123,127,255,.12)}.creation-mode-option input{width:16px;height:16px;margin:0}.creation-mode-option strong{font-size:14px;color:#0f172a}.creation-mode-option span{font-size:12px;color:#64748b;line-height:1.3}.hero-prompt-box{min-height:140px;font-size:15px;line-height:1.5}.studio-record-card{min-width:0}.studio-record-card .policy-card-list{margin-top:12px}.studio-record-card .action-row{display:flex;gap:8px;flex-wrap:wrap}.studio-record-card .action-row form{margin:0}.studio-record-card ol{margin:10px 0 0;padding-left:20px}.studio-record-card li{margin:6px 0;color:#334155;line-height:1.4}.studio-record-card li strong{font-weight:700}
.code-textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.5}
@media (max-width:980px){.studio-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.studio-tabs{position:relative}.creation-mode-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:620px){.studio-kpis{grid-template-columns:1fr}.creation-mode-grid{grid-template-columns:1fr}}

/* Global shell compression for narrow browser panes. */
@media (max-width:900px){
  .oh-app{display:block;min-height:100vh}
  .oh-sidebar{position:sticky;top:0;z-index:20;height:auto;max-height:none;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;box-shadow:0 10px 30px rgba(1,13,61,.18)}
  .oh-sidebar .oh-logo{padding:12px 14px}.oh-sidebar .oh-logo img{width:132px}
  .sidebar-account{padding:10px 12px 10px 0}.sidebar-account-label,.sidebar-account-role,.sidebar-tenant,.sidebar-impersonation{display:none}.sidebar-account-name{font-size:12px;margin:0}
  .oh-sidebar nav{grid-column:1/-1;display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;padding:0 10px 10px;scrollbar-width:thin}
  .nav-section-title{display:none}.oh-sidebar nav a{min-width:max-content;min-height:34px;border-left:0;border-radius:10px;padding:8px 10px;background:rgba(255,255,255,.05)}.oh-sidebar nav a.active{border-left:0;background:rgba(123,127,255,.24)}
  .oh-sidebar nav a svg{width:16px;height:16px}.oh-sidebar nav a .nav-label{max-width:150px}.sidebar-logout{min-width:max-content}.sidebar-logout button{min-height:34px;border-radius:10px;background:rgba(255,255,255,.05);padding:8px 12px;white-space:nowrap}
  .oh-main{padding:14px 14px 48px}.oh-topbar{margin-bottom:12px;padding:12px 14px;border-radius:14px}.oh-topbar h1{font-size:26px;line-height:1.05}.oh-topbar .eyebrow{font-size:10px}.sources-header{padding:14px;border-radius:14px}.sources-header h2{font-size:22px}.source-kpis{gap:8px}.source-kpis .analytics-widget{min-height:92px}
}

.qr-asset-card{grid-column:span 1}.qr-asset-layout{display:grid;grid-template-columns:132px minmax(0,1fr);gap:12px;align-items:start}.qr-preview{border:1px solid #eef2ff;border-radius:14px;background:#fff;display:grid;place-items:center;padding:10px}.qr-preview img{width:100%;max-width:112px;height:auto;display:block}.qr-details{display:grid;gap:10px;min-width:0}.qr-details .smart-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.qr-details .code-block{font-size:11px;max-height:74px;overflow:auto}.qr-url-stack{display:grid;gap:8px}.qr-url-stack div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px;min-width:0}.qr-url-stack span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}.qr-url-stack strong{display:block;margin-top:4px;color:#0f172a;font-size:12px;line-height:1.35;overflow-wrap:anywhere}
@media (max-width:760px){.qr-asset-layout{grid-template-columns:1fr}.qr-preview img{max-width:180px}.qr-details .smart-metrics{grid-template-columns:1fr}}

.marketing-layout,.support-ops-layout{grid-template-columns:minmax(320px,.9fr) minmax(320px,1fr) minmax(300px,.85fr)}
.marketing-funnel{display:grid;gap:12px}
.marketing-funnel div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:12px}
.marketing-funnel span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}
.marketing-funnel strong{display:block;margin:4px 0 8px;font-size:28px;color:#0f172a}
.compact-bars{height:220px;min-height:220px}
.compact-bars .score-point{height:190px;min-width:42px}
.dual-bar{display:grid!important;grid-template-columns:1fr 1fr;align-items:end;gap:4px}
.dual-bar small{grid-column:1/-1;text-align:center}
.dual-bar .resolved{background:linear-gradient(180deg,#22c55e,#14b8a6)!important}
@media (max-width:1100px){.marketing-layout,.support-ops-layout{grid-template-columns:1fr}}

.seo-command-stack{display:grid;gap:8px;align-self:stretch}.seo-command-stack form{margin:0}.seo-run-button{width:100%;justify-content:center;min-height:42px}.seo-scan-status{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.seo-command-stack .seo-location-filter{min-width:260px}
@media (max-width:760px){.seo-command-stack .seo-location-filter{min-width:0}.seo-run-button{width:100%}}

/* Single-column tab workspaces. Tabs should read like workflows, not dashboards
   squeezed into side-by-side panes. */
.seo-workspace .benchmark-tabs,
.studio-workspace .benchmark-tabs,
.social-workspace .benchmark-tabs,
.sources-tabs .benchmark-tabs,
.benchmark-workspace .benchmark-tabs{flex-wrap:wrap;overflow:visible;align-items:stretch}
.seo-workspace .benchmark-tabs button,
.studio-workspace .benchmark-tabs button,
.social-workspace .benchmark-tabs button,
.sources-tabs .benchmark-tabs button,
.benchmark-workspace .benchmark-tabs button{flex:1 1 150px;text-align:center}
.benchmark-tab-panel .seo-grid,
.benchmark-tab-panel .seo-grid.pages,
.benchmark-tab-panel .smart-card-grid,
.benchmark-tab-panel .market-card-grid,
.benchmark-tab-panel .benchmark-grid,
.benchmark-tab-panel .benchmark-grid.two,
.benchmark-tab-panel .report-card-grid,
.benchmark-tab-panel .runs-grid,
.benchmark-tab-panel .card-grid,
.benchmark-tab-panel .oh-grid.two,
.benchmark-tab-panel .form-grid.two,
.benchmark-tab-panel .form-grid.three,
.benchmark-tab-panel .marketing-layout,
.benchmark-tab-panel .support-ops-layout{grid-template-columns:minmax(0,1fr)!important}
.benchmark-tab-panel .benchmark-card,
.benchmark-tab-panel .smart-card,
.benchmark-tab-panel .report-block{max-width:none;width:100%}
.benchmark-tab-panel .policy-card-list,
.benchmark-tab-panel .compact-opportunities,
.benchmark-tab-panel .opportunity-card-list{grid-template-columns:minmax(0,1fr)}

/* App-wide workflow screens: keep the main reading path in one column.
   KPI tiles may still use compact grids, but operational cards, reports,
   charts, support queues, and forms should not create permanent right panes. */
.analytics-grid,
.analytics-grid.three,
.analytics-layout,
.marketing-layout,
.support-ops-layout,
.smart-card-grid,
.market-card-grid,
.report-grid,
.oh-grid.two,
.oh-row.three,
.form-grid.two,
.form-grid.three,
.benchmark-coordinates,
.campaign-detail-grid,
.campaign-run-grid,
.report-card-grid,
.runs-grid,
.onboard-shell,
.upload-inline,
.creation-mode-grid{grid-template-columns:minmax(0,1fr)!important}
.analytics-hero-card,
.benchmark-hero,
.section-head,
.market-toolbar,
.campaign-head,
.benchmark-run-top{display:grid!important;grid-template-columns:minmax(0,1fr)!important}
.analytics-score-badge{width:100%;min-width:0}
.pipeline{display:grid;grid-template-columns:minmax(0,1fr)!important;overflow:visible}
.feed-card,
.media-asset-row,
.qr-asset-layout{grid-template-columns:minmax(0,1fr)!important}
.media-thumb{width:100%;max-width:160px}
.source-filter-form{display:grid!important;grid-template-columns:minmax(0,1fr)!important}
.source-filter-form .btn,
.action-row .btn{justify-content:center}

/* Repeated review cards should use screen width efficiently. */
.feedback-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.feedback-card-grid .feedback-tile{display:grid!important;grid-template-columns:48px minmax(0,1fr)!important;align-content:start;gap:12px;min-height:190px}
.feedback-card-grid .feedback-tile>div:last-child{grid-column:1/-1}
.feedback-card-grid .feedback-tile .btn{width:100%;justify-content:center}
.feedback-card-grid .avatar{width:48px;max-width:48px}
@media (min-width:1500px){.feedback-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (min-width:980px) and (max-width:1499px){.feedback-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:900px){.survey-product-grid,.survey-builder-form,.survey-distribution-grid{grid-template-columns:minmax(0,1fr)}.survey-builder-form .survey-wide{grid-column:auto}.nps-scale{grid-template-columns:repeat(6,minmax(40px,1fr))}.survey-public-step{padding:22px}.survey-public-footer{grid-template-columns:1fr}.survey-public-footer .btn{width:100%;justify-content:center}}
@media (max-width:720px){.feedback-card-grid{grid-template-columns:minmax(0,1fr)}}

/* Dashboard analytics are executive scan cards, so they intentionally use two columns. */
.dashboard-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:stretch}
.dashboard-two-col .oh-panel{min-width:0}
.score-card-layout,.velocity-visual-layout{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;align-items:center}
.velocity-ring.compact{width:138px;height:138px;margin:0}
.velocity-ring.compact>div{width:96px;height:96px}
.funnel-mini-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.funnel-mini-grid div{border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px;min-width:0}
.funnel-mini-grid span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}
.funnel-mini-grid strong{display:block;margin-top:3px;color:#0f172a;font-size:18px}
.funnel-mini-grid i{display:block;height:7px;margin-top:8px;border-radius:999px;background:var(--oh-grad-primary)}
.channel-bar-chart{display:grid;gap:13px;margin-top:12px}
.channel-bar-row{display:grid;grid-template-columns:86px minmax(0,1fr) 48px;gap:10px;align-items:center}
.channel-bar-row span{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}
.channel-bar-row strong{text-align:right;color:#0f172a}
.channel-bar{height:18px;border-radius:999px;background:#eef2ff;overflow:hidden}
.channel-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7B7FFF,#14b8a6)}
.alert-chart-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:end;min-height:132px;margin:4px 0 14px}
.alert-chart-grid div{position:relative;display:grid;align-content:end;gap:5px;min-height:118px;border:1px solid #eef2ff;border-radius:12px;background:#f8faff;padding:10px;overflow:hidden}
.alert-chart-grid i{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(254,96,168,.6),rgba(245,158,11,.38));border-radius:12px 12px 0 0;z-index:0}
.alert-chart-grid span,.alert-chart-grid strong{position:relative;z-index:1}
.alert-chart-grid span{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-weight:800}
.alert-chart-grid strong{font-size:22px;color:#0f172a}
@media (max-width:1180px){.dashboard-two-col{grid-template-columns:minmax(0,1fr)}}
@media (max-width:720px){.score-card-layout,.velocity-visual-layout{grid-template-columns:minmax(0,1fr)}.funnel-mini-grid,.alert-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.channel-bar-row{grid-template-columns:72px minmax(0,1fr) 36px}}
