
:root{
    --yellow:#f4c400;
    --yellow-soft:#fff5bf;
    --dark:#111111;
    --text:#1a1a1a;
    --muted:#666666;
    --border:#eadfba;
    --bg:#fffdf7;
    --card:#ffffff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Arial, Helvetica, sans-serif;
    color:var(--text);
    background:var(--bg);
    line-height:1.6;
}
a{text-decoration:none;color:inherit}
.container{width:min(1140px, calc(100% - 32px));margin:0 auto}

.site-header{
    position:sticky;
    top:0;
    z-index:50;
    background:rgba(255,253,247,.95);
    border-bottom:1px solid var(--border);
    backdrop-filter:blur(10px);
}
.nav{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:16px 0;
}
.brand{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}
.brand-text strong{
    display:block;
    font-size:20px;
    line-height:1.1;
}
.brand-text small{
    display:block;
    color:var(--muted);
}
.brand-icon{
    width:50px;
    height:50px;
    border-radius:14px;
    background:var(--yellow);
    display:grid;
    place-items:center;
    font-weight:700;
    color:#000;
    flex-shrink:0;
}
.menu{
    display:flex;
    gap:24px;
    flex-wrap:wrap;
    align-items:center;
    justify-content:center;
    flex:1;
}
.menu a{
    font-weight:700;
    color:#343434;
}
.header-actions{
    display:flex;
    gap:10px;
    align-items:center;
    flex-shrink:0;
}
.phone-link{
    font-weight:700;
    white-space:nowrap;
}
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:13px 18px;
    border-radius:14px;
    font-weight:700;
    border:1px solid transparent;
    transition:.2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--yellow);color:#000}
.btn-dark{background:#111;color:#fff}
.btn-outline{background:#fff;border-color:#ddd0a6;color:#111}
.full{width:100%}

.mobile-menu-toggle{
    display:none;
    width:46px;
    height:46px;
    border:none;
    border-radius:14px;
    background:#111;
    padding:0;
    cursor:pointer;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
}
.mobile-menu-toggle span{
    display:block;
    width:20px;
    height:2px;
    background:#fff;
    border-radius:999px;
}
.mobile-menu-overlay{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.36);
    z-index:69;
}
.mobile-menu-panel{
    display:none;
    position:fixed;
    top:0;
    right:0;
    width:min(88vw, 360px);
    height:100vh;
    background:#fffdf7;
    border-left:1px solid var(--border);
    box-shadow:-8px 0 28px rgba(0,0,0,.12);
    z-index:70;
    padding:18px;
    overflow:auto;
    transform:translateX(100%);
    transition:transform .24s ease;
}
.mobile-menu-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:18px;
}
.mobile-menu-brand{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}
.mobile-menu-close{
    width:42px;
    height:42px;
    border:none;
    border-radius:12px;
    background:#111;
    color:#fff;
    font-size:28px;
    line-height:1;
    cursor:pointer;
    flex-shrink:0;
}
.mobile-menu-links{
    display:grid;
    gap:10px;
}
.mobile-menu-links a{
    display:block;
    padding:14px 16px;
    border-radius:16px;
    background:#fff;
    border:1px solid var(--border);
    font-weight:700;
}
.mobile-menu-contact{
    display:grid;
    gap:12px;
    margin-top:18px;
}
.mobile-phone{
    display:block;
    text-align:center;
    font-weight:700;
    padding:14px 16px;
    border-radius:16px;
    background:#fff5bf;
    color:#4d3d00;
    border:1px solid #ecd76d;
}
body.mobile-menu-open{overflow:hidden}
body.mobile-menu-open .mobile-menu-overlay{display:block}
body.mobile-menu-open .mobile-menu-panel{
    display:block;
    transform:translateX(0);
}

.hero{
    background:linear-gradient(180deg,#fff8d9 0%, #fffdf7 68%);
    padding:60px 0 54px;
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:center}
.eyebrow{
    display:inline-block;
    padding:8px 12px;
    border-radius:999px;
    background:#fff0a1;
    color:#6c5900;
    font-size:13px;
    font-weight:700;
}
.hero h1,.section h1,.section h2{line-height:1.15;margin:16px 0}
.hero h1{font-size:52px;max-width:720px}
.hero p{font-size:18px;color:#484848;max-width:700px}
.hero-box,.card,.blog-row,.single-post,.login-box{
    background:var(--card);
    border:1px solid var(--border);
    border-radius:24px;
    box-shadow:0 10px 30px rgba(0,0,0,.04);
}
.hero-box{padding:24px}
.quote-form,.contact-card{display:grid;gap:12px}
input,textarea,select{
    width:100%;
    padding:14px 15px;
    border:1px solid #ddd1aa;
    border-radius:14px;
    background:#fff;
    font:inherit;
    color:#111;
}
textarea{min-height:220px;resize:vertical}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0}
.mini-info{display:flex;gap:14px;flex-wrap:wrap}
.mini-info div{
    background:#fff;
    border:1px solid var(--border);
    padding:14px 16px;
    border-radius:18px;
    min-width:140px;
}
.mini-info strong{display:block}
.mini-info span{color:var(--muted)}
.section{padding:72px 0}
.section.white{background:#fff}
.section.yellow{background:#fff7cf}
.section.dark{background:#121212;color:#fff}
.section.dark a{color:#fff}
.section-head{margin-bottom:28px}
.section-head h1,.section-head h2{font-size:40px}
.section-head.split{display:flex;align-items:end;justify-content:space-between;gap:18px;flex-wrap:wrap}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-5{grid-template-columns:repeat(5,1fr)}
.card{padding:24px}
.card h3{margin-top:0}
.routes-grid .card{padding:20px}
.routes-grid h3{margin-bottom:8px}
.blog-card .meta,.blog-row .meta,.single-post .meta{font-size:13px;color:#8d7f3a;font-weight:700}
.read-more{display:inline-block;margin-top:12px;font-weight:700;color:#8a6e00}
.contact-grid{display:grid;grid-template-columns:1fr .9fr;gap:24px;align-items:start}
.contact-list{padding-left:18px}
.contact-card{padding:24px;color:#111}
.blog-list{display:grid;gap:18px}
.blog-row{
    padding:22px;
    display:grid;
    grid-template-columns:1fr auto;
    gap:18px;
    align-items:center;
}
.page-main{min-height:60vh}
.single-post{padding:30px;max-width:850px}
.post-content{font-size:17px}
.site-footer{background:#0f0f0f;color:#fff;padding-top:48px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.footer-grid a{color:#ffe680}
.copyright{
    margin-top:26px;
    border-top:1px solid rgba(255,255,255,.1);
    text-align:center;
    padding:18px 12px;
    color:#d9d9d9;
}
.floating-whatsapp{
    position:fixed;
    right:18px;
    bottom:18px;
    background:#25d366;
    color:#fff;
    padding:14px 18px;
    border-radius:999px;
    font-weight:700;
    box-shadow:0 12px 28px rgba(0,0,0,.2);
}
.login-page{
    display:grid;
    place-items:center;
    min-height:100vh;
    background:#fff9df;
}
.login-box{width:min(420px, calc(100% - 32px));padding:28px}
.error{color:#b00020;font-weight:700}

@media (max-width: 1180px){
    .nav{
        flex-wrap:wrap;
        row-gap:14px;
    }
    .menu{
        order:3;
        width:100%;
        justify-content:flex-start;
        gap:18px;
        padding-top:4px;
    }
    .header-actions{
        margin-left:auto;
    }
}

@media (max-width: 980px){
    .menu,
    .desktop-wa,
    .phone-link{
        display:none;
    }
    .mobile-menu-toggle{
        display:inline-flex;
    }
    .mobile-menu-panel{
        display:block;
    }
    .hero-grid,
    .grid-2,
    .grid-3,
    .grid-4,
    .grid-5,
    .contact-grid,
    .footer-grid,
    .blog-row{
        grid-template-columns:1fr;
    }
    .hero h1{font-size:38px}
    .nav{
        flex-wrap:nowrap;
        padding:14px 0;
    }
    .brand-text strong{font-size:17px}
    .brand-text small{font-size:12px}
    .floating-whatsapp{
        right:14px;
        bottom:14px;
        padding:12px 16px;
    }
}

@media (max-width: 640px){
    .container{width:min(100% - 24px, 1140px)}
    .brand-icon{
        width:44px;
        height:44px;
    }
    .mobile-menu-panel{
        width:min(92vw, 340px);
    }
    .hero{
        padding:40px 0 36px;
    }
    .hero h1{
        font-size:32px;
    }
    .section{
        padding:54px 0;
    }
    .section-head h1,.section-head h2{
        font-size:30px;
    }
    .card,
    .hero-box,
    .single-post,
    .login-box{
        border-radius:20px;
    }
}
