/* ===================================================================
   Aaditya's Facilities — Shared Stylesheet
   Theme: Professional navy + bright azure, clean & trustworthy
   =================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  --navy:        #1c3a8b;   /* deep brand blue   */
  --navy-dark:   #142a66;
  --azure:       #2f7bf5;   /* bright accent     */
  --azure-light: #e8f1ff;
  --ink:         #16213e;
  --slate:       #5a6679;
  --line:        #e2e8f4;
  --bg:          #ffffff;
  --bg-soft:     #f5f8ff;
  --white:       #ffffff;
  --radius:      14px;
  --shadow:      0 10px 30px rgba(28,58,139,.10);
  --shadow-lg:   0 24px 60px rgba(28,58,139,.18);
  --maxw:        1180px;
  --display: 'Sora', sans-serif;
  --body: 'Manrope', sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

h1,h2,h3,h4{ font-family:var(--display); line-height:1.15; color:var(--ink); font-weight:700; }
.section{ padding:84px 0; }
.section-soft{ background:var(--bg-soft); }

.eyebrow{
  display:inline-block; font-family:var(--display); font-weight:700;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--azure); margin-bottom:14px;
}
.section-title{ font-size:clamp(1.9rem,4vw,2.8rem); margin-bottom:16px; }
.section-lead{ color:var(--slate); font-size:1.06rem; max-width:640px; }
.center{ text-align:center; }
.center .section-lead{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--display); font-weight:600; font-size:.98rem;
  padding:14px 28px; border-radius:50px; border:none; cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{ background:var(--azure); color:#fff; box-shadow:0 8px 22px rgba(47,123,245,.35); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 14px 30px rgba(47,123,245,.45); }
.btn-ghost{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,.6); }
.btn-ghost:hover{ background:rgba(255,255,255,.14); border-color:#fff; }
.btn-dark{ background:var(--navy); color:#fff; }
.btn-dark:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ display:flex; align-items:center; gap:11px; }
.brand-mark{
  width:42px; height:42px; border-radius:11px;
  background:linear-gradient(135deg,var(--azure),var(--navy));
  display:grid; place-items:center; color:#fff; font-family:var(--display);
  font-weight:800; font-size:1.25rem; box-shadow:var(--shadow);
}
.brand-name{ font-family:var(--display); font-weight:800; font-size:1.18rem; color:var(--navy); letter-spacing:-.01em; }
.brand-name small{ display:block; font-weight:500; font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--slate); }
.nav-links{ display:flex; align-items:center; gap:6px; list-style:none; }
.nav-links a{
  font-family:var(--display); font-weight:600; font-size:.94rem; color:var(--ink);
  padding:9px 15px; border-radius:8px; transition:.2s; position:relative;
}
.nav-links a:hover{ color:var(--azure); background:var(--azure-light); }
.nav-links a.active{ color:var(--azure); }
.nav-links a.active::after{
  content:""; position:absolute; left:15px; right:15px; bottom:2px; height:2px; background:var(--azure); border-radius:2px;
}
.nav-cta{ margin-left:8px; }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.burger span{ width:24px; height:2.5px; background:var(--navy); border-radius:2px; transition:.3s; }

/* ---------- Hero ---------- */
.hero{
  position:relative; color:#fff; overflow:hidden;
  background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 55%,var(--azure) 130%);
}
.hero::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:46px 46px; opacity:.5;
}
.hero-deco{
  position:absolute; width:420px; height:420px; border-radius:30px;
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,0));
  transform:rotate(45deg); top:-120px; right:-120px; pointer-events:none;
}
.hero-deco.two{ width:260px; height:260px; bottom:-90px; left:-80px; top:auto; right:auto; opacity:.6; }
.hero-inner{ position:relative; z-index:2; padding:96px 0 104px; max-width:720px; }
.hero h1{ color:#fff; font-size:clamp(2.4rem,5.4vw,4rem); font-weight:800; letter-spacing:-.02em; }
.hero .tagline{ color:#bcd3ff; font-style:italic; font-size:1.15rem; margin:10px 0 22px; font-family:var(--display); }
.hero p.lead{ color:#dbe7ff; font-size:1.12rem; max-width:560px; margin-bottom:34px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-badges{ display:flex; gap:26px; margin-top:46px; flex-wrap:wrap; }
.hero-badge b{ font-family:var(--display); font-size:1.8rem; display:block; }
.hero-badge span{ color:#bcd3ff; font-size:.85rem; }

/* page hero (inner pages) */
.page-hero{
  position:relative; color:#fff; padding:72px 0 60px;
  background:linear-gradient(135deg,var(--navy-dark),var(--navy));
  overflow:hidden;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:46px 46px; opacity:.45;
}
.page-hero .container{ position:relative; z-index:2; }
.page-hero h1{ color:#fff; font-size:clamp(2rem,4.5vw,3rem); font-weight:800; }
.page-hero p{ color:#cfe0ff; max-width:620px; margin-top:10px; }
.crumbs{ font-size:.86rem; color:#9db8f0; margin-bottom:14px; font-family:var(--display); font-weight:600; }
.crumbs a:hover{ color:#fff; }

/* ---------- Cards / grids ---------- */
.grid{ display:grid; gap:26px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; box-shadow:var(--shadow); transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.card .ico{
  width:54px; height:54px; border-radius:13px; display:grid; place-items:center;
  background:var(--azure-light); color:var(--azure); margin-bottom:18px;
}
.card .ico svg{ width:28px; height:28px; }
.card h3{ font-size:1.25rem; margin-bottom:10px; }
.card p{ color:var(--slate); font-size:.97rem; }

/* feature list */
.feat-list{ list-style:none; display:grid; gap:13px; }
.feat-list li{ display:flex; gap:12px; align-items:flex-start; color:var(--slate); }
.feat-list li::before{
  content:"✓"; flex:0 0 22px; height:22px; margin-top:2px;
  background:var(--azure); color:#fff; border-radius:50%;
  display:grid; place-items:center; font-size:.75rem; font-weight:700;
}

/* competency pills */
.comp-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.comp{
  display:flex; align-items:center; gap:14px; padding:18px 22px;
  border-radius:12px; font-family:var(--display); font-weight:600;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow);
}
.comp.solid{ background:var(--navy); color:#fff; border-color:var(--navy); }
.comp .dot{ width:10px; height:10px; border-radius:50%; background:var(--azure); flex:0 0 auto; }
.comp.solid .dot{ background:#7fb0ff; }

/* stat strip */
.stat-strip{ background:var(--navy); color:#fff; }
.stat-strip .grid-4{ gap:0; }
.stat{ text-align:center; padding:40px 16px; border-right:1px solid rgba(255,255,255,.12); }
.stat:last-child{ border-right:none; }
.stat b{ font-family:var(--display); font-size:2.6rem; font-weight:800; display:block; }
.stat span{ color:#bcd3ff; font-size:.92rem; }

/* clients */
.client-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.client-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 24px; text-align:center; box-shadow:var(--shadow);
  transition:transform .25s, box-shadow .25s;
}
.client-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.client-logo{
  width:70px; height:70px; margin:0 auto 16px; border-radius:16px;
  background:linear-gradient(135deg,var(--azure-light),#fff);
  border:1px solid var(--line); display:grid; place-items:center;
  font-family:var(--display); font-weight:800; font-size:1.5rem; color:var(--navy);
}
.client-card h4{ font-size:1.05rem; }
.client-card span{ color:var(--slate); font-size:.86rem; }

/* CTA band */
.cta-band{
  background:linear-gradient(135deg,var(--azure),var(--navy));
  color:#fff; border-radius:24px; padding:54px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-band::after{
  content:""; position:absolute; width:300px; height:300px; border-radius:30px;
  background:rgba(255,255,255,.08); transform:rotate(45deg); top:-120px; right:-80px;
}
.cta-band h2{ color:#fff; font-size:clamp(1.8rem,3.5vw,2.5rem); position:relative; z-index:2; }
.cta-band p{ color:#e3edff; margin:12px auto 28px; max-width:520px; position:relative; z-index:2; }
.cta-band .btn{ position:relative; z-index:2; }

/* ---------- Forms ---------- */
.form-wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:start; }
.form-card{
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:38px; box-shadow:var(--shadow-lg);
}
.field{ margin-bottom:20px; }
.field label{ display:block; font-family:var(--display); font-weight:600; font-size:.9rem; margin-bottom:7px; }
.field label .req{ color:#e0464b; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--body); font-size:1rem; color:var(--ink);
  padding:13px 15px; border:1.5px solid var(--line); border-radius:10px;
  background:#fbfcff; transition:border .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--azure); box-shadow:0 0 0 4px rgba(47,123,245,.12); background:#fff;
}
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field .err{ color:#e0464b; font-size:.82rem; margin-top:5px; display:none; }
.field.invalid input, .field.invalid select, .field.invalid textarea{ border-color:#e0464b; background:#fff5f5; }
.field.invalid .err{ display:block; }
.form-note{ font-size:.82rem; color:var(--slate); margin-top:6px; }
.form-success{
  display:none; background:#e8f8ee; border:1px solid #aee1c1; color:#1c7a44;
  padding:16px 18px; border-radius:12px; font-weight:600; margin-bottom:18px;
}
.form-success.show{ display:block; }
.form-error{
  display:none; background:#fdecec; border:1px solid #f3b4b4; color:#b3261e;
  padding:14px 16px; border-radius:12px; font-weight:600; font-size:.92rem; margin-bottom:18px;
}
.form-error.show{ display:block; }

/* contact info aside */
.contact-aside .info-card{
  background:var(--navy); color:#fff; border-radius:18px; padding:34px; box-shadow:var(--shadow-lg);
}
.contact-aside h3{ color:#fff; margin-bottom:20px; }
.info-line{ display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.info-line .ico{
  width:42px; height:42px; flex:0 0 auto; border-radius:11px;
  background:rgba(255,255,255,.12); display:grid; place-items:center; color:#cfe0ff;
}
.info-line .ico svg{ width:20px; height:20px; }
.info-line b{ font-family:var(--display); font-size:.92rem; display:block; }
.info-line span{ color:#cfe0ff; font-size:.92rem; }
.info-legal{ margin-top:22px; padding-top:20px; border-top:1px solid rgba(255,255,255,.15); font-size:.84rem; color:#bcd3ff; line-height:1.9; }
.info-legal b{ color:#fff; font-family:var(--display); }

/* ---------- About blocks ---------- */
.mv-card{ border-left:5px solid var(--azure); padding:24px 28px; background:var(--bg-soft); border-radius:0 14px 14px 0; }
.mv-card.vision{ border-left-color:var(--navy); }
.mv-card h3{ font-size:1.2rem; margin-bottom:8px; color:var(--navy); }
.mv-card p{ color:var(--slate); }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.split-media{
  border-radius:20px; min-height:340px; box-shadow:var(--shadow-lg);
  background:linear-gradient(135deg,var(--navy),var(--azure)); position:relative; overflow:hidden;
}
.split-media::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:38px 38px;
}
.split-media .emoji{ position:absolute; inset:0; display:grid; place-items:center; font-size:5rem; opacity:.9; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#c9d2e3; padding:60px 0 26px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; margin-bottom:40px; }
.site-footer h4{ color:#fff; font-size:1rem; margin-bottom:16px; }
.footer-links{ list-style:none; display:grid; gap:10px; }
.footer-links a{ color:#9aa6bd; font-size:.93rem; transition:.2s; }
.footer-links a:hover{ color:#fff; padding-left:4px; }
.footer-brand p{ color:#9aa6bd; font-size:.92rem; margin-top:14px; }
.footer-contact{ font-size:.9rem; color:#9aa6bd; line-height:1.95; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding-top:22px; text-align:center; font-size:.85rem; color:#7c889f; }
.footer-bottom a{ color:#9db8f0; }

/* ---------- Floating action buttons ---------- */
.fab-stack{
  position:fixed; right:20px; bottom:22px; z-index:80;
  display:flex; flex-direction:column; gap:12px;
}
.fab{
  display:flex; align-items:center; gap:9px; padding:13px 20px; border-radius:50px;
  font-family:var(--display); font-weight:700; font-size:.95rem; color:#fff;
  box-shadow:var(--shadow-lg); transition:transform .2s ease; white-space:nowrap;
}
.fab svg{ width:20px; height:20px; flex:0 0 auto; }
.fab:hover{ transform:translateY(-3px) scale(1.03); }
.fab-quote{ background:var(--azure); }
.fab-call{ background:var(--navy); }

/* ---------- Homepage mini enquiry form ---------- */
.home-form-section{ background:var(--bg-soft); }
.home-form-wrap{ display:grid; grid-template-columns:.95fr 1.05fr; gap:48px; align-items:center; }
.home-form-card{
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:34px; box-shadow:var(--shadow-lg);
}
.home-form-card h3{ font-size:1.4rem; margin-bottom:6px; }
.home-form-card .sub{ color:var(--slate); font-size:.93rem; margin-bottom:22px; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .grid-3,.grid-4,.client-grid{ grid-template-columns:repeat(2,1fr); }
  .form-wrap,.split,.home-form-wrap{ grid-template-columns:1fr; }
  .comp-grid{ grid-template-columns:1fr; }
  .stat{ border-right:none; border-bottom:1px solid rgba(255,255,255,.12); }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:28px; }
}
@media (max-width:720px){
  .nav-links{
    position:fixed; top:74px; left:0; right:0; background:#fff; flex-direction:column;
    align-items:stretch; gap:0; padding:10px 18px 22px; border-bottom:1px solid var(--line);
    box-shadow:var(--shadow); transform:translateY(-130%); transition:transform .3s ease; z-index:55;
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ padding:14px 12px; border-radius:8px; }
  .nav-links a.active::after{ display:none; }
  .nav-cta{ margin:8px 0 0; }
  .burger{ display:flex; }
  .section{ padding:60px 0; }
  .grid-2,.grid-3,.grid-4,.client-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 26px; }
  .footer-grid{ grid-template-columns:1fr; }
  .stat b{ font-size:2.1rem; }
  .fab-stack{ right:14px; bottom:14px; }
  .fab span{ display:none; }
  .fab{ padding:14px; border-radius:50%; }
}
