/* Al Nafi Soft — static styles */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0a2540;--navy-2:#11304f;
  --red:#e11d2b;--red-2:#c81825;
  --ink:#1a2533;--muted:#5b6a7d;
  --bg:#eef4fb;--card:#ffffff;
  --dark:#0d1b2a;--dark-2:#13243a;
  --line:#e3eaf2;
  --radius:14px;
  --shadow:0 10px 30px rgba(10,37,64,.08);
  --maxw:1200px;
}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:#fff;line-height:1.55;
  -webkit-font-smoothing:antialiased
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

h1,h2,h3,h4{
  font-family:'Poppins','Inter',sans-serif;
  color:var(--navy);line-height:1.2;font-weight:700
}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:.25rem}
h3{font-size:1.15rem}

.section{padding:64px 0}
.section--sm{padding:44px 0}
.subtitle{color:var(--muted);margin-bottom:32px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;border-radius:999px;
  font-weight:600;border:0;cursor:pointer;
  transition:.2s;font-size:.95rem
}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-2);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{background:#fff;color:var(--navy);box-shadow:var(--shadow)}

/* Header + nav (SINGLE source of truth) */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(10,37,64,.04),0 4px 18px rgba(10,37,64,.04)
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;max-width:var(--maxw);margin:0 auto;gap:16px
}
.logo{display:flex;align-items:center;gap:10px;min-width:0}
.logo img{height:48px;width:auto;border-radius:8px}
.logo-text{
  font-family:'Poppins',sans-serif;font-weight:800;
  color:var(--navy);font-size:1.15rem;line-height:1;
  white-space:nowrap;letter-spacing:.02em
}
.logo-text span{color:var(--red)}

.nav-links{display:none;align-items:center;gap:6px}
.nav-links > a{
  position:relative;
  padding:10px 14px;border-radius:10px;
  font-weight:600;font-size:.92rem;color:var(--ink);
  transition:.18s
}
.nav-links > a:hover{background:#eef4fb;color:var(--navy)}
.nav-links > a.active{
  background:linear-gradient(135deg,rgba(225,29,43,.1),rgba(10,37,64,.05));
  color:var(--red)
}

.nav-cta{display:none}
.nav-cta.btn-primary{padding:11px 20px;font-size:.9rem;box-shadow:0 6px 16px rgba(225,29,43,.28)}

.menu-btn{background:transparent;border:0;font-size:1.6rem;color:var(--navy);cursor:pointer;padding:6px}

.mobile-menu{display:none;background:#fff;border-top:1px solid var(--line);padding:10px 20px 18px}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:10px 0;border-bottom:1px solid var(--line);font-weight:500}
.mobile-menu .btn{margin-top:12px;width:100%;justify-content:center}

@media(min-width:900px){
  .nav-links,.nav-cta{display:flex}
  .menu-btn{display:none}
}

/* Nav dropdowns (desktop) */
.has-dropdown{position:relative}
.has-dropdown > .drop-trigger{
  padding:10px 14px;border-radius:10px;
  font-weight:600;font-size:.92rem;color:var(--ink);
  cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  transition:.18s
}
.has-dropdown:hover > .drop-trigger,
.has-dropdown > .drop-trigger:focus{background:#eef4fb;color:var(--navy)}
.has-dropdown.active > .drop-trigger{color:var(--red)}
.has-dropdown .caret{font-size:.65rem;opacity:.7;transition:.2s}
.has-dropdown:hover .caret{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(10px);
  background:#fff;min-width:520px;max-width:560px;
  border-radius:16px;
  box-shadow:0 24px 60px rgba(10,37,64,.18),0 2px 6px rgba(10,37,64,.06);
  border:1px solid #e6edf5;
  padding:14px;
  opacity:0;visibility:hidden;transition:.2s;
  z-index:100;max-height:70vh;overflow-y:auto
}
.dropdown::before{
  content:"";position:absolute;top:-7px;left:50%;
  transform:translateX(-50%) rotate(45deg);
  width:14px;height:14px;background:#fff;
  border-left:1px solid #e6edf5;border-top:1px solid #e6edf5
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)
}
.dropdown ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:2px 8px}
.dropdown a{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;font-size:.88rem;border-radius:8px;
  color:var(--ink);font-weight:500;transition:.15s
}
.dropdown a::before{
  content:"›";color:var(--red);font-weight:700;
  opacity:0;transition:.15s;margin-left:-4px;width:0;overflow:hidden
}
.dropdown a:hover{background:#f3f7fc;color:var(--navy);padding-left:8px}
.dropdown a:hover::before{opacity:1;width:12px;margin-left:0}

/* Compact dropdown variant (REPLACES nth-child hack)
   Add class="dropdown dropdown--compact" in HTML where needed */
.dropdown.dropdown--compact{min-width:300px;max-width:340px}
.dropdown.dropdown--compact ul{grid-template-columns:1fr}

@media(max-width:899px){
  .has-dropdown,.dropdown{display:none}
}

/* Mobile dropdown via <details> */
.mobile-menu .m-cat{border-bottom:1px solid var(--line);padding:6px 0}
.mobile-menu .m-cat summary{
  cursor:pointer;list-style:none;padding:10px 0;
  font-weight:600;color:var(--navy);
  display:flex;justify-content:space-between;align-items:center
}
.mobile-menu .m-cat summary::after{content:"+";color:var(--red);font-size:1.2rem}
.mobile-menu .m-cat[open] summary::after{content:"–"}
.mobile-menu .m-cat a{padding:7px 14px;font-size:.9rem;border:0;color:var(--muted)}
.mobile-menu .m-cat a strong{color:var(--navy)}
.mobile-menu .m-sub-h{
  padding:10px 14px 4px;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--red);font-weight:700
}

/* Hero */
.hero{background:linear-gradient(180deg,#eaf2fb 0%,#dde9f7 100%);position:relative;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;padding:48px 0 0}
.hero h1{color:var(--navy)}
.hero h1 em{color:var(--red);font-style:normal}
.hero .eyebrow{
  letter-spacing:.18em;font-size:.8rem;color:var(--navy-2);
  font-weight:600;text-transform:uppercase;margin:18px 0 8px
}
.hero p.lead{color:var(--muted);max-width:520px;margin-bottom:24px}

/* Keep only hero-search (remove older search-box usage) */
.hero-search{
  display:flex;gap:8px;max-width:520px;margin:0 0 16px;
  background:#fff;border:1px solid #e3e8ef;border-radius:14px;
  padding:6px;box-shadow:0 8px 24px rgba(15,23,42,.06)
}
.hero-search input{
  flex:1;border:0;outline:0;padding:12px 14px;
  font-size:15px;background:transparent;color:#0f172a;border-radius:10px
}
.hero-search button{
  border:0;background:var(--red);color:#fff;border-radius:10px;
  padding:0 16px;font-size:16px;cursor:pointer;font-weight:600
}
.hero-search button:hover{filter:brightness(1.05)}
@media(max-width:520px){.hero-search{max-width:100%}}

.hero-img{position:relative;display:flex;justify-content:center}
.hero-img .blob{
  width:min(420px,90vw);aspect-ratio:1;
  background:radial-gradient(circle at 30% 30%,var(--red),var(--navy));
  border-radius:50%;display:flex;align-items:flex-end;justify-content:center;
  overflow:hidden;box-shadow:0 20px 60px rgba(10,37,64,.25)
}
.hero-img .blob img{width:100%;height:100%;object-fit:cover;mix-blend-mode:luminosity;opacity:.95}

.stats{
  background:var(--dark);color:#fff;border-radius:18px 18px 0 0;
  padding:24px;display:grid;grid-template-columns:repeat(2,1fr);
  gap:18px;margin-top:30px
}
.stat strong{display:block;font-size:1.8rem;font-family:'Poppins';color:#fff}
.stat span{font-size:.85rem;color:#b9c6d6}
@media(min-width:760px){
  .hero-inner{grid-template-columns:1.1fr .9fr;padding:64px 0 0}
  .stats{grid-template-columns:repeat(4,1fr);margin-top:48px}
}

/* Services grid */
.services-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.services-grid{grid-template-columns:repeat(3,1fr)}}

.service-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:.25s;display:flex;flex-direction:column
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.service-card .ph{aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy),var(--red));position:relative;overflow:hidden}
.service-card .ph img{width:100%;height:100%;object-fit:cover}
.service-card .body{padding:18px 20px 22px}
.service-card .count{color:var(--muted);font-size:.8rem;font-weight:600;letter-spacing:.04em}
.service-card h3{margin:6px 0 6px;color:var(--navy)}
.service-card p{color:var(--muted);font-size:.92rem}

/* Tabs popular */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 26px}
.tab{
  padding:8px 18px;border-radius:999px;background:#fff;border:1px solid var(--line);
  font-weight:600;font-size:.9rem;color:var(--muted);
  cursor:pointer;transition:.2s
}
.tab:hover{border-color:var(--navy);color:var(--navy)}
.tab.active{background:var(--navy);border-color:var(--navy);color:#fff}

.popular-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.popular-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.popular-grid{grid-template-columns:repeat(3,1fr)}}

.pop-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.25s}
.pop-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.pop-card .ph{aspect-ratio:16/10;overflow:hidden}
.pop-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pop-card:hover .ph img{transform:scale(1.05)}
.pop-card .body{padding:14px 18px 18px}
.pop-card .cat{color:var(--red);font-size:.8rem;font-weight:600}
.pop-card h4{font-family:'Poppins';color:var(--navy);margin:4px 0 6px;font-size:1.05rem}
.pop-card .stars{color:#f5b400;font-size:.85rem}
.pop-card .stars small{color:var(--muted);margin-left:4px}

/* Categories dark */
.cat-section{background:var(--dark);color:#fff;padding:64px 0}
.cat-section h2{color:#fff}
.cat-section .subtitle{color:#9bb0c7}
.cat-block{margin-top:36px}
.cat-block > h3{color:var(--red);font-family:'Poppins';font-size:1.1rem;margin-bottom:18px;letter-spacing:.04em;text-transform:uppercase}
.cat-cols{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:640px){.cat-cols{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.cat-cols{grid-template-columns:repeat(3,1fr)}}
.cat-col h4{color:#fff;font-family:'Poppins';font-size:1.05rem;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid rgba(225,29,43,.4)}
.cat-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.cat-col li a{color:#c8d4e2;font-size:.92rem;display:block;padding:4px 0;transition:.2s}
.cat-col li a:hover{color:var(--red);transform:translateX(4px)}

/* Blogs */
.blogs-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:30px}
@media(min-width:760px){.blogs-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{background:#eef4fb;border-radius:18px;overflow:hidden;transition:.25s}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.blog-card .ph{aspect-ratio:16/10;overflow:hidden;border-radius:18px;margin:6px}
.blog-card .ph img{width:100%;height:100%;object-fit:cover}
.blog-card .body{padding:8px 22px 24px}
.blog-card .date{color:var(--muted);font-size:.8rem;margin-bottom:6px}
.blog-card h4{font-family:'Poppins';color:var(--navy);font-size:1.05rem;margin-bottom:8px}
.blog-card p{color:var(--muted);font-size:.88rem}

.section-title-center{text-align:center}
.section-title-center .subtitle{margin:6px auto 0;max-width:600px}
.section-title-center h2 span{color:var(--red)}

/* CTA */
.cta{
  background:linear-gradient(135deg,var(--navy),var(--dark));
  color:#fff;border-radius:20px;padding:46px 28px;
  text-align:center;margin:40px auto;max-width:var(--maxw)
}
.cta h2{color:#fff;margin-bottom:10px}
.cta p{color:#b9c6d6;margin-bottom:22px}

/* Footer */
.footer{background:#06121f;color:#9bb0c7;padding:54px 0 22px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:30px}
@media(min-width:760px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer h5{color:#fff;font-family:'Poppins';margin-bottom:14px;font-size:1rem}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer a:hover{color:var(--red)}
.footer .logo-text{color:#fff}
.footer p{font-size:.9rem;margin-top:10px}
.footer-bottom{border-top:1px solid #122334;margin-top:30px;padding-top:18px;text-align:center;font-size:.85rem}

/* WhatsApp FAB */
.fab{
  position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 25px rgba(37,211,102,.4);z-index:60;font-size:1.7rem;transition:.2s
}
.fab:hover{transform:scale(1.08)}

/* Forms */
.form{
  display:flex;flex-direction:column;gap:14px;max-width:560px;margin:0 auto;
  background:#fff;padding:28px;border-radius:18px;box-shadow:var(--shadow)
}
.form input,.form textarea{
  width:100%;padding:12px 16px;border:1px solid var(--line);border-radius:10px;
  font-size:1rem;font-family:inherit;outline:0
}
.form input:focus,.form textarea:focus{border-color:var(--navy)}
.form textarea{min-height:120px;resize:vertical}

/* Page hero (keep centered default; use service-hero for left aligned layouts) */
.page-hero{
  background:linear-gradient(135deg,var(--navy),var(--dark));
  color:#fff;padding:80px 0 60px;text-align:center
}
.page-hero h1{color:#fff}
.page-hero p{color:#b9c6d6;max-width:600px;margin:14px auto 0}

/* Service detail page */
.service-hero .service-hero-grid{
  display:grid;grid-template-columns:1fr;gap:30px;align-items:center;margin-top:10px;text-align:left
}
@media(min-width:820px){.service-hero .service-hero-grid{grid-template-columns:1.2fr 1fr}}
.service-hero .eyebrow{letter-spacing:.16em;font-size:.78rem;color:var(--red);font-weight:700;text-transform:uppercase;margin-bottom:10px}
.service-hero h1{color:#fff;text-align:left}
.service-hero p{color:#cfdbe9;margin:14px 0 22px;max-width:540px}
.service-hero-img img{
  border-radius:18px;box-shadow:0 20px 50px rgba(0,0,0,.3);
  width:100%;height:100%;object-fit:cover;max-height:360px
}

/* Extra components kept from your file */
.about-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
@media(min-width:800px){.about-grid{grid-template-columns:1fr 1fr}}
.about-grid img{border-radius:18px;box-shadow:var(--shadow)}

.values{display:grid;grid-template-columns:1fr;gap:18px;margin-top:30px}
@media(min-width:640px){.values{grid-template-columns:repeat(3,1fr)}}
.value{padding:24px;background:#fff;border-radius:14px;border:1px solid var(--line)}
.value .icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg,var(--navy),var(--red));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:12px
}
.value h4{color:var(--navy);font-family:'Poppins';margin-bottom:6px}
.value p{color:var(--muted);font-size:.92rem}

.contact-grid{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:820px){.contact-grid{grid-template-columns:1fr 1.2fr}}
.contact-info{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px}
.contact-info h3{color:var(--navy);margin-bottom:16px;font-family:'Poppins'}
.contact-info .row{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.contact-info .row .ic{
  width:38px;height:38px;border-radius:10px;background:#eef4fb;
  color:var(--navy);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-weight:700
}
.contact-info .row strong{color:var(--navy);display:block;font-size:.95rem}
.contact-info .row span{color:var(--muted);font-size:.9rem}

.breadcrumbs{color:#9bb0c7;font-size:.85rem;margin-bottom:18px}
.breadcrumbs a{color:#cfdbe9}
.breadcrumbs a:hover{color:#fff}

.cat-section-title{
  color:var(--navy);font-family:'Poppins';font-size:1.3rem;margin:36px 0 16px;
  padding-bottom:8px;border-bottom:2px solid var(--red)
}
.cat-section-title:first-child{margin-top:0}

.service-body{display:grid;grid-template-columns:1fr;gap:30px;align-items:start}
@media(min-width:900px){.service-body{grid-template-columns:1.6fr 1fr}}
.service-body h2{margin-bottom:10px}
.service-body h3{color:var(--navy);font-family:'Poppins'}

.checklist{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:10px}
.checklist li{padding-left:28px;position:relative;color:var(--ink)}
.checklist li::before{
  content:"✓";position:absolute;left:0;top:0;width:20px;height:20px;border-radius:50%;
  background:var(--red);color:#fff;font-size:.75rem;display:flex;align-items:center;justify-content:center;font-weight:700
}

.process{counter-reset:step;list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:12px}
.process li{padding-left:44px;position:relative;color:var(--muted)}
.process li strong{color:var(--navy)}
.process li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:0;top:-2px;width:32px;height:32px;border-radius:10px;
  background:linear-gradient(135deg,var(--navy),var(--red));
  color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center
}

.service-aside{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;
  box-shadow:var(--shadow);position:sticky;top:90px
}
.service-aside h4{color:var(--navy);font-family:'Poppins';margin-bottom:8px}
.service-aside p{color:var(--muted);font-size:.9rem;margin-bottom:16px}
/* Helpers used by the rewritten index.html */
.section--soft { background:#f8fafd; }
.tabs--center { justify-content:center; }
.services-grid--spaced { margin-top:36px; }

.footer-brand { display:flex; align-items:center; gap:10px; }
.footer-logo { height:42px; width:auto; border-radius:6px; }

.accent { color: var(--red); }

/* A11y helpers */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.skip-link{
  position:absolute; left:-999px; top:10px; background:#fff; color:var(--navy);
  border:2px solid var(--navy); padding:10px 14px; border-radius:10px; z-index:999;
}
.skip-link:focus{ left:10px; }