/* ============================================================
   Georgioupolis 2026 — design system "Quiet Aegean Luxury"
   Mobile-first · WCAG 2.2 AA · no jQuery, no builder CSS
   ============================================================ */

:root {
  --navy: #14233C;
  --gold: #B08D4A;
  --sand: #F6F1E9;
  --white: #FFFFFF;
  --ink: #1C1C1C;
  --cta: #C0392B;
  --cta-dark: #A93226;
  --font-display: 'Noto Serif Display', Georgia, 'Times New Roman', serif;
  --font-body: Inter, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --container: 1200px;
  --wide: 1440px;
  --radius: 6px;
  --shadow: 0 10px 30px rgba(20, 35, 60, .12);
  --header-h: 76px;
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 12px); }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
body { margin: 0; font-family: var(--font-body); font-size: 1rem; line-height: 1.6; color: var(--ink); background: var(--white); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.2; color: var(--navy); margin: 0 0 .5em; }
h1 { font-size: clamp(1.9rem, 4.5vw, 3.05rem); }
h2 { font-size: clamp(1.55rem, 3.4vw, 2.44rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.56rem); }
p { margin: 0 0 1em; }
a { color: var(--gold); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--navy); }
:focus-visible { outline: 3px solid var(--gold); outline-offset: 2px; border-radius: 2px; }

.container { max-width: var(--container); margin-inline: auto; padding-inline: 20px; }
.section { padding-block: 40px; }
@media (min-width: 768px) { .section { padding-block: 64px; } }

.skip-link { position: absolute; left: -9999px; top: 0; background: var(--navy); color: #fff; padding: 10px 18px; z-index: 200; }
.skip-link:focus { left: 12px; top: 12px; }

/* Gold rule under section headings (replaces old red underline) */
.gr-rule, .wp-block-heading.has-rule { position: relative; padding-bottom: 14px; }
.gr-rule::after, .wp-block-heading.has-rule::after { content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); width: 64px; height: 2px; background: var(--gold); }
.has-text-align-left.has-rule::after { left: 0; transform: none; }

/* ---------- Buttons ---------- */
.btn, .wp-block-button__link { display: inline-block; font-family: var(--font-body); font-weight: 600; font-size: .9375rem; letter-spacing: .06em; text-transform: uppercase; text-decoration: none; padding: 13px 28px; border-radius: var(--radius); border: 2px solid transparent; cursor: pointer; transition: background .2s, color .2s, border-color .2s; }
.btn--cta, .is-style-cta .wp-block-button__link { background: var(--cta); color: #fff; }
.btn--cta:hover, .is-style-cta .wp-block-button__link:hover { background: var(--cta-dark); color: #fff; }
.btn--gold { background: var(--gold); color: #fff; }
.btn--gold:hover { background: #97793D; color: #fff; }
.btn--ghost, .is-style-ghost .wp-block-button__link { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn--ghost:hover { background: var(--navy); color: #fff; }

/* ---------- Header ---------- */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 100; background: rgba(255,255,255,.97); border-bottom: 1px solid rgba(20,35,60,.08); transition: box-shadow .25s; }
.site-header.is-scrolled { box-shadow: 0 4px 18px rgba(20,35,60,.10); }
.header-inner { display: flex; align-items: center; gap: 18px; min-height: var(--header-h); max-width: var(--wide); margin-inline: auto; padding-inline: 20px; }
.brand { margin-right: auto; display: flex; align-items: center; text-decoration: none; }
.brand img { max-height: 56px; width: auto; }
.brand-text { font-family: var(--font-display); font-size: 1.25rem; color: var(--navy); letter-spacing: .12em; text-transform: uppercase; }
body { padding-top: var(--header-h); }

/* Primary nav (desktop) */
.main-nav ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 4px; }
.main-nav li { position: relative; }
.main-nav a { display: block; padding: 26px 13px; font-size: .875rem; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--navy); text-decoration: none; }
.main-nav a:hover, .main-nav .current-menu-item > a, .main-nav .current-menu-ancestor > a { color: var(--gold); }
.main-nav .sub-menu { position: absolute; top: 100%; left: 0; min-width: 280px; background: #fff; box-shadow: var(--shadow); border-top: 2px solid var(--gold); border-radius: 0 0 var(--radius) var(--radius); display: none; flex-direction: column; gap: 0; padding: 8px 0; z-index: 50; max-height: calc(100vh - var(--header-h) - 20px); overflow: auto; }
.main-nav li:hover > .sub-menu, .main-nav li:focus-within > .sub-menu { display: flex; }
.main-nav .sub-menu a { padding: 10px 20px; text-transform: none; letter-spacing: 0; font-weight: 500; }
.submenu-toggle { display: none; }

/* Header actions */
.header-actions { display: flex; align-items: center; gap: 14px; }
.lang-switcher select, .lang-switcher { font-size: .875rem; }
.lang-switcher ul { list-style: none; display: flex; gap: 8px; margin: 0; padding: 0; }
.book-btn { white-space: nowrap; }

/* Burger */
.nav-toggle { display: none; background: none; border: 0; width: 44px; height: 44px; padding: 8px; cursor: pointer; }
.nav-toggle span { display: block; height: 2px; background: var(--navy); margin: 6px 0; transition: transform .2s, opacity .2s; }

@media (max-width: 1023px) {
  .nav-toggle { display: block; }
  .main-nav { position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0; background: #fff; overflow-y: auto; padding: 12px 20px 120px; display: none; }
  body.nav-open .main-nav { display: block; }
  body.nav-open { overflow: hidden; }
  body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
  body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
  body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
  .main-nav ul { flex-direction: column; gap: 0; }
  .main-nav a { padding: 14px 4px; border-bottom: 1px solid rgba(20,35,60,.08); }
  .main-nav .sub-menu { position: static; display: none; box-shadow: none; border: 0; padding-left: 16px; max-height: none; }
  .main-nav li.is-open > .sub-menu { display: flex; }
  .submenu-toggle { display: inline-flex; align-items: center; justify-content: center; position: absolute; right: 0; top: 4px; width: 44px; height: 44px; background: none; border: 0; cursor: pointer; }
  .submenu-toggle::after { content: ""; width: 9px; height: 9px; border-right: 2px solid var(--navy); border-bottom: 2px solid var(--navy); transform: rotate(45deg); transition: transform .2s; }
  li.is-open > .submenu-toggle::after { transform: rotate(-135deg); }
  .header-actions .book-btn { display: none; } /* mobile uses sticky bar */
}

/* Sticky mobile booking bar */
.mobile-book-bar { display: none; }
@media (max-width: 1023px) {
  .mobile-book-bar { display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 90; padding: 10px 16px calc(10px + env(safe-area-inset-bottom)); background: rgba(255,255,255,.96); border-top: 1px solid rgba(20,35,60,.1); }
  .mobile-book-bar .btn { width: 100%; text-align: center; }
}

/* ---------- Hero ---------- */
.gr-hero, .wp-block-cover.gr-hero { min-height: 64vh; display: flex; align-items: center; justify-content: center; text-align: center; color: #fff; }
.gr-hero h1, .gr-hero h2 { color: #fff; text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.gr-hero p { font-size: 1.125rem; text-shadow: 0 1px 10px rgba(0,0,0,.4); }
.gr-hero--page { min-height: 38vh; }

/* ---------- Cards ---------- */
.card-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 640px)  { .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .card-grid { grid-template-columns: repeat(3, 1fr); } }
.gr-card { background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: 0 4px 16px rgba(20,35,60,.08); display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s; }
.gr-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.gr-card img { aspect-ratio: 3 / 2; object-fit: cover; width: 100%; }
.gr-card__body { padding: 20px 22px 24px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.gr-card__body h3 { margin: 0; font-size: 1.25rem; }
.gr-card__meta { font-size: .8125rem; letter-spacing: .04em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.gr-card__body .btn { margin-top: auto; align-self: flex-start; }

/* Facts strip (room pages) */
.facts-strip { display: flex; flex-wrap: wrap; gap: 12px 32px; padding: 18px 24px; background: var(--sand); border-radius: var(--radius); margin-block: 20px; }
.facts-strip strong { color: var(--navy); }

/* Pricing cards (waterpark) */
.price-card { background: var(--sand); border-radius: var(--radius); padding: 28px; text-align: center; }
.price-card .price { font-family: var(--font-display); font-size: 2.2rem; color: var(--navy); }

/* PDF / catalogue list */
.pdf-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
@media (min-width: 640px) { .pdf-list { grid-template-columns: repeat(2, 1fr); } }
.pdf-list a { display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: #fff; border: 1px solid rgba(20,35,60,.12); border-radius: var(--radius); text-decoration: none; font-weight: 600; color: var(--navy); }
.pdf-list a::before { content: "PDF"; flex: 0 0 auto; font-size: .6875rem; font-weight: 700; letter-spacing: .05em; color: #fff; background: var(--cta); border-radius: 4px; padding: 4px 7px; }
.pdf-list a:hover { border-color: var(--gold); color: var(--gold); }

/* Hours chip */
.hours-chip { display: inline-block; background: var(--navy); color: #fff; font-size: .8125rem; font-weight: 600; border-radius: 999px; padding: 5px 14px; margin: 4px 6px 4px 0; }

/* ---------- FAQ / accordions ---------- */
details.gr-acc { border: 1px solid rgba(20,35,60,.12); border-radius: var(--radius); margin-bottom: 10px; background: #fff; }
details.gr-acc summary { cursor: pointer; list-style: none; padding: 16px 48px 16px 20px; font-weight: 600; color: var(--navy); position: relative; }
details.gr-acc summary::-webkit-details-marker { display: none; }
details.gr-acc summary::after { content: ""; position: absolute; right: 20px; top: 50%; width: 10px; height: 10px; margin-top: -8px; border-right: 2px solid var(--gold); border-bottom: 2px solid var(--gold); transform: rotate(45deg); transition: transform .2s; }
details.gr-acc[open] summary::after { transform: rotate(-135deg); margin-top: -2px; }
details.gr-acc > *:not(summary) { padding: 0 20px 16px; }

/* ---------- Gallery ---------- */
.gr-gallery { display: grid; gap: 10px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .gr-gallery { grid-template-columns: repeat(3, 1fr); } }
.gr-gallery img { aspect-ratio: 3 / 2; object-fit: cover; border-radius: 4px; cursor: zoom-in; }

/* Lightbox */
.gr-lightbox { position: fixed; inset: 0; z-index: 150; background: rgba(10, 16, 28, .92); display: flex; align-items: center; justify-content: center; padding: 4vh 4vw; }
.gr-lightbox img { max-width: 100%; max-height: 100%; width: auto; border-radius: 4px; }
.gr-lightbox button { position: absolute; top: 16px; right: 16px; width: 44px; height: 44px; font-size: 26px; line-height: 1; color: #fff; background: transparent; border: 2px solid rgba(255,255,255,.6); border-radius: 50%; cursor: pointer; }

/* ---------- Booking modal ---------- */
.booking-modal[hidden] { display: none; }
.booking-modal { position: fixed; inset: 0; z-index: 160; display: flex; align-items: center; justify-content: center; padding: 16px; }
.booking-modal__backdrop { position: absolute; inset: 0; background: rgba(10,16,28,.8); }
.booking-modal__panel { position: relative; width: min(920px, 100%); background: #fff; border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.booking-modal__panel iframe { display: block; width: 100%; height: min(560px, 80vh); border: 0; }
.booking-modal__close { position: absolute; top: 8px; right: 8px; z-index: 2; width: 40px; height: 40px; font-size: 22px; line-height: 1; background: var(--navy); color: #fff; border: 0; border-radius: 50%; cursor: pointer; }
.booking-modal__close:hover { background: var(--cta); }

/* ---------- Footer ---------- */
.site-footer { background: var(--navy); color: rgba(255,255,255,.85); margin-top: 64px; font-size: .9375rem; }
.site-footer a { color: #fff; }
.site-footer a:hover { color: var(--gold); }
.footer-info { border-bottom: 1px solid rgba(255,255,255,.15); }
.footer-info details { border: 0; border-bottom: 1px solid rgba(255,255,255,.12); }
.footer-info summary { cursor: pointer; padding: 16px 0; font-weight: 600; color: #fff; letter-spacing: .04em; text-transform: uppercase; font-size: .8125rem; list-style: none; }
.footer-info summary::-webkit-details-marker { display: none; }
.footer-info details > div { padding: 0 0 18px; columns: 1; }
@media (min-width: 768px) { .footer-info details > div { columns: 2; column-gap: 48px; } }
.footer-cols { display: grid; gap: 32px; padding-block: 40px; grid-template-columns: 1fr; }
@media (min-width: 768px) { .footer-cols { grid-template-columns: 2fr 1fr 1.5fr 1fr; } }
.footer-cols h4 { color: #fff; font-family: var(--font-body); font-size: .8125rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 14px; }
.footer-cols ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.footer-logo img { max-height: 64px; width: auto; }
.social-links { display: flex; gap: 14px; margin-top: 14px; }
.social-links a { display: inline-flex; width: 40px; height: 40px; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; text-decoration: none; font-size: .8125rem; font-weight: 700; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.15); padding-block: 18px; font-size: .8125rem; display: flex; flex-wrap: wrap; gap: 8px 24px; justify-content: space-between; }

/* ---------- WP block tweaks ---------- */
.wp-block-cover { margin: 0; }
.alignfull { width: 100%; max-width: none; }
.alignwide { max-width: var(--wide); margin-inline: auto; }
.entry-content > *:not(.alignfull):not(.alignwide),
.page-content > .wp-block-group:not(.alignfull):not(.alignwide) { max-width: var(--container); margin-inline: auto; padding-inline: 20px; }
/* Full-width bands (e.g. sand sections): constrain their direct children instead */
.wp-block-group.alignfull.section > * { max-width: var(--container); margin-inline: auto; }
.wp-block-group.alignfull.section { padding-inline: 20px; }
.has-sand-background-color { background-color: var(--sand); }
.has-navy-background-color { background-color: var(--navy); }
.has-navy-background-color h2, .has-navy-background-color h3, .has-navy-background-color p { color: #fff; }

/* Forms (CF7) */
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"],
.wpcf7 input[type="date"], .wpcf7 select, .wpcf7 textarea {
  width: 100%; padding: 12px 14px; border: 1px solid rgba(20,35,60,.25); border-radius: var(--radius);
  font: inherit; background: #fff;
}
.wpcf7 input:focus, .wpcf7 select:focus, .wpcf7 textarea:focus { border-color: var(--gold); outline: 2px solid var(--gold); outline-offset: 0; }
.wpcf7 label { font-weight: 600; color: var(--navy); display: block; margin-bottom: 14px; }
.wpcf7 .wpcf7-submit { composes: none; }
.wpcf7 input[type="submit"] { background: var(--cta); color: #fff; border: 0; border-radius: var(--radius); padding: 13px 32px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; cursor: pointer; }
.wpcf7 input[type="submit"]:hover { background: var(--cta-dark); }

/* ---------- Video hero (homepage, muted YouTube background) ---------- */
.gr-video-hero { position: relative; overflow: hidden; min-height: 64vh; background: var(--navy); }
.gr-video-hero iframe { position: absolute; top: 50%; left: 50%; width: 177.78vh; min-width: 100%; height: 56.25vw; min-height: 100%; transform: translate(-50%, -50%); border: 0; pointer-events: none; }
.gr-video-hero__overlay { position: absolute; inset: 0; background: rgba(10,16,28,.35); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 20px; }
.gr-video-hero__overlay h1 { color: #fff; text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.gr-video-hero__overlay p { color: #fff; font-size: 1.125rem; text-shadow: 0 1px 10px rgba(0,0,0,.4); }
/* ---------- Awards grid (homepage) ---------- */
.awards-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; align-items: center; justify-items: center; max-width: 1100px; margin-inline: auto; }
@media (min-width: 640px)  { .awards-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .awards-grid { grid-template-columns: repeat(4, 1fr); } }
.awards-grid img { max-height: 220px; width: auto; height: auto; object-fit: contain; filter: drop-shadow(0 4px 14px rgba(20,35,60,.12)); transition: transform .2s; }
.awards-grid img:hover { transform: translateY(-4px); }

/* Awards grid — uniform equal tiles, aligned, responsive (override) */
.awards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:1120px;margin-inline:auto;align-items:stretch;justify-items:stretch;}
@media(min-width:560px){.awards-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.awards-grid{grid-template-columns:repeat(5,1fr);}}
.awards-grid img{width:100%;max-height:none;height:190px;object-fit:contain;background:#fff;border-radius:8px;padding:10px;box-shadow:0 4px 14px rgba(20,35,60,.10);transition:transform .2s;}
.awards-grid img:hover{transform:translateY(-4px);}

/* ---------- Video (centered, contained) ---------- */
.gr-video{position:relative;max-width:960px;margin-inline:auto;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#14233C;}
.gr-video .yt-facade{position:absolute;inset:0;width:100%;height:100%;border:0;cursor:pointer;background-size:cover;background-position:center;}
.gr-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.gr-video__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:64px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4);}
/* ---------- All Inclusive vs Platinum columns ---------- */
.ai-cols{display:grid;grid-template-columns:1fr;gap:24px;max-width:920px;margin-inline:auto;}
@media(min-width:768px){.ai-cols{grid-template-columns:1fr 1fr;}}
.ai-col{border-radius:12px;padding:26px 22px;text-align:center;border:1px solid rgba(20,35,60,.1);}
.ai-col--std{background:#fff;}
.ai-col--plat{background:#14233C;}
.ai-col h3{margin:0 0 6px;}
.ai-col--plat h3{color:#fff;}
.ai-col .ai-desc{font-size:.9rem;line-height:1.5;margin:0 0 18px;min-height:66px;}
.ai-col--plat .ai-desc{color:rgba(255,255,255,.85);}
.ai-col a{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border-radius:6px;margin:10px 0;font-weight:600;font-size:.9375rem;text-decoration:none;color:#fff;transition:background .2s,transform .2s;}
.ai-col--std a{background:var(--gold);}
.ai-col--std a:hover{background:#97793D;transform:translateY(-2px);}
.ai-col--plat a{background:#2a3c5c;}
.ai-col--plat a:hover{background:#3a4f74;transform:translateY(-2px);}
.ai-col a::before{content:"PDF";font-size:.62rem;font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.22);padding:3px 6px;border-radius:3px;}

.ai-img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:6px;margin:0 0 14px;}

/* === Header logo fix + logo left of menu (2026-06-13) === */
.brand{margin-right:24px;flex-shrink:0;}
.brand img{height:52px;width:auto;max-width:none;display:block;}
.header-actions{margin-left:auto;}

/* === Flag-based language switcher (EN/EL/DE) === */
ul.lang-switcher{list-style:none;display:flex;align-items:center;gap:12px;margin:0;padding:0;}
ul.lang-switcher .gr-lang a{display:inline-flex;align-items:center;gap:5px;text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--navy);text-transform:uppercase;opacity:.65;transition:opacity .15s,color .15s;}
ul.lang-switcher .gr-lang.is-active a,ul.lang-switcher .gr-lang a:hover{opacity:1;color:var(--gold);}
ul.lang-switcher .gr-lang img{display:block;width:20px;height:13px;border-radius:2px;box-shadow:0 0 0 1px rgba(20,35,60,.12);}
@media (max-width:1023px){ul.lang-switcher{gap:8px;}ul.lang-switcher .gr-lang span{display:none;}}

/* gr-mobile-submenu-fix 2026-06-14: on mobile, submenu opens/closes only via .is-open (hover/focus-within kept it stuck open on touch) */
@media (max-width: 1023px) {
  .main-nav li:hover > .sub-menu,
  .main-nav li:focus-within > .sub-menu { display: none; }
  .main-nav li.is-open > .sub-menu { display: flex; }
}
