/* ============================================================
   HiPaaS — Marketing site theme  ("Clinical Calm, premium")
   Clean white canvas · deep pine forest · sage/mint · clay accent
   Type: Space Grotesk (display) + Manrope (text)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500&display=swap');

:root {
  /* surfaces */
  --bone:       #FFFFFF;   /* page canvas (white)      */
  --paper:      #FFFFFF;   /* cards / panels           */
  --sand:       #F2F6F3;   /* alt band (faint green)   */
  --line:       #E6E9E6;   /* hairline borders         */
  --line-soft:  #EFF1EF;

  /* greens */
  --forest:       #1E4D3C;  /* primary brand            */
  --forest-deep:  #122A22;  /* dark sections            */
  --forest-700:   #194034;
  --forest-500:   #2E6B53;
  --sage:         #7FB39A;
  --mint:         #CDE9D7;
  --mint-100:     #E4F1E9;

  /* ink */
  --ink:        #16241D;   /* headings on light        */
  --ink-2:      #56655D;   /* body / muted             */
  --ink-3:      #8A968E;   /* captions                 */
  --on-dark:    #EAF1EC;
  --on-dark-2:  #9DB3A8;

  /* accent (clay / coral) */
  --clay:       #D6552E;   /* accent                   */
  --clay-btn:   #C8492A;   /* button bg (AA on white)  */
  --clay-600:   #B23E22;
  --clay-soft:  #F5DDD1;
  --gold:       #BE8A35;   /* rare micro accent        */

  /* type */
  --display: 'Space Grotesk', sans-serif;
  --sans: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  /* radii */
  --r-sm: 10px; --r-md: 16px; --r-lg: 22px; --r-xl: 30px; --r-pill: 999px;

  /* elevation (warm-tinted) */
  --sh-sm: 0 2px 10px rgba(30,40,30,.05);
  --sh-md: 0 14px 40px rgba(30,45,35,.08);
  --sh-lg: 0 30px 70px rgba(20,35,28,.13);
  --sh-clay: 0 14px 30px rgba(214,85,46,.28);

  --ease: cubic-bezier(.2,.8,.2,1);
  --dur: .55s;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--sans); color: var(--ink-2); background: var(--bone);
  -webkit-font-smoothing: antialiased; overflow-x: hidden; font-size: 17px; line-height: 1.6; }

h1,h2,h3,h4 { font-family: var(--display); color: var(--ink); margin: 0; font-weight: 700;
  letter-spacing: -0.02em; line-height: 1.05; }

.wrap { max-width: 1240px; margin: 0 auto; padding: 0 36px; }

/* eyebrow */
.eyebrow { font-family: var(--mono); font-size: 12.5px; font-weight: 500; letter-spacing: .14em;
  text-transform: uppercase; color: var(--forest-500); display: inline-flex; align-items: center; gap: 9px; }
.eyebrow::before { display: none; }
.eyebrow.on-dark { color: var(--sage); }

/* buttons */
.btn { font-family: var(--sans); font-weight: 600; font-size: 16px; cursor: pointer; border: 0;
  border-radius: var(--r-pill); padding: 15px 28px; display: inline-flex; align-items: center; gap: 9px;
  text-decoration: none; transition: transform .35s var(--ease), background .25s, box-shadow .35s, color .25s; white-space: nowrap; }
.btn i { width: 18px; height: 18px; }
.btn-primary { background: var(--clay-btn); color: #fff; box-shadow: var(--sh-clay); }
.btn-primary:hover { background: var(--clay-600); transform: translateY(-3px); box-shadow: 0 20px 38px rgba(214,85,46,.34); }
.btn-primary:active { transform: scale(.98); }
.btn-dark { background: var(--forest); color: #fff; }
.btn-dark:hover { background: var(--forest-700); transform: translateY(-3px); }
.btn-out { background: transparent; color: var(--ink); border: 1.5px solid var(--line); }
.btn-out:hover { border-color: var(--forest); color: var(--forest); background: var(--paper); }
.btn-ghost-d { background: rgba(255,255,255,.08); color: #fff; border: 1.5px solid rgba(255,255,255,.26); }
.btn-ghost-d:hover { background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.5); }

/* section rhythm */
.section { padding: 130px 0; position: relative; }
.section.tight { padding: 90px 0; }
.dark { background: var(--forest-deep); color: var(--on-dark-2); }
/* Headings on dark sections must use a light color (defaults are tuned for light bg). */
.dark h1, .dark h2, .dark h3, .dark h4 { color: var(--on-dark); }

/* card */
.card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); }

/* pill / tag */
.tag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 12px;
  font-weight: 500; letter-spacing: .04em; padding: 6px 13px; border-radius: var(--r-pill);
  background: var(--mint-100); color: var(--forest-500); border: 1px solid var(--mint); }
.tag i { width: 13px; height: 13px; }

/* reveal */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"]{transition-delay:.09s} .reveal[data-d="2"]{transition-delay:.18s}
.reveal[data-d="3"]{transition-delay:.27s} .reveal[data-d="4"]{transition-delay:.36s}

/* grain + animated wash for hero */
@keyframes washMove { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(40px,-26px) scale(1.15)} }
@keyframes washMove2 { 0%,100%{transform:translate(0,0) scale(1.1)} 50%{transform:translate(-34px,30px) scale(.94)} }
@keyframes pulse { 0%,100%{opacity:.4} 50%{opacity:1} }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }

.grain::after { content:""; position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:multiply;
  background-image: url("noise.png"); }

.kit-input { width:100%; box-sizing:border-box; font-family:var(--sans); font-size:15.5px; color:var(--ink);
  padding:13px 16px; border:1.5px solid var(--line); border-radius:var(--r-sm); background:#fff; outline:none;
  transition:border .15s, box-shadow .15s; }
.kit-input:focus { border-color:var(--forest-500); box-shadow:0 0 0 3px rgba(46,107,83,.16); }

::-webkit-scrollbar { width: 11px; }
::-webkit-scrollbar-thumb { background: #cfc6b4; border-radius: 8px; border: 3px solid var(--bone); }

/* ============================================================
   RESPONSIVE / MOBILE  (added)
   Inline component styles are overridden here with !important
   only where the property is set inline (grids, fixed widths,
   floating cards). Type & spacing use ordinary cascade order.
   ============================================================ */

/* visibility helpers */
.only-mobile { display: none !important; }

/* ---- Tablet ---- */
@media (max-width: 1024px) {
  .wrap { padding: 0 28px; }
  .section { padding: 104px 0; }
}

/* ---- Collapse the desktop nav into a hamburger ---- */
@media (max-width: 920px) {
  .nav-desktop { display: none !important; }
  .nav-home-pill { display: none !important; }
  .nav-cta-desktop { display: none !important; }
  .nav-burger { display: inline-flex !important; }
}
@media (min-width: 921px) {
  .nav-burger { display: none !important; }
  .nav-mobile-panel { display: none !important; }
}

/* ---- Phones / small tablets ---- */
@media (max-width: 768px) {
  body { font-size: 16px; }
  .wrap { padding: 0 20px; }

  .section { padding: 66px 0; }
  .section.tight { padding: 46px 0; }

  /* fluid headings — overrides inline font-size because !important */
  h1 { font-size: clamp(34px, 9.4vw, 52px) !important; line-height: 1.04 !important; }
  h2 { font-size: clamp(27px, 6.8vw, 40px) !important; }
  h3 { font-size: clamp(20px, 5vw, 25px) !important; }

  .btn { padding: 13px 20px; font-size: 15px; }

  /* generic grid collapses (grids are inline → need !important) */
  .col-1-mobile { grid-template-columns: 1fr !important; }
  .col-2-mobile { grid-template-columns: 1fr 1fr !important; }

  /* hero / service-hero two-column → stacked */
  .hero-cols { grid-template-columns: 1fr !important; gap: 40px !important; padding-bottom: 52px !important; }
  .hero-sec  { padding-top: 116px !important; }

  /* GCC global-presence panel */
  .gcc-global { grid-template-columns: 1fr !important; gap: 28px !important; }
  .gcc-stats  { min-width: 0 !important; }

  /* footer */
  .footer-grid  { grid-template-columns: 1fr 1fr !important; gap: 34px 24px !important; }
  .footer-inner { padding-top: 56px; padding-bottom: 36px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }

  /* shrink the very large stat numbers that aren't <h*> tags */
  .num-xl { font-size: 40px !important; }

  /* hide decorative floating cards / chevrons that overflow on small screens */
  .hide-on-mobile { display: none !important; }

  /* demo modal */
  .modal-card { padding: 26px !important; }
}

/* ---- Very small phones ---- */
@media (max-width: 460px) {
  .col-2-mobile, .footer-grid { grid-template-columns: 1fr !important; }
}
