@font-face { font-family: "PoppinsLocal"; src: url("fonts/poppins-pxibyp8kv8jhgfvrlgt9z1xlfq.woff2") format("woff2"); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: "PoppinsLocal"; src: url("fonts/poppins-pxieyp8kv8jhgfvrjjnecmne.woff2") format("woff2"); font-weight: 600; font-style: normal; font-display: swap; }
@font-face { font-family: "PoppinsLocal"; src: url("fonts/poppins-pxigyp8kv8jhgfvrlptufntakpy.woff2") format("woff2"); font-weight: 700; font-style: normal; font-display: swap; }
:root { --bg: #f6f1e8; --surface: rgba(255, 252, 247, 0.94); --surface-strong: #fffaf2; --ink: #1f2b2c; --muted: #586468; --brand: #183a37; --brand-soft: #254b47; --accent: #d98d32; --accent-soft: #f6d9b4; --line: rgba(24, 58, 55, 0.14); --shadow: 0 24px 60px rgba(24, 58, 55, 0.12); --radius: 28px; --container: 1180px; }
* { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; font-family: "PoppinsLocal", "Segoe UI", sans-serif; color: var(--ink); line-height: 1.7; background: radial-gradient(circle at top left, rgba(217, 141, 50, 0.18), transparent 25%), radial-gradient(circle at 100% 10%, rgba(24, 58, 55, 0.13), transparent 22%), linear-gradient(180deg, #f7f3eb 0%, #fffdf8 40%, #f1ebe0 100%); }
img, iframe { max-width: 100%; display: block; } a { color: inherit; text-decoration: none; } p a { color: var(--brand-soft); text-decoration: underline; text-decoration-thickness: 1.5px; } .container { width: min(calc(100% - 2rem), var(--container)); margin: 0 auto; }
.topbar { background: linear-gradient(90deg, #112927, #254b47); color: #fef8ef; font-size: 0.95rem; } .topbar-inner, .navbar-inner, .cta-row, .topbar-actions, .topbar-stack { display: flex; gap: 1rem; align-items: center; justify-content: space-between; flex-wrap: wrap; } .topbar-inner { padding: 0.8rem 0; }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255, 251, 245, 0.9); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(24, 58, 55, 0.08); } .navbar-inner { padding: 1rem 0; }
.brand { display: flex; align-items: center; gap: 0.95rem; min-width: 0; } .brand img { width: 74px; height: 74px; object-fit: contain; } .brand-copy { display: grid; gap: 0.12rem; } .brand-copy strong { font-size: 1.15rem; color: var(--brand); line-height: 1.1; } .brand-copy span { color: var(--muted); font-size: 0.92rem; }
.menu-toggle { display: none; font: inherit; font-weight: 700; border-radius: 999px; border: 1px solid var(--line); background: var(--surface-strong); color: var(--brand); padding: 0.8rem 1rem; }
.nav-links { display: flex; flex-wrap: wrap; gap: 1.25rem; align-items: center; } .nav-links a { font-weight: 600; color: var(--brand); } .nav-links a[aria-current="page"] { color: var(--accent); }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 0.95rem 1.35rem; border-radius: 999px; font-weight: 700; border: 0; transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; } .btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, #f0a747, #d98d32); color: #1f2522; box-shadow: 0 14px 28px rgba(217, 141, 50, 0.26); } .btn-secondary { background: linear-gradient(135deg, #254b47, #183a37); color: #fff; box-shadow: 0 14px 28px rgba(24, 58, 55, 0.2); }
.hero, .page-hero { padding: 3.6rem 0 2.4rem; } .hero-layout, .split-layout, .info-grid, .service-grid-4, .zone-panel-grid, .map-layout, .metric-grid, .footer-layout { display: grid; gap: 1.5rem; } .hero-layout, .split-layout, .map-layout { grid-template-columns: 1.08fr 0.92fr; align-items: center; } .metric-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 1.5rem; }
.metric-card, .card-surface, .service-tile, .zone-panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); } .card-surface, .service-tile, .zone-panel, .metric-card { padding: 1.5rem; }
.hero-visual { padding: 1.15rem; position: relative; overflow: hidden; } .hero-visual img { border-radius: 18px; min-height: 420px; object-fit: cover; width: 100%; } .hero-badge { position: absolute; left: 1.8rem; right: 1.8rem; bottom: 1.8rem; padding: 1rem 1.2rem; background: rgba(17, 41, 39, 0.82); color: #fff; border-radius: 20px; }
.eyebrow { display: inline-flex; align-items: center; gap: 0.45rem; background: var(--accent-soft); color: var(--brand); border-radius: 999px; padding: 0.45rem 0.9rem; font-size: 0.9rem; font-weight: 700; margin-bottom: 1rem; } .eyebrow-dark, .eyebrow-light { background: rgba(255, 255, 255, 0.15); color: #fff; }
.split-head { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 1.5rem; align-items: end; margin-bottom: 1.5rem; }
h1, h2, h3 { margin: 0 0 0.9rem; line-height: 1.1; color: var(--brand); } h1 { font-size: clamp(2.45rem, 4.4vw, 4.8rem); } h2 { font-size: clamp(1.7rem, 3vw, 2.7rem); } h3 { font-size: 1.2rem; } .lead { font-size: 1.12rem; color: var(--muted); } .section { padding: 2.4rem 0; } .section-alt { background: linear-gradient(180deg, rgba(24, 58, 55, 0.035), rgba(24, 58, 55, 0.015)); } .section-dark { padding: 2.8rem 0; background: linear-gradient(135deg, #183a37, #254b47); color: #fff; } .section-dark h2, .section-dark p { color: #fff; }
.info-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .service-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); } .service-stack { display: grid; gap: 1rem; } .prose-block, .prose-wide, .map-copy, .map-embed { padding: 1.7rem; } .tag { display: inline-flex; width: fit-content; padding: 0.35rem 0.7rem; border-radius: 999px; background: rgba(24, 58, 55, 0.08); color: var(--brand); font-size: 0.82rem; font-weight: 700; margin-bottom: 0.9rem; }
.corridor { display: grid; gap: 1.25rem; grid-template-columns: 1.1fr 0.9fr; align-items: center; } .zone-chip-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.85rem; } .zone-chip-grid a { display: block; padding: 0.95rem 1rem; background: rgba(255, 255, 255, 0.12); border-radius: 20px; color: #fff; font-weight: 600; border: 1px solid rgba(255, 255, 255, 0.14); }
.breadcrumbs { padding-top: 1rem; color: var(--muted); font-size: 0.94rem; } .breadcrumbs .container { display: flex; gap: 0.5rem; align-items: center; } .cta-band { padding: 2rem; border-radius: var(--radius); background: linear-gradient(135deg, rgba(24, 58, 55, 0.98), rgba(34, 75, 71, 0.92)); color: #fff; box-shadow: var(--shadow); } .cta-band h2, .cta-band p, .cta-band a { color: #fff; }
.map-section { padding: 1rem 0 0; } .map-embed iframe { width: 100%; min-height: 360px; border: 0; border-radius: 18px; }
.site-footer { margin-top: 3rem; padding: 3rem 0 1.6rem; background: #102422; color: rgba(255, 252, 247, 0.82); } .site-footer h3, .site-footer strong, .site-footer a { color: #fff; } .footer-layout { grid-template-columns: 1.2fr 0.8fr 0.8fr; align-items: start; } .footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.55rem; } .footer-copy { margin-top: 1rem; } .legal-note { margin-top: 1.4rem; padding-top: 1rem; border-top: 1px solid rgba(255, 255, 255, 0.12); font-size: 0.92rem; }
.sticky-contact { position: fixed; bottom: 1rem; right: 1rem; z-index: 40; display: none; gap: 0.6rem; } .sticky-contact a { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0.85rem 1rem; border-radius: 999px; background: #183a37; color: #fff; box-shadow: var(--shadow); font-weight: 700; } .sticky-contact a:last-child { background: #d98d32; color: #1f2522; }
table { width: 100%; border-collapse: collapse; font-size: 0.95rem; } th, td { border: 1px solid var(--line); padding: 0.8rem; text-align: left; vertical-align: top; } th { background: rgba(24, 58, 55, 0.06); }
@media (max-width: 980px) { .menu-toggle { display: inline-flex; } .nav-links { display: none; position: absolute; top: calc(100% + 0.5rem); left: 1rem; right: 1rem; padding: 1rem; background: var(--surface-strong); border-radius: 24px; border: 1px solid var(--line); box-shadow: var(--shadow); flex-direction: column; align-items: flex-start; } .nav-links.is-open { display: flex; } .hero-layout, .split-layout, .map-layout, .split-head, .corridor, .footer-layout, .info-grid, .service-grid-4, .metric-grid, .zone-panel-grid { grid-template-columns: 1fr; } .sticky-contact { display: flex; } }
@media (max-width: 640px) { .container { width: min(calc(100% - 1.1rem), var(--container)); } .hero, .page-hero { padding-top: 2.8rem; } h1 { font-size: 2.35rem; } .brand img { width: 60px; height: 60px; } .hero-visual img { min-height: 300px; } }
