/* ============================================================
   Landmeterskop Farm Cottages — interim site
   Warm, traditional Overberg sheep-farm character.
   Deliberately homely (not the Rauthin rebrand look).
   ============================================================ */
:root{
  --green:#3f5d42;        /* sheep-pasture green */
  --green-dk:#2f4632;
  --wheat:#c9a14a;        /* harvest gold */
  --cream:#f7f3e9;        /* paper cream */
  --paper:#fffdf8;
  --ink:#33312c;          /* warm near-black text */
  --mute:#6f6a60;
  --line:#e4dcc8;
  --sky:#7fa6b0;          /* dam/sky accent */
  --maxw:1140px;
  --serif:Georgia,'Times New Roman',serif;
  --sans:'Segoe UI',system-ui,-apple-system,Helvetica,Arial,sans-serif;
  --shadow:0 8px 26px -14px rgba(47,70,50,.4);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--wheat)}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.18;color:var(--green-dk)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:clamp(40px,6vw,68px) 0}

/* ---------- HEADER ---------- */
.masthead{background:var(--green-dk);color:var(--cream);text-align:center;padding:26px 18px 20px}
.masthead h1{color:var(--cream);font-size:clamp(1.7rem,4vw,2.5rem);margin:0;letter-spacing:.02em}
.masthead .tag{color:var(--wheat);font-style:italic;font-family:var(--serif);font-size:1.05rem;margin-top:4px}
.masthead .contact{font-size:.86rem;color:rgba(247,243,233,.85);margin-top:12px;line-height:1.7}
.masthead .contact a{color:var(--cream);border-bottom:1px solid rgba(201,161,74,.6)}
.masthead .contact a:hover{color:var(--wheat)}

nav.bar{background:var(--green);position:sticky;top:0;z-index:50;box-shadow:0 2px 10px rgba(0,0,0,.12)}
nav.bar .inner{display:flex;flex-wrap:wrap;justify-content:center;gap:2px;max-width:var(--maxw);margin:0 auto;padding:0 10px}
nav.bar a{color:var(--cream);padding:13px 17px;font-size:.92rem;font-weight:600;letter-spacing:.02em;border-bottom:3px solid transparent;transition:background .2s,border-color .2s}
nav.bar a:hover{background:var(--green-dk);color:#fff}
nav.bar a.active{border-bottom-color:var(--wheat);color:#fff}
.nav-toggle{display:none}

/* ---------- HERO IMAGE ---------- */
.hero{position:relative;height:clamp(300px,46vw,520px);background:var(--green) center/cover no-repeat;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--green),var(--sky));color:rgba(247,243,233,.5);font-family:var(--serif);font-size:1.4rem}
.hero .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 22px;color:#fff;
  background:linear-gradient(transparent,rgba(20,30,22,.78));font-family:var(--serif);font-size:clamp(1.2rem,3vw,1.9rem)}

/* ---------- CONTENT BLOCKS ---------- */
.lead{font-size:1.12rem}
.block h2{font-size:clamp(1.5rem,3.4vw,2.1rem);margin:0 0 16px}
.block h2 .sw{color:var(--wheat)}
.block p{margin:0 0 16px;max-width:72ch}
.eyebrow{display:inline-block;font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--wheat);margin-bottom:8px}
.rule{height:3px;width:64px;background:var(--wheat);border:0;margin:0 0 22px;border-radius:2px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}
.split.flip .txt{order:2}
.frame{border-radius:8px;overflow:hidden;box-shadow:var(--shadow);background:var(--paper);aspect-ratio:3/2;position:relative}
.frame img{width:100%;height:100%;object-fit:cover}
.frame .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,#eee6d2,#eee6d2 14px,#e7ddc6 14px,#e7ddc6 28px);color:var(--mute);font-family:var(--serif)}

/* ---------- CARDS / LISTS ---------- */
.bg-paper{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bg-green{background:var(--green-dk);color:var(--cream)}
.bg-green h2{color:#fff}
.bg-green .eyebrow{color:var(--wheat)}
.acts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.act{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:22px 24px;box-shadow:var(--shadow)}
.bg-green .act{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16)}
.act h3{margin:0 0 12px;font-size:1.2rem;color:var(--green-dk)}
.bg-green .act h3{color:#fff}
.act ul{margin:0;padding-left:1.1em}
.act li{margin-bottom:7px}
.bg-green .act li{color:rgba(247,243,233,.9)}

/* ---------- COTTAGE CARDS ---------- */
.cottages{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:8px}
.cottage{background:var(--paper);border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.cottage .pic{aspect-ratio:16/10;position:relative;background:linear-gradient(135deg,var(--green),var(--sky))}
.cottage .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cottage .pic .lab{position:absolute;left:0;bottom:0;background:rgba(47,70,50,.85);color:#fff;font-family:var(--serif);padding:7px 14px;font-size:1.05rem}
.cottage .body{padding:20px 22px;flex:1}
.cottage h3{margin:0 0 6px;font-size:1.35rem}
.cottage .meta{font-size:.85rem;color:var(--wheat);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.cottage p{margin:0 0 10px;font-size:.97rem}

/* ---------- RATES ---------- */
.rates{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px}
.rate{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:24px 26px;box-shadow:var(--shadow)}
.rate h3{margin:0 0 14px;font-size:1.3rem;border-bottom:2px solid var(--wheat);padding-bottom:10px}
.rate .row{display:flex;justify-content:space-between;gap:14px;padding:6px 0;border-bottom:1px dotted var(--line)}
.rate .row .lbl{color:var(--mute)}
.rate .row .amt{font-weight:700;color:var(--green-dk);white-space:nowrap}
.rate .fine{font-size:.84rem;color:var(--mute);margin-top:14px;line-height:1.6}
.rate .fine strong{color:var(--green-dk)}

/* ---------- DIRECTIONS ---------- */
.dir{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:8px}
.dir-card{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:22px 26px;box-shadow:var(--shadow)}
.dir-card h3{margin:0 0 12px;font-size:1.2rem}
.gps{background:var(--green-dk);color:var(--cream);border-radius:10px;padding:20px 26px;text-align:center;margin-top:24px;font-family:var(--serif);font-size:1.1rem}
.gps span{color:var(--wheat)}

/* ---------- CTA / BUTTONS ---------- */
.btn{display:inline-block;background:var(--wheat);color:#3a2d10;font-weight:700;padding:14px 30px;border-radius:6px;
  font-family:var(--sans);letter-spacing:.02em;border:2px solid var(--wheat);transition:all .2s;cursor:pointer}
.btn:hover{background:#b8902f;border-color:#b8902f;color:#fff;transform:translateY(-2px)}
.btn-out{background:transparent;color:var(--cream);border-color:rgba(247,243,233,.6)}
.btn-out:hover{background:var(--cream);color:var(--green-dk);border-color:var(--cream)}
.cta-band{background:var(--green);color:var(--cream);text-align:center}
.cta-band h2{color:#fff;margin:0 0 10px}
.cta-band p{color:rgba(247,243,233,.9);max-width:60ch;margin:0 auto 22px}

/* ---------- FOOTER ---------- */
footer{background:var(--green-dk);color:rgba(247,243,233,.85);padding:34px 22px;text-align:center;font-size:.9rem}
footer a{color:var(--cream)}
footer .fcontact{margin:10px 0;line-height:1.8}
footer .sm{font-size:.8rem;color:rgba(247,243,233,.55);margin-top:14px}

/* ---------- WHATSAPP FAB ---------- */
.wa-fab{position:fixed;right:18px;bottom:18px;z-index:70;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:#25D366;color:#fff;
  box-shadow:0 10px 26px -8px rgba(0,0,0,.4);transition:transform .2s}
.wa-fab:hover{transform:translateY(-3px);color:#fff}

/* ---------- RESPONSIVE ---------- */
@media(max-width:780px){
  .split,.dir{grid-template-columns:1fr}
  .split.flip .txt{order:0}
  .acts{grid-template-columns:1fr}
  .cottages,.rates{grid-template-columns:1fr}
  nav.bar .inner{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
  nav.bar a{white-space:nowrap}
}
