
:root{
  --bg:#FCF9F6;           /* soft cream */
  --ink:#3E2C23;          /* rich brown */
  --muted:#7B6A60;        /* muted warm brown */
  --soft:#F5ECE6;         /* light cream blush */
  --line:#E4D6CC;         /* light warm line */
  --brand:#8B5E3C;        /* medium warm brown */
  --brand-ink:#6F4325;    /* darker warm brown */
  --radius:16px;
  --shadow: 0 8px 20px rgba(0,0,0,.05);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.65;
}

.container{max-width:1120px; margin:0 auto; padding:0 20px}

.site-header{
  position:sticky; top:0; z-index:10; background:rgba(252,249,246,0.95); backdrop-filter: blur(6px);
  border-bottom:1px solid var(--line);
}
.site-header .container{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 20px}
.brand img,.brand svg{height:50px; display:block}

.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--ink); text-decoration:none; font-weight:600}
.nav a:hover{color:var(--brand-ink)}
.nav .btn{margin-left:8px}

.nav-toggle{display:none; font-size:24px; background:none; border:none}

.hero{
  padding:96px 0; 
  background:linear-gradient(180deg, rgba(252,249,246,1) 0%, rgba(245,236,230,1) 100%);
}
.hero h1{font-size:52px; line-height:1.1; margin:0 0 12px}
.hero p{font-size:18px; color:var(--muted); margin:0 0 24px}
.cta-row{display:flex; gap:12px; flex-wrap:wrap}
.badges{display:flex; gap:8px; list-style:none; padding:0; margin:18px 0 0}
.badges li{border:1px solid var(--line); padding:6px 12px; border-radius:999px; font-size:14px; color:var(--ink); background:#fff}

.section{padding:80px 0}
.section.alt{background:var(--soft)}
.section h2{font-size:36px; margin:0 0 18px}

.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.card{border:1px solid var(--line); border-radius:var(--radius); padding:22px; background:#fff; box-shadow:var(--shadow)}
.card.highlight{outline:2px solid var(--brand); outline-offset:-2px}
.card h3{margin:0 0 8px; color:var(--brand-ink)}
.list{margin:10px 0 0 16px}

.grid-gallery{
  display:grid; grid-template-columns:repeat(4,1fr); gap:12px
}
.grid-gallery figure{margin:0; border-radius:14px; overflow:hidden; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow)}
.grid-gallery img{width:100%; display:block; aspect-ratio:1/1; object-fit:cover}
.grid-gallery figcaption{font-size:14px; color:var(--ink); padding:10px 12px; background:var(--soft)}

.contact-form{display:grid; gap:12px; max-width:720px; margin:0 auto}
.contact-form .row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.contact-form label{display:grid; gap:6px; font-weight:600; font-size:14px}
.contact-form input, .contact-form textarea, .contact-form select{
  border:1px solid var(--line); border-radius:12px; padding:12px; font:inherit; background:#fff
}
.contact-form button{box-shadow:var(--shadow)}
.small{font-size:14px; color:var(--muted)}
.center{text-align:center}
.hint{color:var(--muted); font-size:14px; margin-top:10px}

.btn{display:inline-block; padding:12px 18px; border-radius:12px; border:2px solid var(--brand); text-decoration:none; color:#fff; background:var(--brand); font-weight:800}
.btn:hover{background:var(--brand-ink)}
.btn-sm{padding:8px 12px; font-weight:700; border:2px solid var(--brand); border-radius:999px; color:var(--brand); background:#fff}
.btn.btn-outline{background:#fff; color:var(--brand)}

.site-footer{border-top:1px solid var(--line); padding:32px 0; background:#fff}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:18px; align-items:start}
.footer-logo{height:40px; display:block; margin-bottom:10px}
.copyright{text-align:center; color:var(--muted); font-size:14px; margin:10px 0 0}

@media (max-width: 900px){
  .cards{grid-template-columns:1fr}
  .grid-gallery{grid-template-columns:repeat(2,1fr)}
  .contact-form .row{grid-template-columns:1fr}
  .nav{display:none}
  .nav.open{display:flex; flex-direction:column; position:absolute; top:64px; right:10px; background:#fff; border:1px solid var(--line); padding:12px; border-radius:12px; box-shadow:var(--shadow)}
  .nav-toggle{display:block}
  .hero{padding:64px 0}
  .hero h1{font-size:38px}
}
