/* DS Live Scan Services - Main Stylesheet v6.0 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:&amp;#039;Inter&amp;#039;,sans-serif;color:#1a1a2e;background:#fff;line-height:1.6}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.btn-primary{display:inline-block;background:#2563eb;color:#fff;padding:.85rem 2rem;border-radius:50px;font-weight:600;font-size:1rem;transition:background .2s,transform .1s;cursor:pointer}
.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px)}
.btn-ghost{display:inline-block;background:transparent;color:#fff;padding:.85rem 2rem;border-radius:50px;font-weight:600;font-size:1rem;border:2px solid rgba(255,255,255,.5);transition:border-color .2s,background .2s;cursor:pointer}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.sec-hdr{text-align:center;margin-bottom:1.5rem}
.sec-hdr h2{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:2.2rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}
.sec-hdr p{color:#64748b;font-size:1.1rem}
.site-header{position:sticky;top:0;z-index:100;background:#0f172a;box-shadow:0 2px 20px rgba(0,0,0,.3)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;max-width:1200px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.85rem;text-decoration:none}
.logo svg{width:52px;height:52px;color:#f59e0b;flex-shrink:0}
.logo-txt{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1.4rem;font-weight:700;color:#fff;white-space:nowrap}
.logo-ds{color:#f59e0b}
.hdr-phone{display:flex;align-items:center;gap:.5rem;background:#2563eb;color:#fff;padding:.65rem 1.5rem;border-radius:50px;font-weight:600;font-size:.95rem;text-decoration:none;transition:background .2s;white-space:nowrap}
.hdr-phone:hover{background:#1d4ed8}
.hdr-phone svg{flex-shrink:0}
.hero{position:relative;min-height:70vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);z-index:0}
.hero-bg::after{content:&amp;#039;&amp;#039;;position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(37,99,235,.3),transparent 70%)}
.hero-inner{position:relative;z-index:1;max-width:700px;margin:0 auto;padding:3rem 1.5rem}
.hero-badge{display:inline-block;background:rgba(37,99,235,.2);border:1px solid rgba(37,99,235,.4);color:#93c5fd;font-size:.8rem;font-weight:600;letter-spacing:.1em;padding:.4rem 1.2rem;border-radius:50px;margin-bottom:1.5rem;text-transform:uppercase}
.hero-h1{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:clamp(2.8rem,6vw,4.5rem);font-weight:800;line-height:1.1;color:#fff;margin-bottom:1.5rem}
.hero-h1 em{color:#f59e0b;font-style:normal}
.hero-p{color:#94a3b8;font-size:1.15rem;max-width:520px;margin-bottom:2.5rem;line-height:1.7}
.hero-btns{display:flex;flex-wrap:wrap;gap:1rem}
.svc-sec{padding:3rem 0;background:#f8fafc}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.svc-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 15px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.12)}
.svc-ico{width:56px;height:56px;background:#eff6ff;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;color:#2563eb}
.svc-card h3{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.6rem}
.svc-card p{color:#64748b;font-size:.9rem;line-height:1.6}
.res-sec{padding:3rem 0;background:#fff}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.res-card{display:flex;flex-direction:column;background:#f8fafc;border:2px solid #e2e8f0;border-radius:16px;padding:2rem;transition:border-color .2s,transform .2s,box-shadow .2s;color:#1a1a2e}
.res-card:hover{border-color:#2563eb;transform:translateY(-4px);box-shadow:0 8px 30px rgba(37,99,235,.15)}
.res-ico{width:56px;height:56px;background:#eff6ff;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;color:#2563eb}
.res-card h3{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1.05rem;font-weight:700;color:#0f172a;margin-bottom:.6rem}
.res-card p{color:#64748b;font-size:.9rem;line-height:1.6;flex:1}
.res-link{display:inline-block;margin-top:1.2rem;color:#2563eb;font-weight:600;font-size:.9rem}
.loc-sec{padding:3rem 0;background:#f8fafc}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;margin-bottom:2rem}
.loc-box,.price-box{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 2px 15px rgba(0,0,0,.06)}
.loc-box-h{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1.4rem;font-weight:700;color:#0f172a;margin-bottom:1.5rem}
address{font-style:normal}
.loc-item{display:flex;align-items:flex-start;gap:.85rem;padding:.85rem 0;border-bottom:1px solid #f1f5f9;color:#334155}
.loc-item:last-child{border-bottom:none}
.loc-item svg{flex-shrink:0;margin-top:.2rem;color:#2563eb;stroke:#2563eb}
.loc-item a{color:#2563eb;font-weight:500}
.loc-item a:hover{text-decoration:underline}
.price-item{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0;border-bottom:1px solid #f1f5f9}
.price-item:last-of-type{border-bottom:none}
.price-label{color:#475569;font-size:.95rem}
.price-val{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1.4rem;font-weight:700;color:#0f172a}
.price-note{margin-top:1.2rem;color:#64748b;font-size:.85rem;line-height:1.6;background:#f8fafc;border-radius:8px;padding:1rem}
.map-wrap{border-radius:16px;overflow:hidden;box-shadow:0 2px 20px rgba(0,0,0,.1)}
.map-wrap iframe{display:block;width:100%;height:420px;border:none}
.why-sec{padding:3rem 0;background:#0f172a}
.why-sec .sec-hdr h2{color:#fff}
.why-sec .sec-hdr p{color:#94a3b8}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.why-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2rem;transition:background .2s,border-color .2s}
.why-card:hover{background:rgba(37,99,235,.15);border-color:rgba(37,99,235,.4)}
.why-num{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:2.5rem;font-weight:800;color:rgba(37,99,235,.4);margin-bottom:.5rem;line-height:1}
.why-card h3{font-family:&amp;#039;Montserrat&amp;#039;,sans-serif;font-size:1rem;font-weight:700;color:#fff;margin-bottom:.6rem}
.why-card p{color:#94a3b8;font-size:.9rem;line-height:1.6}
.site-footer{background:#0a0f1e;color:#64748b;padding:2rem 1.5rem;text-align:center;font-size:.875rem}
.site-footer a{color:#94a3b8}
.footer-inner{max-width:1200px;margin:0 auto}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr}.res-grid{grid-template-columns:1fr 1fr}.why-grid{grid-template-columns:1fr 1fr}.loc-grid{grid-template-columns:1fr}.hero-inner{padding:2rem 1.5rem}}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr}.res-grid{grid-template-columns:1fr}.why-grid{grid-template-columns:1fr}.sec-hdr h2{font-size:1.8rem}.hero-h1{font-size:2.5rem}.hero-btns{flex-direction:column}.hero-btns .btn-primary,.hero-btns .btn-ghost{text-align:center}.map-wrap iframe{height:300px}}

/* ============================================================
   NAVIGATION MENU
   ============================================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #0a1628;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  max-width: 1200px;
  margin: 0 auto;
  height: 70px;
  gap: 20px;
}

.site-nav ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 4px;
}

.site-nav ul li a {
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  padding: 8px 12px;
  border-radius: 6px;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}

.site-nav ul li a:hover,
.site-nav ul li a:focus {
  background: rgba(255,255,255,0.1);
  color: #f5a623;
}

.header-phone {
  color: #fff;
  background: #1a6af5;
  border-radius: 50px;
  padding: 10px 20px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.2s;
  flex-shrink: 0;
}

.header-phone:hover {
  background: #1558d4;
  color: #fff;
}

.nav-toggle {
  display: none;
  background: none;
  border: none;
  color: #fff;
  font-size: 24px;
  cursor: pointer;
  padding: 8px;
  line-height: 1;
}

/* Mobile nav */
@media (max-width: 768px) {
  .nav-toggle {
    display: block;
  }
  .site-nav {
    display: none;
    position: absolute;
    top: 70px;
    left: 0;
    right: 0;
    background: #0a1628;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    z-index: 999;
  }
  .site-nav.nav-open {
    display: block;
  }
  .site-nav ul {
    flex-direction: column;
    padding: 12px 16px;
    gap: 0;
  }
  .site-nav ul li a {
    display: block;
    padding: 12px 16px;
    font-size: 15px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .header-phone {
    display: none;
  }
}

/* Site logo */
.site-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  flex-shrink: 0;
}
.site-logo svg {
  color: #f5a623;
  flex-shrink: 0;
}
.site-logo-text {
  font-family: \'Montserrat\', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}
.site-logo-text strong {
  color: #f5a623;
}



/* ===== Inner Page Layout ===== */
.inner-page-wrap{display:flex;min-height:calc(100vh - 140px);max-width:1200px;margin:0 auto;padding:0 1.5rem}
.inner-page-accent{width:48px;flex-shrink:0;position:relative;margin-right:2.5rem;padding-top:60px}
.inner-page-accent::before{content:"";position:absolute;left:50%;transform:translateX(-50%);top:0;bottom:0;width:4px;background:linear-gradient(to bottom,transparent 0%,#0a1628 10%,#0a1628 90%,transparent 100%);border-radius:4px;opacity:0.5}
.accent-dot{display:block;width:7px;height:7px;border-radius:50%;background:#0a1628;opacity:0.45;margin:0 auto}
.accent-dots{position:absolute;left:50%;transform:translateX(-50%);top:100px;display:flex;flex-direction:column;align-items:center;gap:22px}
.inner-page-content{flex:1;padding:60px 0 80px;min-width:0}
.inner-page-content h1{font-size:2rem;font-weight:700;color:#1a1a2e;margin-bottom:1.25rem;line-height:1.2}
.inner-page-content h2{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin-top:1.75rem;margin-bottom:.6rem}
.inner-page-content h3{font-size:1.1rem;font-weight:600;color:#1a1a2e;margin-top:1.25rem;margin-bottom:.5rem}
.inner-page-content p{margin-bottom:1rem;color:#374151;line-height:1.75}
.inner-page-content ul,.inner-page-content ol{margin:.5rem 0 1rem 1.5rem;color:#374151;line-height:1.8}
.inner-page-content strong{color:#1a1a2e}
.inner-page-content a{color:#2563eb;text-decoration:underline}
.inner-page-content table{width:100%;border-collapse:collapse;margin:1rem 0}
.inner-page-content th{background:#f1f5f9;padding:.65rem 1rem;text-align:left;font-weight:600;color:#1a1a2e;border-bottom:2px solid #e2e8f0}
.inner-page-content td{padding:.65rem 1rem;border-bottom:1px solid #e2e8f0;color:#374151}
@media(max-width:768px){.inner-page-accent{display:none}.inner-page-content{padding:40px 0 60px}}
.footer-nav{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem;flex-wrap:wrap}
.footer-nav a{color:#94a3b8;font-size:.875rem;transition:color .2s}
.footer-nav a:hover{color:#fff}
.footer-copy{color:#64748b;font-size:.8rem}
/* ===== Footer Separator ===== */
.footer-sep{color:#475569;margin:0 .25rem}

/* ===== Map Full Width ===== */
.map-full{grid-column:1 / -1}

/* ===== FAQ Accordion ===== */
.ds-faq-wrap{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.ds-accordion-item{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:box-shadow .2s}
.ds-accordion-item:hover{box-shadow:0 3px 12px rgba(10,22,40,.1)}
.ds-accordion-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.4rem;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit}
.ds-accordion-btn[aria-expanded="true"]{background:#f8fafc;border-bottom:1px solid #e2e8f0}
.ds-accordion-q{font-weight:600;font-size:1rem;color:#0f172a;line-height:1.4}
.ds-accordion-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:2px solid #0a1628;color:#0a1628;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .2s,color .2s}
.ds-accordion-btn[aria-expanded="true"] .ds-accordion-icon{background:#0a1628;color:#fff}
.ds-accordion-body{padding:1rem 1.4rem 1.2rem}
.ds-accordion-ans{color:#374151;line-height:1.75;margin:0}

/* ===== Service Boxes ===== */
.ds-services-wrap{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.ds-service-box{border:1px solid #e2e8f0;border-left:4px solid #0a1628;border-radius:0 10px 10px 0;background:#fff;padding:1.1rem 1.4rem;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.ds-service-title{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.4rem}
.ds-service-desc{color:#374151;line-height:1.75;margin:0;font-size:.95rem}
/* ===== Contact Page Layout ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;margin-top:1.5rem}
.contact-info-col{display:flex;flex-direction:column;gap:.75rem}
.contact-form-col{}
.ds-contact-form-box{border:1px solid #e2e8f0;border-left:4px solid #0a1628;border-radius:0 10px 10px 0;background:#fff;padding:1.75rem;box-shadow:0 1px 8px rgba(0,0,0,.06)}
.ds-contact-form{display:flex;flex-direction:column;gap:1rem}
.ds-field{display:flex;flex-direction:column;gap:.35rem}
.ds-field label{font-size:.875rem;font-weight:600;color:#0f172a}
.req{color:#dc2626}
.ds-field input,.ds-field textarea{padding:.7rem .9rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-family:inherit;color:#1a1a2e;transition:border-color .2s;width:100%}
.ds-field input:focus,.ds-field textarea:focus{outline:none;border-color:#0a1628;box-shadow:0 0 0 3px rgba(10,22,40,.08)}
.ds-field textarea{resize:vertical;min-height:110px}
.ds-captcha-field input{max-width:120px!important}
.ds-submit-btn{align-self:flex-start;background:#0a1628;color:#fff;border:none;padding:.85rem 2rem;border-radius:50px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s}
.ds-submit-btn:hover{background:#1e3a5f}
.ds-form-msg{padding:.75rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500}
.ds-form-ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.ds-form-err{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
@media(max-width:768px){.contact-layout{grid-template-columns:1fr}}

/* ===== About Office Photo ===== */
.about-office-photo{margin-top:1rem;margin-bottom:1rem}

/* ===== Contact Form 7 Styling ===== */
.ds-contact-form-box .wpcf7 {
  width: 100%;
}
.ds-contact-form-box .wpcf7 label {
  display: block;
  font-weight: 600;
  color: #1e293b;
  margin-bottom: 4px;
  font-size: 0.9rem;
}
.ds-contact-form-box .wpcf7 input[type="text"],
.ds-contact-form-box .wpcf7 input[type="email"],
.ds-contact-form-box .wpcf7 input[type="tel"],
.ds-contact-form-box .wpcf7 textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 0.95rem;
  font-family: inherit;
  color: #1e293b;
  background: #fff;
  box-sizing: border-box;
  margin-top: 2px;
  transition: border-color 0.2s;
}
.ds-contact-form-box .wpcf7 input[type="text"]:focus,
.ds-contact-form-box .wpcf7 input[type="email"]:focus,
.ds-contact-form-box .wpcf7 input[type="tel"]:focus,
.ds-contact-form-box .wpcf7 textarea:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}
.ds-contact-form-box .wpcf7 textarea {
  min-height: 130px;
  resize: vertical;
}
.ds-contact-form-box .wpcf7 .wpcf7-submit {
  background: #0a1628;
  color: #fff;
  border: none;
  padding: 12px 28px;
  border-radius: 30px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 6px;
  transition: background 0.2s, transform 0.1s;
  letter-spacing: 0.5px;
}
.ds-contact-form-box .wpcf7 .wpcf7-submit:hover {
  background: #2563eb;
  transform: translateY(-1px);
}
.ds-contact-form-box .wpcf7 .wpcf7-not-valid-tip {
  color: #e53e3e;
  font-size: 0.82rem;
  margin-top: 3px;
  display: block;
}
.ds-contact-form-box .wpcf7 .wpcf7-response-output {
  margin-top: 14px;
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 500;
}
.ds-contact-form-box .wpcf7 .wpcf7-mail-sent-ok {
  background: #f0fdf4;
  border: 1px solid #86efac;
  color: #166534;
}
.ds-contact-form-box .wpcf7 .wpcf7-mail-sent-ng,
.ds-contact-form-box .wpcf7 .wpcf7-validation-errors,
.ds-contact-form-box .wpcf7 .wpcf7-spam-blocked {
  background: #fff1f2;
  border: 1px solid #fca5a5;
  color: #991b1b;
}
.ds-contact-form-box .wpcf7 br {
  display: none;
}