:root{
  --deep-ocean:#0a1f0a;
  --midnight:#142d10;
  --sand:#f2e6d9;
  --steel:#2b2f33;
  --gloss-black:#000000;
  --aqua:#7dd957;
  --accent-red:#ff4d4d;
  --soft-white:#f8fafc;
  --radius:18px;
  --container:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--deep-ocean);
  color:var(--soft-white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.3s}

.container{max-width:var(--container);margin:0 auto;padding:0 28px}

h1,h2,h3,h4{font-family:'Montserrat',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.05}
h1{font-size:clamp(2.6rem,6vw,5.4rem)}
h2{font-size:clamp(2rem,4vw,3.4rem)}
h3{font-size:1.4rem;letter-spacing:-.01em}
h4{font-family:'Oswald',sans-serif;font-size:.9rem;letter-spacing:.18em;text-transform:uppercase;color:var(--aqua);margin-bottom:18px}
p{color:rgba(248,250,252,.72)}
.lead{font-size:1.15rem;color:rgba(248,250,252,.85)}

.eyebrow{
  display:inline-block;
  font-family:'Oswald',sans-serif;
  font-size:.75rem;
  letter-spacing:.3em;
  color:var(--accent-red);
  text-transform:uppercase;
  margin-bottom:18px;
}
.accent{color:var(--accent-red)}

/* HEADER */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:22px 0;
  transition:.4s;
  background:transparent;
}
.site-header.scrolled{
  background:rgba(10,31,10,.85);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  padding:14px 0;
  border-bottom:1px solid rgba(125,217,87,.18);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:30px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.05rem}
.logo-mark{color:var(--accent-red);font-size:1.4rem;text-shadow:0 0 20px rgba(255,77,77,.6)}
.logo-text em{font-style:normal;color:rgba(248,250,252,.5);font-weight:400}
.main-nav{display:flex;gap:36px}
.main-nav a{
  position:relative;
  font-size:.9rem;
  font-weight:500;
  letter-spacing:.02em;
  padding:6px 0;
  color:rgba(248,250,252,.75);
}
.main-nav a:hover,.main-nav a.active{color:var(--soft-white)}
.main-nav a::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;height:1px;
  background:linear-gradient(90deg, var(--aqua), var(--accent-red));
  transition:.3s;
}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.menu-toggle span{width:24px;height:2px;background:var(--soft-white);transition:.3s}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 32px;
  border-radius:60px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:.85rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  transition:.4s;
  cursor:pointer;
  border:none;
}
.btn-primary{
  background:linear-gradient(135deg, var(--aqua), var(--accent-red));
  color:#0a1f0a;
  box-shadow:0 10px 40px rgba(255,77,77,.3);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 50px rgba(125,217,87,.45)}
.btn-ghost{
  background:transparent;
  color:var(--soft-white);
  border:1px solid rgba(248,250,252,.2);
}
.btn-ghost:hover{border-color:var(--aqua);color:var(--aqua)}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(125,217,87,.16), transparent 60%),
    radial-gradient(ellipse at 80% 80%, rgba(255,77,77,.14), transparent 60%),
    linear-gradient(180deg, var(--deep-ocean) 0%, var(--midnight) 60%, #1f3a14 100%);
  padding-top:120px;
  padding-bottom:80px;
}
.hero-ocean{
  position:absolute;
  bottom:0;left:0;right:0;
  height:35%;
  pointer-events:none;
}
.wave{
  position:absolute;
  left:-10%;right:-10%;
  height:200px;
  background:radial-gradient(ellipse at center, rgba(125,217,87,.18) 0%, transparent 70%);
  border-radius:50%;
  animation:waveMove 8s ease-in-out infinite;
}
.wave-1{bottom:-100px;animation-delay:0s;opacity:.6}
.wave-2{bottom:-140px;animation-delay:-2s;opacity:.4;background:radial-gradient(ellipse at center, rgba(255,77,77,.22) 0%, transparent 70%)}
.wave-3{bottom:-180px;animation-delay:-4s;opacity:.3;background:radial-gradient(ellipse at center, rgba(125,217,87,.25) 0%, transparent 70%)}
@keyframes waveMove{
  0%,100%{transform:translateX(0) scaleY(1)}
  50%{transform:translateX(40px) scaleY(1.1)}
}

.hero-boat{
  position:absolute;
  right:-5%;
  top:18%;
  width:62%;
  max-width:880px;
  z-index:2;
  pointer-events:none;
  filter:drop-shadow(0 60px 80px rgba(0,0,0,.6));
  animation:boatFloat 6s ease-in-out infinite;
  transition:transform .2s ease-out;
}
.hero-boat img{
  width:100%;
  border-radius:24px;
  mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
}
@keyframes boatFloat{
  0%,100%{transform:translateY(0) rotate(-.5deg)}
  50%{transform:translateY(-22px) rotate(.5deg)}
}

.hero-content{position:relative;z-index:5;max-width:780px}
.hero-content h1{margin-bottom:24px}
.hero-content p{font-size:1.18rem;max-width:560px;margin-bottom:36px}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-bottom:60px}

.hero-stats{
  display:flex;
  gap:50px;
  flex-wrap:wrap;
  padding-top:30px;
  border-top:1px solid rgba(248,250,252,.1);
  max-width:560px;
}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats strong{font-family:'Montserrat',sans-serif;font-size:2rem;font-weight:800;color:var(--soft-white)}
.hero-stats span{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(248,250,252,.5);margin-top:4px}

.scroll-indicator{
  position:absolute;
  bottom:30px;left:50%;
  transform:translateX(-50%);
  font-family:'Oswald',sans-serif;
  font-size:.7rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:rgba(248,250,252,.5);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  z-index:5;
}
.scroll-indicator span{
  width:1px;height:50px;
  background:linear-gradient(to bottom, var(--aqua), var(--accent-red), transparent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* PAGE HERO */
.page-hero{
  padding:200px 0 100px;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(125,217,87,.16), transparent 60%),
    radial-gradient(ellipse at 20% 80%, rgba(255,77,77,.14), transparent 60%),
    linear-gradient(180deg, var(--deep-ocean), var(--midnight));
  position:relative;
}
.page-hero h1{margin-bottom:20px}
.page-hero p{max-width:600px;font-size:1.15rem}

/* SECTIONS */
.section{padding:120px 0;position:relative}
.section.dark{
  background:linear-gradient(180deg, var(--midnight), #1a3a14, var(--midnight));
}
.section-head{margin-bottom:70px;max-width:680px}
.section-head.center{margin:0 auto 70px;text-align:center}
.section-head.between{display:flex;justify-content:space-between;align-items:flex-end;max-width:none;gap:30px;flex-wrap:wrap;margin-bottom:50px}
.section-head h2{margin-bottom:14px}

/* SPLIT LAYOUTS */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split.reverse .split-image{order:2}
.split.reverse .split-content{order:1}

.split-content h2{margin-bottom:24px}
.split-content p{margin-bottom:18px;font-size:1.05rem}

.image-frame{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.5);
  aspect-ratio:4/3;
}
.image-frame.tall{aspect-ratio:3/4}
.image-frame img{width:100%;height:100%;object-fit:cover;transition:.6s}
.image-frame:hover img{transform:scale(1.05)}

.float-badge{
  position:absolute;
  bottom:-22px;left:30px;
  background:linear-gradient(135deg, var(--aqua), var(--accent-red));
  color:#0a1f0a;
  padding:14px 26px;
  border-radius:60px;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  box-shadow:0 14px 40px rgba(255,77,77,.4);
}
.split-image{position:relative}

.feature-list{list-style:none;margin:30px 0}
.feature-list li{
  display:flex;
  align-items:center;
  gap:18px;
  padding:14px 0;
  border-bottom:1px solid rgba(248,250,252,.08);
  font-size:1rem;
}
.feature-list li span{
  font-family:'Oswald',sans-serif;
  color:var(--accent-red);
  font-size:.85rem;
  letter-spacing:.1em;
}

.bullet-list{list-style:none;margin-top:24px}
.bullet-list li{
  position:relative;
  padding:14px 0 14px 30px;
  border-bottom:1px solid rgba(248,250,252,.08);
  color:rgba(248,250,252,.85);
}
.bullet-list li::before{
  content:'';
  position:absolute;
  left:0;top:22px;
  width:14px;height:1px;
  background:linear-gradient(90deg, var(--aqua), var(--accent-red));
}
.bullet-list li strong{color:var(--soft-white)}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

.glass-card{
  background:linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(125,217,87,.14);
  border-radius:var(--radius);
  padding:36px 30px;
  backdrop-filter:blur(10px);
  transition:.4s;
  position:relative;
  overflow:hidden;
}
.glass-card::before{
  content:'';
  position:absolute;
  top:0;left:-100%;
  width:100%;height:1px;
  background:linear-gradient(90deg, transparent, var(--aqua), var(--accent-red), transparent);
  transition:.6s;
}
.glass-card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,77,77,.4);
  box-shadow:0 30px 70px rgba(125,217,87,.12);
}
.glass-card:hover::before{left:100%}
.glass-card .card-num{
  font-family:'Oswald',sans-serif;
  color:var(--accent-red);
  font-size:.85rem;
  letter-spacing:.2em;
  margin-bottom:18px;
}
.glass-card h3{margin-bottom:12px}
.glass-card.big{padding:50px 40px}
.glass-card.big h3{font-size:1.8rem;margin-bottom:16px}

/* PROCESS */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.process-step{
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  overflow:hidden;
  transition:.4s;
}
.process-step:hover{transform:translateY(-6px);border-color:rgba(125,217,87,.35)}
.step-img{aspect-ratio:4/3;overflow:hidden}
.step-img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.process-step:hover .step-img img{transform:scale(1.08)}
.process-step .step-num{
  display:block;
  font-family:'Oswald',sans-serif;
  color:var(--accent-red);
  font-size:.78rem;
  letter-spacing:.25em;
  padding:24px 24px 0;
}
.process-step h3{padding:8px 24px 6px;font-size:1.3rem}
.process-step p{padding:0 24px 30px;font-size:.95rem}

/* CONCEPT STATS */
.concept-stats{display:flex;gap:40px;margin:30px 0 36px;flex-wrap:wrap}
.concept-stats div{display:flex;flex-direction:column}
.concept-stats strong{font-family:'Montserrat',sans-serif;font-size:2rem;font-weight:800;color:var(--aqua)}
.concept-stats div:nth-child(even) strong{color:var(--accent-red)}
.concept-stats span{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(248,250,252,.55);margin-top:4px}

/* GALLERY GRID */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:240px;
  gap:18px;
}
.gallery-item{
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}

/* MASONRY GALLERY PAGE */
.masonry{
  column-count:3;
  column-gap:20px;
}
.m-item{
  break-inside:avoid;
  margin-bottom:20px;
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  transition:.4s;
}
.m-item img{width:100%;height:auto;transition:.6s}
.m-item:hover{transform:translateY(-4px)}
.m-item:hover img{transform:scale(1.05)}

/* CTA BANNER */
.cta-banner{
  padding:100px 0;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(125,217,87,.2), transparent 60%),
    radial-gradient(ellipse at 70% 50%, rgba(255,77,77,.18), transparent 60%),
    linear-gradient(135deg, var(--midnight), #1f3a14);
}
.cta-inner{
  text-align:center;
  max-width:680px;
  margin:0 auto;
}
.cta-inner h2{margin-bottom:18px}
.cta-inner p{margin-bottom:34px;font-size:1.1rem}

/* BOAT CARDS */
.boat-list{display:flex;flex-direction:column;gap:80px}
.boat-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.boat-card.reverse .boat-card-img{order:2}
.boat-card-img{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:5/4;
  box-shadow:0 40px 90px rgba(0,0,0,.5);
}
.boat-card-img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.boat-card:hover .boat-card-img img{transform:scale(1.05)}
.boat-tag{
  position:absolute;
  top:24px;left:24px;
  background:rgba(10,31,10,.7);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,77,77,.35);
  color:var(--accent-red);
  padding:8px 18px;
  border-radius:60px;
  font-family:'Oswald',sans-serif;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.boat-card-body h2{margin-bottom:16px;font-size:2.6rem}
.boat-card-body p{margin-bottom:30px;font-size:1.05rem}
.specs{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-bottom:30px;
}
.specs div{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  padding:18px 20px;
  border-radius:12px;
}
.specs div span{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--aqua);
  margin-bottom:6px;
}
.specs div:nth-child(even) span{color:var(--accent-red)}
.specs div strong{
  font-family:'Montserrat',sans-serif;
  font-size:1.1rem;
  font-weight:700;
}

/* TIMELINE */
.timeline{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  margin-top:40px;
}
.timeline-item{
  background:linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(125,217,87,.12);
  border-radius:var(--radius);
  padding:36px 30px;
  position:relative;
  transition:.4s;
}
.timeline-item:hover{transform:translateY(-6px);border-color:rgba(255,77,77,.4)}
.t-num{
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:3rem;
  font-weight:900;
  background:linear-gradient(135deg, rgba(125,217,87,.4), rgba(255,77,77,.4));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  margin-bottom:10px;
  line-height:1;
}
.timeline-item h3{margin-bottom:10px}

/* STAT GRID */
.stat-grid{text-align:center}
.stat strong{
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:3.4rem;
  font-weight:800;
  color:var(--aqua);
  line-height:1;
  margin-bottom:10px;
}
.stat:nth-child(even) strong{color:var(--accent-red)}
.stat span{
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(248,250,252,.6);
}

/* CONTACT */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:80px;
}
.contact-info h2{margin-bottom:8px;font-size:2rem}
.contact-info .lead{margin-bottom:34px}
.info-block{
  padding:18px 0;
  border-bottom:1px solid rgba(248,250,252,.08);
}
.info-block span{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:.7rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--accent-red);
  margin-bottom:6px;
}
.info-block p{color:var(--soft-white);font-size:1rem}
.info-block a:hover{color:var(--aqua)}

.contact-form{
  background:linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(125,217,87,.14);
  border-radius:var(--radius);
  padding:40px;
  backdrop-filter:blur(10px);
}
.field{margin-bottom:22px}
.field label{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--aqua);
  margin-bottom:10px;
}
.field input,
.field select,
.field textarea{
  width:100%;
  padding:16px 18px;
  background:rgba(10,31,10,.6);
  border:1px solid rgba(248,250,252,.1);
  border-radius:10px;
  color:var(--soft-white);
  font-family:'Inter',sans-serif;
  font-size:.95rem;
  transition:.3s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent-red);
  background:rgba(10,31,10,.9);
}
.consent-field .consent-label{
  display:flex;
  gap:12px;
  align-items:flex-start;
  font-family:'Inter',sans-serif;
  text-transform:none;
  letter-spacing:0;
  color:rgba(248,250,252,.75);
  font-size:.88rem;
  line-height:1.5;
  cursor:pointer;
}
.consent-field input[type="checkbox"]{
  width:auto;
  margin-top:4px;
  accent-color:var(--accent-red);
  flex-shrink:0;
}
.consent-field a{color:var(--aqua);text-decoration:underline}
.form-success{
  margin-top:18px;
  color:var(--aqua);
  font-size:.9rem;
}

/* LEGAL PAGES */
.legal-content{
  max-width:860px;
  margin:0 auto;
}
.legal-content .legal-meta{
  font-family:'Oswald',sans-serif;
  font-size:.78rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--accent-red);
  margin-bottom:40px;
  padding-bottom:20px;
  border-bottom:1px solid rgba(248,250,252,.08);
}
.legal-content h2{
  font-size:1.6rem;
  margin:48px 0 16px;
  color:var(--soft-white);
}
.legal-content h2:first-of-type{margin-top:0}
.legal-content p{
  margin-bottom:16px;
  color:rgba(248,250,252,.78);
  font-size:1rem;
  line-height:1.8;
}
.legal-content a{
  color:var(--aqua);
  text-decoration:underline;
  text-underline-offset:3px;
}
.legal-content a:hover{color:var(--accent-red)}
.legal-content ul.bullet-list{margin:16px 0 24px}
.legal-content ul.bullet-list li{font-size:.98rem}

/* COOKIE BANNER */
.cookie-banner{
  position:fixed;
  bottom:20px;left:20px;right:20px;
  z-index:200;
  background:rgba(10,31,10,.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(125,217,87,.25);
  border-radius:var(--radius);
  padding:22px 26px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  max-width:1100px;
  margin:0 auto;
  transform:translateY(150%);
  transition:transform .5s ease;
}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner[hidden]{display:none}
.cookie-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
  flex-wrap:wrap;
}
.cookie-text{flex:1;min-width:260px}
.cookie-text strong{
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:1rem;
  margin-bottom:4px;
  color:var(--soft-white);
}
.cookie-text p{
  font-size:.88rem;
  color:rgba(248,250,252,.7);
  margin:0;
  line-height:1.5;
}
.cookie-text a{color:var(--aqua);text-decoration:underline}
.cookie-actions{
  display:flex;
  gap:12px;
  flex-shrink:0;
}
.cookie-actions .btn{padding:12px 22px;font-size:.78rem}

/* FOOTER */
.site-footer{
  background:var(--gloss-black);
  padding:80px 0 30px;
  border-top:1px solid rgba(125,217,87,.15);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:50px;
}
.footer-brand p{margin-top:16px;font-size:.92rem;max-width:260px}
.site-footer h4{color:var(--accent-red)}
.site-footer ul{list-style:none}
.site-footer ul li{padding:6px 0;font-size:.92rem;color:rgba(248,250,252,.65)}
.site-footer ul li a:hover{color:var(--aqua)}
.footer-bottom{
  padding-top:30px;
  border-top:1px solid rgba(248,250,252,.06);
  font-size:.82rem;
  color:rgba(248,250,252,.4);
}
.footer-bottom a{color:rgba(248,250,252,.6)}
.footer-bottom a:hover{color:var(--aqua)}

/* RESPONSIVE */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .timeline{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .hero-boat{width:80%;opacity:.5;top:auto;bottom:0}
}
@media(max-width:768px){
  .main-nav{
    position:fixed;
    top:70px;left:0;right:0;
    background:rgba(10,31,10,.97);
    backdrop-filter:blur(18px);
    flex-direction:column;
    padding:30px;
    gap:20px;
    transform:translateY(-150%);
    transition:.4s;
    border-bottom:1px solid rgba(125,217,87,.15);
  }
  .main-nav.open{transform:translateY(0)}
  .menu-toggle{display:flex}
  .split,.contact-grid,.boat-card{grid-template-columns:1fr;gap:40px}
  .split.reverse .split-image,.boat-card.reverse .boat-card-img{order:0}
  .grid-2,.grid-3,.grid-4,.process-grid,.timeline{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery-item.wide{grid-column:span 2}
  .masonry{column-count:2}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .section{padding:80px 0}
  .page-hero{padding:160px 0 80px}
  .hero-stats{gap:30px}
  .contact-form{padding:28px}
  .section-head.between{flex-direction:column;align-items:flex-start}
  .cookie-banner{
    bottom:10px;left:10px;right:10px;
    padding:18px 20px;
  }
  .cookie-inner{flex-direction:column;align-items:stretch;gap:16px}
  .cookie-actions{justify-content:stretch}
  .cookie-actions .btn{flex:1;justify-content:center}
}
@media(max-width:520px){
  .masonry{column-count:1}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item.wide,.gallery-item.tall{grid-column:auto;grid-row:auto}
  .specs{grid-template-columns:1fr}
}