*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#003A59;
  --blue:#1A6FA0;
  --sky:#E8F4FD;
  --sky-deep:#D0E8F7;
  --orange:#F09748;
  --orange-hover:#E58535;
  --cream:#FAFCFE;
  --white:#FFFFFF;
  --text:#2A3A48;
  --text-light:#5A6E7F;
  --serif:'Literata',Georgia,serif;
  --sans:'Figtree',system-ui,sans-serif;
  --nav-h:72px;
  --section-pad:clamp(60px,10vw,120px);
  --container:1200px;
  --radius:12px;
  --radius-lg:20px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--sans);
  color:var(--text);
  line-height:1.7;
  font-size:clamp(15px,1.1vw,17px);
  background:var(--cream);
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}

/* ── Accessibility ── */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--navy);color:#fff;padding:12px 24px;border-radius:0 0 8px 8px;z-index:10000;font-weight:600;transition:top .2s}
.skip-link:focus{top:0}
a:focus-visible,button:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right{opacity:1;transform:none;transition:none}}

a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--sans);font-weight:700;line-height:1.2}
.hero-tagline,.tl-year,.footer h5{font-family:var(--serif)}
.container{width:min(var(--container),92%);margin:0 auto}

/* ── Noise texture overlay for depth ── */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
  opacity:.018;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Reveal animations ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-left.visible,.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ══════════════════════════════════════
   NAVIGATION
   ══════════════════════════════════════ */
.nav-bar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(0,58,89,.06);
  transition:box-shadow .3s,background .3s;
}
.nav-bar.scrolled{
  background:rgba(255,255,255,.96);
  box-shadow:0 1px 24px rgba(0,58,89,.08);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;gap:24px;
}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:36px;width:auto}
/* ── Desktop dropdown nav ── */
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links > li{position:relative}
.nav-links > li > a{
  display:flex;align-items:center;gap:5px;padding:8px 14px;
  font-size:14.5px;font-weight:500;letter-spacing:.01em;
  color:var(--navy);border-radius:8px;
  transition:background .2s,color .2s;
  white-space:nowrap;
}
.nav-links > li > a:hover,
.nav-links > li:hover > a{background:var(--sky);color:var(--blue)}

/* chevron indicator for items with dropdowns */
.nav-links > li.has-dropdown > a::after{
  content:'';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 .25s;flex-shrink:0;
}
.nav-links > li.has-dropdown:hover > a::after{
  transform:rotate(-135deg) translateY(-2px);
}

/* dropdown panel */
.nav-dropdown{
  position:absolute;top:100%;left:0;
  min-width:240px;padding:8px 0;
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,58,89,.12),0 1px 4px rgba(0,58,89,.06);
  opacity:0;visibility:hidden;
  transform:translateY(6px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  pointer-events:none;
  z-index:1002;
}
/* hover bridge — prevents gap between nav item and dropdown */
.nav-links > li.has-dropdown::before{
  content:'';position:absolute;top:100%;left:0;
  width:100%;height:8px;
  display:none;
}
.nav-links > li.has-dropdown:hover::before{display:block}
/* slight hover delay to avoid accidental triggers */
.nav-links > li.has-dropdown:hover > .nav-dropdown{
  opacity:1;visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
  transition-delay:.08s;
}
/* dropdown items */
.nav-dropdown a{
  display:block;padding:9px 20px;
  font-size:14px;font-weight:450;
  color:var(--text);
  transition:background .15s,color .15s;
  white-space:nowrap;
}
.nav-dropdown a:hover{
  background:var(--sky);color:var(--blue);
}
.nav-icons{display:flex;align-items:center;gap:6px;flex-shrink:0}
.nav-icon{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:99px;
  color:var(--navy);background:var(--sky);
  transition:background .2s,color .2s;flex-shrink:0;
}
.nav-icon:hover{background:var(--navy);color:var(--white)}
.nav-icon svg{width:18px;height:18px}
.nav-phone{
  display:flex;align-items:center;gap:8px;
  font-weight:600;font-size:14px;color:var(--navy);
  background:var(--sky);padding:8px 18px;border-radius:99px;
  transition:background .2s,color .2s;flex-shrink:0;
  white-space:nowrap;
}
.nav-phone:hover{background:var(--navy);color:var(--white)}
.nav-phone svg{width:16px;height:16px;flex-shrink:0}
.burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;z-index:1001;
}
.burger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .3s}
.burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{display:none}

/* Mobile nav */
@media(max-width:960px){
  .mobile-menu{display:flex}
  .nav-links,.nav-phone-desktop,.nav-icons{display:none}
  .burger{display:flex}
  .nav-inner>img{margin-left:auto !important}
  .mobile-menu{
    position:fixed;inset:0;z-index:999;
    background:var(--white);
    display:flex;flex-direction:column;align-items:stretch;
    padding:calc(var(--nav-h) + 16px) 24px 32px;
    overflow-y:auto;
    transform:translateY(-100%);transition:transform .4s cubic-bezier(.16,1,.3,1);
  }
  .mobile-menu.open{transform:translateY(0)}

  /* section toggle button */
  .mob-section{border-bottom:1px solid rgba(0,58,89,.08)}
  .mob-toggle{
    display:flex;align-items:center;justify-content:space-between;
    width:100%;background:none;border:none;cursor:pointer;
    font-family:var(--serif);font-size:clamp(20px,4.5vw,28px);font-weight:600;
    color:var(--navy);padding:14px 4px;
    transition:color .2s;
  }
  .mob-toggle:hover{color:var(--blue)}
  .mob-toggle::after{
    content:'';display:inline-block;width:10px;height:10px;
    border-right:2px solid currentColor;border-bottom:2px solid currentColor;
    transform:rotate(45deg);transition:transform .3s;flex-shrink:0;
  }
  .mob-section.open .mob-toggle::after{transform:rotate(-135deg)}

  /* sub-links */
  .mob-sub{
    max-height:0;overflow:hidden;
    transition:max-height .35s cubic-bezier(.16,1,.3,1);
  }
  .mob-section.open .mob-sub{max-height:600px}
  .mob-sub a{
    display:block;padding:10px 12px 10px 20px;
    font-family:var(--sans);font-size:15px;font-weight:450;
    color:var(--text);border-radius:8px;
    transition:background .15s,color .15s;
  }
  .mob-sub a:hover{background:var(--sky);color:var(--blue)}

  /* direct link (no dropdown, e.g. Kontakt) */
  .mob-direct{
    display:block;
    font-family:var(--serif);font-size:clamp(20px,4.5vw,28px);font-weight:600;
    color:var(--navy);padding:14px 4px;
    border-bottom:1px solid rgba(0,58,89,.08);
    transition:color .2s;
  }
  .mob-direct:hover{color:var(--blue)}

  .mobile-menu .mobile-phone{
    margin-top:24px;align-self:center;
    font-family:var(--sans);font-size:16px;font-weight:600;
    color:var(--blue);display:flex;align-items:center;gap:8px;
  }
}

/* ══════════════════════════════════════
   HERO
   ══════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('/assets/img/Cockpitblick-mobile.jpg') center/cover no-repeat;
}
@media(min-width:801px){
  .hero-bg{background-image:url('/assets/img/Cockpitblick.jpg')}
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(175deg,rgba(0,58,89,.82) 0%,rgba(0,58,89,.55) 40%,rgba(26,111,160,.3) 70%,rgba(240,151,72,.1) 100%),
    linear-gradient(to top,rgba(0,58,89,.7) 0%,transparent 40%);
}
.hero-content{
  position:relative;z-index:2;text-align:center;
  padding:calc(var(--nav-h) + 40px) 24px 60px;
  max-width:900px;
}
.hero-tagline{
  display:inline-block;
  font-family:var(--serif);font-style:italic;font-size:clamp(14px,1.8vw,18px);
  color:rgba(255,255,255,.75);letter-spacing:.06em;
  margin-bottom:20px;
  padding:6px 20px;
  border:1px solid rgba(255,255,255,.15);border-radius:99px;
}
.hero h1{
  font-size:clamp(26px,4.5vw,52px);
  color:var(--white);font-weight:800;
  margin-bottom:12px;
  text-shadow:0 2px 40px rgba(0,30,50,.3);
}
.hero h2{
  font-size:clamp(18px,2.5vw,26px);
  color:rgba(255,255,255,.85);font-weight:400;
  font-family:var(--sans);
  margin-bottom:32px;
}
.hero-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:var(--white);
  font-weight:600;font-size:clamp(15px,1.2vw,17px);
  padding:16px 36px;border-radius:99px;
  transition:background .25s,transform .25s,box-shadow .25s;
  box-shadow:0 4px 24px rgba(240,151,72,.35);
}
.hero-cta:hover{
  background:var(--orange-hover);
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(240,151,72,.45);
}
.hero-cta svg{width:18px;height:18px;transition:transform .25s}
.hero-cta:hover svg{transform:translateX(3px)}

/* Decorative horizon line */
.hero-horizon{
  position:absolute;bottom:0;left:0;right:0;height:80px;z-index:3;
  background:linear-gradient(to top,var(--cream),transparent);
}

/* ══════════════════════════════════════
   SERVICE CARDS
   ══════════════════════════════════════ */
.services{
  position:relative;z-index:4;
  margin-top:clamp(32px,5vw,60px);
  padding-bottom:var(--section-pad);
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.service-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s;
  box-shadow:0 4px 32px rgba(0,58,89,.08);
}
.service-card:hover{
  transform:translateY(-6px);
  box-shadow:0 12px 48px rgba(0,58,89,.14);
}
.service-card-img{
  height:220px;overflow:hidden;
}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card-body{
  padding:28px 28px 32px;flex:1;
  display:flex;flex-direction:column;
}
.service-card h3{
  font-size:clamp(20px,1.6vw,24px);margin-bottom:10px;
}
.service-card p{font-size:15px;line-height:1.65;flex:1;margin-bottom:16px}
.service-card .card-link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:14px;
  transition:gap .25s;
}
.service-card:hover .card-link{gap:10px}
.service-card .card-link svg{width:16px;height:16px}

/* Card color variants */
.card-sky{background:var(--sky)}
.card-sky h3,.card-sky .card-link{color:var(--navy)}
.card-sky p{color:var(--text)}

.card-navy{background:var(--navy)}
.card-navy h3,.card-navy p,.card-navy .card-link{color:var(--white)}
.card-navy p{color:rgba(255,255,255,.8)}

.card-orange{background:var(--orange)}
.card-orange h3,.card-orange p,.card-orange .card-link{color:var(--white)}
.card-orange p{color:rgba(255,255,255,.88)}

@media(max-width:800px){
  .services-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .services{margin-top:24px}
}

/* ══════════════════════════════════════
   ABOUT / INTRO
   ══════════════════════════════════════ */
.about{padding:var(--section-pad) 0;background:var(--white)}
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
}
.about-text h2{
  font-size:clamp(26px,3vw,40px);
  color:var(--navy);margin-bottom:24px;
  max-width:520px;
}
.about-text h2::after{
  content:'';display:block;width:60px;height:3px;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  border-radius:3px;margin-top:16px;
}
.about-text p{
  color:var(--text-light);margin-bottom:16px;
  max-width:540px;font-size:clamp(15px,1.1vw,17px);
}
.about-text p:last-child{margin-bottom:0}
.about-image{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 8px 48px rgba(0,58,89,.1);
}
.about-image img{width:100%;height:100%;object-fit:cover}
@media(max-width:800px){
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-image{max-width:560px}
}

/* ══════════════════════════════════════
   DETAILED SERVICES (alternating)
   ══════════════════════════════════════ */
.detail-services{
  padding:var(--section-pad) 0;
  background:var(--sky);
  position:relative;
}
.detail-services::before{
  content:'';position:absolute;top:0;left:0;right:0;height:120px;
  background:linear-gradient(to bottom,var(--white),var(--sky));
}
.detail-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);
  align-items:center;
  margin-bottom:clamp(48px,8vw,96px);
  position:relative;
}
.detail-block:last-child{margin-bottom:0}
.detail-block.reversed{direction:rtl}
.detail-block.reversed>*{direction:ltr}
.detail-img{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:16/11;
  box-shadow:0 8px 40px rgba(0,58,89,.1);
}
.detail-img img{width:100%;height:100%;object-fit:cover}
.detail-text h3{
  font-size:clamp(24px,2.5vw,36px);
  color:var(--navy);margin-bottom:16px;
}
.detail-text p{
  color:var(--text-light);margin-bottom:20px;
  max-width:500px;
}
.detail-links{display:flex;flex-direction:column;gap:8px}
.detail-links a{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;font-size:15px;color:var(--blue);
  transition:color .2s,gap .2s;
}
.detail-links a:hover{color:var(--orange);gap:12px}
.detail-links a svg{width:16px;height:16px;flex-shrink:0}
.detail-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--navy);color:var(--white);
  padding:12px 28px;border-radius:99px;
  font-weight:600;font-size:15px;
  transition:background .25s,transform .25s;
  margin-top:4px;
}
.detail-btn:hover{background:var(--blue);transform:translateY(-2px)}
@media(max-width:800px){
  .detail-block,.detail-block.reversed{grid-template-columns:1fr;direction:ltr}
  .detail-block.reversed>*{direction:ltr}
  .detail-img{max-width:560px}
}

/* ══════════════════════════════════════
   DESTINATIONS
   ══════════════════════════════════════ */
.destinations{
  padding:var(--section-pad) 0;
  background:var(--white);
}
.section-header{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.section-header h2{
  font-size:clamp(28px,3.2vw,44px);color:var(--navy);
  margin-bottom:8px;
}
.section-header p{color:var(--text-light);font-size:clamp(15px,1.2vw,18px)}
.dest-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.dest-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/3;cursor:pointer;
  box-shadow:0 4px 24px rgba(0,58,89,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s;
}
.dest-card:hover{
  transform:translateY(-6px);
  box-shadow:0 12px 48px rgba(0,58,89,.15);
}
.dest-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s;
}
.dest-card:hover img{transform:scale(1.07)}
.dest-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,58,89,.7) 0%,transparent 60%);
  display:flex;align-items:flex-end;padding:24px;
}
.dest-card h4{
  color:var(--white);font-size:clamp(18px,1.6vw,24px);
  text-shadow:0 2px 12px rgba(0,0,0,.2);
}
@media(max-width:700px){
  .dest-grid{grid-template-columns:1fr 1fr;gap:16px}
}
@media(max-width:480px){
  .dest-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════
   CONTACT / CTA
   ══════════════════════════════════════ */
.contact{
  padding:var(--section-pad) 0;
  background:linear-gradient(170deg,var(--sky) 0%,var(--sky-deep) 100%);
  position:relative;
  scroll-margin-top:calc(var(--nav-h) + 20px);
}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px);
  align-items:start;
}
.contact-info h2{
  font-size:clamp(28px,3.2vw,44px);color:var(--navy);
  margin-bottom:20px;
}
.contact-info h2::after{
  content:'';display:block;width:60px;height:3px;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  border-radius:3px;margin-top:16px;
}
.contact-info p{color:var(--text-light);margin-bottom:12px}
.contact-detail{
  display:flex;align-items:center;gap:14px;
  margin-bottom:16px;
}
.contact-detail .icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--white);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,58,89,.06);
  flex-shrink:0;
}
.contact-detail .icon svg{width:22px;height:22px;color:var(--blue)}
.contact-detail a{
  font-weight:600;font-size:clamp(16px,1.3vw,20px);
  color:var(--navy);transition:color .2s;
}
.contact-detail a:hover{color:var(--blue)}
.contact-detail span{font-size:13px;color:var(--text-light)}
.contact-cta-text{
  margin-top:20px;
  font-weight:600;font-size:clamp(15px,1.1vw,17px);
  color:var(--navy);
}
.contact-map{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 8px 40px rgba(0,58,89,.1);
}
.contact-map iframe{width:100%;height:100%;border:none}
@media(max-width:800px){
  .contact-grid{grid-template-columns:1fr}
  .contact-map{max-width:560px;aspect-ratio:16/10}
}

/* ══════════════════════════════════════
   TIMELINE / HISTORY
   ══════════════════════════════════════ */
.history{
  padding:var(--section-pad) 0;
  background:var(--white);
  overflow:hidden;
}
.timeline{
  position:relative;
  max-width:800px;margin:0 auto;
  padding-left:48px;
}
.timeline::before{
  content:'';position:absolute;left:18px;top:0;bottom:0;
  width:2px;
  background:linear-gradient(to bottom,var(--sky-deep),var(--blue),var(--sky-deep));
  border-radius:2px;
}
.tl-item{
  position:relative;
  margin-bottom:clamp(28px,4vw,44px);
  padding-left:24px;
}
.tl-item:last-child{margin-bottom:0}
.tl-dot{
  position:absolute;left:-37px;top:6px;
  width:14px;height:14px;border-radius:50%;
  background:var(--white);
  border:3px solid var(--blue);
  transition:background .3s,border-color .3s;
  z-index:1;
}
.tl-item:hover .tl-dot{background:var(--blue);border-color:var(--navy)}
.tl-year{
  font-family:var(--serif);font-weight:800;
  font-size:clamp(20px,1.8vw,26px);
  color:var(--navy);margin-bottom:4px;
}
.tl-text{
  color:var(--text-light);font-size:clamp(14px,1vw,16px);
  max-width:600px;
}
@media(max-width:600px){
  .timeline{padding-left:36px}
  .timeline::before{left:10px}
  .tl-dot{left:-33px}
}

/* ══════════════════════════════════════
   FOOTER
   ══════════════════════════════════════ */
.footer{
  background:var(--navy);color:rgba(255,255,255,.7);
  padding:clamp(48px,6vw,72px) 0 32px;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(24px,4vw,48px);
  margin-bottom:40px;
}
.footer-brand img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-brand p{font-size:14px;line-height:1.7;max-width:280px}
.footer h5{
  font-family:var(--serif);font-size:15px;font-weight:700;
  color:var(--white);margin-bottom:14px;
}
.footer ul{list-style:none}
.footer ul li{margin-bottom:8px}
.footer ul a{
  font-size:14px;transition:color .2s;
}
.footer ul a:hover{color:var(--white)}
.footer-social{display:flex;gap:12px;margin-top:4px}
.footer-social a{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s;
}
.footer-social a:hover{background:rgba(255,255,255,.15)}
.footer-social svg{width:18px;height:18px;color:rgba(255,255,255,.7)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:13px;flex-wrap:wrap;gap:12px;
}
.footer-bottom a{transition:color .2s}
.footer-bottom a:hover{color:var(--white)}
@media(max-width:700px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════
   SUB-PAGE HERO
   ══════════════════════════════════════ */
.page-hero{
  position:relative;padding:calc(var(--nav-h) + 80px) 0 80px;
  background:linear-gradient(170deg,var(--navy) 0%,var(--blue) 100%);
  overflow:hidden;min-height:340px;
}
.page-hero.has-bg{
  min-height:420px;display:flex;align-items:flex-end;
  background-size:cover;background-position:center;
}
.page-hero.has-bg::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(175deg,rgba(0,58,89,.78) 0%,rgba(0,58,89,.5) 40%,rgba(26,111,160,.35) 100%);
}
.page-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:60px;
  background:linear-gradient(to top,var(--cream),transparent);
}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{
  font-size:clamp(28px,4vw,48px);color:var(--white);margin-bottom:8px;
}
.page-hero p{color:rgba(255,255,255,.85);font-size:clamp(16px,1.5vw,20px)}
.page-hero .subtitle{
  font-size:clamp(16px,1.5vw,20px);color:rgba(255,255,255,.7);
  font-style:normal;
}
.page-hero-img{
  position:absolute;inset:0;opacity:.15;
  background-size:cover;background-position:center;
}

/* Full-width image break */
.image-break{
  width:100%;overflow:hidden;
  max-height:400px;
}
.image-break img{width:100%;height:100%;object-fit:cover}
.image-accent{
  border-radius:var(--radius-lg);overflow:hidden;
  margin:clamp(24px,4vw,48px) 0;
  box-shadow:0 8px 40px rgba(0,58,89,.1);
}
.image-accent img{width:100%;display:block}
.breadcrumb{
  display:flex;align-items:center;gap:6px;
  font-size:13px;color:rgba(255,255,255,.5);margin-bottom:16px;
  flex-wrap:wrap;
}
.breadcrumb a{color:rgba(255,255,255,.6);transition:color .2s}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb .sep{margin:0 2px}

/* ══════════════════════════════════════
   CONTENT BLOCKS (sub-pages)
   ══════════════════════════════════════ */
.content-section{padding:var(--section-pad) 0}
.content-section:nth-child(even){background:var(--white)}
.content-section:nth-child(odd){background:var(--cream)}
.content-narrow{max-width:800px;margin:0 auto;padding-left:20px;padding-right:20px}
.content-narrow h2{
  font-size:clamp(24px,2.5vw,36px);color:var(--navy);
  margin-bottom:20px;
}
.content-narrow h3{
  font-size:clamp(20px,2vw,28px);color:var(--navy);
  margin-bottom:16px;
}
.content-narrow p,.content-narrow ul,.content-narrow ol{
  color:var(--text-light);margin-bottom:16px;
}
.content-narrow ul,.content-narrow ol{padding-left:24px}
.content-narrow li{margin-bottom:6px}
.content-narrow a{color:var(--blue);font-weight:500;transition:color .2s}
.content-narrow a:hover{color:var(--orange)}
.content-narrow img{
  border-radius:var(--radius);margin:24px 0;
  box-shadow:0 4px 24px rgba(0,58,89,.08);
}
.content-narrow strong{color:var(--text)}

/* Split content (image + text side by side) */
.content-split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px);align-items:center;
}
.content-split.reversed{direction:rtl}
.content-split.reversed>*{direction:ltr}
.content-split-img{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:16/11;box-shadow:0 8px 40px rgba(0,58,89,.1);
}
.content-split-img img{width:100%;height:100%;object-fit:cover}
@media(max-width:800px){
  .content-split,.content-split.reversed{grid-template-columns:1fr;direction:ltr}
  .content-split.reversed>*{direction:ltr}
}

/* Image divider banner */
.image-divider{
  width:100%;height:clamp(200px,25vw,360px);
  overflow:hidden;
}
.image-divider img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}

/* Accordion */
.accordion{max-width:800px;margin:0 auto}
.accordion-item{
  border:1px solid rgba(0,58,89,.08);
  border-radius:var(--radius);margin-bottom:8px;
  overflow:hidden;background:var(--white);
  transition:box-shadow .3s;
}
.accordion-item:hover{box-shadow:0 2px 12px rgba(0,58,89,.06)}
.accordion-trigger{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:18px 24px;
  background:none;border:none;cursor:pointer;
  font-family:var(--sans);font-size:clamp(15px,1.1vw,17px);font-weight:600;
  color:var(--navy);text-align:left;gap:16px;
}
.accordion-trigger svg{
  width:20px;height:20px;flex-shrink:0;
  transition:transform .3s;color:var(--blue);
}
.accordion-item.open .accordion-trigger svg{transform:rotate(180deg)}
.accordion-content{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .3s;
}
.accordion-content-inner{
  padding:0 24px 20px;
  color:var(--text-light);font-size:15px;line-height:1.7;
}
.accordion-content-inner p{margin-bottom:12px}
.accordion-content-inner p:last-child{margin-bottom:0}
.accordion-content-inner a{color:var(--blue);font-weight:500}

/* Info cards grid (for fleet, licenses etc.) */
.info-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:24px;
}
.info-card{
  background:var(--white);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 4px 24px rgba(0,58,89,.06);
  transition:transform .3s,box-shadow .3s;
}
.info-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 32px rgba(0,58,89,.12);
}
.info-card-img{height:200px;overflow:hidden}
.info-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.info-card:hover .info-card-img img{transform:scale(1.04)}
.info-card-body{padding:24px}
.info-card-body h3{
  font-size:clamp(18px,1.4vw,22px);color:var(--navy);margin-bottom:8px;
}
.info-card-body p{color:var(--text-light);font-size:14px;margin-bottom:12px}
/* Direct children (no -body wrapper) */
.info-card>h3{font-size:clamp(18px,1.4vw,22px);color:var(--navy);margin:24px 24px 8px}
.info-card>p{color:var(--text-light);font-size:14px;margin:0 24px 24px}
.info-card .card-link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:14px;color:var(--blue);
  transition:color .2s,gap .2s;
}
.info-card:hover .card-link{gap:10px;color:var(--orange)}
.info-card .card-link svg{width:16px;height:16px}

/* CTA banner */
.cta-banner{
  padding:clamp(48px,6vw,80px) 0;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  text-align:center;
}
.cta-banner h2{color:var(--white);font-size:clamp(24px,3vw,40px);margin-bottom:12px}
.cta-banner p{color:rgba(255,255,255,.75);margin-bottom:24px;font-size:clamp(15px,1.2vw,18px)}
.cta-banner .btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:var(--white);
  padding:14px 32px;border-radius:99px;
  font-weight:600;font-size:16px;
  transition:background .25s,transform .25s;
  box-shadow:0 4px 20px rgba(240,151,72,.3);
}
.cta-banner .btn:hover{background:var(--orange-hover);transform:translateY(-2px)}

/* Spec table */
.spec-table{
  width:100%;border-collapse:collapse;margin:24px 0;
  font-size:15px;
}
.spec-table th,.spec-table td{
  padding:12px 16px;text-align:left;
  border-bottom:1px solid rgba(0,58,89,.08);
}
.spec-table th{
  font-weight:600;color:var(--navy);background:var(--sky);
  font-size:14px;text-transform:uppercase;letter-spacing:.03em;
}
.spec-table td{color:var(--text-light)}
.spec-table tr:hover td{background:rgba(232,244,253,.4)}

/* Magazine article cards */
.article-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;
}
.article-card{
  background:var(--white);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 4px 24px rgba(0,58,89,.06);
  transition:transform .3s,box-shadow .3s;
  display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,58,89,.12)}
.article-card-img{height:200px;overflow:hidden}
.article-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.article-card:hover .article-card-img img{transform:scale(1.04)}
.article-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.article-card-body h3{font-size:18px;color:var(--navy);margin-bottom:8px}
.article-card-body p{color:var(--text-light);font-size:14px;flex:1;margin-bottom:12px}
/* Direct children (no -body wrapper) */
.article-card>h3{font-size:18px;color:var(--navy);margin:24px 24px 8px}
.article-card>p{color:var(--text-light);font-size:14px;flex:1;margin:0 24px 24px}

/* Contact form styling */
.form-group{margin-bottom:20px}
.form-group label{
  display:block;font-weight:600;font-size:14px;
  color:var(--navy);margin-bottom:6px;
}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:12px 16px;
  border:1px solid rgba(0,58,89,.12);border-radius:var(--radius);
  font-family:var(--sans);font-size:15px;color:var(--text);
  background:var(--white);
  transition:border-color .2s,box-shadow .2s;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  outline:none;border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(26,111,160,.1);
}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--orange);color:var(--white);
  padding:14px 32px;border-radius:99px;border:none;
  font-family:var(--sans);font-weight:600;font-size:16px;
  cursor:pointer;transition:background .25s,transform .25s;
}
.form-submit:hover{background:var(--orange-hover);transform:translateY(-2px)}

