/* Dockless Marine LLC — bespoke marine services site */
:root{
  --navy:#16223f;        /* deep hull navy (logo) */
  --navy-2:#0d1730;      /* deeper, hero base */
  --steel:#5b6b86;       /* steel gray */
  --ink:#16223f;         /* headings */
  --body:#46566f;        /* body text */
  --muted:#7c8aa3;       /* muted */
  --sea:#1d7fbf;         /* marine accent */
  --sea-2:#37a3da;       /* accent hover/light */
  --foam:#eef4fa;        /* light tint */
  --sand:#f6f8fb;        /* page bg */
  --line:#e4e9f1;        /* borders */
  --white:#ffffff;
  --r:14px;
  --shadow:0 1px 2px rgba(16,34,63,.05), 0 8px 24px -12px rgba(16,34,63,.18);
  --shadow-lg:0 24px 60px -24px rgba(16,34,63,.35);
  --sans:'Manrope',system-ui,-apple-system,sans-serif;
  --display:'Fraunces',Georgia,serif;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--body);background:var(--sand);
  font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);font-weight:600;line-height:1.08;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--sea)}
.eyebrow.on-dark{color:var(--sea-2)}
.eyebrow .anchor{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px rgba(29,127,191,.18)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;
  padding:13px 22px;border-radius:11px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s; white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--sea);color:#fff;box-shadow:0 8px 20px -8px rgba(29,127,191,.6)}
.btn-primary:hover{background:var(--sea-2);box-shadow:0 12px 26px -8px rgba(29,127,191,.7)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#1d2c4f}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--steel);background:#fff}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.28)}
.btn-ghost.on-dark:hover{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.06)}
.btn svg{width:17px;height:17px}

/* ---------- Top utility bar ---------- */
.util{background:var(--navy-2);color:#aebbd0;font-size:13px}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:42px}
.util a{color:#cdd8ea}
.util a:hover{color:#fff}
.util .r{display:flex;align-items:center;gap:16px}
.util .sep{width:1px;height:14px;background:rgba(255,255,255,.18)}
.util .ping{display:inline-flex;align-items:center;gap:8px}
.util .ping i{width:7px;height:7px;border-radius:50%;background:#3fd29a;box-shadow:0 0 0 3px rgba(63,210,154,.2)}
@media(max-width:760px){.util .l{display:none}.util .wrap{justify-content:center}}

/* ---------- Header / nav — luxurious nautical (navy + brass) ---------- */
header.site{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,#17243f 0%,#101a31 100%);
  border-bottom:1px solid rgba(201,165,92,.22);box-shadow:0 8px 30px rgba(0,0,0,.26)}
header.site::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,rgba(201,165,92,.25),#e6cf9e 50%,rgba(201,165,92,.25))}
.nav{position:relative;display:flex;align-items:center;justify-content:space-between;height:92px}
.nav-right{display:flex;align-items:center;gap:18px}

/* brand defaults — single-line, strong sans wordmark (footer + drawer on light) */
.brand{display:flex;align-items:center;gap:12px}
.brand .brand-mark{height:48px;width:auto;flex:none}
.brand-word{display:flex;align-items:baseline;gap:9px;line-height:1}
.brand-word b{font-family:var(--sans);font-weight:800;font-size:20px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.brand-word span{font-family:var(--sans);font-weight:800;font-size:20px;letter-spacing:.08em;text-transform:uppercase;color:var(--steel)}
.brand.on-dark .brand-word b{color:#fff}
.brand.on-dark .brand-word span{color:#e6cf9e}

/* header brand — BIG, single line, on a gold-ringed cream medallion */
header.site .wrap{max-width:1340px}
header.site .brand{gap:15px}
.brand-medallion{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;
  background:radial-gradient(circle at 50% 36%,#fff,#e7eef8);box-shadow:0 6px 18px rgba(0,0,0,.42), inset 0 0 0 2px rgba(201,165,92,.6)}
.brand-medallion img{width:47px;height:auto}
header.site .brand-word b{font-size:31px;color:#fff;letter-spacing:.07em;white-space:nowrap}
header.site .brand-word span{font-size:31px;color:#e6cf9e;letter-spacing:.07em;white-space:nowrap}

/* nav links — light with gold underline */
.nav-links{display:flex;align-items:center;gap:1px}
.nav-links a{font-weight:600;font-size:14px;color:#d8e1f0;padding:8px 11px;border-radius:9px;position:relative;white-space:nowrap;transition:color .2s}
.nav-links a:hover{color:#e6cf9e}
.nav-links a::after{content:"";position:absolute;left:11px;right:11px;bottom:3px;height:1.5px;background:#c9a55c;transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav-links a:hover::after{transform:scaleX(1)}

/* hours of operation + phone */
.hours-info{display:flex;flex-direction:column;gap:2px;padding-right:16px;border-right:1px solid rgba(255,255,255,.14)}
.hours-info .hi-hours{display:flex;align-items:center;gap:6px;font-size:11.5px;color:#9fb0cb;font-weight:600;white-space:nowrap}
.hours-info .hi-hours svg{width:13px;height:13px;color:#c9a55c;flex:none}
.hours-info .hi-tel{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:700;color:#fff;white-space:nowrap;font-variant-numeric:tabular-nums lining-nums}
.hours-info .hi-tel svg{width:14px;height:14px;color:#c9a55c;flex:none}
.hours-info .hi-tel:hover{color:#e6cf9e}

/* actions — brass Login + gold Request Service */
.nav-actions{display:flex;align-items:center;gap:10px}
.btn-login{background:transparent;border:1px solid rgba(201,165,92,.55);color:#e6cf9e;padding:9px 15px;font-weight:700;font-size:14px;border-radius:10px;white-space:nowrap}
.btn-login:hover{background:rgba(201,165,92,.14);border-color:#c9a55c;color:#fff}
header.site .nav-actions .btn-primary{background:linear-gradient(180deg,#dcbb6c,#c29a4c);color:#15223e;border:1px solid rgba(255,255,255,.18);box-shadow:0 6px 18px rgba(201,165,92,.35);white-space:nowrap}
header.site .nav-actions .btn-primary:hover{background:linear-gradient(180deg,#e6c87d,#cda657)}
a[href^="tel:"], .contact-info .v{font-variant-numeric:tabular-nums lining-nums}
.menu-btn{display:none;background:none;border:none;color:#fff;cursor:pointer}
@media(max-width:1240px){
  .nav-links,.hours-info,.btn-login{display:none}
  .menu-btn{display:block}
}

/* mobile drawer */
.drawer{position:fixed;inset:0 0 0 auto;width:min(330px,86vw);background:#fff;z-index:100;
  transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--shadow-lg);padding:22px;display:flex;flex-direction:column;gap:6px}
.drawer.open{transform:translateX(0)}
.drawer a{font-weight:600;color:var(--ink);padding:13px 12px;border-radius:10px;font-size:16px}
.drawer a:hover{background:var(--foam)}
.drawer .btn{margin-top:10px;justify-content:center}
.scrim{position:fixed;inset:0;background:rgba(13,23,48,.45);z-index:99;opacity:0;pointer-events:none;transition:opacity .3s}
.scrim.open{opacity:1;pointer-events:auto}
.drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.drawer-top img{height:38px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:#eaf1fb;
  background:radial-gradient(1200px 600px at 75% -10%, #234074 0%, transparent 60%),
             linear-gradient(160deg,#16284c 0%, var(--navy-2) 70%)}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 320px at 12% 110%, rgba(29,127,191,.28), transparent 60%);pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center;
  padding:84px 24px 96px}
.hero h1{color:#fff;font-size:clamp(38px,5.4vw,62px);letter-spacing:-.02em;margin:20px 0 0}
.hero h1 .accent{color:#7cc4f0;font-style:italic}
.hero .lede{margin-top:22px;font-size:clamp(17px,1.6vw,19.5px);color:#bccadfe6;color:#c2cfe4;max-width:540px;line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px}
.hero-trust{display:flex;flex-wrap:wrap;gap:18px 26px;margin-top:38px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12)}
.hero-trust .t{display:flex;align-items:center;gap:10px;font-size:14px;color:#cfdaec;font-weight:600}
.hero-trust .t svg{width:18px;height:18px;color:#5fd2a0;flex:none}

/* ----- Centered hero with animated emblem ----- */
.hero-center .wrap{display:block;text-align:center;max-width:840px;padding:60px 24px 92px}
.hero-center h1{margin:18px auto 0;max-width:760px}
.hero-center .lede{margin:22px auto 0}
.hero-center .eyebrow,.hero-center .hero-actions,.hero-center .hero-trust{justify-content:center}
.hero-center .hero-trust{display:inline-flex;margin-left:auto;margin-right:auto}
.hero-logo{display:flex;justify-content:center;align-items:center}
.orbit{position:relative;width:282px;height:282px;display:flex;align-items:center;justify-content:center}
.orbit-core{position:absolute;width:182px;height:182px;border-radius:50%;z-index:2;animation:bob 4.5s ease-in-out infinite;
  background:radial-gradient(circle at 50% 36%, #ffffff 0%, #eef4fb 60%, #d8e6f5 100%);
  box-shadow:0 12px 36px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.75)}
.hero-emblem{width:152px;height:auto;z-index:3;filter:drop-shadow(0 5px 12px rgba(16,34,63,.28));animation:bob 4.5s ease-in-out infinite;will-change:transform}
.ring{position:absolute;border-radius:50%;pointer-events:none;will-change:transform}
.ring-dash{inset:0;border:2px dashed rgba(124,196,240,.6);animation:spin 16s linear infinite}
.ring-spin{inset:22px;border:2.5px solid rgba(255,255,255,.07);border-top-color:#7cc4f0;border-right-color:rgba(124,196,240,.45);animation:spin 5.5s linear infinite}
.ring-sweep{inset:4px;background:conic-gradient(from 0deg, rgba(124,196,240,.5), rgba(124,196,240,0) 30%);-webkit-mask:radial-gradient(closest-side, transparent 62%, #000 63%);mask:radial-gradient(closest-side, transparent 62%, #000 63%);animation:spin 3.5s linear infinite}
.orbit-dot{position:absolute;inset:-2px;animation:spin 6s linear infinite}
.orbit-dot::before{content:"";position:absolute;top:-6px;left:50%;width:12px;height:12px;margin-left:-6px;border-radius:50%;background:#9ad4f5;box-shadow:0 0 14px 3px rgba(124,196,240,.9)}
.orbit-dot2{position:absolute;inset:20px;animation:spin 9s linear infinite reverse}
.orbit-dot2::before{content:"";position:absolute;bottom:-5px;left:50%;width:8px;height:8px;margin-left:-4px;border-radius:50%;background:#5fd2a0;box-shadow:0 0 10px 2px rgba(95,210,160,.75)}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media(max-width:900px){.hero-logo{order:-1;margin-bottom:8px}}
@media(max-width:560px){.orbit{width:210px;height:210px}.hero-emblem{width:116px}.orbit-core{width:138px;height:138px}}
/* hero emblem card */
.hero-card{position:relative;background:linear-gradient(170deg,rgba(255,255,255,.09),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:34px;backdrop-filter:blur(2px);box-shadow:var(--shadow-lg)}
.hero-card .emblem{width:140px;margin:0 auto 18px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.4))}
.hero-card h3{color:#fff;text-align:center;font-size:23px;margin-bottom:6px}
.hero-card p{text-align:center;color:#b9c6dd;font-size:14.5px;margin-bottom:22px}
.hero-card ul{list-style:none;display:grid;gap:11px}
.hero-card li{display:flex;align-items:center;gap:12px;font-size:14.5px;color:#dde6f4;font-weight:600}
.hero-card li svg{width:18px;height:18px;color:#7cc4f0;flex:none}
@media(max-width:900px){.hero .wrap{grid-template-columns:1fr;gap:40px;padding:60px 24px 72px}.hero-card{max-width:440px}}

/* wave divider */
.wave{display:block;width:100%;height:auto;margin-top:-1px}

/* ---------- Section scaffolding ---------- */
section{padding:84px 0}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(30px,3.6vw,44px);margin-top:14px}
.sec-head p{margin-top:16px;font-size:17.5px;color:var(--body)}

/* ---------- Services ---------- */
#services{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:transform .22s,box-shadow .22s,border-color .22s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cdd8e8}
.svc .ic{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,var(--foam),#dceaf6);color:var(--sea);margin-bottom:18px}
.svc .ic svg{width:25px;height:25px}
.svc h3{font-size:20px;margin-bottom:9px}
.svc p{font-size:15px;color:var(--body);line-height:1.6}
.svc .tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:7px}
.svc .tags span{font-size:12px;font-weight:600;color:var(--steel);background:var(--sand);border:1px solid var(--line);padding:4px 9px;border-radius:7px}

/* engine note */
.note{margin-top:34px;display:flex;align-items:center;gap:16px;background:var(--navy);color:#dbe6f6;
  border-radius:var(--r);padding:20px 24px}
.note svg{width:26px;height:26px;color:#7cc4f0;flex:none}
.note b{color:#fff}

/* ---------- Why / values ---------- */
#why{background:var(--sand)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.why-grid{grid-template-columns:1fr}}
.value{display:flex;gap:18px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px}
.value .ic{width:46px;height:46px;border-radius:12px;background:var(--navy);color:#7cc4f0;display:flex;align-items:center;justify-content:center;flex:none}
.value .ic svg{width:23px;height:23px}
.value h3{font-size:19px;margin-bottom:7px}
.value p{font-size:15px;color:var(--body)}

/* ---------- About / split ---------- */
#about{background:#fff;border-top:1px solid var(--line)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:36px}}
.about-card{background:linear-gradient(165deg,var(--navy),var(--navy-2));border-radius:20px;padding:40px;color:#dbe6f6;box-shadow:var(--shadow-lg)}
.about-card .emblem{width:96px;margin-bottom:22px}
.about-card h3{color:#fff;font-size:24px;margin-bottom:14px}
.about-card ul{list-style:none;margin-top:20px;display:grid;gap:13px}
.about-card li{display:flex;gap:12px;font-size:15px;color:#cdd9ec;font-weight:600}
.about-card li svg{width:19px;height:19px;color:#5fd2a0;flex:none}
.prose p{margin-bottom:16px;font-size:16.5px}
.prose strong{color:var(--ink)}

/* ---------- CTA band ---------- */
.cta-band{background:radial-gradient(900px 400px at 80% 0%, #234074, transparent 60%),linear-gradient(160deg,#16284c,var(--navy-2));
  color:#fff;text-align:center;border-radius:0}
.cta-band h2{color:#fff;font-size:clamp(28px,3.4vw,42px)}
.cta-band p{color:#c2cfe4;max-width:560px;margin:16px auto 0;font-size:17.5px}
.cta-band .hero-actions{justify-content:center}

/* ---------- Contact ---------- */
#contact{background:var(--sand)}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px}}
.contact-info .item{display:flex;gap:15px;margin-bottom:26px}
.contact-info .ic{width:44px;height:44px;border-radius:12px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--sea);flex:none}
.contact-info .ic svg{width:21px;height:21px}
.contact-info h4{font-family:var(--sans);font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:3px}
.contact-info .v{font-weight:700;color:var(--ink);font-size:16px}
.form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.form .row{grid-template-columns:1fr}}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:15px;color:var(--ink);
  background:var(--sand);border:1px solid var(--line);border-radius:10px;padding:12px 14px;transition:border .2s,box-shadow .2s,background .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sea);background:#fff;box-shadow:0 0 0 3px rgba(29,127,191,.14)}
.field textarea{min-height:118px;resize:vertical}
.form .btn{width:100%;justify-content:center;margin-top:6px;font-size:16px;padding:15px}
.form-note{font-size:13px;color:var(--muted);margin-top:14px;text-align:center}
.form-ok{display:none;text-align:center;padding:28px 10px}
.form-ok.show{display:block}
.form-ok .ring{width:60px;height:60px;border-radius:50%;background:var(--foam);color:var(--sea);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.form-ok h3{font-size:23px;margin-bottom:8px}
.form-ok p{color:var(--body)}

/* ---------- Footer ---------- */
footer{background:var(--navy-2);color:#9fb0cb;padding:62px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
footer img.flogo{height:42px;margin-bottom:18px}
footer .blurb{font-size:14.5px;color:#9fb0cb;max-width:300px;line-height:1.6}
footer h5{font-family:var(--sans);color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
footer ul{list-style:none;display:grid;gap:11px}
footer a:hover{color:#fff}
footer .legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:13px;color:#7c8ba6}
footer .legal a{color:#9fb0cb;margin-left:18px}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
