:root{
  --green:#2f5e2d;
  --green-deep:#203f1f;
  --brown:#80512b;
  --gold:#b88339;
  --cream:#f5f1e8;
  --ink:#152115;
  --muted:#687666;
  --white:#ffffff;
  --shadow:0 18px 55px rgba(23, 37, 22, .12);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ink);background:#fff;overflow-x:hidden}
h1,h2,h3,h4,h5,.brand-text{font-family:'Manrope',sans-serif}
a{text-decoration:none}
img{max-width:100%}
.topbar{background:linear-gradient(90deg,var(--green-deep),var(--brown))}
.main-nav{background:rgba(17,31,16,.92);backdrop-filter:blur(12px)}
.brand-logo{width:58px;height:58px;object-fit:contain;background:#fff;border-radius:50%;padding:4px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.navbar .nav-link{color:#ecf4ec!important;font-weight:600;padding:.9rem 1rem!important}
.navbar .nav-link.active,.navbar .nav-link:hover{color:#fff!important}
.btn-brand{background:linear-gradient(135deg,var(--gold),#d5a560);color:#172617;border:none;font-weight:800;padding:.9rem 1.3rem;border-radius:999px;box-shadow:var(--shadow)}
.btn-brand:hover{transform:translateY(-1px);color:#172617}
.btn-outline-brand{border:1px solid rgba(255,255,255,.45);color:#fff;border-radius:999px;padding:.9rem 1.3rem;font-weight:700}
.btn-outline-brand:hover{background:#fff;color:var(--green)}
.mega-menu{width:min(100%,1050px);left:50%!important;transform:translateX(-50%);margin-top:0;padding:0;border-radius:24px}
.mega-copy{background:radial-gradient(circle at top right,rgba(255,255,255,.18),transparent 35%),linear-gradient(180deg,var(--green),var(--green-deep))}
.mega-service-card{display:flex;gap:1rem;align-items:flex-start;padding:1rem;border-radius:18px;color:var(--ink);background:#fff;border:1px solid #edf1ea;height:100%;transition:.25s ease}
.mega-service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--green)}
.service-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:rgba(47,94,45,.1);color:var(--green);font-size:1.15rem;flex:0 0 44px}
.eyebrow,.mini-label{letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;font-weight:800;color:var(--gold)}
.hero{position:relative;isolation:isolate;background:linear-gradient(180deg,rgba(18,29,16,.72),rgba(18,29,16,.84)),url('../images/real/large-tree-removal-niles-mi.webp') center 30%/cover no-repeat;color:#fff;padding:7rem 0 6rem;overflow:hidden}
.hero::after{content:'';position:absolute;inset:auto 0 -90px 0;height:180px;background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 60%);z-index:-1}
.hero h1{font-size:clamp(2.5rem,5vw,4.5rem);line-height:1.02;letter-spacing:-.03em}
.hero p{font-size:1.08rem;color:#e6ede6}
.hero-badges{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.4rem}
.hero-badges span,.tag-pill,.stat-chip{background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);padding:.7rem 1rem;border-radius:999px;color:#fff;font-weight:600}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:1.4rem;backdrop-filter:blur(12px);box-shadow:var(--shadow)}
.hero-visual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.hero-shot{min-height:180px;border-radius:20px;background-size:cover;background-position:center;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.15)}
.hero-shot.tall{min-height:380px;grid-row:span 2}
.section-pad{padding:5.5rem 0}
.section-soft{background:linear-gradient(180deg,#fff, var(--cream))}
.section-title{max-width:760px;margin-bottom:2rem}
.section-title h2{font-size:clamp(2rem,4vw,3rem);line-height:1.05;margin-bottom:.7rem}
.trust-strip{margin-top:-2rem;position:relative;z-index:5}
.trust-wrap{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:1.3rem 1.5rem}
.trust-item{display:flex;gap:1rem;align-items:flex-start}
.trust-item i{font-size:1.35rem;color:var(--green)}
.image-panel,.service-visual,.gallery-tile,.cta-visual{border-radius:24px;background-size:cover;background-position:center;box-shadow:var(--shadow)}
.image-panel{min-height:480px}
.service-card{background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid #eef1eb;transition:.3s ease}
.service-card:hover{transform:translateY(-8px)}
.service-visual{min-height:240px}
.text-link{font-weight:800;color:var(--green)}
.text-link i{transition:.2s ease}
.text-link:hover i{transform:translateX(4px)}
.feature-card,.process-card,.faq-card,.contact-card,.stat-card,.testimonial-card{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:var(--shadow);border:1px solid #eef1eb;height:100%}
.feature-card i,.process-card .number-badge,.stat-card i{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:rgba(47,94,45,.1);color:var(--green);font-size:1.3rem;margin-bottom:1rem}
.process-card .number-badge{font-weight:800;font-style:normal}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat-card strong{display:block;font-size:2rem;line-height:1}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start}
.check-list i{color:var(--green);font-size:1.1rem;margin-top:.1rem}
.gallery-grid{columns:3 260px;column-gap:1rem}
.gallery-tile{break-inside:avoid;display:block;min-height:240px;margin-bottom:1rem;position:relative;overflow:hidden}
.gallery-tile.large{min-height:360px}
.gallery-tile::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(11,20,10,.72));opacity:.95}
.gallery-tile span{position:absolute;left:1rem;right:1rem;bottom:1rem;color:#fff;font-weight:700}
.page-hero{padding:5rem 0;background:linear-gradient(180deg,rgba(17,31,16,.82),rgba(47,94,45,.86)),url('../images/real/tree-removal-niles-mi.webp') center/cover;color:#fff}
.breadcrumb-clean{--bs-breadcrumb-divider:'›'}
.contact-form .form-control,.contact-form .form-select{border-radius:16px;border:1px solid #dfe6dd;padding:.95rem 1rem}
.contact-form .form-control:focus,.contact-form .form-select:focus{box-shadow:0 0 0 .2rem rgba(47,94,45,.12);border-color:rgba(47,94,45,.45)}
.map-placeholder{min-height:420px;border-radius:24px;border:1px dashed rgba(47,94,45,.35);display:grid;place-items:center;background:linear-gradient(135deg,rgba(47,94,45,.06),rgba(184,131,57,.12));text-align:center;padding:2rem}
.cta-band{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;border-radius:32px;padding:2rem;box-shadow:var(--shadow)}
.site-footer{background:#111a10;color:#dce4da;margin-top:4rem}
.site-footer h3{font-size:1rem;color:#fff;margin-bottom:1rem}
.footer-links li+li{margin-top:.65rem}.footer-links a,.footer-contact a{color:#dce4da}.footer-links a:hover,.footer-contact a:hover{color:#fff}
.footer-contact li{display:flex;gap:.85rem;align-items:flex-start}.footer-contact i{color:var(--gold);margin-top:.15rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);font-size:.95rem}
.footer-logo{width:82px;height:82px;background:#fff;border-radius:50%;padding:6px}
.whatsapp-float{position:fixed;right:22px;bottom:22px;width:66px;height:66px;border-radius:50%;display:grid;place-items:center;background:#25D366;color:#fff;font-size:1.8rem;z-index:99;box-shadow:0 16px 30px rgba(37,211,102,.35)}
.shockwave{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(37,211,102,.45);animation:shockwave 2.1s infinite}
.shockwave-delay{animation-delay:1s}
@keyframes shockwave{0%{transform:scale(1);opacity:.85}100%{transform:scale(1.9);opacity:0}}
.reveal-up{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.reveal-up.is-visible{opacity:1;transform:none}
.floaty{animation:floaty 5s ease-in-out infinite}@keyframes floaty{50%{transform:translateY(-10px)}}
@media (max-width:1199px){.mega-menu{transform:none;left:auto!important;width:100%;border-radius:20px}.hero-visual-grid{margin-top:2rem}}
@media (max-width:991px){.stat-grid{grid-template-columns:repeat(2,1fr)}.image-panel{min-height:360px}.gallery-grid{columns:2 220px}.hero{padding:5.5rem 0 4.8rem}}
@media (max-width:575px){.stat-grid{grid-template-columns:1fr}.gallery-grid{columns:1 100%}.hero-shot.tall{min-height:240px}.whatsapp-float{width:60px;height:60px;right:16px;bottom:16px}}

.hero-shot,.image-panel,.service-visual,.gallery-tile{background-color:#dfe6dd}
.video-tile{display:block;position:relative;background:#102112!important}
.video-tile video{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.play-badge{position:absolute;top:1rem;right:1rem;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.92);color:var(--green);font-size:1.5rem;z-index:2;box-shadow:var(--shadow)}
.gallery-tile:hover .play-badge{transform:scale(1.06)}
#galleryModalBody img,#galleryModalBody video{width:100%;max-height:78vh;object-fit:contain;border-radius:18px}
.modal-content{border-radius:24px;overflow:hidden}
.service-card p{color:var(--muted)}
.hero-card,.trust-wrap,.feature-card,.process-card,.faq-card,.contact-card,.stat-card,.testimonial-card,.service-card{backdrop-filter:blur(3px)}

.map-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* ratio 16:9 */
    overflow: hidden;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.map-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.gallery-preview-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.video-tile {
    position: relative;
    overflow: hidden;
}

.video-tile .play-badge {
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    font-size: 1.75rem;
}

.video-tile span {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    z-index: 3;
}

.video-tile::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.65), rgba(0,0,0,.15));
    z-index: 2;
}