/*
Theme Name: Hardwood Scaffolding
Theme URI: https://hardwoodscaffolding.ie
Author: Hardwood Scaffolding & Plant
Description: Custom industrial theme for Hardwood Scaffolding & Plant, Longwood, Co. Meath. Includes Home, About, Services, Gallery, Contact templates with maroon/charcoal palette.
Version: 1.0.0
License: GPLv2 or later
Text Domain: hardwood
Tags: business, construction, one-column, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments
*/

:root{
  --primary:#8B1A1A;
  --primary-hover:#6B1414;
  --dark:#1A1A1A;
  --text:#2B2B2B;
  --cream:#F5F1EA;
  --border:#E5E2DC;
  --white:#ffffff;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3','Source Sans Pro',system-ui,sans-serif;color:var(--text);line-height:1.6;background:var(--white)}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-hover)}
h1,h2,h3,h4,h5,h6{font-family:'Oswald',sans-serif;font-weight:600;color:var(--dark);line-height:1.2;text-transform:uppercase;letter-spacing:.5px}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem);margin-bottom:1rem}
h3{font-size:1.35rem;margin-bottom:.5rem}
p{margin-bottom:1rem}
.container{max-width:1200px;margin:0 auto;padding:0 1.25rem}

/* Header */
.site-header{background:var(--dark);color:var(--white);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem}
.site-branding{display:flex;align-items:center;gap:.75rem}
.site-branding img{height:54px;width:auto;border-radius:4px}
.site-title{color:var(--white);font-family:'Oswald',sans-serif;font-size:1.25rem;text-transform:uppercase;letter-spacing:1px}
.site-title a{color:var(--white)}
.main-nav ul{list-style:none;display:flex;gap:1.75rem;align-items:center}
.main-nav a{color:var(--white);font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:.95rem;letter-spacing:1px;padding:.5rem 0;border-bottom:2px solid transparent}
.main-nav a:hover,.main-nav .current-menu-item a{border-color:var(--primary);color:var(--white)}
.nav-cta a{background:var(--primary);padding:.6rem 1.1rem!important;border-radius:2px;border:none!important}
.nav-cta a:hover{background:var(--primary-hover)}
.menu-toggle{display:none;background:none;border:1px solid var(--white);color:var(--white);padding:.4rem .7rem;cursor:pointer;font-size:1.2rem}

/* Hero */
.hero{position:relative;min-height:75vh;display:flex;align-items:center;color:var(--white);background:#000}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.45}
.hero-content{position:relative;z-index:2;padding:5rem 0;max-width:760px}
.hero h1{color:var(--white);margin-bottom:1rem}
.hero p{font-size:1.2rem;margin-bottom:1.75rem}
.btn{display:inline-block;background:var(--primary);color:var(--white);padding:.85rem 1.75rem;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1px;border:none;cursor:pointer;border-radius:2px;transition:background .2s}
.btn:hover{background:var(--primary-hover);color:var(--white)}
.btn-outline{background:transparent;border:2px solid var(--white);margin-left:.5rem}
.btn-outline:hover{background:var(--white);color:var(--dark)}

/* Sections */
section{padding:4.5rem 0}
.section-cream{background:var(--cream)}
.section-dark{background:var(--dark);color:var(--white)}
.section-dark h2,.section-dark h3{color:var(--white)}
.section-title{text-align:center;margin-bottom:.5rem}
.section-sub{text-align:center;color:#666;margin-bottom:3rem;font-size:1.1rem}
.section-dark .section-sub{color:#bbb}

/* Grid */
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.75rem}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}

.card{background:var(--white);border:1px solid var(--border);overflow:hidden;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.1)}
.card img{height:220px;object-fit:cover;width:100%}
.card-body{padding:1.5rem}
.card-body h3{color:var(--dark)}
.card-body a{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:.9rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center}
.stat-num{font-family:'Oswald',sans-serif;font-size:3rem;color:var(--primary);font-weight:700;display:block}
.stat-label{text-transform:uppercase;letter-spacing:1px;font-size:.9rem;color:#bbb}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.gallery-grid img{height:280px;object-fit:cover;width:100%;border-radius:2px}

/* Contact */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
@media(max-width:768px){.contact-wrap{grid-template-columns:1fr}}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:.85rem;border:1px solid var(--border);font-family:inherit;font-size:1rem;margin-bottom:1rem;border-radius:2px;background:var(--white)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-info{background:var(--cream);padding:2rem;border-left:4px solid var(--primary)}
.contact-info h3{margin-top:1.25rem}
.contact-info h3:first-child{margin-top:0}

/* Page header */
.page-header{background:var(--dark);color:var(--white);padding:4rem 0;text-align:center}
.page-header h1{color:var(--white)}
.page-header p{color:#ccc;margin-bottom:0}

/* Footer */
.site-footer{background:#0d0d0d;color:#bbb;padding:3.5rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-bottom:2rem}
.footer-col h4{color:var(--white);font-family:'Oswald',sans-serif;text-transform:uppercase;margin-bottom:1rem;font-size:1.05rem;letter-spacing:1px}
.footer-col a{color:#bbb;display:block;padding:.25rem 0}
.footer-col a:hover{color:var(--primary)}
.footer-col ul{list-style:none}
.footer-bottom{border-top:1px solid #2a2a2a;padding-top:1.5rem;text-align:center;font-size:.9rem}

/* Mobile */
@media (max-width:860px){
  .menu-toggle{display:block}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--dark);padding:1rem 1.25rem}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:.5rem}
  .main-nav a{padding:.75rem 0;display:block;border-bottom:1px solid #2a2a2a}
  .nav-cta a{text-align:center}
  .site-header .container{position:relative}
}
