*{
margin:0;
padding:0;
box-sizing:border-box;
}

:root{
--dark:#050b18;
--navy:#0f172a;
--text:#111827;
--muted:#4b5563;
--soft:#6b7280;
--line:#e5e7eb;
--bg:#f7f7f7;
--white:#ffffff;
--yellow:#facc15;
--yellow-dark:#eab308;
--shadow:0 12px 32px rgba(15,23,42,0.08);
--radius:22px;
}

html{
scroll-behavior:smooth;
}

body{
font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
background:var(--bg);
color:var(--text);
line-height:1.6;
}

img{
max-width:100%;
display:block;
}

a{
color:inherit;
}

.container{
width:min(1200px,92%);
margin:auto;
}

.topbar{
background:var(--dark);
color:#fff;
font-size:14px;
padding:10px 0;
}

.topbar-inner{
display:flex;
justify-content:center;
gap:42px;
flex-wrap:wrap;
}

.topbar a{
text-decoration:none;
font-weight:600;
}

.topbar a:hover{
text-decoration:underline;
}

.header{
background:#fff;
border-bottom:1px solid var(--line);
position:sticky;
top:0;
z-index:50;
}

.nav{
display:flex;
align-items:center;
justify-content:space-between;
gap:22px;
padding:16px 0;
}

.brand{
display:flex;
align-items:center;
}

.logo{
height:62px;
width:auto;
object-fit:contain;
}

.main-nav{
display:flex;
gap:24px;
align-items:center;
}

.main-nav a{
text-decoration:none;
font-weight:700;
color:var(--text);
position:relative;
font-size:15px;
}

.main-nav a.active::after,
.main-nav a:hover::after{
content:'';
position:absolute;
left:0;
bottom:-8px;
width:100%;
height:3px;
background:var(--yellow);
border-radius:999px;
}

.menu-toggle{
display:none;
border:1px solid var(--line);
background:#fff;
border-radius:999px;
padding:10px 16px;
font:inherit;
font-weight:800;
cursor:pointer;
}

.hero{
padding:64px 0;
background:#fff;
}

.hero-grid{
display:grid;
grid-template-columns:1.02fr 0.98fr;
gap:42px;
align-items:center;
}

.eyebrow,.section-tag{
color:var(--yellow-dark);
font-weight:900;
font-size:13px;
letter-spacing:0.04em;
margin-bottom:14px;
text-align:center;
}

.hero-left{
text-align:center;
}

h1{
font-size:clamp(44px,5vw,68px);
line-height:1.03;
margin-bottom:24px;
font-weight:900;
letter-spacing:-0.055em;
max-width:880px;
margin-left:auto;
margin-right:auto;
}

.lead{
font-size:21px;
color:var(--muted);
max-width:740px;
margin:0 auto 30px;
line-height:1.65;
}

.hero-buttons{
display:flex;
justify-content:center;
gap:16px;
margin-bottom:28px;
flex-wrap:wrap;
}

.btn{
padding:15px 24px;
border-radius:12px;
font-weight:800;
text-decoration:none;
display:inline-flex;
align-items:center;
justify-content:center;
gap:8px;
transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.btn:hover{
transform:translateY(-2px);
}

.yellow{
background:var(--yellow);
color:#111827;
box-shadow:0 8px 18px rgba(250,204,21,0.26);
}

.yellow:hover{
background:#f2be0b;
}

.white{
background:#fff;
border:2px solid #d1d5db;
color:var(--text);
}

.trust-row{
display:flex;
justify-content:center;
flex-wrap:wrap;
gap:12px;
color:#374151;
font-weight:700;
font-size:14px;
}

.trust-row span{
background:#fff;
border:1px solid var(--line);
border-radius:999px;
padding:9px 13px;
box-shadow:0 4px 12px rgba(15,23,42,0.04);
}

.hero-map-card{
background:#fff;
border-radius:24px;
overflow:hidden;
box-shadow:var(--shadow);
border:1px solid var(--line);
}

.map-image{
width:100%;
height:470px;
object-fit:cover;
}

.map-caption{
font-size:15px;
line-height:1.65;
color:var(--muted);
padding:18px 22px 22px;
background:#fff;
text-align:center;
font-weight:600;
}

.services,
.how-it-works,
.trust-section,
.faq{
padding:88px 0;
}

.services h2,
.how-it-works h2,
.trust-section h2,
.faq h2{
text-align:center;
font-size:clamp(36px,4vw,54px);
line-height:1.08;
margin-bottom:12px;
font-weight:900;
letter-spacing:-0.045em;
}

.section-sub{
text-align:center;
color:var(--soft);
margin:0 auto 48px;
font-size:18px;
max-width:780px;
}

.services-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:24px;
}

.service-card{
background:#fff;
border-radius:18px;
padding:28px;
display:flex;
gap:18px;
align-items:flex-start;
box-shadow:0 5px 18px rgba(0,0,0,0.06);
border:1px solid #ececec;
min-height:218px;
}

.icon{
width:56px;
height:56px;
border-radius:16px;
background:#f3f4f6;
display:flex;
align-items:center;
justify-content:center;
flex-shrink:0;
border:1px solid var(--line);
}

.icon svg{
width:26px;
height:26px;
fill:#2563eb;
display:block;
}

.icon-email svg{fill:#0f766e;}
.icon-upgrade svg{fill:#7c3aed;}
.icon-virus svg{fill:#dc2626;}
.icon-home svg{fill:#d97706;}
.icon-business svg{fill:#0f766e;}

.service-card h3{
font-size:23px;
line-height:1.2;
margin-bottom:8px;
letter-spacing:-0.02em;
}

.service-card p{
color:var(--muted);
font-size:15px;
line-height:1.7;
}

.card-link{
display:inline-flex;
margin-top:14px;
font-size:14px;
font-weight:800;
color:#0f172a;
text-decoration:none;
border-bottom:2px solid var(--yellow);
}

.card-link:hover{
color:#000;
}

.how-it-works{
background:#fff;
}

.steps-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:24px;
margin-top:34px;
}

.step-card{
background:#f8fafc;
border:1px solid var(--line);
border-radius:20px;
padding:30px;
box-shadow:0 8px 24px rgba(15,23,42,0.05);
}

.step-card span{
display:grid;
place-items:center;
width:44px;
height:44px;
border-radius:50%;
background:var(--yellow);
font-weight:900;
margin-bottom:18px;
}

.step-card h3{
font-size:22px;
margin-bottom:10px;
letter-spacing:-0.02em;
}

.step-card p{
color:var(--muted);
font-size:16px;
line-height:1.75;
}

.why{
padding:88px 0;
background:#fff;
}

.why-grid{
display:grid;
grid-template-columns:1fr 0.95fr;
gap:46px;
align-items:center;
}

.why-left .section-tag{
text-align:left;
}

.why-left h2{
font-size:clamp(38px,4vw,56px);
line-height:1.05;
margin-bottom:18px;
letter-spacing:-0.045em;
}

.why-intro{
font-size:18px;
color:var(--muted);
margin:0 0 30px;
max-width:660px;
line-height:1.8;
}

.why-item{
margin-bottom:24px;
}

.why-item strong{
display:block;
font-size:21px;
margin-bottom:8px;
}

.why-item p{
color:var(--muted);
line-height:1.75;
}

.why-image{
overflow:hidden;
border-radius:24px;
background:var(--navy);
box-shadow:0 15px 40px rgba(0,0,0,0.12);
aspect-ratio:4/5;
max-height:680px;
}

.why-image img{
width:100%;
height:100%;
object-fit:cover;
object-position:center center;
}

.business-support{
padding:88px 0;
background:#ffffff;
}

.business-grid{
display:grid;
grid-template-columns:1.18fr 0.82fr;
gap:42px;
align-items:start;
}

.business-copy .section-tag,
.pricing-box .section-tag{
text-align:left;
}

.business-copy h2{
font-size:clamp(36px,4vw,52px);
line-height:1.08;
margin-bottom:24px;
font-weight:900;
letter-spacing:-0.045em;
max-width:760px;
}

.business-copy p{
font-size:18px;
color:var(--muted);
margin-bottom:20px;
line-height:1.85;
}

.pricing-box{
background:var(--navy);
padding:34px;
border-radius:24px;
color:#fff;
box-shadow:0 15px 40px rgba(0,0,0,0.12);
}

.price-card{
background:#111827;
border:1px solid rgba(255,255,255,0.08);
padding:26px;
border-radius:18px;
margin-bottom:18px;
}

.price-card h3{
font-size:52px;
color:var(--yellow);
margin-bottom:6px;
line-height:1;
}

.price-card span{
display:block;
font-size:18px;
font-weight:800;
margin-bottom:12px;
}

.price-card p{
color:#d1d5db;
font-size:15px;
line-height:1.7;
}

.pricing-box small{
display:block;
margin-top:10px;
color:#d1d5db;
font-size:14px;
line-height:1.7;
}

.trust-section{
background:#f8fafc;
}

.trust-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:24px;
margin-top:36px;
}

.trust-grid article{
background:#fff;
border:1px solid var(--line);
border-radius:20px;
padding:28px;
box-shadow:0 8px 24px rgba(15,23,42,0.05);
}

.trust-grid h3{
font-size:22px;
margin-bottom:10px;
letter-spacing:-0.02em;
}

.trust-grid p{
color:var(--muted);
line-height:1.75;
}

.faq{
background:#fff;
}

.faq-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:16px;
margin-top:34px;
}

details{
background:#f8fafc;
border:1px solid var(--line);
border-radius:16px;
padding:20px 22px;
}

summary{
cursor:pointer;
font-weight:800;
font-size:17px;
color:var(--text);
}

details p{
margin-top:12px;
color:var(--muted);
line-height:1.75;
}

.contact{
padding:88px 0;
background:#f8fafc;
}

.contact-grid{
display:grid;
grid-template-columns:1fr 1.1fr;
gap:50px;
align-items:start;
}

.contact .section-tag{
text-align:left;
}

.contact h2{
font-size:clamp(36px,4vw,52px);
line-height:1.08;
margin-bottom:22px;
letter-spacing:-0.045em;
}

.contact-text{
color:var(--muted);
margin-bottom:24px;
font-size:18px;
line-height:1.75;
}

.contact-list p{
margin-bottom:14px;
font-weight:600;
}

.contact-list a{
text-decoration:none;
}

.phone-nudge{
margin-top:22px;
font-weight:800;
color:var(--text);
}

.phone-nudge a{
color:#000;
text-decoration:underline;
text-decoration-color:var(--yellow);
text-decoration-thickness:3px;
text-underline-offset:4px;
}

.form{
background:#fff;
padding:28px;
border-radius:20px;
box-shadow:0 8px 24px rgba(0,0,0,0.06);
border:1px solid var(--line);
}

.row{
display:grid;
grid-template-columns:1fr 1fr;
gap:14px;
margin-bottom:14px;
}

input,
textarea,
select{
width:100%;
padding:15px;
border:1px solid #d1d5db;
border-radius:10px;
font-family:inherit;
font-size:15px;
background:#fff;
color:var(--text);
}

input:focus,
textarea:focus,
select:focus{
outline:none;
border-color:#facc15;
box-shadow:0 0 0 4px rgba(250,204,21,0.18);
}

textarea{
height:140px;
resize:vertical;
margin-bottom:18px;
}

.honeypot{
display:none;
}

.submit-btn{
width:100%;
padding:16px;
border:none;
border-radius:12px;
background:var(--yellow);
font-weight:900;
font-size:16px;
cursor:pointer;
transition:background .2s ease, transform .2s ease;
}

.submit-btn:hover{
background:#f2be0b;
transform:translateY(-1px);
}

.seo-content{
padding:70px 0;
background:#ffffff;
border-top:1px solid #ececec;
}

.seo-content h2{
font-size:38px;
margin-bottom:24px;
text-align:center;
font-weight:900;
letter-spacing:-0.035em;
}

.seo-content p{
max-width:900px;
margin:0 auto 20px;
font-size:17px;
line-height:1.8;
color:var(--muted);
text-align:center;
}

.footer{
background:var(--dark);
color:#fff;
padding-top:60px;
}

.footer-grid{
display:grid;
grid-template-columns:1.2fr 1fr 1fr 1fr;
gap:40px;
padding-bottom:40px;
}

.footer-logo{
width:220px;
margin-bottom:18px;
}

.footer h4{
margin-bottom:16px;
font-size:18px;
}

.footer a,
.footer p{
display:block;
margin-bottom:10px;
color:#d1d5db;
text-decoration:none;
}

.footer a:hover{
text-decoration:underline;
}

.copyright{
border-top:1px solid rgba(255,255,255,0.1);
padding:18px;
text-align:center;
font-size:14px;
color:#9ca3af;
}

.mobile-sticky-cta{
display:none;
}

@media(max-width:1100px){
.services-grid,
.steps-grid,
.trust-grid{
grid-template-columns:repeat(2,1fr);
}

.main-nav{
gap:16px;
}
}

@media(max-width:900px){
.hero-grid,
.why-grid,
.business-grid,
.contact-grid,
.footer-grid{
grid-template-columns:1fr;
}

.hero{
padding:46px 0;
}

.map-image{
height:360px;
}

.why-left .section-tag,
.business-copy .section-tag,
.pricing-box .section-tag,
.contact .section-tag{
text-align:center;
}

.business-copy h2,
.contact h2,
.why-left h2{
text-align:center;
}

.why-intro,
.business-copy p,
.contact-text{
text-align:center;
margin-left:auto;
margin-right:auto;
}

.contact-list,
.phone-nudge{
text-align:center;
}

.why-image{
max-width:520px;
width:100%;
margin:0 auto;
}

.menu-toggle{
display:inline-flex;
margin-left:auto;
}

.main-nav{
display:none;
position:absolute;
left:4%;
right:4%;
top:100%;
background:#fff;
border:1px solid var(--line);
box-shadow:0 14px 34px rgba(15,23,42,0.12);
border-radius:18px;
padding:18px;
flex-direction:column;
align-items:flex-start;
z-index:80;
}

.main-nav.open{
display:flex;
}

.nav{
position:relative;
}

.logo{
height:54px;
}
}

@media(max-width:700px){
body{
padding-bottom:72px;
}

h1{
font-size:42px;
letter-spacing:-0.045em;
}

.lead{
font-size:18px;
}

.hero-buttons,
.btn{
width:100%;
}

.trust-row{
align-items:stretch;
}

.trust-row span{
width:100%;
text-align:center;
}

.services-grid,
.steps-grid,
.trust-grid,
.faq-grid{
grid-template-columns:1fr;
}

.service-card{
min-height:auto;
}

.row{
grid-template-columns:1fr;
}

.topbar-inner{
gap:12px;
}

.mobile-sticky-cta{
display:grid;
grid-template-columns:1fr 1fr;
position:fixed;
left:0;
right:0;
bottom:0;
z-index:200;
box-shadow:0 -8px 24px rgba(15,23,42,0.18);
}

.mobile-sticky-cta a{
display:flex;
align-items:center;
justify-content:center;
min-height:62px;
text-decoration:none;
font-weight:900;
font-size:16px;
}

.mobile-sticky-cta a:first-child{
background:var(--yellow);
color:#111827;
}

.mobile-sticky-cta a:last-child{
background:#111827;
color:#fff;
}
}

@media(max-width:480px){
.container{
width:min(100% - 24px,1200px);
}

.logo{
height:46px;
}

.services,
.how-it-works,
.trust-section,
.faq,
.why,
.business-support,
.contact{
padding:64px 0;
}

.map-image{
height:300px;
}

.hero-map-card{
border-radius:18px;
}
}


/* Customer confidence section now has two cards */
.trust-grid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  max-width:860px;
  margin-left:auto;
  margin-right:auto;
}

@media(max-width:700px){
  .trust-grid{
    grid-template-columns:1fr;
  }
}


.hero-support-line{
font-size:17px;
font-weight:700;
color:#111827;
margin:0 auto 26px;
max-width:760px;
line-height:1.7;
}


.hero-small{
padding:70px 0 40px;
}

.problem-section{
padding: 0 0 88px;
background:#fff;
}

.problems-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:24px;
}

.problem-card{
background:#fff;
border:1px solid #ececec;
border-radius:20px;
padding:28px;
box-shadow:0 8px 24px rgba(15,23,42,0.05);
}

.problem-card h2{
font-size:28px;
margin-bottom:14px;
line-height:1.2;
letter-spacing:-0.03em;
}

.problem-card p{
font-size:16px;
line-height:1.8;
color:#4b5563;
}

@media(max-width:900px){
.problems-grid{
grid-template-columns:1fr;
}
}


.seo-links{
padding:30px 0 10px;
background:#fff;
}

.seo-links p{
text-align:center;
font-size:15px;
color:#6b7280;
line-height:1.7;
}

.seo-links a{
font-weight:700;
text-decoration:none;
border-bottom:2px solid #facc15;
}


/* Larger SEO footer link */
.seo-links{
padding:42px 0 18px;
background:#fff;
}

.seo-links p{
text-align:center;
font-size:18px;
color:#4b5563;
line-height:1.9;
max-width:900px;
margin:auto;
}

.seo-links a{
font-weight:800;
font-size:18px;
text-decoration:none;
border-bottom:3px solid #facc15;
color:#111827;
}
