/*════════════════════════════════════════════════════════════════════════
   FixGrid — Public Site Stylesheet (style.css)
   Mobile-first. Trustworthy/corporate visual style.
════════════════════════════════════════════════════════════════════════*/

:root{
  --blue:#0B3C5D;
  --blue-d:#082B43;
  --blue-l:#1565C0;
  --orange:#FF6F00;
  --orange-d:#E65A00;
  --bg:#FFFFFF;
  --bg-tint:#F7F9FC;
  --text:#0F1B2D;
  --text-2:#445569;
  --muted:#6B7B91;
  --line:#E1E7EF;
  --line-soft:#EEF2F7;
  --success:#16A34A;
  --warn:#F59E0B;
  --danger:#EF4444;
  --r:12px; --r-lg:18px; --r-xl:24px;
  --sh-1:0 2px 8px rgba(15,27,45,.06);
  --sh-2:0 8px 24px rgba(15,27,45,.08);
  --sh-3:0 16px 48px rgba(15,27,45,.10);
  --container:1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'Inter','Segoe UI',sans-serif;
  font-size:16px;line-height:1.6;
  color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none;transition:color .15s}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--text)}

.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.container-narrow{max-width:760px}
.text-center{text-align:center}

.tag{
  display:inline-block;
  background:rgba(11,60,93,.08);color:var(--blue);
  padding:6px 14px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;margin-bottom:14px;
}

/*════════════════════════════════════════════════════════════════════════
   NAV
════════════════════════════════════════════════════════════════════════*/
.topnav{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
  transition:box-shadow .2s;
}
.topnav.scrolled{box-shadow:var(--sh-1)}
.nav-wrap{display:flex;align-items:center;gap:24px;padding:14px 20px}
.nav-logo{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.nav-logo img{width:34px;height:34px;object-fit:contain}
.nav-brand{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:21px;color:var(--blue);letter-spacing:-.02em}
.nav-brand span{color:var(--orange)}
.nav-links{flex:1;display:flex;justify-content:center;gap:24px}
.nav-links a{font-weight:500;font-size:14px;color:var(--text-2);padding:6px 2px;border-bottom:2px solid transparent;transition:all .15s}
.nav-links a:hover{color:var(--blue)}
.nav-links a.active{color:var(--blue);border-bottom-color:var(--orange)}
.nav-cta{
  background:var(--orange);color:#fff;font-weight:600;
  padding:10px 18px;border-radius:var(--r);font-size:14px;
  transition:all .2s;box-shadow:0 4px 12px rgba(255,111,0,.25);
  flex:0 0 auto;
}
.nav-cta:hover{background:var(--orange-d);color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px rgba(255,111,0,.35)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);transition:.3s;border-radius:1px}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mob-backdrop{position:fixed;inset:0;background:rgba(15,27,45,.4);opacity:0;pointer-events:none;transition:opacity .3s;z-index:90}
.mob-backdrop.active{opacity:1;pointer-events:auto}
.mob-nav{
  position:fixed;top:0;right:-100%;width:280px;height:100vh;
  background:#fff;z-index:95;padding:80px 20px 32px;
  display:flex;flex-direction:column;gap:4px;
  transition:right .3s;box-shadow:-8px 0 24px rgba(0,0,0,.12);
}
.mob-nav.active{right:0}
.mob-nav a{padding:14px 16px;border-radius:var(--r);font-weight:500;color:var(--text);font-size:16px}
.mob-nav a:hover{background:var(--bg-tint)}
.mob-cta{background:var(--orange);color:#fff !important;text-align:center;margin-top:12px;font-weight:600}

/*════════════════════════════════════════════════════════════════════════
   BUTTONS
════════════════════════════════════════════════════════════════════════*/
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--orange);color:#fff !important;
  padding:14px 26px;border-radius:var(--r);
  font-weight:600;font-size:15px;
  box-shadow:0 8px 20px rgba(255,111,0,.3);
  transition:all .2s;
}
.btn-primary:hover{background:var(--orange-d);transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,111,0,.4)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--blue);
  padding:14px 24px;border-radius:var(--r);
  font-weight:600;font-size:15px;
  border:1.5px solid var(--line);
  transition:all .2s;
}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn-wa{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;color:#fff !important;
  padding:14px 26px;border-radius:var(--r);
  font-weight:600;font-size:15px;
  box-shadow:0 8px 20px rgba(37,211,102,.3);
  transition:all .2s;
}
.btn-wa:hover{background:#1DA851;transform:translateY(-2px)}

/*════════════════════════════════════════════════════════════════════════
   SECTIONS
════════════════════════════════════════════════════════════════════════*/
.section{padding:64px 0}
.section-tinted{background:var(--bg-tint)}
.section-head{margin-bottom:36px;max-width:680px}
.section-head.text-center{margin-left:auto;margin-right:auto}
.section-title{font-size:clamp(26px,4vw,38px);margin-bottom:10px}
.section-sub{font-size:16px;color:var(--text-2);line-height:1.65}

/*════════════════════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════════════════════*/
.hero{
  background:
    radial-gradient(circle at 90% 0%,rgba(255,111,0,.06) 0%,transparent 45%),
    radial-gradient(circle at 0% 100%,rgba(11,60,93,.06) 0%,transparent 50%),
    var(--bg-tint);
  padding:56px 0 72px;
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);
  padding:7px 14px;border-radius:30px;
  font-size:12px;font-weight:600;color:var(--text-2);
  margin-bottom:18px;box-shadow:var(--sh-1);
}
.hero-pulse{width:8px;height:8px;border-radius:50%;background:var(--success);position:relative}
.hero-pulse::after{content:"";position:absolute;inset:-4px;border-radius:50%;background:var(--success);opacity:.3;animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.3}100%{transform:scale(2.2);opacity:0}}
.hero-title{font-size:clamp(30px,5.5vw,52px);margin-bottom:18px;line-height:1.1}
.hero-title-2{display:block;color:var(--blue)}
.hero-title-3{display:block;color:var(--orange);font-style:italic;font-weight:700}
.hero-sub{font-size:16px;color:var(--text-2);margin-bottom:24px;max-width:540px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-image img{max-width:340px;margin:0 auto;display:block;filter:drop-shadow(0 24px 48px rgba(11,60,93,.18))}

/*════════════════════════════════════════════════════════════════════════
   TRUST STRIP
════════════════════════════════════════════════════════════════════════*/
.trust-strip{padding:24px 0;background:var(--blue);color:#fff}
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.trust-item{text-align:center}
.trust-num{font-family:'Plus Jakarta Sans',sans-serif;font-size:24px;font-weight:800;color:var(--orange);line-height:1}
.trust-label{font-size:11px;color:rgba(255,255,255,.7);font-weight:500;margin-top:4px;letter-spacing:.04em;text-transform:uppercase}

/*════════════════════════════════════════════════════════════════════════
   PAGE HEADER (sub-pages)
════════════════════════════════════════════════════════════════════════*/
.page-header{
  background:
    radial-gradient(circle at 0% 0%,rgba(11,60,93,.06),transparent 50%),
    var(--bg-tint);
  padding:64px 0 48px;
  text-align:center;
}
.ph-title{font-size:clamp(28px,5vw,44px);margin-bottom:14px}
.ph-sub{font-size:17px;color:var(--text-2);max-width:640px;margin:0 auto;line-height:1.6}

/*════════════════════════════════════════════════════════════════════════
   RICH TEXT
════════════════════════════════════════════════════════════════════════*/
.rich-heading{font-size:24px;margin-bottom:18px}
.rich-body p{font-size:16px;color:var(--text-2);line-height:1.75;margin-bottom:16px}
.rich-body p:last-child{margin-bottom:0}

/*════════════════════════════════════════════════════════════════════════
   SERVICES GRID
════════════════════════════════════════════════════════════════════════*/
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.service-card{
  display:flex;align-items:center;gap:14px;
  background:#fff;padding:18px;
  border-radius:var(--r-lg);
  border:1px solid var(--line);
  transition:all .2s;
}
.service-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--sh-2)}
.service-icon{
  width:48px;height:48px;flex:0 0 48px;
  border-radius:14px;
  background:linear-gradient(135deg,rgba(11,60,93,.06),rgba(255,111,0,.06));
  display:flex;align-items:center;justify-content:center;font-size:24px;
}
.service-info{flex:1;min-width:0}
.service-name{font-weight:600;font-size:14px;line-height:1.3}
.service-price{font-size:12px;color:var(--orange);font-weight:600;margin-top:2px}

/*════════════════════════════════════════════════════════════════════════
   HOW IT WORKS
════════════════════════════════════════════════════════════════════════*/
.how-grid{display:grid;grid-template-columns:1fr;gap:18px}
.how-step{
  position:relative;text-align:center;
  padding:28px 18px;background:#fff;
  border-radius:var(--r-lg);
  border:1px solid var(--line-soft);
}
.how-num{
  width:48px;height:48px;
  background:linear-gradient(135deg,var(--blue),var(--blue-l));
  color:#fff;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:20px;font-weight:800;
  margin-bottom:14px;box-shadow:0 8px 20px rgba(11,60,93,.18);
}
.how-title{font-size:17px;margin-bottom:6px}
.how-desc{font-size:14px;color:var(--text-2);line-height:1.6}

/*════════════════════════════════════════════════════════════════════════
   FEATURE COLUMNS / WHY US
════════════════════════════════════════════════════════════════════════*/
.features-grid{display:grid;grid-template-columns:1fr;gap:18px}
.feature-card{
  padding:24px 20px;background:#fff;
  border-radius:var(--r-lg);
  border:1px solid var(--line-soft);
  transition:all .2s;
}
.feature-card:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.feature-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,var(--blue),var(--blue-l));
  display:flex;align-items:center;justify-content:center;font-size:22px;
  margin-bottom:14px;color:#fff;box-shadow:0 8px 16px rgba(11,60,93,.15);
}
.feature-title{font-size:17px;margin-bottom:6px}
.feature-desc{font-size:14px;color:var(--text-2);line-height:1.6}

/*════════════════════════════════════════════════════════════════════════
   PRICING TABLE
════════════════════════════════════════════════════════════════════════*/
.pricing-table{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;
}
.pricing-row{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;
}
.pricing-row + .pricing-row{border-top:1px solid var(--line-soft)}
.pricing-row-text{flex:1;min-width:0}
.pricing-item{font-weight:700;font-size:15px}
.pricing-desc{font-size:13px;color:var(--text-2);margin-top:2px;line-height:1.5}
.pricing-price{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;color:var(--orange);font-size:17px;flex:0 0 auto;text-align:right}

/*════════════════════════════════════════════════════════════════════════
   ZONES
════════════════════════════════════════════════════════════════════════*/
.zones-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.zone-card{
  display:flex;align-items:center;gap:10px;
  background:#fff;padding:12px 16px;
  border-radius:var(--r);border:1px solid var(--line-soft);
}
.zone-dot{width:10px;height:10px;border-radius:50%;flex:0 0 10px;position:relative}
.zone-dot::after{content:"";position:absolute;inset:-3px;border-radius:50%;opacity:.3;animation:pulse 2.4s infinite}
.zone-dot-green{background:var(--success)}.zone-dot-green::after{background:var(--success)}
.zone-dot-yellow{background:var(--warn)}.zone-dot-yellow::after{background:var(--warn)}
.zone-dot-red{background:var(--danger)}.zone-dot-red::after{background:var(--danger)}
.zone-dot-blue{background:var(--blue)}.zone-dot-blue::after{background:var(--blue)}
.zone-dot-gray{background:#9CA8B8;animation:none}.zone-dot-gray::after{display:none}
.zone-text{flex:1;min-width:0}
.zone-name{font-weight:600;font-size:13px}
.zone-city{font-size:11px;color:var(--muted);margin-top:1px}

/*════════════════════════════════════════════════════════════════════════
   CTA BANNER
════════════════════════════════════════════════════════════════════════*/
.cta-banner{
  padding:64px 0;
  background:
    radial-gradient(circle at 0% 0%,rgba(255,111,0,.08),transparent 50%),
    radial-gradient(circle at 100% 100%,rgba(11,60,93,.08),transparent 50%),
    var(--bg-tint);
}
.cta-title{font-size:clamp(24px,4vw,34px);margin-bottom:10px}
.cta-sub{font-size:16px;color:var(--text-2);margin-bottom:26px;max-width:540px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/*════════════════════════════════════════════════════════════════════════
   BLOG
════════════════════════════════════════════════════════════════════════*/
.blog-list{display:grid;grid-template-columns:1fr;gap:24px}
.blog-card{
  background:#fff;border:1px solid var(--line-soft);
  border-radius:var(--r-lg);overflow:hidden;
  transition:all .2s;
}
.blog-card:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.blog-image{aspect-ratio:16/9;overflow:hidden;background:var(--bg-tint)}
.blog-image img{width:100%;height:100%;object-fit:contain;padding:32px}
.blog-body{padding:20px}
.blog-date{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.blog-title{font-size:18px;margin-bottom:8px;line-height:1.35}
.blog-title a{color:var(--text);transition:color .15s}
.blog-title a:hover{color:var(--orange)}
.blog-excerpt{font-size:14px;color:var(--text-2);line-height:1.6}

/*════════════════════════════════════════════════════════════════════════
   CONTACT
════════════════════════════════════════════════════════════════════════*/
.contact-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.contact-tile{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:#fff;padding:20px 14px;
  border-radius:var(--r-lg);
  border:1px solid var(--line-soft);
  text-align:center;color:var(--text);
  transition:all .2s;
}
.contact-tile:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--sh-2);color:var(--text)}
.contact-tile-icon{font-size:24px}
.contact-tile-label{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-top:4px}
.contact-tile-value{font-size:13px;font-weight:600;color:var(--text);word-break:break-word}
.contact-address{
  text-align:center;font-size:14px;color:var(--text-2);
  padding:14px;background:#fff;border-radius:var(--r);
  border:1px solid var(--line-soft);
}

.contact-form{
  background:#fff;padding:28px 22px;border-radius:var(--r-lg);
  border:1px solid var(--line);box-shadow:var(--sh-1);
}
.form-row{display:grid;grid-template-columns:1fr;gap:14px}
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.form-field input,.form-field textarea{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--line);border-radius:var(--r);
  font-size:14px;color:var(--text);background:#fff;
  transition:all .15s;font-family:inherit;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(11,60,93,.1)}
.form-field textarea{resize:vertical;min-height:96px}
.form-submit{width:100%;margin-top:6px}
.form-msg{margin-top:14px;padding:12px;border-radius:var(--r);font-size:13px;font-weight:600;text-align:center;display:none}
.form-msg.show{display:block}
.form-msg.success{background:rgba(22,163,74,.1);color:var(--success);border:1px solid rgba(22,163,74,.25)}
.form-msg.error{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.25)}

/*════════════════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════════════════*/
.site-footer{background:#0F1B2D;color:#fff;padding:48px 0 0;margin-top:48px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:32px;padding-bottom:32px}
.foot-brand-text{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:24px;color:#fff;margin-bottom:10px;letter-spacing:-.02em}
.foot-brand-text span{color:var(--orange)}
.foot-about{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6;max-width:340px}
.foot-col h4{font-size:14px;color:#fff;margin-bottom:14px;font-weight:600}
.foot-col a{display:block;font-size:13px;color:rgba(255,255,255,.6);padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--orange)}
.foot-bottom{padding:20px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.5);text-align:center}

/*════════════════════════════════════════════════════════════════════════
   DESKTOP / TABLET
════════════════════════════════════════════════════════════════════════*/
@media (min-width:768px){
  .nav-wrap{padding:14px 24px}
  .container{padding:0 24px}
  .section{padding:80px 0}
  .hero{padding:72px 0 88px}
  .hero-grid{grid-template-columns:1.2fr 1fr;gap:48px}
  .trust-grid{grid-template-columns:repeat(4,1fr)}
  .services-grid{grid-template-columns:repeat(3,1fr);gap:16px}
  .how-grid{grid-template-columns:repeat(3,1fr);gap:24px}
  .features-grid{grid-template-columns:repeat(3,1fr)}
  .zones-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .blog-list{grid-template-columns:repeat(2,1fr);gap:28px}
  .contact-card-grid{grid-template-columns:repeat(4,1fr)}
  .form-row{grid-template-columns:1fr 1fr;gap:14px}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;padding:0 24px 32px}
}

@media (min-width:1024px){
  .blog-list{grid-template-columns:repeat(3,1fr)}
  .zones-grid{grid-template-columns:repeat(4,1fr)}
}

@media (max-width:767px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-cta{display:none}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions a{justify-content:center}
  .pricing-row{flex-direction:column;align-items:flex-start;gap:8px}
  .pricing-price{align-self:flex-end}
  .cta-buttons{flex-direction:column;align-items:stretch}
  .cta-buttons a{justify-content:center}
}
