/*
Theme Name: CleanLine Renovations & Construction
Theme URI: https://cleanlinerenovations.co.za
Author: CleanLine Renovations & Construction
Description: Custom WordPress theme for CleanLine Renovations & Construction. Includes homepage sections, Customizer controls, and an Elementor import template.
Version: 2.0
Requires at least: 5.8
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: cleanline
*/
:root{--navy:#06162e;--blue:#0b63ce;--gold:#f8b400;--dark:#10141c;--muted:#667085;--light:#f7f9fc;--white:#fff;--shadow:0 15px 45px rgba(8,22,46,.12)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--dark);background:#fff;line-height:1.6}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.container{width:min(1180px,92%);margin:auto}.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border-radius:4px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:14px}.btn-primary{background:var(--gold);color:#06162e}.btn-blue{background:var(--blue);color:#fff}.btn-outline{border:2px solid #fff;color:#fff}.site-header{position:absolute;top:0;left:0;right:0;z-index:50;background:rgba(3,10,24,.78);backdrop-filter:blur(8px)}.header-inner{height:82px;display:flex;align-items:center;justify-content:space-between}.logo img{height:48px;width:auto}.nav{display:flex;align-items:center;gap:34px;color:#fff;font-weight:700}.nav a:hover{color:var(--gold)}.hero{min-height:760px;display:flex;align-items:center;position:relative;color:#fff;background:linear-gradient(90deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.58) 40%,rgba(0,0,0,.18) 100%),url('assets/images/hero.jpg') center/cover no-repeat}.hero-content{max-width:680px;padding-top:80px}.eyebrow{color:var(--gold);font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.1em}.hero h1{font-size:clamp(42px,6vw,76px);line-height:1.05;margin:16px 0 22px;font-weight:900}.hero p{font-size:20px;max-width:620px;margin-bottom:32px}.hero-actions{display:flex;gap:16px;flex-wrap:wrap}.section{padding:86px 0}.section-title{text-align:center;margin-bottom:44px}.section-title h2,.about-text h2{font-size:clamp(30px,4vw,44px);line-height:1.15;margin:8px 0 14px;font-weight:900}.section-title p{color:var(--muted);max-width:680px;margin:auto}.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:54px;align-items:center}.about-text p{color:#344054;font-size:17px}.about-collage{display:grid;grid-template-columns:1fr 1fr;gap:14px}.about-collage img{height:235px;width:100%;object-fit:cover;border-radius:4px;box-shadow:var(--shadow)}.about-collage img:first-child{grid-column:span 2;height:310px}.services{background:var(--light)}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.service-card{background:#fff;padding:30px 24px;border-radius:8px;box-shadow:var(--shadow);border-top:4px solid var(--gold);min-height:210px}.service-icon{font-size:34px;color:var(--gold);margin-bottom:12px}.service-card h3{margin:0 0 10px;font-size:19px}.service-card p{color:var(--muted);margin:0;font-size:15px}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.gallery-grid img{height:230px;width:100%;object-fit:cover;border-radius:6px}.why{background:linear-gradient(135deg,var(--navy),#0b2a52);color:#fff}.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.why-card{padding:28px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);border-radius:8px}.why-card h3{margin:0 0 8px}.quote{background:#fff}.quote-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:start}.quote-info{padding:36px;background:var(--navy);color:#fff;border-radius:10px}.quote-info h2{font-size:38px;line-height:1.15;margin-top:0}.quote-info p{color:#d7e3f5}.contact-list{margin-top:28px}.contact-list div{margin:12px 0}.quote-form{background:#fff;border-radius:10px;box-shadow:var(--shadow);padding:34px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-grid .full{grid-column:1/-1}label{font-weight:800;display:block;margin-bottom:8px}input,select,textarea{width:100%;padding:14px 12px;border:1px solid #d0d5dd;border-radius:4px;font:inherit}textarea{min-height:140px}.site-footer{background:#020817;color:#fff;padding:54px 0 24px}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:28px}.footer-grid img{height:46px}.footer-grid p,.footer-grid li{color:#cbd5e1}.footer-grid ul{list-style:none;padding:0;margin:0}.copyright{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:22px;color:#94a3b8;text-align:center}.mobile-menu{display:none}@media (max-width:900px){.nav{display:none}.mobile-menu{display:block;color:#fff}.hero{min-height:680px}.about-grid,.quote-wrap{grid-template-columns:1fr}.services-grid{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:repeat(2,1fr)}.why-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}}@media (max-width:560px){.services-grid,.gallery-grid,.footer-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column}.btn{justify-content:center}.header-inner{height:72px}.logo img{height:38px}}


/* Elementor-friendly spacing */
.elementor-template-cleanline .section { padding: 86px 0; }
.elementor-template-cleanline .container { width: min(1180px,92%); margin: auto; }

/* Customizer image fallbacks */
.custom-logo { max-height: 56px; width: auto; }


/* Native contact form messages */
.cleanline-form-notice {
  margin: 0 0 18px;
  padding: 14px 16px;
  border-radius: 6px;
  font-weight: 700;
}
.cleanline-form-notice.success {
  background: #ecfdf3;
  color: #027a48;
  border: 1px solid #abefc6;
}
.cleanline-form-notice.error {
  background: #fef3f2;
  color: #b42318;
  border: 1px solid #fecdca;
}
.cleanline-native-form button {
  border: 0;
  cursor: pointer;
}
.cleanline-native-form button:hover {
  filter: brightness(.96);
}
