/* ============================================
   CC's Decor - Custom Stylesheet
   Deck Design & Construction, Mukwonago, WI
   ============================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;font-weight:400;line-height:1.65;color:var(--text);background:var(--bg);transition:background .3s,color .3s;padding-bottom:2.25rem}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font:inherit}

/* --- CSS Variables --- */
:root{
  --bg:#f5f3ef;--bg-alt:#ebe8e2;--bg-card:#ffffff;--bg-dark:#1f2420;
  --text:#2a2e2a;--text-muted:#5a5e58;--text-faint:#8a8e88;
  --primary:#4a6741;--primary-rgb:74,103,65;--primary-light:#dfe8db;
  --accent:#8b6d42;--accent-light:#f0e4d0;
  --border:#cdd0c8;--border-light:#dfe1da;
  --shadow:0 2px 12px rgba(0,0,0,.06);
  --shadow-lg:0 8px 30px rgba(0,0,0,.08);
  --radius:6px;
  --nav-height:72px;
}
html.dark{
  --bg:#171a16;--bg-alt:#1e221c;--bg-card:#262a24;--bg-dark:#0d0f0c;
  --text:#e2e4de;--text-muted:#8a8e88;--text-faint:#5a5e58;
  --primary:#6d9a60;--primary-rgb:109,154,96;--primary-light:#253020;
  --accent:#b89560;--accent-light:#2a2418;
  --border:#343832;--border-light:#2c302a;
  --shadow:0 2px 12px rgba(0,0,0,.25);
  --shadow-lg:0 8px 30px rgba(0,0,0,.35);
}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:'Archivo',system-ui,sans-serif;letter-spacing:-.02em;line-height:1.15;color:var(--text)}
h1{font-size:clamp(2.25rem,1.6rem + 2.5vw,3.5rem);font-weight:700}
h2{font-size:clamp(1.75rem,1.3rem + 1.8vw,2.75rem);font-weight:700}
h3{font-size:clamp(1.25rem,1.1rem + .6vw,1.5rem);font-weight:600}
h4{font-size:1.125rem;font-weight:600}
p+p{margin-top:1em}

/* --- Layout --- */
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
section{padding:80px 0}
@media(max-width:768px){section{padding:56px 0}}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius);font-weight:600;font-size:.9375rem;transition:all .2s;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:color-mix(in srgb,var(--primary) 85%,#000);transform:translateY(-1px);box-shadow:0 4px 14px rgba(var(--primary-rgb),.3)}
.btn-outline{border:2px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-white{background:#fff;color:var(--primary)}
.btn-white:hover{background:var(--primary-light)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}
.btn-sm{padding:10px 20px;font-size:.875rem}

/* ============================================
   NAVIGATION
   ============================================ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .3s,box-shadow .3s,border-color .3s;background:var(--bg);border-bottom:1px solid var(--border-light)}
.site-nav.at-top{background:transparent;border-color:transparent}
.site-nav.scrolled{background:var(--bg);box-shadow:var(--shadow);border-color:var(--border-light)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-height);max-width:1140px;margin:0 auto;padding:0 24px}
.nav-logo{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.25rem;color:var(--text);transition:color .3s}
.nav-logo span{color:var(--primary)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:.9375rem;font-weight:500;color:var(--text-muted);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--primary);border-radius:1px}
.nav-cta-phone{font-weight:600;color:var(--primary)!important;display:flex;align-items:center;gap:6px}
.nav-cta-phone svg{width:16px;height:16px}

/* Dark hero nav override */
.has-dark-hero .site-nav.at-top .nav-logo,
.has-dark-hero .site-nav.at-top .nav-links a,
.has-dark-hero .site-nav.at-top .nav-cta-phone,
.has-dark-hero .site-nav.at-top .theme-toggle{color:#fff!important}
.has-dark-hero .site-nav.at-top .nav-links a:hover{color:var(--accent-light)!important}
.has-dark-hero .site-nav.at-top .hamburger span{background:#fff}

/* Theme toggle */
.theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-muted);transition:color .2s,background .2s}
.theme-toggle:hover{background:var(--bg-alt);color:var(--text)}
.theme-toggle svg{width:18px;height:18px}
.theme-toggle .icon-moon{display:none}
html.dark .theme-toggle .icon-sun{display:none}
html.dark .theme-toggle .icon-moon{display:block}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;width:28px;padding:4px 0;cursor:pointer}
.hamburger span{display:block;height:2px;background:var(--text);border-radius:1px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
@media(max-width:900px){
  .hamburger{display:flex}
  .nav-links{position:fixed;top:var(--nav-height);left:0;right:0;bottom:0;background:var(--bg);flex-direction:column;justify-content:flex-start;padding:40px 24px;gap:0;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:999}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.125rem;padding:16px 0;border-bottom:1px solid var(--border-light);width:100%;display:block}
  .nav-links a.active::after{display:none}
  .nav-cta-phone{margin-top:16px;padding-top:24px!important;border-bottom:none!important}
  /* Override dark hero for mobile open menu */
  .has-dark-hero .site-nav.at-top .nav-links.open{background:var(--bg)}
  .has-dark-hero .site-nav.at-top .nav-links.open a{color:var(--text-muted)!important}
  .has-dark-hero .site-nav.at-top .nav-links.open a:hover{color:var(--primary)!important}
  .has-dark-hero .site-nav.at-top .nav-links.open .nav-cta-phone{color:var(--primary)!important}
}

/* ============================================
   HERO
   ============================================ */
.hero{position:relative;min-height:600px;display:flex;align-items:center;padding:calc(var(--nav-height) + 60px) 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,.4) 60%,rgba(0,0,0,.25) 100%)}
.hero .wrap{position:relative;z-index:1}
.hero-content{max-width:640px}
.hero h1{color:#fff;margin-bottom:20px}
.hero-sub{color:rgba(255,255,255,.85);font-size:1.125rem;line-height:1.7;margin-bottom:32px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-phone{font-family:'Archivo',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.hero-phone a{color:#fff}
.hero-phone svg{width:20px;height:20px;color:var(--accent)}
@media(max-width:600px){
  .hero{min-height:520px}
  .hero-phone{font-size:1.25rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{text-align:center;justify-content:center}
}

/* ============================================
   WOOD GRAIN STRIP
   ============================================ */
.wood-strip{height:8px;background:linear-gradient(90deg,#8b6d42 0%,#a0845a 15%,#6e5530 30%,#8b6d42 45%,#a0845a 60%,#6e5530 75%,#8b6d42 90%,#a0845a 100%);background-size:200% 100%;position:relative;overflow:hidden}
.wood-strip::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,transparent 40px,rgba(0,0,0,.04) 40px,rgba(0,0,0,.04) 42px);opacity:.6}
@media(prefers-reduced-motion:no-preference){.wood-strip{animation:grain-drift 20s linear infinite}}
@keyframes grain-drift{to{background-position:200% 0}}

/* ============================================
   SERVICES
   ============================================ */
.services{background:var(--bg)}
.services h2{text-align:center;margin-bottom:12px}
.section-sub{text-align:center;color:var(--text-muted);max-width:560px;margin:0 auto 48px}
.services-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:24px}
.service-card{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-light);transition:transform .25s,box-shadow .25s}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.service-card-img{height:220px;overflow:hidden}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.service-card:hover .service-card-img img{transform:scale(1.04)}
.service-card-body{padding:28px 24px}
.service-card h3{margin-bottom:12px}
.service-card p{color:var(--text-muted);font-size:.9375rem}
.service-card .card-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:600;font-size:.875rem;color:var(--primary);transition:gap .2s}
.service-card .card-link:hover{gap:10px}
.service-card .card-link svg{width:14px;height:14px}
@media(max-width:900px){.services-grid{grid-template-columns:1fr}}

/* ============================================
   ABOUT
   ============================================ */
.about{background:var(--bg-alt);position:relative;overflow:hidden}
.about-inner{display:grid;grid-template-columns:1fr 380px;gap:60px;align-items:center}
.about-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(6rem,10vw,12rem);color:var(--border-light);white-space:nowrap;pointer-events:none;user-select:none;z-index:0;opacity:.5}
html.dark .about-watermark{opacity:.15}
.about-text{position:relative;z-index:1}
.about-text h2{margin-bottom:20px}
.about-text p{color:var(--text-muted)}
.about-text p+p{margin-top:16px}
.about-text .btn{margin-top:28px}
.about-img{position:relative;z-index:1;border-radius:var(--radius);overflow:hidden}
.about-img img{width:100%;height:100%;object-fit:cover;min-height:360px}
@media(max-width:900px){
  .about-inner{grid-template-columns:1fr;gap:40px}
  .about-img{max-height:320px}
}

/* ============================================
   PROCESS
   ============================================ */
.process{background:var(--bg)}
.process h2{text-align:center;margin-bottom:56px}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process-steps::before{content:'';position:absolute;top:32px;left:calc(12.5% + 12px);right:calc(12.5% + 12px);height:2px;background:var(--border)}
.step{text-align:center;position:relative;padding:0 16px}
.step-num{width:64px;height:64px;border-radius:50%;background:var(--primary);color:#fff;font-family:'Archivo',sans-serif;font-weight:700;font-size:1.25rem;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative;z-index:1;border:4px solid var(--bg)}
.step h4{margin-bottom:8px}
.step p{color:var(--text-muted);font-size:.875rem}
@media(max-width:768px){
  .process-steps{grid-template-columns:1fr 1fr;gap:40px 24px}
  .process-steps::before{display:none}
}
@media(max-width:480px){.process-steps{grid-template-columns:1fr}}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials{background:var(--bg-alt)}
.testimonials h2{text-align:center;margin-bottom:48px}
.testimonials-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:32px;position:relative}
.testimonial-card::before{content:'\201C';position:absolute;top:16px;left:24px;font-family:'Archivo',sans-serif;font-size:4rem;color:var(--primary-light);line-height:1}
.testimonial-card blockquote{font-size:1.0625rem;color:var(--text);line-height:1.7;margin-bottom:20px;position:relative;z-index:1}
.testimonial-card cite{font-style:normal;font-weight:600;font-size:.875rem;color:var(--primary)}
.stars{color:var(--accent);margin-bottom:12px;display:flex;gap:2px}
.stars svg{width:16px;height:16px;fill:var(--accent)}
@media(max-width:768px){.testimonials-grid{grid-template-columns:1fr}}

/* ============================================
   FAQ
   ============================================ */
.faq{background:var(--bg)}
.faq h2{text-align:center;margin-bottom:48px}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border-light)}
.faq-item:first-child{border-top:1px solid var(--border-light)}
.faq-q{width:100%;text-align:left;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:600;font-size:1rem;color:var(--text);cursor:pointer;background:none;border:none}
.faq-q svg{width:20px;height:20px;flex-shrink:0;color:var(--text-muted);transition:transform .3s}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 0 20px;color:var(--text-muted);font-size:.9375rem;line-height:1.7}

/* ============================================
   CTA BAND
   ============================================ */
.cta-band{background:var(--primary);color:#fff;text-align:center;padding:64px 0}
.cta-band h2{color:#fff;margin-bottom:16px}
.cta-band p{color:rgba(255,255,255,.85);max-width:520px;margin:0 auto 28px;font-size:1.0625rem}
.cta-band .btn-white{font-weight:600}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:var(--bg-dark);color:rgba(255,255,255,.7);padding:56px 0 calc(3.5rem + 60px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.125rem;color:#fff;margin-bottom:12px}
.footer-brand span{color:var(--accent)}
.footer-desc{font-size:.875rem;line-height:1.7;margin-bottom:20px}
.footer-col h4{color:#fff;font-size:.875rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}
.footer-col a{display:block;font-size:.875rem;padding:4px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-contact-line{display:flex;align-items:center;gap:8px;font-size:.875rem;padding:4px 0}
.footer-contact-line svg{width:14px;height:14px;flex-shrink:0;color:var(--accent)}
.footer-bar{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.8125rem;color:rgba(255,255,255,.4)}
.footer-bar a{transition:color .2s}
.footer-bar a:hover{color:rgba(255,255,255,.7)}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bar{flex-direction:column;text-align:center}
}

/* ============================================
   INTERIOR PAGES
   ============================================ */
.page-header{background:var(--bg-alt);padding:calc(var(--nav-height) + 48px) 0 48px;border-bottom:1px solid var(--border-light)}
.page-header h1{margin-bottom:8px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-muted)}
.breadcrumb a{color:var(--primary);transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:var(--text-faint)}

.page-body{padding:64px 0;background:var(--bg)}
.page-body .content{max-width:760px}
.page-body .content h2{margin:48px 0 16px}
.page-body .content h2:first-child{margin-top:0}
.page-body .content p{color:var(--text-muted)}
.page-body .content ul{margin:16px 0;padding-left:0}
.page-body .content ul li{padding:8px 0 8px 24px;position:relative;color:var(--text-muted)}
.page-body .content ul li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:8px;border-radius:50%;background:var(--primary-light);border:2px solid var(--primary)}

/* Two-column layout for service pages */
.page-two-col{display:grid;grid-template-columns:1fr 340px;gap:60px;align-items:start}
.page-sidebar{position:sticky;top:calc(var(--nav-height) + 24px)}
.sidebar-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:28px;margin-bottom:24px}
.sidebar-card h4{margin-bottom:16px;font-size:1rem}
.sidebar-card ul li{font-size:.9375rem}
.sidebar-card .btn{width:100%;justify-content:center;margin-top:16px}
@media(max-width:900px){
  .page-two-col{grid-template-columns:1fr}
  .page-sidebar{position:static}
}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:500;font-size:.875rem;margin-bottom:6px;color:var(--text)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);transition:border-color .2s,box-shadow .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a5e58' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-msg{padding:14px 18px;border-radius:var(--radius);font-size:.9375rem;font-weight:500;margin-top:16px;display:none}
.form-msg.success{display:block;background:var(--primary-light);color:var(--primary);border:1px solid var(--primary)}
.form-msg.error{display:block;background:#fce8e8;color:#a33;border:1px solid #e8a0a0}
html.dark .form-msg.error{background:#2a1a1a;color:#e88;border-color:#5a2a2a}

.contact-info-block{margin-bottom:28px}
.contact-info-block h3{margin-bottom:16px}
.contact-info-line{display:flex;align-items:flex-start;gap:12px;padding:10px 0;color:var(--text-muted)}
.contact-info-line svg{width:18px;height:18px;flex-shrink:0;color:var(--primary);margin-top:2px}
.contact-info-line a{color:var(--primary);font-weight:500}
.contact-info-line a:hover{text-decoration:underline}

.contact-map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-light);height:200px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;color:var(--text-faint);font-size:.875rem}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* Turnstile */
.cf-turnstile{margin-bottom:16px}

/* ============================================
   404
   ============================================ */
.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;background:linear-gradient(var(--border-light) 1px,transparent 1px),linear-gradient(90deg,var(--border-light) 1px,transparent 1px);background-size:40px 40px}
html.dark .error-page{background:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px}
.error-page h1{font-size:clamp(4rem,8vw,8rem);color:var(--primary);margin-bottom:8px}
.error-page h2{margin-bottom:12px}
.error-page p{color:var(--text-muted);margin-bottom:28px;max-width:400px}
.error-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============================================
   ANIMATIONS (motion-safe)
   ============================================ */
@media(prefers-reduced-motion:no-preference){
  .step-num{animation:step-pop .5s cubic-bezier(.34,1.56,.64,1) both}
  .step:nth-child(2) .step-num{animation-delay:.12s}
  .step:nth-child(3) .step-num{animation-delay:.24s}
  .step:nth-child(4) .step-num{animation-delay:.36s}
  @keyframes step-pop{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}

  .service-card{animation:card-rise .45s ease both}
  .service-card:nth-child(2){animation-delay:.1s}
  .service-card:nth-child(3){animation-delay:.2s}
  @keyframes card-rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
}

/* ============================================
   UTILITIES
   ============================================ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}

/* FOUC prevention */
html:not(.js-ready) body{opacity:0}
html.js-ready body{opacity:1;transition:opacity .15s}

/* Print */
@media print{
  .site-nav,.site-footer,.cta-band,.theme-toggle,.hamburger{display:none!important}
  body{background:#fff;color:#000}
  section{padding:32px 0}
}

/* Disclaimer bar */
.disclaimer-bar{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:90;
  background:#1C1E24;
  color:#9B9DA6;
  font-size:0.8rem;
  text-align:center;
  padding:0.6rem 1rem;
  border-top:1px solid rgba(255,255,255,0.08);
}
