/* ── JOHNSON RANCH LANDWORKS — SHARED STYLES ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400;1,600&family=DM+Mono:wght@300;400;500&family=Lato:wght@300;400;700&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}

:root{
  --navy:#3a1f0d;
  --navy-dark:#2a1508;
  --copper:#7a3b10;
  --copper-lt:#9a4e1a;
  --cream:#f5f0e8;
  --bone:#fdfaf4;
  --stone:#ede5d8;
  --warm:#6b3210;
  --charcoal:#2a1a0e;
  --ghost:rgba(42,26,14,.45);
  --border:rgba(58,31,13,.13);
  --border-warm:rgba(122,59,16,.22);
  --serif:'Cormorant Garamond',serif;
  --mono:'DM Mono',monospace;
  --sans:'Lato',sans-serif;
}

body{
  font-family:var(--serif);font-size:16px;
  background:var(--cream);color:var(--charcoal);
  min-height:100vh;
}

/* ── NAV ── */
.nav{
  background:var(--navy);
  padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  height:68px;border-bottom:3px solid var(--copper);
  position:sticky;top:0;z-index:100;
}
.nav-brand{display:flex;align-items:center;gap:0;text-decoration:none;}
.nav-brand img{
  height:54px;width:auto;
  filter:brightness(0) invert(1);
  opacity:.9;
}
.nav-icon{display:none;}
.nav-name{display:none;}
.nav-sub{display:none;}
.nav-links{display:flex;gap:0;list-style:none;}
.nav-links a{
  font-family:var(--mono);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:rgba(255,255,255,.65);
  text-decoration:none;padding:0 16px;line-height:68px;
  transition:color .2s,background .2s;border-left:1px solid rgba(255,255,255,.06);
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.05);}
.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:var(--navy);
  background:var(--copper);padding:9px 18px;
  text-decoration:none;transition:background .2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--copper-lt);}
.mob-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.mob-btn span{display:block;width:20px;height:1.5px;background:rgba(255,255,255,.5);transition:all .3s;}
.mob-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.mob-btn.open span:nth-child(2){opacity:0;}
.mob-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* Mobile nav */
.mob-nav{
  display:none;position:fixed;inset:0;z-index:99;
  background:rgba(26,39,68,.98);backdrop-filter:blur(12px);
  flex-direction:column;justify-content:center;padding:0 36px;
}
.mob-nav.open{display:flex;}
.mob-nav ul{list-style:none;}
.mob-nav li{border-bottom:1px solid rgba(255,255,255,.07);}
.mob-nav a{
  font-family:var(--serif);font-size:34px;font-weight:300;font-style:italic;
  color:rgba(255,255,255,.55);text-decoration:none;display:block;
  padding:14px 0;transition:color .2s;
}
.mob-nav a:hover{color:var(--copper);}
.mob-nav-cta{
  margin-top:24px;display:inline-block;
  font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;
  color:var(--navy);background:var(--copper);padding:13px 24px;text-decoration:none;
}

/* ── FOOTER ── */
.footer{
  background:var(--navy);padding:48px 40px 40px;
  border-top:3px solid var(--copper);
  margin-top:80px;
}
.footer-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  margin-bottom:40px;
}
.footer-brand .nav-name{color:#fff;font-size:22px;}
.footer-brand .nav-sub{color:rgba(255,255,255,.55);font-size:12px;}
.footer-brand p{
  font-family:var(--serif);font-style:italic;font-size:13px;
  color:rgba(255,255,255,.6);line-height:1.7;margin-top:12px;
}
.footer-col h4{
  font-family:var(--mono);font-size:13px;letter-spacing:1px;
  text-transform:uppercase;color:var(--copper);margin-bottom:14px;
}
.footer-col a,.footer-col p{
  font-family:var(--serif);font-size:13px;color:rgba(255,255,255,.4);
  text-decoration:none;display:block;line-height:1;margin-bottom:10px;
  transition:color .2s;
}
.footer-col a:hover{color:rgba(255,255,255,.8);}
.footer-bottom{
  max-width:1100px;margin:0 auto;
  padding-top:20px;border-top:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
}
.footer-bottom p{
  font-family:var(--mono);font-size:12px;letter-spacing:1px;
  color:rgba(255,255,255,.65);
}
.footer-bottom a{color:rgba(106,181,168,.4);text-decoration:none;}

/* ── UTILS ── */
.container{max-width:1100px;margin:0 auto;padding:0 40px;}
.section{padding:80px 0;}
.section-label{
  font-family:var(--mono);font-size:13px;letter-spacing:4px;
  text-transform:uppercase;color:var(--copper);
  display:flex;align-items:center;gap:12px;margin-bottom:12px;
}
.section-label::before{content:'';width:18px;height:1px;background:var(--copper);}
.section-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(32px,4vw,52px);line-height:1.05;
  color:var(--navy);letter-spacing:-.5px;margin-bottom:10px;
}
.section-h em{color:var(--copper);font-style:italic;}
.section-sub{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(15px,1.5vw,18px);color:var(--ghost);
  line-height:1.65;max-width:560px;
}
.divider{width:48px;height:2px;background:var(--copper);margin:20px 0;}

/* ── BUTTONS ── */
.btn{
  display:inline-block;font-family:var(--mono);font-size:12px;
  letter-spacing:2.5px;text-transform:uppercase;text-decoration:none;
  padding:13px 26px;transition:all .2s;cursor:pointer;border:none;
}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--copper);}
.btn-copper{background:var(--copper);color:var(--navy);}
.btn-copper:hover{background:var(--copper-lt);}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--border);}
.btn-outline:hover{background:var(--navy);color:#fff;border-color:var(--navy);}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3);}
.btn-outline-white:hover{background:#fff;color:var(--navy);}

/* ── CARDS ── */
.card{background:var(--bone);border:1px solid var(--border);}
.card-img{width:100%;height:220px;object-fit:cover;display:block;background:var(--stone);}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none;}
  .mob-btn{display:flex;}
  .nav{padding:0 20px;}
  .container{padding:0 20px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
  .section{padding:56px 0;}
}
