:root{
  --ink:#15333f;--muted:#657b84;--blue:#0a6686;--blue-dark:#06384f;--aqua:#10a9c4;--sand:#fbf1de;--cream:#fffaf1;--white:#fff;--line:#d9ebef;--shadow:0 20px 55px rgba(6,56,79,.14);--radius:22px;--max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);font-size:17px;line-height:1.7;background:linear-gradient(180deg,#e9f8fb 0,#fff 520px)}a{color:var(--blue);font-weight:700;text-decoration:none}a:hover{text-decoration:underline;color:var(--aqua)}img{max-width:100%;height:auto}.skip-link{position:absolute;left:-999px;top:12px;background:#fff;padding:10px 14px;border-radius:10px;z-index:100}.skip-link:focus{left:12px}.site-header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.site-header__inner{max-width:var(--max);margin:auto;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.site-logo{display:flex;align-items:center;gap:10px;color:var(--blue-dark)}.site-logo:hover{text-decoration:none}.site-logo__mark{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--aqua));color:#fff;font-size:24px;font-weight:900}.site-logo__text{font-size:25px;font-weight:900;letter-spacing:-.05em}.site-logo__text span{color:var(--aqua)}.menu-toggle{display:none;border:0;border-radius:14px;background:var(--blue);color:#fff;padding:10px 15px;font-weight:800;cursor:pointer}.primary-nav{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.primary-nav a{padding:9px 11px;border-radius:999px;color:var(--blue-dark);font-size:15px}.primary-nav a:hover,.primary-nav a[aria-current="page"]{background:#e8f8fb;color:var(--blue);text-decoration:none}.hero{position:relative;min-height:490px;display:flex;align-items:flex-end;overflow:hidden;background:linear-gradient(130deg,#07506f,#11a7bd);isolation:isolate}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.32),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.8),rgba(4,58,80,.38)),url('images/naxos-island-greece.jpg') center/cover no-repeat;z-index:-2}.hero:after{content:"";position:absolute;inset:auto 0 0;height:140px;background:linear-gradient(transparent,rgba(0,0,0,.22));z-index:-1}.hero__content{width:100%;max-width:var(--max);margin:0 auto;padding:70px 18px}.eyebrow,.section-label{margin:0 0 10px;color:#08728f;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:13px}.hero .eyebrow{color:#d8fbff}.hero h1{max-width:850px;margin:0;color:#fff;font-size:clamp(42px,7vw,78px);line-height:.98;letter-spacing:-.065em;text-shadow:0 8px 30px rgba(0,0,0,.24)}.hero__lead{max-width:760px;margin:18px 0 0;color:#f1fdff;font-size:clamp(18px,2.1vw,24px)}.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.button{display:inline-flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:999px;font-weight:900}.button:hover{text-decoration:none;transform:translateY(-1px)}.button--primary{background:#fff;color:var(--blue-dark)}.button--light{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.45)}.page-shell{max-width:var(--max);margin:-46px auto 0;padding:0 18px 50px;display:grid;grid-template-columns:280px minmax(0,1fr);gap:26px;align-items:start;position:relative;z-index:5}.sidebar,.content-card{background:rgba(255,255,255,.98);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius)}.sidebar{padding:18px;position:sticky;top:86px}.sidebar__section+ .sidebar__section{margin-top:16px}.sidebar h2{margin:0 0 8px;color:var(--blue-dark);font-size:14px;text-transform:uppercase;letter-spacing:.1em}.sidebar ul{list-style:none;margin:0;padding:0}.sidebar a{display:block;padding:8px 10px;border-radius:12px;color:var(--ink);font-weight:700}.sidebar a:hover{background:#effafd;color:var(--blue);text-decoration:none}.content-card{padding:clamp(24px,4vw,48px)}.content-card h2{margin:0 0 15px;color:var(--blue-dark);font-size:clamp(29px,4vw,48px);line-height:1.12;letter-spacing:-.045em}.content-card h2:not(:first-of-type){margin-top:34px}.content-card p{margin:0 0 18px}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:28px 0 10px}.feature-card{min-height:150px;padding:18px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#f3fbfd);color:var(--ink);display:flex;flex-direction:column;justify-content:space-between}.feature-card:hover{text-decoration:none;border-color:#bfe8ef;transform:translateY(-2px)}.feature-card span{font-size:20px;font-weight:900;color:var(--blue-dark)}.feature-card strong{font-size:14px;line-height:1.45;color:var(--muted)}.image-panel{margin:30px 0;padding:12px;background:var(--cream);border:1px solid var(--line);border-radius:22px}.image-panel img{display:block;width:100%;border-radius:16px;box-shadow:0 16px 40px rgba(6,56,79,.12)}.image-panel figcaption{padding:10px 4px 2px;color:var(--muted);font-size:14px}.image-panel--missing{min-height:170px;background:linear-gradient(135deg,#e5f8fb,#fff7e6)}.quick-links{padding:24px;border-radius:22px;background:#f4fbfd;border:1px solid var(--line)}.quick-links h2{font-size:28px;margin-bottom:16px}.quick-links__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.quick-links__grid a{padding:11px 13px;border-radius:14px;background:#fff;border:1px solid var(--line);color:var(--blue-dark)}.quick-links__grid a:hover{background:#eaf9fc;text-decoration:none}.language-box{margin-top:30px;padding:24px;border-radius:22px;background:linear-gradient(135deg,#fff7e6,#effbfe);border:1px solid var(--line)}.language-box h2{font-size:26px;margin-bottom:8px}.language-list{display:flex;gap:8px;flex-wrap:wrap}.language-list a{padding:8px 13px;border-radius:999px;background:#fff;border:1px solid var(--line)}.site-footer{background:#07384f;color:#d7f2f8}.site-footer__inner{max-width:var(--max);margin:auto;padding:30px 18px;text-align:center}.site-footer a{color:#fff}@media(max-width:980px){.feature-grid{grid-template-columns:repeat(2,1fr)}.page-shell{grid-template-columns:1fr}.sidebar{position:static;order:2}.content-card{order:1}.hero{min-height:420px}}@media(max-width:760px){body{font-size:16px}.site-header__inner{flex-wrap:wrap}.menu-toggle{display:inline-flex}.primary-nav{display:none;width:100%;justify-content:flex-start;padding-top:8px}.primary-nav.is-open{display:flex}.hero__content{padding:52px 18px 86px}.page-shell{margin-top:-38px}.feature-grid,.quick-links__grid{grid-template-columns:1fr}.content-card{padding:22px}.sidebar{padding:16px}}@media(prefers-reduced-motion:no-preference){.button,.feature-card{transition:.18s ease}}


/* AdSense placements */
.ad-container{
  max-width:1200px;
  margin:34px auto;
  padding:10px 18px;
  text-align:center;
}
.ad-container--middle{
  margin:36px 0;
  padding-left:0;
  padding-right:0;
}
.ad-label{
  display:block;
  margin-bottom:8px;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#7a8794;
}
.adsbygoogle{
  min-height:90px;
}
.faq-section{
  margin-top:34px;
  padding:24px;
  border-radius:22px;
  background:#f7fafc;
  border:1px solid rgba(16,24,40,.08);
}
.faq-section details{
  border-top:1px solid rgba(16,24,40,.08);
  padding:14px 0;
}
.faq-section details:first-of-type{
  border-top:0;
}
.faq-section summary{
  cursor:pointer;
  font-weight:800;
  color:#123047;
}
.faq-section p{
  margin:10px 0 0;
}
@media (max-width:700px){
  .ad-container{margin:24px auto; padding:8px 12px;}
  .faq-section{padding:18px;}
}


/* Full SEO homepage additions */
.hero--large{min-height:560px;}
.attractions-band{background:linear-gradient(180deg,#ffffff 0,#f0fbfd 100%);padding:44px 18px 30px;}
.attractions-band__inner{max-width:1180px;margin:auto;}
.attractions-band h2{margin:0 0 20px;color:#06384f;font-size:clamp(30px,4vw,46px);line-height:1.08;letter-spacing:-.045em;}
.attraction-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.attraction-card{display:block;padding:20px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:0 12px 30px rgba(6,56,79,.08);color:var(--ink);min-height:145px;}
.attraction-card:hover{text-decoration:none;transform:translateY(-2px);border-color:#bfe8ef;}
.attraction-card span{display:block;color:var(--blue-dark);font-size:22px;font-weight:900;margin-bottom:8px;}
.attraction-card strong{display:block;color:var(--muted);font-size:15px;line-height:1.45;}
.sidebar__section--highlight{background:linear-gradient(135deg,#e9f8fb,#fff7e6);padding:14px;border-radius:18px;border:1px solid var(--line);}
.feature-grid--guides{grid-template-columns:repeat(3,1fr);}
.feature-card--large{min-height:190px;}
.feature-card--large span{font-size:23px;line-height:1.15;}
.content-card h2{scroll-margin-top:90px;}
@media(max-width:980px){.attraction-grid,.feature-grid--guides{grid-template-columns:repeat(2,1fr)}.hero--large{min-height:500px}}
@media(max-width:700px){.attraction-grid,.feature-grid--guides{grid-template-columns:1fr}.attractions-band{padding:30px 14px 20px}.hero--large{min-height:470px}}

/* Homepage photo upgrade */
.home-page .hero:before{
  background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.32),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.78),rgba(4,58,80,.34)),url('naxos-25.jpg') center/cover no-repeat;
}
.beaches-page .hero:before{
  background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.25),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.76),rgba(4,58,80,.28)),url('plaka_beach.jpg') center/cover no-repeat;
}
.attraction-card--image,
.feature-card--photo{
  position:relative;
  overflow:hidden;
  min-height:230px;
  color:#fff;
  border:0;
  background:#08384f;
  justify-content:flex-end;
}
.attraction-card--image::before,
.feature-card--photo::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(5,33,47,.72)),var(--card-image) center/cover no-repeat;
  transition:transform .25s ease;
}
.attraction-card--image:hover::before,
.feature-card--photo:hover::before{transform:scale(1.045)}
.attraction-card--image span,
.attraction-card--image strong,
.feature-card--photo span,
.feature-card--photo strong{
  position:relative;
  z-index:1;
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.45);
}
.attraction-card--image strong,
.feature-card--photo strong{color:#effbff}
.photo-gallery{
  margin:34px 0;
  padding:26px;
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg,#fff,#f5fcfd);
}
.photo-gallery h2{margin-top:0!important}
.photo-gallery__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:18px;
}
.photo-gallery figure{
  margin:0;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 12px 28px rgba(6,56,79,.08);
}
.photo-gallery img{
  display:block;
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}
.photo-gallery figcaption{
  padding:8px 10px;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
@media(max-width:980px){.photo-gallery__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.photo-gallery{padding:16px}.photo-gallery__grid{grid-template-columns:1fr}.attraction-card--image,.feature-card--photo{min-height:210px}}


/* Page-specific hero images and safe image cards */
.home-page .hero:before{
  background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.32),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.78),rgba(4,58,80,.34)),url('naxos-25.jpg') center/cover no-repeat!important;
}
.beaches-page .hero:before{
  background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.25),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.76),rgba(4,58,80,.28)),url('plaka_beach.jpg') center/cover no-repeat!important;
}
.beaches-page .content-card img,
.home-page .content-card img{
  max-width:100%;
  height:auto;
}
.beaches-page .beach-photo,
.beaches-page .image-panel{
  margin:26px 0;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 14px 34px rgba(6,56,79,.10);
}
.beaches-page .beach-photo img,
.beaches-page .image-panel img{
  display:block;
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
}
.beaches-page .beach-photo figcaption,
.beaches-page .image-panel figcaption{
  padding:10px 14px;
  color:var(--muted);
  font-size:14px;
  font-weight:700;
}


/* Final homepage fix: prevent the main content from overlapping the last attraction cards */
.home-page .page-shell{
  margin-top:0;
}

/* Keep enough space after the attraction cards before the main content starts */
.home-page .attractions-band{
  padding-bottom:54px;
}

/* Stable homepage attraction grid */
.home-page .attraction-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}

.home-page .attraction-card--image{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  min-width:0;
  min-height:260px;
  height:auto;
  padding:20px;
  isolation:isolate;
}

.home-page .attraction-card--image::before{
  z-index:0;
}

.home-page .attraction-card--image span,
.home-page .attraction-card--image strong{
  position:relative;
  z-index:1;
}

@media(max-width:980px){
  .home-page .attraction-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:700px){
  .home-page .page-shell{
    margin-top:0;
  }

  .home-page .attraction-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .home-page .attraction-card--image{
    min-height:230px;
  }
}


/* Maps page */
.maps-page .hero:before,
.maps-page .hero--maps:before{
  background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.26),transparent 24%),linear-gradient(120deg,rgba(4,58,80,.78),rgba(4,58,80,.30)),url('naxos_sat.jpg') center/cover no-repeat!important;
}
.quick-map-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:26px 0 12px;
}
.quick-map-links a{
  display:inline-flex;
  padding:9px 13px;
  border-radius:999px;
  background:#eef8fb;
  border:1px solid #d5eef5;
  color:var(--blue-dark);
  font-weight:800;
}
.quick-map-links a:hover{
  background:#fff7e6;
  text-decoration:none;
}
.map-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
  margin:28px 0 34px;
}
.map-card{
  min-width:0;
  border:1px solid var(--line);
  border-radius:22px;
  background:#fff;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(6,56,79,.10);
}
.map-card a{
  display:block;
  color:inherit;
  height:100%;
}
.map-card a:hover{
  text-decoration:none;
}
.map-card figure{
  display:flex;
  flex-direction:column;
  height:100%;
  margin:0;
}
.map-card__image{
  display:grid;
  place-items:center;
  min-height:300px;
  padding:16px;
  background:linear-gradient(180deg,#f4fbfd,#eef4f7);
}
.map-card__image img{
  display:block;
  width:auto;
  max-width:100%;
  max-height:275px;
  object-fit:contain;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(6,56,79,.10);
}
.map-card figcaption{
  display:block;
  position:static;
  padding:18px 18px 20px;
  background:#fff;
  color:var(--muted);
}
.map-card figcaption strong{
  display:block;
  margin-bottom:6px;
  color:var(--blue-dark);
  font-size:21px;
  line-height:1.2;
}
.map-card figcaption span{
  display:block;
  color:var(--muted);
  font-size:15px;
  line-height:1.55;
  font-weight:600;
}
.map-tips{
  margin-top:34px;
  padding:24px;
  border-radius:22px;
  background:linear-gradient(135deg,#eef8fb,#fff7e6);
  border:1px solid var(--line);
}
.map-tips h2{
  font-size:clamp(26px,3vw,38px);
}
.map-tips__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:18px;
}
.map-tips__grid div{
  padding:18px;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
}
.map-tips__grid strong,
.map-tips__grid span{
  display:block;
}
.map-tips__grid strong{
  color:var(--blue-dark);
  font-size:18px;
  margin-bottom:6px;
}
.map-tips__grid span{
  color:var(--muted);
  font-size:15px;
  font-weight:600;
  line-height:1.55;
}
.footer-links{
  margin-top:34px;
  padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.footer-links a{
  padding:9px 13px;
  border-radius:999px;
  background:#f4fbfd;
  border:1px solid var(--line);
  color:var(--blue-dark);
}
.footer-links a:hover{
  background:#fff7e6;
  text-decoration:none;
}
@media(max-width:900px){
  .map-grid,.map-tips__grid{grid-template-columns:1fr;}
  .map-card__image{min-height:220px;}
}
.booking-widget{
  margin:40px 0;
  padding:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 10px 28px rgba(0,0,0,.08);
}

.iframe-wrapper{
  overflow:hidden;
  border-radius:16px;
}

.iframe-wrapper iframe{
  display:block;
  width:100%;
  min-height:465px;
  border:0;
}
.ticket-widgets{
  margin:40px 0;
}

.ticket-widget-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
  align-items:start;
}

.ticket-widget{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 10px 28px rgba(0,0,0,.08);
  text-align:center;
  overflow:hidden;
}

.ticket-widget iframe{
  max-width:100%;
  border:0;
}

.ticket-widget img{
  width:1px;
  height:1px;
  opacity:0;
}

@media(max-width:900px){
  .ticket-widget-grid{
    grid-template-columns:1fr;
  }
}