/*
Theme Name: Neos Marmaras
Theme URI: https://neosmarmarasnet.gr/
Author: Neos Marmaras
Description: Ταξιδιωτικός οδηγός για τον Νέο Μαρμαρά και τη Σιθωνία — editorial atelier theme.
Version: 1.0.3
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: neosmarmaras
Tags: travel, editorial, custom-menu, featured-images
*/

/* ============ Fonts (self-hosted, Greek subset) ============ */
@font-face{font-family:'Cardo';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/cardo-400.woff2') format('woff2');unicode-range:U+0370-03FF,U+1F00-1FFF,U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122;}
@font-face{font-family:'Cardo';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/cardo-700.woff2') format('woff2');unicode-range:U+0370-03FF,U+1F00-1FFF,U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122;}
@font-face{font-family:'Fira Sans';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/firasans-400.woff2') format('woff2');unicode-range:U+0370-03FF,U+1F00-1FFF,U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122;}
@font-face{font-family:'Fira Sans';font-style:normal;font-weight:500;font-display:swap;
  src:url('assets/fonts/firasans-500.woff2') format('woff2');unicode-range:U+0370-03FF,U+1F00-1FFF,U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122;}
@font-face{font-family:'Fira Sans';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/firasans-700.woff2') format('woff2');unicode-range:U+0370-03FF,U+1F00-1FFF,U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122;}

/* ============ Tokens (Aegean pastel) ============ */
:root{
  --teal:#2a6f6b; --teal-deep:#1f534f; --clay:#d98555; --clay-deep:#bd6a3c;
  --cream:#faf6ef; --sand:#f0e9dc; --ink:#2b2b28; --ink-soft:#5a574f;
  --line:#e0d7c6; --white:#fffdf9;
  --serif:'Cardo',Georgia,'Times New Roman',serif;
  --sans:'Fira Sans',-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --rad:4px; --maxw:1180px; --read:68ch;
}

/* ============ Base ============ */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--sans);
  font-size:18px;line-height:1.72;font-weight:400;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--clay-deep);text-decoration:underline;text-underline-offset:3px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.18;color:var(--teal-deep);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.3rem);letter-spacing:.2px}
h2{font-size:clamp(1.5rem,3vw,2.05rem);margin-top:1.8em}
h3{font-size:1.28rem;color:var(--ink)}
p{margin:0 0 1.15em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:12px;background:var(--white);padding:8px 14px;z-index:99;border-radius:var(--rad)}

/* ============ Header ============ */
.site-header{background:var(--cream);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:74px}
.brand{display:flex;align-items:center;gap:12px;color:var(--teal-deep)}
.brand:hover{text-decoration:none}
.brand svg{flex:none}
.brand .name{font-family:var(--serif);font-weight:700;font-size:1.4rem;line-height:1;letter-spacing:.3px}
.brand .tag{display:block;font-family:var(--sans);font-size:.66rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--clay-deep);margin-top:4px}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:var(--rad);padding:8px 10px;cursor:pointer;color:var(--teal-deep)}
.main-nav ul{list-style:none;display:flex;gap:28px;margin:0;padding:0}
.main-nav a{font-weight:500;font-size:.96rem;color:var(--ink);padding:6px 0;position:relative}
.main-nav a:hover{text-decoration:none;color:var(--teal)}
.main-nav .current-menu-item a,.main-nav .current_page_item a{color:var(--teal-deep)}
.main-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--clay);transition:right .25s ease}
.main-nav a:hover::after,.main-nav .current-menu-item a::after,.main-nav .current_page_item a::after{right:0}

/* ============ Full-bleed hero (Atelier) ============ */
.hero{position:relative;min-height:clamp(420px,64vh,620px);display:flex;align-items:flex-end;
  color:var(--white);overflow:hidden;background:var(--teal-deep)}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,83,79,.12) 0%,rgba(31,83,79,.20) 45%,rgba(31,83,79,.78) 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 24px 54px;width:100%}
.hero__eyebrow{font-family:var(--sans);font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  font-size:.72rem;color:#f6d9c4;margin-bottom:14px}
.hero h1{color:var(--white);max-width:18ch;text-shadow:0 1px 24px rgba(20,40,38,.35)}
.hero__lead{font-family:var(--serif);font-size:clamp(1.15rem,2.2vw,1.45rem);max-width:48ch;
  color:#f4efe8;margin:.4em 0 0}

/* ============ Article / page body ============ */
.page-main{padding:56px 0 72px}
.layout{display:flex;gap:56px;align-items:flex-start}
.layout__body{flex:1 1 auto;min-width:0;max-width:var(--read)}
.layout__aside{flex:0 0 268px;position:sticky;top:98px}
.entry-content > p:first-of-type::first-letter{
  font-family:var(--serif);font-weight:700;float:left;font-size:3.5em;line-height:.78;
  padding:.06em .12em 0 0;color:var(--clay-deep)}
.entry-content figure{margin:1.8em 0}
.entry-content figure img{border-radius:var(--rad)}
.entry-content figcaption{font-size:.84rem;color:var(--ink-soft);margin-top:8px;font-style:italic}
.entry-content ul,.entry-content ol{padding-left:1.3em;margin:0 0 1.2em}
.entry-content li{margin:.3em 0}
.entry-content h2{padding-top:.2em}

/* meta / byline */
.entry-meta{display:flex;align-items:center;gap:14px;margin:0 0 30px;font-size:.92rem;color:var(--ink-soft)}
.entry-meta img{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:none}
.entry-meta a{font-weight:500}
.entry-meta .sep{opacity:.5}

/* page heading band */
.page-head{max-width:var(--read);margin:0 auto 0;padding:0 24px}
.page-head .kicker{font-family:var(--sans);font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  font-size:.72rem;color:var(--clay-deep);margin-bottom:10px}

/* ---- Site-specific callout: "wave note" (NOT bg/10 + border-l-4 + bold label) ---- */
.wave-note{position:relative;margin:2em 0;padding:24px 26px 24px 30px;background:var(--white);
  border:1px solid var(--line);border-radius:var(--rad)}
.wave-note::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:6px;border-radius:6px;
  background:repeating-linear-gradient(180deg,var(--teal) 0 7px,var(--clay) 7px 14px)}
.wave-note p:last-child{margin-bottom:0}
.wave-note .wn-ico{float:right;margin:0 0 8px 16px;color:var(--teal);opacity:.55}

/* ============ Topic grid (homepage) — asymmetric, not 3 equal cards ============ */
.section-head{max-width:var(--read);margin:0 auto 26px;padding:0 24px}
.section-head h2{margin-top:0}
.topics{display:grid;grid-template-columns:repeat(6,1fr);gap:22px}
.topic{grid-column:span 3;position:relative;border-radius:var(--rad);overflow:hidden;background:var(--sand);
  display:flex;flex-direction:column;min-height:260px}
.topic--wide{grid-column:span 6}
.topic--tall{grid-column:span 2}
.topic__img{position:relative;flex:1 1 auto;min-height:170px}
.topic__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.topic__body{padding:18px 20px 22px;background:var(--white)}
.topic__body h3{margin:0 0 6px;font-family:var(--serif);font-size:1.3rem;color:var(--teal-deep)}
.topic--wide .topic__body h3{font-size:1.65rem}
.topic__body p{margin:0;font-size:.95rem;color:var(--ink-soft)}
.topic__link{position:absolute;inset:0;z-index:2}
.topic:hover{box-shadow:0 8px 30px -16px rgba(31,83,79,.5)}
.topic:hover .topic__img img{transform:scale(1.04)}
.topic__img img{transition:transform .5s ease}

/* ============ FAQ — custom disclosure (no stock accordion look) ============ */
.faq{max-width:var(--read);margin:48px auto 0;padding:0 24px}
.faq h2{margin-top:0}
.faq__item{border-top:1px solid var(--line);padding:18px 0}
.faq__item:last-child{border-bottom:1px solid var(--line)}
.faq__q{font-family:var(--serif);font-weight:700;font-size:1.12rem;color:var(--teal-deep);margin:0 0 .4em;
  display:flex;gap:12px;align-items:baseline;
  width:100%;background:none;border:0;padding:0;text-align:left;cursor:pointer}
.faq--js .faq__q{margin:0}
.faq--js .faq__item.is-open .faq__q{margin:0 0 .4em}
.faq__q .n{font-family:var(--sans);font-size:.8rem;color:var(--clay-deep);font-weight:700;flex:none;
  letter-spacing:.05em}
.faq__qt{flex:1 1 auto}
.faq__ind{flex:none;align-self:center;width:10px;height:10px;border-right:2px solid var(--clay-deep);
  border-bottom:2px solid var(--clay-deep);transform:rotate(45deg);transition:transform .2s ease}
.faq__item.is-open .faq__ind{transform:rotate(-135deg)}
.faq__q:focus-visible{outline:2px solid var(--teal-deep);outline-offset:3px}
.faq__a{margin:0;color:var(--ink)}

/* ============ Related / prev-next ============ */
.related{background:var(--sand);margin-top:64px;padding:48px 0}
.related h2{margin-top:0}
.related ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:14px}
.related a{display:inline-block;background:var(--white);border:1px solid var(--line);border-radius:var(--rad);
  padding:10px 16px;font-weight:500;font-size:.94rem}
.related a:hover{text-decoration:none;border-color:var(--teal);color:var(--teal-deep)}

/* ============ Author box / archive ============ */
.author-card{display:flex;gap:24px;align-items:flex-start;background:var(--white);border:1px solid var(--line);
  border-radius:var(--rad);padding:26px 28px;margin:0 auto;max-width:var(--read)}
.author-card img{width:104px;height:104px;border-radius:50%;object-fit:cover;flex:none}
.author-card h2{margin:0 0 6px;font-size:1.4rem}
.author-card .role{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--clay-deep);margin-bottom:10px}
.author-card p{margin:0 0 .6em;font-size:.97rem}

/* ============ Footer ============ */
.site-footer{background:var(--teal-deep);color:#d9e6e4;margin-top:0;padding:54px 0 30px;font-size:.94rem}
.site-footer a{color:#f1e6db}
.site-footer a:hover{color:#fff}
.footer-grid{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between}
.footer-grid h4{color:#fff;font-family:var(--serif);font-size:1.1rem;margin:0 0 14px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin:.4em 0}
.footer-about{max-width:34ch}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:40px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#a9c4c1;font-size:.85rem}

/* ============ 404 / generic ============ */
.notice{max-width:var(--read);margin:60px auto;padding:0 24px;text-align:center}

/* ============ Responsive ============ */
@media(max-width:900px){
  .layout{flex-direction:column;gap:36px}
  .layout__aside{position:static;flex-basis:auto;width:100%}
  .topics{grid-template-columns:repeat(2,1fr)}
  .topic,.topic--wide,.topic--tall{grid-column:span 1}
  .topic--wide{grid-column:span 2}
}
@media(max-width:680px){
  body{font-size:17px}
  .main-nav{display:none;position:absolute;top:74px;left:0;right:0;background:var(--cream);
    border-bottom:1px solid var(--line);padding:8px 0}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:0;padding:0 24px}
  .main-nav li{border-top:1px solid var(--line)}
  .main-nav li:first-child{border-top:none}
  .main-nav a{display:block;padding:13px 0}
  .nav-toggle{display:inline-flex}
  .topics{grid-template-columns:1fr}
  .topic--wide{grid-column:span 1}
  .author-card{flex-direction:column;align-items:center;text-align:center}
}
