/* ==========================================================================
   Vouliagmeni.gr — Athenian Riviera 2026
   ========================================================================== */

:root {
	--ink: #181614;
	--ink-soft: #5c564e;
	--ink-muted: #8e867b;
	--aegean: #1b3a4b;       /* βαθύ μπλε θάλασσας — accents/links */
	--aegean-deep: #142c39;
	--sand: #8a7b63;
	--star: #e03131;
	--bg: #faf7f2;           /* ζεστό «χαρτί» */
	--surface: #ffffff;
	--line: #e5dfd5;
	--radius: 2px;
	--radius-sm: 2px;
	--shadow-sm: 0 1px 2px rgba(24, 22, 20, 0.05), 0 4px 12px rgba(24, 22, 20, 0.04);
	--shadow-md: 0 4px 8px rgba(24, 22, 20, 0.06), 0 16px 32px rgba(24, 22, 20, 0.10);
	--font-serif: "Playfair Display", Georgia, serif; /* display/headings */
	--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--container: 1180px;
	--ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.65;
	color: var(--ink);
	background: var(--bg);
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--aegean); }

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

.screen-reader-text {
	position: absolute;
	width: 1px; height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
}

:focus-visible {
	outline: 2px solid var(--aegean);
	outline-offset: 2px;
	border-radius: 4px;
}

/* --------------------------------------------------------------------------
   Header
   -------------------------------------------------------------------------- */

.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(250, 247, 242, 0.92);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--line);
}


.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	min-height: 68px;
}

.site-title {
	font-family: var(--font-serif);
	font-size: 1.45rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	color: var(--ink);
}

.site-title span { color: var(--sand); }


/* Custom logo (SVG) */
.site-branding .custom-logo-link { display: block; line-height: 0; }

.site-branding .custom-logo {
	height: 104px;
	width: auto;
	display: block;
	padding: 10px 0;
	transition: height 0.25s var(--ease);
}

/* Shrink στο scroll */
body.is-scrolled .site-branding .custom-logo { height: 60px; padding: 6px 0; }
body.is-scrolled .site-header__inner { min-height: 60px; }


.site-nav .menu {
	display: flex;
	align-items: center;
	gap: 1.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
	flex-wrap: nowrap;
}

.site-nav .menu a,
.site-nav .menu button { white-space: nowrap; }

/* Ομάδα εικονιδίων (LinkedIn / Spotify / Search): κοντά μεταξύ τους, με διαχωριστικό από τα links */
.site-nav .menu > li:has(.social-link),
.site-nav .menu > li:has(.search-trigger) { margin-left: -1.05rem; }

.site-nav .menu > li.menu-icons-start {
	margin-left: 0;
	padding-left: 1.4rem;
	border-left: 1px solid var(--line);
}

.site-nav a {
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
	color: var(--ink-soft);
	transition: color 0.2s var(--ease);
}

.site-nav a:hover { color: var(--aegean); }

.site-nav .menu > li { display: flex; align-items: center; }

.site-nav a,
.dropdown-trigger {
	font-family: var(--font-sans);
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.95rem;
	font-weight: 500;
}

.nav-toggle { display: none; }

/* Social icons στο menu */
.social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	color: var(--ink-soft) !important;
	transition: color 0.2s var(--ease), background 0.2s var(--ease);
}

.social-link:hover { background: #f0f0ef; color: #0a66c2 !important; }
.social-link--spotify:hover { color: #1db954 !important; }
.social-link--whatsapp:hover { color: #25d366 !important; }

/* Spotify page */
.spotify-page { max-width: 1100px; padding-top: 2.5rem; padding-bottom: 5rem; }

.spotify-page__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(440px, 100%), 1fr));
	gap: 1.5rem;
}

.spotify-page__label {
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 0.6rem;
}

.spotify-page__title {
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(2rem, 5vw, 3rem);
	margin: 0 0 0.4rem;
}

.spotify-page__title span { color: #1db954; }
.spotify-page__subtitle { color: var(--ink-soft); margin: 0 0 2rem; }

/* CTA: Προσθήκη Επιχείρησης */
.nav-cta {
	border: 1px solid var(--ink);
	color: var(--ink) !important;
	border-radius: 999px;
	padding: 0.5rem 1.1rem;
	transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.nav-cta:hover { background: var(--ink); color: #fff !important; }

/* Dropdown Κατηγορίες */
.has-dropdown { position: relative; }

.dropdown-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	cursor: pointer;
	border: 0;
	background: none;
	font-family: inherit;
	font-weight: 500;
	color: var(--ink-soft);
	padding: 0.5rem 0;
	transition: color 0.2s var(--ease);
}

.dropdown-trigger svg { transition: transform 0.25s var(--ease); }
.has-dropdown:hover .dropdown-trigger,
.has-dropdown.open .dropdown-trigger { color: var(--aegean); }
.has-dropdown:hover .dropdown-trigger svg,
.has-dropdown.open .dropdown-trigger svg { transform: rotate(180deg); }

.dropdown {
	position: absolute;
	top: calc(100% + 18px);
	left: 50%;
	transform: translateX(-50%) translateY(6px);
	min-width: 620px;
	background: var(--bg);
	border: 1px solid var(--ink);
	border-radius: 0;
	box-shadow: 0 24px 60px rgba(24, 22, 20, 0.16);
	padding: 1.5rem 1.75rem 1.6rem;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s var(--ease), transform 0.25s var(--ease), visibility 0.25s;
	z-index: 60;
}

.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown,
.has-dropdown.open .dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}

.dropdown__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 2.5rem;
	max-height: 420px;
	overflow-y: auto;
}

.dropdown__item {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.65rem 0;
	border-bottom: 1px solid var(--line);
	text-decoration: none;
	transition: border-color 0.2s var(--ease);
}

.dropdown__item:hover { border-bottom-color: var(--dot); }

.dropdown__name {
	font-family: var(--font-serif);
	font-size: 1.05rem !important;
	font-weight: 600;
	color: var(--ink);
	text-transform: none;
	letter-spacing: -0.01em;
	transition: color 0.2s var(--ease);
}

.dropdown__item:hover .dropdown__name { color: var(--dot); }

.dropdown__count {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 0.85rem;
	font-weight: 400;
	color: var(--ink-muted);
	background: none;
	padding: 0;
	min-width: 0;
	text-align: right;
}

.dropdown__item:hover .dropdown__count { color: var(--ink); }

/* --------------------------------------------------------------------------
   Search overlay (από το header icon)
   -------------------------------------------------------------------------- */

.search-trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px; height: 42px;
	cursor: pointer;
	border: 1px solid var(--line);
	border-radius: 50%;
	background: var(--surface);
	color: var(--ink);
	transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}

.search-trigger:hover { background: var(--ink); border-color: var(--ink); color: #fff; }

.search-overlay { position: fixed; inset: 0; z-index: 100; }

.search-overlay__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 10, 12, 0.7);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.search-overlay__panel {
	position: relative;
	max-width: 880px;
	margin: 7vh auto 0;
	max-height: 86vh;
	display: flex;
	flex-direction: column;
	padding: 0 1.25rem;
}

.search-overlay__bar {
	display: flex;
	align-items: center;
	gap: 0.9rem;
	background: #fff;
	border-radius: 999px;
	padding: 0.45rem 0.6rem 0.45rem 1.4rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
	color: var(--ink-soft);
}

.search-overlay__bar input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: none;
	font: inherit;
	font-size: 1.1rem;
	color: var(--ink);
	padding: 0.7rem 0;
}

.search-overlay__bar input:focus { outline: none; }

.search-overlay__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px; height: 44px;
	cursor: pointer;
	border: 0;
	border-radius: 50%;
	background: #f0f0ef;
	color: var(--ink);
	transition: background 0.2s var(--ease);
}

.search-overlay__close:hover { background: var(--ink); color: #fff; }

.search-overlay__count {
	color: rgba(255, 255, 255, 0.75);
	font-size: 0.9rem;
	margin: 1.1rem 0 0.9rem;
	min-height: 1.2em;
}

.search-overlay__results {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	overflow-y: auto;
	padding: 4px 4px 2rem;
	max-width: 640px;
	margin: 0 auto;
	width: 100%;
}

.place-row {
	display: flex;
	align-items: center;
	gap: 0.9rem;
	background: #fff;
	border-radius: 14px;
	padding: 0.6rem 0.9rem 0.6rem 0.6rem;
	text-decoration: none;
	color: var(--ink);
	transition: transform 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.place-row:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.place-row__thumb {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: 10px;
	overflow: hidden;
	background: #ecece9;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #a5a5ab;
}

.place-row__thumb img { width: 100%; height: 100%; object-fit: cover; }

.place-row__body { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.place-row__title {
	font-size: 0.98rem;
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.place-row__meta { font-size: 0.82rem; color: var(--ink-soft); }
.place-row__arrow { color: var(--ink-muted); flex-shrink: 0; }

/* --------------------------------------------------------------------------
   Personas hero — "Για ποιον ψάχνεις;"
   -------------------------------------------------------------------------- */

.personas {
	position: relative;
	color: #fff;
	padding: 2.75rem 0 3.25rem;
	background:
		radial-gradient(1100px 500px at 85% -10%, rgba(255, 255, 255, 0.07), transparent 60%),
		radial-gradient(900px 600px at 10% 110%, rgba(255, 255, 255, 0.04), transparent 55%),
		linear-gradient(160deg, #142c39 0%, #1b3a4b 55%, #22485d 100%);
}

/* Full width — όχι container περιορισμός */
.personas .container {
	max-width: none;
	padding: 0 clamp(1.25rem, 3vw, 3rem);
}

.personas__title {
	margin: 0;
	text-align: center;
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(1.8rem, 4.5vw, 2.8rem);
}

.personas__subtitle {
	margin: 0.5rem auto 2.25rem;
	text-align: center;
	max-width: 480px;
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.98rem;
}

.personas__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(215px, 1fr));
	gap: 1rem;
}

.persona {
	position: relative;
	text-decoration: none;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.55rem;
	text-align: left;
	font-family: inherit;
	padding: 0.35rem 1.2rem 0.5rem;
	border-left: 1px solid rgba(255, 255, 255, 0.18);
	color: #fff;
	transition: border-color 0.3s var(--ease);
}

.persona:hover { border-left-color: rgba(255, 255, 255, 0.55); }

.persona.is-active {
	border-left: 2px solid var(--dot);
	padding-left: calc(1.2rem - 1px);
}

.persona__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	margin-bottom: 0.4rem;
}

/* Facepile: μικρές στρογγυλές φωτό από μαγαζιά του term */
.persona__faces { display: flex; }

.persona__face-wrap {
	position: relative;
	display: inline-flex;
	margin-left: -12px;
	transition: margin 0.3s var(--ease);
}

.persona__face-wrap:first-child { margin-left: 0; }
.persona:hover .persona__face-wrap { margin-left: -5px; }
.persona:hover .persona__face-wrap:first-child { margin-left: 0; }

.persona__face {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid #1b3a4b;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
	transition: transform 0.25s var(--ease), border-color 0.25s var(--ease);
}

/* Tooltip με το όνομα του μαγαζιού στο hover του κυκλακίου */
.persona__face-wrap::after {
	content: attr(data-name);
	position: absolute;
	bottom: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%) translateY(3px);
	background: #fff;
	color: var(--ink);
	font-size: 0.72rem;
	font-weight: 600;
	line-height: 1.2;
	padding: 0.3rem 0.6rem;
	border-radius: 8px;
	white-space: nowrap;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.45);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.2s var(--ease), transform 0.2s var(--ease);
	z-index: 5;
}

.persona__face-wrap:hover::after {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}

.persona__face-wrap:hover .persona__face {
	transform: scale(1.18);
	border-color: #fff;
	z-index: 4;
}

.persona__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.6);
	transition: color 0.3s var(--ease);
}

.persona:hover .persona__icon { color: #fff; }

.persona__name {
	font-weight: 700;
	font-size: 1.04rem;
	line-height: 1.3;
	letter-spacing: -0.01em;
}

.persona__count {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.55);
	transition: color 0.3s var(--ease), gap 0.3s var(--ease);
}

.persona:hover .persona__count { color: #fff; gap: 0.45rem; }

/* Sponsored ένδειξη (πολύ μικρά γράμματα) */

.sponsored-tag {
	position: absolute;
	bottom: 0.7rem;
	left: 0.85rem;
	font-size: 0.58rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.95);
	background: rgba(10, 10, 12, 0.55);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	padding: 0.18rem 0.5rem;
	border-radius: 999px;
}

/* Featured row στην αρχική (1 γραμμή, οριζόντιο scroll) */

.featured-row {
	padding: 2.25rem 0 2.25rem max(1.25rem, calc((100vw - var(--container)) / 2));
}

.featured-row__head { padding-right: 1.25rem; margin-bottom: 1rem; }

.section-title--sm { font-size: 1.4rem; }

.featured-row__track {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 280px;
	gap: 1.25rem;
	overflow-x: auto;
	padding: 4px 1.25rem 14px 4px;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
}

.featured-row__track .place-card { scroll-snap-align: start; }

/* Sticky filter bar (κάτω από το hero, μένει ορατή στο scroll) */

.filter-bar {
	position: sticky;
	top: 60px;
	z-index: 30;
	background: rgba(250, 247, 242, 0.94);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--line);
}

.filter-bar__inner {
	max-width: none;
	display: flex;
	gap: 0.5rem;
	overflow-x: auto;
	scrollbar-width: none;
	padding: 0.7rem max(1.25rem, calc((100vw - var(--container)) / 2));
}

.filter-bar__inner::-webkit-scrollbar { display: none; }

.chip {
	flex-shrink: 0;
	cursor: pointer;
	border: 1px solid var(--line);
	background: var(--surface);
	color: var(--ink-soft);
	font: inherit;
	font-size: 0.86rem;
	font-weight: 500;
	padding: 0.45rem 0.95rem;
	border-radius: 999px;
	white-space: nowrap;
	transition: background 0.2s var(--ease), border-color 0.2s var(--ease), color 0.2s var(--ease);
}

.chip:hover { border-color: var(--aegean); color: var(--aegean); }

.chip.is-active {
	background: var(--ink);
	border-color: var(--ink);
	color: #fff;
}

.chip__count {
	font-size: 0.74rem;
	opacity: 0.65;
	margin-left: 0.25rem;
}

/* --------------------------------------------------------------------------
   Places grid & cards
   -------------------------------------------------------------------------- */

.places-section { padding: 0; position: relative; }

/* Σε taxonomy/απλές σελίδες (χωρίς split layout) δώσε κάθετα κενά */
.places-section > .container { padding-top: 3rem; padding-bottom: 5rem; }

.places-section__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.75rem;
}

.section-title {
	margin: 0;
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(1.6rem, 3vw, 2.1rem);
	color: var(--ink);
}

.places-count {
	margin: 0;
	font-size: 0.92rem;
	color: var(--ink-soft);
}

.places-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
	gap: 1.5rem;
}

.places-grid--3 { grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); }

.places-grid.is-loading { opacity: 0.45; pointer-events: none; }
.places-grid { transition: opacity 0.25s var(--ease); }

.place-card {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: box-shadow 0.3s var(--ease), transform 0.3s var(--ease), border-color 0.3s var(--ease);
}

.place-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
	border-color: #d3dee5;
}

.place-card__link {
	display: block;
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}

.place-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: linear-gradient(135deg, #e8eef2, #d6e2e9);
}

.place-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s var(--ease);
}

.place-card:hover .place-card__img { transform: scale(1.05); }

.place-card__img--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #9fb4c2;
}

.place-card__badge {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	color: var(--ink);
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	padding: 0.32rem 0.7rem;
	border-radius: 999px;
	box-shadow: 0 2px 8px rgba(10, 37, 64, 0.12);
}

.place-card__rating {
	position: absolute;
	top: 0.85rem;
	right: 0.85rem;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: rgba(250, 247, 242, 0.95);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	color: var(--ink);
	font-size: 0.8rem;
	font-weight: 600;
	padding: 0.32rem 0.65rem;
	border-radius: 999px;
}

.place-card__rating svg { color: var(--star); }

.place-card__body { padding: 1.1rem 1.2rem 1.25rem; }

.place-card__title {
	margin: 0 0 0.3rem;
	font-family: var(--font-serif);
	font-size: 1.3rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.25;
	color: var(--ink);
	transition: color 0.2s var(--ease);
}

.place-card:hover .place-card__title { color: var(--star); }

.place-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0 0 0.8rem;
	font-size: 0.85rem;
	color: var(--ink-soft);
}

.place-card__price { color: var(--sand); font-weight: 600; }

.place-card__dot {
	width: 3px; height: 3px;
	border-radius: 50%;
	background: #b9c8d2;
}

.place-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin: 0;
}

.place-card__tag {
	font-size: 0.74rem;
	font-weight: 500;
	color: #3c3c43;
	background: #f0f0ef;
	border-radius: 999px;
	padding: 0.22rem 0.6rem;
}

.place-card__tag--more { background: #e6e6e4; color: var(--ink-soft); }

/* Split layout: λίστα αριστερά + sticky χάρτης δεξιά (spitogatos-style) */

.places-split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 42%;
	gap: 0;
	align-items: start;
}

.places-split__list {
	padding: 2.5rem 2rem 4rem max(1.25rem, calc((100vw - var(--container)) / 2));
	min-width: 0;
}

.places-split__map {
	position: sticky;
	top: 118px; /* shrunk header 60px + filter bar */
	height: calc(100vh - 118px);
}

.places-map {
	height: 100%;
	width: 100%;
	z-index: 1;
}

.places-grid--split {
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.25rem;
}

.map-toggle { display: none; }

.vlgm-pin-wrap { background: none; border: none; }

.vlgm-pin {
	display: block;
	width: 30px;
	height: 30px;
	background: linear-gradient(135deg, #22485d, #142c39);
	border: 2px solid #faf7f2;
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	box-shadow: 0 3px 10px rgba(20, 44, 57, 0.4);
	transition: transform 0.2s var(--ease);
}

.vlgm-pin-wrap:hover .vlgm-pin { transform: rotate(-45deg) scale(1.12); }

.vlgm-pin-wrap.is-hovered .vlgm-pin {
	transform: rotate(-45deg) scale(1.35);
	background: linear-gradient(135deg, #e03131, #b82424);
	box-shadow: 0 4px 16px rgba(224, 49, 49, 0.5);
}

.vlgm-pin-wrap.is-hovered .vlgm-pin__dot { background: #fff; }

.vlgm-pin__dot {
	position: absolute;
	top: 50%; left: 50%;
	width: 8px; height: 8px;
	margin: -4px 0 0 -4px;
	background: #fff;
	border-radius: 50%;
}

.leaflet-popup-content-wrapper {
	border-radius: 14px;
	box-shadow: var(--shadow-md);
	padding: 0;
	overflow: hidden;
}

.leaflet-popup-content { margin: 0; width: 230px !important; }
.leaflet-popup-tip { box-shadow: var(--shadow-sm); }

.map-pop {
	display: block;
	text-decoration: none;
	color: var(--ink);
	font-family: var(--font-sans);
}

.map-pop__media { display: block; position: relative; }

.map-pop__img {
	width: 100%;
	height: 130px;
	object-fit: cover;
	display: block;
}

.map-pop__badge {
	position: absolute;
	top: 0.6rem;
	left: 0.6rem;
	background: rgba(255, 255, 255, 0.94);
	color: var(--ink);
	font-size: 0.66rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	padding: 0.22rem 0.55rem;
	border-radius: 999px;
}

.map-pop__body { display: block; padding: 0.75rem 0.95rem 0.85rem; }

.map-pop__title {
	display: block;
	font-family: var(--font-sans);
	font-weight: 700;
	font-size: 1rem;
	line-height: 1.3;
	margin-bottom: 0.25rem;
}

.map-pop__meta {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.82rem;
	color: var(--ink-soft);
}

.map-pop__rating { color: #b07d28; font-weight: 700; }
.map-pop__count { color: var(--ink-muted); font-size: 0.76rem; }
.map-pop__price { font-weight: 600; color: var(--ink-soft); margin-left: auto; }

.map-pop__addr {
	display: block;
	font-size: 0.78rem;
	color: var(--ink-muted);
	margin-top: 0.25rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.map-pop__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem;
	margin-top: 0.5rem;
}

.map-pop__tag {
	font-size: 0.68rem;
	font-weight: 500;
	color: #3c3c43;
	background: #f0f0ef;
	border-radius: 999px;
	padding: 0.16rem 0.5rem;
}

.map-pop__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-top: 0.6rem;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--ink);
}

.map-pop:hover .map-pop__cta { text-decoration: underline; }

/* Promo card */

.promo-card {
	position: relative;
	min-height: 100%;
	display: flex;
}

.promo-card__tag { z-index: 2; bottom: auto; top: 0.7rem; left: auto; right: 0.85rem; }

.promo-card__link,
.promo-card__html {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 280px;
}

.promo-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.promo-card__html { overflow: hidden; }

.places-empty {
	text-align: center;
	padding: 3rem 0;
	color: var(--ink-soft);
}

.places-more { text-align: center; margin-top: 2.5rem; }

/* Infinite scroll: το κουμπί γίνεται αόρατο sentinel + spinner όσο φορτώνει */
.btn.is-sentinel {
	pointer-events: none;
	color: transparent;
	background: transparent;
	border-color: transparent;
	position: relative;
	min-height: 44px;
}

.places-grid.is-loading ~ .places-more .btn.is-sentinel::after {
	content: "";
	position: absolute;
	top: 50%; left: 50%;
	width: 22px; height: 22px;
	margin: -11px 0 0 -11px;
	border: 2.5px solid var(--line);
	border-top-color: var(--aegean);
	border-radius: 50%;
	animation: vlgm-spin 0.7s linear infinite;
}

@keyframes vlgm-spin { to { transform: rotate(360deg); } }

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	cursor: pointer;
	border-radius: 999px;
	padding: 0.8rem 1.8rem;
	font: inherit;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: background 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease), filter 0.2s var(--ease);
}

.btn--primary {
	border: 0;
	color: #fff;
	background: linear-gradient(135deg, var(--aegean) 0%, var(--aegean-deep) 100%);
}

.btn--primary:hover { filter: brightness(1.12); }

.btn--ghost {
	border: 1px solid var(--ink);
	background: transparent;
	color: var(--ink);
}

.btn--ghost:hover { background: var(--ink); color: #fff; border-color: var(--ink); }

.btn[disabled] { opacity: 0.6; cursor: wait; }

/* --------------------------------------------------------------------------
   Single place
   -------------------------------------------------------------------------- */

.place { padding: 2rem 0 5rem; }

.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: 0.85rem;
	color: var(--ink-soft);
	margin-bottom: 1.5rem;
}

.breadcrumb a { color: var(--ink-soft); text-decoration: none; }
.breadcrumb a:hover { color: var(--aegean); }
.breadcrumb [aria-current] { color: var(--ink); font-weight: 500; }

.place__header { margin-bottom: 1.75rem; }

.place__category {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sand);
	text-decoration: none;
	margin-bottom: 0.4rem;
}

.place__title {
	margin: 0 0 0.6rem;
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(2rem, 5vw, 3.2rem);
	line-height: 1.1;
}

.place__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin: 0;
	font-size: 0.95rem;
	color: var(--ink-soft);
}

.place__stars {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--ink);
}

.place__stars svg { color: var(--star); }

.place__closed {
	color: #b3261e;
	font-weight: 600;
	background: #fdecea;
	padding: 0.2rem 0.7rem;
	border-radius: 999px;
	font-size: 0.82rem;
}

/* Gallery */

.place__gallery { margin-bottom: 2.5rem; }

.place__gallery.has-thumbs {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 0.75rem;
}

.place__gallery-main { border-radius: var(--radius); overflow: hidden; }

.place__gallery-thumbs {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
}

.place__gallery-thumbs img { border-radius: var(--radius-sm); }

.place__gallery-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.place__gallery-main .place__gallery-img { aspect-ratio: 16 / 10; }
.place__gallery-thumbs .place__gallery-img { aspect-ratio: 4 / 3; }

/* Layout */

.place__layout {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 2.5rem;
	align-items: start;
}

.place__section { margin-bottom: 2.5rem; }

.place__section-title {
	margin: 0 0 1rem;
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: 1.45rem;
}

.place__summary {
	font-size: 1.08rem;
	color: var(--ink-soft);
	margin: 0;
}

.place__amenities {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.6rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.place__amenities li {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.92rem;
	color: var(--ink-soft);
}

.place__amenities svg { color: var(--aegean); flex-shrink: 0; }

/* Reviews */

.reviews-toggle summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	cursor: pointer;
	list-style: none;
	padding: 1rem 1.25rem;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	transition: border-color 0.2s var(--ease);
}

.reviews-toggle summary::-webkit-details-marker { display: none; }
.reviews-toggle summary:hover { border-color: #cfcfcc; }
.reviews-toggle summary .place__section-title { margin: 0; font-size: 1.25rem; }
.reviews-toggle__count { color: var(--ink-soft); font-size: 0.95rem; font-family: var(--font-sans); }
.reviews-toggle__chevron { color: var(--ink-soft); flex-shrink: 0; transition: transform 0.25s var(--ease); }
.reviews-toggle[open] summary { border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
.reviews-toggle[open] .reviews-toggle__chevron { transform: rotate(180deg); }
.reviews-toggle[open] .place__reviews { margin-top: 0.75rem; }

.place__reviews {
	display: grid;
	gap: 1rem;
}

.review {
	margin: 0;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 1.25rem 1.4rem;
}

.review__head {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-bottom: 0.5rem;
}

.review__author { font-weight: 600; font-size: 0.95rem; }
.review__stars { display: inline-flex; gap: 1px; color: var(--star); }
.review__date { font-size: 0.82rem; color: var(--ink-soft); }

.review__text {
	margin: 0;
	font-size: 0.95rem;
	color: var(--ink-soft);
}

/* Website embed */

.place__site-embed {
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--line);
	box-shadow: var(--shadow-sm);
}

.place__site-embed iframe {
	display: block;
	width: 100%;
	height: 480px;
	border: 0;
}

.place__site-embed-link { margin: 0.5rem 0 0; font-size: 0.85rem; }

/* Sidebar */

.place__sidebar {
	position: sticky;
	top: 132px;
	display: grid;
	gap: 1.25rem;
}

.info-card {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow-sm);
	padding: 1.5rem;
}

.info-card__title {
	margin: 0 0 1.1rem;
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 600;
}

.info-card__row {
	display: flex;
	align-items: flex-start;
	gap: 0.7rem;
	padding: 0.55rem 0;
	font-size: 0.93rem;
	color: var(--ink-soft);
}

.info-card__row svg { color: var(--aegean); flex-shrink: 0; margin-top: 2px; }
.info-card__row a { color: var(--ink); text-decoration: none; font-weight: 500; }
.info-card__row a:hover { color: var(--aegean); }

.info-card__hours { padding: 0.55rem 0; }

.info-card__hours summary {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	cursor: pointer;
	font-size: 0.93rem;
	font-weight: 500;
	color: var(--ink);
	list-style: none;
}

.info-card__hours summary::-webkit-details-marker { display: none; }
.info-card__hours summary svg { color: var(--aegean); }

.info-card__hours ul {
	list-style: none;
	margin: 0.7rem 0 0;
	padding: 0 0 0 1.7rem;
	font-size: 0.86rem;
	color: var(--ink-soft);
	display: grid;
	gap: 0.3rem;
}

.info-card__cta { width: 100%; margin-top: 1rem; }

.place__map {
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--line);
	box-shadow: var(--shadow-sm);
}

.place__map iframe {
	display: block;
	width: 100%;
	height: 260px;
	border: 0;
}

.place__related { margin-top: 3rem; }
.place__related .section-title { margin-bottom: 1.5rem; }

/* --------------------------------------------------------------------------
   Taxonomy archive
   -------------------------------------------------------------------------- */

.tax-hero {
	background: linear-gradient(160deg, #142c39 0%, #1b3a4b 60%, #22485d 100%);
	color: #fff;
	padding: 1.75rem 0 1.5rem;
}

.tax-hero .breadcrumb { margin-bottom: 0.6rem; font-size: 0.8rem; }
.tax-hero .places-count { font-size: 0.85rem; margin-top: 0.15rem; }

.tax-hero .breadcrumb,
.tax-hero .breadcrumb a { color: rgba(255, 255, 255, 0.7); }
.tax-hero .breadcrumb [aria-current] { color: #fff; }
.tax-hero .places-count { color: rgba(255, 255, 255, 0.75); }

.tax-hero__title {
	margin: 0;
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(1.6rem, 3.5vw, 2.3rem);
}

.tax-hero__sub { color: #b9b9c0; font-style: italic; }

/* Pagination */

.pagination { margin-top: 2.5rem; text-align: center; }

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 0.6rem;
	margin: 0 0.15rem;
	border-radius: 999px;
	border: 1px solid var(--line);
	background: var(--surface);
	color: var(--ink);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.92rem;
	transition: border-color 0.2s var(--ease), color 0.2s var(--ease);
}

.pagination .page-numbers:hover { border-color: var(--aegean); color: var(--aegean); }
.pagination .page-numbers.current { background: var(--ink); border-color: var(--ink); color: #fff; }

/* --------------------------------------------------------------------------
   Generic content / fallbacks
   -------------------------------------------------------------------------- */

.site-main { min-height: 60vh; }
body:not(.home) .site-main > .container { padding-top: 2.5rem; padding-bottom: 4rem; }

.entry-title { font-family: var(--font-serif); }

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */

.site-footer {
	background: #f4f0e8;
	border-top: 1px solid var(--line);
	color: var(--ink-soft);
	padding: 4rem 0 2rem;
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: 3rem;
	padding-bottom: 3rem;
}

.footer-brand {
	font-family: var(--font-serif);
	font-size: 1.7rem;
	font-weight: 600;
	color: var(--ink);
	text-decoration: none;
}

.footer-brand span { color: var(--ink-muted); }

.footer-tagline {
	margin: 0.9rem 0 1.4rem;
	font-size: 0.92rem;
	line-height: 1.7;
	color: var(--ink-soft);
	max-width: 320px;
}

.footer-social { display: flex; gap: 0.6rem; }

.footer-social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	border: 1px solid var(--line);
	color: var(--ink-soft);
	transition: background 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease);
}

.footer-social a:hover { background: var(--ink); border-color: var(--ink); color: #fff; }

.footer-col__title {
	margin: 0 0 1.1rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.footer-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.55rem;
}

.footer-col ul a {
	color: var(--ink-soft);
	text-decoration: none;
	font-size: 0.92rem;
	transition: color 0.2s var(--ease), padding-left 0.2s var(--ease);
}

.footer-col ul a:hover { color: var(--ink); padding-left: 4px; }

.footer-cta {
	display: inline-block;
	margin-top: 1.3rem;
	padding: 0.6rem 1.3rem;
	border: 1px solid var(--ink);
	border-radius: 999px;
	color: var(--ink);
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 600;
	transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.footer-cta:hover { background: var(--ink); color: #fff; }

.footer-bottom {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding-top: 1.75rem;
	border-top: 1px solid var(--line);
}

.copyright { margin: 0; font-size: 0.82rem; color: var(--ink-muted); }

.made-by-line {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	margin: 0;
	font-size: 1rem;
	color: var(--ink-soft);
}

.made-by-line a {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.made-by-line__logo { width: 20px; height: 20px; display: inline-block; }

.made-by-line svg { color: #e03131; }

.made-by-line a {
	color: var(--ink);
	text-decoration: none;
	font-weight: 600;
}

.made-by-line a:hover { color: var(--star); }

@media (max-width: 900px) {
	.footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
	.footer-col--brand { grid-column: 1 / -1; }
}

@media (max-width: 540px) {
	.footer-grid { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */

@media (max-width: 900px) {
	.places-split { grid-template-columns: 1fr; }
	.places-split__list { padding: 2rem 1.25rem 4rem; }

	.places-split__map {
		position: fixed;
		inset: 118px 0 0;
		height: auto;
		z-index: 40;
		visibility: hidden;
		opacity: 0;
		transition: opacity 0.25s var(--ease), visibility 0.25s;
	}

	.places-section.show-map .places-split__map {
		visibility: visible;
		opacity: 1;
	}

	.map-toggle {
		position: fixed;
		bottom: 1.4rem;
		left: 50%;
		transform: translateX(-50%);
		z-index: 45;
		display: inline-flex;
		align-items: center;
		gap: 0.5rem;
		cursor: pointer;
		border: 0;
		border-radius: 999px;
		padding: 0.75rem 1.5rem;
		font: inherit;
		font-weight: 600;
		font-size: 0.92rem;
		color: #fff;
		background: var(--ink);
		box-shadow: 0 6px 24px rgba(7, 28, 48, 0.4);
	}

	.place__layout { grid-template-columns: 1fr; }
	.place__sidebar { position: static; }
	.place__gallery.has-thumbs { grid-template-columns: 1fr; }
	.place__gallery-thumbs { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 1080px) {
	.nav-toggle {
		display: inline-flex;
		align-items: center;
		cursor: pointer;
		border: 0;
		background: none;
		color: var(--ink);
		padding: 0.4rem;
	}


	.site-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0; right: 0;
		background: var(--bg);
		border-bottom: 1px solid var(--ink);
		box-shadow: 0 28px 50px rgba(24, 22, 20, 0.18);
		padding: 0.75rem 1.4rem 1.6rem;
		max-height: calc(100vh - 80px);
		overflow-y: auto;
	}

	.site-nav.open { display: block; }

	.site-nav .menu { flex-direction: row; flex-wrap: wrap; align-items: stretch; gap: 0; }

	.site-nav .menu > li { display: block; width: 100%; border-bottom: 1px solid var(--line); }

	.site-nav a,
	.dropdown-trigger {
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: 100%;
		text-align: left;
		padding: 1rem 0.25rem;
		font-family: var(--font-serif);
		font-size: 1.25rem;
		font-weight: 600;
		letter-spacing: -0.01em;
		color: var(--ink) !important;
	}

	/* Σειρά εικονιδίων: δίπλα-δίπλα, χωρίς serif/γραμμές */
	.site-nav .menu > li:has(.social-link),
	.site-nav .menu > li:has(.search-trigger) {
		display: inline-flex;
		width: auto;
		border-bottom: 0;
		margin: 1rem 0.7rem 0 0;
	}

	.site-nav .menu > li.menu-icons-start { border-left: 0; padding-left: 0; }

	.site-nav .social-link,
	.site-nav .search-trigger {
		width: 44px; height: 44px;
		padding: 0;
		justify-content: center;
		border: 1px solid var(--line);
		border-radius: 50%;
		font-size: 0;
	}

	/* Κατηγορίες: πάντα ανοιχτές στο burger — χωρίς accordion */
	.dropdown,
	.has-dropdown:hover .dropdown,
	.has-dropdown:focus-within .dropdown,
	.has-dropdown.open .dropdown {
		position: static;
		transform: none;
		min-width: 0;
		opacity: 1;
		visibility: visible;
		max-height: none;
		overflow: visible;
		padding: 0 0 0.9rem;
		border: 0;
		box-shadow: none;
		background: transparent;
		transition: none;
	}

	/* Ο trigger γίνεται απλή επικεφαλίδα (το βελάκι φεύγει) */
	.dropdown-trigger { pointer-events: none; }
	.dropdown-trigger svg { display: none; }

	.dropdown__grid { grid-template-columns: 1fr 1fr; column-gap: 1.5rem; max-height: none; }

	.dropdown__item { padding: 0.55rem 0.25rem; }
	.dropdown__item:last-child { border-bottom: 0; }
	.dropdown__name { font-size: 0.98rem !important; font-weight: 500; }
}

@media (max-width: 640px) {
	/* Κινητό: 2 κάρτες ανά σειρά */
	.places-grid,
	.places-grid--split { grid-template-columns: repeat(2, 1fr); gap: 0.9rem; }

	.place-card__title { font-size: 1.05rem; }
	.place-card__meta { font-size: 0.78rem; gap: 0.35rem; }
	.place-card__tags { display: none; } /* στενές κάρτες — τα tags δεν χωράνε καθαρά */
	.place-card__badge { font-size: 0.6rem; padding: 0.25rem 0.5rem; }
	.place-card__rating { font-size: 0.72rem; padding: 0.25rem 0.5rem; }

	.place__gallery-thumbs { grid-template-columns: repeat(2, 1fr); }
	.site-nav .menu { gap: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after {
		transition-duration: 0.01ms !important;
		animation-duration: 0.01ms !important;
	}
}

.tax-intro {
	max-width: 760px;
	margin-bottom: 2.25rem;
	color: var(--ink-soft);
	font-size: 1.02rem;
	line-height: 1.75;
}

.tax-hero__desc {
	margin: 0.5rem 0 0.75rem;
	max-width: 560px;
	color: rgba(255, 255, 255, 0.75);
	font-size: 1rem;
}

/* Playfair Display headings: editorial βάρος + σφιχτό letter-spacing */
.personas__title, .section-title, .place__title,
.tax-hero__title, .spotify-page__title, .info-card__title,
.place__section-title, .footer-brand {
	font-weight: 600;
	letter-spacing: -0.01em;
}

/* ==========================================================================
   Editorial flat restyle — βάσει reference (flat, borders, extrabold + τελεία)
   ========================================================================== */

:root {
	--radius: 2px;
	--radius-sm: 2px;
	--dot: #e03131;
}

/* Τίτλοι: extrabold με κόκκινη τελεία (σήμα κατατεθέν) */
.section-title::after,
.personas__title::after,
.tax-hero__title::after,
.place__title::after,
.spotify-page__title::after {
	content: ".";
	color: var(--dot);
}

/* Κάρτες: flat, χωρίς σκιά, λεπτή γραμμή κάτω */
.place-card {
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--line);
	border-radius: 0;
	box-shadow: none;
}

.place-card:hover {
	transform: none;
	box-shadow: none;
	border-bottom-color: var(--dot);
}

.place-card__media { border-radius: var(--radius); }
.place-card__body { padding: 0.9rem 0 1.1rem; }

.place-card__badge {
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.68rem;
}

.place-card__rating { border-radius: 0; }
.place-card__tag { border-radius: 0; }
.sponsored-tag { border-radius: 0; }

/* Κουμπιά: μαύρα, τετράγωνα, uppercase */
.btn,
.footer-cta,
.nav-cta {
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.88rem;
}

.btn--primary { background: var(--ink); }
.btn--primary:hover { background: #3c4350; filter: none; }

/* Chips φίλτρων: editorial tabs με underline */
.chip {
	border-radius: 0;
	text-transform: uppercase;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	background: transparent;
	border: 0;
	border-bottom: 2px solid transparent;
	padding: 0.5rem 0.85rem 0.55rem;
}

.chip:hover { background: transparent; color: var(--ink); border-bottom-color: var(--line); }

.chip.is-active {
	background: transparent;
	color: var(--ink);
	font-weight: 600;
	border-bottom-color: var(--star);
}

.chip__count {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 0.78rem;
	letter-spacing: 0;
	text-transform: none;
}

/* Search */
.search-overlay__bar { border-radius: 0; }
.search-overlay__close { border-radius: 0; }
.place-row { border-radius: 0; }
.place-row__thumb { border-radius: 0; }

/* Panels / cards */
.info-card,
.review,
.place__map,
.place__site-embed,
.places-map,
.reviews-toggle summary,
.promo-card,
.dropdown { border-radius: var(--radius); }

.dropdown__item { border-radius: 0; }
.dropdown__count { border-radius: 0; }

/* Personas tiles: πιο flat */
.persona { border-radius: var(--radius); }
.persona__icon { border-radius: 0; }
.persona__face { border-radius: 50%; } /* τα κυκλάκια μένουν κύκλοι */

/* Featured row / pagination */
.pagination .page-numbers { border-radius: 0; }
.map-pop__badge { border-radius: 0; }
.map-pop__tag { border-radius: 0; }
.leaflet-popup-content-wrapper { border-radius: var(--radius); }

/* ==========================================================================
   Home hero — editorial (Playfair, αναζήτηση ως κύριο CTA)
   ========================================================================== */

.home-hero {
	padding: 4.5rem 0 4rem;
	border-bottom: 1px solid var(--line);
	background: var(--bg);
}

.home-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(260px, 1fr);
	gap: 4rem;
	align-items: end;
}

.home-hero__eyebrow {
	margin: 0 0 1rem;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-soft);
}

.home-hero__title {
	margin: 0;
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(2.6rem, 5.2vw, 4.2rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--ink);
}

.home-hero__title em {
	font-style: italic;
	color: var(--aegean);
}

.home-hero__dot { color: var(--dot); }

.home-hero__search {
	margin-top: 2.2rem;
	display: flex;
	align-items: stretch;
	max-width: 600px;
	background: var(--surface);
	border: 1px solid var(--ink);
}

.home-hero__search button svg {
	flex: none;
	display: block;
	margin: 0;
	color: #fff;
}

.home-hero__search input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: none;
	font: inherit;
	font-size: 0.98rem;
	color: var(--ink);
	padding: 1.05rem 1rem;
}

.home-hero__search input:focus { outline: none; }

.home-hero__search button {
	flex: none;
	cursor: pointer;
	border: 0;
	background: var(--ink);
	color: #fff;
	font: inherit;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0 1.8rem;
	transition: background 0.2s var(--ease);
}

.home-hero__search button:hover { background: var(--dot); }

.home-hero__lead {
	margin: 0;
	font-size: 0.95rem;
	color: var(--ink-soft);
}

.home-hero__stats {
	display: flex;
	gap: 2.25rem;
	margin-top: 1.2rem;
	padding-top: 1.2rem;
	border-top: 1px solid var(--line);
}

.home-hero__stat { display: flex; flex-direction: column; }

.home-hero__num {
	font-family: var(--font-serif);
	font-size: 1.9rem;
	font-weight: 600;
	line-height: 1;
	color: var(--ink);
}

.home-hero__lbl {
	margin-top: 0.35rem;
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-soft);
}

@media (max-width: 900px) {
	.home-hero { padding: 3rem 0 2.5rem; }
	.home-hero__grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* Personas: τίτλος ορατός πάνω από τη συλλογή (αν προστεθεί) + serif counts */
.persona__count { font-variant-numeric: tabular-nums; }

/* Featured row τίτλος με serif */
.featured-row .section-title { font-family: var(--font-serif); }

/* ==========================================================================
   Home: κατάλογος κατηγοριών στο τέλος του feed (#vlgm-cats)
   ========================================================================== */

.home-cats { margin-top: 3.5rem; }

.home-cats__title {
	margin: 0 0 1.5rem;
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: clamp(1.5rem, 2.6vw, 2rem);
	letter-spacing: -0.01em;
}

.home-cats__title em { font-style: italic; color: var(--aegean); }
.home-cats__dot { color: var(--dot); }

.home-cats__list { border-top: 1px solid var(--line); }

.home-cats__row {
	display: grid;
	grid-template-columns: 44px minmax(0, 1fr) auto 24px;
	align-items: center;
	gap: 1.25rem;
	padding: 1.1rem 0;
	border-bottom: 1px solid var(--line);
	text-decoration: none;
	transition: padding-left 0.25s var(--ease), border-color 0.25s var(--ease);
}

.home-cats__row:hover { padding-left: 10px; border-bottom-color: var(--dot); }

.home-cats__idx {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 0.95rem;
	color: var(--ink-muted);
}

.home-cats__name {
	font-family: var(--font-serif);
	font-size: clamp(1.2rem, 2vw, 1.55rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--ink);
	transition: color 0.2s var(--ease);
}

.home-cats__row:hover .home-cats__name { color: var(--dot); }

.home-cats__count {
	font-size: 0.8rem;
	letter-spacing: 0.05em;
	color: var(--ink-soft);
	white-space: nowrap;
}

.home-cats__arr {
	color: var(--ink-muted);
	transition: transform 0.25s var(--ease), color 0.25s var(--ease);
}

.home-cats__row:hover .home-cats__arr { transform: translateX(5px); color: var(--dot); }

/* Hero search: autocomplete panel μέσα στο κουτί */
.home-hero__search { position: relative; }

.home-hero__results[hidden] { display: none !important; }

.home-hero__results {
	position: absolute;
	top: 100%;
	left: -1px;
	right: -1px;
	z-index: 40;
	background: var(--surface);
	border: 1px solid var(--ink);
	border-top: 0;
	max-height: 380px;
	overflow-y: auto;
	padding: 0.4rem;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	box-shadow: 0 24px 48px rgba(24, 22, 20, 0.14);
}

.home-hero__results .place-row:hover {
	transform: none;
	box-shadow: none;
	background: #f4f0e8;
}

.home-hero__noresults {
	margin: 0;
	padding: 0.9rem 1rem;
	font-size: 0.9rem;
	color: var(--ink-soft);
}

/* ==========================================================================
   Hero search v2 — pill, καθαρό, icon button
   ========================================================================== */

.home-hero__search {
	margin-top: 2rem;
	max-width: 440px;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 0.3rem 0.3rem 0.3rem 1.3rem;
	box-shadow: 0 2px 6px rgba(24, 22, 20, 0.05), 0 14px 34px rgba(24, 22, 20, 0.07);
	transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.home-hero__search:focus-within {
	border-color: var(--ink);
	box-shadow: 0 2px 6px rgba(24, 22, 20, 0.06), 0 18px 44px rgba(24, 22, 20, 0.11);
}

.home-hero__search input {
	padding: 0.75rem 0.6rem 0.75rem 0;
	font-size: 0.95rem;
}

.home-hero__search input::placeholder { color: var(--ink-muted); }

.home-hero__search button {
	width: 42px;
	height: 42px;
	flex: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border-radius: 50%;
	background: var(--ink);
	color: #fff;
	cursor: pointer;
	border: 0;
	transition: background 0.2s var(--ease), transform 0.2s var(--ease);
}

.home-hero__search button:hover { background: var(--dot); transform: scale(1.06); }

/* Panel αποτελεσμάτων κάτω από το pill */
.home-hero__results {
	top: calc(100% + 10px);
	left: 0;
	right: 0;
	border: 1px solid var(--line);
	border-radius: 16px;
	box-shadow: 0 28px 60px rgba(24, 22, 20, 0.16);
	padding: 0.45rem;
}

/* ==========================================================================
   Ανοιχτά τώρα (hero δεξιά)
   ========================================================================== */

.open-now__label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 0 0.9rem;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ink-soft);
}

.open-now__pulse {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #1d9e55;
	box-shadow: 0 0 0 0 rgba(29, 158, 85, 0.45);
	animation: vlgm-pulse 2s ease-out infinite;
}

@keyframes vlgm-pulse {
	0% { box-shadow: 0 0 0 0 rgba(29, 158, 85, 0.45); }
	70% { box-shadow: 0 0 0 9px rgba(29, 158, 85, 0); }
	100% { box-shadow: 0 0 0 0 rgba(29, 158, 85, 0); }
}

.open-now__list {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--line);
}

.open-now__row {
	display: flex;
	align-items: center;
	gap: 0.8rem;
	padding: 0.65rem 0;
	border-bottom: 1px solid var(--line);
	text-decoration: none;
	transition: border-color 0.2s var(--ease);
}

.open-now__row:hover { border-bottom-color: var(--dot); }

.open-now__thumb {
	width: 46px;
	height: 46px;
	border-radius: 50%;
	object-fit: cover;
	flex: none;
}

.open-now__body { min-width: 0; display: flex; flex-direction: column; }

.open-now__name {
	font-family: var(--font-serif);
	font-size: 1.02rem;
	font-weight: 600;
	color: var(--ink);
	line-height: 1.25;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: color 0.2s var(--ease);
}

.open-now__row:hover .open-now__name { color: var(--dot); }

.open-now__meta { font-size: 0.78rem; color: var(--ink-soft); }
.open-now__star { color: var(--dot); font-weight: 600; }

.open-now__arr {
	margin-left: auto;
	flex: none;
	color: var(--ink-muted);
	transition: transform 0.2s var(--ease), color 0.2s var(--ease);
}

.open-now__row:hover .open-now__arr { transform: translateX(4px); color: var(--dot); }

/* ==========================================================================
   Back to top
   ========================================================================== */

.back-to-top {
	position: fixed;
	right: 1.4rem;
	bottom: 1.4rem;
	z-index: 45;
	width: 46px;
	height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border: 1px solid var(--line);
	border-radius: 50%;
	background: var(--surface);
	color: var(--ink);
	box-shadow: 0 6px 24px rgba(24, 22, 20, 0.16);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 0.25s var(--ease), transform 0.25s var(--ease), visibility 0.25s, background 0.2s var(--ease), color 0.2s var(--ease);
}

.back-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.back-to-top:hover { background: var(--ink); color: #fff; border-color: var(--ink); }

@media (max-width: 900px) {
	/* Να μην πέφτει πάνω στο κουμπί Χάρτης */
	.back-to-top { bottom: 1.3rem; right: 1rem; }
}

/* ==========================================================================
   Insider Vouliagmeni News
   ========================================================================== */

.insider {
	background: linear-gradient(160deg, #142c39 0%, #1b3a4b 60%, #22485d 100%);
	color: #f4f1ea;
	padding: 4rem 0;
}

.insider__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: 3rem;
	align-items: center;
}

@media (max-width: 900px) {
	.insider__grid { grid-template-columns: 1fr; gap: 1.75rem; }
}

.insider__eyebrow {
	margin: 0 0 0.8rem;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #9fb6c1;
}

.insider__title {
	margin: 0;
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: clamp(1.6rem, 3vw, 2.3rem);
	letter-spacing: -0.01em;
}

.insider__title em { font-style: italic; color: #c8a35f; }
.insider__dot { color: var(--dot); }

.insider__sub {
	margin: 0.7rem 0 0;
	font-size: 0.95rem;
	color: rgba(244, 241, 234, 0.7);
	max-width: 42ch;
}

.insider__hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }

.insider__fields {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.6rem;
}

.insider__fields input {
	border: 1px solid rgba(244, 241, 234, 0.25);
	background: rgba(255, 255, 255, 0.06);
	color: #fff;
	font: inherit;
	font-size: 0.92rem;
	padding: 0.8rem 1rem;
	border-radius: 2px;
	transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}

.insider__fields input::placeholder { color: rgba(244, 241, 234, 0.55); }

.insider__fields input:focus {
	outline: none;
	border-color: #fff;
	background: rgba(255, 255, 255, 0.1);
}

.insider__btn {
	cursor: pointer;
	border: 0;
	border-radius: 2px;
	background: #f4f1ea;
	color: var(--aegean-deep);
	font: inherit;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.8rem 1rem;
	transition: background 0.2s var(--ease), color 0.2s var(--ease);
}

.insider__btn:hover { background: var(--dot); color: #fff; }
.insider__btn[disabled] { opacity: 0.6; cursor: wait; }

.insider__msg {
	margin: 0.7rem 0 0;
	min-height: 1.3em;
	font-size: 0.88rem;
	color: #9fe0b6;
}

.insider__msg.is-error { color: #ffb4b4; }

@media (max-width: 560px) {
	.insider__fields { grid-template-columns: 1fr; }
}

/* Sponsored κάρτα στο κινητό: ολόκληρη γραμμή */
@media (max-width: 640px) {
	.places-grid .promo-card,
	.places-grid--split .promo-card { grid-column: 1 / -1; }
	.promo-card__link, .promo-card__html { min-height: 240px; }
}
