/* ============================================================
   Lobit — Homepage extras
   Overrides and modernised components: CTA frame, reviews,
   contact form, footer typography.
   Loaded AFTER /css/style.css.
   ============================================================ */

/* ---------- 1. "Not sure which package fits?" CTA frame ---------- */
.cta-frame{
  margin-top:64px;
  position:relative;
  border-radius:28px;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(245,165,36,.55) 0%,
    rgba(43,127,255,.4) 50%,
    rgba(245,165,36,.55) 100%);
  background-size:200% 200%;
  animation:ctaFrameShift 12s ease infinite;
  box-shadow:0 30px 80px -30px rgba(245,165,36,.35),
             0 10px 40px -20px rgba(43,127,255,.45);
}
@keyframes ctaFrameShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.cta-frame-inner{
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(43,127,255,.18) 0%, transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(245,165,36,.18) 0%, transparent 55%),
    linear-gradient(180deg, #11173d 0%, #0d1338 100%);
  border-radius:27px;
  padding:42px 44px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:32px;
}
.cta-frame-icon{
  font-size:60px;
  line-height:1;
  width:96px;height:96px;
  display:flex;align-items:center;justify-content:center;
  border-radius:24px;
  background:linear-gradient(135deg, rgba(245,165,36,.18), rgba(43,127,255,.18));
  border:1px solid rgba(255,255,255,.1);
  box-shadow:inset 0 0 30px rgba(245,165,36,.12);
}
.cta-frame-tag{
  display:inline-block;
  font:600 11.5px ui-monospace,monospace;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--orange);
  background:rgba(245,165,36,.1);
  border:1px solid rgba(245,165,36,.3);
  padding:6px 12px;
  border-radius:999px;
  margin-bottom:14px;
}
.cta-frame-body h3{
  font-size:clamp(22px,2.4vw,28px);
  font-weight:800;
  color:#fff;
  letter-spacing:-0.01em;
  margin:0 0 10px;
  line-height:1.2;
}
.cta-frame-body p{
  color:var(--ink-2);
  font-size:15.5px;
  line-height:1.6;
  margin:0 0 14px;
  max-width:540px;
}
.cta-frame-checks{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px 18px;
}
.cta-frame-checks li{
  font-size:13.5px;
  color:var(--silver);
  font-weight:500;
}
.cta-frame-action{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}
.cta-frame-btn{
  white-space:nowrap;
  font-size:16px;
  padding:18px 28px;
  box-shadow:0 18px 40px -10px rgba(245,165,36,.55);
}
.cta-frame-note{
  font-size:12.5px;
  color:var(--muted);
  font-weight:500;
}
@media (max-width:880px){
  .cta-frame-inner{
    grid-template-columns:1fr;
    padding:32px 26px;
    gap:20px;
    text-align:left;
  }
  .cta-frame-action{align-items:stretch}
  .cta-frame-icon{margin-bottom:4px}
}

/* ---------- 2. Reviews section ---------- */
.reviews-section{position:relative;overflow:hidden}
.reviews-section::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(60% 50% at 20% 0%, rgba(245,165,36,.08) 0%, transparent 60%),
    radial-gradient(50% 40% at 80% 100%, rgba(43,127,255,.1) 0%, transparent 60%);
  pointer-events:none;
}
.reviews-section > .container{position:relative;z-index:1}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:22px;
  margin-top:46px;
}
.review-card{
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  padding:30px 28px 26px;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  overflow:hidden;
}
.review-card::before{
  content:"\201C"; /* big opening quote */
  position:absolute;
  top:-14px;
  right:18px;
  font-size:110px;
  line-height:1;
  font-family:Georgia,serif;
  color:rgba(245,165,36,.18);
  pointer-events:none;
}
.review-card:hover{
  transform:translateY(-4px);
  border-color:rgba(245,165,36,.35);
  box-shadow:0 30px 60px -25px rgba(0,0,0,.5),
             0 0 0 1px rgba(245,165,36,.15);
}
.review-stars{
  color:var(--orange);
  font-size:18px;
  letter-spacing:3px;
  margin-bottom:14px;
  filter:drop-shadow(0 0 8px rgba(245,165,36,.45));
}
.review-card p{
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  margin:0 0 24px;
  font-weight:400;
}
.review-author{
  display:flex;
  align-items:center;
  gap:14px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
}
.review-author .avatar{
  width:44px;height:44px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--orange), #ff8a4c);
  color:#0A0E2A;
  font-weight:800;
  font-size:14px;
  letter-spacing:.5px;
  box-shadow:0 6px 18px -6px rgba(245,165,36,.5);
  flex-shrink:0;
}
.review-author strong{
  display:block;
  color:#fff;
  font-size:14.5px;
  font-weight:700;
  line-height:1.2;
  margin-bottom:2px;
}
.review-author span{
  color:var(--muted);
  font-size:12.5px;
  font-weight:500;
}

/* ---------- 3. Contact section ---------- */
.contact-section{position:relative;overflow:hidden}
.contact-section::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(50% 45% at 0% 50%, rgba(43,127,255,.1) 0%, transparent 60%),
    radial-gradient(50% 45% at 100% 50%, rgba(245,165,36,.08) 0%, transparent 60%);
  pointer-events:none;
}
.contact-section > .container{position:relative;z-index:1}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:56px;
  align-items:start;
}
.contact-info .section-title{margin-bottom:14px}
.contact-lead{
  color:var(--ink-2);
  font-size:16px;
  line-height:1.65;
  margin-bottom:30px;
}
.contact-perks{
  list-style:none;
  padding:0;
  margin:0 0 32px;
  display:grid;
  gap:14px;
}
.contact-perks li{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:14px 16px;
  border-radius:14px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
}
.contact-perk-icon{
  font-size:22px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.contact-perks strong{
  display:block;
  color:#fff;
  font-size:14.5px;
  font-weight:700;
  margin-bottom:2px;
}
.contact-perks span{
  display:block;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.5;
}
.contact-channels{
  display:grid;
  gap:10px;
}
.contact-channel{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:14px 16px;
  border-radius:12px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  color:var(--ink-2);
  text-decoration:none;
  transition:border-color .15s, background .15s;
}
a.contact-channel:hover{
  border-color:rgba(245,165,36,.4);
  background:rgba(245,165,36,.06);
}
.contact-channel-icon{
  font-size:20px;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.contact-channel strong{
  display:block;
  color:#fff;
  font-weight:700;
  font-size:14.5px;
  margin-bottom:2px;
}
.contact-channel span span{
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}

/* Form card */
.contact-form--card{
  background:linear-gradient(180deg,
    rgba(255,255,255,.04) 0%,
    rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  padding:34px 32px;
  position:relative;
  box-shadow:0 40px 100px -40px rgba(0,0,0,.6),
             inset 0 1px 0 rgba(255,255,255,.06);
}
.contact-form--card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:25px;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(245,165,36,.4) 0%,
    rgba(43,127,255,.0) 40%,
    rgba(43,127,255,.0) 60%,
    rgba(245,165,36,.25) 100%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}
.contact-form-header{
  margin:0 -32px 26px;
  padding:0 32px 22px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.contact-form-header h3{
  font-size:22px;
  font-weight:800;
  color:#fff;
  margin:0 0 6px;
  letter-spacing:-0.01em;
}
.contact-form-header p{
  color:var(--muted);
  font-size:13.5px;
  font-weight:500;
  margin:0;
}
.contact-form--card label{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--ink-2);
  margin-bottom:14px;
  letter-spacing:.01em;
}
.contact-form--card .form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.contact-form--card input[type="text"],
.contact-form--card input[type="email"],
.contact-form--card input[type="url"],
.contact-form--card select,
.contact-form--card textarea{
  display:block;
  width:100%;
  margin-top:7px;
  padding:13px 14px;
  background:rgba(10,14,42,.55);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  color:#fff;
  font:400 15px Inter,system-ui,sans-serif;
  transition:border-color .15s, box-shadow .15s, background .15s;
}
.contact-form--card textarea{resize:vertical;min-height:108px;line-height:1.5}
.contact-form--card input::placeholder,
.contact-form--card textarea::placeholder{color:rgba(212,218,240,.4)}
.contact-form--card input:focus,
.contact-form--card select:focus,
.contact-form--card textarea:focus{
  outline:0;
  border-color:rgba(245,165,36,.55);
  background:rgba(10,14,42,.75);
  box-shadow:0 0 0 4px rgba(245,165,36,.14);
}
.contact-form--card select{
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238FBAFF' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:14px;
  padding-right:38px;
}
.contact-form--card .checkbox-row{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-weight:400;
  font-size:13px;
  color:var(--muted);
  line-height:1.5;
  margin:8px 0 14px;
}
.contact-form--card .checkbox-row input[type="checkbox"]{
  margin-top:3px;
  accent-color:var(--orange);
  flex-shrink:0;
}
.contact-form--card .checkbox-row a{color:var(--blue-300);text-decoration:underline}
.contact-form--card .btn-block{
  width:100%;
  display:block;
  text-align:center;
  font-size:16px;
  padding:18px 28px;
  margin-top:6px;
  box-shadow:0 18px 40px -10px rgba(245,165,36,.55);
}
.contact-form--card .form-note{
  text-align:center;
  font-size:12.5px;
  color:var(--muted);
  margin:14px 0 0;
}
@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-form--card{padding:28px 22px}
  .contact-form-header{margin:0 -22px 22px;padding:0 22px 18px}
  .contact-form--card .form-row{grid-template-columns:1fr}
}

/* ---------- 4. Footer (typography + spacing) ---------- */
.site-footer{
  padding-top:84px !important;
  padding-bottom:32px;
}
.site-footer .footer-grid{
  padding-top:24px;
  gap:56px;
  margin-bottom:56px;
}
.site-footer .footer-col h4{
  font:800 16px Inter,system-ui,sans-serif !important;
  letter-spacing:-0.005em !important;
  text-transform:none !important;
  color:#fff !important;
  margin-bottom:22px !important;
  position:relative;
  padding-bottom:14px;
}
.site-footer .footer-col h4::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:30px;
  height:3px;
  border-radius:2px;
  background:linear-gradient(90deg, var(--orange), #ff8a4c);
}
.site-footer .footer-col ul{gap:14px}
.site-footer .footer-col a{
  font-size:15px;
  font-weight:500;
  color:var(--ink-2);
}
.site-footer .footer-col a:hover{color:var(--orange)}
.site-footer .footer-col li{color:var(--ink-2);font-size:14.5px;line-height:1.6}
.site-footer .footer-brand{padding-top:8px}
.site-footer .footer-brand .footer-logo{height:42px;width:auto;margin-bottom:18px}
.site-footer .footer-brand p{
  color:var(--muted);
  font-size:15px;
  line-height:1.65;
  max-width:340px;
  margin-bottom:22px;
}
.footer-socials{display:flex;gap:10px}
.footer-socials a{
  width:40px;height:40px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  display:inline-flex;
  align-items:center;justify-content:center;
  color:#fff;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  transition:transform .15s, background .15s, border-color .15s;
}
.footer-socials a:hover{
  background:var(--orange);
  color:#0A0E2A;
  border-color:var(--orange);
  transform:translateY(-2px);
}
.site-footer .footer-bottom{
  font-family:Inter,system-ui,sans-serif !important;
  font-size:13.5px !important;
  color:var(--silver) !important;
  text-transform:none !important;
  letter-spacing:0 !important;
}
.footer-legal a{color:var(--ink-2);text-decoration:none;margin-left:6px}
.footer-legal a:hover{color:var(--orange)}

@media (max-width:980px){
  .site-footer .footer-grid{gap:36px;grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .site-footer .footer-grid{grid-template-columns:1fr}
  .site-footer{padding-top:64px !important}
}

/* ============================================================
   Inner page upgrades (SEO Optimisation, SEO Audit, etc.)
   ============================================================ */

/* ---------- Service page hero ---------- */
.svc-hero{
  position:relative;
  padding:120px 0 70px;
  overflow:hidden;
}
.svc-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(50% 50% at 80% 0%, rgba(245,165,36,.16) 0%, transparent 60%),
    radial-gradient(60% 60% at 0% 100%, rgba(43,127,255,.18) 0%, transparent 60%);
  pointer-events:none;
}
.svc-hero > .container{position:relative;z-index:1}
.svc-hero-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:64px;
  align-items:center;
}
.svc-hero .section-eyebrow{margin-bottom:14px}
.svc-hero h1{
  font-size:clamp(36px,5vw,56px);
  font-weight:900;
  line-height:1.05;
  letter-spacing:-0.025em;
  color:#fff;
  margin:0 0 18px;
}
.svc-hero h1 .accent{
  background:linear-gradient(135deg, var(--orange), #ff8a4c);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.svc-hero .hero-tagline{
  font-size:clamp(20px,2.2vw,26px);
  color:var(--ink-2);
  font-weight:500;
  margin:0 0 20px;
  line-height:1.35;
}
.svc-hero .hero-subtitle{
  font-size:17px;
  color:var(--silver);
  line-height:1.7;
  max-width:580px;
  margin:0 0 30px;
}
.svc-hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:34px;
}
.svc-hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  max-width:560px;
}
.svc-hero-stats > div{
  border-left:2px solid rgba(245,165,36,.5);
  padding-left:16px;
}
.svc-hero-stat-num{
  font-size:28px;
  font-weight:800;
  color:#fff;
  letter-spacing:-0.01em;
  line-height:1.1;
}
.svc-hero-stat-label{
  font-size:12.5px;
  color:var(--muted);
  margin-top:6px;
  line-height:1.4;
}
.svc-hero-visual{
  position:relative;
  border-radius:24px;
  padding:1px;
  background:linear-gradient(135deg, rgba(245,165,36,.45), rgba(43,127,255,.35));
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
}
.svc-hero-visual-inner{
  background:linear-gradient(180deg,#11173d,#0d1338);
  border-radius:23px;
  padding:32px;
  position:relative;
  overflow:hidden;
}
.svc-hero-visual-inner::before{
  content:"";
  position:absolute;
  inset:-50% -50% auto auto;
  width:60%;
  height:200%;
  background:radial-gradient(circle, rgba(245,165,36,.25), transparent 60%);
  pointer-events:none;
}
.svc-hero-visual h4{
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--blue-300);
  margin:0 0 18px;
  position:relative;
}
.svc-hero-visual ul{
  list-style:none;
  padding:0;
  margin:0;
  position:relative;
  display:grid;
  gap:14px;
}
.svc-hero-visual ul li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:15px;
  line-height:1.55;
  color:var(--ink-2);
}
.svc-hero-visual ul li::before{
  content:"✓";
  width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(245,165,36,.18);
  border:1px solid rgba(245,165,36,.35);
  color:var(--orange);
  border-radius:50%;
  font-size:12px;
  font-weight:800;
  flex-shrink:0;
  margin-top:1px;
}
@media (max-width:980px){
  .svc-hero{padding:80px 0 50px}
  .svc-hero-grid{grid-template-columns:1fr;gap:36px}
  .svc-hero-stats{grid-template-columns:repeat(3,1fr);gap:14px}
}
@media (max-width:560px){
  .svc-hero-stats{grid-template-columns:1fr 1fr;gap:14px}
}

/* ---------- Modern numbered process steps ---------- */
.proc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
  margin-top:40px;
  counter-reset:proc;
}
.proc-card{
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:30px 24px 24px;
  counter-increment:proc;
  transition:transform .25s, border-color .25s, box-shadow .25s;
  overflow:hidden;
}
.proc-card::before{
  content:counter(proc,decimal-leading-zero);
  position:absolute;
  top:18px;
  right:20px;
  font-size:34px;
  font-weight:900;
  background:linear-gradient(135deg, rgba(245,165,36,.35), rgba(43,127,255,.25));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  letter-spacing:-0.04em;
  line-height:1;
}
.proc-card:hover{
  transform:translateY(-4px);
  border-color:rgba(245,165,36,.35);
  box-shadow:0 30px 60px -25px rgba(0,0,0,.5);
}
.proc-card .proc-icon{
  font-size:30px;
  width:54px;height:54px;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(245,165,36,.15), rgba(43,127,255,.1));
  border:1px solid rgba(255,255,255,.08);
  margin-bottom:16px;
}
.proc-card h3{
  font-size:17px;
  font-weight:800;
  color:#fff;
  margin:0 0 8px;
  letter-spacing:-0.01em;
}
.proc-card p{
  font-size:14.5px;
  color:var(--ink-2);
  line-height:1.6;
  margin:0;
}

/* ---------- Proof strip ---------- */
.proof-strip{
  margin-top:50px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  background:linear-gradient(180deg,
    rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  overflow:hidden;
}
.proof-strip .proof{
  padding:24px 22px;
  text-align:center;
  border-right:1px solid rgba(255,255,255,.08);
}
.proof-strip .proof:last-child{border-right:0}
.proof-strip .proof-num{
  font-size:30px;
  font-weight:900;
  color:var(--orange);
  letter-spacing:-0.02em;
  line-height:1.1;
  margin-bottom:4px;
}
.proof-strip .proof-label{
  font-size:13px;
  color:var(--silver);
  font-weight:500;
}
@media (max-width:760px){
  .proof-strip{grid-template-columns:1fr 1fr}
  .proof-strip .proof{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}
  .proof-strip .proof:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}
}

/* ---------- Benefits grid ---------- */
.benefits-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:18px;
  margin-top:36px;
}
.benefit-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:24px 22px;
  transition:border-color .2s, transform .2s;
}
.benefit-card:hover{
  border-color:rgba(245,165,36,.35);
  transform:translateY(-2px);
}
.benefit-card .benefit-icon{
  font-size:24px;
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(245,165,36,.15), rgba(43,127,255,.1));
  margin-bottom:14px;
}
.benefit-card strong{
  display:block;
  font-size:15px;
  font-weight:700;
  color:#fff;
  margin-bottom:6px;
}
.benefit-card p{
  font-size:14px;
  color:var(--ink-2);
  line-height:1.55;
  margin:0;
}

/* ---------- Modern pricing grid ---------- */
.pricing-deck{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:46px;
}
.pricing-deck .price{
  position:relative;
  background:linear-gradient(180deg,
    rgba(255,255,255,.04) 0%,
    rgba(255,255,255,.015) 100%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:22px;
  padding:30px 28px 28px;
  display:flex;flex-direction:column;
  transition:border-color .25s, transform .25s, box-shadow .25s;
}
.pricing-deck .price:hover{
  border-color:rgba(43,127,255,.3);
  transform:translateY(-4px);
}
.pricing-deck .price.popular{
  background:linear-gradient(180deg,
    rgba(245,165,36,.08) 0%,
    rgba(255,255,255,.02) 100%);
  border-color:rgba(245,165,36,.45);
  box-shadow:0 30px 80px -30px rgba(245,165,36,.4);
}
.pricing-deck .price.popular::before{
  content:"MOST POPULAR";
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  background:linear-gradient(135deg, var(--orange), #ff8a4c);
  color:#0A0E2A;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  padding:6px 14px;
  border-radius:999px;
  box-shadow:0 8px 24px -6px rgba(245,165,36,.6);
}
.pricing-deck .price .price-eyebrow{
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  color:var(--blue-300);
  text-transform:uppercase;
  margin-bottom:14px;
}
.pricing-deck .price.popular .price-eyebrow{color:var(--orange)}
.pricing-deck .price .price-amount{
  font-size:38px;
  font-weight:900;
  color:#fff;
  letter-spacing:-0.025em;
  line-height:1;
  margin-bottom:6px;
}
.pricing-deck .price .price-amount .price-prefix{
  font-size:14px;
  font-weight:500;
  color:var(--muted);
  display:block;
  letter-spacing:0;
  margin-bottom:4px;
}
.pricing-deck .price .price-amount .price-period{
  font-size:14px;
  font-weight:500;
  color:var(--muted);
  letter-spacing:0;
}
.pricing-deck .price .price-blurb{
  font-size:14px;
  color:var(--ink-2);
  line-height:1.55;
  margin:14px 0 22px;
  padding-bottom:20px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.pricing-deck .price ul.price-feats{
  list-style:none;
  padding:0;
  margin:0 0 26px;
  display:grid;
  gap:10px;
  flex:1;
}
.pricing-deck .price ul.price-feats li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  color:var(--ink-2);
  line-height:1.5;
}
.pricing-deck .price ul.price-feats li::before{
  content:"✓";
  width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(82,214,147,.15);
  color:var(--success);
  border-radius:50%;
  font-size:12px;
  font-weight:800;
  flex-shrink:0;
  margin-top:1px;
}
.pricing-deck .price .price-cta{
  display:block;
  text-align:center;
  font-size:14.5px;
  padding:14px 18px;
}
@media (max-width:980px){
  .pricing-deck{grid-template-columns:1fr;gap:30px}
  .pricing-deck .price.popular{order:-1}
}

/* ---------- Modern details FAQ ---------- */
.faq-modern{
  margin-top:36px;
  display:grid;
  gap:12px;
  max-width:920px;
}
.faq-modern details{
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  overflow:hidden;
  transition:border-color .25s;
}
.faq-modern details[open]{
  border-color:rgba(245,165,36,.4);
  box-shadow:0 14px 40px -16px rgba(0,0,0,.5);
}
.faq-modern summary{
  list-style:none;
  cursor:pointer;
  padding:18px 22px;
  font-size:16px;
  font-weight:700;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  letter-spacing:-0.005em;
  line-height:1.4;
  transition:color .15s;
}
.faq-modern summary::-webkit-details-marker{display:none}
.faq-modern summary:hover{color:var(--orange-2)}
.faq-modern summary::after{
  content:"+";
  flex-shrink:0;
  width:32px;height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:rgba(245,165,36,.15);
  border:1px solid rgba(245,165,36,.3);
  color:var(--orange);
  font-size:20px;
  font-weight:700;
  line-height:1;
  transition:transform .3s ease, background .2s;
}
.faq-modern details[open] summary::after{
  transform:rotate(45deg);
  background:rgba(245,165,36,.25);
}
.faq-modern details > div{
  padding:0 22px 22px;
  color:var(--ink-2);
  font-size:15px;
  line-height:1.7;
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:18px;
  margin-top:-1px;
}
.faq-modern details:not([open]) > div{display:none}

/* ---------- Background variants for service pages ---------- */
.section-soft{
  position:relative;
  overflow:hidden;
}
.section-soft::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(40% 40% at 10% 0%, rgba(43,127,255,.08) 0%, transparent 60%),
    radial-gradient(50% 40% at 100% 100%, rgba(245,165,36,.06) 0%, transparent 60%);
  pointer-events:none;
}
.section-soft > .container{position:relative;z-index:1}


/* ---------- Pricing note callout ---------- */
.pricing-note{
  margin-top:32px;
  padding:22px 26px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-left:3px solid var(--orange);
  border-radius:12px;
}
.pricing-note p{
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.65;
  margin:0;
}
.pricing-note p + p{margin-top:8px}
.pricing-note strong{color:#fff}

/* ============================================================
   H1 hierarchy enforcement — H1 must dominate visually
   ============================================================ */

/* Service-page H1 (SEO Optimisation, SEO Audit) */
.svc-hero h1{
  font-size:clamp(48px, 7vw, 84px) !important;
  font-weight:900 !important;
  letter-spacing:-0.035em;
  line-height:1.02;
  margin:0 0 16px;
}
.svc-hero .hero-tagline{
  font-size:clamp(18px, 1.9vw, 22px);
  font-weight:500;
  color:var(--ink-2);
  margin:0 0 18px;
  line-height:1.4;
  max-width:560px;
}

/* Standard page-hero H1 (Case Studies, About, Blog, Contact) */
.page-hero h1{
  font-size:clamp(48px, 6.5vw, 80px) !important;
  font-weight:900 !important;
  letter-spacing:-0.035em;
  line-height:1.02;
  margin:8px auto 16px;
}
.page-hero .hero-tagline{
  font-size:clamp(18px, 1.9vw, 22px);
  font-weight:500;
  color:var(--ink-2);
  margin:0 auto 14px;
  max-width:680px;
  line-height:1.45;
  text-align:center;
}
.page-hero .hero-subtitle{
  font-size:16px;
  max-width:620px;
  margin:0 auto 28px;
}

/* Homepage hero H1 */
.hero h1{
  font-size:clamp(54px, 8vw, 96px) !important;
  font-weight:900 !important;
  letter-spacing:-0.04em !important;
  line-height:1 !important;
  margin:0 0 18px !important;
}

@media (max-width:640px){
  .svc-hero h1,
  .page-hero h1{
    font-size:clamp(40px, 9vw, 56px) !important;
  }
  .hero h1{
    font-size:clamp(44px, 10vw, 64px) !important;
  }
}

/* ============================================================
   Pricing deck — 2-card centered variant
   ============================================================ */
.pricing-deck--duo{
  grid-template-columns:repeat(2, minmax(0, 360px)) !important;
  justify-content:center;
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}
@media (max-width:780px){
  .pricing-deck--duo{
    grid-template-columns:1fr !important;
    max-width:480px;
  }
}

/* ============================================================
   Beautified section eyebrows
   Adds a small orange gradient line + soft pill background
   to every .section-eyebrow site-wide.
   ============================================================ */
.section-eyebrow{
  display:inline-flex !important;
  align-items:center;
  gap:10px;
  font:700 12px Inter,system-ui,sans-serif !important;
  letter-spacing:.16em !important;
  text-transform:uppercase !important;
  color:var(--orange) !important;
  background:rgba(245,165,36,.08);
  border:1px solid rgba(245,165,36,.25);
  padding:7px 14px 7px 10px;
  border-radius:999px;
  margin-bottom:18px !important;
  position:relative;
  isolation:isolate;
}
.section-eyebrow::before{
  content:"";
  width:18px;
  height:2px;
  border-radius:2px;
  background:linear-gradient(90deg, var(--orange), #ff8a4c);
  box-shadow:0 0 8px rgba(245,165,36,.6);
  flex-shrink:0;
}
/* Center-aligned variant when section title block is centered */
.page-hero .section-eyebrow,
section[class*="section"] .section-eyebrow{
  /* Keep inline-flex default — flows naturally with text-align */
}
/* When the eyebrow is centered (e.g. in .page-hero), ensure the pill itself centers */
.page-hero .section-eyebrow{
  margin-left:auto;
  margin-right:auto;
}


/* ============================================================
   Case Studies — modern portfolio tiles
   ============================================================ */
.case-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(340px, 1fr));
  gap:24px;
  margin-top:48px;
}

.case-tile{
  position:relative;
  display:flex;
  flex-direction:column;
  text-decoration:none;
  border-radius:24px;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(255,255,255,.08) 0%,
    rgba(255,255,255,.02) 100%);
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
}
.case-tile::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:24px;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(245,165,36,.0) 0%,
    rgba(245,165,36,.0) 100%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
  transition:background .3s ease;
  z-index:2;
}
.case-tile:hover{
  transform:translateY(-6px);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.55),
             0 0 0 1px rgba(245,165,36,.2);
}
.case-tile:hover::before{
  background:linear-gradient(135deg,
    rgba(245,165,36,.55) 0%,
    rgba(43,127,255,.3) 50%,
    rgba(245,165,36,.45) 100%);
}

/* inner card */
.case-tile > *{position:relative;z-index:1}
.case-tile{
  background-clip:padding-box;
}
.case-tile::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:23px;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(43,127,255,.14) 0%, transparent 55%),
    radial-gradient(120% 80% at 100% 100%, rgba(245,165,36,.12) 0%, transparent 60%),
    linear-gradient(180deg, #11173d 0%, #0d1338 100%);
  z-index:0;
  pointer-events:none;
}

/* head */
.case-tile-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:24px 26px 0;
}
.case-tile-icon{
  width:60px;height:60px;
  font-size:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:16px;
  background:linear-gradient(135deg, rgba(245,165,36,.18), rgba(43,127,255,.14));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 0 20px rgba(245,165,36,.1);
  flex-shrink:0;
}
.case-tile-headline{
  font-size:clamp(28px, 3.4vw, 38px);
  font-weight:900;
  letter-spacing:-0.03em;
  line-height:1;
  background:linear-gradient(135deg, var(--orange) 0%, #ff8a4c 60%, #ffb547 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 6px 20px rgba(245,165,36,.35));
  text-align:right;
}

/* body */
.case-tile-body{
  padding:18px 26px 22px;
  flex:1;
}
.case-tile-niche{
  display:inline-block;
  font:700 11px Inter,system-ui,sans-serif;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue-300);
  background:rgba(43,127,255,.1);
  border:1px solid rgba(43,127,255,.25);
  padding:5px 10px;
  border-radius:999px;
  margin-bottom:14px;
}
.case-tile-body h3{
  font-size:20px;
  font-weight:800;
  color:#fff;
  letter-spacing:-0.015em;
  line-height:1.25;
  margin:0 0 12px;
}
.case-tile-body p{
  font-size:14.5px;
  color:var(--ink-2);
  line-height:1.55;
  margin:0;
}
.case-tile-body strong{color:#fff;font-weight:700}

/* stats strip */
.case-tile-stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  padding:0 26px;
  margin:0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.case-tile-stats > div{
  padding:16px 8px;
  text-align:center;
  border-right:1px solid rgba(255,255,255,.06);
}
.case-tile-stats > div:last-child{border-right:0}
.case-stat-num{
  font-size:17px;
  font-weight:800;
  color:#fff;
  letter-spacing:-0.01em;
  line-height:1.1;
  margin-bottom:3px;
}
.case-stat-label{
  font-size:11px;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--muted);
}

/* CTA */
.case-tile-cta{
  padding:18px 26px 22px;
  font-weight:700;
  font-size:14.5px;
  color:var(--orange-2);
  letter-spacing:-0.005em;
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:color .2s, gap .2s;
}
.case-tile-cta::after{
  content:"→";
  font-size:18px;
  transition:transform .25s ease;
}
.case-tile:hover .case-tile-cta{color:#fff}
.case-tile:hover .case-tile-cta::after{transform:translateX(6px)}

@media (max-width:640px){
  .case-grid{grid-template-columns:1fr;gap:18px}
  .case-tile-stats{grid-template-columns:repeat(3, 1fr)}
  .case-tile-head{padding:20px 20px 0}
  .case-tile-body{padding:16px 20px 20px}
  .case-tile-stats{padding:0 20px}
  .case-tile-cta{padding:16px 20px 20px}
}


/* ============================================================
   Modern breadcrumb (site-wide upgrade)
   Drop-in: <nav class="breadcrumb-modern container">...
   ============================================================ */
.breadcrumb-modern{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  padding:24px 20px 0;
  font:600 13px Inter,system-ui,sans-serif;
  color:var(--silver);
}
.breadcrumb-modern a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  color:var(--ink-2);
  text-decoration:none;
  transition:border-color .15s, color .15s, background .15s;
}
.breadcrumb-modern a:hover{
  color:var(--orange);
  border-color:rgba(245,165,36,.45);
  background:rgba(245,165,36,.08);
}
.breadcrumb-modern .bc-icon{font-size:13px;line-height:1}
.breadcrumb-modern .bc-sep{
  color:var(--muted);
  font-size:14px;
  line-height:1;
}
.breadcrumb-modern .bc-current{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  background:linear-gradient(135deg, rgba(245,165,36,.14), rgba(43,127,255,.1));
  border:1px solid rgba(245,165,36,.3);
  border-radius:999px;
  color:#fff;
  font-weight:700;
}

/* ============================================================
   Blog — Featured post (big card)
   ============================================================ */
.featured-post{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:0;
  text-decoration:none;
  border-radius:24px;
  overflow:hidden;
  margin-top:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.1);
  transition:transform .3s, border-color .3s, box-shadow .3s;
  position:relative;
}
.featured-post::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(60% 50% at 0% 0%, rgba(43,127,255,.1) 0%, transparent 60%),
    radial-gradient(60% 50% at 100% 100%, rgba(245,165,36,.1) 0%, transparent 60%);
  pointer-events:none;
}
.featured-post > *{position:relative;z-index:1}
.featured-post:hover{
  transform:translateY(-4px);
  border-color:rgba(245,165,36,.4);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.55),
             0 0 0 1px rgba(245,165,36,.15);
}
.featured-post-body{
  padding:40px 44px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.featured-post-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 14px;
  margin-bottom:18px;
}
.featured-post-body h2{
  font-size:clamp(26px, 3.4vw, 38px);
  font-weight:800;
  color:#fff;
  letter-spacing:-0.018em;
  line-height:1.15;
  margin:0 0 16px;
}
.featured-post-body p{
  font-size:16px;
  color:var(--ink-2);
  line-height:1.6;
  margin:0 0 22px;
  max-width:580px;
}
.featured-post-body strong{color:#fff;font-weight:700}
.featured-cta{
  font-weight:700;
  font-size:15px;
  color:var(--orange-2);
  letter-spacing:-0.005em;
}
.featured-post:hover .featured-cta{color:#fff}

.featured-post-visual{
  background:
    radial-gradient(60% 60% at 50% 50%, rgba(245,165,36,.16) 0%, transparent 70%),
    linear-gradient(135deg, #0d1338 0%, #11173d 100%);
  border-left:1px solid rgba(255,255,255,.06);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:30px;
}
.featured-post-stat{text-align:center}
.featured-stat-label{
  font:700 11px Inter,system-ui,sans-serif;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue-300);
  margin-bottom:10px;
}
.featured-stat-num{
  font-size:clamp(60px, 8vw, 88px);
  font-weight:900;
  letter-spacing:-0.04em;
  line-height:1;
  background:linear-gradient(135deg, var(--orange) 0%, #ff8a4c 60%, #ffb547 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 10px 30px rgba(245,165,36,.4));
}
.featured-stat-sub{
  margin-top:6px;
  font-size:13px;
  color:var(--silver);
  font-weight:500;
}

@media (max-width:880px){
  .featured-post{grid-template-columns:1fr}
  .featured-post-body{padding:32px 26px}
  .featured-post-visual{padding:36px 20px;border-left:0;border-top:1px solid rgba(255,255,255,.06)}
}

/* ============================================================
   Blog — Post tags
   ============================================================ */
.post-tag{
  display:inline-block;
  font:700 11px Inter,system-ui,sans-serif;
  letter-spacing:.13em;
  text-transform:uppercase;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid;
  white-space:nowrap;
}
.post-tag--orange{
  color:var(--orange);
  background:rgba(245,165,36,.1);
  border-color:rgba(245,165,36,.3);
}
.post-tag--blue{
  color:var(--blue-300);
  background:rgba(43,127,255,.1);
  border-color:rgba(43,127,255,.3);
}
.post-tag--green{
  color:var(--success);
  background:rgba(82,214,147,.1);
  border-color:rgba(82,214,147,.3);
}
.post-tag--purple{
  color:#c084fc;
  background:rgba(192,132,252,.1);
  border-color:rgba(192,132,252,.3);
}
.post-meta-item{
  font:500 12.5px Inter,system-ui,sans-serif;
  color:var(--muted);
  letter-spacing:.005em;
}

/* ============================================================
   Blog — Post cards grid
   ============================================================ */
.post-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:20px;
  margin-top:36px;
}
.post-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:24px 24px 20px;
  transition:transform .25s, border-color .25s, box-shadow .25s, background .25s;
  position:relative;
  overflow:hidden;
}
.post-card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--orange), transparent);
  opacity:0;
  transition:opacity .3s;
}
.post-card:hover{
  transform:translateY(-4px);
  border-color:rgba(245,165,36,.35);
  background:linear-gradient(180deg, rgba(245,165,36,.04), rgba(255,255,255,.015));
  box-shadow:0 30px 60px -25px rgba(0,0,0,.5);
}
.post-card:hover::before{opacity:1}
.post-card-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
}
.post-card h3{
  font-size:18px;
  font-weight:800;
  color:#fff;
  letter-spacing:-0.012em;
  line-height:1.3;
  margin:0 0 12px;
}
.post-card p{
  font-size:14px;
  color:var(--ink-2);
  line-height:1.55;
  margin:0 0 18px;
  flex:1;
}
.post-card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.06);
}
.post-author{
  font-size:12.5px;
  color:var(--muted);
  font-weight:500;
}
.post-arrow{
  font-size:18px;
  color:var(--orange);
  font-weight:700;
  transition:transform .25s;
}
.post-card:hover .post-arrow{transform:translateX(4px)}

/* ============================================================
   Blog — Topic pills (browse by topic)
   ============================================================ */
.topic-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:14px;
  margin-top:36px;
}
.topic-pill{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px 20px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  text-decoration:none;
  transition:border-color .15s, background .15s, transform .15s;
}
.topic-pill:hover{
  border-color:rgba(245,165,36,.4);
  background:rgba(245,165,36,.06);
  transform:translateY(-2px);
}
.topic-pill[data-active="true"]{
  border-color:rgba(245,165,36,.4);
  background:rgba(245,165,36,.08);
}
.topic-pill .topic-icon{
  font-size:24px;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(245,165,36,.15), rgba(43,127,255,.1));
  border:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.topic-pill > span:last-child{display:flex;flex-direction:column;gap:2px;min-width:0}
.topic-pill strong{
  font-size:14.5px;
  font-weight:700;
  color:#fff;
  line-height:1.2;
}
.topic-pill > span:last-child > span{
  font-size:12.5px;
  color:var(--muted);
  font-weight:500;
  line-height:1.3;
}

/* ============================================================
   Legacy .breadcrumb upgrade — make existing breadcrumbs
   look like .breadcrumb-modern without changing HTML.
   ============================================================ */
.breadcrumb{
  display:flex !important;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  padding:24px 0 0 !important;
  font:600 13px Inter,system-ui,sans-serif !important;
  letter-spacing:0 !important;
  text-transform:none !important;
  color:var(--silver) !important;
  margin-bottom:0 !important;
}
.breadcrumb a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  color:var(--ink-2) !important;
  text-decoration:none;
  transition:border-color .15s, color .15s, background .15s;
}
.breadcrumb a:hover{
  color:var(--orange) !important;
  border-color:rgba(245,165,36,.45);
  background:rgba(245,165,36,.08);
}
/* For legacy breadcrumb that uses "›" as plain text between links,
   we need to make the last text node (current page name) look highlighted.
   This is achieved with a generic adjacent-sibling rule on text after the last link. */
.breadcrumb > *:last-child:not(a){
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  background:linear-gradient(135deg, rgba(245,165,36,.14), rgba(43,127,255,.1));
  border:1px solid rgba(245,165,36,.3);
  border-radius:999px;
  color:#fff !important;
  font-weight:700;
}

/* ============================================================
   Case Study DETAIL pages — modern redesign
   ============================================================ */
.cs-hero{
  position:relative;
  padding:64px 0 30px;
  overflow:hidden;
}
.cs-hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(50% 50% at 80% 0%, rgba(245,165,36,.14) 0%, transparent 60%),
    radial-gradient(60% 60% at 0% 100%, rgba(43,127,255,.16) 0%, transparent 60%);
  pointer-events:none;
}
.cs-hero > .container{position:relative;z-index:1}

.cs-hero-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:48px;
  align-items:center;
}
.cs-hero-niche{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font:700 12px Inter,system-ui,sans-serif;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue-300);
  background:rgba(43,127,255,.1);
  border:1px solid rgba(43,127,255,.3);
  padding:7px 14px;
  border-radius:999px;
  margin-bottom:18px;
}
.cs-hero h1{
  font-size:clamp(36px, 4.4vw, 52px) !important;
  font-weight:900 !important;
  letter-spacing:-0.025em;
  line-height:1.05;
  color:#fff;
  margin:0 0 18px;
}
.cs-hero .lead{
  font-size:17px;
  color:var(--ink-2);
  line-height:1.65;
  margin:0 0 22px;
  max-width:580px;
}
.cs-hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  font-size:13.5px;
  color:var(--muted);
}
.cs-hero-meta-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  color:var(--ink-2);
  font-weight:600;
}

/* Headline number panel (right of hero) */
.cs-hero-panel{
  background:linear-gradient(180deg, #11173d, #0d1338);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  padding:34px 30px;
  text-align:center;
  position:relative;
  overflow:hidden;
  box-shadow:0 30px 80px -30px rgba(245,165,36,.3);
}
.cs-hero-panel::before{
  content:"";
  position:absolute;
  inset:-50% -50% auto auto;
  width:100%;height:200%;
  background:radial-gradient(circle, rgba(245,165,36,.18), transparent 60%);
  pointer-events:none;
}
.cs-hero-panel > *{position:relative;z-index:1}
.cs-hero-panel-label{
  font:700 11px Inter,system-ui,sans-serif;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue-300);
  margin-bottom:8px;
}
.cs-hero-panel-num{
  font-size:clamp(60px, 8vw, 92px);
  font-weight:900;
  letter-spacing:-0.04em;
  line-height:1;
  background:linear-gradient(135deg, var(--orange) 0%, #ff8a4c 60%, #ffb547 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 10px 30px rgba(245,165,36,.4));
}
.cs-hero-panel-sub{
  margin-top:6px;
  font-size:14px;
  color:var(--silver);
  font-weight:500;
  line-height:1.45;
}

@media (max-width:920px){
  .cs-hero-grid{grid-template-columns:1fr;gap:32px}
  .cs-hero-panel{padding:28px 24px}
}

/* Section frames */
.cs-section{
  padding:50px 0;
  position:relative;
}
.cs-section + .cs-section{padding-top:20px}
.cs-section h2{
  font-size:clamp(24px, 2.6vw, 32px);
  font-weight:800;
  color:#fff;
  letter-spacing:-0.02em;
  line-height:1.2;
  margin:0 0 22px;
}
.cs-section p{
  font-size:16px;
  color:var(--ink-2);
  line-height:1.7;
  max-width:760px;
  margin:0 0 16px;
}
.cs-section .container{position:relative;z-index:1}

/* Eyebrow already styled by section-eyebrow override; keep harmony */

/* Challenge callout */
.cs-callout{
  background:linear-gradient(180deg, rgba(245,165,36,.08), rgba(255,255,255,.02));
  border:1px solid rgba(245,165,36,.25);
  border-left:4px solid var(--orange);
  border-radius:14px;
  padding:22px 26px;
  margin:0 0 8px;
}
.cs-callout p{margin:0;color:var(--ink);font-size:15.5px;line-height:1.6}
.cs-callout strong{color:#fff}

/* Implementation bullet cards */
.cs-impl-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:14px;
  margin-top:26px;
}
.cs-impl-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:16px 18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.5;
  font-weight:500;
}
.cs-impl-item::before{
  content:"✓";
  flex-shrink:0;
  width:24px;height:24px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(82,214,147,.15);
  color:var(--success);
  border-radius:50%;
  font-weight:800;
  font-size:13px;
}

/* Big results grid */
.cs-results-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
  margin-top:30px;
}
.cs-result{
  background:linear-gradient(180deg,
    rgba(255,255,255,.04), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:30px 22px 26px;
  text-align:center;
  position:relative;
  overflow:hidden;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.cs-result::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg, transparent, var(--orange), transparent);
  opacity:.6;
}
.cs-result:hover{
  transform:translateY(-3px);
  border-color:rgba(245,165,36,.35);
  box-shadow:0 30px 60px -25px rgba(0,0,0,.5);
}
.cs-result-num{
  font-size:clamp(32px, 4vw, 44px);
  font-weight:900;
  letter-spacing:-0.025em;
  line-height:1;
  background:linear-gradient(135deg, var(--orange) 0%, #ff8a4c 60%, #ffb547 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 6px 18px rgba(245,165,36,.3));
  margin-bottom:10px;
}
.cs-result-label{
  font-size:13.5px;
  color:var(--ink-2);
  font-weight:500;
  line-height:1.45;
}
@media (max-width:760px){
  .cs-results-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:480px){
  .cs-results-grid{grid-template-columns:1fr}
}

/* Strategy / approach numbered cards (reuse .proc-grid but slim) */
.cs-strategy-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:16px;
  margin-top:26px;
  counter-reset:cs-proc;
}
.cs-strategy-card{
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:22px 22px 20px;
  counter-increment:cs-proc;
  transition:transform .25s, border-color .25s;
}
.cs-strategy-card::before{
  content:counter(cs-proc, decimal-leading-zero);
  position:absolute;
  top:14px;
  right:18px;
  font-size:24px;
  font-weight:900;
  background:linear-gradient(135deg, rgba(245,165,36,.4), rgba(43,127,255,.3));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  letter-spacing:-0.03em;
  line-height:1;
}
.cs-strategy-card:hover{
  transform:translateY(-3px);
  border-color:rgba(245,165,36,.3);
}
.cs-strategy-card h3{
  font-size:16px;
  font-weight:800;
  color:#fff;
  margin:0 0 8px;
  letter-spacing:-0.01em;
  padding-right:40px;
}
.cs-strategy-card p{
  font-size:14px;
  color:var(--ink-2);
  line-height:1.55;
  margin:0;
}

/* Conclusion box */
.cs-conclusion{
  background:
    radial-gradient(60% 100% at 0% 100%, rgba(43,127,255,.14) 0%, transparent 65%),
    radial-gradient(60% 100% at 100% 0%, rgba(245,165,36,.12) 0%, transparent 65%),
    linear-gradient(180deg, #11173d, #0d1338);
  border:1px solid rgba(255,255,255,.1);
  border-radius:22px;
  padding:34px 36px;
}
.cs-conclusion p{
  font-size:16px;
  color:var(--ink);
  line-height:1.7;
  margin:0 0 12px;
}
.cs-conclusion p:last-child{margin-bottom:0}

