@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Nunito+Sans:wght@400;500;600;700;800&display=swap');

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito Sans',Helvetica,sans-serif;line-height:1.6;transition:background .5s,color .4s}
a{text-decoration:none;color:inherit;transition:color .3s}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit}
ul{list-style:none}

/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:100;font-size:14px;font-weight:600;transition:top .3s}.skip-link:focus{top:0}

/* ── CSS VARIABLES ── */
:root{
  --bg:#f7f3ed;--bg-alt:#efe9df;--bg-card:rgba(90,114,71,.04);--bg-card-hover:rgba(90,114,71,.10);
  --card-border:rgba(90,114,71,.12);--text:#2c2416;--text-muted:#8a7d6b;--text-faint:#b0a594;
  --accent:#5a7247;--accent-dark:#3d5132;--accent-light:rgba(90,114,71,.10);
  --nav-border:rgba(44,36,22,.08);--footer-bg:#2c2416;--footer-text:#a89b8a;--footer-heading:#f7f3ed;
  --review-bg:#fff;--review-border:rgba(90,114,71,.10);--stars:#d4a843;
  --cta-bg:linear-gradient(135deg,#5a7247,#3d5132);--cta-text:#f7f3ed;--cta-btn:#f7f3ed;--cta-btn-text:#3d5132;
  --hero-bg:linear-gradient(170deg,#f7f3ed 0%,#efe9df 40%,#f7f3ed 100%);
  --hero-solid:#f0ece4;--hero-solid-0:rgba(240,236,228,0);
  --services-bg:#efe9df;--logo-filter:none;
}
[data-theme="dark"]{
  --bg:#0a0f0a;--bg-alt:#0d110d;--bg-card:rgba(255,255,255,.02);--bg-card-hover:rgba(90,114,71,.12);
  --card-border:rgba(255,255,255,.04);--text:#e8e6e1;--text-muted:#a8a49c;--text-faint:#7a776f;
  --accent:#6b8a57;--accent-dark:#4a6e3a;--accent-light:rgba(107,138,87,.12);
  --nav-border:rgba(255,255,255,.06);--footer-bg:#060806;--footer-text:#7a776f;--footer-heading:#e8e6e1;
  --review-bg:rgba(255,255,255,.02);--review-border:rgba(255,255,255,.06);
  --cta-bg:linear-gradient(135deg,#1a2e18,#2d5a27);--cta-text:#e8e6e1;--cta-btn:#fff;--cta-btn-text:#1a2e18;
  --hero-bg:linear-gradient(170deg,#0a0f0a 0%,#0d1a0d 40%,#0a0f0a 100%);
  --hero-solid:#0a0f0a;--hero-solid-0:rgba(10,15,10,0);
  --services-bg:#0d110d;--logo-filter:invert(.85) sepia(.15) hue-rotate(50deg);
}
body{background:var(--bg);color:var(--text)}

/* ── TYPOGRAPHY ── */
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.15}
.label{font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--accent);font-weight:700;font-family:'Nunito Sans',sans-serif}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:14px 40px;background:var(--bg);border-bottom:1px solid var(--nav-border)}
.nav-logo{display:flex;align-items:center;gap:14px;margin-right:32px}
.nav-logo-img{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--accent);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--review-bg);flex-shrink:0}
.nav-logo-img img{width:36px;height:36px;object-fit:contain;filter:var(--logo-filter)}
.nav-brand-name{font-size:16px;font-weight:700;letter-spacing:1.5px;color:var(--text);font-family:'Cormorant Garamond',Georgia,serif;line-height:1.1}
.nav-brand-sub{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);font-weight:700;margin-top:2px}
.nav-links{display:flex;gap:20px;font-size:12px;letter-spacing:.5px;font-weight:500;align-items:center}
.nav-links a{color:var(--text-muted);white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-phone{color:var(--accent);font-size:14px;font-weight:700;letter-spacing:.5px;white-space:nowrap;margin-left:8px;display:flex;align-items:center;line-height:1}
.btn-primary{background:var(--accent);color:var(--cta-text);border:none;padding:10px 22px;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:background .4s}
.btn-primary:hover{background:var(--accent-dark)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--card-border);padding:14px 24px;border-radius:6px;font-size:14px;font-weight:600;letter-spacing:.5px;transition:all .4s}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-lg{padding:15px 34px;font-size:13px}

/* Dark mode toggle */
.theme-toggle{width:52px;height:28px;border-radius:14px;border:none;background:var(--accent-light);position:relative;padding:0;transition:background .4s}
.theme-toggle .knob{width:22px;height:22px;border-radius:50%;background:var(--accent);position:absolute;top:3px;left:3px;transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:11px}
[data-theme="dark"] .theme-toggle .knob{left:27px}

/* Mobile menu */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.mobile-menu{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg);z-index:100;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:20px;font-weight:600;color:var(--text)}
.mobile-menu .close-btn{position:absolute;top:20px;right:24px;font-size:28px;background:none;border:none;color:var(--text)}

/* ── HERO ── */
.hero{position:relative;padding:88px 40px 108px;background:var(--hero-bg);overflow:hidden;min-height:520px}
.hero-video-wrap{position:absolute;top:0;right:0;width:60%;height:100%;overflow:hidden}
.hero-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease}
.hero-video.active{opacity:1}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to right,var(--hero-solid) 30%,var(--hero-solid) 40%,var(--hero-solid-0) 75%);z-index:1}
.hero-glow-a{position:absolute;top:-100px;right:-80px;width:480px;height:480px;background:radial-gradient(circle,var(--accent-light) 0%,transparent 70%);border-radius:60% 40% 55% 45%}
.hero-glow-b{position:absolute;bottom:-40px;left:22%;width:300px;height:300px;background:radial-gradient(circle,rgba(180,160,120,.08) 0%,transparent 70%);border-radius:45% 55% 40% 60%}
.hero-content{max-width:680px;position:relative;z-index:2}
.hero-badges{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap}
.hero-badge{background:var(--accent-light);color:var(--accent);padding:5px 14px;border-radius:16px;font-weight:700;font-size:12px;letter-spacing:.5px}
.isa-badge{width:120px;height:auto;margin-bottom:20px;border-radius:8px}
.hero h1{font-size:56px;margin:0 0 24px}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p{font-size:18px;line-height:1.75;color:var(--text-muted);max-width:520px;margin:0 0 40px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}

/* Stats strip */
.stats{display:flex;gap:48px;margin-top:80px;padding-top:40px;border-top:1px solid var(--nav-border);flex-wrap:wrap;position:relative;z-index:2}
.stat-num{font-size:32px;font-weight:800;color:var(--accent);font-family:'Cormorant Garamond',serif}
.stat-label{font-size:11px;color:var(--text-faint);letter-spacing:2.5px;text-transform:uppercase;margin-top:4px;font-weight:600}

/* ── SERVICES GRID ── */
.services-section{padding:76px 40px;background:var(--services-bg);transition:background .5s}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:12px}
.section-header h2{font-size:40px}
.section-link{font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.5px}
.section-link:hover{text-decoration:underline}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.service-card{padding:38px;background:var(--bg-card);border:1px solid var(--card-border);transition:all .4s;cursor:pointer;border-radius:2px}
.service-card:hover{background:var(--bg-card-hover);transform:translateY(-3px)}
.service-card .icon{font-size:30px;margin-bottom:14px}
.service-card h3{font-size:19px;font-weight:600;margin:0 0 10px}
.service-card p{font-size:14px;line-height:1.75;color:var(--text-muted);margin:0}

/* ── ABOUT SECTION ── */
.about-section{padding:76px 40px;background:var(--bg)}
.about-inner{display:grid;grid-template-columns:1fr 280px;gap:48px;align-items:start}
.about-text .label{margin-bottom:12px;display:block}
.about-text h2{font-size:36px;margin:0 0 24px}
.about-text p{font-size:15px;line-height:1.85;color:var(--text-muted);margin:0 0 16px}
.about-stats{display:flex;flex-direction:column;gap:20px;position:sticky;top:120px}
.about-stat{padding:24px;background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px;text-align:center}
.about-stat-num{font-size:28px;font-weight:800;color:var(--accent);font-family:'Cormorant Garamond',serif}
.about-stat-label{font-size:11px;color:var(--text-faint);letter-spacing:2px;text-transform:uppercase;margin-top:4px;font-weight:600}

/* ── PROCESS / HOW IT WORKS ── */
.process-section{padding:64px 40px;background:var(--bg-card)}
.process-section h2{font-size:32px;margin:0 0 40px;text-align:center}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.process-step{text-align:center}
.process-num{width:54px;height:54px;border-radius:50%;margin:0 auto 14px;background:var(--accent);color:var(--cta-text);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800}
.process-step h4{font-size:15px;font-weight:700;margin-bottom:6px}
.process-step p{font-size:13px;color:var(--text-muted);line-height:1.65}

/* ── CTA BANNER ── */
.cta-banner{padding:56px 40px;text-align:center;background:var(--cta-bg);color:var(--cta-text);position:relative;overflow:hidden}
.cta-banner .dots{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(rgba(255,255,255,.4) 1px,transparent 1px);background-size:18px 18px}
.cta-banner h2{font-size:34px;margin:0 0 10px;position:relative}
.cta-banner p{font-size:15px;opacity:.85;margin:0 0 28px;position:relative}
.cta-banner .btn{background:var(--cta-btn);color:var(--cta-btn-text);border:none;padding:15px 38px;border-radius:6px;font-size:13px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;position:relative}

/* ── REVIEWS ── */
.reviews-section{padding:76px 40px;background:var(--bg)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{padding:34px;background:var(--review-bg);border:1px solid var(--review-border);border-radius:4px}
.review-stars{color:var(--stars);font-size:18px;margin-bottom:14px}
.review-card blockquote{font-size:15px;line-height:1.8;color:var(--text-muted);margin:0 0 18px;font-style:italic}
.review-name{font-size:14px;font-weight:700}
.review-loc{font-size:12px;color:var(--text-faint)}

/* ── PAGE HERO (subpages) ── */
.page-hero{padding:80px 40px 60px;background:var(--hero-bg);position:relative;overflow:hidden}
.page-hero h1{font-size:48px;margin:0 0 16px}
.page-hero p{font-size:17px;color:var(--text-muted);max-width:600px}
.page-hero .label{margin-bottom:12px;display:block}

/* ── SERVICE DETAIL CARDS ── */
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:60px 40px}
.detail-card{padding:36px;background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px}
.detail-card h3{font-size:22px;margin:0 0 12px}
.detail-card p{font-size:15px;line-height:1.75;color:var(--text-muted);margin:0}

/* ── GALLERY ── */
.gallery-filters{display:flex;justify-content:center;gap:8px;padding:32px 40px 0;flex-wrap:wrap}
.gallery-filter{background:var(--bg-card);border:1px solid var(--card-border);padding:8px 20px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;transition:all .3s;font-family:inherit}
.gallery-filter:hover,.gallery-filter.active{background:var(--accent);color:var(--cta-text);border-color:var(--accent)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:24px 40px 40px}
.gallery-item{overflow:hidden;border-radius:4px;background:var(--bg-alt);position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .5s}
.gallery-item:hover img{transform:scale(1.05);filter:brightness(.75)}
.gallery-item .gallery-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px;opacity:0;transition:opacity .4s;pointer-events:none}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px}
.gallery-overlay small{color:rgba(255,255,255,.7);font-size:11px;margin-top:2px}
.gallery-item--tall{grid-row:span 2}
.gallery-item--wide{grid-column:span 2}
.gallery-item--tall img{height:100%}
.gallery-item:not(.gallery-item--tall){aspect-ratio:4/3}
.gallery-item--tall{min-height:0}

/* ── CONTACT FORM ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:60px 40px}
.contact-info h3{font-size:24px;margin:0 0 16px}
.contact-info p{color:var(--text-muted);margin-bottom:12px;line-height:1.7}
.contact-info .info-item{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-size:15px}
.contact-info .info-item .icon{font-size:22px}
.contact-form label{display:block;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:12px 16px;border:1px solid var(--card-border);border-radius:6px;background:var(--bg);color:var(--text);font-size:15px;font-family:inherit;margin-bottom:20px;transition:border-color .3s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--accent)}
.contact-form input[type="file"]{padding:10px 12px;font-size:13px;cursor:pointer}
.contact-form textarea{min-height:140px;resize:vertical}

/* ── FAQ ── */
.faq-section{padding:60px 40px}
.faq-item{border-bottom:1px solid var(--card-border);padding:20px 0}
.faq-q{font-size:17px;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:22px;color:var(--accent);font-weight:400}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s;color:var(--text-muted);font-size:15px;line-height:1.7}
.faq-item.open .faq-a{max-height:300px;padding-top:12px}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:40px}
.blog-card{background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px;overflow:hidden;transition:transform .3s}
.blog-card:hover{transform:translateY(-4px)}
.blog-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt)}
.blog-card-img img{width:100%;height:100%;object-fit:cover}
.blog-card-body{padding:24px}
.blog-card-body .date{font-size:12px;color:var(--text-faint);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.blog-card-body h3{font-size:18px;margin:0 0 8px}
.blog-card-body p{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0}

/* ── BLOG ARTICLE ── */
.blog-article{max-width:760px;margin:0 auto;padding:48px 40px 60px}
.blog-article .back-link{font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.5px;display:inline-block;margin-bottom:24px}
.blog-article .back-link:hover{text-decoration:underline}
.blog-article .article-date{font-size:12px;color:var(--text-faint);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.blog-article h1{font-size:38px;margin:0 0 24px;line-height:1.2}
.blog-article .article-hero{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;margin-bottom:32px}
.blog-article p{font-size:16px;line-height:1.85;color:var(--text-muted);margin-bottom:20px}
.blog-article h2{font-size:26px;margin:36px 0 16px}
.blog-article ul,.blog-article ol{margin:0 0 20px 24px;color:var(--text-muted);font-size:16px;line-height:1.85}
.blog-article li{margin-bottom:8px}
.blog-article .article-cta{margin-top:40px;padding:32px;background:var(--accent-light);border-radius:8px;text-align:center}
.blog-article .article-cta h3{font-size:22px;margin:0 0 8px}
.blog-article .article-cta p{text-align:center}
@media(max-width:600px){.blog-article{padding:32px 20px 40px}.blog-article h1{font-size:28px}}

/* ── FOOTER ── */
.footer{padding:44px 40px 28px;border-top:1px solid var(--nav-border);background:var(--footer-bg);color:var(--footer-text);font-size:13px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px;transition:all .5s}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.footer-logo-img{width:40px;height:40px;border-radius:50%;border:1px solid var(--accent);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--review-bg)}
.footer-logo-img img{width:32px;height:32px;object-fit:contain;filter:var(--logo-filter)}
.footer-brand{color:var(--footer-heading);font-weight:700;font-size:15px;font-family:'Cormorant Garamond',Georgia,serif}
.footer-tags{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.footer-tag{background:var(--accent-light);padding:3px 10px;border-radius:4px;font-size:11px;font-weight:600;color:var(--accent)}
.footer-isa-badge{width:90px;height:auto;border-radius:4px;align-self:center}
.footer-socials{display:flex;gap:12px;margin-top:14px}
.footer-socials a{width:34px;height:34px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;transition:background .3s}
.footer-socials a:hover{background:var(--accent)}
.footer-socials a svg{width:16px;height:16px;fill:var(--accent);transition:fill .3s}
.footer-socials a:hover svg{fill:var(--cta-text)}
.footer-right{text-align:right}
.footer-phone{color:var(--accent);font-size:20px;font-weight:800;margin-bottom:4px}

/* ── IMAGE HERO OVERLAY ── */
.img-hero{position:relative;min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.img-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.img-hero .overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.55),rgba(0,0,0,.7))}
.img-hero .content{position:relative;z-index:2;text-align:center;color:#fff;padding:40px}
.img-hero h1{color:#fff;font-size:48px}
.img-hero p{color:rgba(255,255,255,.8);font-size:18px;max-width:600px;margin:12px auto 0}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-phone,.nav-right .btn-primary{display:none}
  .nav-right{gap:10px}
  .hero h1,.page-hero h1,.img-hero h1{font-size:36px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr;padding:40px 20px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);padding:24px 20px 40px}
  .gallery-item--tall{grid-row:span 1}
  .gallery-item--wide{grid-column:span 1}
  .gallery-filters{padding:24px 20px 0}
  .blog-grid{grid-template-columns:1fr;padding:24px 20px}
  .contact-grid{grid-template-columns:1fr;padding:40px 20px;gap:32px}
  .stats{gap:24px}
  .about-inner{grid-template-columns:1fr;gap:32px}
  .about-stats{flex-direction:row;flex-wrap:wrap;position:static}
  .about-stat{flex:1;min-width:120px}
  .hero,.page-hero,.services-section,.process-section,.reviews-section,.cta-banner,.faq-section,.about-section{padding-left:20px;padding-right:20px}
  .nav{padding:16px 20px}
  .nav-logo{margin-right:0}
  .footer{padding:32px 20px 20px;flex-direction:column;gap:20px}
  .footer-right{text-align:left}
  .hero-video-wrap{width:100%;opacity:.3}
  .hero-overlay{background:linear-gradient(to right,var(--hero-solid) 20%,var(--hero-solid-0) 90%)}
}
@media(max-width:600px){
  .services-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .hero h1,.page-hero h1,.img-hero h1{font-size:30px}
  .hero p{font-size:16px}
  .stats{flex-direction:column;gap:16px}
  .process-grid{grid-template-columns:1fr}
  .cta-banner h2{font-size:26px}
}
