/* FluxFront — shop-photography · sliced verbatim from the original sections.css block (render-identical). See docs/marketing-site-architecture.md for the selector map. */
/* ===================== REAL SHOP PHOTOGRAPHY ===================== */
/* full-bleed photo band after hero */
.photoband { position: relative; min-height: clamp(340px, 42vw, 520px); display: flex; align-items: flex-end; overflow: hidden; }
.photoband-bg { position: absolute; inset: 0; background-size: cover; background-position: center 52%; transform: scale(1.02); }
.photoband-scrim { position: absolute; inset: 0; background:
  linear-gradient(90deg, rgb(9 11 14 / 0.92) 0%, rgb(9 11 14 / 0.74) 40%, rgb(9 11 14 / 0.46) 70%, rgb(9 11 14 / 0.34) 100%),
  linear-gradient(0deg, rgb(9 11 14 / 0.58), transparent 56%); }
.photoband-in { position: relative; z-index: 2; padding-block: clamp(40px, 6vw, 76px); color: #fff; display: flex; justify-content: flex-start; }
.photoband-copy { max-width: 560px; }
.photoband-h { font-family: var(--font-display); font-size: clamp(1.6rem, 1.05rem + 2.3vw, 2.9rem); font-weight: 600;
  letter-spacing: -0.025em; line-height: 1.08; max-width: 17ch; color: #F4F2EC; margin-top: 14px; text-wrap: balance; }
.photoband-stats { display: flex; flex-wrap: wrap; gap: 22px 44px; margin-top: 30px; }
.pb-stat b { display: block; font-size: clamp(1.5rem, 1.1rem + 1.3vw, 2.1rem); font-weight: 600; letter-spacing: -0.02em; color: var(--teal-bright); }
.pb-stat span { font-size: 0.82rem; color: #C9CED7; }

/* founder photo (real) */
.founder-img { aspect-ratio: 4 / 3; }
.founder-img::after { display: none; }
.founder-img img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 42%; display: block; }

/* final CTA — subtle photo backdrop */
.cta-sec { position: relative; overflow: hidden; }
.cta-photo { position: absolute; inset: 0; background-size: cover; background-position: center 28%; opacity: 0.26;
  mask-image: linear-gradient(90deg, transparent 0%, #000 55%); -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 55%); }
.cta-sec > .wrap { position: relative; z-index: 2; }
/* second photo band (built-in-Ottawa) contact chips */
.photoband-alt .photoband-bg { background-position: center 42%; }
.pb-contact { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.pb-link { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: var(--r-pill);
  border: 1px solid rgb(255 255 255 / 0.22); background: rgb(255 255 255 / 0.06); color: #EDEBE4;
  font-family: var(--font-mono); font-size: 0.8rem; backdrop-filter: blur(4px);
  transition: border-color var(--d-2), background var(--d-2), color var(--d-2); }
.pb-link svg { width: 16px; height: 16px; color: var(--teal-bright); }
.pb-link:hover { border-color: var(--teal); background: rgb(45 212 191 / 0.14); color: #fff; }

/* compact spacing so devices keep proper aspect ratios */
.ui-segchips, .ui-kpis, .ui-kpis-mini, .ui-dash-2col { margin-bottom: 8px; }
.ui-ph-top { padding: 2px 2px 8px; }
.ui-ph-kpis, .ui-ph-actions, .ui-ph-queue { margin-bottom: 8px; }
.ui-ph-act { padding: 8px 3px; }
.ui-ph-qrow { padding: 7px 9px; margin-bottom: 5px; }
.ui-ph-paybtn { padding: 10px; }

/* Aria "call to test" card (replaces the sample-call player) */
.aria-ring { animation: ariaRing 2.2s var(--e-out) infinite; }
.aria-ring:nth-child(2) { animation-delay: 1.1s; }
.aria-callcard { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; padding: 18px;
  border-radius: var(--r-lg); background: linear-gradient(135deg, rgb(45 212 191 / 0.16), rgb(45 212 191 / 0.05));
  border: 1px solid rgb(45 212 191 / 0.3); transition: border-color var(--d-2), background var(--d-2), transform var(--d-2) var(--e-spring); }
.aria-callcard:hover { border-color: var(--teal); background: linear-gradient(135deg, rgb(45 212 191 / 0.22), rgb(45 212 191 / 0.08)); transform: translateY(-2px); }
.aria-call-ic { position: relative; flex: none; width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center;
  background: var(--teal); color: #06231f; }
.aria-call-ic svg { width: 22px; height: 22px; }
.aria-call-ping { position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--teal); animation: ariaRing 1.8s var(--e-out) infinite; }
.aria-call-meta { display: flex; flex-direction: column; gap: 3px; }
.aria-call-label { font-size: 0.58rem; letter-spacing: 0.1em; color: var(--teal-bright); }
.aria-call-num { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; letter-spacing: -0.01em; color: #fff; line-height: 1.05; }
.aria-call-sub { font-size: 0.72rem; color: #A7AEB9; line-height: 1.4; }

/* staff section — locations bar */
.roles-wrap { display: flex; flex-direction: column; gap: 12px; }
.role-locs { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.role-locs-l { font-size: 0.6rem; letter-spacing: 0.1em; color: var(--ink-3); margin-right: 2px; }
.role-loc { font-size: 0.74rem; font-weight: 500; color: var(--ink-2); padding: 6px 12px; border-radius: var(--r-pill);
  border: 1px solid var(--hairline-2); background: var(--cream); }
.role-loc.active { background: var(--teal-wash); color: var(--teal-800); border-color: var(--teal-600); font-weight: 600; }

