/* LET'S GO!! Train Dogs - Sunpeak v3 */
:root {
  --brand: #1C8585;
  --brand-dark: #136969;
  --brand-light: #e8f5f5;
  --white: #ffffff;
  --gray-light: #f7f7f7;
  --gray: #666;
  --text: #222;
  --radius: 8px;
  --shadow: 0 2px 12px rgba(0,0,0,.10);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--text);line-height:1.6;background:#fff}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1100px;margin:0 auto;padding:0 20px}

/* BUTTONS */
.btn{display:inline-block;padding:12px 28px;border-radius:var(--radius);font-weight:700;font-size:1rem;cursor:pointer;transition:.2s;border:2px solid transparent;text-align:center}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-primary:hover{background:var(--brand-dark);border-color:var(--brand-dark);text-decoration:none}
.btn-outline{background:transparent;color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--brand);text-decoration:none}

/* HEADER */
.site-header{background:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:16px;height:70px}
.header-logo{height:44px;width:auto;object-fit:contain}
.logo-link{flex-shrink:0}
.desktop-nav{margin-left:auto}
.nav-list{display:flex;align-items:center;gap:6px;list-style:none;flex-wrap:nowrap}
.nav-link,.drop-btn{display:inline-block;padding:8px 16px;background:var(--brand);color:#fff!important;border-radius:24px;font-size:.88rem;font-weight:600;border:none;cursor:pointer;white-space:nowrap;transition:.15s;line-height:1.2}
.nav-link:hover,.drop-btn:hover{background:var(--brand-dark);color:#fff!important;text-decoration:none}
.nav-phone{background:transparent!important;color:var(--brand)!important;font-weight:700;border-radius:24px;padding:8px 14px!important;border:2px solid var(--brand)!important;font-size:.88rem}
.nav-phone:hover{background:var(--brand-light)!important;text-decoration:none!important}
.dropdown{position:relative}
.drop-menu{display:none;position:absolute;top:100%;left:0;background:#fff;box-shadow:var(--shadow);border-radius:var(--radius);min-width:220px;list-style:none;z-index:200;padding:8px 0}
.drop-menu li a{display:block;padding:10px 16px;color:var(--text);font-size:.93rem}
.drop-menu li a:hover{color:var(--brand);background:var(--brand-light)}
.drop-menu.show{display:block}
.drop-areas{min-width:180px}
.nav-cta-btn{display:inline-block;padding:8px 18px;background:#fff;color:var(--brand)!important;border-radius:24px;font-size:.88rem;font-weight:700;border:2px solid #fff;white-space:nowrap;transition:.15s;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.nav-cta-btn:hover{background:var(--brand-light);color:var(--brand-dark)!important;text-decoration:none}
.hamburger{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto}
.mobile-nav{display:none;background:#fff;padding:16px 20px;border-top:1px solid #eee}
.mobile-nav.open{display:block}
.mobile-nav ul{list-style:none}
.mobile-nav > ul > li{padding:8px 0;border-bottom:1px solid #eee}
.mobile-nav ul ul{padding-left:16px;margin-top:6px}
.mobile-nav a{color:var(--text);font-size:1rem}

/* TRUST BAR */
.trust-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 32px;background:var(--brand);color:#fff;font-weight:700;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;padding:12px 20px}
.trust-bar span::before{content:"✓  "}

/* STEPS */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:8px}
.step{text-align:center;padding:32px 24px;background:#fff;border-radius:12px;box-shadow:var(--shadow)}
.step-num{display:flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--brand);color:#fff;border-radius:50%;font-size:1.4rem;font-weight:700;margin:0 auto 16px}
.step h3{margin-bottom:10px}
.step p{font-size:.95rem;color:var(--gray)}

/* PHOTO STRIP */
.photo-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory}
.photo-strip::-webkit-scrollbar{height:4px}
.photo-strip::-webkit-scrollbar-thumb{background:var(--brand);border-radius:4px}
.strip-img{flex:0 0 260px;height:200px;object-fit:cover;border-radius:10px;scroll-snap-align:start}

/* CHECK LIST */
.check-list{list-style:none;margin:16px 0;display:flex;flex-direction:column;gap:10px}
.check-list li{padding-left:28px;position:relative;font-size:1rem;color:#333;line-height:1.6}
.check-list li::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:700}

/* ROUNDED IMAGE */
.rounded-img{border-radius:12px;width:100%;aspect-ratio:4/3;object-fit:cover}

/* CONTACT HOME GRID */
.contact-home-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:32px}
.contact-info-block iframe.map-embed{width:100%;height:280px;border:0;border-radius:12px;display:block;margin-bottom:20px}
.contact-details p{margin-bottom:4px;font-size:.95rem}

/* HERO */
.hero{position:relative;background:#1a1a1a;color:#fff;min-height:520px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;z-index:0;opacity:.55}
.hero-content{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:80px 24px}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.15;margin-bottom:16px;max-width:640px}
.hero p{font-size:1.2rem;margin-bottom:28px;max-width:560px;opacity:.92}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-short{min-height:300px}

/* SECTIONS */
section{padding:64px 0}
section:nth-child(even){background:var(--gray-light)}
.section-tag{font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;margin-bottom:20px;color:var(--text)}
h3{font-size:1.2rem;font-weight:700;margin-bottom:10px;color:var(--text)}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:32px}
.service-card{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:28px;transition:.2s;border:2px solid transparent}
.service-card:hover{border-color:var(--brand);transform:translateY(-2px)}
.service-card-icon{width:48px;height:48px;background:var(--brand-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.service-card-icon svg{width:24px;height:24px;fill:var(--brand)}
.service-card h3{font-size:1.1rem}
.service-card p{font-size:.95rem;color:var(--gray);margin:10px 0 16px}
.service-card a{color:var(--brand);font-weight:600;font-size:.95rem}

/* TWO-COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.two-col.flip{direction:rtl}
.two-col.flip > *{direction:ltr}
.two-col img{border-radius:12px;width:100%;aspect-ratio:4/3;object-fit:cover}

/* CONTENT SECTIONS (service pages) */
.content-section{padding:48px 0}
.content-section h2{margin-bottom:16px}
.content-section p{font-size:1.05rem;color:#444;line-height:1.75}

/* FAQ ACCORDION */
.faq-list{margin-top:28px;border-top:1px solid #e0e0e0}
.faq-item{border-bottom:1px solid #e0e0e0}
.faq-btn{width:100%;text-align:left;background:none;border:none;padding:18px 4px;font-size:1.05rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--text)}
.faq-btn:hover{color:var(--brand)}
.faq-btn .icon{font-size:1.3rem;color:var(--brand);flex-shrink:0;transition:.2s}
.faq-body{display:none;padding:0 4px 18px;font-size:.97rem;color:#444;line-height:1.75}
.faq-item.open .faq-body{display:block}
.faq-item.open .icon{transform:rotate(45deg)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:24px}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;loading:lazy}

/* FORM SECTION */
.form-section{padding:64px 0;background:var(--gray-light)}
.form-section h2{text-align:center;margin-bottom:8px}
.form-section .sub{text-align:center;color:var(--gray);margin-bottom:32px}
.form-wrap{max-width:720px;margin:0 auto}
.form-map-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.form-map-grid iframe.map-embed{width:100%;height:450px;border:0;border-radius:12px;display:block}
@media(max-width:900px){.form-map-grid{grid-template-columns:1fr}}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;align-items:start}
.contact-info h3{font-size:1.1rem;margin-bottom:6px}
.contact-info p{margin-bottom:14px;color:#444}
.contact-info a{color:var(--brand)}

/* ABOUT */
.testimonial-pull{background:var(--brand);color:#fff;border-radius:12px;padding:36px 40px;margin:40px 0;font-size:1.15rem;font-style:italic;line-height:1.7}
.testimonial-pull cite{display:block;margin-top:12px;font-style:normal;font-weight:700;font-size:.95rem;opacity:.85}

/* REVIEW WIDGET */
.reviews-section{padding:48px 0}
.reviews-section h2{margin-bottom:24px;text-align:center}

/* CTA BAND */
.cta-band{background:var(--brand);color:#fff;text-align:center;padding:56px 20px}
.cta-band h2{color:#fff;margin-bottom:12px}
.cta-band p{margin-bottom:28px;opacity:.9;font-size:1.05rem}

/* FOOTER */
.site-footer{background:#1a1a1a;color:#ccc;padding:56px 0 0}
.footer-inner{max-width:1100px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.footer-brand .footer-logo{height:44px;margin-bottom:14px;filter:brightness(0) invert(1)}
.footer-brand p{margin-bottom:6px;font-size:.93rem}
.footer-brand a{color:#ccc}
.footer-links h4{color:#fff;margin-bottom:12px;font-size:.95rem}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:7px}
.footer-links a{color:#bbb;font-size:.9rem}
.footer-links a:hover{color:#fff}
.footer-hours{font-size:.82rem;margin-top:12px;color:#999}
.footer-bottom{border-top:1px solid #333;margin-top:40px;padding:16px 20px;text-align:center;font-size:.85rem;color:#777}

/* RESPONSIVE */
@media(max-width:900px){
  .two-col{grid-template-columns:1fr}
  .two-col.flip{direction:ltr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .contact-home-grid{grid-template-columns:1fr}
  .form-map-grid{grid-template-columns:1fr}
}
@media(max-width:680px){
  .desktop-nav{display:none}
  .hamburger{display:block}
  .hero{min-height:420px}
  .hero-short{min-height:220px}
  .footer-inner{grid-template-columns:1fr}
  .trust-bar{gap:6px 16px;font-size:.78rem}
}
