:root {
  --bg: #f3f2ea;
  --bg-soft: #e9efe4;
  --text: #17301c;
  --muted: #57675d;
  --line: #d6dfd2;
  --card: rgba(255,255,255,.88);
  --shadow: 0 18px 40px rgba(18, 48, 28, .08);
  --radius: 22px;
  --call-blue: #0a84ff;
  --call-green: #34c759;
  --email-amber: #ea4335;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', sans-serif;
  background: linear-gradient(180deg, #fbfcf8 0%, var(--bg) 100%);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
.container { width: min(1180px, calc(100% - 2rem)); margin: 0 auto; }
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.narrow { width: min(760px, calc(100% - 2rem)); margin: 0 auto; }
.narrow-left { max-width: 760px; }
.section { padding: 4.5rem 0; }
.soft-bg { background: linear-gradient(180deg, rgba(60,141,77,.06), rgba(255,255,255,0)); }
.top-banner {
  background: var(--accent);
  color: #fff;
  font-weight: 600;
  padding: .8rem 0;
  text-align: center;
}
.top-banner .container { display: flex; justify-content: center; }
.site-header {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: blur(14px);
  background: rgba(251,252,248,.83);
  border-bottom: 1px solid rgba(219,230,219,.7);
}
.nav-wrap { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 86px; }
.brand-logo { width: min(390px, 56vw); max-height: 72px; object-fit: contain; }
.main-nav { display: flex; align-items: center; gap: 1rem; }
.main-nav a {
  padding: .85rem 1rem; border-radius: 999px; color: var(--muted); font-weight: 600;
}
.main-nav a.active, .main-nav a:hover { background: rgba(60,141,77,.1); color: var(--text); }
.nav-call { background: var(--accent); color: #fff !important; }
.menu-toggle {
  display: none; width: 52px; height: 52px; border-radius: 14px; border: 1px solid var(--line);
  background: #fff; align-items: center; justify-content: center; flex-direction: column; gap: 5px; cursor: pointer;
  appearance: none; -webkit-appearance: none;
}
.menu-toggle span { width: 22px; height: 2px; background: var(--text); display: block; transition: transform .2s ease, opacity .2s ease; }
.hero {
  position: relative; overflow: hidden;
  padding: 5rem 0 4rem;
}
.home-hero { min-height: 78vh; display: flex; align-items: center; }
.hero-backgrounds, .hero-overlay { position: absolute; inset: 0; }
.hero-backgrounds { z-index: 0; }
.hero-bg-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transform: scale(1.03); transition: opacity .7s ease, transform 4.8s ease; }
.hero-bg-slide.is-active { opacity: 1; transform: scale(1); }
.hero-overlay { z-index: 1; background: linear-gradient(90deg, rgba(16,28,18,.76) 0%, rgba(16,28,18,.58) 36%, rgba(16,28,18,.38) 62%, rgba(16,28,18,.18) 100%); }
.hero-grid { position: relative; z-index: 2; }
.home-hero .hero-copy-col h1, .home-hero .hero-copy, .home-hero .small-note { color: #fff; }
.home-hero .eyebrow { color: #d7ebd4; }
.home-hero .glass-card { background: rgba(248,245,238,.92); }
.hero-grid, .split-grid, .contact-panel, .footer-grid, .admin-header, .admin-grid, .contact-split {
  display: grid; gap: 1.5rem;
}
.hero-grid { grid-template-columns: 1.15fr .85fr; align-items: center; }
.hero-copy-col h1, .page-header h1 { font-size: clamp(2.3rem, 5vw, 4.8rem); line-height: .98; margin: .4rem 0 1rem; }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; color: var(--accent); font-size: .78rem; font-weight: 800; }
.hero-copy, .page-header p, .card p, .slide-content p { color: var(--muted); font-size: 1.08rem; line-height: 1.7; }
.hero-actions, .contact-actions, .footer-links, .admin-inline-actions { display: flex; gap: .9rem; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; padding: .95rem 1.35rem;
  border-radius: 999px; font-weight: 700; border: none; cursor: pointer; box-shadow: var(--shadow);
}
.btn-primary { background: var(--accent); color: #fff; }
.btn-secondary { background: #fff; color: var(--text); border: 1px solid var(--line); }
.btn-danger { background: #8f2d2d; color: #fff; }
.large-btn { min-width: 220px; }
.small-note { color: var(--muted); font-size: .98rem; margin-top: 1rem; }
.card, .glass-card, .price-card, .admin-card, .empty-card {
  background: var(--card); border: 1px solid rgba(255,255,255,.8); box-shadow: var(--shadow); border-radius: var(--radius);
  padding: 1.5rem;
}
.glass-card { backdrop-filter: blur(14px); }
.service-list, .bullet-list { margin: 1rem 0 0; padding-left: 1.2rem; color: var(--muted); line-height: 1.8; }
.split-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.page-header { padding: 4rem 0 2rem; }
.section-head h2, .card h2, .price-card h2, .slide-content h3 { margin: .35rem 0 .75rem; font-size: clamp(1.4rem, 3vw, 2.1rem); }
.dynamic-pricing-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.35rem; align-items: stretch; margin-bottom: 1.5rem; }
.price-card { border: 1px solid rgba(60,141,77,.12); background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(240,245,238,.96)); }
.price-card.featured { background: linear-gradient(180deg, rgba(60,141,77,.16), rgba(255,255,255,.94)); border-color: rgba(60,141,77,.24); transform: translateY(-2px); }
.price-line { font-size: 2rem; font-weight: 800; margin: .4rem 0; }
.minute-rate, .pricing-note-badge { color: var(--accent); font-weight: 700; }
.gallery-page-section { padding-top: 1rem; }
.full-width-gallery { width: min(1320px, calc(100% - 1rem)); }
.gallery-slider { display: grid; gap: 1rem; }
.slider-stage {
  position: relative; min-height: 68vh; display: flex; align-items: center; justify-content: center;
  border-radius: 28px; overflow: hidden; background: #101814; box-shadow: var(--shadow);
}
.slider-track { width: 100%; }
.slide { display: none; grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr); min-height: 68vh; }
.slide.is-active { display: grid; }
.slide-media { min-height: 68vh; background: #0f1612; display: flex; align-items: center; justify-content: center; }
.slide-image, .slide-video { width: 100%; height: 68vh; object-fit: cover; }
.slide-content {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,247,241,.95)); padding: 2rem; display: flex; flex-direction: column; justify-content: flex-end;
}
.slider-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; width: 54px; height: 54px; border-radius: 50%; border: none;
  background: rgba(255,255,255,.92); color: var(--text); font-size: 2rem; cursor: pointer;
}
.slider-arrow.prev { left: 1rem; }
.slider-arrow.next { right: 1rem; }
.slider-thumbs {
  display: flex; gap: .85rem; overflow-x: auto; padding-bottom: .4rem; scroll-snap-type: x proximity;
}
.thumb {
  min-width: 136px; max-width: 160px; border: 1px solid var(--line); background: #fff; border-radius: 18px; padding: .5rem; cursor: pointer; margin: 10px 0px 0px 4px;
  display: grid; gap: .5rem; color: var(--muted); box-shadow: 0 10px 24px rgba(14,34,20,.05); scroll-snap-align: center;
}
.thumb img { width: 100%; aspect-ratio: 1.25/1; object-fit: cover; border-radius: 12px; }
.thumb span { font-size: .86rem; font-weight: 700; }
.thumb.is-active { outline: 3px solid rgba(60,141,77,.32); transform: translateY(-2px); }
.compare-card { position: relative; width: 100%; height: 68vh; overflow: hidden; background: #111; cursor: ew-resize; touch-action: pan-y; }
.compare-before, .compare-after-base { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.compare-before-wrap { position: absolute; inset: 0; width: 100% !important; overflow: hidden; pointer-events: none; }
.compare-before { clip-path: inset(0 calc(100% - var(--compare-position, 50%)) 0 0); }
.compare-divider { position: absolute; top: 0; bottom: 0; left: 50%; width: 0; z-index: 3; }
.compare-divider::before { content: ""; position: absolute; top: 0; bottom: 0; left: -1px; width: 2px; background: rgba(255,255,255,.92); box-shadow: 0 0 0 1px rgba(17,17,17,.18); }
.compare-handle { position: absolute; top: 50%; left: 0; transform: translate(-50%, -50%); width: 54px; height: 54px; border-radius: 999px; background: rgba(255,255,255,.96); box-shadow: 0 12px 26px rgba(0,0,0,.2); }
.compare-handle::before, .compare-handle::after { content: ""; position: absolute; top: 50%; width: 10px; height: 10px; border-top: 2px solid #23422b; border-right: 2px solid #23422b; }
.compare-handle::before { left: 13px; transform: translateY(-50%) rotate(-135deg); }
.compare-handle::after { right: 13px; transform: translateY(-50%) rotate(45deg); }

.compare-card.is-demo-animating .compare-before-wrap,
.compare-card.is-demo-animating .compare-divider { transition: none; }
.compare-range {
  position: absolute; inset: auto 1.2rem 1.2rem 1.2rem; width: calc(100% - 2.4rem); z-index: 2; opacity: 0; pointer-events: none;
}
.compare-label {
  position: absolute; top: 1rem; z-index: 2; background: rgba(16,24,20,.72); color: #fff; padding: .45rem .7rem; border-radius: 999px; font-size: .86rem; font-weight: 700;
}
.compare-label.before { left: 1rem; }
.compare-label.after { right: 1rem; }
.contact-panel { grid-template-columns: 1fr auto; align-items: center; }
.contact-big a { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; }
.map-shell { display: grid; gap: .8rem; }
.service-map { height: 420px; border-radius: 28px; box-shadow: var(--shadow); overflow: hidden; background: #dfe8dd; }
.service-map .leaflet-control-zoom a { color: var(--text); }
.map-attribution { text-align: center; color: var(--muted); font-size: .92rem; }
.site-footer { padding: 2rem 0 2.6rem; border-top: 1px solid rgba(219,230,219,.85); }
.footer-grid { grid-template-columns: 1fr auto; align-items: center; }
.footer-links { margin-top: .65rem; }
.footer-powered a { font-weight: 700; color: var(--accent); }
.leaf-stage { position: absolute; inset: 0; pointer-events: none; }
.leaf {
  position: absolute; top: -30px; width: 16px; height: 16px; background: linear-gradient(180deg, #7ec96f, #4d9954);
  border-radius: 2px 80% 2px 80%; opacity: .65; animation: fall linear forwards;
}
@keyframes fall {
  from { transform: translateY(-40px) rotate(0deg); }
  to { transform: translateY(110vh) translateX(40px) rotate(280deg); }
}
.login-shell { text-align: center; }
.login-card { max-width: 500px; margin: 0 auto; text-align: left; }
.admin-grid { grid-template-columns: minmax(0, 1.45fr) 340px; align-items: start; }
.wide-admin-grid { width: min(1380px, calc(100% - 1rem)); }
.admin-main, .admin-side, .stack-gap { display: grid; gap: 1rem; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.form-grid label, .stack-gap label { display: grid; gap: .45rem; font-weight: 600; color: var(--text); }
.form-grid input, .form-grid textarea, .form-grid select, .stack-gap input, .stack-gap textarea, .stack-gap select {
  width: 100%; border: 1px solid var(--line); border-radius: 16px; padding: .9rem 1rem; background: #fff;
}
.form-grid textarea, .stack-gap textarea { resize: vertical; }
.full { grid-column: 1 / -1; }
.checkbox-row { display: flex !important; align-items: center; gap: .75rem; }
.checkbox-row input { width: auto !important; }
.admin-notice, .admin-error {
  padding: 1rem 1.1rem; border-radius: 16px; font-weight: 700;
}
.admin-notice { background: rgba(60,141,77,.12); color: #1f5d2a; }
.admin-error { background: rgba(143,45,45,.12); color: #8f2d2d; }
.admin-card-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.danger-card { padding-top: 0; }
.empty-card { text-align: center; }
@media (max-width: 980px) {
  .hero-grid, .split-grid, .contact-panel, .footer-grid, .slide, .admin-grid, .contact-split { grid-template-columns: 1fr; }
  .slide-media, .slide-image, .slide-video, .compare-card { min-height: 48vh; height: 48vh; }
  .menu-toggle { display: inline-flex; }
  .main-nav {
    position: absolute; top: calc(100% + .75rem); right: 1rem; left: 1rem; background: rgba(255,255,255,.98); border: 1px solid var(--line);
    border-radius: 22px; padding: 1rem; display: flex; flex-direction: column; align-items: stretch; gap: .25rem; box-shadow: var(--shadow);
    opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(-8px); transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 80;
  }
  .main-nav.is-open { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
  .brand-logo { width: min(290px, 62vw); }
}
@media (max-width: 720px) {
  .section { padding: 3.5rem 0; }
  .container { width: min(100% - 1rem, 1180px); }
  .hero { padding-top: 3.5rem; }
  .slider-arrow { width: 46px; height: 46px; }
  .thumb { min-width: 118px; }
  .form-grid { grid-template-columns: 1fr; }
}

.btn-text { background: var(--call-blue); color: #fff; box-shadow: 0 16px 32px rgba(10,132,255,.22); }
.btn-call { background: var(--call-green); color: #fff; box-shadow: 0 16px 32px rgba(52,199,89,.24); }
.btn-email { background: linear-gradient(180deg, #ea4335, #d93025); color: #fff; box-shadow: 0 16px 32px rgba(234,67,53,.22); }
.slide-kicker { text-transform: uppercase; letter-spacing: .16em; color: var(--accent); font-size: .78rem; font-weight: 800; margin: 0 0 .75rem; }
.slide-writeup { color: var(--muted); line-height: 1.8; font-size: 1rem; display: grid; gap: .8rem; }
.slide-actions { margin-top: 1.2rem; }
.gallery-detail-section { padding-top: 1rem; }
.gallery-detail-card { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr); gap: 1.5rem; align-items: start; }
.gallery-detail-media, .gallery-detail-image, .gallery-detail-video, .gallery-detail-compare { min-height: 72vh; height: 72vh; border-radius: 28px; overflow: hidden; background: #101814; box-shadow: var(--shadow); }
.gallery-detail-image, .gallery-detail-video { width: 100%; object-fit: cover; }
.gallery-detail-copy { align-self: stretch; }
.gallery-detail-writeup { color: var(--muted); line-height: 1.85; font-size: 1.02rem; white-space: normal; }
.gallery-detail-actions { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 1.2rem; }
.service-map { position: relative; z-index: 1; height: 420px; border-radius: 28px; box-shadow: var(--shadow); overflow: hidden; background: #dfe8dd; }
.site-header { isolation: isolate; }
.leaflet-pane, .leaflet-top, .leaflet-bottom { z-index: 1 !important; }
.service-map .leaflet-control-container { z-index: 2; }
.map-shell { position: relative; z-index: 1; }
@media (max-width: 980px) { .gallery-detail-card { grid-template-columns: 1fr; } .gallery-detail-media, .gallery-detail-image, .gallery-detail-video, .gallery-detail-compare { min-height: 52vh; height: 52vh; } }


.site-header { position: sticky; top: 0; z-index: 120; background: rgba(248,245,238,.94); backdrop-filter: blur(12px); }
.menu-toggle.is-open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.menu-toggle.is-open span:nth-child(2) { opacity: 0; }
.menu-toggle.is-open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
@media (min-width: 981px) {
  .main-nav { display: flex !important; opacity: 1 !important; visibility: visible !important; pointer-events: auto !important; transform: none !important; }
}


.pricing-grid { gap: 1.25rem; margin-bottom: 1.25rem; }
.price-card { padding: 1.5rem; }
.price-card:nth-child(2) { background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,248,245,.96)); }
.contact-actions .btn { min-width: 190px; justify-content: center; }
.admin-accordion summary { list-style: none; cursor: pointer; font-weight: 800; font-size: 1.05rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.admin-accordion summary::-webkit-details-marker { display: none; }
.admin-accordion summary::after { content: '+'; font-size: 1.4rem; color: var(--accent); }
.admin-accordion[open] summary::after { content: '−'; }
.admin-accordion-body { margin-top: 1rem; }
.icon-btn { width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; border: 1px solid var(--line); background: #fff; cursor: pointer; font-size: 1.2rem; }
.icon-save { color: var(--accent); }
.icon-delete { color: #b42318; }
.admin-inline-actions { display: flex; gap: .6rem; }
.our-work-link, .gallery-link { }


.contact-direct-row { display: flex; gap: 1.25rem 2rem; flex-wrap: wrap; margin-top: 1rem; align-items: center; }
.contact-direct-row p { margin: 0; }
.contact-direct-row a { font-size: clamp(1.12rem, 2.2vw, 1.35rem); font-weight: 700; color: var(--text); text-decoration: none; }
.contact-direct-row a:hover { color: var(--accent); }
.contact-bigger a { font-size: clamp(1.45rem, 3vw, 2rem); font-weight: 800; }
@media (max-width: 680px) { .contact-direct-row { flex-direction: column; align-items: flex-start; } }
