
:root {
  --red: #c8102e;
  --ink: #111827;
  --border: #e5e7eb;
  --muted: #6b7280;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif; color: var(--ink); background: #ffffff; }
a { color: var(--ink); text-decoration: none; }
a:hover { text-decoration: underline; }

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

.skip-link { position:absolute; left:-10000px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { position: static; width: auto; height: auto; padding: .5rem; background: var(--red); color: #fff; }

.site-header { background: #ffffff; position: sticky; top: 0; z-index: 20; border-bottom: 1px solid var(--border); }
.header-inner { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 1rem; padding: .9rem 0; }
.brand { font-weight: 800; letter-spacing: .3px; }
.nav a { margin: 0 .6rem; white-space: nowrap; }
.cta-row { display: flex; gap: .5rem; }
.nav-toggle { display: none; background: none; color: var(--ink); border: 1px solid #d1d5db; border-radius: 8px; padding: .2rem .5rem; }

.btn { display: inline-block; padding: .7rem 1rem; border-radius: 12px; border: 1px solid transparent; font-weight: 600; }
.btn-primary { background: var(--red); color: #ffffff; }
.btn-outline { border-color: #d1d5db; color: var(--ink); }
.btn-ghost { border-color: transparent; opacity: .9; color: var(--ink); }
.btn-link { background: transparent; border: 0; padding: 0; color: var(--ink); font-weight: 600; }
.btn:hover { filter: brightness(1.05); text-decoration: none; }

.hero-light { background: linear-gradient(180deg, #ffffff, #fafafa); padding: 3.0rem 0 2rem; }
.hero h1 { font-size: clamp(1.9rem, 2.5vw + 1rem, 3rem); margin: 0 0 .5rem; }
.hero .sub { color: #374151; max-width: 60ch; }
.hero-ctas { display: flex; gap: .6rem; margin: 1rem 0 0; flex-wrap: wrap; }
.trust-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: .6rem; margin: 2rem 0 0; padding: 0; list-style: none; color: #374151; }
.trust-row li { background: #f9fafb; border: 1px solid var(--border); border-radius: 12px; padding: .7rem; text-align: center; }

.team { background: #ffffff; }
.team-card { display: grid; grid-template-columns: 1.2fr 1fr; gap: 1rem; align-items: center; padding: 1.6rem 0; }
.team-figure { margin: 0; background: #ffffff; border-radius: 16px; overflow: hidden; box-shadow: 0 8px 28px rgba(17,24,39,.08); }
.team-figure img.avatar { display: block; width: 100%; height: auto; }
.team-figure figcaption { padding: .5rem .8rem; color: #9ca3af; font-size: .9rem; }
.team-copy h2 { margin: 0 0 .25rem; letter-spacing: .1px; }
.team-copy p { color: #4b5563; margin: 0 0 .75rem; }
.team-ctas { display: flex; gap: .4rem; flex-wrap: wrap; }

.expect { background: #f9fafb; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.expect h2 { margin-bottom: .5rem; }
.expect-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: .6rem; padding: 0; list-style: none; }
.expect-steps li { background: #ffffff; border: 1px solid var(--border); border-radius: 12px; padding: .9rem; text-align: center; }

.services h2, .reviews h2 { margin-top: 2rem; }
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; margin: 1rem 0; }
.card { background: #ffffff; border: 1px solid var(--border); border-radius: 16px; padding: 1rem; }
.card:hover { border-color: #d1d5db; }
.rates-note { color: var(--muted); margin-top: .5rem; }

.work { background: #ffffff; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 1.2rem 0 1.6rem; }
.work h2 { margin: 0 0 .3rem; }
.work-sub { color: var(--muted); margin: 0 0 .8rem; }
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .5rem; }
.work-item { margin: 0; background: #ffffff; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.work-item img { display: block; width: 100%; height: 140px; object-fit: cover; }
.work-item figcaption { padding: .45rem .6rem; color: #6b7280; font-size: .85rem; border-top: 1px solid var(--border); }

.review-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.9rem; align-items:start; margin:0; padding:0; }
.review{ background:#fff; border:1px solid var(--border); border-radius:16px; padding:1rem; line-height:1.45; }
.review .stars{ font-weight:700; margin:0 0 .35rem; line-height:1; color: var(--red); }
.review p{ margin:0; text-wrap:pretty; }
.review .meta{ display:block; margin-top:.55rem; color:#6b7280; font-size:.95rem; }

.page-hero { background: linear-gradient(180deg, #ffffff, #fafafa); padding: 2.2rem 0 1.2rem; border-bottom: 1px solid var(--border); }
.page-hero h1 { margin: 0; }

.service-grid .service-card .options { display: grid; grid-template-columns: repeat(3, 1fr); gap: .6rem; margin: .6rem 0; }
.option { background: #ffffff; border: 1px solid var(--border); border-radius: 12px; padding: .7rem; }
.service-card .disclaimer { color: var(--muted); font-size: .95rem; }
.badge { display:inline-block; padding: .1rem .4rem; border-radius: 8px; background: rgba(200,16,46,.08); border: 1px solid rgba(200,16,46,.25); color: var(--ink); }

.faq details { background: #ffffff; border: 1px solid var(--border); border-radius: 12px; padding: .6rem .9rem; margin: .6rem 0; }
.faq summary { cursor: pointer; font-weight: 600; }

.about-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1rem; }
.area-list { columns: 2; padding-left: 1rem; }

.contact { display: grid; grid-template-columns: 2fr 1fr; gap: 1rem; }
.contact-card { background: #ffffff; border: 1px solid var(--border); border-radius: 16px; padding: 1rem; }
.contact-aside { background: #ffffff; border: 1px solid var(--border); border-radius: 16px; padding: 1rem; }
.form-row { display: grid; gap: .3rem; margin: .6rem 0; }
input, select, textarea { background: #ffffff; color: var(--ink); border: 1px solid #d1d5db; border-radius: 10px; padding: .6rem .7rem; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--red); border-color: var(--red); }
.hidden-honeypot { position:absolute; left:-10000px; width:1px; height:1px; overflow:hidden; }
.fineprint { color: var(--muted); font-size: .9rem; }

.site-footer { background: #fafafa; margin-top: 2rem; border-top: 1px solid var(--border); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1rem; padding: 1.2rem 0; }
.footer-heading { font-weight: 700; margin-bottom: .4rem; }
.brand-footer { font-weight: 800; margin-bottom: .5rem; }
.footer-ctas { display: flex; gap: .5rem; }
.footer-bottom { color: var(--muted); padding: .8rem 0; border-top: 1px solid var(--border); }

.center { text-align: center; margin-top: 1rem; }

@media (max-width: 900px) {
  .header-inner { grid-template-columns: 1fr auto auto; }
  .nav { display: none; }
  .nav.open { display: block; position: absolute; top: 56px; right: 0; background: #ffffff; padding: .8rem; border: 1px solid var(--border); border-radius: 12px; }
  .nav a { display: block; padding: .4rem .6rem; }
  .nav-toggle { display: inline-block; }
  .trust-row { grid-template-columns: 1fr 1fr; }
  .expect-steps { grid-template-columns: 1fr 1fr; }
  .card-grid, .review-grid { grid-template-columns: 1fr; }
  .about-grid, .contact { grid-template-columns: 1fr; }
  .area-list { columns: 1; }
  .service-grid .service-card .options { grid-template-columns: 1fr; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .work-item img { height: 120px; }
}


/* Small service-icons image at top of home */
.home-icons{display:flex;justify-content:center;margin:1rem 0 .5rem}
.home-icons img{width:100%;max-width:260px;height:auto;border:1px solid var(--border);border-radius:12px;background:#fff}


/* Home icons: smaller, offset to the side */
.home-icons.side{display:flex;justify-content:flex-end;gap:.5rem;margin:.6rem 0 .3rem}
.home-icons.side img{width:100%;max-width:160px;height:auto;border:1px solid var(--border);border-radius:12px;background:#fff}
@media (max-width: 700px){
  .home-icons.side{justify-content:center}
  .home-icons.side img{max-width:140px}
}


/* --- Pinned card vibe for home icons --- */
.home-icons.side{display:flex;justify-content:flex-end;gap:.6rem;margin:.6rem 0 .3rem;position:relative;z-index:1}
.home-icons.side .pin-tile{position:relative;display:inline-block;padding:.5rem .5rem .7rem;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 10px 28px rgba(17,24,39,.14);transform:rotate(-2.5deg);transition:transform .18s ease, box-shadow .18s ease}
.home-icons.side .pin-tile:nth-child(2){transform:rotate(2.2deg)}
.home-icons.side .pin-tile img{display:block;width:100%;max-width:150px;height:auto;border-radius:10px}
.home-icons.side .pin-tile::before{content:"";position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #ffd6d6 0, #c8102e 45%, #7a0b1b 100%);box-shadow:0 2px 6px rgba(0,0,0,.25)}
.home-icons.side .pin-tile:hover{transform:rotate(-1deg);box-shadow:0 14px 36px rgba(17,24,39,.18)}
.home-icons.side .pin-tile:nth-child(2):hover{transform:rotate(1deg)}

@media (max-width:700px){
  .home-icons.side{justify-content:center}
  .home-icons.side .pin-tile{transform:rotate(-1.5deg)}
  .home-icons.side .pin-tile:nth-child(2){transform:rotate(1.2deg)}
  .home-icons.side .pin-tile img{max-width:130px}
}
