:root{
  --bg:#f3ebe6;
  --surface:#fff8f3;
  --surface-2:#efe4dc;
  --text:#241d1a;
  --muted:#6d5f56;
  --line:rgba(36,29,26,.12);
  --accent:#2f2a28;
  --accent-2:#8b6e5d;
  --shadow:0 18px 50px rgba(36,29,26,.10);
  --shadow-soft:0 10px 30px rgba(36,29,26,.08);
  --radius:28px;
  --radius-sm:18px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.75), transparent 35%),
    linear-gradient(180deg, #f7f0ea 0%, var(--bg) 55%, #f1e7df 100%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{width:min(var(--max), calc(100% - 32px));margin:0 auto}
.skip-link{position:absolute;left:-9999px;top:12px;background:#fff;padding:12px 16px;border-radius:999px;z-index:1000}
.skip-link:focus{left:16px}
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(243,235,230,.82);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(36,29,26,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:14px;background:var(--accent);color:#fff;box-shadow:var(--shadow-soft)}
.nav{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center}
.nav a{padding:10px 14px;border-radius:999px;color:var(--muted);transition:.2s ease}
.nav a:hover,.nav a.active{background:rgba(47,42,40,.08);color:var(--accent)}
.header-cta,.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:13px 20px;border:1px solid transparent;font-weight:700;transition:.22s ease;white-space:nowrap}
.header-cta{background:var(--accent);color:#fff;box-shadow:var(--shadow-soft)}
.header-cta:hover,.btn.primary:hover{transform:translateY(-1px);filter:brightness(1.02)}
.btn.primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-soft)}
.btn.secondary{background:transparent;border-color:var(--line);color:var(--accent)}
.btn.secondary:hover{background:rgba(255,255,255,.48)}
main{padding-bottom:44px}
.hero{padding:48px 0 24px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:rgba(47,42,40,.06);font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.hero h1{font-size:clamp(2.5rem, 6vw, 4.9rem);line-height:1;letter-spacing:-.04em;margin:18px 0 18px;max-width:10ch}
.lead{font-size:1.08rem;line-height:1.8;color:var(--muted);max-width:58ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.hero-panel{display:grid;gap:16px}
.hero-collage{
  display:grid;gap:14px;
  grid-template-columns:1.2fr .8fr;
  grid-template-rows:220px 160px;
}
.hero-collage .tile{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:var(--surface);box-shadow:var(--shadow);
}
.hero-collage .tile.big{grid-row:1 / span 2;min-height:394px}
.hero-collage img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.hero-collage .tile:hover img,.gallery-card:hover img,.service-card:hover img{transform:scale(1.04)}
.hero-badge{
  position:absolute;left:16px;bottom:16px;right:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.84));
  backdrop-filter:blur(8px);
  color:var(--accent);padding:14px 16px;border-radius:18px;border:1px solid rgba(36,29,26,.08);
}
.hero-badge strong{display:block;font-size:1.02rem;margin-bottom:4px}
.section{padding:28px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:18px}
.section h2{font-size:clamp(1.6rem,3vw,2.6rem);line-height:1.05;margin:0 0 10px}
.section p{margin:0;color:var(--muted);line-height:1.7}
.grid{display:grid;gap:18px}
.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cards-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card,.service-card,.contact-card,.info-card,.quote-card,.media-card{
  background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-soft)
}
.card,.contact-card,.info-card{padding:22px}
.tag{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(47,42,40,.08);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.card h3,.contact-card h3,.service-card h3{margin:14px 0 10px;font-size:1.15rem}
.card p,.contact-card p,.service-card p{line-height:1.75}
.collage{display:grid;gap:14px;grid-template-columns:repeat(12,1fr)}
.gallery-card{position:relative;overflow:hidden;border-radius:var(--radius);min-height:220px;box-shadow:var(--shadow-soft);border:1px solid var(--line);background:var(--surface)}
.gallery-card img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.gallery-card .caption{
  position:absolute;left:14px;right:14px;bottom:14px;
  background:rgba(255,255,255,.8);backdrop-filter:blur(8px);border:1px solid rgba(36,29,26,.08);
  border-radius:16px;padding:10px 12px;font-size:.92rem;font-weight:700;color:var(--accent)
}
.span-5{grid-column:span 5}.span-4{grid-column:span 4}.span-3{grid-column:span 3}.span-6{grid-column:span 6}.span-7{grid-column:span 7}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.media-card{overflow:hidden}
.media-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.media-content{padding:22px}
.service-card{overflow:hidden;display:grid;grid-template-rows:240px 1fr}
.service-card img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.service-card .content{padding:20px}
.service-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.pill{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.86rem;color:var(--muted)}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.contact-stack{display:grid;gap:14px}
.contact-card a{font-weight:700}
.contact-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.footer{padding:24px 0 34px;color:var(--muted)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.small{font-size:.94rem}
.map-box{min-height:280px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:linear-gradient(135deg, rgba(47,42,40,.12), rgba(255,255,255,.65));display:grid;place-items:center;color:var(--muted);padding:24px;text-align:center}
.note{font-size:.92rem;color:var(--muted);line-height:1.7}
@media (max-width: 960px){
  .hero-grid,.feature,.contact-layout,.cards-3,.cards-2{grid-template-columns:1fr}
  .section-head{align-items:start;flex-direction:column}
  .hero h1{max-width:14ch}
  .hero-collage{grid-template-columns:1fr 1fr;grid-template-rows:200px 160px}
  .span-7,.span-6,.span-5,.span-4,.span-3{grid-column:span 1}
}
@media (max-width: 640px){
  .header-inner{flex-wrap:wrap}
  .nav{order:3;width:100%;justify-content:flex-start}
  .header-cta{display:none}
  .hero{padding-top:30px}
  .hero-collage{grid-template-columns:1fr;grid-template-rows:auto}
  .hero-collage .tile.big{grid-row:auto;min-height:260px}
}
.footer-logo{
    width:550px;
    height:auto;
    margin:0 auto 20px auto;
}
.hero-panel{
  display:flex;
  align-items:center;
  justify-content:center;
  width:auto;
  margin:0;
}

.hero-logo{
  width:min(520px, 100%);
  height:auto;
  display:block;
  background:none;
  border:0;
  box-shadow:none;
  border-radius:0;
  object-fit:contain;
}
.hero-panel{
    width:1000px;
    height:auto;
    margin:0 auto 20px auto;
}
.sub-info{
  font-size:0.9rem;
  color:var(--muted);
  font-style:italic;
  margin-top:6px;
  margin-bottom:12px;
}
.hero-centered{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

.hero-centered .eyebrow{
  display:block;
  width:fit-content;
  margin:0 auto 16px auto;
}

.hero-centered h1{
  margin-left:auto;
  margin-right:auto;
}

.hero-centered .hero-actions{
  justify-content:center;
}