/* ============================================
   Premium Wallpaper Installation — Main Styles
   Fonts: Manrope (headings), Inter (body)
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Manrope:wght@400;500;600;700;800&display=swap');

/* --- CSS Variables --- */
:root {
  --clr-primary: #3b4a2f;
  --clr-primary-dark: #2c3822;
  --clr-secondary: #2a3520;
  --clr-ivory: #f5f0e8;
  --clr-ivory-dark: #ebe5d9;
  --clr-text-light: #f3efe7;
  --clr-text-dark: #3d4a35;
  --clr-accent: #b8975a;
  --clr-accent-hover: #a6843e;
  --clr-white: #ffffff;
  --clr-border: rgba(184,151,90,0.25);
  --font-heading: 'Manrope', sans-serif;
  --font-body: 'Inter', sans-serif;
  --max-width: 1200px;
  --header-h: 72px;
  --transition: 0.3s ease;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--clr-text-dark);background:var(--clr-ivory);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
h1,h2,h3,h4{font-family:var(--font-heading);line-height:1.25;color:var(--clr-primary-dark)}

/* --- Utility --- */
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.section-padding{padding:80px 0}
.text-center{text-align:center}

/* ============================================
   HEADER
   ============================================ */
.topbar{background:var(--clr-secondary);border-bottom:1px solid var(--clr-border)}
.topbar-inner{max-width:var(--max-width);margin:0 auto;padding:8px 24px;display:flex;align-items:center;justify-content:flex-end;gap:20px}
.topbar-link{font-size:0.82rem;color:var(--clr-text-light);opacity:0.9;transition:color var(--transition),opacity var(--transition)}
.topbar-link:hover{color:var(--clr-accent);opacity:1}

.site-header{position:sticky;top:0;z-index:1000;background:var(--clr-primary);border-bottom:1px solid var(--clr-border);height:var(--header-h);display:flex;align-items:center}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}
.header-logo{flex:1 1 auto;min-width:0}
.header-logo a{display:block;max-width:100%;font-family:var(--font-heading);font-size:clamp(0.95rem,1.2vw,1.2rem);font-weight:700;color:var(--clr-accent);letter-spacing:0.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-logo a span{color:var(--clr-text-light);font-weight:400}

/* Desktop Nav */
.desktop-nav{display:flex;align-items:center;gap:4px}
.desktop-nav>li{position:relative}
.desktop-nav>li>a{display:block;padding:10px 14px;font-size:0.9rem;font-weight:500;color:var(--clr-text-light);transition:color var(--transition)}
.desktop-nav>li>a:hover,.desktop-nav>li>a:focus{color:var(--clr-accent)}

/* Dropdown */
.has-dropdown>a::after{content:'';display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:6px;vertical-align:2px;transition:transform var(--transition)}
.has-dropdown:hover>a::after,.has-dropdown:focus-within>a::after{transform:rotate(-135deg)}
.dropdown{position:absolute;top:100%;left:0;min-width:240px;background:var(--clr-primary);border:1px solid var(--clr-border);border-radius:6px;padding:8px 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--transition);box-shadow:0 12px 32px rgba(0,0,0,0.2)}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li{opacity:0;transform:translateY(6px);transition:all 0.25s ease}
.has-dropdown:hover .dropdown li,.has-dropdown:focus-within .dropdown li{opacity:1;transform:translateY(0)}
.has-dropdown:hover .dropdown li:nth-child(1),.has-dropdown:focus-within .dropdown li:nth-child(1){transition-delay:0.05s}
.has-dropdown:hover .dropdown li:nth-child(2),.has-dropdown:focus-within .dropdown li:nth-child(2){transition-delay:0.1s}
.has-dropdown:hover .dropdown li:nth-child(3),.has-dropdown:focus-within .dropdown li:nth-child(3){transition-delay:0.15s}
.has-dropdown:hover .dropdown li:nth-child(4),.has-dropdown:focus-within .dropdown li:nth-child(4){transition-delay:0.2s}
.has-dropdown:hover .dropdown li:nth-child(5),.has-dropdown:focus-within .dropdown li:nth-child(5){transition-delay:0.25s}
.has-dropdown:hover .dropdown li:nth-child(6),.has-dropdown:focus-within .dropdown li:nth-child(6){transition-delay:0.3s}
.has-dropdown:hover .dropdown li:nth-child(7),.has-dropdown:focus-within .dropdown li:nth-child(7){transition-delay:0.35s}
.has-dropdown:hover .dropdown li:nth-child(8),.has-dropdown:focus-within .dropdown li:nth-child(8){transition-delay:0.4s}
.has-dropdown:hover .dropdown li:nth-child(9),.has-dropdown:focus-within .dropdown li:nth-child(9){transition-delay:0.45s}
.has-dropdown:hover .dropdown li:nth-child(10),.has-dropdown:focus-within .dropdown li:nth-child(10){transition-delay:0.5s}
.has-dropdown:hover .dropdown li:nth-child(11),.has-dropdown:focus-within .dropdown li:nth-child(11){transition-delay:0.55s}
.dropdown a{display:block;padding:8px 20px;font-size:0.85rem;color:var(--clr-text-light);transition:background var(--transition),color var(--transition)}
.dropdown a:hover,.dropdown a:focus{background:rgba(184,151,90,0.12);color:var(--clr-accent)}

/* Burger */
.burger-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.burger-toggle span{display:block;width:24px;height:2px;background:var(--clr-text-light);margin:5px 0;transition:var(--transition)}

/* Mobile Nav */
.mobile-nav-overlay{display:none;position:fixed;top:0;right:0;width:50%;max-width:400px;height:100vh;height:100dvh;background:var(--clr-primary);z-index:2000;padding:20px 24px;overflow-y:auto;transform:translateX(100%);transition:transform 0.35s cubic-bezier(.4,0,.2,1);flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,0.3)}
.mobile-nav-overlay.active{display:flex;transform:translateX(0)}
.mobile-nav-backdrop{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.55);z-index:1999;opacity:0;transition:opacity 0.3s ease}
.mobile-nav-backdrop.active{display:block;opacity:1}
.mobile-nav-close{background:none;border:2px solid var(--clr-border);cursor:pointer;align-self:flex-end;padding:8px;margin-bottom:20px;border-radius:6px;transition:all var(--transition);display:flex;align-items:center;justify-content:center}
.mobile-nav-close:hover,.mobile-nav-close:active{border-color:var(--clr-accent);background:rgba(184,151,90,0.1)}
.mobile-nav-close svg{width:24px;height:24px;stroke:var(--clr-text-light);stroke-width:2}
.mobile-nav-overlay ul{display:flex;flex-direction:column;gap:0}
.mobile-nav-overlay>ul>li>a{display:block;padding:14px 0;font-size:1rem;font-weight:600;color:var(--clr-text-light);border-bottom:1px solid var(--clr-border);font-family:var(--font-heading);text-align:left}
.mobile-nav-overlay .mobile-dropdown-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 0;font-size:1rem;font-weight:600;color:var(--clr-text-light);border-bottom:1px solid var(--clr-border);font-family:var(--font-heading);background:none;border-left:none;border-right:none;border-top:none;cursor:pointer;text-align:left}
.mobile-nav-overlay .mobile-dropdown-toggle svg{width:18px;height:18px;stroke:var(--clr-accent);stroke-width:2;transition:transform var(--transition);flex-shrink:0}
.mobile-nav-overlay .mobile-dropdown-toggle.open svg{transform:rotate(180deg)}
.mobile-nav-overlay .mobile-sub{display:none;padding-left:16px}
.mobile-nav-overlay .mobile-sub.open{display:block}
.mobile-nav-overlay .mobile-sub a{display:block;padding:10px 0;font-size:0.9rem;color:var(--clr-ivory);border-bottom:1px solid rgba(184,151,90,0.1);text-align:left}
.mobile-nav-contact{margin-top:auto;padding-top:24px;border-top:1px solid var(--clr-border)}
.mobile-nav-contact a{display:flex;align-items:center;gap:10px;padding:10px 0;font-size:0.9rem;color:var(--clr-text-light);text-align:left;overflow-wrap:anywhere}
.mobile-nav-contact svg{width:18px;height:18px;stroke:var(--clr-accent);stroke-width:2;fill:none}

/* ============================================
   HERO
   ============================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:stretch;padding:0;background:var(--clr-primary);overflow:hidden}
.hero-content{position:relative;z-index:3;display:flex;align-items:stretch;flex:1;width:100%;max-width:none;margin:0;padding:0}
.hero-shell{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,390px);align-items:center;gap:42px;min-height:100vh;width:100%;padding:104px clamp(24px,5vw,72px) 64px;overflow:hidden;border-radius:0;border:none;box-shadow:none}
.hero-bg{position:absolute;inset:0;z-index:1}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.34}
.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,rgba(43,53,32,0.84) 0%,rgba(43,53,32,0.56) 45%,rgba(43,53,32,0.18) 100%)}
.hero-copy{position:relative;z-index:3;display:flex;align-items:center;min-height:100%;max-width:min(100%,920px)}
.hero-text{max-width:760px}
.hero-eyebrow{display:inline-flex;align-items:center;padding:8px 14px;margin-bottom:22px;border-radius:0;border:1px solid rgba(243,239,231,0.18);background:rgba(243,239,231,0.08);font-family:var(--font-heading);font-size:0.82rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--clr-ivory)}
.hero-text h1{font-size:3.3rem;font-weight:800;color:var(--clr-text-light);margin-bottom:20px;line-height:1.06;max-width:14ch}
.hero-text h1 span{color:var(--clr-accent)}
.hero-text p{font-size:1.1rem;color:var(--clr-ivory);opacity:0.92;margin-bottom:32px;max-width:680px}
.hero-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--clr-accent);color:var(--clr-primary-dark);padding:12px 24px;font-size:0.95rem;font-weight:600;font-family:var(--font-heading);line-height:1.2;border:none;border-radius:0;cursor:pointer;transition:all var(--transition);letter-spacing:0.02em}
.hero-cta svg{width:18px;height:18px;stroke-width:2;flex-shrink:0}
.hero-cta:hover{background:var(--clr-accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,151,90,0.3)}

/* Hero Form */
.hero-form-wrap{position:relative;z-index:3;align-self:center;margin:0 0 0 auto;width:100%;max-width:390px;background:rgba(243,239,231,0.96);backdrop-filter:blur(10px);border:1px solid rgba(43,53,32,0.08);padding:30px 28px;border-radius:0;box-shadow:0 30px 60px rgba(20,24,15,0.24)}

/* ============================================
   FORM STYLES
   ============================================ */
.feedback-form-container h2,.feedback-form-container .form-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:20px;text-align:center}
.hero-form-wrap .feedback-form-container h2,.hero-form-wrap .feedback-form-container .form-title{color:var(--clr-primary-dark);text-align:left;margin-bottom:18px}
.hero-form-wrap .contact-form input,.hero-form-wrap .contact-form textarea{background:rgba(255,255,255,0.88);color:var(--clr-text-dark);border:1px solid #d4cfc5}
.hero-form-wrap .contact-form input::placeholder,.hero-form-wrap .contact-form textarea::placeholder{color:#8a8578}
.hero-form-wrap .feedback-form-container .contact-form .form-submit{text-align:left}
.hero-form-wrap .submit-btn{width:100%;border-radius:0}
.hero-form-wrap #form-success p{color:var(--clr-primary-dark)}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.contact-form .form-group{display:flex;flex-direction:column}
.contact-form input,.contact-form textarea{width:100%;padding:14px 16px;font-family:var(--font-body);font-size:0.95rem;border:1px solid var(--clr-border);background:rgba(255,255,255,0.08);color:var(--clr-text-light);border-radius:4px;transition:border-color var(--transition)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(243,239,231,0.5)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--clr-accent)}
.contact-form textarea{min-height:100px;resize:vertical;margin-bottom:14px}
.feedback-form-container .contact-form .form-submit{text-align:center}
.submit-btn{background:var(--clr-accent);color:var(--clr-primary-dark);padding:14px 36px;font-size:1rem;font-weight:600;font-family:var(--font-heading);border:none;cursor:pointer;transition:all var(--transition);letter-spacing:0.02em}
.submit-btn:hover{background:var(--clr-accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(184,151,90,0.3)}
#form-success p{color:var(--clr-accent);font-weight:500;font-size:1.05rem;padding:20px 0}

/* Light bg form */
.section-light .feedback-form-container h2,.section-light .feedback-form-container .form-title{color:var(--clr-primary-dark)}
.section-light .contact-form input,.section-light .contact-form textarea{background:var(--clr-white);color:var(--clr-text-dark);border:1px solid #d4cfc5}
.section-light .contact-form input::placeholder,.section-light .contact-form textarea::placeholder{color:#8a8578}
.section-light #form-success p{color:var(--clr-primary)}

/* ============================================
   SECTIONS
   ============================================ */
.section-dark{background:var(--clr-primary);color:var(--clr-text-light)}
.section-dark h2,.section-dark h3{color:var(--clr-text-light)}
.section-light{background:var(--clr-ivory);color:var(--clr-text-dark)}
.section-alt{background:var(--clr-ivory-dark);color:var(--clr-text-dark)}
.section-accent{background:var(--clr-secondary);color:var(--clr-text-light)}
.section-accent h2,.section-accent h3{color:var(--clr-text-light)}

h2{font-size:2.2rem;font-weight:700;margin-bottom:20px}
.section-subtitle{font-size:1.05rem;opacity:0.85;max-width:640px;margin-bottom:40px}
.section-subtitle.text-center{margin-left:auto;margin-right:auto}

/* Split layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-img{position:relative;overflow:hidden;border-radius:6px;border:1px solid var(--clr-border)}
.split-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.split-text h2{margin-bottom:16px}
.split-text p{margin-bottom:16px}

/* Cards grid */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}
.cards-grid .card{display:flex;flex-direction:column;height:100%}
.cards-grid .card-icon{margin-left:auto;margin-right:auto}
.cards-grid .card-link{margin-top:auto}
.cards-grid.cards-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.cards-grid.cards-grid-4 .card{display:flex;flex-direction:column;align-items:center;text-align:center;height:100%}
.cards-grid.cards-grid-4 .card-icon{margin-left:auto;margin-right:auto}
.cards-grid.cards-grid-4 .card-link{margin-top:auto}
.cards-grid.cards-grid-4 .card-link svg{width:14px;height:14px;stroke-width:2.2}
.card{background:rgba(255,255,255,0.04);border:1px solid var(--clr-border);border-radius:8px;padding:32px 28px;transition:all var(--transition)}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.12)}
.section-light .card{background:var(--clr-white);border-color:#e0dbd1}
.card-icon{width:48px;height:48px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;background:rgba(184,151,90,0.12);border-radius:8px}
.card-icon svg{width:24px;height:24px;stroke:var(--clr-accent);fill:none;stroke-width:1.5}
.card h3{font-size:1.15rem;font-weight:700;margin-bottom:10px}
.card p{font-size:0.95rem;opacity:0.85;line-height:1.65}
.card-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:0.9rem;font-weight:600;color:var(--clr-accent);transition:gap var(--transition)}
.card-link:hover{gap:10px}

/* Image card */
.img-card{overflow:hidden;border-radius:8px;border:1px solid var(--clr-border);transition:all var(--transition)}
.img-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.12)}
.img-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.img-card-body{padding:24px}
.img-card-body h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.img-card-body p{font-size:0.9rem;opacity:0.85}
.cards-grid .img-card .card-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 16px;border:1px solid var(--clr-accent);border-radius:4px;color:var(--clr-accent);font-weight:600;line-height:1.1;transition:all var(--transition)}
.cards-grid .img-card .card-link svg{width:12px;height:12px;stroke-width:2.2}
.cards-grid .img-card .card-link:hover{background:var(--clr-accent);color:var(--clr-primary-dark);gap:10px}

/* Testimonials */
.testimonials-section{padding:60px 0}
.testimonials-section h2{text-align:center;margin-bottom:30px}

/* Map */
.map-container{width:100%;border-radius:8px;overflow:hidden;border:1px solid var(--clr-border)}
.map-container iframe{width:100%;height:400px;border:0}

/* CTA Banner */
.cta-banner{text-align:center;padding:80px 24px}
.cta-banner h2{color:var(--clr-text-light);margin-bottom:16px}
.cta-banner p{color:var(--clr-ivory);opacity:0.85;margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto}
.cta-banner .btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--clr-accent);color:var(--clr-primary-dark);padding:12px 24px;font-size:0.95rem;line-height:1.2;font-weight:600;font-family:var(--font-heading);border-radius:4px;transition:all var(--transition)}
.cta-banner .btn-primary svg{width:14px;height:14px;stroke-width:2.2;flex-shrink:0}
.cta-banner .btn-primary:hover{background:var(--clr-accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,151,90,0.3)}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:var(--clr-secondary);color:var(--clr-text-light);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-col h2,.footer-col .footer-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--clr-accent);margin-bottom:16px}
.footer-col p{font-size:0.9rem;opacity:0.8;line-height:1.7}
.footer-col a{display:block;font-size:0.9rem;padding:4px 0;opacity:0.8;transition:opacity var(--transition),color var(--transition)}
.footer-col a:hover{opacity:1;color:var(--clr-accent)}
.footer-brand{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--clr-accent);margin-bottom:12px}
.footer-bottom{border-top:1px solid var(--clr-border);padding:20px 0;text-align:center;font-size:0.85rem;opacity:0.6}

/* ============================================
   STICKY QUOTE BUTTON + MODAL
   ============================================ */
.sticky-quote-btn{position:fixed;bottom:24px;right:24px;z-index:900;background:var(--clr-accent);color:var(--clr-primary-dark);padding:16px 28px;font-size:0.95rem;font-weight:700;font-family:var(--font-heading);border:none;cursor:pointer;box-shadow:0 8px 28px rgba(184,151,90,0.35);transition:all var(--transition);letter-spacing:0.02em}
.sticky-quote-btn:hover{background:var(--clr-accent-hover);transform:translateY(-2px)}
.modal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.6);align-items:center;justify-content:center;padding:24px}
.modal-overlay.active{display:flex}
.modal-box{background:var(--clr-primary);border:1px solid var(--clr-border);border-radius:10px;padding:36px;max-width:540px;width:100%;position:relative;max-height:90vh;overflow-y:auto}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;cursor:pointer}
.modal-close svg{width:28px;height:28px;stroke:var(--clr-text-light);stroke-width:2}
.modal-box .feedback-form-container h2,.modal-box .feedback-form-container .form-title{color:var(--clr-text-light)}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb{padding:16px 0;font-size:0.85rem}
.breadcrumb a{color:var(--clr-accent);font-weight:500}
.breadcrumb span{opacity:0.6;margin:0 6px}

/* ============================================
   PAGE HERO (inner pages)
   ============================================ */
.page-hero{position:relative;padding:100px 0 60px;background:var(--clr-primary);overflow:hidden;min-height:320px;display:flex;align-items:flex-end}
.service-inner-page .page-hero{min-height:460px;padding:140px 0 90px}
.area-inner-page .page-hero{min-height:460px;padding:140px 0 90px}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.2}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,53,32,0.7) 0%,rgba(43,53,32,0.95) 100%)}
.service-inner-page .page-hero-overlay{background:linear-gradient(180deg,rgba(43,53,32,0.38) 0%,rgba(43,53,32,0.58) 100%)}
.service-inner-page .page-hero-bg img{opacity:0.34}
.area-inner-page .page-hero-overlay{background:linear-gradient(180deg,rgba(43,53,32,0.38) 0%,rgba(43,53,32,0.58) 100%)}
.area-inner-page .page-hero-bg img{opacity:0.34}
.area-inner-page .cards-grid .card-link{display:inline-flex;align-items:center}
.area-inner-page .cards-grid .card-link svg{width:13px;height:13px;stroke-width:2.1;flex-shrink:0;transform:translateY(1px)}
.page-hero-content{position:relative;z-index:2}
.page-hero h1{color:var(--clr-text-light);font-size:2.6rem;font-weight:800;margin-bottom:12px}
.page-hero p{color:var(--clr-ivory);opacity:0.85;font-size:1.1rem;max-width:600px}

/* ============================================
   FAQ
   ============================================ */
.faq-item{border-bottom:1px solid var(--clr-border);padding:20px 0}
.faq-question{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--clr-primary-dark)}
.faq-question svg{width:20px;height:20px;stroke:var(--clr-accent);stroke-width:2;transition:transform var(--transition);flex-shrink:0}
.faq-question.open svg{transform:rotate(180deg)}
.faq-answer{display:none;padding-top:12px;font-size:0.95rem;line-height:1.7;opacity:0.85}
.faq-answer.open{display:block}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info-list{display:flex;flex-direction:column;gap:20px}
.contact-info-item{display:flex;align-items:flex-start;gap:14px}
.contact-info-item .ci-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(184,151,90,0.12);border-radius:8px;flex-shrink:0}
.contact-info-item .ci-icon svg{width:20px;height:20px;stroke:var(--clr-accent);fill:none;stroke-width:1.5}
.contact-info-item h3{font-size:0.95rem;font-weight:700;margin-bottom:2px}
.contact-info-item p,.contact-info-item a{font-size:0.9rem;opacity:0.85}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .hero{min-height:auto}
  .hero-content{display:block}
  .hero-shell{grid-template-columns:1fr;gap:32px;min-height:auto;padding:112px 32px 44px}
  .hero-copy{min-height:auto}
  .hero-text{max-width:100%}
  .hero-text h1{font-size:2.7rem;max-width:13ch}
  .hero-form-wrap{margin:0;max-width:100%}
  .split{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--header-h:60px}
  .topbar{display:none}
  .desktop-nav{display:none}
  .burger-toggle{display:block}
  .header-inner{gap:10px}
  .header-logo{flex:1 1 calc(100% - 52px)}
  .header-logo a{font-size:0.92rem}
  .mobile-nav-overlay{width:min(88vw,400px)}
  .hero{min-height:auto}
  .hero-content{padding:0}
  .hero-shell{grid-template-columns:1fr;align-items:start;gap:24px;min-height:auto;padding:76px 20px 20px}
  .hero-overlay{background:linear-gradient(180deg,rgba(43,53,32,0.56) 0%,rgba(43,53,32,0.82) 100%)}
  .hero-copy{display:block;min-height:auto;max-width:none}
  .hero-text{max-width:none}
  .hero-eyebrow{display:none}
  .hero-text h1{font-size:2.15rem;max-width:12ch}
  .hero-text p{max-width:none}
  .hero-cta{padding:11px 20px;font-size:0.9rem}
  .hero-form-wrap{align-self:auto;margin:0;max-width:none;padding:22px 18px;border-radius:0}
  .hero-form-wrap .feedback-form-container h2,.hero-form-wrap .feedback-form-container .form-title{font-size:1.2rem}
  h2{font-size:1.8rem}
  .page-hero h1{font-size:2rem}
  .page-hero{min-height:240px;padding:80px 0 40px}
  .service-inner-page .page-hero{min-height:320px;padding:110px 0 55px}
  .area-inner-page .page-hero{min-height:320px;padding:110px 0 55px}
  .section-padding{padding:50px 0}
  .cards-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
  .sticky-quote-btn{bottom:16px;right:50%;transform:translateX(50%);white-space:nowrap}
  .sticky-quote-btn:hover{transform:translateX(50%) translateY(-2px)}
}
@media(max-width:480px){
  .header-logo a{font-size:0.86rem}
  .mobile-nav-contact a{font-size:0.84rem;line-height:1.35}
  .hero-text h1{font-size:1.8rem;max-width:none}
  .hero-text p{font-size:1rem}
  .hero-cta{width:100%;max-width:none}
  h2{font-size:1.5rem}
  .hero-shell{gap:18px;padding:72px 16px 16px}
  .hero-form-wrap{padding:20px 16px}
  .service-inner-page .page-hero{min-height:290px;padding:95px 0 45px}
  .area-inner-page .page-hero{min-height:290px;padding:95px 0 45px}
}

/* Animations */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
