/* ============================================================
   Wharfline — palette sampled from the brand logos
   Harbor slate #2E4254 · Dock blue #557588 · Waterline #A9C0CE
   Cream #F3E6D3 · Teal accent #1B8585
   Type: Plus Jakarta Sans (display) + Inter (body)
   ============================================================ */

:root{
  --cream:    #F3E6D3;
  --cream-2:  #FBF5EA;
  --harbor:   #2E4254;
  --harbor-d: #223544;
  --dock:     #557588;
  --dock-lt:  #A9C0CE;
  --teal:     #1B8585;
  --teal-d:   #14706C;
  --line:     #E3D4BE;
  --line-d:   #3A5266;
  --muted:    #6E7C88;
  --white:    #FFFFFF;

  --ink:      var(--harbor);
  --bg:       var(--cream-2);

  --maxw: 1140px;
  --pad: 24px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 1px 2px rgba(34,53,68,.04), 0 12px 32px -16px rgba(34,53,68,.18);
  --shadow-lift: 0 1px 2px rgba(34,53,68,.06), 0 22px 48px -20px rgba(34,53,68,.28);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,.eyebrow,.btn,.brand,.nav,.pkg-name,.step-num,.crow-label{
  font-family:"Plus Jakarta Sans",system-ui,sans-serif;
}
h1,h2,h3{color:var(--harbor);margin:0;letter-spacing:-.02em;line-height:1.12;font-weight:700}
h1{font-size:clamp(2.2rem,5.2vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem)}
h3{font-size:1.12rem;letter-spacing:-.01em}
p{margin:0}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-d)}
img{max-width:100%;display:block}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

.skip-link{
  position:absolute;left:-999px;top:8px;background:var(--harbor);color:#fff;
  padding:10px 16px;border-radius:8px;z-index:200;
}
.skip-link:focus{left:8px}

:focus-visible{outline:3px solid var(--teal);outline-offset:2px;border-radius:6px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:600;font-size:1rem;letter-spacing:-.01em;
  padding:14px 26px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s var(--ease),background .18s var(--ease),
    box-shadow .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease);
  white-space:nowrap;
}
.btn-sm{padding:10px 20px;font-size:.95rem}
.btn-block{display:flex;width:100%}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 10px 24px -12px rgba(27,133,133,.7)}
.btn-primary:hover{background:var(--teal-d);color:#fff;transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(27,133,133,.75)}
.btn-ghost{background:transparent;color:var(--harbor);border-color:var(--dock)}
.btn-ghost:hover{background:rgba(85,117,136,.1);color:var(--harbor);transform:translateY(-2px)}
.btn-on-dark{background:var(--cream);color:var(--harbor)}
.btn-on-dark:hover{background:#fff;color:var(--harbor-d);transform:translateY(-2px)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(243,230,211,.82);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:box-shadow .25s var(--ease),border-color .25s var(--ease),background .25s var(--ease);
}
.site-header.scrolled{
  box-shadow:0 1px 0 rgba(34,53,68,.06),0 10px 30px -24px rgba(34,53,68,.5);
  border-bottom-color:var(--line);
  background:rgba(243,230,211,.92);
}
.header-inner{display:flex;align-items:center;gap:24px;height:74px}
.brand{display:flex;align-items:center}
.brand-logo{height:52px;width:auto}
.nav{margin-left:auto;display:flex;gap:28px}
.nav a{color:var(--harbor);font-weight:600;font-size:.96rem;position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--teal);transition:right .25s var(--ease)}
.nav a:hover{color:var(--harbor)}
.nav a:hover::after{right:0}
.nav-cta{margin-left:4px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;margin-left:auto;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--harbor);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;flex-direction:column;gap:6px;padding:12px var(--pad) 22px;border-top:1px solid var(--line);background:var(--cream)}
.mobile-nav a:not(.btn){color:var(--harbor);font-weight:600;padding:12px 6px;border-radius:8px}
.mobile-nav a.btn{padding:14px 26px}
.mobile-nav a:not(.btn):hover{background:rgba(85,117,136,.1)}
.mobile-nav .btn{margin-top:8px}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--cream);padding:clamp(48px,7vw,86px) 0 0;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding-bottom:64px}
.eyebrow{
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.14em;color:var(--dock);margin-bottom:16px;
}
.eyebrow-light{color:var(--dock-lt)}
.hero h1{margin-bottom:20px}
.ink-accent{color:var(--teal)}
.lede{font-size:1.18rem;color:#42525e;max-width:38ch;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-trust{font-size:.92rem;color:var(--muted);font-weight:500;letter-spacing:.01em}

/* hero call card */
.hero-visual{display:flex;justify-content:center}
.call-card{
  width:100%;max-width:400px;background:#fff;border:1px solid var(--line);
  border-radius:20px;box-shadow:var(--shadow-lift);padding:22px 22px 8px;
}
.call-card-top{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--harbor);font-weight:600}
.status-dot{width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(27,133,133,.5);animation:pulse 2.4s var(--ease) infinite}
.call-status{flex:1}
.call-time{color:var(--muted);font-variant-numeric:tabular-nums;font-weight:500}
.waveform{display:flex;align-items:center;gap:4px;height:60px;margin:20px 2px 18px}
.waveform span{
  flex:1;background:linear-gradient(var(--dock),var(--dock-lt));border-radius:3px;
  height:22%;transform-origin:center;animation:wave 1.3s ease-in-out infinite;
}
.waveform span:nth-child(odd){animation-duration:1.05s}
.waveform span:nth-child(3n){animation-duration:1.6s}
.waveform span:nth-child(5n){background:linear-gradient(var(--teal),var(--dock-lt))}
.call-rows{border-top:1px solid var(--line);padding-top:6px}
.call-rows li{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid #f2ecdf;font-size:.92rem}
.call-rows li:last-child{border-bottom:0}
.crow-label{color:var(--dock);font-weight:600;font-size:.84rem;text-transform:uppercase;letter-spacing:.06em}
.crow-val{color:var(--harbor);text-align:right;font-weight:500}

/* signature dock + waterline */
.dock{position:relative;height:78px;margin-top:-8px}
.dock-deck{position:absolute;left:0;right:0;top:8px;height:9px;background:var(--dock);border-radius:4px}
.dock-pilings{position:absolute;left:0;right:0;top:17px;display:flex;justify-content:space-between;padding:0 6%}
.dock-pilings span{width:7px;height:30px;background:var(--dock);border-radius:0 0 2px 2px;opacity:.92}
.waterline{position:absolute;left:0;right:0;top:46px;height:30px;overflow:hidden}
.wave{position:absolute;left:-50%;right:-50%;top:6px;height:2px;background:var(--dock-lt);
  -webkit-mask:repeating-linear-gradient(90deg,#000 0 22px,transparent 22px 30px);
  mask:repeating-linear-gradient(90deg,#000 0 22px,transparent 22px 30px);
  animation:drift 9s linear infinite;opacity:.8}
.wave2{top:15px;opacity:.45;animation-duration:13s;animation-direction:reverse}

/* ---------- generic sections ---------- */
.section{padding:clamp(58px,8vw,104px) 0}
.section-cream{background:var(--cream)}
.section-harbor{background:var(--harbor);color:#cfdbe4}
.section-head{max-width:62ch;margin:0 auto clamp(34px,5vw,54px);text-align:center}
.section-head.section-head-light h2{color:#fff}
.section-sub{font-size:1.12rem;color:#52616d;margin-top:16px}
.section-sub-light{color:#aebfca}

/* problem grid */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.mini-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.mini-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.mini-card h3{margin-bottom:9px}
.mini-card p{color:#52616d;font-size:.98rem}

/* solution */
.solution-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.chip-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.chip-list li{background:rgba(85,117,136,.1);color:var(--harbor);border:1px solid var(--line);padding:8px 16px;border-radius:999px;font-weight:600;font-size:.92rem}
.quote-card{background:var(--harbor);color:#eaf1f6;border-radius:var(--radius);padding:34px 32px;box-shadow:var(--shadow-lift);position:relative}
.quote-card::before{content:"";position:absolute;left:32px;top:18px;width:34px;height:3px;background:var(--teal);border-radius:3px}
.quote{font-size:1.22rem;line-height:1.5;font-weight:500;margin-top:18px}
.quote-by{margin-top:18px;color:var(--dock-lt);font-size:.9rem}

/* features */
.grid-feature{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.feature h3{margin-bottom:8px}
.feature p{color:#52616d;font-size:.95rem}
.feature-ic{display:flex;width:46px;height:46px;border-radius:12px;background:rgba(85,117,136,.12);margin-bottom:16px;
  background-repeat:no-repeat;background-position:center;background-size:24px 24px}
.feature-ic[data-ic="clock"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 7v5l3 2'/></svg>")}
.feature-ic[data-ic="calendar"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4.5' width='18' height='16' rx='2'/><path d='M3 9h18M8 3v3M16 3v3'/><path d='M9 14l2 2 4-4'/></svg>")}
.feature-ic[data-ic="filter"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 5h18l-7 8v6l-4-2v-4z'/></svg>")}
.feature-ic[data-ic="chat"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M4 5h16v11H8l-4 3z'/><path d='M8 9h8M8 12h5'/></svg>")}
.feature-ic[data-ic="doc"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M7 3h7l5 5v13H7z'/><path d='M14 3v5h5M10 13h6M10 16h6'/></svg>")}
.feature-ic[data-ic="handoff"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M4 9h11l-3-3M20 15H9l3 3'/></svg>")}
.feature-ic[data-ic="link"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M9 15l6-6M10 6l1.5-1.5a4 4 0 015.5 5.5L15 12M14 18l-1.5 1.5a4 4 0 01-5.5-5.5L9 12'/></svg>")}
.feature-ic[data-ic="gear"]{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E4254' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='3'/><path d='M12 3v2M12 19v2M3 12h2M19 12h2M5.5 5.5l1.5 1.5M17 17l1.5 1.5M18.5 5.5L17 7M7 17l-1.5 1.5'/></svg>")}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;list-style:none}
.step{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow)}
.step-num{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:var(--harbor);color:#fff;font-weight:700;font-size:1.15rem;margin-bottom:16px}
.step h3{margin-bottom:8px}
.step p{color:#52616d;font-size:.97rem}

/* industries */
.industry-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.industry-grid li{background:rgba(255,255,255,.06);border:1px solid var(--line-d);border-radius:var(--radius-sm);
  padding:18px 16px;text-align:center;font-weight:600;color:#dde7ee;font-family:"Plus Jakarta Sans",sans-serif;
  transition:background .2s var(--ease),transform .2s var(--ease),border-color .2s var(--ease)}
.industry-grid li:hover{background:rgba(169,192,206,.14);border-color:var(--dock-lt);transform:translateY(-3px)}

/* benefits */
.grid-benefit{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.benefit{display:flex;align-items:center;gap:14px;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:18px 20px;font-weight:600;color:var(--harbor);box-shadow:var(--shadow)}
.benefit-tick{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(27,133,133,.12);
  background-repeat:no-repeat;background-position:center;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B8585' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12l4 4L19 7'/></svg>")}

/* packages */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pkg{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.pkg:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.pkg-feat{border:2px solid var(--harbor);box-shadow:var(--shadow-lift)}
.pkg-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--harbor);color:#fff;
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;white-space:nowrap}
.pkg-name{font-size:1.4rem;font-weight:700;margin-bottom:10px}
.pkg-vol{display:inline-block;background:rgba(85,117,136,.12);color:var(--harbor);font-weight:600;
  font-size:.92rem;padding:7px 14px;border-radius:999px;margin-bottom:20px}
.pkg-feats{margin-bottom:20px}
.pkg-feats li{position:relative;padding:7px 0 7px 26px;color:#42525e;font-size:.97rem;border-bottom:1px solid #f3ede2}
.pkg-feats li:last-child{border-bottom:0}
.pkg-feats li::before{content:"";position:absolute;left:0;top:13px;width:15px;height:15px;
  background-repeat:no-repeat;background-position:center;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23557588' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12l4 4L19 7'/></svg>")}
.pkg-best{color:var(--muted);font-size:.9rem;margin-bottom:22px;min-height:2.4em}
.pkg-note{text-align:center;color:var(--muted);font-size:.95rem;margin-top:28px;font-style:italic}

/* faq */
.faq-wrap{max-width:780px}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:22px 4px;font-family:"Plus Jakarta Sans",sans-serif;font-weight:600;font-size:1.08rem;color:var(--harbor);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-mark{position:relative;flex:none;width:18px;height:18px}
.faq-mark::before,.faq-mark::after{content:"";position:absolute;background:var(--dock);border-radius:2px;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.faq-mark::before{top:8px;left:0;width:18px;height:2px}
.faq-mark::after{top:0;left:8px;width:2px;height:18px}
.faq-item[open] .faq-mark::after{transform:rotate(90deg);opacity:0}
.faq-body{overflow:hidden;color:#52616d}
.faq-body p{padding:0 4px 22px;max-width:64ch}

/* contact */
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:50px;align-items:start}
.contact-copy{position:sticky;top:100px}
.contact-direct{margin-top:24px;font-size:1.05rem;color:#42525e}
.contact-reassure{margin-top:12px;color:var(--muted);font-size:.95rem}
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-lift)}
.field{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-weight:600;color:var(--harbor);font-size:.92rem;margin-bottom:7px}
.opt{color:var(--muted);font-weight:500}
input,select,textarea{
  width:100%;font:inherit;font-size:.97rem;color:var(--harbor);background:var(--cream-2);
  border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s;
}
input::placeholder,textarea::placeholder{color:#9aa6b0}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(27,133,133,.15)}
textarea{resize:vertical;min-height:84px}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23557588' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:40px}
.check-field{border:0;padding:0;margin:0 0 18px;min-width:0;inline-size:100%}
.check-field legend{font-weight:600;color:var(--harbor);font-size:.92rem;margin-bottom:12px;padding:0}
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;align-items:start}
.check{display:grid;grid-template-columns:18px 1fr;align-items:start;gap:10px;width:100%;font-weight:500;color:#42525e;font-size:.93rem;line-height:1.4;cursor:pointer;margin:0}
.check span{min-width:0}
.check input[type="checkbox"]{
  -webkit-appearance:auto;appearance:auto;
  width:18px;height:18px;min-height:0;margin:1px 0 0;padding:0;
  border:0;border-radius:0;background:none;box-shadow:none;accent-color:var(--teal);
}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
#submitBtn{margin-top:4px}
.form-status{margin-top:14px;font-weight:600;font-size:.96rem;min-height:1.2em}
.form-status.ok{color:var(--teal-d)}
.form-status.err{color:#b4452f}
.form-fineprint{margin-top:14px;color:var(--muted);font-size:.84rem;line-height:1.5}

/* final cta */
.final-cta{background:var(--harbor-d);color:#fff;padding:clamp(54px,7vw,82px) 0}
.final-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.final-cta h2{color:#fff;max-width:18ch}

/* footer */
.site-footer{background:var(--harbor);color:#aebfca;padding:56px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:34px;border-bottom:1px solid var(--line-d)}
/* Logo is a transparent PNG, so we can recolor it to a clean white silhouette
   for the dark footer. */
.footer-logo{height:40px;width:auto;filter:brightness(0) invert(1)}
.footer-tag{margin-top:16px;max-width:34ch;font-size:.95rem;color:#aebfca}
.footer-nav{display:flex;flex-direction:column;gap:11px}
.footer-nav a,.footer-contact a{color:#cfdbe4;font-size:.95rem}
.footer-nav a:hover,.footer-contact a:hover{color:#fff}
.footer-contact{display:flex;flex-direction:column;gap:11px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:22px;font-size:.86rem;color:#8ba0ae;flex-wrap:wrap}
.footer-legal a{color:#8ba0ae}
.footer-legal a:hover{color:#fff}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- animations ---------- */
@keyframes wave{0%,100%{height:22%}50%{height:100%}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(27,133,133,.5)}70%{box-shadow:0 0 0 9px rgba(27,133,133,0)}100%{box-shadow:0 0 0 0 rgba(27,133,133,0)}}
@keyframes drift{0%{transform:translateX(0)}100%{transform:translateX(30px)}}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .grid-4,.grid-feature{grid-template-columns:repeat(2,1fr)}
  .industry-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:860px){
  .nav,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .mobile-nav.open{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:2}
  .solution-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .contact-copy{position:static}
  .steps,.grid-benefit,.packages{grid-template-columns:1fr}
  .packages{max-width:440px;margin:0 auto}
  .industry-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-best{min-height:0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
}
@media (max-width:520px){
  body{font-size:16px}
  .field-row,.check-grid{grid-template-columns:1fr}
  .grid-4,.grid-feature{grid-template-columns:1fr}
  .final-cta-inner{flex-direction:column;align-items:flex-start}
  .form-card{padding:22px}
  .header-inner{height:64px}
  .brand-logo{height:42px}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
