
:root{
  --bg:#eef1f2;
  --bg-soft:#f7f8f9;
  --surface:#ffffff;
  --surface-2:#f2f4f6;
  --text:#173156;
  --muted:#5d6a7c;
  --brand:#102e58;
  --brand-2:#163b70;
  --orange:#f2ad0f;
  --orange-2:#ff8e1d;
  --green:#25d366;
  --border:#d9e0e8;
  --shadow:0 18px 40px rgba(16,46,88,.10);
  --shadow-soft:0 10px 26px rgba(16,46,88,.08);
  --radius-xl:30px;
  --radius-lg:24px;
  --radius-md:18px;
  --radius-sm:14px;
  --container:min(1180px, calc(100vw - 32px));
  --header-h:88px;
  --transition:.28s ease;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(242,173,15,.10), transparent 22%),
    linear-gradient(180deg, #f8f9fa 0%, var(--bg) 44%, #f4f6f7 100%);
  min-height:100vh;
  line-height:1.65;
  overflow-x:hidden;
}
body.menu-open{overflow:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
.skip-link{
  position:fixed;
  left:16px;
  top:-56px;
  background:var(--brand);
  color:#fff;
  padding:12px 16px;
  border-radius:12px;
  z-index:999;
  transition:top var(--transition);
}
.skip-link:focus{top:16px}
.container{width:var(--container);margin:0 auto}
.site-main{padding-top:calc(var(--header-h) + 18px);padding-bottom:120px}
@media (min-width: 992px){
  .site-main{padding-bottom:0}
}
.section,.home-services-top,.page-hero{
  content-visibility:auto;
  contain-intrinsic-size:1px 980px;
}
.section{padding:36px 0}
.section-head{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:24px;
}
.section-kicker,.eyebrow,.card-badge,.blog-meta,.mobile-contact-title,.review-stars,.district-card-top{
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.section-kicker, .eyebrow{
  color:var(--brand);
  font-weight:700;
  letter-spacing:.01em;
}
.section-head h2, .page-hero h1, .home-head h1{
  margin:0;
  font-size:clamp(2rem, 4vw, 3.25rem);
  line-height:1.1;
  letter-spacing:-.02em;
}
.section-head p,.page-lead,.home-head p{
  margin:0;
  color:var(--muted);
  max-width:780px;
  font-size:1.05rem;
}
.section-head h2{font-size:clamp(1.75rem, 3.2vw, 2.55rem)}
.site-loader{
  position:fixed;
  inset:0;
  background:linear-gradient(180deg, rgba(247,248,249,.98), rgba(238,241,242,.98));
  display:grid;
  place-items:center;
  z-index:1200;
  transition:opacity .35s ease, visibility .35s ease;
}
.site-loader.hidden{opacity:0;visibility:hidden}
.loader-inner{
  width:min(240px, 60vw);
  padding:20px;
  border-radius:28px;
  background:#fff;
  box-shadow:var(--shadow);
  animation:pulseLogo 1.8s infinite ease-in-out;
}
.loader-inner img{width:100%;height:auto}
@keyframes pulseLogo{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.035)}
}

.site-header{
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
}

.header-shell{
  width: var(--container);
  margin: 0 auto;
  min-height: var(--header-h);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(217,224,232,.8);
  box-shadow: var(--shadow-soft);
  border-radius: 28px;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 10px 14px 10px 18px;
}
.brand-wrap{display:flex;align-items:center;min-width:150px}
.brand-logo{
  width:320px;
  max-width:50vw;
  height:auto;
  opacity:0;
  transition:opacity .4s ease;
}
.brand-logo.is-loaded,.footer-logo.is-loaded,.responsive-img.is-loaded,.banner-img.is-loaded{opacity:1}
.desktop-nav{flex:1;display:none}
.nav-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.nav-item{position:relative}
.nav-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 16px;
  font-weight:700;
  color:var(--brand);
  border-radius:16px;
  transition:background var(--transition), color var(--transition), transform var(--transition);
}
.nav-link:hover,.nav-item.active > .nav-link,.nav-item.has-dropdown:hover > .nav-link{
  background:#f2f4f7;
  color:var(--brand-2);
  transform:translateY(-1px);
}
.nav-caret{font-size:.9rem}
.dropdown-panel{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:320px;
  max-height:420px;
  overflow:auto;
  padding:14px;
  background:#fff;
  border-radius:24px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  display:grid;
  gap:8px;
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:opacity var(--transition), transform var(--transition);
}
.area-panel{
  min-width:420px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.has-dropdown:hover .dropdown-panel,
.has-dropdown:focus-within .dropdown-panel{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.dropdown-link{
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--surface-2);
  border-radius:16px;
  padding:12px 14px;
  color:var(--brand);
  font-weight:700;
  transition:background var(--transition), transform var(--transition);
}
.dropdown-link:hover{
  background:#eef3fa;
  transform:translateX(3px);
}
.desktop-cta{
  display:flex;
  align-items:center;
  gap:12px;
  margin-left:auto;
}
.desktop-action{display:none}
.btn{
  border:0;
  cursor:pointer;
  border-radius:16px;
  padding:14px 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-weight:800;
  transition:transform var(--transition), box-shadow var(--transition), filter var(--transition);
  box-shadow:var(--shadow-soft);
}
.btn:hover{transform:translateY(-2px);filter:saturate(1.02)}
.btn:focus-visible,.menu-toggle:focus-visible,.drawer-close:focus-visible,.faq-question:focus-visible,.mobile-nav-button:focus-visible{
  outline:3px solid rgba(242,173,15,.4);
  outline-offset:2px;
}
.btn-detail{background:#667281;color:#fff}
.btn-call{background:var(--orange-2);color:#fff}
.btn-whatsapp{background:var(--green);color:#fff}
.full-width{width:100%}
.menu-toggle{
  display:inline-flex;
  flex-direction:column;
  gap:5px;
  width:54px;
  height:54px;
  justify-content:center;
  align-items:center;
  border-radius:18px;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:var(--shadow-soft);
  cursor:pointer;
}
.menu-toggle span{
  width:22px;height:2px;background:var(--brand);border-radius:999px;display:block;transition:transform var(--transition),opacity var(--transition)
}
body.menu-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-overlay{
  position:fixed;inset:0;background:rgba(6,18,39,.44);opacity:0;pointer-events:none;transition:opacity var(--transition)
}
.mobile-drawer{
  position:fixed;
  top:8px;right:8px;bottom:8px;
  width:min(390px, calc(100vw - 16px));
  background:linear-gradient(180deg,#eceff2 0%, #e0e6e8 100%);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 26px 60px rgba(6,18,39,.28);
  border-radius:32px;
  transform:translateX(112%);
  transition:transform var(--transition);
  display:flex;
  flex-direction:column;
}
.mobile-drawer-head{
  padding:16px 16px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.drawer-close{
  width:44px;height:44px;border:1px solid var(--border);background:#f6f8fa;border-radius:16px;color:var(--brand);cursor:pointer;box-shadow:var(--shadow-soft)
}
.mobile-drawer-scroll{
  overflow:auto;
  padding:8px 14px 18px;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.mobile-nav, .mobile-contact-card{background:transparent}
.mobile-nav-link,.mobile-nav-button{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#fff;
  color:var(--brand);
  border:1px solid var(--border);
  border-radius:20px;
  padding:16px 16px;
  font-weight:800;
  box-shadow:var(--shadow-soft);
}
.mobile-nav-left{display:flex;align-items:center;gap:12px}
.mobile-nav-left i,.mobile-submenu-link i,.dropdown-link i,.section-kicker i,.eyebrow i,.card-badge i{
  color:var(--orange);
}
.mobile-nav-link + .mobile-nav-link,
.mobile-nav-link + .mobile-accordion,
.mobile-accordion + .mobile-nav-link,
.mobile-accordion + .mobile-accordion{margin-top:12px}
.mobile-submenu{
  max-height:0;
  overflow:hidden auto;
  transition:max-height .35s ease;
  display:grid;
  gap:10px;
  padding:0 2px;
}
.mobile-accordion.open .mobile-submenu{max-height:265px;margin-top:10px}
.mobile-submenu-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px 16px;
  font-weight:700;
  color:var(--brand);
}
.mobile-submenu-link.active,
.mobile-nav-link.active,
.mobile-accordion.active > .mobile-nav-button{
  border-color:rgba(242,173,15,.55);
  background:#fff;
}
.mobile-contact-card{
  border-radius:24px;
  border:1px solid rgba(196,205,214,.9);
  background:rgba(255,255,255,.65);
  padding:18px 16px;
  box-shadow:var(--shadow-soft);
}
.mobile-contact-title{font-weight:800;font-size:1.375rem;color:var(--brand)}
.mobile-contact-card p{margin:6px 0 16px;color:var(--muted)}
.mobile-contact-card .btn + .btn{margin-top:12px}
body.menu-open .mobile-overlay{opacity:1;pointer-events:auto}
body.menu-open .mobile-drawer{transform:translateX(0)}

.page-hero{
  padding:24px 0 12px;
}
.home-services-top{
  padding:18px 0 22px;
}
.page-hero .container,
.home-services-top .container{
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.86));
  border:1px solid rgba(217,224,232,.9);
  box-shadow:var(--shadow);
  border-radius:34px;
  padding:28px;
}
.breadcrumb{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:.95rem;
  color:var(--muted);
  margin-bottom:10px;
}
.breadcrumb a{color:var(--brand)}
.home-head{text-align:left}
.stat-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}
.stat-pills span, .tag-cloud span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:#f2f5f8;
  border:1px solid var(--border);
  color:var(--brand);
  font-weight:700;
}
.service-grid,.feature-grid,.blog-grid,.district-grid,.content-grid,.callout-grid,.contact-grid,.area-link-grid{
  display:grid;
  gap:20px;
}
.service-grid{grid-template-columns:1fr}
.feature-grid,.content-grid.three{grid-template-columns:1fr}
.content-grid.two,.callout-grid,.contact-grid{grid-template-columns:1fr}
.blog-grid,.district-grid,.area-link-grid{grid-template-columns:1fr}
.service-card,.blog-card,.district-card,.feature-card,.content-card,.callout-card,.contact-card,.review-card{
  background:rgba(255,255,255,.96);
  border:1px solid var(--border);
  border-radius:28px;
  box-shadow:var(--shadow-soft);
}
.service-card{
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.service-card.compact h3{font-size:1.4rem}
.service-card-content{
  padding:18px 18px 20px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.service-card h3,.blog-card h2,.review-card h3,.contact-card h2,.content-card h2,.callout-card h2{
  margin:0;
  line-height:1.2;
}
.service-card h3{font-size:1.55rem}
.service-card p,.content-card p,.callout-card p,.contact-card p,.review-card p,.blog-card p,.district-card p,.feature-card p{
  margin:0;
  color:var(--muted);
}
.stacked-actions{
  display:grid;
  gap:10px;
  margin-top:6px;
}
.media-frame{
  position:relative;
  overflow:hidden;
  aspect-ratio:4/3;
  background:
    linear-gradient(180deg, rgba(247,248,249,.9), rgba(238,241,242,.95)),
    url("/assets/img/logo-160.webp") center/110px auto no-repeat;
}
.responsive-img, .banner-img, .footer-logo{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .45s ease, transform .8s ease;
}
.service-card:hover .responsive-img,
.blog-card:hover .responsive-img,
.overlay-banner:hover .banner-img{transform:scale(1.03)}
.gallery-band{
  background:linear-gradient(180deg, rgba(242,173,15,.90), rgba(255,142,29,.92));
  color:#fff;
}
.gallery-band .section-kicker,.gallery-band .section-head h2,.gallery-band .section-head p{
  color:#fff;
}
.gallery-marquee{
  overflow:hidden;
  margin-top:8px;
  border-radius:30px;
}
.gallery-track{
  display:flex;
  gap:18px;
  width:max-content;
  animation:marquee 28s linear infinite;
}
.gallery-slide{
  width:min(280px, 66vw);
}
.gallery-slide .media-frame{
  border-radius:24px;
  overflow:hidden;
  border:3px solid rgba(255,255,255,.35);
  box-shadow:0 14px 30px rgba(16,46,88,.18);
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.overlay-banner{
  position:relative;
  border:6px solid var(--orange-2);
  border-radius:30px;
  overflow:hidden;
  min-height:360px;
  box-shadow:var(--shadow);
}
.overlay-banner-image{position:absolute;inset:0}
.overlay-banner-image::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(0,0,0,.42);
}
.overlay-banner-content{
  position:relative;
  z-index:1;
  min-height:360px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:14px;
  padding:clamp(24px, 5vw, 46px);
  color:#fff;
}
.overlay-banner-content h2{
  margin:0;
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1.05;
}
.overlay-banner-content p{margin:0;max-width:620px;color:rgba(255,255,255,.88)}
.review-list{
  display:grid;
  gap:16px;
}
.review-card{
  padding:20px;
}
.review-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:10px;
}
.review-head p{font-size:.95rem}
.review-stars{
  color:#f4c542;
  white-space:nowrap;
}
.pulse-stars{animation:pulseStars 1.8s infinite}
@keyframes pulseStars{
  0%,100%{transform:scale(1); filter:drop-shadow(0 0 0 rgba(244,197,66,.2))}
  50%{transform:scale(1.05); filter:drop-shadow(0 0 12px rgba(244,197,66,.35))}
}
.about-snippet .content-grid{align-items:start}
.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.tag-cloud.large{margin-top:6px}
.mini-checks{
  display:grid;
  gap:12px;
  margin-top:18px;
}
.mini-checks div{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--brand);
  font-weight:700;
}
.mini-checks i{color:var(--orange-2)}
.split-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
  align-items:center;
}
.split-copy{
  background:rgba(255,255,255,.86);
  border:1px solid var(--border);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.split-copy h2{margin:0 0 12px;font-size:clamp(1.65rem, 3vw, 2.35rem);line-height:1.1}
.split-copy p{margin:0 0 14px;color:var(--muted)}
.article-section .article-container{
  background:rgba(255,255,255,.94);
  border:1px solid var(--border);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.article-block + .article-block{
  border-top:1px solid var(--border);
  margin-top:22px;
  padding-top:22px;
}
.article-block h2{
  margin:0 0 12px;
  font-size:clamp(1.45rem, 2.6vw, 2rem);
  line-height:1.15;
}
.article-block p{margin:0 0 14px;color:var(--muted)}
.callout-card, .contact-card{
  padding:22px;
}
.callout-card.secondary{background:#f7f9fb}
.callout-icon,.contact-icon{
  width:58px;height:58px;border-radius:18px;display:grid;place-items:center;background:#f4f7fb;color:var(--orange-2);font-size:1.35rem;margin-bottom:12px
}
.area-link-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft);
  color:var(--brand);
  font-weight:700;
}
.area-link-card span{flex:1}
.district-card{
  padding:20px;
  transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.district-card:hover,.area-link-card:hover{
  transform:translateY(-3px);
  border-color:rgba(242,173,15,.65);
  box-shadow:var(--shadow);
}
.district-card-top{
  font-weight:800;
  color:var(--brand);
  margin-bottom:10px;
}
.district-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:14px;
  color:var(--orange-2);
  font-weight:800;
}
.blog-card{overflow:hidden}
.blog-card-content{padding:18px 18px 22px;display:grid;gap:12px}
.blog-card h2{font-size:1.45rem}
.text-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:800;
  color:var(--brand);
}
.article-header-media .blog-meta.large{margin-bottom:16px;color:var(--muted)}
.faq-list{
  display:grid;
  gap:14px;
}
.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border:0;
  padding:18px 20px;
  background:#fff;
  color:var(--brand);
  font-weight:800;
  text-align:left;
  cursor:pointer;
}
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease;
}
.faq-answer p{
  margin:0;
  padding:0 20px 18px;
  color:var(--muted);
}
.faq-item.open .faq-answer{max-height:240px}
.faq-item.open .faq-question i{transform:rotate(45deg)}
.site-footer{
  background:linear-gradient(180deg, rgba(16,46,88,.98), rgba(10,28,54,1));
  color:#fff;
  padding-top:44px;
  margin-top:36px;
}
.footer-grid{
  display:grid;
  gap:28px;
  padding-bottom:30px;
}
.footer-brand p{color:rgba(255,255,255,.76);max-width:380px}
.footer-logo-wrap{display:inline-flex;max-width:190px}
.footer-logo{
  width:100%;
  height:auto;
}
.footer-heading{
  font-weight:800;
  margin-bottom:12px;
  font-size:1.1rem;
}
.footer-links,.footer-simple-links,.footer-contact-list{
  display:grid;
  gap:10px;
}
.footer-links a,.footer-simple-links a,.footer-contact-list a{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.82);
}
.footer-links a i,.footer-contact-list a i{color:var(--orange)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:14px 0 100px;
}
.footer-bottom-row{
  display:flex;
  flex-direction:column;
  gap:6px;
  color:rgba(255,255,255,.72)
}
.mobile-sticky-bar{
  position:fixed;
  left:0;right:0;bottom:14px;
  z-index:880;
}
.mobile-sticky-inner{
  width:min(540px, calc(100vw - 18px));
  margin:0 auto;
  background:#fff;
  border:2px solid var(--orange-2);
  border-radius:24px;
  padding:8px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  box-shadow:var(--shadow);
}
.mobile-sticky-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  border-radius:18px;
  font-weight:800;
  color:#fff;
}
.mobile-call{background:var(--orange-2)}
.mobile-wa{background:var(--green)}

@media (min-width:768px){
  .section{padding:44px 0}
  .page-hero .container,.home-services-top .container{padding:34px}
  .service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content-grid.two,.callout-grid,.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .blog-grid,.district-grid,.area-link-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .footer-bottom-row{flex-direction:row;justify-content:space-between;align-items:center}
}

@media (min-width:992px){
  .desktop-nav{display:block}
  .desktop-action{display:inline-flex}
  .menu-toggle{display:none}
  .mobile-drawer,.mobile-overlay{display:none}
  .home-services-top .container,.page-hero .container{padding:42px}
  .service-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .content-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
  .split-layout{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr)}
  .split-layout .media-frame{height:100%;min-height:420px}
  .contact-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .mobile-sticky-bar{display:none}
  .site-main{padding-top:130px}
  .footer-bottom{padding-bottom:18px}
}

@media (max-width:991.98px){
  .desktop-action{display:none}
}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto}
  .site-loader,.gallery-track,.pulse-stars,.loader-inner,.btn,.responsive-img,.banner-img,.menu-toggle span,.mobile-overlay,.mobile-drawer{animation:none!important;transition:none!important}
}












.about-section{
  padding: 70px 20px;
  background: linear-gradient(180deg, #f8f8f8 0%, #efefef 100%);
}

.container{
  max-width: 1200px;
  margin: 0 auto;
}

.about-wrapper{
  max-width: 1000px;
  margin: 0 auto;
}

.about-title{
  text-align: center;
  font-size: 44px;
  font-weight: 800;
  line-height: 1.2;
  color: #0f2747;
  margin: 0 0 28px;
  letter-spacing: -0.5px;
  text-shadow: 0 2px 0 rgba(255,255,255,0.8);
}

.about-card{
  background: linear-gradient(145deg, #ffffff 0%, #f7f7f7 100%);
  border: 5px solid #f59e0b;
  border-radius: 24px;
  padding: 38px 34px;
  box-shadow:
    0 6px 0 #d97706,
    0 16px 35px rgba(0, 0, 0, 0.12),
    inset 0 2px 0 rgba(255,255,255,0.9),
    inset 0 -2px 8px rgba(0,0,0,0.04);
  position: relative;
  overflow: hidden;
}

.about-card::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 8px;
  background: linear-gradient(90deg, #fbbf24 0%, #f59e0b 50%, #d97706 100%);
}

.about-card p{
  font-size: 18px;
  line-height: 1.95;
  color: #374151;
  margin: 0 0 22px;
}

.about-card p:last-child{
  margin-bottom: 0;
}

@media (max-width: 991px){
  .about-title{
    font-size: 38px;
  }

  .about-card{
    padding: 30px 24px;
  }

  .about-card p{
    font-size: 17px;
    line-height: 1.85;
  }
}

@media (max-width: 768px){
  .about-section{
    padding: 50px 16px;
  }

  .about-title{
    font-size: 32px;
    margin-bottom: 22px;
  }

  .about-card{
    border-width: 4px;
    border-radius: 18px;
    padding: 24px 18px;
    box-shadow:
      0 5px 0 #d97706,
      0 12px 24px rgba(0, 0, 0, 0.10),
      inset 0 2px 0 rgba(255,255,255,0.9);
  }

  .about-card p{
    font-size: 16px;
    line-height: 1.8;
    margin-bottom: 18px;
  }
}




.site-loader{
  display: none !important;
}









.cta-strip{
  padding: 30px 20px 50px;
}

.cta-strip-box{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: 34px 32px;
  background: linear-gradient(145deg, #ffffff 0%, #f8f8f8 100%);
  border: 4px solid #f97316;
  border-radius: 24px;
  box-shadow:
    0 8px 0 #d65f0e,
    0 18px 35px rgba(0,0,0,0.10);
  position: relative;
  overflow: hidden;
}

.cta-strip-box::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(249,115,22,0.08), rgba(249,115,22,0));
  pointer-events: none;
}

.cta-strip-content{
  position: relative;
  z-index: 1;
  flex: 1 1 520px;
}

.cta-strip-content h2{
  margin: 0 0 10px;
  font-size: 34px;
  line-height: 1.2;
  font-weight: 800;
  color: #111827;
}

.cta-strip-content p{
  margin: 0;
  font-size: 18px;
  line-height: 1.7;
  color: #374151;
}

.cta-strip-actions{
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 14px;
  flex: 0 1 430px;
}

.cta-btn{
  min-width: 170px;
  height: 54px;
  padding: 0 22px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none;
  font-size: 16px;
  font-weight: 700;
  transition: all 0.25s ease;
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
}

.cta-btn i{
  font-size: 18px;
}

.cta-call{
  background: #f97316;
  color: #ffffff;
}

.cta-whatsapp{
  background: #16a34a;
  color: #ffffff;
}

.cta-location{
  background: #111827;
  color: #ffffff;
}

.cta-btn:hover{
  transform: translateY(-3px);
  box-shadow: 0 14px 24px rgba(0,0,0,0.14);
}

@media (max-width: 991px){
  .cta-strip-box{
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    padding: 28px 24px;
  }

  .cta-strip-content{
    flex: 1 1 auto;
    width: 100%;
  }

  .cta-strip-content h2{
    font-size: 30px;
  }

  .cta-strip-content p{
    font-size: 17px;
  }

  .cta-strip-actions{
    width: 100%;
    flex: 1 1 auto;
    justify-content: flex-start;
  }
}

@media (max-width: 768px){
  .cta-strip{
    padding: 20px 16px 40px;
  }

  .cta-strip-box{
    gap: 14px;
    padding: 20px 16px;
    border-width: 3px;
    border-radius: 18px;
    box-shadow:
      0 6px 0 #d65f0e,
      0 14px 24px rgba(0,0,0,0.10);
  }

  .cta-strip-content{
    width: 100%;
    flex: unset;
  }

  .cta-strip-content h2{
    font-size: 24px;
    margin-bottom: 8px;
  }

  .cta-strip-content p{
    font-size: 15px;
    line-height: 1.6;
  }

  .cta-strip-actions{
    width: 100%;
    flex: unset;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 2px;
  }

  .cta-btn{
    width: 100%;
    min-width: 100%;
    height: 50px;
    padding: 0 16px;
    font-size: 15px;
    border-radius: 12px;
  }

  .cta-btn i{
    font-size: 16px;
  }
}















.hero-banner{
  position: relative;
  min-height: 620px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(8,33,62,0.88) 0%, rgba(8,33,62,0.70) 38%, rgba(20,20,20,0.35) 70%, rgba(249,115,22,0.18) 100%),
    url("../img/hero.webp") center center / cover no-repeat;
}

.hero-overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at left center, rgba(30,64,175,0.22), transparent 35%),
    radial-gradient(circle at right center, rgba(249,115,22,0.18), transparent 28%);
  pointer-events: none;
}

.hero-banner .container{
  position: relative;
  z-index: 2;
  width: min(1200px, calc(100% - 32px));
  margin: 0 auto;
}

.hero-content{
  max-width: 760px;
  padding: 90px 0 80px;
  color: #fff;
}

.hero-badge{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(8px);
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 18px;
}

.hero-badge i{
  color: #f59e0b;
}

.hero-content h1{
  margin: 0 0 18px;
  font-size: 56px;
  line-height: 1.08;
  font-weight: 800;
  color: #fff;
}

.hero-content p{
  max-width: 700px;
  margin: 0 0 26px;
  font-size: 24px;
  line-height: 1.6;
  color: rgba(255,255,255,0.94);
}

.hero-rating{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 28px;
}

.hero-rating strong{
  font-size: 32px;
  color: #fff;
}

.hero-stars{
  display: inline-flex;
  gap: 6px;
}

.hero-stars i{
  color: #fbbf24;
  font-size: 20px;
}

.hero-review-pill{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.16);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
}

.hero-actions{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}

.hero-btn{
  min-width: 210px;
  height: 58px;
  padding: 0 24px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 11px;
  text-decoration: none;
  font-size: 20px;
  font-weight: 800;
  transition: 0.25s ease;
}

.hero-btn-call{
  background: #f97316; /* turuncu */
  color: #ffffff;
  border: 2px solid #ea580c;
}

.hero-btn-whatsapp{
  background: #22c55e;
  color: #fff;
  border: 2px solid rgba(255,255,255,0.10);
}

.hero-btn:hover{
  transform: translateY(-3px);
}

@media (max-width: 768px){
  .hero-banner{
    min-height: 520px;
  }

  .hero-content{
    padding: 56px 0 54px;
  }

  .hero-content h1{
    font-size: 34px;
  }

  .hero-content p{
    font-size: 17px;
  }

  .hero-actions{
    flex-direction: column;
    align-items: stretch;
  }

  .hero-btn{
    width: 100%;
    min-width: 100%;
    height: 54px;
    font-size: 17px;
  }
}







/* NABIZ ANİMASYONU */
@keyframes pulseGlow {
  0% {
    transform: scale(1);
    text-shadow: 0 0 0 rgba(251,191,36,0);
  }
  50% {
    transform: scale(1.08);
    text-shadow: 0 0 14px rgba(251,191,36,0.9);
  }
  100% {
    transform: scale(1);
    text-shadow: 0 0 0 rgba(251,191,36,0);
  }
}

/* 5.0 yazısı */
.hero-rating strong{
  font-size: 32px;
  color: #ffffff;
  animation: pulseGlow 1.6s infinite ease-in-out;
}

/* yıldızlar */
.hero-stars i{
  color: #fbbf24;
  font-size: 20px;
  animation: pulseGlow 1.6s infinite ease-in-out;
}

/* yıldızların sırayla atması */
.hero-stars i:nth-child(1){ animation-delay: 0s; }
.hero-stars i:nth-child(2){ animation-delay: 0.2s; }
.hero-stars i:nth-child(3){ animation-delay: 0.4s; }
.hero-stars i:nth-child(4){ animation-delay: 0.6s; }
.hero-stars i:nth-child(5){ animation-delay: 0.8s; }















.site-header{
  position: relative;
  margin: 0;
  padding: 0;
}

.header-shell{
  width: var(--container);
  margin: 0 auto 6px; /* alttaki boşluğu küçültür */
  min-height: var(--header-h);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(217,224,232,.8);
  box-shadow: var(--shadow-soft);
  border-radius: 28px;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 10px 14px 10px 18px;
}

.hero-banner{
  margin-top: 0;
  padding-top: 0;
}

.hero-content{
  padding-top: 18px; /* çok yakın olsun */
}















/* HEADER - HERO BOŞLUK FIX */
.site-main{
  padding-top: 0 !important;
}

/* masaüstü için override */
@media (min-width: 992px){
  .site-main{
    padding-top: 0 !important;
  }
}

/* ekstra garanti */
.site-header{
  margin-bottom: 0 !important;
}

.hero-banner{
  margin-top: 0 !important;
}














/* HEADER FULL GENİŞLİK FIX */
.header-shell{
  width: 100% !important;
  max-width: 100% !important;
  border-radius: 0 !important;
}

/* container sınırını kaldır */
.site-header .container{
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
}

/* header iç padding dengesi */
.header-shell{
  padding-left: 16px !important;
  padding-right: 16px !important;
}
















/* MASAÜSTÜ → 3 KART YAN YANA */
@media (min-width: 992px){
  .service-grid{
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
  }
}

/* TABLET → 2 KART */
@media (min-width: 768px) and (max-width: 991px){
  .service-grid{
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* MOBİL → ALT ALTA */
@media (max-width: 767px){
  .service-grid{
    grid-template-columns: 1fr !important;
  }
}


/* MOBİLDE KARTLARI GENİŞLET */
@media (max-width: 768px){

  .container{
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .service-grid{
    gap: 16px !important;
  }

  .service-card{
    width: 100%;
  }

}







/* MOBİL SABİT BAR FULL GENİŞLİK */
.mobile-sticky-bar{
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
}

/* iç kutuyu tam geniş yap */
.mobile-sticky-inner{
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  border-radius: 0 !important; /* ovali kaldır */
  border: none !important; /* turuncu border kaldır */
  padding: 0 !important;
  gap: 0 !important;
}

/* butonları tam böl */
.mobile-sticky-btn{
  border-radius: 0 !important;
  height: 60px;
  font-size: 16px;
}

/* ikiye bölünmüş görünüm */
.mobile-call{
  background: #dc2626 !important; /* kırmızı */
}
.mobile-wa{
  background: #25d366 !important;
}

/* ortadaki çizgi */
.mobile-call{
  border-right: 2px solid rgba(255,255,255,0.2);
}















.footer-simple-links a{
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.85);
  text-decoration: none;
}

.footer-simple-links a i{
  width: 18px;
  min-width: 18px;
  text-align: center;
  color: #f2ad0f;
  font-size: 15px;
}

.footer-simple-links a span{
  display: inline-block;
}










.district-board-section{
  padding: 60px 0;
}

.district-board{
  background: linear-gradient(180deg, #f8f8f8 0%, #eceff1 100%);
  border: 4px solid #f97316;
  border-radius: 28px;
  box-shadow:
    0 8px 0 #d65f0e,
    0 18px 35px rgba(0,0,0,0.10);
  padding: 34px 30px;
  position: relative;
  overflow: hidden;
}

.district-board::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(249,115,22,0.08), rgba(249,115,22,0));
  pointer-events: none;
}

.district-board-head{
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 860px;
  margin: 0 auto 28px;
}

.district-board-badge{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(249,115,22,0.22);
  color: #102e58;
  font-size: 15px;
  font-weight: 800;
  margin-bottom: 16px;
}

.district-board-badge i{
  color: #f97316;
}

.district-board-head h2{
  margin: 0 0 12px;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.15;
  font-weight: 800;
  color: #102e58;
}

.district-board-head p{
  margin: 0;
  font-size: 17px;
  line-height: 1.75;
  color: #4b5563;
}

.district-board-grid{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.district-board-item{
  min-height: 64px;
  padding: 0 18px;
  border-radius: 18px;
  background: rgba(255,255,255,0.96);
  border: 1px solid #d9e0e8;
  box-shadow: 0 10px 22px rgba(16,46,88,0.08);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #102e58;
  font-size: 17px;
  font-weight: 800;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.district-board-item i{
  color: #f97316;
  font-size: 18px;
  animation: pinPulse 1.8s infinite ease-in-out;
  transform-origin: center;
}

.district-board-item:hover{
  transform: translateY(-4px);
  border-color: rgba(249,115,22,0.55);
  box-shadow: 0 14px 28px rgba(16,46,88,0.12);
}

@keyframes pinPulse{
  0%, 100%{
    transform: scale(1);
    filter: drop-shadow(0 0 0 rgba(249,115,22,0));
  }
  50%{
    transform: scale(1.18);
    filter: drop-shadow(0 0 10px rgba(249,115,22,0.55));
  }
}

@media (max-width: 1199px){
  .district-board-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px){
  .district-board{
    padding: 28px 22px;
  }

  .district-board-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px){
  .district-board-section{
    padding: 42px 0;
  }

  .district-board{
    border-width: 3px;
    border-radius: 20px;
    padding: 22px 16px;
    box-shadow:
      0 6px 0 #d65f0e,
      0 14px 24px rgba(0,0,0,0.10);
  }

  .district-board-head{
    margin-bottom: 20px;
  }

  .district-board-badge{
    min-height: 38px;
    padding: 0 14px;
    font-size: 13px;
    margin-bottom: 12px;
  }

  .district-board-head h2{
    font-size: 30px;
  }

  .district-board-head p{
    font-size: 15px;
    line-height: 1.65;
  }

  .district-board-grid{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .district-board-item{
    min-height: 56px;
    padding: 0 14px;
    font-size: 15px;
    border-radius: 14px;
  }

  .district-board-item i{
    font-size: 16px;
  }
}















.mobile-sticky-btn{
  height: 46px !important;
  font-size: 13.5px !important;
  gap: 6px !important;
}

.mobile-sticky-btn i{
  font-size: 14px !important;
}































/* HEADER HERO'NUN ÜSTÜNE BİNSİN */
.site-header{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: transparent !important;
  margin-bottom: 0 !important;
}

/* BEYAZ KUTUYU KALDIR */
.header-shell{
  width: 100% !important;
  max-width: 100% !important;
  min-height: var(--header-h);
  margin: 0 !important;
  padding: 18px 16px !important;
  border-radius: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
  border: none !important;
  box-shadow: none !important;
}

/* HEADER İÇ CONTAINER TAM UYSUN */
.site-header .container{
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 16px !important;
}

/* HERO HEADER'I DA İÇİNE ALSIN */
.site-main{
  padding-top: 0 !important;
}

.hero-banner{
  position: relative;
  min-height: 620px;
  margin-top: 0 !important;
  padding-top: calc(var(--header-h) + 30px);
  display: flex;
  align-items: center;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(8,33,62,0.88) 0%, rgba(8,33,62,0.70) 38%, rgba(20,20,20,0.35) 70%, rgba(249,115,22,0.18) 100%),
    url("../img/hero.webp") center center / cover no-repeat;
}

/* HERO İÇERİĞİ HEADER'A YAPIŞMASIN */
.hero-content{
  max-width: 760px;
  padding: 70px 0 80px;
  color: #fff;
}

/* MOBİL */
@media (max-width: 768px){
  .header-shell{
    padding: 14px 12px !important;
  }

  .hero-banner{
    min-height: 520px;
    padding-top: calc(var(--header-h) + 20px);
  }

  .hero-content{
    padding: 40px 0 54px;
  }
}










@media (min-width: 992px){
  .btn-call{
    display: none !important;
  }
}















@media (max-width: 768px){
  .brand-wrap{
    position: relative !important;
    top: 0 !important;
    align-self: center !important;
  }

  .brand-logo{
    width: 280px !important;
    max-width: none !important;
    opacity: 1 !important;
    position: relative !important;
    top: -16px !important; /* 🔥 BURAYI ARTIRDIM */
  }

  .menu-toggle{
    margin-top: 0 !important;
  }
}







@media (max-width: 768px){

  .header-shell{
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .brand-wrap{
    display: flex;
    align-items: center;
  }

  .brand-logo{
    width: 200px !important;
    position: relative !important;
    top: 0 !important; /* ❌ -16px kaldır */
  }

  .menu-toggle{
    position: relative;
    top: 0;
  }

}



@media (max-width: 768px){

  .menu-toggle{
    position: relative;
    top: -10px; /* 🔥 yukarı al */
  }

}





@media (max-width: 768px){

  .header-shell{
    align-items: flex-start !important;
    padding-top: 6px !important;
  }

  .brand-wrap{
    position: relative !important;
    top: -10px !important;
  }

  .brand-logo{
    width: 320px !important;
    max-width: none !important;
    height: auto !important;
    position: relative !important;
    top: -10px !important;
  }

  .menu-toggle{
    position: relative !important;
    top: -10px !important;
  }

}


@media (max-width: 768px){

  .brand-logo{
    width: 320px !important;
    max-width: none !important;
    position: relative !important;
    top: -6px !important; /* 🔥 az yukarı */
  }

  .menu-toggle{
    position: relative !important;
    top: 1px !important; /* 🔥 biraz aşağı aldık */
  }

}


@media (max-width: 768px){

  .brand-wrap{
    transform: translateY(-52px) !important; /* 🔥 logoyu komple yukarı taşır */
  }

}













@media (max-width: 768px){

  .brand-wrap{
    transform: translate(-20px, -60px) !important; /* 🔥 sola + yukarı */
  }

}










@media (max-width: 768px){

  /* header iç boşlukları sıfırla */
  .header-shell{
    padding-left: 0 !important;
  }

  /* container da itmesin */
  .site-header .container{
    padding-left: 0 !important;
  }

  /* logo tamamen sola yaslansın */
  .brand-wrap{
    margin-left: -10px !important; /* 🔥 sola çek */
  }

}








