/* Woodwork Handbook — static recreation
   Approximates the "handyman-blocks" WordPress theme. */

:root{
  --wood-dark:#2b1d12;
  --wood:#5a3a22;
  --amber:#d98b2b;
  --amber-dark:#b9711d;
  --cream:#f7f1e7;
  --ink:#2a2521;
  --muted:#6f6457;
  --line:#e6dccb;
  --white:#ffffff;
  --max:1180px;
  --radius:10px;
  --shadow:0 10px 30px rgba(43,29,18,.12);
  --font:"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --head:"Georgia","Times New Roman",serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--white);line-height:1.65;font-size:17px}
img{max-width:100%;height:auto;display:block}
a{color:var(--amber-dark);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
h1,h2,h3,h4{font-family:var(--head);line-height:1.2;color:var(--wood-dark)}
section{padding:64px 0}

/* Buttons */
.btn{display:inline-block;background:var(--amber);color:#fff;border:none;cursor:pointer;
  padding:14px 30px;border-radius:50px;font-weight:700;font-size:16px;letter-spacing:.3px;
  transition:.2s;text-decoration:none}
.btn:hover{background:var(--amber-dark);text-decoration:none;transform:translateY(-1px)}
.btn-outline{background:transparent;border:2px solid #fff;color:#fff}
.btn-outline:hover{background:#fff;color:var(--wood-dark)}
.btn-lg{padding:16px 40px;font-size:18px}

/* Header */
.site-header{background:var(--wood-dark);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.logo img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:28px;margin-left:auto}
.nav a{color:#f3e8d9;font-weight:600}
.nav a:hover{color:#fff;text-decoration:none}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:26px;cursor:pointer}

/* Hero */
.hero{position:relative;color:#fff;text-align:center;padding:120px 0;
  background:linear-gradient(rgba(30,20,12,.66),rgba(30,20,12,.72)),
  url('assets/img/8387a0b8-banner_bg.jpg') center/cover}
.hero h1{color:#fff;font-size:48px;margin:0 0 16px;max-width:860px;margin-inline:auto}
.hero p{font-size:20px;max-width:680px;margin:0 auto 32px;color:#f1e7d8}
.hero .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Page banner (interior) */
.page-banner{position:relative;color:#fff;text-align:center;padding:80px 0;
  background:linear-gradient(rgba(30,20,12,.6),rgba(30,20,12,.7)),
  url('assets/img/8387a0b8-banner_bg.jpg') center/cover}
.page-banner h1{color:#fff;font-size:40px;margin:0}

/* Section heading */
.sec-head{text-align:center;max-width:720px;margin:0 auto 44px}
.sec-head h2{font-size:34px;margin:0 0 12px}
.sec-head p{color:var(--muted);margin:0;font-size:18px}
.bg-cream{background:var(--cream)}

/* Cards grid */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:.2s}
.card:hover{transform:translateY(-4px)}
.card .pad{padding:24px}
.card h3{margin:0 0 10px;font-size:21px}
.card p{margin:0;color:var(--muted);font-size:15.5px}
.card .icon{height:64px;margin:24px 24px 0}
.card img.cover{width:100%;height:200px;object-fit:cover}

/* About / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}
.prose p{margin:0 0 18px}

/* CTA band */
.cta{position:relative;color:#fff;text-align:center;padding:90px 0;
  background:linear-gradient(rgba(30,20,12,.7),rgba(30,20,12,.78)),
  url('assets/img/e7ce243e-ctabg.jpg') center/cover}
.cta h2{color:#fff;font-size:34px;margin:0 0 14px}
.cta p{color:#f1e7d8;margin:0 0 28px;font-size:19px}
.cta .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Testimonials */
.testimonials{background:var(--wood-dark);color:#fff;
  background:linear-gradient(rgba(30,20,12,.86),rgba(30,20,12,.9)),
  url('assets/img/56c5eddf-testimonialbg.jpg') center/cover}
.testimonials h2,.testimonials h3{color:#fff}
.t-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);padding:26px}
.t-card .stars{height:22px;margin-bottom:14px}
.t-card .quote{font-size:15px;color:#f0e7da}
.t-card .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.t-card .who img{width:54px;height:54px;border-radius:50%;object-fit:cover}
.t-card .who b{display:block;color:#fff}
.t-card .who span{font-size:13px;color:#cdbfae}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 26px;margin-bottom:16px}
.faq-item h4{margin:0 0 8px;font-size:18px}
.faq-item p{margin:0;color:var(--muted)}

/* Blog list */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.post-card img{width:100%;height:190px;object-fit:cover}
.post-card .pad{padding:20px}
.post-card .cat{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--amber-dark);font-weight:700}
.post-card h3{font-size:19px;margin:8px 0}
.post-card .date{color:var(--muted);font-size:13px}
.post-card p{color:var(--muted);font-size:14.5px}

/* Article layout */
.article-wrap{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.article h1{font-size:36px;margin:0 0 8px}
.article .meta{color:var(--muted);margin-bottom:22px}
.article .feat{border-radius:var(--radius);margin-bottom:26px}
.article h2{font-size:26px;margin:34px 0 12px}
.article h3{font-size:21px;margin:26px 0 10px}
.sidebar .widget{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:24px}
.sidebar .widget h4{margin:0 0 14px;font-size:18px;border-bottom:2px solid var(--amber);padding-bottom:8px}
.sidebar .mini{display:flex;gap:12px;margin-bottom:14px}
.sidebar .mini img{width:64px;height:64px;object-fit:cover;border-radius:6px}
.sidebar .mini a{font-size:14px;font-weight:600;color:var(--wood-dark)}
.sidebar ul{list-style:none;padding:0;margin:0}
.sidebar li{padding:6px 0;border-bottom:1px dashed var(--line);font-size:14.5px}

/* Footer */
.site-footer{background:var(--wood-dark);color:#cdbfae;padding:60px 0 0}
.site-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px}
.site-footer img.flogo{height:48px;margin-bottom:16px}
.site-footer h4{color:#fff;font-size:17px;margin:0 0 16px}
.site-footer a{color:#cdbfae}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:10px}
.social{display:flex;gap:14px;margin-top:8px}
.social a{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.1);color:#fff;font-size:14px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);text-align:center;padding:20px 0;font-size:14px}

/* Gallery strip */
.gallery{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}
.gallery img{height:90px;width:100%;object-fit:cover;border-radius:6px}

/* ---------- POPUP / MODAL ---------- */
.wh-modal-overlay{position:fixed;inset:0;background:rgba(20,13,7,.72);
  display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.wh-modal-overlay.open{display:flex}
.wh-modal{background:#fff;width:100%;max-width:460px;border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.45);animation:pop .25s ease}
@keyframes pop{from{transform:translateY(18px);opacity:0}to{transform:none;opacity:1}}
.wh-modal .head{background:var(--wood-dark);color:#fff;padding:26px 28px;text-align:center;position:relative}
.wh-modal .head h3{color:#fff;margin:0 0 6px;font-size:23px}
.wh-modal .head p{margin:0;color:#f0e3d2;font-size:14px}
.wh-modal .close{position:absolute;top:12px;right:16px;background:none;border:0;color:#fff;
  font-size:26px;line-height:1;cursor:pointer;opacity:.85}
.wh-modal .close:hover{opacity:1}
.wh-modal .body{padding:26px 28px}
.wh-modal label{display:block;font-weight:600;font-size:14px;margin:0 0 6px;color:var(--wood-dark)}
.wh-modal input{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:8px;
  font-size:15px;margin-bottom:16px;font-family:var(--font)}
.wh-modal input:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(217,139,43,.15)}
.wh-modal .btn{width:100%}
.wh-modal .consent{font-size:11.5px;color:var(--muted);margin:14px 0 0;text-align:center;line-height:1.5}
.wh-modal .err{display:none;background:#fdecec;color:#a12b2b;border:1px solid #f3c4c4;
  padding:10px 12px;border-radius:8px;font-size:13.5px;margin-bottom:14px}
.wh-modal .err.show{display:block}
.wh-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.5);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:900px){
  .grid-3,.posts{grid-template-columns:1fr 1fr}
  .split,.article-wrap{grid-template-columns:1fr}
  .site-footer .cols{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:640px){
  .hero h1{font-size:34px}.hero{padding:80px 0}
  .grid-3,.grid-2,.posts{grid-template-columns:1fr}
  .nav{display:none;position:absolute;top:78px;left:0;right:0;background:var(--wood-dark);
    flex-direction:column;padding:18px;gap:14px}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .gallery{grid-template-columns:repeat(3,1fr)}
  section{padding:48px 0}
}

/* ---- refinements: SVG icon/star swaps + closer theme match ---- */
.card .icon{height:64px;width:64px;margin:24px 24px 0}
.card .icon path,.card .icon circle{vector-effect:non-scaling-stroke}
.t-card .stars{display:flex;gap:3px;margin-bottom:14px}
.t-card .stars svg{width:20px;height:20px}
.site-header{box-shadow:0 2px 14px rgba(0,0,0,.18)}
.logo img{height:48px}
.hero{padding:128px 0}
.hero h1{font-size:50px;letter-spacing:-.5px}
.btn{box-shadow:0 6px 18px rgba(217,139,43,.28)}
.btn-outline{box-shadow:none}
.card:hover{box-shadow:0 18px 44px rgba(43,29,18,.18)}
.section-tag{color:var(--amber);letter-spacing:1.5px;text-transform:uppercase;font-size:14px;font-weight:700}
