:root{
  --accent:#2AE98B;
  --accentHover:#22C873;
  --accentRGB: 42, 233, 139;
  --accentGlow: rgba(42, 233, 139, 0.35);

  --bg:#F7F8FA;
  --text:#111111;
  --muted:#5f6368;
  --rule:#e7e7e7;

  --cardBg:#ffffff;
  --cardBgSoft:#F1F3F5;

  --pill:#111111;
  --pillText:#ffffff;

  --radius:28px;
  --container:1180px;
  --padX:60px;
  --padY:96px;
  --h1: clamp(44px, 6vw, 84px);
  --h2: clamp(34px, 4.2vw, 52px);
  --h3: 28px;
  --p: 18px;
  --lead: 22px;
  --tag: clamp(22px, 3.1vw, 40px);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  transition: opacity .22s ease, transform .22s ease;

  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  letter-spacing:-0.01em;
}
a{color:inherit;text-decoration:none}
a:hover{opacity:.75}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--padX)}
.rule{border-top:1px solid var(--rule)}
.spacer{height:28px}

/* Header */
.header{
  position:sticky;top:0;z-index:20;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(0,0,0,0.04);

  position:sticky;top:0;z-index:50;
}
.header.isScrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(0,0,0,0.04);
}

.headerInner{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.brand{
  font-weight:700;
  font-size:18px;
  letter-spacing:0.18em;
}
.nav{display:flex;align-items:center;gap:10px;}
.nav a{
  margin-left:0;
  font-size:15px;
  letter-spacing:-0.01em;
}

/* Typography */
h1{font-size:var(--h1);font-weight:650;letter-spacing:-0.03em;line-height:0.98}
h2{font-size:var(--h2);font-weight:650;letter-spacing:-0.03em;line-height:1.05}
.sectionLabel{
  font-size:18px;
  color:var(--muted);
  letter-spacing:-0.01em;
  margin-bottom:18px;
}
.lead{
  font-size:var(--lead);
  color:var(--muted);
  max-width:900px;
}
.p{
  font-size:var(--p);
  max-width:900px;
}
.tagline{
  font-size:var(--tag);
  font-weight:650;
  letter-spacing:-0.03em;
  line-height:1.05;
  margin-top:18px;
  max-width:980px;
}

/* Sections */
.section{padding:var(--padY) 0}
.hero{padding:92px 0 86px}
.hero .lead{margin-top:20px}
.pill{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--pill);
  color:var(--pillText);
  padding:18px 44px;
  border-radius: 28px;
  font-size:16px;
  margin-top:26px;
  transition:transform .18s ease, opacity .18s ease;
}
.pill:hover{transform:translateY(-1px);opacity:.92}
.pill.secondary{
  background:transparent;
  color:var(--text);
  border:1px solid var(--rule);
}

/* Capabilities cards */
.cards{
  margin-top:44px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:26px;
}
.card{
  border-radius: 28px;
  border:1px solid var(--rule);
  padding:28px;
  overflow:hidden;
  min-height:320px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background: var(--cardBg);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}
.cardTop{
  border-radius: 28px;
  height:180px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:20px;
  border:1px solid rgba(0,0,0,0.04);
}
.cardTop span{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.18em;
  color:rgba(0,0,0,.55);
}
.card h3{font-size:34px;font-weight:650;letter-spacing:-0.03em;line-height:1.05;margin-bottom:16px}
.list{
  font-size:18px;
  color:var(--text);
  line-height:1.7;
}
.list .muted{color:var(--muted)}

/* Process / Approach */
.steps{margin-top:28px}
.step{
  padding:38px 0;
  border-top:1px solid var(--rule);
}
.stepNum{
  font-family:var(--mono);
  font-size:16px;
  letter-spacing:0.18em;
  color:var(--muted);
  margin-bottom:10px;
}
.stepTitle{
  font-size:34px;
  font-weight:650;
  letter-spacing:-0.03em;
  margin-bottom:10px;
}
.stepSub{
  font-size:18px;
  color:rgba(0,0,0,.35);
  margin-bottom:14px;
}
.step p{max-width:980px}

/* Work grid */
.workGrid{
  margin-top:42px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.workItem{
  border:1px solid var(--rule);
  border-radius: 28px;
  padding:22px;
  min-height:220px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.workItem .kicker{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.18em;
  color:var(--muted);
}
.workItem h3{font-size:26px;font-weight:650;letter-spacing:-0.02em;line-height:1.1;margin-top:10px}
.workItem p{color:var(--muted);font-size:16px;margin-top:10px}

/* Contact */
.contactGrid{
  margin-top:38px;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:34px;
  align-items:start;
}
.contactBox{
  border:1px solid var(--rule);
  border-radius: 28px;
  padding:28px;
}
.field{display:flex;flex-direction:column;margin-top:14px}
label{font-size:13px;color:var(--muted);margin-bottom:8px}
input, textarea, select{
  font-family:var(--sans);
  font-size:16px;
  padding:14px 14px;
  border-radius: 28px;
  border:1px solid var(--rule);
  outline:none;
}
input:focus, textarea:focus, select:focus{border-color:#cfcfcf}
textarea{min-height:140px;resize:vertical}

/* Footer */
.footer{padding:70px 0;border-top:1px solid var(--rule)}
.footerInner{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap:24px;
}
.footerTitle{font-weight:700;letter-spacing:0.22em;font-size:16px}
.footerLabel{font-size:14px;color:rgba(0,0,0,.35);margin-bottom:12px}
.footerInner a{display:block;margin-bottom:10px}
.small{font-size:14px;color:var(--muted)}

/* Mobile */
@media (max-width: 1020px){
  :root{
  --accent:#1ED6FF;
  --accentHover:#00C8E8;
  --accentGlow: rgba(42, 233, 139, 0.35);
--padX:32px;--padY:74px}
  .cards{grid-template-columns:repeat(2, 1fr)}
  .workGrid{grid-template-columns:repeat(2, 1fr)}
  .contactGrid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .nav{gap:10px;}

  .nav{gap:10px;}
  .brand{font-size:18px;letter-spacing:0.16em;}

  :root{
  --accent:#1ED6FF;
  --accentHover:#00C8E8;
  --accentGlow: rgba(42, 233, 139, 0.35);
--padX:22px}
  .nav a{margin-left:18px}
  .cards{
    display:flex;
    overflow:auto;
    gap:14px;
    scroll-snap-type:x mandatory;
    padding-bottom:8px;
  }
  .card{
    min-width:82%;
    scroll-snap-align:center;
  }
  .workGrid{grid-template-columns:1fr}
  .footerInner{grid-template-columns:1fr}
}
/* Notice banner */
.notice{
  margin-top:22px;
  padding:16px 18px;
  border-radius: 28px;
  border:1px solid var(--rule);
  background:rgba(0,0,0,0.02);
  color:var(--text);
  font-size:16px;
}

/* Motion */
[data-animate]{
  opacity:0;
  transform:translateY(12px);
  transition:opacity .55s ease, transform .55s ease;
  transition-delay: var(--delay, 0ms);
  will-change: opacity, transform;
}
[data-animate].reveal{
  opacity:1;
  transform:translateY(0);
}
html.page-leave body{
  transition: opacity .22s ease, transform .22s ease;

  opacity:0;
  transform: translateY(-6px);
  transition: opacity .22s ease, transform .22s ease;
}

/* Motion refinements */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
  [data-animate]{opacity:1 !important; transform:none !important;}
}


  [data-animate]{opacity:1 !important; transform:none !important; filter:none !important;}
}

/* Hero Intro Video (inline, rounded) */
.heroIntroVideo{
  width:100%;
  max-width: 980px;
  margin: 0 0 0 0;
  border-radius: 32px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,0.06);
  background: #000;
}
.introVideo{
  border-radius:24px;

  width:100%;
  height:auto;
  display:block;
}

/* Header fit tweaks */
.headerInner{gap:12px;}
.brand{white-space:nowrap; flex:0 0 auto;}
.nav{white-space:nowrap; flex:0 0 auto;}
/* Slightly tighter spacing by default */
.nav{gap:10px;}
@media (max-width: 820px){
  :root{
  --accent:#1ED6FF;
  --accentHover:#00C8E8;
  --accentGlow: rgba(42, 233, 139, 0.35);
--padX:24px;}
  .nav{gap:10px;}
  .nav a{font-size:14px;}
}
@media (max-width: 420px){
  .brand{letter-spacing:0.14em;font-size:17px;}
  .nav{gap:10px;}
}

/* Vingamedia-like motion */
[data-animate]{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .65s cubic-bezier(.2,.8,.2,1),
              transform .65s cubic-bezier(.2,.8,.2,1);
  transition-delay: var(--delay, 0ms);
  will-change: opacity, transform;
}
[data-animate].reveal{
  opacity:1;
  transform: translateY(0);
}
html.page-leave body{
  opacity:0;
  transform: translateY(-6px);
  transition: opacity .22s ease, transform .22s ease;
}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
  [data-animate]{opacity:1 !important; transform:none !important;}
}

/* Kinetic words */
.kinetic{
  margin: 0 0 22px 0;
  display:flex;
  align-items:baseline;
  gap:14px;
}
.kineticLabel{
  font-family: var(--mono);
  font-size:12px;
  letter-spacing:0.22em;
  color: rgba(0,0,0,.45);
}
.kineticWords{
  font-size: clamp(26px, 3.6vw, 44px);
  font-weight:650;
  letter-spacing:-0.03em;
  line-height:1.05;
}
.kw{display:none}
.kw.active{display:inline}

/* Contact direct */
.contactDirect{margin-top:12px; display:flex; flex-direction:column; gap:16px;}
.contactItem{display:flex; justify-content:space-between; gap:18px; align-items:baseline; padding-top:8px; border-top:1px solid var(--rule);}
.contactItem:first-child{border-top:none; padding-top:0;}
.contactKey{font-size:14px; color: rgba(0,0,0,.35);}
.contactVal{font-size:18px; color: var(--text);}

/* Footer business alignment */
.footerBusiness .small{margin-top:0;}
.footerBusiness .small + .small{margin-top:8px;}

/* Footer alignment tweaks */
.footerInner{align-items:start;}
.footerLabel{line-height:1.2;}
.footerInner a{line-height:1.25;}
.footerBusiness .small{line-height:1.35;}

.intelligenceVideoWrap{
  margin-top:40px;
  padding:24px;
  border-radius:28px;
  background: rgba(200,230,235,0.45);
}
.intelligenceVideo{
  width:100%;
  display:block;
  border-radius:20px;
}

.pillarMedia{
  padding:18px;
  border-radius:28px;
  background: rgba(180,220,230,0.35);
}
.pillarVideo{
  width:100%;
  display:block;
  border-radius:22px;
}

/* Footer alignment v15 */
.footerInner{align-items:start;}
.footerInner > div{min-width:0;}
.footerLabel{display:block;}
.footerInner a{display:block;}

/* Doctrine video */

.doctrineVideoWrap{
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.doctrineVideo{
  width:100%;
  display:block;
  border-radius: 22px;
}

/* Header clean layout v16 */
.headerInner{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav{justify-content:flex-end;}

/* Services slider v16 */
.pillarsTrack{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:6px;
}
.pillarsTrack::-webkit-scrollbar{height:0px;}
.pillarCard{
  scroll-snap-align:start;
  min-width: min(520px, 86vw);
}
.pillarMedia{
  padding:18px;
  border-radius:28px;
  background: var(--accentBg, rgba(200,230,235,0.28));
}
.pillarVideo{
  width:100%;
  display:block;
  border-radius:22px;
}
.pill.pillAccent{
  background: var(--accent);
  color: #071a12;
  border-color: transparent;
  box-shadow: 0 14px 44px rgba(0,0,0,0.45);
}
.pill.pillAccent:hover{box-shadow: 0 18px 64px rgba(0,0,0,0.55), 0 0 28px var(--accentGlow);}

@supports not (background: color-mix(in srgb, black 20%, white)){
  .pill.pillAccent{
  background: var(--accent);
  color: #071a12;
  border-color: transparent;
  box-shadow: 0 14px 44px rgba(0,0,0,0.45);
}
.pill.pillAccent:hover{box-shadow: 0 18px 64px rgba(0,0,0,0.55), 0 0 28px var(--accentGlow);}

}
.sliderDots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:14px;
}
.sliderDot{
  width:8px;
  height:8px;
  border-radius:999px;
  background: rgba(var(--accentRGB),0.22);
  border:none;
  padding:0;
}
.sliderDot.active{ background: var(--accent); box-shadow: 0 0 14px var(--accentGlow); }

/* Footer business aligned v16 */
.footerBusiness{padding-left:0; margin-left:0;}

/* Doctrine video border remove v16 */

.doctrineVideoWrap{
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}


/* Services slider v18 */
.cardsTrack{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:6px;
}
.cardsTrack::-webkit-scrollbar{height:0px;}
.cardsTrack .card{
  scroll-snap-align:start;
  min-width: min(520px, 86vw);
}
.cardMedia{
  margin-top:14px;
  padding:18px;
  border-radius:28px;
  background: var(--accentBg, rgba(200,230,235,0.22));
}
.cardVideo{
  width:100%;
  display:block;
  border-radius:22px;
}
.pill.secondary.pillAccent{
  background: color-mix(in srgb, var(--accent, black 26%, white 74%));
  border-color: transparent;
}
@supports not (background: color-mix(in srgb, black 20%, white)){
  .pill.secondary.pillAccent{
    background: rgba(5, 5, 5, 0.04);
    border-color: var(--rule);
  }
}
.sliderDots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:14px;
}
.sliderDot{
  width:8px;
  height:8px;
  border-radius:999px;
  background: rgba(var(--accentRGB),0.22);
  border:none;
  padding:0;
}
.sliderDot.active{ background: var(--accent); box-shadow: 0 0 14px var(--accentGlow); }

/* Footer alignment v18 */
.footerInner{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:28px;
  align-items:start;
}
.footerBusiness{
  grid-column: 2 / -1;
  margin-top: 8px;
}
@media (max-width: 820px){
  .footerInner{grid-template-columns: 1fr 1fr;}
  .footerBusiness{grid-column: 1 / -1;}
}

.footerBusiness{margin-left:0;}

/* Footer layout v19 */
.footerInner{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:28px;
  align-items:start;
}
.footerBusiness{
  grid-column: 2 / -1;
  margin-top: 10px;
}
@media (max-width: 820px){
  .footerInner{grid-template-columns: 1fr 1fr;}
  .footerBusiness{grid-column: 1 / -1;}
}

/* Spacing between service video and headline */
.cardMedia{margin-bottom:24px;}

/* Unified service button color v22 */
.cardsTrack .pill.secondary,
.cardsTrack .pill.secondary.pillAccent{
  background: #b196bd !important;
  border-color: #ab8cb3 !important;
  color: #000 !important;
}


/* Service card accent fill v25 */
.cardsTrack .card{
  border: 1px solid var(--accent, rgba(0,0,0,0.1));
  background: var(--accentBg, rgba(0,0,0,0.03));
}

/* Hero spacing fix v26 */
.heroIntroVideo + h1,
.heroIntroVideo + .heroContent,
.heroIntroVideo + .container h1{
  margin-top: 90px;
}

/* Service card accent fix v28 */
.cardsTrack .card{
  border: 1px solid var(--accent);
  background: var(--accentBg);
}

/* Service cards no borders v30 */
.cardsTrack .card{
  border: none !important;
  background: color-mix(in srgb, var(--accent) 10%, white 90%);
}
@supports not (background: color-mix(in srgb, black 10%, white)){
  .cardsTrack .card{
    background: var(--accentBg, rgba(0,0,0,0.03));
  }
}
.cardMedia{
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
}
.cardVideo{
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Doctrine video border removal v31 */
.doctrineVideo{
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Work page v33 */
.workGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:18px;
  margin-top:26px;
}
.workItem{
  display:flex;
  gap:18px;
  padding:18px;
  border-radius:28px;
  background: rgba(255,255,255,0.35);
  text-decoration:none;
  color: inherit;
}
.workItem:hover{transform: translateY(-2px);}
.workMedia{
  width:140px;
  min-width:140px;
  height:140px;
  border-radius:22px;
  background: color-mix(in srgb, var(--accent) 18%, white 82%);
}
@supports not (background: color-mix(in srgb, black 10%, white)){
  .workMedia{background: rgba(0,0,0,0.04);}
}
.workMeta .kicker{margin-bottom:8px;}
.workMeta h3{margin:0 0 8px 0;}
.workMeta p{margin:0;}
.workCTA{
  margin-top:34px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  padding:22px;
  border-radius:28px;
  background: rgba(255,255,255,0.35);
}
.workCTA h2{margin:0 0 8px 0;}
.workCTA .lead{margin:0;}
@media (max-width: 900px){
  .workGrid{grid-template-columns:1fr;}
  .workMedia{width:120px; min-width:120px; height:120px;}
  .workCTA{flex-direction:column; align-items:flex-start;}
}

.mediumSpacer{height:28px;}

.workMedia{
  position:relative;
  overflow:hidden;
}
.workThumb{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:inherit;
  filter: contrast(0.98) saturate(0.98);
}

/* Card hover polish */
.card{
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  background: #fff;
}
.card:hover{
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--accent, #000) 40%, var(--rule) 60%);
  box-shadow:
    0 24px 80px rgba(0,0,0,0.10),
    0 0 0 1px rgba(0,0,0,0.02),
    0 0 50px color-mix(in srgb, var(--accent, #000) 18%, transparent 82%);
}

/* Process */
.processGrid{
  margin-top:42px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
}
.processStep{
  border:1px solid var(--rule);
  border-radius: var(--radius);
  padding:24px;
  background:#fff;
}
.stepNum{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.18em;
  color:rgba(0,0,0,.55);
  margin-bottom:10px;
}
.processStep h3{
  font-size:22px;
  letter-spacing:-0.02em;
}
.processStep p{
  margin-top:10px;
  color:var(--muted);
  line-height:1.55;
  font-size:15px;
}

/* FAQ */
.faq{
  margin-top:42px;
  display:grid;
  gap:12px;
}
.faqItem{
  border:1px solid var(--rule);
  border-radius: var(--radius);
  padding:18px 22px;
  background:#fff;
}
.faqItem summary{
  cursor:pointer;
  font-weight:650;
  letter-spacing:-0.01em;
  list-style:none;
}
.faqItem summary::-webkit-details-marker{display:none;}
.faqBody{
  margin-top:12px;
  color:var(--muted);
  line-height:1.6;
  font-size:15px;
  max-width: 900px;
}
.faqItem[open]{
  box-shadow: 0 18px 60px rgba(0,0,0,0.08);
}

/* CTA strip (repeated CTA like high-converting landing pages) */
.ctaStrip{
  margin-top:28px;
  border:1px solid var(--rule);
  border-radius: calc(var(--radius) + 6px);
  padding:26px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.00));
}
.ctaStrip h3{font-size:22px;letter-spacing:-0.02em;}
.ctaStrip .muted{color:var(--muted);margin-top:8px;}

/* Doctrine video insert */
.doctrineVideo{padding-top:86px;padding-bottom:86px;}
.videoStatement{text-align:center;max-width:820px;margin:0 auto 34px auto;}
.videoWrapper{
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 24px 90px rgba(0,0,0,0.18);
  border:1px solid rgba(0,0,0,0.06);
}
.videoWrapper video{width:100%;display:block;}

/* Responsive */
@media (max-width: 980px){
  .processGrid{grid-template-columns:1fr 1fr;}
  .ctaStrip{flex-direction:column;align-items:flex-start;}
}
@media (max-width: 640px){
  .processGrid{grid-template-columns:1fr;}
  .faqItem{padding:16px 18px;}
}

/* Subtle grid + noise texture */
body{position:relative;}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at 20% 10%, rgba(30,214,255,0.10), transparent 45%),
    radial-gradient(circle at 85% 70%, rgba(124,107,255,0.10), transparent 50%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 64px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.035) 0 1px, transparent 1px 64px);
  opacity:0.35;
  mix-blend-mode:screen;
}

@keyframes dotPulse{
  0%,100%{transform:scale(1);opacity:.85}
  50%{transform:scale(1.25);opacity:1}
}
.sliderDot.active{animation: dotPulse 1.6s ease-in-out infinite;}

/* Cinematic slow zoom on insert videos */
@keyframes slowZoom{
  0%{transform: scale(1);}
  100%{transform: scale(1.05);}
}
.videoWrapper video{
  animation: slowZoom 18s ease-in-out infinite alternate;
  transform-origin: center;
}

/* Typography & spacing rhythm */
.section{padding:120px 0;}
.hero{padding:110px 0 96px;}
h1{letter-spacing:-0.02em;}
.hero h1{font-size: clamp(34px, 4.2vw, 64px); line-height:1.05;}
h2{font-size: clamp(26px, 2.6vw, 40px); line-height:1.12;}
p{line-height:1.7;}

/* Availability indicator */
.availability{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  margin-left:18px;
  color:#333;
}

.availabilityDot{
  width:8px;
  height:8px;
  background:#22c55e;
  border-radius:50%;
  box-shadow:0 0 8px rgba(34,197,94,0.6);
}



/* Availability banner (landing page) */
.availabilityBanner{
  display:flex;
  justify-content:center;
  padding: 10px 16px 0;
}

.availabilityPill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.65);
  color:#fff;
  font-size:13px;
  letter-spacing:0.2px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.35);
}

/* Comparison table */
.compareSection .sectionHead{
  max-width: 760px;
  margin: 0 auto 32px;
  text-align:center;
}

.compareTable{
  width:100%;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.10);
  background: #ffffff;
}

.compareRow{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1.2fr;
  gap:0;
}

.compareCell{
  padding:14px 14px;
  border-top:1px solid rgba(0,0,0,0.08);
  font-size:14px;
  color: rgba(0,0,0,0.82);
}

.compareHeader .compareCell{
  border-top:none;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color: rgba(0,0,0,0.55);
  background: rgba(0,0,0,0.03);
}

.compareFeature{
  color:#0b0b0b;
  font-weight:600;
}

.compareBrand{
  background: linear-gradient(90deg, rgba(34,197,94,0.12), rgba(34,197,94,0.02));
}

.tick{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:999px;
  margin-right:8px;
  background: rgba(34,197,94,0.15);
  color:#22c55e;
  font-weight:700;
  font-size:12px;
}

.mutedTick{
  background: rgba(0,0,0,0.06);
  color: rgba(0,0,0,0.55);
}

.chip{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  border:1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.03);
  color: rgba(0,0,0,0.75);
}

.chip.ok{
  border-color: rgba(34,197,94,0.35);
  background: rgba(34,197,94,0.12);
  color:#c8ffd9;
}

.chip.warn{
  border-color: rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.04);
}

.compareFoot{
  display:flex;
  justify-content:center;
  margin-top: 22px;
}

@media (max-width: 900px){
  .compareRow{
    grid-template-columns: 1.3fr 1fr 1fr;
  }
  .compareRow .compareCell:nth-child(4){
    display:none;
  }
}

@media (max-width: 640px){
  .compareRow{
    grid-template-columns: 1.2fr 1fr;
  }
  .compareRow .compareCell:nth-child(3){
    display:none;
  }
}
