/* ============================================================
   Rod Timber Products — Bold Timber Editorial
   Warm paper, espresso ink, timber tones, Outfit display
   ============================================================ */

:root{
  --paper:#f3f5ef;
  --paper-2:#e7ece1;
  --card:#ffffff;
  --ink:#2b2f31;           /* brand charcoal (TIMBER grey) */
  --ink-2:#5b6164;
  --timber:#0b9444;        /* brand green (from logo) */
  --timber-deep:#00792e;   /* deepest ROD green */
  --amber:#2fa653;         /* medium green highlight */
  --sage:#5b6164;          /* charcoal accent */
  --line:rgba(43,47,49,.14);
  --shadow:0 24px 60px -28px rgba(43,47,49,.4);
  --shadow-sm:0 10px 30px -16px rgba(43,47,49,.38);
  --wrap:1160px;
  --display:"Outfit", system-ui, sans-serif;
  --body:"Figtree", system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* subtle paper grain */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:1;
  opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--wrap); margin:0 auto; padding:0 24px; position:relative; z-index:2}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

h1,h2,h3{font-family:var(--display); font-weight:700; line-height:1.06; letter-spacing:-.03em; margin:0}
h1{font-size:clamp(2.5rem,5.8vw,4.6rem); line-height:1.02}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
h3{font-size:1.4rem; letter-spacing:-.02em}
p{margin:0 0 1rem}

.eyebrow{
  font-family:var(--body); font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  font-size:.74rem; color:var(--timber);
  display:inline-flex; align-items:center; gap:.6rem;
}
.eyebrow::before{content:""; width:30px; height:2px; background:var(--timber); display:inline-block}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--body); font-weight:700; font-size:1rem;
  padding:.95rem 1.6rem; border-radius:2px;
  border:1.5px solid var(--ink);
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, color .25s, box-shadow .25s;
  cursor:pointer;
}
.btn-primary{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.btn-primary:hover{background:var(--timber); border-color:var(--timber); transform:translateY(-3px); box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent; color:var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--paper); transform:translateY(-3px)}
.btn svg{width:17px; height:17px}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex; align-items:center; justify-content:space-between; height:78px}
.brand{display:flex; align-items:center; gap:.7rem; font-family:var(--display); font-weight:700; font-size:1.3rem; letter-spacing:-.02em; line-height:1.05}
.brand-logo{height:50px; width:auto; display:block}
.brand .mark{
  width:38px; height:38px; border-radius:3px; flex:0 0 auto;
  background:linear-gradient(135deg,var(--timber),var(--timber-deep));
  display:grid; place-items:center; color:var(--paper); font-weight:700; font-size:1.1rem;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);
}
.brand small{display:block; font-family:var(--body); font-weight:600; font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--timber); margin-top:1px}
.nav{display:flex; align-items:center; gap:2rem}
.nav a{font-weight:600; font-size:.98rem; position:relative; padding:.2rem 0}
.nav a:not(.btn)::after{content:""; position:absolute; left:0; bottom:-3px; height:2px; width:0; background:var(--timber); transition:width .25s}
.nav a:not(.btn):hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav .btn{padding:.6rem 1.15rem}
.nav-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px}
.nav-toggle span{display:block; width:26px; height:2px; background:var(--ink); margin:5px 0; transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative; padding:clamp(2.4rem,5vw,4.5rem) 0 clamp(2.6rem,5vw,4rem)}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,3.6rem); align-items:center}
.hero h1 .accent{color:var(--timber)}
.hero .lead{font-size:1.18rem; color:var(--ink-2); max-width:32ch; margin:1.5rem 0 2rem}
.hero-cta{display:flex; gap:1rem; flex-wrap:wrap}
.hero-meta{display:flex; gap:clamp(1.4rem,3vw,2.4rem); margin-top:2.2rem; padding-top:1.6rem; border-top:1px solid var(--line)}
.hero-meta>div{flex:1 1 0; min-width:0}
.hero-meta .n{font-family:var(--display); font-size:clamp(1.7rem,3vw,2.1rem); font-weight:700; color:var(--timber); line-height:1; letter-spacing:-.02em}
.hero-meta .l{font-size:.8rem; color:var(--ink-2); margin-top:.35rem}

/* media frame (placeholder-ready) */
.frame{
  position:relative; border-radius:4px; overflow:hidden;
  box-shadow:var(--shadow);
}
.frame.tall{aspect-ratio:4/5}
.frame.wide{aspect-ratio:16/11}
.frame.square{aspect-ratio:1/1}
.ph{
  position:absolute; inset:0;
  background:
    linear-gradient(115deg, rgba(255,255,255,.06) 0 8%, transparent 8% 16%) ,
    repeating-linear-gradient(92deg, var(--timber-deep) 0 7px, #065d24 7px 9px, var(--timber) 9px 26px, #0a8a40 26px 30px),
    var(--timber);
  display:flex; align-items:flex-end; padding:18px;
}
.ph::after{content:attr(data-label); font-family:var(--body); font-weight:600; font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.85); background:rgba(42,32,23,.4); padding:.3rem .6rem; border-radius:2px; backdrop-filter:blur(2px)}
.frame img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0}

/* full-bleed banner */
.banner-full{width:100%; line-height:0; position:relative; z-index:2}
.banner-full img{width:100%; height:clamp(240px,40vw,540px); object-fit:cover; object-position:center 45%; display:block}

.hero-frame{position:relative}
.hero-badge{
  position:absolute; bottom:-22px; left:-22px; z-index:3;
  background:var(--card); border:1px solid var(--line); border-radius:4px;
  padding:1rem 1.2rem; box-shadow:var(--shadow-sm); max-width:210px;
}
.hero-badge .stars{color:#e3a72f; letter-spacing:2px; font-size:.9rem}
.hero-badge strong{display:block; font-family:var(--display); font-size:1.05rem; margin-top:.2rem}
.hero-badge span{font-size:.78rem; color:var(--ink-2)}

/* ---------- Section scaffolding ---------- */
section{position:relative; z-index:2}
.band{padding:clamp(3rem,6vw,5rem) 0}
.band.dark{background:var(--ink); color:var(--paper)}
.band.dark .eyebrow{color:var(--amber)}
.band.dark .eyebrow::before{background:var(--amber)}
.band.timber{background:linear-gradient(160deg,var(--timber-deep),var(--timber)); color:#fff}
.band.timber .eyebrow{color:#fff}
.band.timber .eyebrow::before{background:#fff}
.band.timber .feat-list svg{color:#fff}
.sec-head{max-width:62ch}
.sec-head p{color:var(--ink-2); font-size:1.12rem; margin-top:1rem}
.band.dark .sec-head p{color:rgba(238,242,236,.8)}
.center{text-align:center; margin-inline:auto}

/* ---------- Services ---------- */
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.4rem}
.svc{
  background:var(--card); border:1px solid var(--line); border-radius:4px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .3s, box-shadow .3s;
}
.svc:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.svc .frame{border-radius:0; box-shadow:none}
.svc-body{padding:1.6rem 1.5rem 1.8rem}
.svc-body h3{margin-bottom:.5rem}
.svc-body p{font-size:.98rem; color:var(--ink-2); margin-bottom:1.1rem}
.svc-link{font-weight:700; color:var(--timber); font-size:.92rem; display:inline-flex; align-items:center; gap:.4rem}
.svc-link svg{width:15px; transition:transform .25s}
.svc:hover .svc-link svg{transform:translateX(4px)}
.svc-num{font-family:var(--display); font-size:.95rem; color:var(--amber); font-weight:600}

/* ---------- Feature / split ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center}
.split.flip .split-media{order:2}
.feat-list{list-style:none; padding:0; margin:1.8rem 0 0; display:grid; gap:1.1rem}
.feat-list li{display:flex; gap:.9rem; align-items:flex-start; font-size:1.02rem}
.feat-list svg{flex:0 0 auto; width:24px; height:24px; color:var(--timber); margin-top:2px}
.band.dark .feat-list svg{color:var(--amber)}

/* ---------- Stats strip ---------- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center}
.stats .n{font-family:var(--display); font-size:clamp(2.4rem,5vw,3.6rem); font-weight:600; line-height:1; color:#fff}
.stats .l{font-size:.86rem; opacity:.85; margin-top:.5rem}

/* ---------- Gallery ---------- */
.masonry{columns:3; column-gap:1.1rem; margin-top:2.8rem}
.masonry .frame{margin-bottom:1.1rem; break-inside:avoid; box-shadow:var(--shadow-sm)}
.masonry .frame:nth-child(3n+1){aspect-ratio:4/5}
.masonry .frame:nth-child(3n+2){aspect-ratio:1/1}
.masonry .frame:nth-child(3n){aspect-ratio:4/3}

/* ---------- Areas ---------- */
.areas{display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.8rem}
.area-pill{
  display:inline-flex; align-items:center; gap:.45rem;
  border:1px solid var(--line); background:var(--card);
  padding:.55rem 1rem .55rem .85rem; border-radius:50px; font-weight:600; font-size:.92rem;
  transition:background .25s,color .25s,transform .25s,box-shadow .25s;
}
.area-pill .pin{width:14px; height:14px; color:var(--timber); transition:color .25s; flex:0 0 auto}
.area-pill:hover{background:var(--timber); color:#fff; border-color:var(--timber); transform:translateY(-2px); box-shadow:var(--shadow-sm)}
.area-pill:hover .pin{color:#fff}

/* ---------- CTA ---------- */
.cta-box{
  background:linear-gradient(160deg,var(--timber-deep),var(--timber));
  color:#fff; border-radius:6px; padding:clamp(2.5rem,5vw,4.5rem);
  text-align:center; box-shadow:var(--shadow); position:relative; overflow:hidden;
}
.cta-box::after{content:""; position:absolute; inset:0; opacity:.12; pointer-events:none; background:repeating-linear-gradient(45deg,#000 0 2px,transparent 2px 22px)}
.cta-box h2,.cta-box p,.cta-box .btn{position:relative; z-index:2}
.cta-box p{max-width:46ch; margin:1rem auto 2rem; opacity:.9; font-size:1.15rem}
.cta-box .btn-primary{background:#fff; color:var(--ink); border-color:#fff}
.cta-box .btn-primary:hover{background:var(--ink); color:#fff; border-color:var(--ink)}

/* ---------- Form ---------- */
.form-card{background:var(--card); border:1px solid var(--line); border-radius:6px; padding:clamp(1.8rem,4vw,3rem); box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.3rem}
.field label{display:block; font-weight:700; font-size:.86rem; margin-bottom:.45rem; letter-spacing:.02em}
.field input,.field select,.field textarea{
  width:100%; font-family:var(--body); font-size:1rem; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--line); border-radius:3px;
  padding:.85rem 1rem; transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--timber); box-shadow:0 0 0 4px rgba(154,80,36,.12)}
.field textarea{resize:vertical; min-height:130px}
.two-col{display:grid; grid-template-columns:1fr 1fr; gap:1.3rem}
.contact-list{list-style:none; padding:0; margin:2rem 0 0; display:grid; gap:1.4rem}
.contact-list li{display:flex; gap:1rem; align-items:flex-start}
.contact-list .ico{width:44px; height:44px; flex:0 0 auto; border-radius:3px; background:var(--paper-2); display:grid; place-items:center; color:var(--timber)}
.contact-list .ico svg{width:20px;height:20px}
.contact-list b{display:block; font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-2)}
.contact-list a,.contact-list span{font-family:var(--display); font-size:1.15rem}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:var(--ink); color:var(--paper); padding:clamp(3rem,7vw,5rem) 0 clamp(2.6rem,5vw,4rem)}
.page-hero .eyebrow{color:var(--amber)}
.page-hero .eyebrow::before{background:var(--amber)}
.page-hero p{color:rgba(238,242,236,.8); font-size:1.15rem; max-width:54ch; margin-top:1rem}
.crumb{font-size:.85rem; color:rgba(238,242,236,.6); margin-bottom:1.4rem}
.crumb a:hover{color:var(--amber)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink); color:rgba(238,242,236,.75); padding:4rem 0 2rem; margin-top:0}
.foot-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.5rem}
.site-footer .brand{color:var(--paper); display:inline-block}
.foot-logo{height:60px; width:auto; display:block; background:#fff; padding:9px 13px; border-radius:8px}
.site-footer h4{font-family:var(--body); font-size:.8rem; text-transform:uppercase; letter-spacing:.16em; color:var(--amber); margin:0 0 1rem}
.site-footer ul{list-style:none; padding:0; margin:0; display:grid; gap:.6rem}
.site-footer a:hover{color:var(--paper)}
.foot-about{max-width:34ch; font-size:.95rem; margin-top:1rem}
.foot-bottom{border-top:1px solid rgba(238,242,236,.14); margin-top:3rem; padding-top:1.5rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.85rem; color:rgba(238,242,236,.55)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none}}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav{position:fixed; inset:78px 0 auto 0; flex-direction:column; align-items:flex-start; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:1rem 24px 1.6rem; transform:translateY(-130%); transition:transform .35s; box-shadow:var(--shadow-sm)}
  .nav.open{transform:none}
  .nav a{width:100%; padding:.85rem 0; border-bottom:1px solid var(--line); font-size:1.05rem}
  .nav a:not(.btn)::after{display:none}
  .nav .btn{margin-top:1rem; width:100%; justify-content:center; padding:.9rem}
  .nav-toggle{display:block}
  .hero-grid,.split,.split.flip .split-media{grid-template-columns:1fr; order:0}
  .split-media{order:-1}
  .svc-grid{grid-template-columns:1fr}
  .masonry{columns:2}
  .stats{grid-template-columns:1fr 1fr; gap:2.4rem 1rem}
  .foot-grid{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .hero-badge{position:static; margin-top:1.2rem; max-width:none}
}
@media (max-width:540px){
  body{font-size:17px}
  .brand-logo{height:42px}
  .masonry{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .hero-meta{flex-wrap:wrap; gap:1.4rem}
}
