﻿/* Polished styles for Pacific Northwest Renovation LLC - Super Reactive & Mesmerizing */
:root{
  --accent:#0b6fa4;
  --accent-2:#005b88;
  --dark:#0b2436;
  --muted:#6b7785;
  --bg:#f6fbff;
  --card:#ffffff;
  --max-width:1100px;
  --radius:10px;
  --transition: 300ms cubic-bezier(.2,.9,.1,1);
  --transition-slow: 420ms cubic-bezier(.2,.9,.1,1);
}
*{box-sizing:border-box}
html,body{height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Arial,sans-serif;margin:0;color:var(--dark);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.container{max-width:var(--max-width);margin:0 auto;padding:28px}
.site-header{background:rgba(255,255,255,0.92);backdrop-filter:saturate(120%) blur(8px);position:sticky;top:0;z-index:40;border-bottom:1px solid rgba(14,55,72,0.06);transition:all var(--transition)}
.site-header.shrink{box-shadow:0 6px 20px rgba(11,59,84,0.08)}
.header-inner{display:flex;gap:24px;align-items:center;justify-content:space-between}
.brand{display:flex;gap:12px;align-items:center;text-decoration:none;color:inherit;flex:1;transition:transform var(--transition)}
.brand:hover{transform:translateY(-2px)}
.logo{width:56px;height:56px;transition:width var(--transition),height var(--transition)}
.site-header.shrink .logo{width:44px;height:44px}
.brand-text h1{margin:0;font-size:1.05rem;font-weight:600}
.tag{margin:2px 0 0;color:var(--muted);font-size:0.85rem;font-weight:400}
.nav{display:flex;align-items:center;gap:12px;flex:1;justify-content:center}
.nav-links{display:none;list-style:none;padding:0;margin:0;gap:12px}
.nav-links.open{display:flex;flex-direction:column;position:absolute;right:28px;top:72px;background:linear-gradient(180deg,rgba(255,255,255,0.98),white);padding:12px;border-radius:10px;box-shadow:0 12px 28px rgba(11,59,84,0.12);z-index:50}
.nav-links li{display:inline-block}
.nav-links a{color:var(--dark);text-decoration:none;padding:8px 12px;border-radius:6px;transition:background-color var(--transition),color var(--transition)}
.nav-links a:hover{background:rgba(11,111,164,0.08);color:var(--accent)}
#nav-toggle{background:transparent;border:0;font-size:1.2rem;cursor:pointer;padding:4px;color:var(--dark);transition:transform var(--transition)}
#nav-toggle:hover{transform:scale(1.1)}
.header-ctas{display:flex;gap:10px;align-items:center}
.phone{color:var(--accent);text-decoration:none;font-weight:600;transition:color var(--transition)}
.phone:hover{color:var(--accent-2)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:8px;text-decoration:none;border:0;cursor:pointer;font-weight:500;font-size:0.95rem;transition:all var(--transition);white-space:nowrap}
.btn-primary{background:var(--accent);color:white;box-shadow:0 4px 12px rgba(11,111,164,0.2)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 8px 20px rgba(11,111,164,0.3)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:white;border:1px solid rgba(11,111,164,0.2);color:var(--accent)}
.btn-outline:hover{background:rgba(11,111,164,0.04);border-color:var(--accent);transform:translateY(-2px)}
.btn-large{padding:12px 20px;font-size:1rem}
.btn-block{width:100%}


.hero{position:relative;overflow:hidden;min-height:360px}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-image{width:100%;height:100%;object-fit:cover;display:block}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.4),rgba(0,0,0,0.2));pointer-events:none}
.hero-content{position:relative;z-index:10;display:flex;align-items:center;min-height:360px;color:white;text-align:left;padding:28px;animation:heroReveal var(--transition-slow) ease-out}
@keyframes heroReveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero-content h2{font-size:clamp(1.8rem,4vw,2.4rem);margin:0 0 12px;text-shadow:0 4px 12px rgba(0,0,0,0.3);line-height:1.2}
.lead{font-size:1rem;color:rgba(255,255,255,0.95);margin:0 0 20px;max-width:600px;text-shadow:0 2px 8px rgba(0,0,0,0.2)}
.hero-ctas{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.hero-ctas .btn{animation:fadeInUp 420ms ease-out 100ms backwards}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.trust-list{list-style:none;padding:0;margin:0;display:flex;gap:24px;flex-wrap:wrap;font-size:0.95rem;color:rgba(255,255,255,0.9);text-shadow:0 2px 4px rgba(0,0,0,0.2)}
.trust-list li{display:flex;align-items:center;gap:6px}

.section{padding:48px 0;background:transparent;opacity:1;transform:none}
.section.reveal{animation:sectionReveal var(--transition-slow) ease-out forwards}
@keyframes sectionReveal{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.section h2{margin:0 0 8px;font-size:clamp(1.5rem,3vw,1.8rem);color:var(--dark)}
.section-sub{color:var(--muted);margin:8px 0 24px;font-size:1rem}

.cards{display:grid;grid-template-columns:1fr;gap:16px}
.card{background:var(--card);padding:24px;border-radius:var(--radius);box-shadow:0 4px 12px rgba(11,59,84,0.06);border:1px solid rgba(11,111,164,0.06);transition:all var(--transition)}
.card h3{margin:0 0 12px;font-size:1.1rem;color:var(--dark)}
.card p{margin:0;color:var(--muted);line-height:1.6}
.card:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(11,59,84,0.12);border-color:rgba(11,111,164,0.12)}

.gallery{display:grid;grid-template-columns:1fr;gap:14px}
.gallery-item{position:relative;overflow:hidden;border-radius:10px;cursor:pointer;margin:0;transition:transform var(--transition),filter var(--transition)}
.gallery-item:focus{outline:3px solid var(--accent);outline-offset:2px}
.gallery-item img{width:100%;height:240px;object-fit:cover;display:block;transition:transform var(--transition),filter var(--transition)}
.gallery-item:hover img{transform:scale(1.05);filter:brightness(0.85)}
.gallery-item figcaption{position:absolute;left:14px;bottom:14px;color:white;background:linear-gradient(0deg,rgba(0,0,0,0.6),rgba(0,0,0,0.2));padding:10px 12px;border-radius:8px;font-size:0.95rem;font-weight:500;opacity:0.9;transition:opacity var(--transition)}
.gallery-item:hover figcaption{opacity:1}

.lazy{opacity:0;transform:translateY(12px)}
.lazy.loaded{opacity:1;transform:none;transition:opacity 400ms ease,transform 400ms ease}

.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(2,6,10,0.8);z-index:1000;opacity:0;pointer-events:none;transition:opacity 220ms ease;backdrop-filter:blur(4px)}
.lightbox[aria-hidden="false"]{opacity:1;pointer-events:auto}
.lightbox-content{max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0;animation:lightboxReveal 220ms ease-out}
@keyframes lightboxReveal{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:none}}
.lightbox-content img{max-width:100%;max-height:72vh;border-radius:12px;box-shadow:0 12px 48px rgba(2,6,10,0.4)}
.lightbox-content figcaption{color:rgba(255,255,255,0.95);margin-top:12px;font-size:0.95rem;text-align:center}
.lightbox-close,.lightbox-prev,.lightbox-next{position:fixed;background:rgba(255,255,255,0.1);border:0;color:white;font-size:28px;padding:12px 14px;cursor:pointer;border-radius:6px;transition:all var(--transition);backdrop-filter:blur(4px)}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,0.2)}
.lightbox-close{top:20px;right:20px}
.lightbox-prev{left:20px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:20px;top:50%;transform:translateY(-50%)}

.process-list{padding-left:20px}
.process-list li{margin-bottom:16px;line-height:1.7;color:var(--dark)}
.process-list strong{color:var(--accent);font-weight:600}

.contact-grid{display:grid;grid-template-columns:1fr;gap:24px}
.contact-details p{margin:8px 0;line-height:1.7}
.contact-details a{color:var(--accent);text-decoration:none;font-weight:500;transition:color var(--transition)}
.contact-details a:hover{color:var(--accent-2);text-decoration:underline}
.contact-form{background:var(--card);padding:28px;border-radius:12px;box-shadow:0 6px 20px rgba(11,59,84,0.08)}
.form-row{margin-bottom:16px}
.form-row label{display:block;margin-bottom:6px;font-size:0.95rem;font-weight:500;color:var(--dark)}
.form-row input,.form-row textarea,.form-row select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(11,111,164,0.15);font-size:0.95rem;font-family:inherit;transition:all var(--transition);background:white;color:var(--dark)}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(11,111,164,0.1)}
.form-note{font-size:0.85rem;color:var(--muted);margin-top:12px}

.site-footer{background:rgba(11,36,54,0.02);border-top:1px solid rgba(11,111,164,0.06);padding:32px 0;margin-top:48px}
.footer-inner{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:flex-start}
.site-footer p{margin:6px 0;font-size:0.95rem;color:var(--muted)}
.site-footer strong{color:var(--dark)}
.site-footer a{color:var(--accent);text-decoration:none;transition:color var(--transition)}
.site-footer a:hover{color:var(--accent-2)}

.to-top{position:fixed;right:20px;bottom:20px;border-radius:10px;background:var(--accent);color:white;border:0;padding:10px 12px;font-size:1.2rem;box-shadow:0 8px 24px rgba(11,111,164,0.25);cursor:pointer;opacity:0;pointer-events:none;transform:translateY(8px);transition:all var(--transition);z-index:800}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{background:var(--accent-2);box-shadow:0 12px 32px rgba(11,111,164,0.35);transform:translateY(-2px)}

a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:3px solid rgba(11,111,164,0.3);outline-offset:2px}

@media(max-width:719px){
  .phone{display:none}
}

@media(min-width:720px){
  .nav-links{display:flex}
  #nav-toggle{display:none}
  .cards{grid-template-columns:repeat(3,1fr);gap:18px}
  .gallery{grid-template-columns:repeat(3,1fr);gap:16px}
  .gallery-item img{height:240px}
  .contact-grid{grid-template-columns:1fr 420px}
  .hero{min-height:520px}
  .hero-content{min-height:520px;padding:48px 28px}
}

