/* Broom Farm Small Animal Retreat — static site styles */
:root{
  --green:#5b7a4f;
  --green-dark:#3f5837;
  --cream:#f7f4ec;
  --sand:#efe9da;
  --ink:#33352f;
  --muted:#6b6f63;
  --accent:#c98a3a;
  --max:1080px;
  --radius:12px;
  --shadow:0 4px 18px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-dark)}

/* Header / nav */
.site-header{
  background:#fff;
  border-bottom:3px solid var(--green);
  position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,.05);
}
.header-inner{
  max-width:var(--max);margin:0 auto;padding:.6rem 1rem;
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--green-dark)}
.brand img{width:54px;height:auto}
.brand .name{font-weight:700;font-size:1.05rem;line-height:1.2;letter-spacing:.02em}
.header-contact{margin-left:auto;text-align:right;font-size:.85rem;color:var(--muted)}
.header-contact a{color:var(--green-dark);text-decoration:none}
.header-contact strong{color:var(--ink)}

.nav-toggle{
  display:none;background:var(--green);color:#fff;border:0;
  padding:.55rem .9rem;border-radius:8px;font-size:1rem;cursor:pointer;margin-left:auto;
}
nav.main-nav{width:100%;border-top:1px solid var(--sand)}
nav.main-nav ul{
  list-style:none;margin:0;padding:.4rem 0;
  display:flex;flex-wrap:wrap;gap:.2rem;justify-content:center;
}
nav.main-nav a{
  text-decoration:none;color:var(--ink);font-size:.9rem;
  padding:.45rem .7rem;border-radius:8px;display:block;
}
nav.main-nav a:hover{background:var(--sand)}
nav.main-nav a.active{background:var(--green);color:#fff}

/* Hero */
.hero{
  position:relative;color:#fff;text-align:center;
  padding:4.5rem 1rem;background:var(--green-dark);
  background-size:cover;background-position:center;
}
.hero::before{content:"";position:absolute;inset:0;background:rgba(40,55,35,.55)}
.hero > *{position:relative}
.hero h1{margin:0 0 .4rem;font-size:2.2rem;letter-spacing:.03em}
.hero p{margin:0;font-size:1.2rem;opacity:.95}

/* Layout */
main{max-width:var(--max);margin:0 auto;padding:2.2rem 1rem 3rem}
.page-title{color:var(--green-dark);font-size:1.9rem;margin:.2rem 0 1.2rem;border-bottom:2px solid var(--sand);padding-bottom:.5rem}
h2{color:var(--green-dark)}
h3{color:var(--green-dark);margin-bottom:.3rem}
.lead{font-size:1.12rem;color:var(--muted)}
.notice{
  background:#fff6e8;border:1px solid #f0d9ab;border-left:4px solid var(--accent);
  padding:.8rem 1rem;border-radius:8px;margin:1.2rem 0;font-weight:600;
}

.card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;
}
.card .body{padding:1.1rem 1.2rem}
.card img{width:100%;aspect-ratio:4/3;object-fit:cover}

.grid{display:grid;gap:1.4rem}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}

.split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin:1.5rem 0}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}

figure{margin:0}
figure figcaption{font-size:.85rem;color:var(--muted);text-align:center;margin-top:.3rem}

.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}
.gallery img{border-radius:8px;box-shadow:var(--shadow);aspect-ratio:1;object-fit:cover}

blockquote{
  background:#fff;border-left:4px solid var(--green);margin:1.2rem 0;
  padding:1rem 1.3rem;border-radius:8px;box-shadow:var(--shadow);font-style:italic;
}
blockquote cite{display:block;margin-top:.6rem;font-style:normal;font-weight:700;color:var(--green-dark)}

.price-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:1rem 0}
.price-table th,.price-table td{padding:.6rem .9rem;text-align:left;border-bottom:1px solid var(--sand);overflow-wrap:break-word}
.price-table th{background:var(--green);color:#fff}
.price-table td:last-child{text-align:right;font-weight:600;white-space:nowrap}
.price-table tr.section td{background:var(--sand);font-weight:700;color:var(--green-dark);text-align:left;white-space:normal}

.btn{
  display:inline-block;background:var(--green);color:#fff;text-decoration:none;
  padding:.7rem 1.3rem;border-radius:8px;font-weight:600;margin:.3rem .3rem .3rem 0;
}
.btn:hover{background:var(--green-dark)}
.btn.accent{background:var(--accent)}

ul.ticks{list-style:none;padding-left:0}
ul.ticks li{padding-left:1.6rem;position:relative;margin:.35rem 0}
ul.ticks li::before{content:"\2713";position:absolute;left:0;color:var(--green);font-weight:700}

/* Contact form */
.contact-form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem;max-width:560px}
.contact-form label{display:block;font-weight:600;margin:.7rem 0 .25rem}
.contact-form input,.contact-form textarea{
  width:100%;padding:.6rem;border:1px solid #ccc;border-radius:8px;font:inherit;
}

/* Booking form */
.hidden-field{position:absolute;left:-9999px;height:0;overflow:hidden}
.booking-form{max-width:720px}
.booking-form fieldset{
  background:#fff;border:1px solid var(--sand);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.1rem 1.3rem 1.4rem;margin:0 0 1.3rem;
}
.booking-form legend{
  font-weight:700;color:var(--green-dark);font-size:1.1rem;padding:0 .4rem;
}
.booking-form label{display:block;font-weight:600;margin:.8rem 0 .25rem}
.booking-form input[type=text],
.booking-form input[type=email],
.booking-form input[type=tel],
.booking-form input[type=date],
.booking-form textarea{
  width:100%;padding:.6rem;border:1px solid #ccc;border-radius:8px;font:inherit;background:#fff;
}
.booking-form input:focus,.booking-form textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(91,122,79,.15);
}
.booking-form textarea{resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.req{color:var(--accent)}
.optional{font-weight:400;font-size:.85rem;color:var(--muted)}
.field-help{font-size:.88rem;color:var(--muted);margin:.15rem 0 .35rem}
.radio-label{display:block;font-weight:600;margin:.8rem 0 .25rem}
.radio-row{display:flex;gap:1.4rem;flex-wrap:wrap;margin:.2rem 0}
.radio-row label,.check-line{font-weight:400;display:flex;align-items:flex-start;gap:.5rem;margin:.2rem 0}
.check-line{font-weight:600}
.radio-row input,.check-line input{width:auto;margin-top:.2rem}
.agreement-box{
  max-height:180px;overflow-y:auto;background:var(--cream);border:1px solid var(--sand);
  border-radius:8px;padding:.9rem 1rem;font-size:.9rem;line-height:1.6;
}
@media(max-width:680px){.form-row{grid-template-columns:1fr}}

/* Footer */
.site-footer{background:var(--green-dark);color:#e9efe2;margin-top:2rem}
.footer-inner{max-width:var(--max);margin:0 auto;padding:2rem 1rem;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}
.site-footer a{color:#fff}
.site-footer h4{margin:.2rem 0 .6rem;color:#fff}
.footer-bottom{text-align:center;padding:.8rem;font-size:.8rem;background:rgba(0,0,0,.18)}

@media(max-width:820px){
  .grid.cols-3{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
}
@media(max-width:680px){
  .nav-toggle{display:block}
  nav.main-nav{display:none}
  nav.main-nav.open{display:block}
  nav.main-nav ul{flex-direction:column}
  .header-contact{display:none}
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  .hero h1{font-size:1.7rem}
}
