/* ============ Theme ============ */
:root{
  --bg: #f7f4ee;        /* warm paper */
  --ink: #0f2a3d;       /* deep teal */
  --ink-2:#1f3f52;      /* muted teal */
  --accent:#e06a2d;     /* island orange */
  --card:#ffffff;
  --muted:#6c7a86;
  --radius:18px;
  --shadow: 0 10px 25px rgba(15,42,61,.08), 0 2px 8px rgba(15,42,61,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin-inline:auto;padding:0 clamp(16px, 4vw, 32px)}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem; padding:.8rem 1.1rem; border-radius:12px; font-weight:700;
  border:1px solid transparent; transition:transform .06s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: var(--shadow); white-space:nowrap;
}
.btn-xl{padding:1rem 1.3rem; font-size:1.05rem}
.btn-ghost{background:transparent;border-color:#d7d9dd;color:var(--ink-2);box-shadow:none}
.btn-ghost:hover{background:#fff}
.btn-accent{background:var(--accent); color:#fff}
.btn-accent:hover{filter:brightness(.96)}

/* ============ Header ============ */
.site-header{position:sticky;top:0;background:rgba(247,244,238,.85);backdrop-filter: blur(8px); z-index:50; border-bottom:1px solid #eee}
.header-inner{display:grid;grid-template-columns:auto 1fr auto auto; align-items:center; gap:1rem; min-height:72px}
.brand{display:flex;align-items:center;gap:.75rem}
.brand-logo{width:40px;height:40px; border-radius:10px; background:#fff; box-shadow: var(--shadow); object-fit:cover}
.brand-name{font-weight:800; letter-spacing:.5px}
.nav{display:flex; gap:1rem; justify-content:center}
.nav a{padding:.4rem .5rem; border-radius:8px; color:var(--ink-2)}
.nav a:hover{background:#fff}
.header-call{display:none}

/* Hamburger */
.hamburger{display:none; width:42px;height:42px; border:0;background:transparent; border-radius:10px; cursor:pointer}
.hamburger span{display:block;height:2px;background:var(--ink);margin:7px;border-radius:2px;transition:.2s}

/* ============ Hero ============ */
.hero{
  background:
    radial-gradient(1200px 600px at 100% -10%, rgba(224,106,45,.12), transparent 50%),
    radial-gradient(900px 500px at -10% 20%, rgba(15,42,61,.08), transparent 50%);
  padding: clamp(28px, 6vw, 64px) 0;
}
.hero-inner{display:grid; gap:2rem; grid-template-columns: 1.2fr .8fr; align-items:center}
.hero-copy h1{font-size: clamp(28px, 4.2vw, 48px); line-height:1.1; margin:0 0 .5rem}
.lead{font-size: clamp(16px, 1.4vw, 18px); color:var(--ink-2); margin:0 0 1rem}
.hero-bullets{list-style:none;padding:0;margin: 1rem 0; display:grid; gap:.5rem}
.hero-bullets li{display:flex; align-items:center; gap:.5rem; color:var(--ink-2)}
.hero-bullets .material-symbols-outlined{font-size:22px;color:var(--accent)}
.cta-row{display:flex; gap:.8rem; flex-wrap:wrap; align-items:center}
.mini-note{font-size:.9rem; color:var(--muted)}
.hero-art{justify-self:end; width:min(440px, 90%); transform:translateY(4px)}
.hero-art img{border-radius:24px; background:#fff; box-shadow: var(--shadow);}

/* ============ Sections ============ */
.section{padding: clamp(40px, 7vw, 84px) 0}
.section.soft{background:#fff;border-top:1px solid #eee;border-bottom:1px solid #eee}
.section-title{font-size: clamp(22px, 3vw, 34px); margin:0 0 .5rem}
.section-sub{color:var(--muted); margin:0 0 1.5rem}

/* Services grid */
.grid{display:grid; gap: clamp(14px, 2vw, 22px)}
.services-grid{grid-template-columns: repeat(4, 1fr)}
.card{
  background:var(--card); border:1px solid #eee; border-radius:16px; padding:1.1rem;
  box-shadow: var(--shadow); transition: transform .06s ease, box-shadow .2s ease;
}
.card:hover{transform: translateY(-2px); box-shadow: 0 12px 28px rgba(15,42,61,.12), 0 2px 8px rgba(15,42,61,.06)}
.card-ico{font-size:28px; color:var(--accent); margin-bottom:.2rem}
.card-cta{display:flex;flex-direction:column;gap:.6rem;}

/* About */
.about-wrap{display:grid; gap:2rem; grid-template-columns: 1.1fr .9fr; align-items:center}
.tick-list{list-style:none;padding:0;margin:.8rem 0 1rem; display:grid; gap:.4rem}
.tick-list li{display:flex; align-items:center; gap:.5rem}
.tick-list .material-symbols-outlined{font-size:22px; color:var(--accent)}
.about-art img{border-radius:16px; box-shadow: var(--shadow)}

/* Reviews */
.reviews-grid{grid-template-columns: repeat(3, 1fr)}
.review{background:#fff;border:1px solid #eee;border-radius:16px;padding:1rem;box-shadow: var(--shadow)}
.review blockquote{margin:.4rem 0 .2rem; font-weight:600}
.review .stars{letter-spacing:1px;color:#f5a623}

/* Contact */
.contact{background:
  linear-gradient(180deg, rgba(224,106,45,.10), rgba(224,106,45,.08) 60%, transparent 100%),
  var(--bg);}
.contact-inner{display:grid; gap:1rem}
.contact-alt,.hours{color:var(--ink-2)}

/* Footer */
.site-footer{border-top:1px solid #eee; background:#fff}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding: 18px 0}
.brand.mini{display:flex; align-items:center; gap:.6rem}
.brand.mini img{width:32px;height:32px;border-radius:8px; background:#fff; box-shadow: var(--shadow)}
.foot-right{display:flex; flex-direction:column; align-items:flex-end; gap:.2rem}
.foot-call{font-weight:800}

/* Mobile call bar */
.mobile-callbar{
  position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 60;
  display:none; align-items:center; justify-content:center; gap:.5rem;
  padding: .9rem 1rem; background: var(--accent); color:#fff; border-radius: 14px;
  box-shadow: var(--shadow); font-weight:800;
}

/* ============ Responsive ============ */
@media (max-width: 1000px){
  .services-grid{grid-template-columns: repeat(3, 1fr)}
  .about-wrap{grid-template-columns: 1fr}
  .hero-inner{grid-template-columns: 1fr}
  .hero-art{justify-self:start}
}

@media (max-width: 740px){
  /* Make header a flex row and push burger to the right */
  .header-inner{display:flex; align-items:center; gap:1rem; min-height:72px}
  .hamburger{display:block; margin-left:auto}   /* <-- right side */
  .header-call{display:none}

  /* Mobile nav panel */
  .nav{
    position:fixed; inset:72px 0 auto 0; background:rgba(247,244,238,.98);
    padding:1rem; display:none; flex-direction:column; gap:.6rem;
    border-bottom:1px solid #eee; z-index:40
  }
  .nav a{padding:.8rem 1rem; border-radius:10px; background:#fff}

  .mobile-callbar{display:flex}
  .services-grid{grid-template-columns: repeat(2, 1fr)}
  .reviews-grid{grid-template-columns: 1fr}
}

@media (max-width: 430px){
  .services-grid{grid-template-columns: 1fr}
  .brand-name{display:none}
}

/* Utilities */
.hidden{display:none !important}
