/* assets/css/styles.css */

/* ---------- Reset & tokens ---------- */
:root{
  --primary:#2563eb;
  --primaryDark:#1e40af;
  --accent:#0f172a;
  --text:#334155;
  --muted:#64748b;
  --bg:#f8fafc;
  --card:#ffffff;
  --line:#e2e8f0;

  --radius:16px;
  --radius2:22px;

  --shadow-sm: 0 1px 2px rgba(2,6,23,.06);
  --shadow-md: 0 10px 30px rgba(2,6,23,.10);
  --shadow-lg: 0 18px 60px rgba(2,6,23,.14);

  --container: 1200px;

  --fs-0: 0.875rem;
  --fs-1: 0.95rem;
  --fs-2: 1.05rem;
  --fs-3: 1.25rem;
  --fs-4: 1.65rem;
  --fs-5: 2.15rem;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: "Manrope", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:"Sora", ui-sans-serif, system-ui;
  color: var(--accent);
  line-height:1.2;
  letter-spacing:-0.02em;
  margin:0;
}
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
[x-cloak]{ display:none !important; }

.container{
  width: min(var(--container), 92%);
  margin: 0 auto;
}

/* ---------- UI helpers ---------- */
.grad-text{
  background: linear-gradient(135deg, var(--primary) 0%, #4f46e5 60%, #06b6d4 115%);
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding: .55rem .9rem;
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 750;
  color: var(--primary);
  background: #eff6ff;
  border: 1px solid #dbeafe;
}
.pill i{ width:16px; height:16px; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding: .86rem 1.25rem;
  border-radius: 12px;
  font-weight: 850;
  font-size: var(--fs-1);
  cursor:pointer;
  border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  user-select:none;
}
.btn i{ width:18px; height:18px; }
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--primary{
  background: linear-gradient(135deg, var(--primary), #4f46e5);
  color:#fff;
  box-shadow: 0 12px 30px rgba(37,99,235,.28);
}
.btn--primary:hover{ background: linear-gradient(135deg, var(--primaryDark), #4338ca); }
.btn--outline{
  background: transparent;
  color: var(--accent);
  border-color: rgba(15,23,42,.22);
}
.btn--outline:hover{
  background: var(--accent);
  color:#fff;
  border-color: var(--accent);
}
.btn--soft{
  background: #fff;
  border-color: var(--line);
  color: var(--accent);
}
.btn--soft:hover{ background:#f1f5f9; }
.btn--white{
  background:#fff;
  color: var(--primary);
  border-color: rgba(255,255,255,.18);
}
.btn--block{ width:100%; }

/* ---------- Top strip (Desktop only) ---------- */
.topstrip{
  background: var(--accent);
  color: rgba(255,255,255,.92);
  font-size: .9rem;
  padding: .55rem 0;
  display:none;               /* hidden by default (mobile) */
}
.topstrip__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:.9rem;
  flex-wrap:wrap;
}
.topstrip__item{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-weight: 750;
}
.topstrip__item i{ width:16px; height:16px; }

@media (min-width: 992px){
  .topstrip{ display:block; } /* show only desktop */
}

/* ---------- Header ---------- */
.header{
  position: sticky; top:0; z-index: 60;
  background: rgba(248,250,252,.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(2,6,23,.06);
  transition: box-shadow .25s ease, background .25s ease;
}
.header--scrolled{
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow-sm);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding: 1rem 0;
}
.brand{
  display:flex; align-items:center; gap:.75rem;
  min-width: 220px;
}
.brand__icon{
  width:44px; height:44px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, #dbeafe, #eef2ff);
  border: 1px solid rgba(37,99,235,.20);
}
.brand__icon i{ width:22px; height:22px; color: var(--primary); }
.brand__name{ font-weight: 950; font-size: 1.1rem; }
.brand__tag{
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: .1rem;
}

.nav{ display:none; gap: 1.6rem; align-items:center; }
.nav a{
  font-weight: 850;
  font-size: var(--fs-1);
  color: var(--text);
  opacity: .88;
}
.nav a:hover{ color: var(--primary); opacity: 1; }
.nav a.active{ color: var(--primary); }

.header__cta{ display:none; gap:.75rem; align-items:center; }

.iconbtn{
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  width: 44px; height: 44px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
}
.iconbtn i{ width:22px; height:22px; color: var(--accent); }

/* Desktop */
@media (min-width: 992px){
  .nav{ display:flex; }
  .header__cta{ display:flex; }
  .iconbtn{ display:none; }
}

/* ---------- Drawer (mobile) ---------- */
.drawerOverlay{
  position: fixed; inset:0;
  background: rgba(2,6,23,.55);
  z-index: 90;
}
.drawer{
  position: fixed; top:0; right:0; bottom:0;
  width: min(420px, 86%);
  background: #fff;
  z-index: 100;
  display:flex;
  flex-direction:column;
  box-shadow: var(--shadow-lg);
}
.drawer__top{
  padding: 1rem 1rem .85rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom: 1px solid rgba(2,6,23,.06);
}
.drawer__links{
  padding: .9rem 1rem;
  display:grid;
  gap:.6rem;
}
.drawer__links a{
  padding: .95rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #fff;
  font-weight: 950;
  color: var(--accent);
  outline: none;
}
.drawer__links a:hover{ background:#f1f5f9; }
.drawer__links a:focus{
  box-shadow: 0 0 0 4px rgba(37,99,235,.18);
  border-color: rgba(37,99,235,.3);
}
.drawer__footer{
  margin-top:auto;
  padding: 1rem;
  border-top: 1px solid rgba(2,6,23,.06);
  display:grid;
  gap:.7rem;
}

/* ---------- Hero ---------- */
.hero{
  position: relative;
  padding: 3.8rem 0 2.8rem;
  overflow:hidden;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.hero__grid{
  display:grid;
  gap: 2.4rem;
  align-items:center;
}
@media (min-width: 992px){
  .hero__grid{ grid-template-columns: 1.15fr 1fr; gap: 3.2rem; }
}

.hero__badgeRow{ display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom: 1.25rem; }

.hero h1{
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  margin-bottom: 1rem;
  font-weight: 950;
}
.hero__lead{
  font-size: clamp(1.02rem, 1.2vw, 1.14rem);
  color: var(--muted);
  max-width: 58ch;
  margin-bottom: 1.7rem;
}
.hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
  margin-bottom: 1.6rem;
}

/* Trust mini list */
.trustRow{
  display:grid;
  grid-template-columns: 1fr;
  gap:.75rem;
  margin-top: 1rem;
}
@media (min-width: 680px){
  .trustRow{ grid-template-columns: repeat(3, 1fr); }
}
.trust{
  background:#fff;
  border: 1px solid rgba(2,6,23,.06);
  border-radius: var(--radius);
  padding: .95rem 1rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
  display:flex;
  gap:.65rem;
}
.trust i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.trust__t{ font-weight: 950; color: var(--accent); font-size: .98rem; }
.trust__d{ color: var(--muted); font-weight: 700; font-size: .92rem; margin-top:.15rem; }

/* Hero visual */
.heroCard{
  position: relative;
  border-radius: 24px;
  overflow:hidden;
  background:#fff;
  border: 1px solid rgba(2,6,23,.06);
  box-shadow: var(--shadow-lg);
}

/* NEW: safe top header area inside hero card (no overlap) */
.heroCard__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  padding: .95rem 1rem;
  border-bottom: 1px solid rgba(2,6,23,.06);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
}
.heroCard__topLeft{
  display:flex;
  align-items:center;
  gap:.75rem;
}
.statusDot{
  width:42px; height:42px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: #dcfce7;
  border: 1px solid rgba(22,101,52,.18);
}
.statusDot i{ width:20px; height:20px; color:#166534; }
.heroCard__topText strong{ display:block; font-weight: 950; color: var(--accent); }
.heroCard__topText span{ display:block; color: var(--muted); font-weight: 800; font-size: .9rem; }

.heroCard__img{
  aspect-ratio: 16/10;
  background:#e2e8f0;
}
.heroCard__img img{
  width:100%; height:100%;
  object-fit:cover;
}

/* Bento below image */
.bento{
  padding: 1rem;
  display:grid;
  gap:.8rem;
  grid-template-columns: 1fr;
  background: linear-gradient(#fff, #fff);
}
@media (min-width: 680px){
  .bento{ grid-template-columns: repeat(2, 1fr); }
}
.bentoItem{
  border-radius: 16px;
  border: 1px solid rgba(2,6,23,.06);
  background: #fff;
  padding: .95rem 1rem;
  display:flex; gap:.65rem;
  align-items:flex-start;
}
.bentoItem i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.bentoItem__t{ font-weight: 950; color: var(--accent); }
.bentoItem__d{ color: var(--muted); font-weight: 700; font-size: .92rem; margin-top:.12rem; }

/* ---------- Stats strip (improved) ---------- */
.statsStrip{
  background: var(--accent);
  color:#fff;
  padding: 2.2rem 0;
  margin-top: -1.7rem;
  position: relative;
  z-index: 10;
}
.statsGrid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media (min-width: 900px){
  .statsGrid{ grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
}

/* NEW: stat cards */
.statCard{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 1rem 1rem;
  display:flex;
  gap:.75rem;
  align-items:center;
}
.statIcon{
  width:46px; height:46px;
  border-radius: 16px;
  background: rgba(147,197,253,.18);
  border: 1px solid rgba(147,197,253,.22);
  display:flex; align-items:center; justify-content:center;
  flex: 0 0 auto;
}
.statIcon i{ width:20px; height:20px; color:#93c5fd; }
.statText{ min-width: 0; }
.statNum{
  font-size: 1.75rem;
  font-weight: 950;
  font-family:"Sora", ui-sans-serif;
  letter-spacing:-0.02em;
  line-height: 1.1;
  color:#fff;
}
.statLbl{
  margin-top:.15rem;
  color:#cbd5e1;
  font-weight: 750;
  font-size: .92rem;
  line-height: 1.35;
}

/* ---------- Sections ---------- */
.section{ padding: 5rem 0; }
.sectionHead{
  text-align:center;
  max-width: 740px;
  margin: 0 auto 3rem;
}
.sectionHead h2{
  font-size: clamp(1.65rem, 2.6vw, 2.35rem);
  margin-bottom: .85rem;
  font-weight: 950;
}
.sectionHead p{
  color: var(--muted);
  font-size: var(--fs-2);
}

/* Services grid */
.servicesGrid{
  display:grid;
  gap: 1.2rem;
  grid-template-columns: 1fr;
}
@media (min-width: 740px){
  .servicesGrid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px){
  .servicesGrid{ grid-template-columns: repeat(3, 1fr); }
}

.serviceCard{
  background:#fff;
  border: 1px solid rgba(2,6,23,.06);
  border-radius: 20px;
  padding: 1.4rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display:flex;
  flex-direction:column;
  min-height: 210px;
}
.serviceCard:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(37,99,235,.28);
}
.serviceIcon{
  width:52px; height:52px;
  border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  margin-bottom: 1rem;
}
.serviceIcon i{ width:22px; height:22px; color: var(--primary); }
.serviceCard h3{
  font-size: 1.2rem;
  font-weight: 950;
  margin-bottom: .55rem;
}
.serviceCard p{
  color: var(--muted);
  font-weight: 700;
  margin-bottom: 1rem;
}
.serviceLink{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-weight: 950;
  color: var(--primary);
}
.serviceLink i{ width:16px; height:16px; }

/* ---------- “Why us” section ---------- */
.alt{
  background: #f1f5f9;
  border-top: 1px solid rgba(2,6,23,.06);
  border-bottom: 1px solid rgba(2,6,23,.06);
}
.whyGrid{
  display:grid;
  gap: 2rem;
  align-items:center;
}
@media (min-width: 992px){
  .whyGrid{ grid-template-columns: 1.05fr .95fr; gap: 3rem; }
}
.checkList{
  margin-top: 1.4rem;
  display:grid;
  gap: 1rem;
}
.checkItem{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  padding: 1rem;
  border-radius: 18px;
  background:#fff;
  border: 1px solid rgba(2,6,23,.06);
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
}
.checkItem i{ width:20px; height:20px; color: var(--primary); margin-top:2px; }
.checkItem strong{ display:block; font-weight: 950; color: var(--accent); }
.checkItem span{ display:block; color: var(--muted); font-weight: 700; margin-top:.1rem; }

.mosaic{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.mosaic img{
  border-radius: 16px;
  box-shadow: 0 14px 40px rgba(2,6,23,.10);
  border: 1px solid rgba(2,6,23,.06);
}
.mosaic img:nth-child(1){ transform: translateY(12px); }
@media (max-width: 520px){
  .mosaic{ grid-template-columns: 1fr; }
  .mosaic img:nth-child(1){ transform:none; }
}

/* ---------- CTA ---------- */
.ctaWrap{ padding: 0 0 4.2rem; }
.cta{
  background: var(--accent);
  color:#fff;
  border-radius: 28px;
  padding: 3.2rem 1.5rem;
  box-shadow: var(--shadow-lg);
  overflow:hidden;
  position:relative;
}
.cta:before{
  content:"";
  position:absolute; inset:-80px;
  background:
    radial-gradient(420px 220px at 20% 30%, rgba(37,99,235,.35), transparent 60%),
    radial-gradient(520px 280px at 80% 20%, rgba(99,102,241,.32), transparent 62%),
    radial-gradient(520px 300px at 70% 80%, rgba(6,182,212,.22), transparent 60%);
  pointer-events:none;
}
.ctaInner{
  position:relative;
  max-width: 920px;
  margin: 0 auto;
  text-align:center;
}
.cta h2{ color:#fff; font-size: clamp(1.6rem, 2.4vw, 2.2rem); font-weight: 950; }
.cta p{ margin-top:.75rem; color:#cbd5e1; font-weight: 700; font-size: var(--fs-2); }
.ctaBtns{ margin-top: 1.6rem; display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.footer{
  background: #0b1220;
  color:#94a3b8;
  padding: 4rem 0 2rem;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footerGrid{
  display:grid;
  gap: 2.2rem;
}
@media (min-width: 840px){
  .footerGrid{ grid-template-columns: 1.4fr 1fr 1fr; }
}
.footer h4{
  color:#fff;
  margin-bottom: 1rem;
  font-size: 1.05rem;
}
.footer a{ display:block; margin-bottom:.7rem; font-weight: 700; }
.footer a:hover{ color:#fff; }
.footerBrand{
  display:flex; align-items:center; gap:.75rem;
}
.footerBrand .brand__icon{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.14);
}
.footerBrand .brand__icon i{ color:#fff; }
.footerSmall{
  margin-top: 1rem;
  color:#a6b3c6;
  line-height: 1.75;
}
.footerContact{
  display:grid;
  gap:.75rem;
  margin-top: 1.1rem;
}
.footerContact div{
  display:flex; gap:.65rem; align-items:flex-start;
  color:#cbd5e1;
  font-weight: 750;
}
.footerContact i{ width:18px; height:18px; margin-top:2px; color:#93c5fd; }
.footerBottom{
  margin-top: 2.4rem;
  padding-top: 1.4rem;
  border-top: 1px solid rgba(255,255,255,.10);
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:1rem;
  font-weight: 700;
  font-size: .92rem;
}

/* ---------- Floating WhatsApp ---------- */
.fab{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 120;
}
.fab a{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding: .85rem 1rem;
  border-radius: 999px;
  background: #16a34a;
  color:#fff;
  font-weight: 950;
  box-shadow: 0 18px 40px rgba(22,163,74,.28);
  border: 1px solid rgba(255,255,255,.18);
}
.fab i{ width:18px; height:18px; }
/* ===== Services Page Additions (append) ===== */

.servicesHero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.servicesHero__grid{
  display:grid;
  gap: 2.2rem;
  align-items:center;
}
@media (min-width: 992px){
  .servicesHero__grid{ grid-template-columns: 1.12fr .88fr; gap: 3.2rem; }
}
.servicesHero__title{ font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: 950; }
.servicesHero__lead{ margin-top: 1rem; color: var(--muted); font-size: var(--fs-2); max-width: 60ch; }
.servicesHero__cta{ margin-top: 1.3rem; display:flex; gap:.8rem; flex-wrap:wrap; }
.servicesHero__card{ margin-top: .4rem; }
.miniBadges{
  margin-top: 1.1rem;
  display:grid;
  gap:.65rem;
  max-width: 52ch;
}
.miniBadge{
  display:flex; gap:.55rem; align-items:center;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 14px;
  padding:.75rem .9rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
  font-weight: 850;
  color: var(--accent);
}
.miniBadge i{ width:18px; height:18px; color: var(--primary); }

/* Toolbar */
.servicesToolbar{
  position: sticky;
  top: 78px; /* below header */
  z-index: 30;
  background: rgba(248,250,252,.82);
  backdrop-filter: blur(12px);
  border-top: 1px solid rgba(2,6,23,.05);
  border-bottom: 1px solid rgba(2,6,23,.06);
}
@media (min-width: 992px){
  .servicesToolbar{ top: 72px; }
}
.servicesToolbar__inner{
  padding: .9rem 0;
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  align-items:center;
  justify-content:space-between;
}
.servicesToolbar__search{
  flex: 1 1 340px;
  display:flex;
  gap:.6rem;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 16px;
  padding: .75rem .9rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.04);
}
.servicesToolbar__search i{ width:18px; height:18px; color: var(--muted); }
.servicesToolbar__search input{
  border:none; outline:none;
  width:100%;
  font-size: var(--fs-1);
  font-weight: 800;
  color: var(--accent);
}
.servicesToolbar__chips{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}
.chip{
  border-radius: 999px;
  padding: .55rem .85rem;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  font-weight: 900;
  color: var(--accent);
  cursor:pointer;
}
.chip:hover{ border-color: rgba(37,99,235,.30); }
.chip--active{
  background: #eff6ff;
  border-color: #dbeafe;
  color: var(--primary);
}
.servicesToolbar__actions{ flex: 0 0 auto; }

/* Cards */
.serviceCard--jump{ scroll-margin-top: 130px; }
.noResults{
  margin: 1.2rem auto 0;
  max-width: 760px;
  text-align:center;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.2rem 1.2rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
}

/* Detailed layout */
.serviceLayout{
  display:grid;
  gap: 1.2rem;
  align-items:start;
}
@media (min-width: 992px){
  .serviceLayout{ grid-template-columns: 340px 1fr; gap: 1.5rem; }
}
.serviceNav{
  position: relative;
}
@media (min-width: 992px){
  .serviceNav{ position: sticky; top: 160px; }
}
.serviceNav__card{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.1rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
}
.serviceNav__title{
  display:flex; align-items:center; gap:.55rem;
  font-weight: 950;
  color: var(--accent);
  margin-bottom: .8rem;
}
.serviceNav__title i{ width:18px; height:18px; color: var(--primary); }
.serviceNav__link{
  display:block;
  padding: .78rem .9rem;
  border-radius: 14px;
  border:1px solid var(--line);
  background:#fff;
  font-weight: 900;
  color: var(--accent);
  margin-bottom: .55rem;
}
.serviceNav__link:hover{ background:#f1f5f9; }
.serviceNav__cta{ margin-top: .9rem; display:grid; gap:.7rem; }

.serviceContent{ display:grid; gap: 1rem; }

.serviceSection{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.2rem 1.15rem;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
  scroll-margin-top: 140px;
}
.serviceSection__head{
  display:flex;
  gap:.9rem;
  align-items:flex-start;
  padding-bottom: .9rem;
  border-bottom: 1px solid rgba(2,6,23,.06);
  margin-bottom: 1rem;
}
.serviceSection__icon{
  width:52px; height:52px;
  border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  flex: 0 0 auto;
}
.serviceSection__icon i{ width:22px; height:22px; color: var(--primary); }
.serviceSection h2{ font-size: 1.4rem; font-weight: 950; }
.serviceSection p{ color: var(--muted); font-weight: 750; margin-top: .25rem; }
.tiny{ margin-top:.8rem; font-size:.9rem; color: var(--muted); }

.serviceSplit{
  display:grid;
  gap: 1rem;
}
@media (min-width: 840px){
  .serviceSplit{ grid-template-columns: 1fr 1fr; }
}
.serviceBox{
  background: #f8fafc;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  padding: 1rem;
}
.serviceBox h3{ font-size: 1.05rem; margin-bottom:.6rem; font-weight: 950; }
.serviceList{ list-style:none; padding:0; margin:0; display:grid; gap:.55rem; }
.serviceList li{ display:flex; gap:.6rem; align-items:flex-start; font-weight: 800; color: var(--accent); }
.serviceList i{ width:18px; height:18px; color: #16a34a; margin-top:2px; }

.tagRow{ display:flex; flex-wrap:wrap; gap:.5rem; }
.tag{
  display:inline-flex;
  padding: .45rem .7rem;
  border-radius: 999px;
  background: #fff;
  border:1px solid rgba(2,6,23,.08);
  font-weight: 900;
  color: var(--accent);
  font-size: .9rem;
}
.note{
  margin-top: .9rem;
  background: #fff;
  border:1px solid rgba(37,99,235,.18);
  border-radius: 16px;
  padding: .85rem .9rem;
}
.note strong{ font-weight: 950; }
.note p{ margin-top:.35rem; }
.note--warn{
  border-color: rgba(245,158,11,.30);
  background: #fff7ed;
}

/* FAQ */
.faq{ margin-top: 1rem; }
.faq h3{ font-size: 1.05rem; font-weight: 950; margin-bottom:.7rem; }
.faqItem{
  border:1px solid rgba(2,6,23,.06);
  border-radius: 16px;
  background:#fff;
  margin-bottom: .6rem;
  overflow:hidden;
}
.faqQ{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  padding: .95rem 1rem;
  background:#fff;
  border:none;
  cursor:pointer;
  font-weight: 950;
  color: var(--accent);
  text-align:left;
}
.faqQ i{ width:18px; height:18px; color: var(--muted); }
.faqA{
  padding: 0 1rem 1rem;
  color: var(--muted);
  font-weight: 750;
}

/* Process */
.serviceSection--soft{
  background: linear-gradient(#ffffff, #ffffff);
}
.processGrid{
  margin-top: 1rem;
  display:grid;
  gap: .8rem;
}
@media (min-width: 900px){
  .processGrid{ grid-template-columns: repeat(4, 1fr); }
}
.processStep{
  border:1px solid rgba(2,6,23,.06);
  background:#f8fafc;
  border-radius: 18px;
  padding: 1rem;
  display:flex;
  gap:.7rem;
}
.processNum{
  width:40px; height:40px;
  border-radius: 14px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: var(--primary);
  font-weight: 950;
  display:flex; align-items:center; justify-content:center;
  flex: 0 0 auto;
  font-family:"Sora", ui-sans-serif;
}
.processStep strong{ font-weight: 950; color: var(--accent); display:block; }
.processStep p{ margin-top:.2rem; color: var(--muted); font-weight: 750; }

.sectionCTA{
  margin-top: 1.2rem;
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  justify-content:center;
}
/* ===== Solutions Page Additions (append) ===== */

.solHero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.solHero__grid{
  display:grid;
  gap: 2.2rem;
  align-items:center;
}
@media (min-width: 992px){
  .solHero__grid{ grid-template-columns: 1.12fr .88fr; gap: 3.2rem; }
}
.solHero__title{ font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: 950; }
.solHero__lead{ margin-top: 1rem; color: var(--muted); font-size: var(--fs-2); max-width: 62ch; }
.solHero__cta{ margin-top: 1.2rem; display:flex; gap:.8rem; flex-wrap:wrap; }

.solHighlights{
  margin-top: 1.2rem;
  display:grid;
  gap:.75rem;
  max-width: 56ch;
}
@media (min-width: 680px){
  .solHighlights{ grid-template-columns: repeat(3, 1fr); }
}
.solHi{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  padding: .95rem 1rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
  display:flex;
  gap:.65rem;
  align-items:flex-start;
}
.solHi i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.solHi strong{ display:block; font-weight: 950; color: var(--accent); }
.solHi span{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; font-size:.92rem; }

/* Type grid */
.solTypeGrid{
  display:grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){
  .solTypeGrid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px){
  .solTypeGrid{ grid-template-columns: repeat(3, 1fr); }
}
.solTypeCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 20px;
  padding: 1.15rem 1.15rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
  display:flex;
  gap:.85rem;
  align-items:center;
  text-align:left;
  cursor:pointer;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.solTypeCard:hover{ transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: rgba(37,99,235,.28); }
.solTypeCard i{ width:22px; height:22px; color: var(--primary); }
.solTypeCard strong{ font-weight: 950; color: var(--accent); display:block; }
.solTypeCard span{ color: var(--muted); font-weight: 750; display:block; margin-top:.15rem; font-size:.92rem; }
.solTypeCard--active{
  border-color: rgba(37,99,235,.34);
  box-shadow: 0 14px 40px rgba(37,99,235,.12);
}

/* Builder */
.builderHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap:wrap;
  margin-bottom: 1.2rem;
}
.builderHead h2{ font-size: clamp(1.6rem, 2.4vw, 2.2rem); font-weight: 950; }
.builderHead p{ margin-top:.35rem; color: var(--muted); font-weight: 750; }

.builderGrid{
  display:grid;
  gap: 1.2rem;
}
@media (min-width: 992px){
  .builderGrid{ grid-template-columns: 1fr 1fr; gap: 1.4rem; }
}
.builderPanel{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.05rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
}
.builderPanel--out{
  background: linear-gradient(#fff, #fff);
}
.builderBlock{
  border:1px solid rgba(2,6,23,.06);
  background:#f8fafc;
  border-radius: 18px;
  padding: 1rem;
  margin-bottom: 1rem;
}
.builderBlock__title{
  display:flex; align-items:center; gap:.55rem;
  font-weight: 950; color: var(--accent);
  margin-bottom: .75rem;
}
.builderBlock__title i{ width:18px; height:18px; color: var(--primary); }

.segRow{ display:flex; flex-wrap:wrap; gap:.55rem; }
.seg{
  padding: .55rem .8rem;
  border-radius: 999px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  font-weight: 900;
  cursor:pointer;
}
.seg--on{
  background:#eff6ff;
  border-color:#dbeafe;
  color: var(--primary);
}

.needGrid{
  display:grid;
  gap: .7rem;
  grid-template-columns: 1fr;
}
@media (min-width: 680px){
  .needGrid{ grid-template-columns: repeat(2, 1fr); }
}
.needCard{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  padding: .9rem .9rem;
  border-radius: 18px;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  cursor:pointer;
}
.needCard input{
  margin-top: .25rem;
  width: 18px;
  height: 18px;
  accent-color: var(--primary);
}
.needCard strong{ display:block; font-weight: 950; color: var(--accent); }
.needCard small{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; }

.builderHint{
  margin-top: .8rem;
  display:flex;
  gap:.55rem;
  align-items:center;
  color: var(--muted);
  font-weight: 750;
  font-size: .92rem;
}
.builderHint i{ width:18px; height:18px; color: var(--primary); }

.prefRow{ display:flex; gap:.55rem; flex-wrap:wrap; }
.radioPill{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding: .6rem .8rem;
  border-radius: 999px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  cursor:pointer;
  font-weight: 900;
}
.radioPill input{ accent-color: var(--primary); }

/* Recommendation Card */
.recCard{
  border:1px solid rgba(2,6,23,.06);
  background: #0b1220;
  border-radius: 22px;
  padding: 1.1rem;
  color:#cbd5e1;
  box-shadow: var(--shadow-lg);
  overflow:hidden;
  position:relative;
}
.recCard:before{
  content:"";
  position:absolute; inset:-80px;
  background:
    radial-gradient(420px 220px at 20% 30%, rgba(37,99,235,.35), transparent 60%),
    radial-gradient(520px 280px at 80% 20%, rgba(99,102,241,.32), transparent 62%),
    radial-gradient(520px 300px at 70% 80%, rgba(6,182,212,.22), transparent 60%);
  pointer-events:none;
}
.recTop{ position:relative; }
.recBadge{
  display:inline-flex; align-items:center; gap:.5rem;
  padding: .5rem .75rem;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  font-weight: 950;
  color:#fff;
}
.recBadge i{ width:18px; height:18px; color:#93c5fd; }
.recTitle{
  margin-top: .85rem;
  font-family: "Sora", ui-sans-serif;
  color:#fff;
  font-weight: 950;
  font-size: 1.45rem;
  letter-spacing:-0.02em;
}
.recSub{ margin-top:.25rem; color:#cbd5e1; font-weight: 750; }

.recCols{
  position:relative;
  margin-top: 1rem;
  display:grid;
  gap: 1rem;
}
@media (min-width: 840px){
  .recCols{ grid-template-columns: 1fr 1fr; }
}
.recBox{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  border-radius: 18px;
  padding: 1rem;
}
.recBox h3{ color:#fff; font-weight: 950; font-size: 1.05rem; margin-bottom:.6rem; }
.recList{ list-style:none; padding:0; margin:0; display:grid; gap:.55rem; }
.recList li{ display:flex; gap:.6rem; align-items:flex-start; font-weight: 800; color:#e2e8f0; }
.recList i{ width:18px; height:18px; color:#22c55e; margin-top:2px; }

.recActions{
  position:relative;
  margin-top: 1rem;
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
}
.recMini{
  position:relative;
  margin-top: 1rem;
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
  color:#cbd5e1;
  font-weight: 750;
  font-size: .92rem;
}
.recMini div{ display:flex; align-items:center; gap:.45rem; }
.recMini i{ width:16px; height:16px; color:#93c5fd; }

/* Packages */
.pkgGrid{
  display:grid;
  gap: 1.2rem;
  grid-template-columns: 1fr;
}
@media (min-width: 900px){
  .pkgGrid{ grid-template-columns: repeat(3, 1fr); }
}
.pkgCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.2rem;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
}
.pkgCard--hot{
  border-color: rgba(37,99,235,.30);
  box-shadow: 0 18px 60px rgba(37,99,235,.14);
  position:relative;
}
.pkgHot{
  display:inline-flex; align-items:center; gap:.45rem;
  font-weight: 950;
  color: var(--primary);
  background:#eff6ff;
  border:1px solid #dbeafe;
  padding: .45rem .7rem;
  border-radius: 999px;
  margin-bottom: .75rem;
}
.pkgHot i{ width:16px; height:16px; }
.pkgTop{ margin-bottom: .9rem; }
.pkgName{
  font-family:"Sora", ui-sans-serif;
  font-weight: 950;
  color: var(--accent);
  font-size: 1.35rem;
}
.pkgTag{ color: var(--muted); font-weight: 750; margin-top:.15rem; }
.pkgList{ list-style:none; padding:0; margin:0 0 1rem; display:grid; gap:.6rem; }
.pkgList li{ display:flex; gap:.6rem; align-items:flex-start; font-weight: 800; color: var(--accent); }
.pkgList i{ width:18px; height:18px; color:#16a34a; margin-top:2px; }

/* FAQ width helper + CTA */
.faqWide{ max-width: 920px; margin: 0 auto; }
.solCTA{ margin-top: 2rem; }
.solCTA__card{
  max-width: 980px;
  margin: 0 auto;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  padding: 1.4rem 1.2rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  text-align:center;
}
.solCTA__card h3{ font-weight: 950; font-size: 1.35rem; }
.solCTA__card p{ margin-top:.5rem; color: var(--muted); font-weight: 750; }
.solCTA__btns{ margin-top: 1.1rem; display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* ===== Projects Page Additions (append) ===== */
.projHero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.projHero__grid{
  display:grid;
  gap: 2.2rem;
  align-items:center;
}
@media (min-width: 992px){
  .projHero__grid{ grid-template-columns: 1.12fr .88fr; gap: 3.2rem; }
}
.projHero__title{ font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: 950; }
.projHero__lead{ margin-top: 1rem; color: var(--muted); font-size: var(--fs-2); max-width: 62ch; }
.projHero__cta{ margin-top: 1.2rem; display:flex; gap:.8rem; flex-wrap:wrap; }

/* toolbar */
.projToolbar{
  position: sticky;
  top: 78px;
  z-index: 30;
  background: rgba(248,250,252,.82);
  backdrop-filter: blur(12px);
  border-top: 1px solid rgba(2,6,23,.05);
  border-bottom: 1px solid rgba(2,6,23,.06);
}
@media (min-width: 992px){
  .projToolbar{ top: 72px; }
}
.projToolbar__inner{
  padding: .9rem 0;
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  align-items:center;
  justify-content:space-between;
}
.projSearch{
  flex: 1 1 340px;
  display:flex;
  gap:.6rem;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 16px;
  padding: .75rem .9rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.04);
}
.projSearch i{ width:18px; height:18px; color: var(--muted); }
.projSearch input{
  border:none; outline:none;
  width:100%;
  font-size: var(--fs-1);
  font-weight: 800;
  color: var(--accent);
}
.projChips{ display:flex; flex-wrap:wrap; gap:.5rem; }

/* grid */
.projGrid{
  display:grid;
  gap: 1.2rem;
  grid-template-columns: 1fr;
}
@media (min-width: 760px){
  .projGrid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px){
  .projGrid{ grid-template-columns: repeat(3, 1fr); }
}
.projCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  overflow:hidden;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display:flex;
  flex-direction:column;
}
.projCard:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(37,99,235,.28);
}
.projThumb{
  position:relative;
  aspect-ratio: 16/10;
  background:#e2e8f0;
}
.projThumb img{
  width:100%; height:100%;
  object-fit:cover;
}
.projBadge{
  position:absolute;
  left: 12px;
  bottom: 12px;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding: .5rem .75rem;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(2,6,23,.08);
  font-weight: 950;
  color: var(--accent);
  backdrop-filter: blur(10px);
}
.projBadge i{ width:16px; height:16px; color: var(--primary); }
.projBody{ padding: 1.05rem 1.05rem 1.1rem; display:flex; flex-direction:column; height:100%; }
.projBody h3{ font-size: 1.15rem; font-weight: 950; margin-bottom:.45rem; }
.projBody p{ color: var(--muted); font-weight: 750; margin-bottom:.8rem; }
.projMeta{
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  color: var(--muted);
  font-weight: 800;
  font-size: .92rem;
  margin-bottom: .8rem;
}
.projMeta div{ display:flex; align-items:center; gap:.4rem; }
.projMeta i{ width:16px; height:16px; color: var(--primary); }
.projTags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:auto; }
.projActions{ margin-top: .9rem; }

/* checklist */
.checkGrid{
  display:grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  max-width: 980px;
  margin: 0 auto;
}
@media (min-width: 900px){
  .checkGrid{ grid-template-columns: repeat(2, 1fr); }
}
.checkCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.1rem 1.1rem;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
  display:flex;
  gap:.8rem;
  align-items:flex-start;
}
.checkCard i{ width:22px; height:22px; color: var(--primary); margin-top:2px; }
.checkCard strong{ display:block; font-weight: 950; color: var(--accent); }
.checkCard p{ margin-top:.2rem; color: var(--muted); font-weight: 750; }

.ctaMini{ margin-top: 2rem; }
.ctaMini__card{
  max-width: 980px;
  margin: 0 auto;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  padding: 1.4rem 1.2rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  text-align:center;
}
.ctaMini__card h3{ font-weight: 950; font-size: 1.35rem; }
.ctaMini__card p{ margin-top:.5rem; color: var(--muted); font-weight: 750; }
.ctaMini__btns{ margin-top: 1.1rem; display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* ===== About Page Additions (append) ===== */

.aboutHero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.aboutHero__grid{
  display:grid;
  gap: 2.2rem;
  align-items:center;
}
@media (min-width: 992px){
  .aboutHero__grid{ grid-template-columns: 1.1fr .9fr; gap: 3.2rem; }
}
.aboutHero__title{ font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: 950; }
.aboutHero__lead{ margin-top: 1rem; color: var(--muted); font-size: var(--fs-2); max-width: 62ch; }
.aboutHero__cta{ margin-top: 1.2rem; display:flex; gap:.8rem; flex-wrap:wrap; }

.aboutMini{
  margin-top: 1.2rem;
  display:grid;
  gap:.75rem;
}
.aboutMini__item{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  padding: .95rem 1rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
  display:flex;
  gap:.65rem;
  align-items:flex-start;
}
.aboutMini__item i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.aboutMini__item strong{ display:block; font-weight: 950; color: var(--accent); }
.aboutMini__item span{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; font-size:.92rem; }

.aboutMediaCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 24px;
  overflow:hidden;
  box-shadow: var(--shadow-lg);
}
.aboutMediaCard__img{ aspect-ratio: 16/10; background:#e2e8f0; }
.aboutMediaCard__img img{ width:100%; height:100%; object-fit:cover; }

.aboutMediaCard__stats{
  padding: 1rem;
  display:grid;
  gap:.8rem;
  grid-template-columns: 1fr;
}
@media (min-width: 680px){
  .aboutMediaCard__stats{ grid-template-columns: repeat(2, 1fr); }
}
.miniStat{
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  background:#fff;
  padding: .95rem 1rem;
  display:flex;
  gap:.75rem;
  align-items:center;
}
.miniStat__icon{
  width:46px; height:46px;
  border-radius: 16px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
}
.miniStat__icon i{ width:20px; height:20px; color: var(--primary); }
.miniStat__num{
  font-family:"Sora", ui-sans-serif;
  color: var(--accent);
  font-weight: 950;
  font-size: 1.35rem;
  line-height: 1.1;
}
.miniStat__lbl{ color: var(--muted); font-weight: 800; font-size: .92rem; margin-top:.15rem; }

.aboutStory{
  display:grid;
  gap: 1.4rem;
  align-items:start;
}
@media (min-width: 992px){
  .aboutStory{ grid-template-columns: 1.05fr .95fr; gap: 2.2rem; }
}
.aboutStory h2{ font-size: clamp(1.6rem, 2.4vw, 2.15rem); font-weight: 950; }
.aboutStory p{ color: var(--muted); font-weight: 750; margin-top:.75rem; }

.aboutPoints{
  margin-top: 1.2rem;
  display:grid;
  gap: 1rem;
}
.aboutPoint{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 20px;
  padding: 1rem 1rem;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
  display:flex;
  gap:.75rem;
  align-items:flex-start;
}
.aboutPoint i{ width:20px; height:20px; color: var(--primary); margin-top:2px; }
.aboutPoint strong{ display:block; font-weight: 950; color: var(--accent); }
.aboutPoint span{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; }

.aboutCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 24px;
  padding: 1.1rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
}
.aboutCard__top{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
}
.aboutCard__icon{
  width:46px; height:46px;
  border-radius: 16px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
  flex:0 0 auto;
}
.aboutCard__icon i{ width:20px; height:20px; color: var(--primary); }
.aboutCard__title{ font-weight: 950; color: var(--accent); font-family:"Sora", ui-sans-serif; }
.aboutCard__desc{ color: var(--muted); font-weight: 750; margin-top:.2rem; }
.aboutCard__line{
  height:1px;
  background: rgba(2,6,23,.06);
  margin: 1rem 0;
}

.aboutCallout{
  margin-top: 1rem;
  background: #0b1220;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 24px;
  padding: 1.1rem;
  color:#cbd5e1;
  box-shadow: var(--shadow-lg);
}
.aboutCallout h3{ color:#fff; font-weight: 950; font-size: 1.25rem; }
.aboutList{ list-style:none; padding:0; margin: .9rem 0 1rem; display:grid; gap:.6rem; }
.aboutList li{ display:flex; gap:.6rem; align-items:flex-start; font-weight: 850; color:#e2e8f0; }
.aboutList i{ width:18px; height:18px; color:#22c55e; margin-top:2px; }

.aboutDo__grid{
  display:grid;
  gap: 1.2rem;
  grid-template-columns: 1fr;
}
@media (min-width: 900px){
  .aboutDo__grid{ grid-template-columns: repeat(4, 1fr); }
}
.doCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 22px;
  padding: 1.2rem;
  box-shadow: 0 12px 36px rgba(2,6,23,.06);
  display:flex;
  flex-direction:column;
}
.doIcon{
  width:52px; height:52px;
  border-radius: 16px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
  margin-bottom: .9rem;
}
.doIcon i{ width:22px; height:22px; color: var(--primary); }
.doCard h3{ font-weight: 950; font-size: 1.1rem; margin-bottom:.45rem; }
.doCard p{ color: var(--muted); font-weight: 750; margin-bottom:.85rem; }

.aboutArea__card{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  padding: 1.25rem 1.1rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  display:flex;
  gap: 1rem;
  align-items:flex-start;
}
.aboutArea__icon{
  width:54px; height:54px;
  border-radius: 18px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
  flex: 0 0 auto;
}
.aboutArea__icon i{ width:22px; height:22px; color: var(--primary); }
.aboutArea__card h2{ margin:0; font-weight: 950; font-size: 1.6rem; }
.aboutArea__card p{ margin-top:.5rem; color: var(--muted); font-weight: 750; }

.areaPills{ margin-top: .9rem; display:flex; flex-wrap:wrap; gap:.55rem; }
.areaBtns{ margin-top: 1rem; display:flex; gap:.8rem; flex-wrap:wrap; }

.aboutCTA{ margin-top: 2rem; }
.aboutCTA__card{
  max-width: 980px;
  margin: 0 auto;
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  padding: 1.4rem 1.2rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  text-align:center;
}
.aboutCTA__card h3{ font-weight: 950; font-size: 1.35rem; }
.aboutCTA__card p{ margin-top:.5rem; color: var(--muted); font-weight: 750; }
.aboutCTA__btns{ margin-top: 1.1rem; display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* About hero right card spacing on small screens */
@media (max-width: 520px){
  .aboutArea__card{ flex-direction:column; }
}
/* ===== Contact Page Additions (append) ===== */

.contactHero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(900px 500px at 78% 12%, #e0e7ff 0%, transparent 48%),
    radial-gradient(850px 520px at 15% 10%, #e0f2fe 0%, transparent 52%),
    linear-gradient(#f8fafc, #f8fafc);
}
.contactHero__grid{
  display:grid;
  gap: 2.2rem;
  align-items:center;
}
@media (min-width: 992px){
  .contactHero__grid{ grid-template-columns: 1.05fr .95fr; gap: 3.2rem; }
}
.contactHero__title{ font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: 950; }
.contactHero__lead{ margin-top: 1rem; color: var(--muted); font-size: var(--fs-2); max-width: 62ch; }
.contactHero__cta{ margin-top: 1.2rem; display:flex; gap:.75rem; flex-wrap:wrap; }

.contactMini{
  margin-top: 1.2rem;
  display:grid;
  gap:.75rem;
}
.contactMini__item{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  padding: .95rem 1rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
  display:flex;
  gap:.65rem;
  align-items:flex-start;
}
.contactMini__item i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.contactMini__item strong{ display:block; font-weight: 950; color: var(--accent); }
.contactMini__item span{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; font-size:.92rem; }

.contactMediaCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 24px;
  overflow:hidden;
  box-shadow: var(--shadow-lg);
}
.contactMediaCard__img{ aspect-ratio: 16/10; background:#e2e8f0; }
.contactMediaCard__img img{ width:100%; height:100%; object-fit:cover; }
.contactMediaCard__bar{
  padding: 1rem;
  display:grid;
  gap:.8rem;
  grid-template-columns: 1fr;
}
@media (min-width: 680px){
  .contactMediaCard__bar{ grid-template-columns: repeat(3, 1fr); }
}
.barItem{
  border:1px solid rgba(2,6,23,.06);
  border-radius: 18px;
  background:#fff;
  padding: .95rem 1rem;
  display:flex;
  gap:.65rem;
  align-items:flex-start;
}
.barItem i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }
.barItem strong{ display:block; font-weight: 950; color: var(--accent); }
.barItem span{ display:block; color: var(--muted); font-weight: 750; margin-top:.15rem; font-size:.92rem; }

/* Quote */
.quoteGrid{
  display:grid;
  gap: 1.2rem;
  align-items:start;
}
@media (min-width: 992px){
  .quoteGrid{ grid-template-columns: 1.05fr .95fr; gap: 1.6rem; }
}

.quoteCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  padding: 1.2rem 1.1rem;
}
.quoteCard__head{
  display:flex;
  gap:.8rem;
  align-items:flex-start;
  margin-bottom: 1rem;
}
.quoteCard__icon{
  width:52px; height:52px;
  border-radius: 18px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
  flex:0 0 auto;
}
.quoteCard__icon i{ width:22px; height:22px; color: var(--primary); }
.quoteCard__head h3{ font-weight: 950; font-size: 1.25rem; margin:0; }
.quoteCard__head p{ margin-top:.25rem; color: var(--muted); font-weight: 750; }

.formGrid{
  display:grid;
  gap: .95rem;
  grid-template-columns: 1fr;
}
@media (min-width: 740px){
  .formGrid{ grid-template-columns: repeat(2, 1fr); }
}
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field--full{ grid-column: 1 / -1; }

.field label{
  font-weight: 900;
  color: var(--accent);
  font-size: .95rem;
}
.field input,
.field select,
.field textarea{
  padding: .85rem .9rem;
  border-radius: 16px;
  border: 1px solid var(--line);
  outline: none;
  font-weight: 800;
  font-size: var(--fs-1);
  background:#fff;
  color: var(--accent);
  transition: box-shadow .18s ease, border-color .18s ease;
}
.field textarea{ resize: vertical; min-height: 120px; }
.field input:focus,
.field select:focus,
.field textarea:focus{
  box-shadow: 0 0 0 4px rgba(37,99,235,.16);
  border-color: rgba(37,99,235,.35);
}
.hint{
  color: var(--muted);
  font-weight: 750;
  font-size: .85rem;
}
.checkRow{
  display:flex;
  gap:.7rem;
  align-items:flex-start;
  padding: .9rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(2,6,23,.06);
  background: #f8fafc;
}
.checkRow input{
  margin-top: .18rem;
  width: 18px; height: 18px;
  accent-color: var(--primary);
}
.checkRow span{ color: var(--muted); font-weight: 800; }

.formActions{
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  align-items:center;
}
.miniNote{
  display:flex;
  gap:.55rem;
  align-items:center;
  color: var(--muted);
  font-weight: 800;
  font-size: .92rem;
  padding: .75rem .9rem;
  border-radius: 18px;
  border: 1px dashed rgba(2,6,23,.12);
}
.miniNote i{ width:18px; height:18px; color: var(--primary); }

/* Side cards */
.quoteSide{ display:grid; gap: 1rem; }
.sideCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
  padding: 1.2rem 1.1rem;
}
.sideCard__head{
  display:flex;
  gap:.8rem;
  align-items:flex-start;
  margin-bottom: 1rem;
}
.sideCard__icon{
  width:52px; height:52px;
  border-radius: 18px;
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid rgba(37,99,235,.18);
  display:flex; align-items:center; justify-content:center;
  flex:0 0 auto;
}
.sideCard__icon i{ width:22px; height:22px; color: var(--primary); }
.sideCard__head h3{ font-weight: 950; font-size: 1.25rem; margin:0; }
.sideCard__head p{ margin-top:.25rem; color: var(--muted); font-weight: 750; }

.sideBtns{ display:grid; gap:.7rem; }
.sideDivider{ height:1px; background: rgba(2,6,23,.06); margin: 1rem 0; }
.sideInfo{ display:grid; gap:.75rem; }
.sideInfo__row{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  color: var(--muted);
  font-weight: 800;
}
.sideInfo__row i{ width:18px; height:18px; color: var(--primary); margin-top:2px; }

.sideCard--dark{
  background:#0b1220;
  border-color: rgba(255,255,255,.10);
  color:#cbd5e1;
}
.sideCard--dark h3{ color:#fff; font-weight: 950; margin:0 0 .75rem; font-size: 1.25rem; }
.sideList{ list-style:none; padding:0; margin:0 0 1rem; display:grid; gap:.65rem; }
.sideList li{ display:flex; gap:.6rem; align-items:flex-start; font-weight: 850; color:#e2e8f0; }
.sideList i{ width:18px; height:18px; color:#22c55e; margin-top:2px; }

/* Visit */
.visitGrid{
  display:grid;
  gap: 1.2rem;
  align-items:stretch;
}
@media (min-width: 992px){
  .visitGrid{ grid-template-columns: 1.05fr .95fr; }
}
.visitCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  padding: 1.2rem 1.1rem;
  box-shadow: 0 14px 40px rgba(2,6,23,.08);
}
.visitCard h3{ font-weight: 950; margin:0; font-size: 1.35rem; }
.visitCard p{ margin-top:.6rem; color: var(--muted); font-weight: 750; }
.visitBtns{ margin-top: 1rem; display:flex; gap:.8rem; flex-wrap:wrap; }
.visitBadges{ margin-top: 1rem; display:flex; flex-wrap:wrap; gap:.55rem; }

.mapCard{
  background:#fff;
  border:1px solid rgba(2,6,23,.06);
  border-radius: 26px;
  overflow:hidden;
  box-shadow: var(--shadow-lg);
  position:relative;
}
.mapCard__img{ aspect-ratio: 16/12; background:#e2e8f0; }
.mapCard__img img{ width:100%; height:100%; object-fit:cover; }
.mapCard__overlay{
  position:absolute;
  inset: 12px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  pointer-events:none;
}
.mapChip{
  pointer-events:none;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding: .5rem .75rem;
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(2,6,23,.08);
  font-weight: 950;
  color: var(--accent);
  width: fit-content;
}
.mapChip i{ width:16px; height:16px; color: var(--primary); }
.mapCard__overlay .btn{ pointer-events:auto; align-self:flex-start; }

@media (max-width: 520px){
  .mapCard__overlay{ inset: 10px; }
}
/* =========================
   FAQ collapse (no Alpine plugin needed)
   ========================= */
.faqA{
  display: grid;
  grid-template-rows: 0fr;
  overflow: hidden;
  transition: grid-template-rows .25s ease;
}
.faqA__inner{
  min-height: 0;
}
.faqA.is-open{
  grid-template-rows: 1fr;
}
