/* ── SmartOffice360 page-specific overrides ── */
/* home.css provides all shared tokens, nav, reveal, hero, ticker, story,
   services/svc-*, stats-strip, audience/aud-*, platforms/plat-*, offer/offer-*,
   contact, footer, wa-fab, back-top, cmdb-* */

/* ── HERO OVERRIDES ── */
.so-hero-bg {
  background-image: url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=1600&q=80');
}
.so-orb {
  background: radial-gradient(circle, rgba(0,184,148,.22) 0%, transparent 70%);
}
.so-orb-2 {
  background: radial-gradient(circle, rgba(66,133,140,.1) 0%, transparent 70%);
}
.so-kicker::before { background: var(--teal) }
h1.hero-h1 .so-l-a { display: block; color: var(--teal) }
h1.hero-h1 .so-l-b { display: block; color: var(--amber) }

/* ── PROBLEM SECTION ── */
.so-stat-sup { font-size: .6em }

.so-eyebrow-teal {
  color: var(--teal);
  margin-bottom: 1.5rem;
}

.so-tech-badge {
  font-size: .7rem;
  font-weight: 800;
  color: #fff;
  padding: .4rem .9rem;
  letter-spacing: .06em;
  opacity: 1;
  filter: none;
}
.so-tech-badge:hover { opacity: 1; filter: none }
.so-tech-ha     { background: #0B3D91 }
.so-tech-unifi  { background: #0559C9 }
.so-tech-sonoff { background: #E8451E }
.so-tech-domotz { background: #1E3250 }

/* ── AUDIENCE CARD COLOUR VARIANTS ── */
.so-aud-purple { --c: #6D28D9 }
.so-aud-teal   { --c: var(--teal) }
.so-aud-green  { --c: var(--green) }

/* ── DEPLOYMENT BUNDLES ── */
.so-packages {
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.so-pkg-hd {
  padding: 5vw 2.2vw 3.5vw;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 3rem;
  align-items: end;
  border-bottom: 1px solid var(--border);
  max-width: 1500px;
  margin: 0 auto;
  width: 100%;
}
.so-pkg-hd .eyebrow { color: var(--muted) }
.so-pkg-h2 {
  font-family: var(--display);
  font-size: clamp(2.4rem, 4.8vw, 5rem);
  font-weight: 900;
  letter-spacing: -.045em;
  line-height: .96;
  color: var(--ink);
  margin-top: 1.1rem;
}
.so-pkg-h2 em  { font-style: italic; font-weight: 400; color: var(--muted) }
.so-pkg-h2 strong { color: var(--red); font-weight: 900 }
.so-pkg-note {
  font-size: .92rem;
  color: var(--muted);
  line-height: 1.75;
  max-width: 44ch;
}

.so-pkg-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.so-pkg-card {
  padding: 3rem 2.4rem;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
  background: #fff;
}
.so-pkg-card:last-child { border-right: none }

.so-pkg-card-featured {
  background: var(--bg-dark);
  color: #fff;
  border-right: none;
}

.so-pkg-badge {
  display: inline-block;
  font-size: .44rem;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  padding: .35rem .8rem;
  border: 1px solid rgba(10,10,10,.15);
  color: var(--muted);
  width: fit-content;
}
.so-pkg-badge-pro {
  color: var(--teal);
  border-color: rgba(66,133,140,.4);
  background: rgba(66,133,140,.06);
}

.so-pkg-price-range {
  font-family: var(--display);
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 900;
  letter-spacing: -.04em;
  color: var(--ink);
  line-height: 1;
}
.so-pkg-price-range sup { font-size: .55em; color: var(--red); vertical-align: super }
.so-pkg-card-featured .so-pkg-price-range { color: #fff }

.so-pkg-price-label {
  font-size: .48rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: .3rem;
}
.so-pkg-card-featured .so-pkg-price-label { color: rgba(255,255,255,.35) }

.so-pkg-best-for { display: flex; flex-direction: column; gap: .6rem }

.so-pkg-bf-label {
  font-size: .44rem;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
}
.so-pkg-card-featured .so-pkg-bf-label { color: rgba(255,255,255,.4) }

.so-pkg-bf-tags { display: flex; flex-wrap: wrap; gap: .4rem }
.so-pkg-bf-tags span {
  font-size: .68rem;
  font-weight: 600;
  color: var(--ink);
  background: var(--bg);
  border: 1px solid var(--border);
  padding: .25rem .7rem;
}
.so-pkg-card-featured .so-pkg-bf-tags span {
  color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}

.so-pkg-divider {
  height: 1px;
  background: var(--border);
}
.so-pkg-divider-light { background: rgba(255,255,255,.1) }

.so-pkg-col-label {
  font-size: .44rem;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
}
.so-pkg-col-label-light { color: rgba(255,255,255,.4) }

.so-pkg-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.so-pkg-list li {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.5;
}
.so-pkg-list li i { color: var(--red); flex-shrink: 0; margin-top: .1em }
.so-pkg-list-light li { color: rgba(255,255,255,.62) }
.so-pkg-list-light li i { color: var(--teal) }

.so-pkg-scenarios { display: flex; flex-direction: column; gap: .75rem }
.so-pkg-scenario {
  font-size: .8rem;
  color: var(--muted);
  line-height: 1.6;
  padding-left: 1rem;
  border-left: 2px solid var(--border);
}
.so-pkg-scenario strong { color: var(--ink); display: block; margin-bottom: .15rem }
.so-pkg-scenarios-light .so-pkg-scenario {
  border-left-color: rgba(255,255,255,.15);
  color: rgba(255,255,255,.52);
}
.so-pkg-scenarios-light .so-pkg-scenario strong { color: #fff }

.so-pkg-mgmt {
  padding: 1.2rem 1.4rem;
  background: var(--bg);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: .3rem;
}
.so-pkg-mgmt-featured {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}
.so-pkg-mgmt-label {
  font-size: .44rem;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
}
.so-pkg-mgmt-featured .so-pkg-mgmt-label { color: rgba(255,255,255,.4) }
.so-pkg-mgmt-price {
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--teal);
}
.so-pkg-mgmt-desc {
  font-size: .72rem;
  color: var(--muted);
  line-height: 1.5;
}
.so-pkg-mgmt-featured .so-pkg-mgmt-desc { color: rgba(255,255,255,.35) }

.so-pkg-note-strip {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: 1.4rem 2.4rem;
  border-top: 1px solid var(--border);
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.65;
  background: #fff;
}
.so-pkg-note-strip i { color: var(--teal); font-size: 1rem; flex-shrink: 0; margin-top: .1em }
.so-pkg-note-strip strong { color: var(--ink) }

/* ── TESTIMONIALS ── */
.so-testi {
  background: var(--bg-dark);
  color: #fff;
  border-top: 1px solid var(--border-dark);
}
.so-testi-hd {
  padding: 4.5vw 2.2vw 3rem;
  border-bottom: 1px solid var(--border-dark);
}
.so-testi-hd .eyebrow { color: rgba(255,255,255,.4) }
.so-testi-hd .eyebrow::before { background: var(--red) }
.so-testi-h2 {
  font-family: var(--display);
  font-size: clamp(2.4rem, 4.5vw, 4.5rem);
  font-weight: 900;
  letter-spacing: -.045em;
  line-height: .98;
  color: #fff;
  margin-top: 1.1rem;
}
.so-testi-h2 em { font-style: italic; font-weight: 400; color: rgba(255,255,255,.3) }

.so-testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.so-testi-card {
  padding: 3rem 2.4rem;
  border-right: 1px solid var(--border-dark);
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  transition: background .3s;
}
.so-testi-card:last-child { border-right: none }
.so-testi-card:hover { background: var(--bg-dark-2) }

.so-testi-quote {
  font-family: var(--display);
  font-size: 3.5rem;
  line-height: .8;
  color: var(--red);
  font-weight: 900;
}
.so-testi-text {
  font-size: .88rem;
  color: rgba(255,255,255,.58);
  line-height: 1.75;
  flex: 1;
}
.so-testi-author {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--border-dark);
}
.so-testi-avatar {
  width: 40px;
  height: 40px;
  background: var(--red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .04em;
  flex-shrink: 0;
}
.so-testi-name {
  font-size: .82rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.01em;
}
.so-testi-role {
  font-size: .7rem;
  color: rgba(255,255,255,.38);
  margin-top: .2rem;
}

/* ── RESPONSIVE ── */
@media(max-width: 960px) {
  .so-pkg-hd   { grid-template-columns: 1fr; gap: 1.5rem }
  .so-pkg-grid { grid-template-columns: 1fr }
  .so-pkg-card { border-right: none; border-bottom: 1px solid var(--border) }
  .so-pkg-card-featured { border-bottom: none }
  .so-testi-grid { grid-template-columns: 1fr }
  .so-testi-card { border-right: none; border-bottom: 1px solid var(--border-dark) }
  .so-testi-card:last-child { border-bottom: none }
}
@media(max-width: 860px) {
  .so-pkg-note-strip { padding: 1.2rem 1.6rem }
}
