:root{--deep:#102A43;--deep-hover:#0B1E30;--blue:#1C7FA6;--coastal:#156984;--terra:#A87545;--amber:#A87545;--earth:#263238;--stone:#52626C;--drift:#74838D;--linen:#F7FBFC;--fog:#D8E1E8;--white:#FFFFFF;--ink:#081827;--rule:rgba(16,42,67,.14);--dark-rule:rgba(255,255,255,.12);--ease:cubic-bezier(.16,1,.3,1)}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:'Open Sans',Arial,sans-serif;background:var(--linen);color:var(--earth);overflow-x:hidden}a{text-decoration:none;color:inherit}img{display:block;max-width:100%;user-select:none}::selection{background:rgba(44,95,124,.18)}
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}.reveal.visible{opacity:1;transform:translateY(0)}.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;border-bottom:1px solid transparent;transition:background .6s var(--ease),border .6s var(--ease),backdrop-filter .6s var(--ease)}.site-nav.scrolled{background:rgba(245,240,232,.78);backdrop-filter:blur(34px) saturate(1.7);border-bottom-color:rgba(216,210,200,.7)}.nav-inner{max-width:1440px;margin:0 auto;padding:34px 56px;display:flex;align-items:center;justify-content:space-between;gap:28px;transition:padding .6s var(--ease)}.site-nav.scrolled .nav-inner{padding-top:18px;padding-bottom:18px}.brand,.footer-brand{font-family:'Montserrat',Arial,sans-serif;color:#fff;font-size:24px;font-weight:500;letter-spacing:.035em;display:inline-flex;gap:7px;align-items:baseline}.brand em,.footer-brand em{font-family:'Open Sans',Arial,sans-serif;font-size:12px;font-style:italic;font-weight:300;letter-spacing:0;color:rgba(255,255,255,.58)}.site-nav.scrolled .brand{color:var(--blue)}.site-nav.scrolled .brand em{color:var(--stone)}.nav-links{display:flex;align-items:center;gap:33px}.nav-links a{font-size:10.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.66);transition:color .3s}.nav-links a:hover,.nav-links a.active{color:#fff}.site-nav.scrolled .nav-links a{color:var(--stone)}.site-nav.scrolled .nav-links a:hover,.site-nav.scrolled .nav-links a.active{color:var(--blue)}.nav-cta{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.46);border-radius:999px;padding:12px 28px;transition:all .35s var(--ease)}.nav-cta:hover{background:#fff;color:var(--deep)}.site-nav.scrolled .nav-cta{color:var(--blue);border-color:var(--blue)}.site-nav.scrolled .nav-cta:hover{background:var(--blue);color:#fff}.menu-btn{display:none;background:none;border:0;flex-direction:column;gap:7px;padding:8px;cursor:pointer}.menu-btn span{display:block;width:25px;height:1px;background:#fff;transition:all .35s var(--ease)}.site-nav.scrolled .menu-btn span{background:var(--blue)}.mobile-menu{display:none;background:rgba(245,240,232,.98);padding:20px 32px 32px;flex-direction:column;gap:20px;border-bottom:1px solid var(--rule)}.mobile-menu a{font-family:'Montserrat',Arial,sans-serif;font-size:28px;color:var(--blue)}.mobile-menu .mobile-cta{font-family:'Open Sans',Arial,sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--terra)}
.hero,.subhero{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden;background:var(--deep)}.subhero{min-height:72vh}.subhero.compact{min-height:56vh}.hero-img,.subhero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}.hero-scrim,.subhero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,58,75,.62),rgba(27,58,75,.34) 38%,rgba(27,58,75,.88))}.hero-content,.subhero-content{position:relative;z-index:2;max-width:1440px;width:100%;margin:0 auto;padding:0 56px 122px}.subhero-content{padding-bottom:88px;max-width:900px;margin-left:calc((100vw - min(1440px, 100vw))/2)}.hero h1,.subhero h1{font-family:'Montserrat',Arial,sans-serif;font-size:clamp(54px,8vw,112px);font-weight:300;line-height:.96;letter-spacing:-.035em;color:#fff;max-width:820px}.subhero h1{font-size:clamp(44px,6vw,78px);line-height:1.02}.hero-italic{font-family:'Montserrat',Arial,sans-serif;font-size:clamp(26px,3.2vw,42px);font-style:italic;font-weight:300;color:var(--amber);margin-top:8px}.hero-copy,.subhero p:not(.overline){font-size:16px;line-height:1.85;font-weight:300;color:rgba(245,240,232,.86);max-width:560px;margin-top:34px}.hero-actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:48px}.hero-marker{position:absolute;left:50%;bottom:38px;z-index:3;transform:translateX(-50%);display:flex;gap:44px}.hero-marker span{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,240,232,.55)}
.overline{display:block;font-size:10.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--terra);margin-bottom:28px}.overline.light{color:var(--amber)}.section{padding:150px 56px}.section.linen{background:var(--linen)}.section.white{background:#fff}.section.fog{background:var(--fog)}.section.dark{background:var(--deep);color:#fff}.wrap{max-width:1440px;margin:0 auto}.narrow{max-width:720px}.center{text-align:center}.section h2,.final-cta h2{font-family:'Montserrat',Arial,sans-serif;font-size:clamp(38px,5vw,68px);font-weight:400;line-height:1.04;letter-spacing:-.025em;color:var(--blue)}.section.dark h2,.final-cta h2{color:#fff}.lead{font-size:16px;line-height:1.85;font-weight:300;color:var(--stone);margin-top:24px}.lead.italic{font-family:'Montserrat',Arial,sans-serif;font-size:25px;font-style:italic;color:var(--terra)}.light-copy{color:rgba(245,240,232,.74)}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:16px 36px;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;border:1px solid transparent;transition:all .35s var(--ease);cursor:pointer}.btn.primary{background:#fff;color:var(--deep)}.btn.primary:hover{background:var(--amber);color:#fff}.btn.ghost{border-color:rgba(255,255,255,.42);color:#fff}.btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}.btn.dark{background:var(--blue);color:#fff}.btn.dark:hover{background:var(--deep)}.text-link{display:inline-flex;margin-top:32px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}
.editorial-grid{display:grid;gap:42px;margin-top:86px}.editorial-grid.three{grid-template-columns:repeat(3,1fr)}.editorial-grid.two{grid-template-columns:repeat(2,1fr)}.pillar,.image-card,.persona,.hub-card,.price-card{background:#fff;border-radius:28px;overflow:hidden;box-shadow:0 18px 50px rgba(27,58,75,.07)}.pillar img{width:100%;height:310px;object-fit:cover}.pillar h3,.image-card h3,.persona h3,.hub-card h3,.price-card h3{font-family:'Montserrat',Arial,sans-serif;font-size:31px;font-weight:400;line-height:1.12;color:var(--blue)}.pillar h3,.pillar p{padding-left:34px;padding-right:34px}.pillar h3{padding-top:34px}.pillar p,.image-card p,.persona p,.hub-card p{font-size:15px;line-height:1.82;font-weight:300;color:var(--stone);padding-bottom:38px;margin-top:16px}.image-card img{height:380px;width:100%;object-fit:cover}.image-card div{padding:34px}.image-card p{padding:0}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:92px;align-items:start}.body-stack{display:flex;flex-direction:column;gap:24px}.body-stack p{font-size:17px;line-height:1.9;font-weight:300;color:var(--stone)}
.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:92px;align-items:start}.service-list{margin-top:56px;border-top:1px solid rgba(245,240,232,.14)}.service-row{display:grid;grid-template-columns:56px 1fr;gap:24px;padding:28px 0;border-bottom:1px solid rgba(245,240,232,.12);cursor:pointer;transition:padding .35s var(--ease)}.service-row:hover,.service-row.active{padding-left:10px}.service-num{font-size:11px;font-weight:600;letter-spacing:.18em;color:rgba(245,240,232,.38);padding-top:9px}.service-row.active .service-num{color:var(--amber)}.service-row h3{font-family:'Montserrat',Arial,sans-serif;font-size:30px;font-weight:400;color:rgba(245,240,232,.46);transition:color .35s}.service-row.active h3{color:#fff}.service-row p{max-height:0;opacity:0;overflow:hidden;font-size:15px;line-height:1.78;color:rgba(245,240,232,.72);transition:all .45s var(--ease)}.service-row.active p{max-height:120px;opacity:1;margin-top:12px}.service-row a{display:inline-flex;max-height:0;opacity:0;overflow:hidden;margin-top:0;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);transition:all .45s var(--ease)}.service-row.active a{max-height:30px;opacity:1;margin-top:18px}.service-image-stage{height:580px;border-radius:30px;overflow:hidden;position:sticky;top:max(100px,calc(50vh - 290px));background:var(--ink);box-shadow:0 22px 70px rgba(0,0,0,.28)}.service-image-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.04);transition:opacity .9s ease,transform 1.4s var(--ease)}.service-image-stage img.active{opacity:1;transform:scale(1)}.service-image-stage:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(27,58,75,.82))}.image-label{position:absolute;left:30px;bottom:28px;z-index:2;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.quote-band{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}.quote-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.quote-band-scrim{position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,58,75,.88),rgba(27,58,75,.64))}.quote-band blockquote{position:relative;z-index:2;max-width:780px;font-family:'Montserrat',Arial,sans-serif;font-size:clamp(34px,5vw,66px);font-style:italic;font-weight:300;line-height:1.15;color:#fff;padding:0 32px}.persona-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:76px}.persona{padding:34px}.persona span{font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--terra)}.persona h3{margin-top:22px}.persona p{padding:0}.timeline{display:flex;flex-direction:column;border-top:1px solid rgba(27,58,75,.17)}.section.dark .timeline{border-color:rgba(245,240,232,.14)}.timeline article{display:grid;grid-template-columns:48px 1fr;gap:24px;padding:25px 0;border-bottom:1px solid rgba(27,58,75,.14)}.section.dark .timeline article{border-color:rgba(245,240,232,.12)}.timeline span{font-family:'Montserrat',Arial,sans-serif;font-size:30px;color:var(--terra)}.section.dark .timeline span{color:var(--amber)}.timeline p{font-size:15px;line-height:1.75;color:var(--stone)}.section.dark .timeline p{color:rgba(245,240,232,.76)}.gallery-grid{display:grid;grid-template-columns:1fr .75fr .75fr;gap:26px;align-items:end}.gallery-grid img{height:460px;width:100%;object-fit:cover;border-radius:28px}.gallery-copy{padding-right:30px}.final-cta{position:relative;background:var(--deep);padding:120px 56px;color:#fff;overflow:hidden}.final-cta.slim{padding:86px 56px}.final-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(212,168,83,.22),transparent 34%),linear-gradient(120deg,rgba(74,124,143,.22),transparent)}.final-cta .wrap{position:relative;z-index:2}.final-cta p{font-size:16px;line-height:1.8;color:rgba(245,240,232,.74);margin:24px auto 34px;max-width:620px}
.stat-grid,.outcome-grid,.process-grid,.pricing-grid,.legal-grid{display:grid;gap:20px}.stat-grid{grid-template-columns:repeat(2,1fr)}.stat-grid article{border:1px solid rgba(245,240,232,.12);border-radius:24px;padding:30px}.stat-grid strong{display:block;font-family:'Montserrat',Arial,sans-serif;font-size:44px;color:var(--amber);font-weight:300}.stat-grid span{display:block;margin-top:16px;font-size:13px;line-height:1.6;color:rgba(245,240,232,.74)}.hub-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:76px}.hub-card img{height:190px;width:100%;object-fit:cover}.hub-card div{padding:24px}.hub-card span{font-size:10px;font-weight:800;letter-spacing:.18em;color:var(--terra)}.hub-card h3{font-size:28px;margin-top:16px}.hub-card p{padding:0}.hub-card a{display:inline-flex;margin-top:22px;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--terra)}.outcome-grid{grid-template-columns:repeat(3,1fr);margin-top:70px}.outcome-grid article{background:var(--linen);border-radius:26px;padding:34px}.outcome-grid span{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}.outcome-grid h3{font-family:'Montserrat',Arial,sans-serif;font-size:31px;font-weight:400;line-height:1.12;color:var(--blue);margin-top:20px}.outcome-grid p{font-size:15px;line-height:1.8;color:var(--stone);margin-top:16px}.cost-stack{border-top:1px solid rgba(245,240,232,.14)}.cost-stack article{display:grid;grid-template-columns:56px 1fr;gap:26px;padding:28px 0;border-bottom:1px solid rgba(245,240,232,.12)}.cost-stack strong{font-family:'Montserrat',Arial,sans-serif;font-size:34px;font-weight:300;color:var(--amber)}.cost-stack p{font-size:16px;line-height:1.82;color:rgba(245,240,232,.78)}.story-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:78px;align-items:center}.story-split img{height:540px;width:100%;object-fit:cover;border-radius:30px}.story-split blockquote{font-family:'Montserrat',Arial,sans-serif;font-size:30px;font-style:italic;line-height:1.48;color:var(--terra);margin-top:34px;border-left:3px solid var(--amber);padding-left:28px}.feature-list{border-top:1px solid var(--rule);margin-top:70px}.feature-list article{display:grid;grid-template-columns:130px 1fr 1.1fr;gap:34px;padding:30px 0;border-bottom:1px solid var(--rule)}.feature-list span{font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}.feature-list h3{font-family:'Montserrat',Arial,sans-serif;font-size:30px;font-weight:400;color:var(--blue)}.feature-list p{font-size:15px;line-height:1.82;color:var(--stone)}.process-grid{grid-template-columns:repeat(5,1fr);margin-top:70px}.process-grid article{border:1px solid rgba(245,240,232,.12);border-radius:24px;padding:28px}.process-grid span{font-size:10px;font-weight:800;letter-spacing:.18em;color:var(--amber)}.process-grid h3{font-family:'Montserrat',Arial,sans-serif;font-size:28px;font-weight:400;color:#fff;margin-top:20px}.process-grid p{font-size:14px;line-height:1.75;color:rgba(245,240,232,.72);margin-top:12px}.pricing-grid{grid-template-columns:repeat(4,1fr);margin-top:70px}.price-card{padding:32px;border:1px solid rgba(27,58,75,.08)}.price-card.featured{background:var(--deep);color:#fff}.price-card p{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}.price-card.featured p,.price-card.featured h3{color:#fff}.price-card h3{margin-top:18px}.price-card span{display:block;margin:12px 0 22px;font-size:13px;color:var(--stone)}.price-card.featured span{color:rgba(245,240,232,.68)}.price-card ul{padding-left:18px;color:var(--stone);font-size:14px;line-height:1.9}.price-card.featured ul{color:rgba(245,240,232,.82)}.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:80px}.guarantee{margin-top:34px;padding:28px;border-left:3px solid var(--amber);background:var(--linen)}.guarantee h3{font-family:'Montserrat',Arial,sans-serif;font-size:30px;font-weight:400;color:var(--blue)}.guarantee p{font-size:15px;line-height:1.8;color:var(--stone);margin-top:10px}.faq-list{border-top:1px solid var(--rule)}details{border-bottom:1px solid var(--rule);padding:24px 0}summary{cursor:pointer;list-style:none;font-family:'Montserrat',Arial,sans-serif;font-size:28px;color:var(--blue)}summary::-webkit-details-marker{display:none}details p{font-size:15px;line-height:1.82;color:var(--stone);padding-top:14px}.form-split,.contact-grid{display:grid;grid-template-columns:.88fr 1.12fr;gap:80px;align-items:start}.quote-form{background:#fff;border-radius:28px;padding:34px;box-shadow:0 20px 60px rgba(27,58,75,.08)}.quote-form label{display:block;font-size:10.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:16px}.field.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}.quote-form input,.quote-form select,.quote-form textarea{display:block;width:100%;margin-top:9px;border:1px solid rgba(27,58,75,.17);border-radius:16px;padding:14px 15px;font:inherit;font-size:14px;color:var(--earth);background:#fff;outline:none}.quote-form textarea{min-height:130px;resize:vertical}.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{border-color:var(--coastal);box-shadow:0 0 0 4px rgba(74,124,143,.12)}.submit{width:100%;margin-top:10px;border:0}.form-success{display:none;margin-top:18px;border-radius:16px;padding:16px;background:rgba(74,124,143,.1);color:var(--blue);font-size:14px;line-height:1.7}.form-success.show{display:block}.ghl-note{margin-top:34px;background:#fff;border-radius:24px;padding:26px}.ghl-note h3{font-family:'Montserrat',Arial,sans-serif;font-size:28px;color:var(--blue);font-weight:400}.ghl-note p{font-size:14px;line-height:1.8;color:var(--stone);margin-top:10px}.contact-methods{display:flex;flex-direction:column;margin-top:38px;border-top:1px solid var(--rule)}.contact-methods a{display:grid;grid-template-columns:90px 1fr;gap:26px;padding:25px 0;border-bottom:1px solid var(--rule);font-size:18px;color:var(--blue);transition:padding .3s}.contact-methods a:hover{padding-left:10px}.contact-methods span{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);padding-top:6px}.policy-list{display:grid;gap:14px}.policy-list p{padding:20px;border:1px solid rgba(245,240,232,.12);border-radius:18px;color:rgba(245,240,232,.76);line-height:1.65}.legal-stack{max-width:840px}.legal-grid{grid-template-columns:repeat(2,1fr)}.legal-grid article{background:var(--linen);border-radius:24px;padding:32px}.legal-grid h3{font-family:'Montserrat',Arial,sans-serif;font-size:31px;font-weight:400;color:var(--blue)}.legal-grid p{font-size:15px;line-height:1.82;color:var(--stone);margin-top:14px}
.footer{background:var(--deep);padding:52px 56px;color:#fff}.footer-inner{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}.footer-brand{font-size:20px}.footer p,.footer small{font-size:12px;line-height:1.7;color:rgba(245,240,232,.46);margin-top:10px}.footer nav{display:flex;justify-content:flex-end;gap:20px;flex-wrap:wrap}.footer nav a{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,240,232,.55)}.footer small{grid-column:1/-1;text-align:center;border-top:1px solid rgba(245,240,232,.1);padding-top:24px}
@media(max-width:1120px){.nav-links,.nav-cta{display:none}.menu-btn{display:flex}.site-nav.open .mobile-menu{display:flex}.site-nav.open .menu-btn span:first-child{transform:rotate(45deg) translate(3px,3px)}.site-nav.open .menu-btn span:last-child{transform:rotate(-45deg) translate(3px,-3px)}.hero-content,.subhero-content,.nav-inner{padding-left:32px;padding-right:32px}.section,.final-cta,.footer{padding-left:32px;padding-right:32px}.editorial-grid.three,.editorial-grid.two,.service-grid,.split,.story-split,.faq-grid,.form-split,.contact-grid,.gallery-grid{grid-template-columns:1fr}.service-image-stage{position:relative;top:auto;height:430px}.persona-grid,.hub-grid,.outcome-grid,.process-grid,.pricing-grid,.legal-grid{grid-template-columns:repeat(2,1fr)}.feature-list article{grid-template-columns:1fr;gap:12px}.footer-inner{grid-template-columns:1fr}.footer nav{justify-content:flex-start}.subhero-content{margin-left:0}}
@media(max-width:700px){.hero h1{font-size:clamp(48px,15vw,74px)}.hero,.subhero{min-height:86vh}.subhero.compact{min-height:62vh}.hero-content,.subhero-content{padding-bottom:82px}.hero-marker{display:none}.hero-actions{align-items:stretch;flex-direction:column}.btn{width:100%}.section{padding-top:86px;padding-bottom:86px}.editorial-grid,.persona-grid,.hub-grid,.outcome-grid,.process-grid,.pricing-grid,.legal-grid,.stat-grid{grid-template-columns:1fr}.pillar img,.image-card img,.story-split img,.gallery-grid img{height:280px}.field.two{grid-template-columns:1fr}.contact-methods a{grid-template-columns:1fr;gap:8px}.service-row{grid-template-columns:42px 1fr}.service-row h3{font-size:25px}.quote-band{min-height:420px}.subhero h1,.section h2,.final-cta h2{font-size:clamp(36px,11vw,54px)}}

/* Dockline enterprise alignment: original marine tokens + crisp premium UI */
.hero h1,.subhero h1,.section h2,.final-cta h2,.pillar h3,.image-card h3,.persona h3,.hub-card h3,.price-card h3,.service-row h3,.outcome-grid h3,.feature-list h3,.process-grid h3,.guarantee h3,.legal-grid h3,.ghl-note h3,summary{
  font-weight:700;
  letter-spacing:-.045em;
}
.brand,.footer-brand{font-weight:700;text-transform:uppercase;letter-spacing:.055em}.brand em,.footer-brand em{font-family:'Open Sans',Arial,sans-serif;font-style:normal;font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.hero-italic{font-family:'Open Sans',Arial,sans-serif;font-size:clamp(15px,1.7vw,20px);font-style:normal;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--terra)}
.hero-scrim,.subhero-scrim{background:linear-gradient(180deg,rgba(8,24,39,.54),rgba(16,42,67,.35) 38%,rgba(8,24,39,.92))}
.hero-img,.subhero img,.pillar img,.image-card img,.service-image-stage img,.quote-band img,.gallery-grid img,.story-split img,.hub-card img{filter:saturate(.94) contrast(1.06)}
.pillar,.image-card,.persona,.hub-card,.price-card,.quote-form,.ghl-note,.guarantee{box-shadow:0 18px 48px rgba(16,42,67,.09)}
.btn.primary{background:#fff;color:var(--deep)}.btn.primary:hover{background:var(--terra);color:#fff}.btn.dark{background:var(--blue);color:#fff}.btn.dark:hover{background:var(--coastal)}
.nav-cta:hover{background:#fff;color:var(--deep)}.site-nav.scrolled .nav-cta:hover{background:var(--deep);color:#fff}
.overline{color:var(--terra)}.overline.light{color:#D4B184}.service-row.active .service-num,.process-grid span,.section.dark .timeline span{color:#D4B184}
.section.dark,.final-cta{background:var(--deep)}.footer{background:var(--ink)}.service-image-stage{background:var(--ink)}
.service-row.active h3{color:#fff}.service-row h3{color:rgba(255,255,255,.52)}.service-row p{color:rgba(255,255,255,.76)}.service-row a{color:#D4B184}
.quote-band blockquote{font-family:'Montserrat',Arial,sans-serif;font-style:normal;font-weight:700;letter-spacing:-.045em}


/* dockline-desktop-type-scale-fix: make desktop hierarchy feel premium and enterprise-scale */
@media (min-width: 1180px) {
  .hero h1 {
    font-size: clamp(78px, 8.8vw, 138px);
    max-width: 980px;
  }
  .subhero h1 {
    font-size: clamp(58px, 6.3vw, 96px);
    max-width: 980px;
  }
  .section h2,
  .final-cta h2 {
    font-size: clamp(50px, 5.2vw, 82px);
    max-width: 960px;
  }
  .center h2 {
    margin-left: auto;
    margin-right: auto;
  }
  .outcome-grid h3,
  .persona h3,
  .hub-card h3,
  .price-card h3 {
    font-size: clamp(38px, 2.9vw, 56px);
    line-height: 1.02;
  }
  .pillar h3,
  .image-card h3,
  .feature-list h3,
  .service-row h3,
  .process-grid h3,
  .legal-grid h3,
  .guarantee h3,
  .ghl-note h3,
  summary {
    font-size: clamp(34px, 2.35vw, 46px);
    line-height: 1.06;
  }
  .outcome-grid article,
  .persona,
  .price-card,
  .process-grid article {
    padding: 44px;
  }
  .outcome-grid p,
  .persona p,
  .price-card li,
  .feature-list p,
  .lead,
  .hero-copy,
  .body-stack p {
    font-size: 18px;
    line-height: 1.82;
  }
  .overline,
  .nav-links a,
  .nav-cta,
  .btn {
    font-size: 12px;
  }
}

/* ============================================
   DOCKLINE 9.95 UPGRADE — NEW COMPONENT STYLES
   ============================================ */

/* --- Hero phone number in hero actions --- */
.hero-phone {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  color: rgba(255,255,255,.72);
  font-family: 'Open Sans', Arial, sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1.3;
  margin-left: 16px;
  padding-left: 20px;
  border-left: 1px solid rgba(255,255,255,.18);
  transition: color .3s;
}
.hero-phone:hover { color: #fff; }
.hero-phone-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 3px;
}
@media(max-width:700px){
  .hero-phone { display:none; }
}

/* --- Nav trust micro-text --- */
.nav-trust {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.36);
  white-space: nowrap;
  display: none;
}
@media(min-width:1280px){ .nav-trust { display:block; } }
.site-nav.scrolled .nav-trust { color: var(--stone); }

/* --- Credibility strip --- */
.cred-strip {
  background: var(--ink);
  padding: 16px 56px;
  position: relative;
  z-index: 1;
}
.cred-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 44px;
  flex-wrap: wrap;
}
.cred-inner span {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(245,240,232,.52);
  white-space: nowrap;
}
@media(max-width:700px){
  .cred-strip { padding: 14px 24px; }
  .cred-inner { gap: 18px; }
  .cred-inner span { font-size: 9px; }
}

/* --- Before / After gallery --- */
.gallery-header { margin-bottom: 0; }
.ba-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  margin-top: 72px;
}
.ba-pair { display: flex; flex-direction: column; gap: 0; }
.ba-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  border-radius: 24px;
  overflow: hidden;
}
.ba-images figure { position: relative; margin: 0; }
.ba-images img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
  filter: saturate(.94) contrast(1.06);
}
.ba-images figcaption {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 8px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(8,24,39,.78);
  backdrop-filter: blur(6px);
  padding: 4px 10px;
  border-radius: 999px;
}
.ba-meta {
  margin-top: 18px;
  padding: 0 4px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.ba-service {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--terra);
}
.ba-boat {
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -.03em;
  line-height: 1.1;
}
.ba-note {
  font-size: 14px;
  color: var(--stone);
  line-height: 1.65;
}
/* First-mover state (no photos yet) */
.ba-firstmover {
  background: var(--linen);
  border-radius: 24px;
  padding: 56px 48px;
  text-align: center;
  border: 2px dashed rgba(28,127,166,.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.ba-firstmover-icon {
  font-size: 36px;
  opacity: .4;
}
.ba-firstmover h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(24px, 2.2vw, 36px);
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -.04em;
  line-height: 1.1;
}
.ba-firstmover p {
  font-size: 15px;
  line-height: 1.8;
  color: var(--stone);
  max-width: 480px;
}
@media(max-width:1120px){ .ba-grid { grid-template-columns: 1fr; } }
@media(max-width:700px){ .ba-images img { height: 200px; } }

/* --- Styled photo upload drop zone --- */
.upload-zone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 40px 24px;
  border: 2px dashed rgba(28,127,166,.28);
  border-radius: 20px;
  background: rgba(28,127,166,.04);
  cursor: pointer;
  transition: all .3s ease;
  text-align: center;
  width: 100%;
  margin-top: 9px;
}
.upload-zone:hover {
  border-color: var(--blue);
  background: rgba(28,127,166,.08);
}
.upload-icon { color: var(--blue); opacity: .6; }
.upload-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--blue);
}
.upload-sub {
  font-size: 12px;
  line-height: 1.7;
  color: var(--stone);
}

/* --- Service guarantee block --- */
.service-guarantee {
  margin-top: 48px;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 24px;
  padding: 32px;
  background: var(--deep);
  border-radius: 24px;
  border-left: 4px solid var(--amber);
  align-items: start;
}
.sg-icon {
  font-size: 28px;
  color: var(--amber);
  padding-top: 4px;
}
.sg-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(22px, 2vw, 30px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1.1;
}
.sg-copy {
  font-size: 15px;
  line-height: 1.82;
  color: rgba(245,240,232,.78);
  margin-top: 10px;
}

/* --- Owner visual with badge (About page) --- */
.owner-visual { position: relative; }
.owner-photo {
  width: 100%;
  height: 540px;
  object-fit: cover;
  object-position: center top;
  border-radius: 30px;
  filter: saturate(.94) contrast(1.06);
  display: block;
}
.owner-badge {
  position: absolute;
  bottom: 28px;
  left: 28px;
  background: rgba(8,24,39,.88);
  backdrop-filter: blur(16px);
  border-radius: 16px;
  padding: 16px 22px;
  border: 1px solid rgba(168,117,69,.28);
}
.owner-name {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.03em;
}
.owner-title {
  display: block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--amber);
  margin-top: 6px;
}
@media(max-width:700px){
  .owner-photo { height: 320px; }
}

/* --- First-mover trust section (no reviews yet) --- */
.firstmover-section { background: var(--linen); }
.firstmover-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.firstmover-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(168,117,69,.12);
  border: 1px solid rgba(168,117,69,.3);
  border-radius: 999px;
  padding: 7px 16px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--terra);
  margin-bottom: 28px;
}
.firstmover-right {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.firstmover-point {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 18px;
  align-items: start;
  padding: 20px;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 8px 28px rgba(16,42,67,.06);
}
.firstmover-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 300;
  color: var(--amber);
  line-height: 1;
}
.firstmover-point h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -.03em;
  line-height: 1.2;
}
.firstmover-point p {
  font-size: 14px;
  line-height: 1.75;
  color: var(--stone);
  margin-top: 5px;
}
@media(max-width:1120px){ .firstmover-inner { grid-template-columns: 1fr; gap: 48px; } }

/* --- Submit trust micro-copy --- */
.submit-trust {
  margin-top: 16px;
  font-size: 12px;
  line-height: 1.8;
  color: var(--stone);
  text-align: center;
}

/* --- Form submit button rename handled in HTML --- */

/* --- Footer v2 --- */
.footer-inner-v2 {
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.footer-cred {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  flex-wrap: wrap;
}
.footer-cred span {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--amber);
  border: 1px solid rgba(168,117,69,.32);
  border-radius: 999px;
  padding: 5px 12px;
}
.footer-nav-heading {
  display: block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(245,240,232,.32);
  margin-bottom: 18px;
}
.footer-nav-col,
.footer-contact-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer-nav-col a,
.footer-contact-col a {
  font-size: 14px;
  color: rgba(245,240,232,.58);
  transition: color .3s;
}
.footer-nav-col a:hover,
.footer-contact-col a:hover { color: #fff; }
.footer-quote-link {
  color: var(--amber) !important;
  font-weight: 700;
  margin-top: 6px;
}
.footer-base {
  max-width: 1440px;
  margin: 48px auto 0;
  padding-top: 24px;
  border-top: 1px solid rgba(245,240,232,.1);
  text-align: center;
}
.footer-base small,
.footer-base a {
  font-size: 11px;
  color: rgba(245,240,232,.32);
  letter-spacing: .06em;
}
@media(max-width:1120px){
  .footer-inner-v2 { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media(max-width:700px){
  .footer-inner-v2 { grid-template-columns: 1fr; }
}

/* --- Service area module (Contact page) --- */
.area-list { display: flex; flex-direction: column; gap: 28px; }
.area-zone {
  background: #fff;
  border-radius: 20px;
  padding: 26px 28px;
  box-shadow: 0 8px 28px rgba(16,42,67,.06);
}
.zone-label {
  display: block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--terra);
  margin-bottom: 14px;
}
.area-zone ul {
  padding-left: 16px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.area-zone ul li {
  font-size: 15px;
  line-height: 1.6;
  color: var(--earth);
}
.area-note {
  font-size: 14px;
  line-height: 1.8;
  color: var(--stone);
  font-style: italic;
  padding: 20px 24px;
  border-left: 3px solid var(--amber);
  background: var(--linen);
  border-radius: 0 16px 16px 0;
}

/* --- Nav dropdown --- */
.nav-dropdown-wrap { position: relative; display: flex; align-items: center; }
.nav-dropdown-trigger {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.66);
  transition: color .3s;
  display: flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
}
.nav-dropdown-trigger:hover,
.nav-dropdown-trigger.active { color: #fff; }
.site-nav.scrolled .nav-dropdown-trigger { color: var(--stone); }
.site-nav.scrolled .nav-dropdown-trigger:hover,
.site-nav.scrolled .nav-dropdown-trigger.active { color: var(--blue); }
.nav-dropdown-arrow {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform .3s;
}
.nav-dropdown-wrap.open .nav-dropdown-arrow { transform: rotate(-135deg) translateY(-2px); }
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 18px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 240px;
  background: rgba(8,24,39,.97);
  backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  padding: 10px;
  box-shadow: 0 28px 60px rgba(0,0,0,.36);
  z-index: 200;
}
.site-nav.scrolled .nav-dropdown-menu {
  background: rgba(245,240,232,.98);
  border-color: rgba(27,58,75,.14);
  box-shadow: 0 20px 50px rgba(16,42,67,.14);
}
.nav-dropdown-wrap.open .nav-dropdown-menu { display: block; }
.nav-dropdown-menu a {
  display: block;
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(245,240,232,.72);
  border-radius: 10px;
  transition: background .2s, color .2s;
}
.nav-dropdown-menu a:hover { background: rgba(255,255,255,.08); color: #fff; }
.site-nav.scrolled .nav-dropdown-menu a { color: var(--stone); }
.site-nav.scrolled .nav-dropdown-menu a:hover { background: rgba(16,42,67,.07); color: var(--blue); }
.dropdown-all-link {
  color: var(--amber) !important;
  border-bottom: 1px solid rgba(255,255,255,.1);
  margin-bottom: 6px;
  padding-bottom: 14px !important;
}
.site-nav.scrolled .dropdown-all-link { color: var(--terra) !important; border-color: rgba(16,42,67,.1); }

/* Mobile dropdown — flat list in mobile menu */
.mobile-service-label {
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--stone);
  padding: 4px 0 8px;
  border-top: 1px solid var(--rule);
  margin-top: 4px;
}
.mobile-menu .mobile-service-link {
  font-family: 'Open Sans', Arial, sans-serif;
  font-size: 18px !important;
  color: var(--blue);
  padding-left: 12px;
}

/* --- Service funnel page — includes grid --- */
.includes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 64px;
}
.include-card {
  background: #fff;
  border-radius: 22px;
  padding: 30px 28px;
  box-shadow: 0 12px 36px rgba(16,42,67,.07);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.include-icon {
  font-size: 26px;
  line-height: 1;
}
.include-card h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(18px, 1.6vw, 24px);
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -.04em;
  line-height: 1.1;
}
.include-card p {
  font-size: 14px;
  line-height: 1.78;
  color: var(--stone);
}
@media(max-width:700px){ .includes-grid { grid-template-columns: 1fr; } }

/* --- Calendar placeholder block --- */
.calendar-block {
  margin-top: 48px;
  padding: 36px;
  background: var(--deep);
  border-radius: 28px;
  border-top: 3px solid var(--amber);
}
.calendar-block .overline { color: #D4B184; }
.calendar-block h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(24px, 2.4vw, 36px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -.045em;
  line-height: 1.08;
  margin-bottom: 10px;
}
.calendar-block p {
  font-size: 15px;
  line-height: 1.8;
  color: rgba(245,240,232,.72);
  max-width: 540px;
  margin-bottom: 28px;
}
.calendar-embed-zone {
  border-radius: 18px;
  overflow: hidden;
  min-height: 420px;
  background: rgba(255,255,255,.05);
  border: 1px dashed rgba(255,255,255,.18);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ghl-form-embed {
  background: #fff;
  border-radius: 28px;
  padding: 0;
  box-shadow: 0 20px 60px rgba(27,58,75,.08);
  overflow: hidden;
}
.ghl-form-embed iframe {
  display: block;
  width: 100%;
  min-height: 860px;
  border: 0;
}
.calendar-embed-zone .ghl-calendar-iframe {
  display: block;
  width: 100%;
  min-height: 640px;
  border: 0;
  background: #fff;
}
.calendar-embed-placeholder {
  text-align: center;
  padding: 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.calendar-embed-placeholder span { font-size: 40px; opacity: .5; }
.calendar-embed-placeholder p {
  font-size: 13px;
  color: rgba(245,240,232,.52);
  line-height: 1.6;
  margin: 0;
}
.calendar-embed-placeholder small {
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--amber);
  opacity: .7;
}

/* --- Service funnel FAQ (compact) --- */
.service-faq { max-width: 760px; margin: 0 auto; }

/* --- Form + calendar two-col layout --- */
.form-calendar-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}
@media(max-width:1120px){ .form-calendar-grid { grid-template-columns: 1fr; } }

/* --- Owner story editorial layout --- */
.owner-story-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 80px;
  align-items: start;
}
.owner-story-body { display: flex; flex-direction: column; gap: 20px; }
.owner-story-body p {
  font-size: 17px;
  line-height: 1.88;
  font-weight: 300;
  color: var(--stone);
}
.owner-story-pullquote {
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: clamp(20px, 1.9vw, 28px);
  font-style: italic;
  font-weight: 300;
  color: var(--terra);
  border-left: 3px solid var(--amber);
  padding-left: 24px;
  margin-top: 12px;
  line-height: 1.5;
}
.owner-story-aside {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding-top: 8px;
}
.owner-story-aside p {
  font-size: 15px;
  line-height: 1.85;
  font-weight: 300;
  color: var(--stone);
}
@media(max-width:1120px){
  .owner-story-grid { grid-template-columns: 1fr; gap: 48px; }
}

/* --- Hero-italic fix (override the incorrect uppercase) --- */
.hero-italic {
  font-family: 'Montserrat', Arial, sans-serif !important;
  font-size: clamp(17px, 1.9vw, 22px) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--terra) !important;
  margin-top: 12px;
}
