/* ===========================================================================
   solutions.css — Automated Australia
   Additive stylesheet for the full-stack expansion. Loaded AFTER style.css so
   it inherits every design token (--ink, --bone, --pulse, --display, --mono…)
   and never has to redefine them. Covers: the Solutions/Work nav mega-menu,
   the homepage capability + trust + integrations strips, and the shared
   "solution page" layout used by /software /infrastructure /crm /growth /audits.
   Nothing here overrides existing rules — all selectors are new.
   =========================================================================== */

/* ---------------------------------------------------------------- NAV MENU
   .nav uses mix-blend-mode:difference, so dropdown PANELS live OUTSIDE the
   header as fixed siblings (see Base.astro #navPanels). Only the triggers sit
   inside .nav__menu and must visually match the existing <a> links. */
.nav__menu .nav__trigger{
  font:inherit; letter-spacing:inherit; text-transform:inherit; color:inherit;
  background:none; border:0; padding:6px 0; cursor:pointer;
  position:relative; display:inline-flex; align-items:center; gap:7px;
}
.nav__menu .nav__trigger::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:0 50%;
  transition:transform .55s var(--ease);
}
.nav__menu .nav__trigger:hover::after,
.nav__menu .nav__trigger[aria-expanded="true"]::after{ transform:scaleX(1); }
.nav__caret{
  width:5px; height:5px; border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor; transform:translateY(-1px) rotate(45deg);
  transition:transform .4s var(--ease);
}
.nav__trigger[aria-expanded="true"] .nav__caret{ transform:translateY(1px) rotate(-135deg); }

/* While a panel is open the nav drops blend-mode and goes solid so the bar and
   the floating panel read as one surface. */
.nav.nav--panel-open{
  mix-blend-mode:normal !important; background:var(--ink); color:var(--bone);
  border-bottom:1px solid hsl(60 8% 96% / .08);
}

/* The floating mega-panels — fixed, dark, blend-mode free */
.navpanels{ position:fixed; inset:0 0 auto 0; z-index:90; pointer-events:none; }
.navpanel{
  position:absolute; top:64px; left:50%;
  transform:translateX(-50%) translateY(-10px);
  width:min(820px, calc(100vw - 40px));
  background:var(--ink-2); color:var(--bone);
  border:1px solid hsl(60 8% 96% / .12); border-radius:16px;
  box-shadow:0 30px 80px -20px hsl(220 40% 2% / .7);
  /* visibility:hidden (not just opacity:0) keeps the closed panel's link text
     OUT of the rendered/snippet text tree so it can't bleed into the SERP
     snippet as leading content; the footer carries the same nav links for
     crawlers. visibility flips visible with no delay on open, and hides only
     after the .42s fade-out on close. Mirrors the cart-drawer + mobile-menu. */
  padding:14px; opacity:0; pointer-events:none; visibility:hidden;
  transition:opacity .42s var(--ease), transform .42s var(--ease), visibility 0s linear .42s;
}
.navpanel.is-open{ transform:translateX(-50%) translateY(0); opacity:1; pointer-events:auto; visibility:visible;
  transition:opacity .42s var(--ease), transform .42s var(--ease), visibility 0s; }
.navpanel--sm{ width:min(560px, calc(100vw - 40px)); }
.navpanel__grid{ display:grid; grid-template-columns:1fr 1fr; gap:4px; }
.navpanel--sm .navpanel__grid{ grid-template-columns:1fr; }
.navpanel__link{
  display:block; padding:13px 15px; border-radius:11px; color:var(--bone);
  transition:background-color .3s var(--ease), transform .3s var(--ease);
}
.navpanel__link:hover{ background:hsl(60 8% 96% / .06); }
.navpanel__link b{
  display:flex; align-items:center; gap:9px;
  font:600 14px/1.1 var(--sans); letter-spacing:-.01em; margin-bottom:4px;
}
.navpanel__link b::before{
  content:""; width:7px; height:7px; background:var(--pulse);
  box-shadow:0 0 12px 1px var(--pulse); flex:none;
}
.navpanel__link > span{
  display:block; font:400 12.5px/1.45 var(--sans); color:hsl(60 8% 96% / .55);
}
.navpanel__tier{ font-weight:500; color:hsl(60 8% 96% / .42); }
@media (max-width:880px){ .navpanels{ display:none; } }

/* Mobile menu group labels */
.mobile-menu__group{
  font:500 10.5px/1 var(--mono); letter-spacing:.22em; text-transform:uppercase;
  color:var(--pulse); padding:22px 0 10px; opacity:.85;
}
.mobile-menu__group:first-child{ padding-top:6px; }

/* ------------------------------------------------- HOMEPAGE: CAPABILITIES
   Namespaced .capsec/.capgrid/.captile (NOT .cap — that's a site-wide chip
   class). Dark + premium to match the hero & solution pages, with a
   cursor-follow cyan glow and a subtle magnetic tilt (wired in index.astro). */
.capsec{ background:var(--ink); color:var(--bone); padding:clamp(96px,13vh,160px) 0; position:relative; overflow:hidden; }
.capsec__head{ max-width:var(--max); margin:0 auto; padding:0 var(--gut); }
.capsec .section-eyebrow{ color:hsl(60 8% 96% / .5); border-top-color:hsl(60 8% 96% / .14); }
.capsec .section-head{ color:var(--bone); }
.capgrid{
  max-width:var(--max); margin:44px auto 0; padding:0 var(--gut);
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
  transform-style:preserve-3d;
}
.captile{
  position:relative; display:block; padding:30px 26px 26px; border-radius:16px;
  background:var(--ink-2); border:1px solid hsl(60 8% 96% / .1);
  overflow:hidden; isolation:isolate; transform-style:preserve-3d;
  transition:border-color .45s var(--ease), background-color .45s var(--ease);
}
/* real-time tilt (no transform transition) so it never drifts off a stationary cursor and
   loses :hover; smooth flatten on leave restored via .is-tilt-reset (toggled in index.astro). */
.captile.is-tilt-reset{ transition:transform .4s var(--ease), border-color .45s var(--ease), background-color .45s var(--ease); }
.captile::before{   /* cursor-follow cyan glow */
  content:""; position:absolute; inset:-1px; z-index:-1; opacity:0;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,0%), hsl(184 90% 48% / .22), transparent 62%);
  transition:opacity .45s var(--ease);
}
.captile:hover{ border-color:hsl(184 90% 48% / .5); background:hsl(220 14% 13%); }
.captile:hover::before{ opacity:1; }
.captile__ix{
  font:500 11px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase;
  color:hsl(60 8% 96% / .45); display:flex; align-items:center; gap:9px; margin-bottom:22px;
}
.captile__ix::before{ content:""; width:8px; height:8px; background:var(--pulse); box-shadow:0 0 12px 1px var(--pulse); }
.captile__title{ font:700 19px/1.15 var(--display); letter-spacing:-.01em; margin-bottom:10px; color:var(--bone); }
.captile__body{ font:400 14px/1.55 var(--sans); color:hsl(60 8% 96% / .62); }
.captile__more{
  margin-top:18px; font:500 11px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase;
  color:hsl(60 8% 96% / .8); display:inline-flex; gap:7px; align-items:center;
}
.captile__more::after{ content:"→"; transition:transform .35s var(--ease); }
.captile:hover .captile__more{ color:var(--pulse); }
.captile:hover .captile__more::after{ transform:translateX(4px); }
@media (max-width:1080px){ .capgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .capgrid{ grid-template-columns:1fr; } .captile{ transform:none !important; } }
@media (prefers-reduced-motion: reduce){ .captile{ transform:none !important; } }

/* ---------------------------------------------------------------- HOMEPAGE: TRUST STRIP */
.trust{ background:var(--ink); color:var(--bone); padding:26px var(--gut); }
.trust__row{
  max-width:var(--max); margin:0 auto; display:flex; flex-wrap:wrap;
  align-items:center; justify-content:center; gap:14px 30px;
  font:500 12px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase;
}
.trust__row span{ display:inline-flex; align-items:center; gap:14px; color:hsl(60 8% 96% / .82); }
.trust__row span::before{ content:""; width:6px; height:6px; background:var(--pulse); box-shadow:0 0 10px 1px var(--pulse); }

/* ---------------------------------------------------------------- HOMEPAGE: INTEGRATIONS */
.intg{ background:var(--bone); color:var(--ink); padding:clamp(70px,9vh,110px) 0; }
.intg__inner{ max-width:var(--max); margin:0 auto; padding:0 var(--gut); }
.intg__label{
  font:500 11px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-mute); border-top:var(--rule); padding-top:16px; margin-bottom:24px;
}
.intg__label em{ color:var(--ink); font-style:normal; }
.intg__row{ display:flex; flex-wrap:wrap; gap:10px; }
.intg__pill{
  font:500 13px/1 var(--mono); letter-spacing:.04em;
  border:1px solid hsl(220 14% 8% / .16); border-radius:999px; padding:11px 17px;
  color:var(--ink-3); transition:border-color .35s var(--ease), color .35s var(--ease);
}
.intg__pill:hover{ border-color:var(--pulse); color:var(--ink); }
.intg__note{ margin-top:22px; font:400 14.5px/1.6 var(--sans); color:var(--ink-3); max-width:62ch; }

/* ----------------------------------- HOMEPAGE: AGENTS ("what we automate")
   Clean left-stacked header (replaces the misaligned .agents__intro 12-col
   grid) + full-description tile elements. Reuses .agent-tile* + accordion JS. */
.hagents__head{ max-width:var(--max); margin:0 auto 46px; padding:0 var(--gut); }
.hagents__eyebrow{ font:500 11px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase; color:hsl(60 8% 96% / .5); border-top:1px solid hsl(60 8% 96% / .14); padding-top:16px; display:inline-block; }
.hagents__title{ font:800 clamp(30px,4.8vw,58px)/1.02 var(--display); letter-spacing:-.022em; color:var(--bone); margin:22px 0 0; max-width:20ch; }
.hagents__title em{ color:var(--pulse); font-style:normal; }
.hagents__lede{ margin:22px 0 0; font:300 clamp(15px,1.5vw,18px)/1.6 var(--sans); color:hsl(60 8% 96% / .66); max-width:62ch; }
.hagents__stat{ margin-top:26px; font:800 32px/1 var(--display); letter-spacing:-.02em; color:var(--bone); font-variation-settings:"opsz" 36; }
.hagents__stat span{ font:500 11px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase; color:hsl(60 8% 96% / .5); padding-left:14px; }
/* The flex-column tile collapses its flex-item detail to 0 height (the site's
   0fr→1fr grid trick fails here), so instead of expanding in-tile we use a
   master-detail panel: the per-tile detail is the DATA SOURCE only (hidden), and
   clicking a tile renders its full description into the full-width #agentPanel
   below the grid — a normal block that always sizes to content, no clipping. */
.agent-tile__detail{ display:none !important; }
.agent-panel{
  grid-column:1 / -1; margin-top:6px; padding:clamp(26px,3.4vw,42px);
  background:var(--ink-2); border:1px solid hsl(184 90% 48% / .35); border-radius:18px;
  box-shadow:0 40px 90px -42px hsl(184 90% 30% / .45);
}
.agent-panel[hidden]{ display:none; }
.agent-panel__name{ font:800 clamp(24px,3vw,38px)/1.05 var(--display); letter-spacing:-.02em; color:var(--bone); margin-bottom:18px; }
.agent-panel .agent-tile__caps{ margin-bottom:18px; }
.agent-panel .agent-tile__caps i{ font-size:11px; padding:6px 10px; }
.agent-panel .agent-tile__full{ font:400 clamp(15px,1.5vw,17px)/1.7 var(--sans); color:hsl(60 8% 96% / .82); max-width:74ch; margin-top:0; }
.agent-panel .agent-tile__best{ margin-top:14px; font:500 13px/1.5 var(--mono); letter-spacing:.02em; color:var(--pulse); }
.agent-panel .agent-tile__foot{ margin-top:22px; padding-top:16px; max-width:320px; }
.agent-panel .agent-tile__cta{ margin-top:18px; font-size:12px; }
.agent-tile__full{ display:block; margin-top:12px; font:400 13.5px/1.62 var(--sans); color:hsl(60 8% 96% / .8); }
.agent-tile__best{ display:block; margin-top:10px; font:500 11.5px/1.5 var(--mono); letter-spacing:.02em; color:var(--pulse); }
.agent-tile__cta{ display:inline-block; margin-top:14px; font:500 11px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:hsl(60 8% 96% / .72); }
.agent-tile__cta:hover{ color:var(--pulse); }

/* ===========================================================================
   SHARED SOLUTION-PAGE LAYOUT  (/software /infrastructure /crm /growth /audits)
   Pages reuse the existing .section-light/.section-dark/.section-inner system
   for their body sections; the rules below add the hero, feature grids, the
   competitive "vs" frame, split blocks, price rows and CTA band.
   =========================================================================== */
.sol-hero{
  position:relative; min-height:92vh; min-height:92svh; isolation:isolate;
  background:var(--ink); color:var(--bone); overflow:hidden;
  display:flex; align-items:flex-end;
  padding:0 var(--gut) clamp(64px,10vh,110px);
}
.sol-anim{ position:absolute; inset:0; z-index:0; }
.sol-anim canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.sol-hero::after{   /* legibility wash */
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, hsl(220 30% 4% / .15) 0%, transparent 30%, hsl(220 30% 4% / .55) 78%, hsl(220 30% 4% / .82) 100%);
}
.sol-hero__inner{ position:relative; z-index:2; max-width:var(--max); margin:0 auto; width:100%; }
.sol-eyebrow{
  font:500 12px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase;
  color:hsl(60 8% 96% / .6); display:inline-flex; align-items:center; gap:11px; margin-bottom:26px;
}
.sol-eyebrow::before{ content:""; width:8px; height:8px; background:var(--pulse); box-shadow:0 0 12px 1px var(--pulse); }
.sol-hero h1{
  font:800 clamp(40px,7vw,92px)/0.98 var(--display); letter-spacing:-.025em;
  max-width:18ch; margin-bottom:30px;
}
.sol-hero h1 em{ color:var(--pulse); font-style:normal; }
.sol-hero__lede{
  font:300 clamp(17px,2vw,21px)/1.55 var(--sans); color:hsl(60 8% 96% / .78);
  max-width:60ch; margin-bottom:38px;
}
.sol-ctas{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.sol-btn{
  display:inline-flex; align-items:center; gap:10px;
  font:500 12px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase;
  border-radius:999px; padding:15px 26px; transition:all .4s var(--ease);
}
.sol-btn--primary{ background:var(--pulse); color:var(--ink); border:1px solid var(--pulse); }
.sol-btn--primary:hover{ background:transparent; color:var(--pulse); }
.sol-btn--ghost{ background:transparent; color:var(--bone); border:1px solid hsl(60 8% 96% / .35); position:relative; isolation:isolate; }
/* conic-gradient glow border on hover (mask-composite isolates a 1px ring) */
.sol-btn--ghost::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; z-index:-1; pointer-events:none;
  background:conic-gradient(from 0deg at 50% -10%, transparent, hsl(184 90% 48% / .55) 25%, hsl(184 90% 48% / .9) 50%, hsl(184 90% 48% / .55) 75%, transparent);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); mask-composite:exclude;
  opacity:0; transition:opacity .4s var(--ease);
}
.sol-btn--ghost:hover{ border-color:transparent; }
.sol-btn--ghost:hover::before{ opacity:1; }
/* proximity glow — ambient cyan as the cursor approaches a magnetic button */
a.magnetic{ transition:box-shadow .4s var(--ease); }
a.magnetic.near{ box-shadow:0 0 38px hsl(184 90% 48% / .26); }
.sol-btn .arrow, .sol-btn::after{ }
.sol-hero__meta{
  display:flex; flex-wrap:wrap; gap:0; margin-top:46px;
  border-top:var(--rule-bone); max-width:760px;
}
.sol-hero__meta div{ padding:18px 26px 0 0; margin-right:26px; }
.sol-hero__meta b{ display:block; font:700 26px/1 var(--display); letter-spacing:-.01em; color:var(--bone); }
.sol-hero__meta span{ display:block; margin-top:7px; font:500 11px/1.3 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .5); }

/* Feature grid (avenues) */
/* ROOT FIX (2026-06-20): flex-wrap + centered last row so tile blocks are ALWAYS
   symmetrical — an incomplete final row centres instead of left-orphaning, and it
   wraps responsively. Caps at 3 per row (max-width = 1/3); min-width forces wrap. */
.sol-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:18px; margin-top:50px; }
.sol-grid > *{ flex:1 1 calc((100% - 36px) / 3); max-width:calc((100% - 36px) / 3); min-width:min(100%, 264px); }
.sol-grid--2 > *{ flex-basis:calc((100% - 18px) / 2); max-width:calc((100% - 18px) / 2); }
.sol-card{
  border:1px solid hsl(220 14% 8% / .12); border-radius:16px; padding:30px 28px;
  background:var(--bone); transition:transform .45s var(--ease), border-color .45s var(--ease), box-shadow .45s var(--ease);
}
.sol-card:hover{ transform:translateY(-4px); border-color:hsl(184 90% 48% / .5); box-shadow:0 24px 50px -28px hsl(184 90% 30% / .45); }
.section-dark .sol-card{ background:var(--ink-2); border-color:hsl(60 8% 96% / .12); }
.sol-card__ix{ font:500 11px/1 var(--mono); letter-spacing:.16em; color:var(--ink-mute); display:flex; align-items:center; gap:9px; margin-bottom:22px; }
.section-dark .sol-card__ix{ color:hsl(60 8% 96% / .5); }
.sol-card__ix::before{ content:""; width:9px; height:9px; background:var(--pulse); box-shadow:0 0 12px 1px var(--pulse); }
.sol-card h3{ font:700 20px/1.15 var(--display); letter-spacing:-.01em; margin-bottom:11px; }
.sol-card p{ font:400 14.5px/1.6 var(--sans); color:var(--ink-3); }
.section-dark .sol-card p{ color:hsl(60 8% 96% / .68); }

/* Avenue checklist */
.sol-list{ list-style:none; margin:28px 0 0; padding:0; columns:2; column-gap:48px; }
.sol-list li{
  break-inside:avoid; padding:13px 0 13px 30px; position:relative;
  border-top:var(--rule); font:400 15px/1.5 var(--sans); color:var(--ink-3);
}
.section-dark .sol-list li{ border-top:var(--rule-bone); color:hsl(60 8% 96% / .72); }
.sol-list li::before{
  content:""; position:absolute; left:0; top:18px; width:11px; height:11px;
  border:1.5px solid var(--pulse); border-radius:50%;
  box-shadow:inset 0 0 0 2px var(--bone), 0 0 8px 0 hsl(184 90% 48% / .5);
}
.section-dark .sol-list li::before{ box-shadow:inset 0 0 0 2px var(--ink), 0 0 8px 0 hsl(184 90% 48% / .5); }
@media (max-width:680px){ .sol-list{ columns:1; } }

/* Competitive "Most agencies / We" frame */
.sol-vs{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:44px; }
.sol-vs__col{ border-radius:16px; padding:32px 30px; }
.sol-vs__col--them{ background:transparent; border:1px dashed hsl(220 14% 8% / .25); }
.section-dark .sol-vs__col--them{ border-color:hsl(60 8% 96% / .22); }
.sol-vs__col--us{ background:var(--ink); color:var(--bone); border:1px solid var(--ink); }
.section-dark .sol-vs__col--us{ background:var(--pulse); color:var(--ink); }
.sol-vs__tag{ font:500 11px/1 var(--mono); letter-spacing:.18em; text-transform:uppercase; opacity:.6; margin-bottom:16px; }
.sol-vs__col--us .sol-vs__tag{ opacity:.7; }
.sol-vs__col p{ font:400 17px/1.5 var(--sans); }
.sol-vs__col--them p{ color:var(--ink-3); }
.section-dark .sol-vs__col--them p{ color:hsl(60 8% 96% / .6); }
@media (max-width:680px){ .sol-vs{ grid-template-columns:1fr; } }

/* Split (text + visual) */
.sol-split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.sol-split--flip > div:first-child{ order:2; }
.sol-split__media{
  border-radius:18px; overflow:hidden; border:1px solid hsl(220 14% 8% / .12);
  background:var(--ink-2); aspect-ratio:4/3; position:relative;
}
.sol-split__media img{ width:100%; height:100%; object-fit:cover; display:block; }
@media (max-width:820px){ .sol-split{ grid-template-columns:1fr; } .sol-split--flip > div:first-child{ order:0; } }

/* Price rows */
.sol-prices{ margin-top:40px; border-top:var(--rule); }
.section-dark .sol-prices{ border-top:var(--rule-bone); }
.sol-price{
  display:flex; flex-wrap:wrap; align-items:baseline; gap:8px 18px;
  padding:20px 0; border-bottom:var(--rule);
}
.section-dark .sol-price{ border-bottom:var(--rule-bone); }
.sol-price__name{ font:600 16px/1.3 var(--sans); flex:1 1 240px; }
.sol-price__val{ font:700 18px/1 var(--display); color:var(--ink); white-space:nowrap; }
.section-dark .sol-price__val{ color:var(--pulse); }
.sol-price__note{ flex-basis:100%; font:400 13px/1.5 var(--sans); color:var(--ink-mute); }
.section-dark .sol-price__note{ color:hsl(60 8% 96% / .45); }
/* software deposits: short "deposit · scoped" disclaimer + add-to-cart on each from-priced item */
.sol-price__deposit{ flex-basis:100%; margin-top:2px; font:400 12px/1.5 var(--sans); color:hsl(60 8% 96% / .52); }
.section-light .sol-price__deposit{ color:var(--ink-mute); }
.sol-price__add{ flex:0 0 auto; margin-top:4px; font:700 13px/1 var(--sans); color:var(--ink); background:var(--pulse); border:1px solid var(--pulse); border-radius:999px; padding:11px 17px; text-decoration:none; white-space:nowrap; transition:.2s var(--ease); }
.sol-price__add:hover, .sol-price__add.is-added{ background:var(--bone); border-color:var(--bone); color:var(--ink); }
.sol-price__add--ghost{ background:transparent; color:var(--bone); border-color:hsl(60 8% 96% / .28); }
.section-light .sol-price__add--ghost{ color:var(--ink); border-color:hsl(220 14% 8% / .25); }
.sol-price__add--ghost:hover{ background:transparent; border-color:var(--pulse); color:var(--pulse); }
/* infra pricing rows: a per-row CTA → free assessment (no cart; scoped/managed services) */
.sol-price__cta{ flex:0 0 auto; margin-top:8px; font:600 11.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--pulse); text-decoration:none; transition:.18s var(--ease); }
.sol-price__cta:hover{ color:var(--bone); letter-spacing:.13em; }
.section-light .sol-price__cta:hover{ color:var(--ink); }

/* CTA band */
.sol-cta-band{ background:var(--ink); color:var(--bone); padding:clamp(80px,12vh,140px) var(--gut); position:relative; overflow:hidden; }
.sol-cta-band__inner{ max-width:var(--max); margin:0 auto; position:relative; z-index:2; }
.sol-cta-band h2{ font:800 clamp(30px,5vw,60px)/1.02 var(--display); letter-spacing:-.022em; max-width:20ch; margin-bottom:22px; }
.sol-cta-band h2 em{ color:var(--pulse); font-style:normal; }
.sol-cta-band p{ font:300 clamp(16px,1.6vw,19px)/1.55 var(--sans); color:hsl(60 8% 96% / .72); max-width:52ch; margin-bottom:36px; }

.sol-prose{ max-width:var(--max); margin:0 auto; padding:0 var(--gut); }
.sol-tagline{ font:500 clamp(20px,2.6vw,30px)/1.4 var(--display); letter-spacing:-.01em; max-width:24ch; }
.sol-tagline em{ color:var(--pulse); font-style:normal; }

/* ---------------------------------------------- UNIFIED GALLERY — live build cards
   (designs use the existing .gcard image thumb; builds reuse .gcard with a live
   scaled iframe + a "Live" badge, so the two card types sit in one grid.) */
/* perf: 489 cards in one grid — let the browser skip rendering/layout for the
   off-screen IMAGE cards (it remembers each card's real height after first
   paint, so the intrinsic-size estimate only affects never-yet-seen cards).
   Deliberately NOT applied to .gcard--build: those carry a live iframe loaded
   by an IntersectionObserver, and content-visibility skipping a subtree can
   delay descendant IO notifications — the live cards are kept lean instead by
   tearing their iframe down once it scrolls out of view (see GalleryGrid). */
.gcard:not(.gcard--build){ content-visibility:auto; contain-intrinsic-size:auto 360px; }
.gcard__thumb--live{ position:relative; }
.gcard__thumb--live iframe{
  position:absolute; top:0; left:0; width:250%; height:250%;
  transform:scale(.4); transform-origin:0 0; border:0; pointer-events:none;
}
.gcard__live{
  position:absolute; top:9px; left:9px; z-index:3;
  font:600 9.5px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  padding:5px 8px; border-radius:999px; background:hsl(220 14% 8% / .72);
  color:var(--pulse); backdrop-filter:blur(6px);
}
.gcard__open{
  position:absolute; right:9px; bottom:9px; z-index:3;
  font:500 10.5px/1 var(--sans); text-decoration:none;
  background:hsl(220 14% 8% / .72); color:var(--bone);
  border:1px solid hsl(60 8% 96% / .25); padding:6px 9px; border-radius:7px;
  opacity:0; transition:opacity .18s var(--ease); backdrop-filter:blur(6px);
}
.gcard--build:hover .gcard__open{ opacity:1; }
.gcard__ph{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font:500 11px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .35);
}
.gcard--build .gcard__anim{ color:var(--pulse); border-color:hsl(184 90% 48% / .35) !important; }

/* ---------------------------------------------- TIER BONUSES (pricing packs)
   Highlighted "included free" block under a tier's features. Reads on both the
   light (Gold/Diamond) cards and the dark featured (Platinum) card. */
.tier__bonus{
  margin:18px 0 6px; padding:15px 16px 13px; border-radius:12px;
  background:hsl(184 90% 48% / .09); border:1px solid hsl(184 90% 48% / .3);
}
.tier.is-feature .tier__bonus{ background:hsl(184 90% 48% / .14); border-color:hsl(184 90% 48% / .4); }
.tier__bonus-label{
  font:600 10px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase;
  color:var(--eucalypt-2); margin-bottom:11px; display:flex; align-items:center; gap:7px;
}
.tier.is-feature .tier__bonus-label{ color:var(--pulse); }
.tier__bonus-label::before{ content:"★"; color:var(--pulse); font-size:11px; }
.tier__bonus-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.tier__bonus-list li{
  position:relative; padding-left:20px; font:500 13px/1.45 var(--sans); color:var(--ink);
}
.tier.is-feature .tier__bonus-list li{ color:hsl(60 8% 96% / .92); }
.tier__bonus-list li::before{ content:"+"; position:absolute; left:3px; top:0; color:var(--pulse); font-weight:700; }
/* "Starts at" lead on the website-pack prices */
.tier__price-lead{ font:500 14px/1 var(--sans); color:var(--ink-3); letter-spacing:0; }
.tier.is-feature .tier__price-lead{ color:hsl(60 8% 96% / .6); }

/* ---------------------------------------------- MAGNETIC PRICING TILES
   3D cursor-tilt + a cursor-tracked glare layer on the tier cards (ported from
   premium/techniques/11-magnetic-tilt, softened to ±8°). Wired by an inline
   controller in Base.astro that injects .tier__glare + the pointer handlers. */
.tier{ transform-style:preserve-3d; will-change:transform; transition:box-shadow .4s var(--ease), border-color .4s var(--ease); }
/* real-time tilt; smooth flatten on leave via .is-tilt-reset (toggled by the Base.astro controller). */
.tier.is-tilt-reset{ transition:transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .4s var(--ease), border-color .4s var(--ease); }
.tier__glare{
  position:absolute; inset:0; border-radius:inherit; z-index:4; opacity:0;
  mix-blend-mode:overlay; pointer-events:none; transform:translateZ(3px);
  transition:opacity .3s var(--ease);
  background:radial-gradient(42% 52% at var(--gx,50%) var(--gy,50%), rgba(255,255,255,.55), rgba(255,255,255,0) 62%);
}
@media (prefers-reduced-motion:reduce){ .tier{ transform:none !important; transition:none; } }
@media (max-width:600px){ .tier{ transform:none !important; } }

/* ---------------------------------------------- 5-UP ESTIMATE ROW (compact tiles) */
.tier-grid--5{ grid-template-columns:repeat(5,1fr); gap:14px; }
.tier--compact{ padding:26px 22px 24px; }
.tier--compact .tier__num{ font-size:9.5px; }
.tier--compact .tier__name{ font-size:21px; }
.tier--compact .tier__price{ font-size:30px; }
.tier--compact .tier__price small{ font-size:10.5px; }
.tier--compact .tier__list{ font-size:12.5px; }
.tier--compact .tier__list li{ padding-left:18px; }
.tier--compact .tier__cta{ font-size:11px; }
@media (max-width:1180px){ .tier-grid--5{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:760px){  .tier-grid--5{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){  .tier-grid--5{ grid-template-columns:1fr; } }

/* ---------------------------------------------- HOW IT WORKS — animated carousel */
.hiw{ background:var(--ink); color:var(--bone); padding:clamp(90px,12vh,150px) 0; }
.hiw .section-eyebrow{ color:hsl(60 8% 96% / .5); border-top-color:hsl(60 8% 96% / .14); }
.hiw .section-head{ color:var(--bone); }
.hiw .section-lede{ color:hsl(60 8% 96% / .66); }
.hiw__carousel{ margin-top:44px; position:relative; }
.hiw__viewport{ overflow:hidden; border:1px solid hsl(60 8% 96% / .12); border-radius:20px; background:var(--ink-2); }
.hiw__track{ display:flex; transition:transform .65s var(--ease); will-change:transform; }
.hiw__slide{ flex:0 0 100%; display:grid; grid-template-columns:auto 1fr; gap:clamp(24px,5vw,72px); align-items:center; padding:clamp(34px,5vw,72px); }
.hiw__num{ font:800 clamp(64px,12vw,150px)/0.9 var(--display); letter-spacing:-.04em; color:var(--pulse); opacity:.22; transition:opacity .6s var(--ease); }
.hiw__slide.is-active .hiw__num{ opacity:1; }
.hiw__content{ max-width:58ch; }
.hiw__title{ font:800 clamp(26px,3.4vw,44px)/1.05 var(--display); letter-spacing:-.02em; color:var(--bone); margin-bottom:18px; opacity:0; transform:translateY(14px); transition:opacity .5s var(--ease) .15s, transform .5s var(--ease) .15s; }
.hiw__desc{ font:300 clamp(15px,1.7vw,19px)/1.6 var(--sans); color:hsl(60 8% 96% / .72); opacity:0; transform:translateY(14px); transition:opacity .5s var(--ease) .25s, transform .5s var(--ease) .25s; }
.hiw__meta{ margin-top:22px; font:500 12px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:var(--pulse); opacity:0; transition:opacity .5s var(--ease) .35s; }
.hiw__slide.is-active .hiw__title, .hiw__slide.is-active .hiw__desc, .hiw__slide.is-active .hiw__meta{ opacity:1; transform:none; }
.hiw__foot{ display:flex; align-items:center; gap:14px; margin-top:24px; }
.hiw__arrow{ flex:none; width:44px; height:44px; border-radius:50%; border:1px solid hsl(60 8% 96% / .2); background:transparent; color:var(--bone); font:300 22px/1 var(--sans); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:border-color .3s var(--ease), background-color .3s var(--ease); }
.hiw__arrow:hover{ border-color:var(--pulse); background:hsl(184 90% 48% / .1); }
.hiw__steps{ flex:1; display:flex; gap:6px; min-width:0; }
.hiw__step{ flex:1 1 0; min-width:0; display:flex; flex-direction:column; gap:5px; align-items:flex-start; text-align:left; padding:12px 14px; border-radius:10px; background:transparent; border:1px solid transparent; cursor:pointer; transition:background-color .3s var(--ease), border-color .3s var(--ease); }
.hiw__step:hover{ background:hsl(60 8% 96% / .05); }
.hiw__step.is-active{ background:hsl(184 90% 48% / .08); border-color:hsl(184 90% 48% / .3); }
.hiw__step-n{ font:600 11px/1 var(--mono); letter-spacing:.1em; color:hsl(60 8% 96% / .4); }
.hiw__step.is-active .hiw__step-n{ color:var(--pulse); }
.hiw__step-t{ font:500 12.5px/1.2 var(--sans); color:hsl(60 8% 96% / .6); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%; }
.hiw__step.is-active .hiw__step-t{ color:var(--bone); }
.hiw__bar{ height:2px; background:hsl(60 8% 96% / .1); margin-top:18px; border-radius:2px; overflow:hidden; }
.hiw__bar i{ display:block; height:100%; width:20%; background:var(--pulse); box-shadow:0 0 12px 1px var(--pulse); transition:width .65s var(--ease); }
@media (max-width:680px){
  .hiw__slide{ grid-template-columns:1fr; gap:16px; }
  .hiw__steps{ gap:8px; }
  .hiw__step{ flex:0 0 auto; align-items:center; padding:10px 12px; }
  .hiw__step-t{ display:none; }
}

/* ---------------------------------------------- HERO PACK KICKER
   Clear page/pack identifier shown above the hero headline, consistent
   across the .page-hero pages; colour themed per website tier. */
.pack-kicker{ margin:0 0 22px; }
.pack-kicker__name{
  display:block;
  font:700 clamp(16px,1.7vw,21px)/1 var(--mono);
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--pulse);
  text-shadow:0 0 26px hsl(184 90% 48% / .35);
}
.pack-kicker__facts{
  display:block; margin-top:10px;
  font:500 12px/1.5 var(--mono); letter-spacing:.13em; text-transform:uppercase;
  color:hsl(60 8% 96% / .62);
}
.pack-kicker--gold .pack-kicker__name{ color:hsl(45 96% 64%); text-shadow:0 0 28px hsl(43 92% 55% / .45); }
.pack-kicker--platinum .pack-kicker__name{ color:hsl(210 16% 87%); text-shadow:0 0 26px hsl(210 40% 82% / .40); }
.pack-kicker--diamond .pack-kicker__name{ color:hsl(0 0% 98%); text-shadow:0 0 30px hsl(200 70% 85% / .55); }
@media (max-width:600px){
  .pack-kicker__name{ letter-spacing:.12em; }
  .pack-kicker__facts{ font-size:11px; letter-spacing:.1em; }
}

/* ── homepage agent tiles: price on the face (2026-06-20) ── */
.agent-tile__facemain{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.agent-tile__faceprice{ font-family:var(--display); font-weight:700; font-size:13px; line-height:1; color:var(--pulse); letter-spacing:-.01em; }
.agent-tile__faceprice small{ font:500 10px/1 var(--mono); color:hsl(60 8% 96% / .5); letter-spacing:.04em; margin-left:1px; }

/* ── agents page: clickable fleet cards → full-screen descriptor takeover ── */
.agent[data-agent]{ cursor:pointer; }
.agent__more{ display:inline-flex; align-items:center; gap:6px; margin-top:12px; font:600 11px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(184 90% 48% / .85); transition:gap .25s var(--ease), color .25s var(--ease); }
.agent[data-agent]:hover .agent__more{ gap:10px; color:var(--pulse); }

.agentx{ position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:clamp(14px,4vw,48px); }
.agentx[hidden]{ display:none; }
.agentx__scrim{ position:absolute; inset:0; background:hsl(220 20% 3% / .74); backdrop-filter:blur(7px); animation:agentxFade .25s var(--ease); }
.agentx__panel{ position:relative; z-index:1; width:min(760px,100%); max-height:90vh; overflow:auto; background:var(--ink-2); border:1px solid hsl(184 90% 48% / .22); border-radius:20px; padding:clamp(26px,4vw,46px); box-shadow:0 50px 130px -30px hsl(220 40% 2% / .92); animation:agentxRise .3s var(--ease); }
@keyframes agentxFade{ from{ opacity:0; } }
@keyframes agentxRise{ from{ opacity:0; transform:translateY(18px); } }
.agentx__close{ position:absolute; top:15px; right:15px; width:38px; height:38px; border-radius:50%; border:1px solid hsl(60 8% 96% / .18); background:hsl(220 14% 9%); color:var(--bone); font-size:14px; line-height:1; cursor:pointer; transition:.2s var(--ease); z-index:2; }
.agentx__close:hover{ border-color:var(--pulse); color:var(--pulse); }
.agentx__kicker{ font:600 11px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase; color:hsl(60 8% 96% / .5); }
.agentx__name{ font:800 clamp(26px,3.6vw,40px)/1.04 var(--display); letter-spacing:-.02em; color:var(--bone); margin:10px 36px 0 0; }
.agentx__name em{ font-style:normal; color:var(--pulse); }
.agentx__lede{ font:300 clamp(15px,1.7vw,17px)/1.62 var(--sans); color:hsl(60 8% 96% / .82); margin:16px 0 0; }
.agentx__sect{ margin-top:26px; }
.agentx__sect h4{ font:600 11px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:hsl(60 8% 96% / .5); margin:0 0 12px; }
.agentx__caps{ display:flex; flex-wrap:wrap; gap:7px; }
.agentx__cap{ font:500 11px/1 var(--mono); letter-spacing:.06em; text-transform:uppercase; color:hsl(60 8% 96% / .82); border:1px solid hsl(60 8% 96% / .18); padding:7px 10px; border-radius:999px; }
.agentx__sect > p{ font:300 15px/1.6 var(--sans); color:hsl(60 8% 96% / .8); margin:0; }
.agentx__roi{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.agentx__metric{ background:hsl(220 14% 9%); border:1px solid hsl(60 8% 96% / .1); border-radius:13px; padding:15px 13px; }
.agentx__metric b{ display:block; font:800 21px/1.05 var(--display); letter-spacing:-.02em; color:var(--bone); }
.agentx__metric b small{ font:500 11px/1 var(--mono); color:hsl(60 8% 96% / .5); letter-spacing:.02em; }
.agentx__metric span{ display:block; margin-top:8px; font:500 10px/1.3 var(--mono); letter-spacing:.07em; text-transform:uppercase; color:hsl(60 8% 96% / .5); }
.agentx__metric--hi{ border-color:hsl(184 90% 48% / .5); background:hsl(184 90% 48% / .09); }
.agentx__metric--hi b{ color:var(--pulse); }
.agentx__basis{ margin:13px 0 0; font:300 13px/1.55 var(--sans); color:hsl(60 8% 96% / .62); }
.agentx__foot{ display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.agentx__add{ font:700 14px/1 var(--sans); color:var(--ink); background:var(--pulse); border-radius:999px; padding:14px 22px; text-decoration:none; transition:.2s var(--ease); }
.agentx__add:hover{ background:var(--bone); }
.agentx__assess{ font:600 14px/1 var(--sans); color:var(--bone); border:1px solid hsl(60 8% 96% / .2); border-radius:999px; padding:13px 20px; text-decoration:none; transition:.2s var(--ease); }
.agentx__assess:hover{ border-color:var(--pulse); color:var(--pulse); }
.agentx__disc{ margin:18px 0 0; font:400 11px/1.5 var(--mono); letter-spacing:.02em; color:hsl(60 8% 96% / .42); }
@media (max-width:560px){ .agentx__roi{ grid-template-columns:repeat(2,1fr); } }
@media (prefers-reduced-motion:reduce){ .agentx__scrim, .agentx__panel{ animation:none; } }

/* ── checkout intake fields (business details + optional preferences) ── */
.checkout-row{ display:grid; grid-template-columns:1fr 1fr; gap:0 18px; }
@media (max-width:560px){ .checkout-row{ grid-template-columns:1fr; } }
.checkout-note{ margin:-4px 0 4px; font:400 12.5px/1.5 var(--sans); color:hsl(220 14% 8% / .55); }
.intake-optional{ margin-top:26px; padding-top:24px; border-top:1px solid hsl(220 14% 8% / .12); }
.intake-optional__head{ font:700 13px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:hsl(220 14% 8% / .82); }
.intake-optional__head span{ font-weight:500; letter-spacing:.02em; text-transform:none; color:hsl(220 14% 8% / .5); }
.intake-group{ border:0; padding:0; margin:20px 0 0; min-inline-size:0; }
.intake-group legend{ padding:0; font:600 14px/1.3 var(--sans); color:hsl(220 14% 8% / .9); margin-bottom:11px; }
.intake-pills{ display:flex; flex-wrap:wrap; gap:9px; }
.intake-pill{ position:relative; display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border:1px solid hsl(220 14% 8% / .18); border-radius:999px; cursor:pointer; font:500 13.5px/1 var(--sans); color:hsl(220 14% 8% / .82); background:#fff; transition:.18s var(--ease); user-select:none; }
.intake-pill:hover{ border-color:hsl(184 90% 38% / .6); }
.intake-pill input{ position:absolute; opacity:0; width:0; height:0; }
.intake-pill span{ pointer-events:none; }
.intake-pill:has(input:checked){ border-color:var(--pulse); background:hsl(184 90% 48% / .1); color:hsl(220 14% 8%); box-shadow:inset 0 0 0 1px var(--pulse); }
.intake-attached{ flex-basis:100%; margin-bottom:4px; font:500 13px/1.5 var(--sans); color:hsl(220 14% 8% / .7); }
.intake-attached b{ color:hsl(220 14% 8%); }
.intake-browse{ margin-top:13px; }
.intake-browse__lbl{ display:block; font:500 12.5px/1.4 var(--sans); color:hsl(220 14% 8% / .6); margin-bottom:8px; }
.intake-browse__row{ display:flex; flex-wrap:wrap; gap:9px; }
.intake-select{ font:500 13.5px/1 var(--sans); color:hsl(220 14% 8%); background:#fff; border:1px solid hsl(220 14% 8% / .18); border-radius:999px; padding:11px 16px; cursor:pointer; }
.intake-browse__btn{ font:700 13.5px/1 var(--sans); color:var(--ink); background:var(--pulse); border:1px solid var(--pulse); border-radius:999px; padding:11px 18px; cursor:pointer; transition:.18s var(--ease); }
.intake-browse__btn:hover{ background:var(--ink); color:var(--bone); border-color:var(--ink); }

/* ── rolling screenshot wall behind hero — SHARED (used on /web/templates + /web).
   Brightened 2026-06-20: opacity .34→.5, +brightness(1.06), lighter scrim. ── */
.page-hero--wall{ position:relative; overflow:hidden; }
.page-hero--wall .page-hero__inner{ position:relative; z-index:3; }
.page-hero--wall .mesh-blob{ z-index:2; }
.hwall{ position:absolute; inset:0; z-index:1; display:flex; gap:14px; padding:0 12px; overflow:hidden; pointer-events:none;
  opacity:.5; filter:saturate(1) contrast(1.03) brightness(1.06);
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 14%, #000 66%, transparent); mask-image:linear-gradient(180deg, transparent, #000 14%, #000 66%, transparent); }
/* text-side scrim — darker on the left where the hero copy sits, lighter (more wall) on the right */
.hwall::after{ content:""; position:absolute; inset:0; background:linear-gradient(96deg, hsl(220 18% 5% / .86) 24%, hsl(220 18% 5% / .5) 54%, hsl(220 18% 5% / .2) 100%); }
.hwall__col{ flex:1 1 0; min-width:0; display:flex; flex-direction:column; gap:14px; animation:hwallUp linear infinite; will-change:transform; }
.hwall__col--down{ animation-name:hwallDown; }
.hwall__img{ width:100%; aspect-ratio:16/10; object-fit:cover; object-position:top center; border-radius:9px; border:1px solid hsl(60 8% 96% / .1); box-shadow:0 8px 24px hsl(220 14% 2% / .5); display:block; }
@keyframes hwallUp{ from{ transform:translateY(0); } to{ transform:translateY(-50%); } }
@keyframes hwallDown{ from{ transform:translateY(-50%); } to{ transform:translateY(0); } }
@media (max-width:820px){ .hwall__col:nth-child(n+4){ display:none; } .hwall::after{ background:linear-gradient(180deg, hsl(220 18% 5% / .6), hsl(220 18% 5% / .86)); } }
@media (prefers-reduced-motion: reduce){ .hwall__col{ animation:none; } }

/* ══════════════════════════════════════════════════════════════════════════
   CRM SHOWCASE — sticky-scroll dashboard mockup (crm.astro)
   Class prefix: .crmsc-*
   5 views: pipeline / contacts / detail / invoicing / reporting
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Section shell ── */
.crmsc-section{
  background:var(--ink);
  color:var(--bone);
  padding:clamp(90px,12vh,150px) 0 clamp(100px,14vh,180px);
  position:relative;
  /* NO overflow:hidden here — an overflow ancestor breaks position:sticky on the
     screen-wrap. The ::before dot-grid is inset:0 (already contained), nothing to clip. */
}
/* Faint dot-grid backdrop */
.crmsc-section::before{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(circle, hsl(60 8% 96% / .05) 1px, transparent 1px);
  background-size:32px 32px;
  z-index:0;
}
.crmsc-inner{
  position:relative; z-index:1;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gut);
}
.crmsc-intro{ max-width:60ch; margin-bottom:clamp(48px,7vh,80px); }
.crmsc-intro .section-eyebrow{
  color:hsl(60 8% 96% / .5);
  border-top-color:hsl(60 8% 96% / .14);
}
.crmsc-intro .section-head{ color:var(--bone); }
.crmsc-intro .section-lede{ color:hsl(60 8% 96% / .66); margin-top:18px; }

/* ── 2-column sticky layout ── */
.crmsc-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);
  align-items:start;
}

/* ── LEFT: sticky screen ── */
/* full-viewport sticky column → the screen stays PINNED + vertically CENTRED for the
   entire copy scroll, instead of pinning at the top and sliding out partway through */
.crmsc-screen-wrap{
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  align-items:center;
}
.crmsc-screen{
  width:100%;
  /* FIXED screen height so it never resizes as views swap (a stable "app window") */
  height:clamp(480px, 66vh, 600px);
  background:hsl(220 18% 10%);
  border:1px solid hsl(60 8% 96% / .1);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 40px 100px -40px hsl(220 40% 2% / .85),
             0 0 0 1px hsl(60 8% 96% / .05);
  position:relative;
}
/* Crossfade: each view absolutely stacked, opacity controlled by JS */
.crmsc-view{
  position:absolute; inset:0; opacity:0;
  transition:opacity .5s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.crmsc-view.is-active{
  opacity:1;
  pointer-events:auto;
}
/* Reduced-motion: no cross-fade, just show/hide */
@media (prefers-reduced-motion:reduce){
  .crmsc-view{ transition:none; }
}

/* ── Shared mockup chrome ── */
.crmsc-chrome{
  display:flex;
  height:100%;
}

/* Sidebar */
.crmsc-sidebar{
  width:52px;
  background:hsl(220 20% 8%);
  border-right:1px solid hsl(60 8% 96% / .07);
  display:flex; flex-direction:column;
  align-items:center; padding:16px 0; gap:6px;
  flex:none;
}
.crmsc-sidebar__logo{
  width:26px; height:26px;
  background:var(--pulse);
  border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:14px;
  box-shadow:0 0 18px hsl(184 90% 48% / .4);
}
.crmsc-sidebar__logo svg{ width:14px; height:14px; fill:var(--ink); }
.crmsc-nav-item{
  width:36px; height:36px; border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:background-color .2s;
  color:hsl(60 8% 96% / .35);
}
.crmsc-nav-item:hover{ background:hsl(60 8% 96% / .07); color:hsl(60 8% 96% / .7); }
.crmsc-nav-item.is-active{
  background:hsl(184 90% 48% / .14);
  color:var(--pulse);
  box-shadow:inset 1px 0 0 var(--pulse);
}
.crmsc-nav-item svg{ width:16px; height:16px; }

/* Main area */
.crmsc-main{ flex:1; min-width:0; display:flex; flex-direction:column; }

/* Top bar */
.crmsc-topbar{
  height:48px; flex:none;
  border-bottom:1px solid hsl(60 8% 96% / .07);
  background:hsl(220 18% 9%);
  display:flex; align-items:center; gap:12px;
  padding:0 16px;
}
.crmsc-topbar__title{
  font:600 13px/1 var(--sans);
  color:var(--bone);
  flex:1;
}
.crmsc-search{
  display:flex; align-items:center; gap:7px;
  background:hsl(220 18% 13%);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:7px; padding:6px 10px;
  font:400 11.5px/1 var(--sans);
  color:hsl(60 8% 96% / .35);
  min-width:140px;
}
.crmsc-search svg{ width:12px; height:12px; flex:none; }
.crmsc-avatar{
  width:28px; height:28px; border-radius:50%;
  background:hsl(260 50% 55%);
  font:600 11px/28px var(--sans);
  text-align:center; color:#fff; flex:none;
}

/* Content area */
.crmsc-content{
  flex:1; overflow:hidden;
  padding:18px;
  background:hsl(220 16% 11%);
  display:flex; flex-direction:column; gap:14px;
}

/* ── View 1: Pipeline / Kanban ── */
.crmsc-kanban{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.crmsc-col__head{
  font:600 10px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase;
  color:hsl(60 8% 96% / .4); margin-bottom:8px; display:flex; align-items:center; justify-content:space-between;
}
.crmsc-col__count{
  font:600 9.5px/16px var(--mono); min-width:18px; text-align:center;
  background:hsl(60 8% 96% / .08); border-radius:999px; padding:0 5px;
  color:hsl(60 8% 96% / .5);
}
.crmsc-col--won .crmsc-col__head{ color:hsl(152 70% 52% / .9); }
.crmsc-col--won .crmsc-col__count{ background:hsl(152 70% 52% / .15); color:hsl(152 70% 55%); }

.crmsc-deal{
  background:hsl(220 18% 15%);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:9px; padding:10px 11px; margin-bottom:7px;
  cursor:pointer;
  transition:border-color .2s, background-color .2s, transform .2s;
}
.crmsc-deal:hover{
  border-color:hsl(184 90% 48% / .5);
  background:hsl(220 18% 17%);
  transform:translateY(-1px);
}
.crmsc-deal__company{ font:600 11.5px/1.3 var(--sans); color:var(--bone); margin-bottom:5px; }
.crmsc-deal__val{ font:700 12px/1 var(--display); color:var(--pulse); letter-spacing:-.01em; }
.crmsc-deal__meta{
  display:flex; align-items:center; justify-content:space-between; margin-top:8px;
}
.crmsc-deal__owner{
  width:18px; height:18px; border-radius:50%;
  font:600 8.5px/18px var(--sans); text-align:center; color:#fff;
  flex:none;
}
.crmsc-deal__days{ font:400 10px/1 var(--mono); color:hsl(60 8% 96% / .35); }

/* Pipeline summary bar */
.crmsc-pipeline-bar{
  background:hsl(220 18% 13%);
  border:1px solid hsl(60 8% 96% / .07);
  border-radius:9px; padding:10px 14px;
  display:flex; align-items:center; gap:18px;
}
.crmsc-pstat{ display:flex; flex-direction:column; gap:3px; }
.crmsc-pstat__val{ font:700 16px/1 var(--display); color:var(--bone); letter-spacing:-.02em; }
.crmsc-pstat__val--pulse{ color:var(--pulse); }
.crmsc-pstat__lbl{ font:500 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .35); }
.crmsc-pipeline-bar__div{ width:1px; height:28px; background:hsl(60 8% 96% / .08); }

/* ── View 2: Contacts table ── */
.crmsc-table{ width:100%; border-collapse:collapse; }
.crmsc-table th{
  font:600 9.5px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  color:hsl(60 8% 96% / .35); padding:0 10px 10px 0; border-bottom:1px solid hsl(60 8% 96% / .07);
  text-align:left; white-space:nowrap;
}
.crmsc-table td{
  padding:9px 10px 9px 0; border-bottom:1px solid hsl(60 8% 96% / .05);
  font:400 12px/1.3 var(--sans); color:hsl(60 8% 96% / .8);
  vertical-align:middle;
}
.crmsc-table tr:hover td{ background:hsl(60 8% 96% / .03); }
.crmsc-table tr:last-child td{ border-bottom:none; }
.crmsc-contact-name{
  display:flex; align-items:center; gap:8px;
}
.crmsc-contact-av{
  width:24px; height:24px; border-radius:50%;
  font:600 10px/24px var(--sans); text-align:center; color:#fff; flex:none;
}
.crmsc-contact-nm{ font:600 12px/1 var(--sans); color:var(--bone); }
.crmsc-contact-co{ font:400 10.5px/1 var(--sans); color:hsl(60 8% 96% / .4); }
.crmsc-pill{
  font:600 10px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase;
  padding:4px 8px; border-radius:999px; white-space:nowrap; display:inline-block;
}
.crmsc-pill--active{ background:hsl(152 70% 52% / .15); color:hsl(152 70% 60%); }
.crmsc-pill--lead{ background:hsl(184 90% 48% / .14); color:var(--pulse); }
.crmsc-pill--inactive{ background:hsl(60 8% 96% / .06); color:hsl(60 8% 96% / .4); }
.crmsc-pill--paid{ background:hsl(152 70% 52% / .15); color:hsl(152 70% 60%); }
.crmsc-pill--overdue{ background:hsl(0 75% 55% / .15); color:hsl(0 75% 65%); }
.crmsc-pill--draft{ background:hsl(60 8% 96% / .07); color:hsl(60 8% 96% / .45); }

/* ── View 3: Customer detail / timeline ── */
.crmsc-detail{ display:grid; grid-template-columns:1fr 180px; gap:14px; }
.crmsc-timeline{ display:flex; flex-direction:column; gap:0; }
.crmsc-tl-item{
  display:flex; gap:10px; padding-bottom:14px;
  position:relative;
}
.crmsc-tl-item:last-child{ padding-bottom:0; }
/* vertical line */
.crmsc-tl-item:not(:last-child)::before{
  content:""; position:absolute; left:10px; top:22px; bottom:0; width:1px;
  background:hsl(60 8% 96% / .07);
}
.crmsc-tl-dot{
  width:20px; height:20px; border-radius:50%; flex:none; margin-top:1px;
  display:flex; align-items:center; justify-content:center;
  font-size:9px; position:relative; z-index:1;
}
.crmsc-tl-dot--call{ background:hsl(184 90% 48% / .2); color:var(--pulse); }
.crmsc-tl-dot--email{ background:hsl(260 50% 55% / .2); color:hsl(260 60% 70%); }
.crmsc-tl-dot--inv{ background:hsl(152 70% 52% / .18); color:hsl(152 70% 55%); }
.crmsc-tl-dot--note{ background:hsl(40 90% 55% / .18); color:hsl(40 90% 62%); }
.crmsc-tl-body{ flex:1; min-width:0; }
.crmsc-tl-type{
  font:600 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase;
  color:hsl(60 8% 96% / .4); margin-bottom:3px;
}
.crmsc-tl-desc{ font:400 11.5px/1.4 var(--sans); color:hsl(60 8% 96% / .75); }
.crmsc-tl-time{ font:400 10px/1 var(--mono); color:hsl(60 8% 96% / .28); margin-top:4px; }

/* detail sidebar */
.crmsc-detail-sidebar{ display:flex; flex-direction:column; gap:10px; }
.crmsc-detail-tag{
  font:600 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase;
  padding:5px 9px; border-radius:999px; display:inline-block;
  border:1px solid hsl(60 8% 96% / .1); color:hsl(60 8% 96% / .55);
}
.crmsc-next-action{
  background:hsl(184 90% 48% / .09);
  border:1px solid hsl(184 90% 48% / .3);
  border-radius:10px; padding:12px;
}
.crmsc-next-action__lbl{
  font:600 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase;
  color:var(--pulse); margin-bottom:6px;
}
.crmsc-next-action__text{ font:400 11.5px/1.4 var(--sans); color:hsl(60 8% 96% / .75); }
.crmsc-next-action__date{ font:500 10.5px/1 var(--mono); color:hsl(60 8% 96% / .4); margin-top:5px; }

.crmsc-record-head{
  background:hsl(220 18% 13%); border:1px solid hsl(60 8% 96% / .07);
  border-radius:10px; padding:12px 14px;
  display:flex; align-items:center; gap:10px;
}
.crmsc-record-av{
  width:34px; height:34px; border-radius:50%;
  font:700 14px/34px var(--sans); text-align:center; color:#fff; flex:none;
}
.crmsc-record-name{ font:700 13px/1.2 var(--sans); color:var(--bone); }
.crmsc-record-co{ font:400 11px/1 var(--sans); color:hsl(60 8% 96% / .45); }

/* ── View 4: Invoicing ── */
.crmsc-inv-total{
  background:hsl(220 18% 13%); border:1px solid hsl(60 8% 96% / .07);
  border-radius:10px; padding:12px 14px;
  display:flex; align-items:center; gap:24px;
}
.crmsc-inv-stat{ display:flex; flex-direction:column; gap:3px; }
.crmsc-inv-stat__val{ font:800 18px/1 var(--display); color:var(--bone); letter-spacing:-.02em; }
.crmsc-inv-stat__val--green{ color:hsl(152 70% 55%); }
.crmsc-inv-stat__val--red{ color:hsl(0 75% 65%); }
.crmsc-inv-stat__lbl{ font:500 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .35); }
.crmsc-inv-div{ width:1px; height:32px; background:hsl(60 8% 96% / .08); }

.crmsc-connections{
  display:flex; align-items:center; gap:8px;
  background:hsl(220 18% 13%); border:1px solid hsl(60 8% 96% / .07);
  border-radius:10px; padding:10px 14px;
}
.crmsc-connections__lbl{
  font:600 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase;
  color:hsl(60 8% 96% / .35); margin-right:4px;
}
.crmsc-conn-badge{
  font:700 10px/1 var(--mono); padding:5px 9px; border-radius:999px;
  letter-spacing:.06em;
}
.crmsc-conn-badge--stripe{ background:hsl(255 60% 55% / .18); color:hsl(255 70% 70%); border:1px solid hsl(255 60% 55% / .25); }
.crmsc-conn-badge--xero{ background:hsl(196 90% 48% / .14); color:hsl(196 90% 60%); border:1px solid hsl(196 90% 48% / .25); }
.crmsc-conn-badge--square{ background:hsl(152 55% 42% / .14); color:hsl(152 70% 55%); border:1px solid hsl(152 55% 42% / .25); }

/* ── View 5: Reporting charts ── */
.crmsc-charts{ display:grid; grid-template-columns:1fr 120px; gap:14px; }
.crmsc-chart-box{
  background:hsl(220 18% 13%); border:1px solid hsl(60 8% 96% / .07);
  border-radius:10px; padding:14px;
}
.crmsc-chart-title{
  font:600 10px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  color:hsl(60 8% 96% / .4); margin-bottom:12px;
}
/* bar chart rows */
.crmsc-bar-row{ display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.crmsc-bar-row:last-child{ margin-bottom:0; }
.crmsc-bar-label{ font:400 10.5px/1 var(--sans); color:hsl(60 8% 96% / .55); min-width:72px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.crmsc-bar-track{ flex:1; height:8px; background:hsl(60 8% 96% / .07); border-radius:999px; overflow:hidden; }
.crmsc-bar-fill{ height:100%; border-radius:999px; background:var(--pulse); box-shadow:0 0 8px hsl(184 90% 48% / .4); }
.crmsc-bar-val{ font:600 10px/1 var(--mono); color:hsl(60 8% 96% / .5); min-width:36px; text-align:right; }

/* donut */
.crmsc-donut-wrap{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.crmsc-donut-wrap svg{ width:88px; height:88px; }
.crmsc-donut-legend{ display:flex; flex-direction:column; gap:6px; width:100%; }
.crmsc-donut-item{ display:flex; align-items:center; gap:6px; font:500 10px/1 var(--mono); color:hsl(60 8% 96% / .55); }
.crmsc-donut-item::before{ content:""; width:8px; height:8px; border-radius:2px; flex:none; }
.crmsc-donut-item--won::before{ background:var(--pulse); }
.crmsc-donut-item--lost::before{ background:hsl(0 75% 55%); }
.crmsc-donut-item--open::before{ background:hsl(60 8% 96% / .2); }

/* trend line row (inline SVG sparkline) */
.crmsc-trend-row{
  background:hsl(220 18% 13%); border:1px solid hsl(60 8% 96% / .07);
  border-radius:10px; padding:14px;
  display:flex; align-items:center; gap:16px;
}
.crmsc-trend-stat{ display:flex; flex-direction:column; gap:4px; min-width:80px; }
.crmsc-trend-big{ font:800 22px/1 var(--display); color:var(--bone); letter-spacing:-.02em; }
.crmsc-trend-lbl{ font:500 9.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .35); }
.crmsc-trend-up{ font:600 11px/1 var(--mono); color:hsl(152 70% 55%); }
.crmsc-trend-spark{ flex:1; }
.crmsc-trend-spark svg{ width:100%; height:44px; display:block; }

/* ── RIGHT: copy scroll track ── */
.crmsc-copy-track{
  display:flex; flex-direction:column;
  gap:0;
  padding:clamp(20px,3vh,40px) 0;
}
.crmsc-copy-block{
  /* ~one viewport tall, content vertically centred → each CRM view gets a "screen"
     of scroll and the sticky screen stays pinned+centred through all of them */
  min-height:96vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(40px,6vh,72px) 0;
  border-top:1px solid hsl(60 8% 96% / .08);
  opacity:.35;
  transition:opacity .5s cubic-bezier(.22,1,.36,1);
}
.crmsc-copy-block:first-child{ border-top:none; }
.crmsc-copy-block.is-active{ opacity:1; }
@media (prefers-reduced-motion:reduce){ .crmsc-copy-block{ transition:none; opacity:1; } }

.crmsc-copy-num{
  font:600 10px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase;
  color:var(--pulse); margin-bottom:12px;
  display:flex; align-items:center; gap:9px;
}
.crmsc-copy-num::before{
  content:""; width:6px; height:6px; background:var(--pulse);
  border-radius:50%; box-shadow:0 0 10px 1px var(--pulse);
}
.crmsc-copy-block.is-active .crmsc-copy-num::before{
  box-shadow:0 0 14px 3px var(--pulse);
}
.crmsc-copy-h{
  font:800 clamp(22px,2.8vw,34px)/1.1 var(--display);
  letter-spacing:-.02em; color:var(--bone); margin-bottom:14px;
}
.crmsc-copy-h em{ color:var(--pulse); font-style:normal; }
.crmsc-copy-p{
  font:300 clamp(15px,1.5vw,17px)/1.65 var(--sans);
  color:hsl(60 8% 96% / .66); max-width:46ch;
}
.crmsc-copy-chips{ display:flex; flex-wrap:wrap; gap:7px; margin-top:16px; }
.crmsc-copy-chip{
  font:500 10.5px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  border:1px solid hsl(60 8% 96% / .12);
  color:hsl(60 8% 96% / .5);
}

/* ── MOBILE STACK (<900px): no stickiness, each mockup above its copy ── */
@media (max-width:900px){
  .crmsc-layout{ grid-template-columns:1fr; gap:0; }
  .crmsc-screen-wrap{ position:static; margin-bottom:0; }
  .crmsc-copy-track{ padding:0; }
  /* Mobile: each copy block has its own screen above it */
  .crmsc-copy-block{ opacity:1 !important; padding:32px 0; min-height:0; display:block; }
  .crmsc-copy-block .crmsc-mobile-screen{
    display:block;
    margin-bottom:22px;
    border-radius:12px; overflow:hidden;
    border:1px solid hsl(60 8% 96% / .1);
  }
  /* Hide the sticky screen on mobile */
  .crmsc-screen-wrap--desktop{ display:none; }
  /* The views inside mobile screens */
  .crmsc-mobile-screen .crmsc-chrome{ min-height:340px; }
  .crmsc-sidebar{ width:44px; }
}
@media (min-width:901px){
  .crmsc-copy-block .crmsc-mobile-screen{ display:none; }
  .crmsc-screen-wrap--desktop{ display:flex; align-items:center; }
}

/* ════════════════════════════════════════════════════════════════════════════
   APPS SHOWCASE  (software.astro)
   Class prefix: .appsc-*
   5 views: ops-dashboard / booking-portal / saas-mvp / mobile-app / ecommerce
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Section shell ── */
.appsc-section{
  background:var(--ink);
  color:var(--bone);
  padding:clamp(90px,12vh,150px) 0 clamp(100px,14vh,180px);
  position:relative;
  /* NO overflow:hidden — an overflow ancestor breaks position:sticky */
}
.appsc-section::before{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(circle, hsl(60 8% 96% / .05) 1px, transparent 1px);
  background-size:32px 32px;
  z-index:0;
}
.appsc-inner{
  position:relative; z-index:1;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gut);
}
.appsc-intro{ max-width:60ch; margin-bottom:clamp(48px,7vh,80px); }
.appsc-intro .section-eyebrow{
  color:hsl(60 8% 96% / .5);
  border-top-color:hsl(60 8% 96% / .14);
}
.appsc-intro .section-head{ color:var(--bone); }
.appsc-intro .section-lede{ color:hsl(60 8% 96% / .66); margin-top:18px; }

/* ── 2-column sticky layout ── */
.appsc-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);
  align-items:start;
}

/* ── LEFT: sticky screen ── */
.appsc-screen-wrap{
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  align-items:center;
}
.appsc-screen{
  width:100%;
  height:clamp(480px, 66vh, 600px);
  background:hsl(220 18% 10%);
  border:1px solid hsl(60 8% 96% / .1);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 40px 100px -40px hsl(220 40% 2% / .85),
             0 0 0 1px hsl(60 8% 96% / .05);
  position:relative;
}
/* Crossfade: each view absolutely stacked, opacity controlled by JS */
.appsc-view{
  position:absolute; inset:0; opacity:0;
  transition:opacity .5s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.appsc-view.is-active{
  opacity:1;
  pointer-events:auto;
}
@media (prefers-reduced-motion:reduce){
  .appsc-view{ transition:none; }
}

/* ── Chrome: sidebar + main ── */
.appsc-chrome{
  display:flex; height:100%;
  background:hsl(220 18% 10%);
}
.appsc-sidebar{
  width:48px; flex:none;
  background:hsl(220 20% 8%);
  border-right:1px solid hsl(60 8% 96% / .07);
  display:flex; flex-direction:column;
  align-items:center; gap:6px;
  padding:14px 0;
}
.appsc-sidebar__logo{
  width:28px; height:28px;
  background:var(--pulse);
  border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:10px;
  color:hsl(220 18% 10%);
}
.appsc-sidebar__logo svg{ width:14px; height:14px; fill:hsl(220 18% 10%); }
.appsc-nav-item{
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  border-radius:8px;
  color:hsl(60 8% 96% / .35);
  cursor:pointer;
  transition:background .15s, color .15s;
}
.appsc-nav-item:hover{ background:hsl(60 8% 96% / .07); color:hsl(60 8% 96% / .7); }
.appsc-nav-item.is-active{
  background:hsl(184 90% 48% / .14);
  color:var(--pulse);
}
.appsc-nav-item svg{ width:16px; height:16px; }

.appsc-main{ flex:1; min-width:0; display:flex; flex-direction:column; }

.appsc-topbar{
  display:flex; align-items:center; gap:10px;
  padding:0 14px;
  height:42px; flex:none;
  border-bottom:1px solid hsl(60 8% 96% / .07);
  background:hsl(220 20% 9%);
}
.appsc-topbar__title{
  font:600 12px/1 var(--sans); color:var(--bone); flex:1; min-width:0;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.appsc-search{
  display:flex; align-items:center; gap:6px;
  font:400 10.5px/1 var(--sans); color:hsl(60 8% 96% / .3);
  background:hsl(60 8% 96% / .05);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:6px; padding:5px 9px;
  white-space:nowrap;
}
.appsc-search svg{ width:12px; height:12px; flex:none; }
.appsc-avatar{
  width:26px; height:26px; flex:none;
  border-radius:50%;
  background:hsl(184 90% 48% / .25);
  color:var(--pulse);
  font:700 9px/26px var(--mono);
  text-align:center; letter-spacing:.04em;
}
.appsc-content{
  flex:1; overflow:hidden;
  padding:12px 14px;
  display:flex; flex-direction:column;
}

/* ── Shared pills ── */
.appsc-pill{
  display:inline-flex; align-items:center;
  font:600 9.5px/1 var(--mono); letter-spacing:.06em; text-transform:uppercase;
  padding:4px 8px; border-radius:999px;
}
.appsc-pill--active{ background:hsl(152 70% 52% / .15); color:hsl(152 70% 60%); }
.appsc-pill--done{ background:hsl(152 70% 52% / .1); color:hsl(152 70% 55%); }
.appsc-pill--review{ background:hsl(40 90% 55% / .15); color:hsl(40 90% 62%); }
.appsc-pill--sched{ background:hsl(184 90% 48% / .12); color:var(--pulse); }
.appsc-pill--plan{ background:hsl(184 90% 48% / .12); color:var(--pulse); }

/* ── Shared table ── */
.appsc-table{ width:100%; border-collapse:collapse; }
.appsc-table th{
  font:600 9px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  color:hsl(60 8% 96% / .3); padding:0 0 7px; text-align:left;
  border-bottom:1px solid hsl(60 8% 96% / .07);
}
.appsc-table td{
  font:400 11px/1.3 var(--sans); color:hsl(60 8% 96% / .6);
  padding:8px 0; border-bottom:1px solid hsl(60 8% 96% / .05);
  white-space:nowrap;
}
.appsc-table tr:hover td{ background:hsl(60 8% 96% / .03); }
.appsc-table tr:last-child td{ border-bottom:none; }

/* ── KPI stat strip (views 1 + 5) ── */
.appsc-kpi-strip{
  display:flex; align-items:center; gap:14px;
  padding:10px 0 12px;
  border-bottom:1px solid hsl(60 8% 96% / .07);
}
.appsc-kpi{ display:flex; flex-direction:column; gap:3px; }
.appsc-kpi__val{ font:700 15px/1 var(--display); color:var(--bone); letter-spacing:-.02em; }
.appsc-kpi__val--pulse{ color:var(--pulse); }
.appsc-kpi__lbl{ font:500 9px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:hsl(60 8% 96% / .35); }
.appsc-kpi-div{ width:1px; height:26px; background:hsl(60 8% 96% / .08); }

/* ── Avatar row (job crew) ── */
.appsc-av-row{ display:flex; }
.appsc-av{
  width:20px; height:20px; border-radius:50%;
  font:700 8px/20px var(--mono); text-align:center; color:var(--bone);
  border:1px solid hsl(220 18% 10%);
  margin-left:-4px;
}
.appsc-av:first-child{ margin-left:0; }

/* ── VIEW 2: Calendar strip + time slots ── */
.appsc-cal-strip{
  display:flex; gap:6px; padding:10px 0;
  border-bottom:1px solid hsl(60 8% 96% / .07);
}
.appsc-cal-day{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:7px 4px; border-radius:8px;
  cursor:pointer;
  transition:background .15s;
}
.appsc-cal-day:hover{ background:hsl(60 8% 96% / .05); }
.appsc-cal-day--today{
  background:hsl(184 90% 48% / .12);
  outline:1px solid hsl(184 90% 48% / .3);
}
.appsc-cal-day--off{ opacity:.35; }
.appsc-cal-wday{ font:500 9px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase; color:hsl(60 8% 96% / .4); }
.appsc-cal-num{ font:700 13px/1 var(--display); color:var(--bone); }
.appsc-cal-day--today .appsc-cal-num{ color:var(--pulse); }

.appsc-slots{ display:flex; flex-direction:column; gap:6px; margin-top:12px; }
.appsc-slot{
  display:flex; align-items:center; gap:10px;
  padding:9px 12px;
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:8px;
  background:hsl(220 20% 12%);
  transition:background .15s;
}
.appsc-slot:hover{ background:hsl(220 20% 14%); }
.appsc-slot--booked{
  background:hsl(184 90% 48% / .1);
  border-color:hsl(184 90% 48% / .25);
}
.appsc-slot--full{ opacity:.4; }
.appsc-slot__time{ font:600 11px/1 var(--mono); color:hsl(60 8% 96% / .5); flex:none; width:52px; }
.appsc-slot__label{ font:400 11.5px/1 var(--sans); color:var(--bone); flex:1; }
.appsc-slot__badge{ font:600 9.5px/1 var(--mono); color:var(--pulse); margin-left:auto; }
.appsc-slot__cta{
  font:600 9.5px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase;
  color:var(--pulse); margin-left:auto;
  border:1px solid hsl(184 90% 48% / .3);
  padding:4px 9px; border-radius:6px;
  cursor:pointer; transition:.15s;
}
.appsc-slot__cta:hover{ background:hsl(184 90% 48% / .1); }

/* ── VIEW 3: SaaS product ── */
.appsc-saas-topnav{
  display:flex; align-items:center; gap:14px;
  padding:0 14px; height:40px; flex:none;
  background:hsl(220 20% 8%);
  border-bottom:1px solid hsl(60 8% 96% / .07);
}
.appsc-saas-brand{
  display:flex; align-items:center; gap:6px;
  font:700 12px/1 var(--display); color:var(--bone); flex:none;
}
.appsc-saas-nav{
  display:flex; gap:2px; flex:1;
}
.appsc-saas-nav__item{
  font:500 10.5px/1 var(--sans); color:hsl(60 8% 96% / .4);
  padding:6px 10px; border-radius:6px; cursor:pointer; transition:.15s;
}
.appsc-saas-nav__item:hover{ color:hsl(60 8% 96% / .8); }
.appsc-saas-nav__item--active{ color:var(--bone); background:hsl(60 8% 96% / .07); }
.appsc-saas-topnav__right{ display:flex; align-items:center; gap:8px; flex:none; }

/* the SaaS view has a top-nav + body (not sidebar|main like the other views), so its
   chrome must STACK vertically instead of inheriting the shared flex-row — otherwise the
   top-nav eats the width and the dashboard body collapses to nothing (blank screen) */
.appsc-chrome:has(.appsc-saas-topnav){ flex-direction:column; }
.appsc-saas-body{
  display:flex; flex:1; min-height:0; overflow:hidden; gap:0;
}
.appsc-saas-sidebar2{
  width:130px; flex:none;
  background:hsl(220 20% 8%);
  border-right:1px solid hsl(60 8% 96% / .07);
  padding:10px 8px;
  display:flex; flex-direction:column; gap:2px;
}
.appsc-saas-menu-item{
  display:flex; align-items:center; gap:8px;
  font:500 11px/1 var(--sans); color:hsl(60 8% 96% / .4);
  padding:7px 8px; border-radius:6px; cursor:pointer; transition:.15s;
}
.appsc-saas-menu-item:hover{ color:hsl(60 8% 96% / .8); }
.appsc-saas-menu-item--active{ color:var(--bone); background:hsl(60 8% 96% / .07); }

.appsc-saas-main2{
  flex:1; min-width:0; padding:14px;
  display:flex; flex-direction:column;
}
.appsc-saas-heading{
  font:700 15px/1.2 var(--display); color:var(--bone); letter-spacing:-.01em;
}
.appsc-saas-subhead{
  font:400 11px/1 var(--sans); color:hsl(60 8% 96% / .4); margin-top:4px;
}
.appsc-saas-cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-top:12px;
}
.appsc-saas-card{
  background:hsl(220 20% 12%);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:10px; padding:11px;
  transition:background .15s;
}
.appsc-saas-card:hover{ background:hsl(220 20% 14%); }
.appsc-saas-card__top{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:8px;
}
.appsc-saas-card__title{ font:500 10px/1 var(--mono); color:hsl(60 8% 96% / .4); text-transform:uppercase; letter-spacing:.08em; }
.appsc-saas-card__badge{
  font:600 9px/1 var(--mono); padding:2px 6px; border-radius:4px;
  background:hsl(60 8% 96% / .08); color:hsl(60 8% 96% / .5);
}
.appsc-saas-card__badge--up{ background:hsl(152 70% 52% / .15); color:hsl(152 70% 60%); }
.appsc-saas-card__val{ font:800 18px/1 var(--display); color:var(--bone); letter-spacing:-.02em; }
.appsc-saas-card__sub{ font:400 9.5px/1 var(--sans); color:hsl(60 8% 96% / .35); margin-top:4px; }

.appsc-usage-strip{ display:flex; flex-direction:column; gap:7px; margin-top:12px; }
.appsc-usage-item{ display:flex; align-items:center; gap:9px; }
.appsc-usage-lbl{ font:500 10px/1 var(--mono); color:hsl(60 8% 96% / .4); text-transform:uppercase; letter-spacing:.08em; width:60px; flex:none; }
.appsc-usage-bar{ flex:1; height:4px; background:hsl(60 8% 96% / .08); border-radius:2px; overflow:hidden; }
.appsc-usage-fill{ height:100%; background:var(--pulse); border-radius:2px; }
.appsc-usage-val{ font:500 10px/1 var(--mono); color:hsl(60 8% 96% / .4); flex:none; }

/* ── VIEW 4: Phone frame ── */
.appsc-mobile-wrap{
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background:hsl(220 18% 10%);
  padding:0;
  container-type:size;       /* query container so the phone can size to the frame height */
}
/* scale the whole 200×400 phone (chrome + content together) to fill ~93% of the
   frame height, responsively — keeps proportions perfect at any screen height.
   Scoped to .appsc-mobile-wrap so the mini phone inside the mobile-screen mockup is untouched. */
.appsc-mobile-wrap .appsc-phone{
  transform: scale(calc(93cqh / 400px));
}
.appsc-phone{
  width:200px; height:400px;
  background:hsl(220 20% 8%);
  border:1.5px solid hsl(60 8% 96% / .15);
  border-radius:32px;
  position:relative;
  overflow:hidden;
  box-shadow:0 20px 60px -20px hsl(220 40% 2% / .7),
             0 0 0 1px hsl(60 8% 96% / .05);
}
.appsc-phone__notch{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:60px; height:7px;
  background:hsl(220 20% 6%);
  border-radius:999px; z-index:2;
}
.appsc-phone__screen{
  position:absolute; inset:0;
  background:hsl(220 18% 11%);
  display:flex; flex-direction:column;
  overflow:hidden;
}
.appsc-phone-status{
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 14px 4px;
  font:600 9.5px/1 var(--mono); color:var(--bone);
  flex:none;
}
.appsc-phone-header{
  padding:10px 14px 8px;
  border-bottom:1px solid hsl(60 8% 96% / .07);
  flex:none;
}
.appsc-phone-header__title{ font:700 14px/1.2 var(--display); color:var(--bone); letter-spacing:-.01em; }
.appsc-phone-header__sub{ font:400 10px/1 var(--sans); color:hsl(60 8% 96% / .4); margin-top:3px; }

.appsc-phone-cards{
  display:grid; grid-template-columns:1fr 1fr; gap:8px;
  padding:10px 12px; flex:none;
}
.appsc-phone-card{
  background:hsl(220 20% 13%);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:10px; padding:10px;
}
.appsc-phone-card--accent{
  background:hsl(184 90% 48% / .12);
  border-color:hsl(184 90% 48% / .2);
}
.appsc-phone-card__label{ font:500 9px/1 var(--mono); color:hsl(60 8% 96% / .4); text-transform:uppercase; letter-spacing:.07em; }
.appsc-phone-card__val{ font:800 22px/1 var(--display); color:var(--bone); margin-top:6px; letter-spacing:-.02em; }
.appsc-phone-card--accent .appsc-phone-card__val{ color:var(--pulse); }

.appsc-phone-section-label{
  font:600 9px/1 var(--mono); color:hsl(60 8% 96% / .3);
  text-transform:uppercase; letter-spacing:.12em;
  padding:0 12px 6px; flex:none;
}
.appsc-phone-items{
  flex:1; overflow:hidden;
  padding:0 12px;
  display:flex; flex-direction:column; gap:0;
}
.appsc-phone-item{
  display:flex; align-items:center; gap:10px;
  padding:9px 0;
  border-bottom:1px solid hsl(60 8% 96% / .05);
  cursor:pointer; transition:background .15s;
}
.appsc-phone-item:last-child{ border-bottom:none; }
.appsc-phone-item:hover{ background:hsl(60 8% 96% / .03); }
.appsc-phone-item__dot{ width:8px; height:8px; border-radius:50%; flex:none; }
.appsc-phone-item__body{ flex:1; min-width:0; }
.appsc-phone-item__title{ font:600 11px/1.2 var(--sans); color:var(--bone); }
.appsc-phone-item__sub{ font:400 9.5px/1 var(--sans); color:hsl(60 8% 96% / .4); margin-top:2px; }

.appsc-phone-tabbar{
  display:flex; border-top:1px solid hsl(60 8% 96% / .07);
  background:hsl(220 20% 8%);
  padding:8px 0 12px;
  flex:none;
}
.appsc-phone-tab{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  font:500 8.5px/1 var(--sans); color:hsl(60 8% 96% / .3);
  cursor:pointer; transition:.15s;
}
.appsc-phone-tab--active{ color:var(--pulse); }

/* ── VIEW 5: Product grid + cart accent ── */
.appsc-product-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:9px; margin-top:2px;
}
.appsc-product{
  background:hsl(220 20% 12%);
  border:1px solid hsl(60 8% 96% / .08);
  border-radius:10px; overflow:hidden;
  transition:background .15s;
  cursor:pointer;
}
.appsc-product:hover{ background:hsl(220 20% 14%); }
.appsc-product__img{
  height:54px; display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid hsl(60 8% 96% / .06);
}
.appsc-product__name{ font:600 10.5px/1.3 var(--sans); color:var(--bone); padding:7px 8px 3px; }
.appsc-product__price{ font:700 11px/1 var(--display); color:var(--pulse); padding:0 8px; letter-spacing:-.01em; }
.appsc-product__stock{ font:400 9px/1 var(--mono); padding:4px 8px 7px; }
.appsc-product__stock--ok{ color:hsl(152 70% 55%); }
.appsc-product__stock--low{ color:hsl(0 75% 65%); }

.appsc-cart-accent{
  display:flex; align-items:center; gap:10px;
  margin-top:10px;
  padding:9px 12px;
  background:hsl(184 90% 48% / .08);
  border:1px solid hsl(184 90% 48% / .2);
  border-radius:9px;
}
.appsc-cart-accent__icon{ color:var(--pulse); display:flex; align-items:center; }
.appsc-cart-accent__label{ font:400 11.5px/1 var(--sans); color:hsl(60 8% 96% / .7); flex:1; }
.appsc-cart-accent__total{ font:700 13px/1 var(--display); color:var(--bone); letter-spacing:-.01em; }
.appsc-cart-accent__cta{ font:600 10px/1 var(--mono); color:var(--pulse); letter-spacing:.04em; white-space:nowrap; }

/* ── RIGHT: copy scroll track ── */
.appsc-copy-track{
  display:flex; flex-direction:column;
  gap:0;
  /* extra bottom room so the LAST view can scroll up to centre while the screen is
     still pinned (the sticky range otherwise ends ~one block early), and it gives the
     final view a brief "rest" as you finish scrolling */
  padding:clamp(20px,3vh,40px) 0 clamp(80px,16vh,200px);
}
.appsc-copy-block{
  min-height:96vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(40px,6vh,72px) 0;
  border-top:1px solid hsl(60 8% 96% / .08);
  opacity:.35;
  transition:opacity .5s cubic-bezier(.22,1,.36,1);
}
.appsc-copy-block:first-child{ border-top:none; }
.appsc-copy-block.is-active{ opacity:1; }
@media (prefers-reduced-motion:reduce){ .appsc-copy-block{ transition:none; opacity:1; } }

.appsc-copy-num{
  font:600 10px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase;
  color:var(--pulse); margin-bottom:12px;
  display:flex; align-items:center; gap:9px;
}
.appsc-copy-num::before{
  content:""; width:6px; height:6px; background:var(--pulse);
  border-radius:50%; box-shadow:0 0 10px 1px var(--pulse);
}
.appsc-copy-block.is-active .appsc-copy-num::before{
  box-shadow:0 0 14px 3px var(--pulse);
}
.appsc-copy-h{
  font:800 clamp(22px,2.8vw,34px)/1.1 var(--display);
  letter-spacing:-.02em; color:var(--bone); margin-bottom:14px;
}
.appsc-copy-h em{ color:var(--pulse); font-style:normal; }
.appsc-copy-p{
  font:300 clamp(15px,1.5vw,17px)/1.65 var(--sans);
  color:hsl(60 8% 96% / .66); max-width:46ch;
}
.appsc-copy-chips{ display:flex; flex-wrap:wrap; gap:7px; margin-top:16px; }
.appsc-copy-chip{
  font:500 10.5px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  border:1px solid hsl(60 8% 96% / .12);
  color:hsl(60 8% 96% / .5);
}

/* ── MOBILE STACK (≤900px): no stickiness, each mockup above its copy ── */
@media (max-width:900px){
  .appsc-layout{ grid-template-columns:1fr; gap:0; }
  .appsc-screen-wrap{ position:static; margin-bottom:0; }
  .appsc-copy-track{ padding:0; }
  .appsc-copy-block{ opacity:1 !important; padding:32px 0; min-height:0; display:block; }
  .appsc-copy-block .appsc-mobile-screen{
    display:block;
    margin-bottom:22px;
    border-radius:12px; overflow:hidden;
    border:1px solid hsl(60 8% 96% / .1);
  }
  .appsc-screen-wrap--desktop{ display:none; }
  .appsc-mobile-screen .appsc-chrome{ min-height:300px; }
  .appsc-sidebar{ width:44px; }
  .appsc-saas-sidebar2{ width:100px; }
  .appsc-saas-nav{ display:none; }
  .appsc-product-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (min-width:901px){
  .appsc-copy-block .appsc-mobile-screen{ display:none; }
  .appsc-screen-wrap--desktop{ display:flex; align-items:center; }
}

/* ── /web tier cards: live auto-playing site previews in the thumb (Platinum + Diamond) ── */
.tier__demo{ position:relative; container-type:inline-size; background:hsl(220 14% 10%); }
.tier__demo-poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; z-index:1; }
.tier__demo iframe{ position:absolute; top:0; left:0; width:1280px; height:800px; transform:scale(calc(100cqw / 1280px)); transform-origin:0 0; border:0; pointer-events:none; z-index:2; }
.tier__demo.is-live .tier__demo-poster{ opacity:0; transition:opacity .45s var(--ease); }
.tier__demo-open{ position:absolute; right:8px; bottom:8px; z-index:3; font:600 9.5px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:var(--bone); background:hsl(220 14% 4% / .72); border:1px solid hsl(60 8% 96% / .25); padding:5px 9px; border-radius:7px; text-decoration:none; backdrop-filter:blur(5px); transition:.18s var(--ease); }
.tier__demo-open:hover{ border-color:var(--pulse); color:var(--pulse); }
