*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--white);line-height:1.6;font-size:16px}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.btn{display:inline-block;padding:14px 28px;border-radius:var(--radius);font-weight:700;font-size:1rem;cursor:pointer;border:none;transition:opacity .2s,transform .2s;text-align:center;line-height:1.3}
.btn:hover{opacity:.9;transform:translateY(-1px);text-decoration:none}
.btn-primary{background:var(--secondary);color:var(--white)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-lg{padding:18px 36px;font-size:1.1rem}
section{padding:60px 0}
h2{font-size:1.9rem;font-weight:800;margin-bottom:20px;color:var(--text)}
h3{font-size:1.2rem;font-weight:700;margin-bottom:8px}
p{margin-bottom:1em;color:var(--muted)}
p:last-child{margin-bottom:0}

/* Header */
.site-header{background:var(--accent);color:var(--white);padding:0}
.top-bar{background:var(--primary);padding:8px 0;text-align:center;font-size:.85rem}
.top-bar a{color:var(--white);font-weight:600}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:16px;flex-wrap:wrap}
.site-logo{font-size:1.4rem;font-weight:800;color:var(--white);line-height:1.2}
.site-logo span{color:var(--secondary)}
.header-phone{display:flex;align-items:center;gap:10px}
.header-phone a{background:var(--secondary);color:var(--white);padding:12px 24px;border-radius:var(--radius);font-weight:700;font-size:1.05rem;white-space:nowrap}
.header-phone a:hover{opacity:.9;text-decoration:none}

/* Nav */
nav{background:var(--primary)}
nav ul{list-style:none;display:flex;gap:4px;padding:0}
nav ul li a{color:var(--white);padding:12px 16px;display:block;font-weight:500;font-size:.95rem;transition:background .2s}
nav ul li a:hover{background:rgba(255,255,255,.15);text-decoration:none}

/* Mobile nav toggle */
.nav-toggle{display:none;background:none;border:2px solid var(--white);color:var(--white);padding:6px 12px;cursor:pointer;border-radius:4px;font-size:1.2rem}

/* ── Mobile responsive ─────────────────────────────────────── */
@media(max-width:700px){
    .nav-toggle{display:block}
    nav ul{display:none;flex-direction:column}
    nav ul.open{display:flex}
    .site-logo{font-size:1.1rem}

    /* Header phone — smaller on mobile */
    .header-phone a{padding:10px 16px;font-size:.9rem}
    .header-inner{padding:12px 0;gap:10px}

    /* Hero adjustments */
    #hero{padding:50px 0}
    #hero h1{font-size:1.8rem !important}
    #hero p{font-size:1rem !important}
    #hero .btn{padding:13px 20px;font-size:.95rem}
    #hero > div > div{flex-direction:column;align-items:center}

    /* Section padding */
    section{padding:40px 0}
    h2{font-size:1.5rem}

    /* Grids — force single column on very small screens */
    [style*="grid-template-columns:repeat"]{grid-template-columns:1fr !important}

    /* Blog cards */
    [style*="height:200px"]{height:160px !important}

    /* Buttons */
    .btn-lg{padding:14px 22px;font-size:1rem}

    /* Footer padding */
    footer{padding:36px 0 16px}
    footer [style*="gap:40px"]{gap:24px !important}

    /* Contact form */
    form input,form textarea,form select{font-size:16px} /* prevent iOS zoom */
}

@media(max-width:480px){
    .container{padding:0 16px}
    #hero{padding:40px 0}
    #hero h1{font-size:1.6rem !important}
    .site-logo{font-size:1rem}
}
