/* ===== Design tokens ===== */
:root{
  --navy:#2e4a6b;
  --navy-dark:#1b2f47;
  --navy-light:#3a5d85;
  --accent:#f5a623;
  --bg:#f6f8fb;
  --card:#ffffff;
  --text:#1f2b3a;
  --muted:#5d6b7d;
  --line:#e3e9f1;
  --radius:14px;
  --shadow:0 10px 30px rgba(27,47,71,.10);
  --shadow-sm:0 4px 14px rgba(27,47,71,.08);
  --max:1120px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 20px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:.4em;justify-content:center;
  background:var(--accent);color:#1c1304;font-weight:700;
  padding:.7em 1.25em;border-radius:999px;border:0;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  box-shadow:0 6px 16px rgba(245,166,35,.35);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(245,166,35,.45)}
.btn-sm{padding:.5em 1em;font-size:.9rem}
.btn-lg{padding:.85em 1.6em;font-size:1.05rem}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7);box-shadow:none}
.btn-ghost:hover{background:rgba(255,255,255,.12);box-shadow:none}
.btn-light{background:#fff;color:var(--navy);box-shadow:0 6px 16px rgba(0,0,0,.15)}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;color:var(--navy);font-weight:800}
.brand-icon{width:42px;height:auto;color:var(--navy)}
.brand-text{font-size:1.05rem;line-height:1;letter-spacing:.2px}
.brand-text small{display:block;font-size:.62rem;font-weight:600;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-weight:600;color:var(--navy);position:relative}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--accent);transition:width .2s}
.nav-links a:not(.btn):hover::after,.nav-links a.active::after{width:100%}

.nav-toggle{display:none}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.nav-burger span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.25s}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-dark) 100%);color:#fff}
.hero-bg{position:absolute;inset:0;opacity:.5;
  background:
    radial-gradient(circle at 80% 20%,rgba(245,166,35,.18),transparent 40%),
    radial-gradient(circle at 15% 90%,rgba(155,180,207,.18),transparent 45%);
}
.hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:70px 20px 80px}
.eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:.8rem;font-weight:700;color:#9bb4cf;margin-bottom:14px}
.hero h1{font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.12;font-weight:800}
.hero .accent{color:var(--accent)}
.lead{margin:18px 0 26px;font-size:1.15rem;color:#dce6f2;max-width:540px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-badges{list-style:none;display:flex;flex-wrap:wrap;gap:18px;margin-top:26px;font-weight:600;color:#cfe0f1}

/* ===== Hero van animation ===== */
.hero-art{display:flex;justify-content:center}
.van-anim{width:100%;max-width:420px}
.van-anim .road{stroke:#9bb4cf;stroke-width:3;stroke-dasharray:18 14;animation:road 1.1s linear infinite}
@keyframes road{to{stroke-dashoffset:-32}}
.van-anim .van{animation:bob 1.6s ease-in-out infinite;transform-origin:center}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.van-anim .wheel{animation:none}
.van-anim .speed line{animation:speed 1s linear infinite}
.van-anim .speed line:nth-child(2){animation-delay:.2s}
.van-anim .speed line:nth-child(3){animation-delay:.4s}
@keyframes speed{0%{opacity:0;transform:translateX(10px)}40%{opacity:1}100%{opacity:0;transform:translateX(-14px)}}

/* ===== Sections ===== */
.section{padding:72px 0}
.section-alt{background:#fff}
.section-title{text-align:center;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--navy);font-weight:800;margin-bottom:8px}
.section-sub{text-align:center;color:var(--muted);margin-bottom:30px}
.section-title + .features,.section-title + .services{margin-top:42px}

/* ===== Features ===== */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feature{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feature .ic{font-size:2rem;display:block;margin-bottom:12px}
.feature h3{color:var(--navy);font-size:1.05rem;margin-bottom:6px}
.feature p{color:var(--muted);font-size:.95rem}

/* ===== Services ===== */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service{background:var(--card);border:1px solid var(--line);border-left:5px solid var(--accent);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.service:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.service h3{color:var(--navy);margin-bottom:8px;font-size:1.12rem}
.service p{color:var(--muted)}
.service-cta{background:var(--navy);color:#fff;border-left-color:var(--navy-dark);display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.service-cta h3,.service-cta p{color:#fff}
.service-cta .btn{margin-top:10px}

/* ===== Reviews teaser ===== */
.reviews-teaser{background:#fff;text-align:center}
.stars{color:var(--accent);font-size:1.4rem;letter-spacing:3px}
.reviews-teaser .stars{margin:6px 0 22px}

/* ===== Page hero (reviews) ===== */
.page-hero{background:linear-gradient(160deg,var(--navy),var(--navy-dark));color:#fff;padding:60px 0 50px;text-align:center}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;margin-bottom:18px}
.rating-summary{display:flex;flex-direction:column;align-items:center;gap:12px}
.big-stars{color:var(--accent);font-size:2rem;letter-spacing:4px}
.rating-summary p{color:#dce6f2}

/* ===== Review cards ===== */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.review-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.review-card .stars{font-size:1.1rem;margin-bottom:12px}
.review-card p{color:var(--text);font-style:italic;flex:1}
.review-card footer{display:flex;align-items:center;gap:12px;margin-top:18px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}
.review-card footer strong{display:block;color:var(--navy)}
.review-card footer small{color:var(--muted)}
.disclaimer{text-align:center;color:var(--muted);margin-top:36px}
.disclaimer a{color:var(--navy);font-weight:700;text-decoration:underline}

/* ===== Gallery ===== */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.gallery-item{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);background:#dde6f1}
.gallery-item img{width:100%;height:300px;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.05)}

/* ===== Contact form ===== */
.section-contact{background:linear-gradient(120deg,var(--navy),var(--navy-light));color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
.contact-info h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;margin-bottom:12px}
.contact-info p{color:#dce6f2;margin-bottom:20px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.contact-list a{font-weight:600;color:#fff}
.contact-list a:hover{color:var(--accent)}
.contact-form{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{font-weight:700;color:var(--navy);font-size:.9rem;margin-bottom:6px}
.field input,.field textarea{
  font:inherit;color:var(--text);background:#f6f8fb;border:1px solid var(--line);
  border-radius:10px;padding:.7em .8em;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,166,35,.2)}
.field textarea{resize:vertical}
.contact-form .btn{width:100%}
.form-status{margin-top:12px;font-weight:600;text-align:center;min-height:1.2em}
.form-status.ok{color:#1c7a3e}
.form-status.err{color:#b3261e}

/* ===== Partner ===== */
.partner-inner{text-align:center;max-width:620px;margin:0 auto}
.partner-label{display:inline-block;text-transform:uppercase;letter-spacing:2px;font-size:.75rem;font-weight:700;color:var(--muted);margin-bottom:10px}
.partner-inner h3{color:var(--navy);font-size:1.4rem;margin-bottom:8px}
.partner-inner p{color:var(--muted);margin-bottom:18px}

/* ===== FAQ ===== */
.faq-wrap{max-width:780px;margin:0 auto}
.faq{margin-top:30px;display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:700;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;font-weight:400;color:var(--accent);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 22px 18px;color:var(--muted)}

/* ===== CTA section ===== */
.section-cta{background:linear-gradient(120deg,var(--navy),var(--navy-light));color:#fff;text-align:center}
.cta-inner h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;margin-bottom:10px}
.cta-inner p{color:#dce6f2;margin-bottom:24px}
.cta-buttons{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ===== Footer ===== */
.site-footer{background:var(--navy-dark);color:#cdd8e6;padding-top:50px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px;padding-bottom:34px}
.footer-grid h4{color:#fff;margin-bottom:12px;font-size:1rem}
.footer-grid a{display:block;color:#cdd8e6;padding:4px 0;transition:color .15s}
.footer-grid a:hover{color:var(--accent)}
.brand-footer .brand-text{color:#fff}
.muted{color:#9fb0c4;margin-top:10px;font-size:.95rem}
.footer-email-btn{margin-top:4px;background:var(--accent);color:#1c1304;box-shadow:none}
.footer-email-btn:hover{box-shadow:none;background:#e69912}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 20px;text-align:center;font-size:.85rem;color:#9fb0c4}

/* ===== Back to top ===== */
.to-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#1c1304;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translateY(10px);transition:.25s;z-index:60}
.to-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}

/* ===== Scroll reveal ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media (max-width:900px){
  .features{grid-template-columns:repeat(2,1fr)}
  .services,.review-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-burger{display:flex}
  .nav-links{
    position:absolute;top:68px;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s ease;
  }
  .nav-links a{padding:14px 20px;width:100%;border-top:1px solid var(--line)}
  .nav-links a.btn{margin:14px 20px;width:auto}
  .nav-toggle:checked ~ .nav-links{max-height:340px}
  .nav-toggle:checked ~ .nav-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

  .hero-inner{grid-template-columns:1fr;text-align:center;padding:50px 20px 60px}
  .hero-cta,.hero-badges{justify-content:center}
  .hero-art{order:-1}
  .lead{margin-left:auto;margin-right:auto}

  .contact-grid{grid-template-columns:1fr;gap:28px}
}
@media (max-width:560px){
  .features,.services,.review-grid,.footer-grid,.gallery{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .gallery-item img{height:240px}
  .section{padding:54px 0}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
