/* =============================================================
   Homepage-specific styles — Broward Dock and Seawall
   ============================================================= */

/* ---------- signature WebGL water hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;isolation:isolate;overflow:hidden}
.hero__poster,#hero-gl{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__poster{z-index:0;filter:saturate(.9)}
#hero-gl{z-index:1}
.hero__scrim{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(6,14,22,.55) 0%,rgba(6,14,22,.25) 40%,rgba(10,23,34,.85) 100%),
             radial-gradient(80% 60% at 70% 20%,rgba(200,164,92,.14),transparent 60%);
}
.hero__content{position:relative;z-index:3;width:100%;padding-top:var(--header-h)}
.hero .eyebrow{color:var(--brass-bright)}
.hero h1{margin:.9rem 0 1.2rem;max-width:16ch}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .char{display:inline-block;will-change:transform}
.hero__lead{font-size:clamp(1.05rem,1.7vw,1.35rem);color:var(--foam);max-width:54ch;text-shadow:0 1px 20px rgba(0,0,0,.5)}
.hero__cta{margin-top:2rem;display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
.hero__since{display:flex;align-items:center;gap:.7rem;margin-top:2.4rem;color:var(--foam-dim);font-size:.9rem}
.hero__since b{color:var(--brass);font-family:var(--display);font-size:1.6rem;font-weight:600}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:3;color:var(--foam-dim);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero__scroll span{width:1px;height:42px;background:linear-gradient(var(--brass),transparent);animation:scrolldrop 2s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media (prefers-reduced-motion:reduce){.hero__scroll span{animation:none}}
@media(max-width:600px){.hero{min-height:92svh}}

/* ---------- intro / value strip ---------- */
.intro p{font-size:clamp(1.15rem,2vw,1.5rem);color:var(--foam);font-family:var(--display);line-height:1.4;max-width:26ch}
.intro .body{font-family:var(--body);font-size:1.0625rem;color:var(--foam-dim);max-width:46ch}

/* ---------- services overview ---------- */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.6rem}
.svc-head .lead{margin-top:1rem}
.svc-card{display:flex;flex-direction:column;min-height:240px}
.svc-card p{flex:1}

/* ---------- why-us split ---------- */
.why{background:linear-gradient(180deg,var(--abyss),#06101a)}
.why .feature{display:grid;gap:1.4rem}
.feature-item{display:flex;gap:1.1rem;align-items:flex-start;padding-bottom:1.4rem;border-bottom:1px solid var(--line-soft)}
.feature-item:last-child{border-bottom:0}
.feature-item .n{font-family:var(--display);color:var(--brass);font-size:1.4rem;flex:none;width:2.4rem}
.feature-item h3{margin-bottom:.35rem}
.feature-item p{font-size:.98rem}

/* ---------- process steps ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
@media(max-width:880px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:1.8rem;background:var(--deep);border:1px solid var(--line-soft);border-radius:var(--r)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);font-size:2.6rem;color:rgba(200,164,92,.28);line-height:1;display:block;margin-bottom:.8rem}
.step h3{font-size:1.15rem;margin-bottom:.5rem}
.step p{font-size:.94rem}

/* ---------- service-area map block ---------- */
.area{background:#06101a}
.area-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.area-list a{background:var(--deep);border:1px solid var(--line-soft);color:var(--foam-dim);padding:.5rem 1rem;border-radius:100px;font-size:.9rem}
.area-list a:hover{border-color:var(--brass);color:var(--brass-bright)}

/* ---------- fleet/equipment callout ---------- */
.equip{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:380px;display:flex;align-items:flex-end;padding:2.2rem;background:var(--deep-2)}
.equip img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.4;z-index:0}
.equip::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,14,22,.92),transparent 70%);z-index:1}
.equip .equip-body{position:relative;z-index:2;max-width:34ch}