/* GDPR Cookie Consent (GR/EU) — frontend styles */

.gccgr-banner,
.gccgr-banner * { box-sizing: border-box; }

.gccgr-banner {
	--gccgr-accent: #0b6e4f;
	--gccgr-bg: #ffffff;
	--gccgr-fg: #1c2024;
	--gccgr-muted: #5a6470;
	--gccgr-border: #e4e8ec;
	position: fixed;
	left: 0;
	right: 0;
	z-index: 2147483000; /* πάνω από σχεδόν τα πάντα */
	background: var(--gccgr-bg);
	color: var(--gccgr-fg);
	border-bottom: 1px solid var(--gccgr-border);
	box-shadow: 0 2px 18px rgba(0, 0, 0, .12);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: 14px;
	line-height: 1.5;
	animation: gccgr-slide-down .35s ease;
}
.gccgr-banner.gccgr-pos-top { top: 0; }
.gccgr-banner.gccgr-pos-bottom {
	top: auto;
	bottom: 0;
	border-bottom: 0;
	border-top: 1px solid var(--gccgr-border);
	animation: gccgr-slide-up .35s ease;
}
.gccgr-banner.gccgr-theme-dark {
	--gccgr-bg: #15191e;
	--gccgr-fg: #eef1f4;
	--gccgr-muted: #aab3bd;
	--gccgr-border: #2a3038;
}

/* Εγγύηση: όταν δεν είναι hidden, εμφανίζεται (αμυντικά απέναντι σε theme CSS). */
.gccgr-banner[hidden] { display: none !important; }

/* ---------------------- Κεντραρισμένο card (στη μέση) ---------------------- */
.gccgr-banner.gccgr-pos-center {
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: rgba(12, 16, 22, .5);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	border: 0;
	box-shadow: none;
	animation: gccgr-fade .3s ease;
}
.gccgr-banner.gccgr-pos-center .gccgr-inner {
	flex-direction: column;
	align-items: stretch;
	gap: 18px;
	width: 100%;
	max-width: 440px;
	padding: 26px 26px 24px;
	background: var(--gccgr-bg);
	border: 1px solid var(--gccgr-border);
	border-radius: 18px;
	box-shadow: 0 24px 70px rgba(0, 0, 0, .38);
	animation: gccgr-pop .3s ease;
}
/* Στο κεντραρισμένο card το .gccgr-inner είναι flex-column, οπότε το
   flex-basis του .gccgr-text (φτιαγμένο για το οριζόντιο bar = πλάτος)
   μετατρέπεται σε ΥΨΟΣ και δημιουργεί τεράστιο κενό. Το μηδενίζουμε. */
.gccgr-banner.gccgr-pos-center .gccgr-text { flex: 0 0 auto; min-width: 0; }
.gccgr-banner.gccgr-pos-center .gccgr-title { font-size: 17px; margin-bottom: 6px; }
.gccgr-banner.gccgr-pos-center .gccgr-msg { font-size: 13.5px; }
.gccgr-banner.gccgr-pos-center .gccgr-actions {
	flex-direction: column;
	align-items: stretch;
	gap: 10px;
	width: 100%;
}
.gccgr-banner.gccgr-pos-center .gccgr-actions .gccgr-btn {
	width: 100%;
	padding: 12px 16px;
	font-size: 14px;
}
/* Σειρά μέσα στο card: Αποδοχή πάνω, Απόρριψη (ισότιμη) από κάτω, Ρυθμίσεις τελευταία. */
.gccgr-banner.gccgr-pos-center [data-gccgr-action="accept"] { order: 0; }
.gccgr-banner.gccgr-pos-center [data-gccgr-action="reject"] { order: 1; }
.gccgr-banner.gccgr-pos-center [data-gccgr-action="settings"] {
	order: 2;
	border: 0;
	background: transparent;
	color: var(--gccgr-muted);
	text-decoration: underline;
	padding: 4px;
	font-weight: 500;
}
.gccgr-banner.gccgr-pos-center [data-gccgr-action="settings"]:hover { color: var(--gccgr-accent); }

@keyframes gccgr-fade { from { opacity: 0; } to { opacity: 1; } }

@keyframes gccgr-slide-down { from { transform: translateY(-100%); } to { transform: translateY(0); } }
@keyframes gccgr-slide-up { from { transform: translateY(100%); } to { transform: translateY(0); } }

.gccgr-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 12px 18px;
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}
.gccgr-text { flex: 1 1 360px; min-width: 240px; }
.gccgr-title { display: block; font-weight: 700; font-size: 14px; margin-bottom: 2px; }
.gccgr-msg { color: var(--gccgr-muted); font-size: 13px; }
.gccgr-msg a { color: var(--gccgr-accent); text-decoration: underline; }

.gccgr-actions {
	display: flex;
	gap: 8px;
	flex: 0 0 auto;
	flex-wrap: wrap;
	align-items: center;
}

.gccgr-btn {
	cursor: pointer;
	border-radius: 8px;
	padding: 9px 16px;
	font-size: 13px;
	font-weight: 600;
	border: 1px solid transparent;
	transition: filter .15s ease, background .15s ease, border-color .15s ease;
	white-space: nowrap;
}
.gccgr-btn:focus-visible { outline: 2px solid var(--gccgr-accent); outline-offset: 2px; }

/* Ισότιμη προβολή: το "Απόρριψη" δεν είναι ποτέ λιγότερο εμφανές από το "Αποδοχή".
   Και τα δύο βασικά κουμπιά είναι ίδιου μεγέθους/βάρους — διαφέρουν μόνο σε χρώμα. */
.gccgr-btn-solid {
	background: var(--gccgr-accent);
	color: #fff;
}
.gccgr-btn-solid:hover { filter: brightness(1.06); }
.gccgr-btn-ghost {
	background: transparent;
	color: var(--gccgr-fg);
	border-color: var(--gccgr-border);
}
.gccgr-btn-ghost:hover { border-color: var(--gccgr-accent); color: var(--gccgr-accent); }

/* ------------------------------- Modal ------------------------------- */
.gccgr-modal {
	--gccgr-accent: #0b6e4f;
	--gccgr-bg: #ffffff;
	--gccgr-fg: #1c2024;
	--gccgr-muted: #5a6470;
	--gccgr-border: #e4e8ec;
	position: fixed;
	inset: 0;
	z-index: 2147483001;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}
.gccgr-modal.gccgr-theme-dark {
	--gccgr-bg: #15191e;
	--gccgr-fg: #eef1f4;
	--gccgr-muted: #aab3bd;
	--gccgr-border: #2a3038;
}
.gccgr-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .5);
}
.gccgr-modal-box {
	position: relative;
	background: var(--gccgr-bg);
	color: var(--gccgr-fg);
	width: min(560px, calc(100% - 32px));
	max-height: calc(100vh - 64px);
	overflow: auto;
	border-radius: 14px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
	animation: gccgr-pop .25s ease;
}
@keyframes gccgr-pop { from { transform: scale(.96); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.gccgr-modal-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 20px;
	border-bottom: 1px solid var(--gccgr-border);
}
.gccgr-modal-head h2 { margin: 0; font-size: 17px; }
.gccgr-x {
	background: none;
	border: 0;
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	color: var(--gccgr-muted);
	padding: 0 4px;
}
.gccgr-x:hover { color: var(--gccgr-fg); }

.gccgr-modal-body { padding: 8px 20px 4px; }
.gccgr-cat { padding: 14px 0; border-bottom: 1px solid var(--gccgr-border); }
.gccgr-cat:last-child { border-bottom: 0; }
.gccgr-cat-head { display: flex; align-items: center; gap: 12px; }
.gccgr-cat-label { font-weight: 600; font-size: 14px; }
.gccgr-cat-label em { color: var(--gccgr-muted); font-weight: 400; font-size: 12px; font-style: normal; }
.gccgr-cat-desc { margin: 6px 0 0 56px; color: var(--gccgr-muted); font-size: 12.5px; }

/* Switch */
.gccgr-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex: 0 0 auto; }
.gccgr-switch input { opacity: 0; width: 0; height: 0; }
.gccgr-slider {
	position: absolute;
	cursor: pointer;
	inset: 0;
	background: #c4ccd4;
	border-radius: 24px;
	transition: background .2s;
}
.gccgr-slider::before {
	content: "";
	position: absolute;
	height: 18px;
	width: 18px;
	left: 3px;
	top: 3px;
	background: #fff;
	border-radius: 50%;
	transition: transform .2s;
}
.gccgr-switch input:checked + .gccgr-slider { background: var(--gccgr-accent); }
.gccgr-switch input:checked + .gccgr-slider::before { transform: translateX(20px); }
.gccgr-switch input:disabled + .gccgr-slider { opacity: .55; cursor: not-allowed; }
.gccgr-switch input:focus-visible + .gccgr-slider { outline: 2px solid var(--gccgr-accent); outline-offset: 2px; }

.gccgr-modal-foot {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
	padding: 16px 20px;
	border-top: 1px solid var(--gccgr-border);
}

/* ----------------------------- Floating btn ----------------------------- */
.gccgr-float {
	--gccgr-accent: #0b6e4f;
	position: fixed;
	left: 18px;
	bottom: 18px;
	z-index: 2147482999;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 0;
	cursor: pointer;
	background: var(--gccgr-accent);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 14px rgba(0, 0, 0, .25);
	transition: filter .15s ease;
}
.gccgr-float:hover { filter: brightness(1.08); }
.gccgr-float:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) {
	.gccgr-banner, .gccgr-modal-box { animation: none; }
}

/* ---- v1.0.4: in-card preferences view (αντικαθιστά το ξεχωριστό modal) ---- */
.gccgr-view[hidden] { display: none !important; }
.gccgr-view { display: flex; flex-direction: column; gap: 14px; }
.gccgr-btn-link {
	background: transparent;
	border: 0;
	color: var(--gccgr-muted);
	text-decoration: underline;
	cursor: pointer;
	font-weight: 500;
	font-size: 13px;
}
.gccgr-btn-link:hover { color: var(--gccgr-accent); }
.gccgr-prefs-head { display: flex; align-items: center; gap: 10px; }
.gccgr-prefs-head .gccgr-title { margin: 0; }
.gccgr-back {
	background: transparent;
	border: 0;
	color: var(--gccgr-muted);
	cursor: pointer;
	font-size: 13px;
	padding: 4px 2px;
	white-space: nowrap;
}
.gccgr-back:hover { color: var(--gccgr-accent); }
.gccgr-prefs-body { max-height: 42vh; overflow: auto; -webkit-overflow-scrolling: touch; }

/* ============================================================================
   Responsive hardening (v1.0.5) — μηδενικό horizontal overflow ("κόψιμο από
   δεξιά") σε ΟΛΕΣ τις συσκευές + σωστό responsive layout για top/bottom bar.
   ========================================================================== */

/* 1) Καθολικό δίχτυ ασφαλείας. Η #1 αιτία που "κόβει από δεξιά" στο flexbox
   είναι το προεπιλεγμένο min-width:auto των flex items: δεν συρρικνώνονται
   κάτω από το πλάτος του περιεχομένου τους, οπότε μια μεγάλη λέξη / URL ή ένα
   κουμπί με nowrap σπρώχνει τη γραμμή πέρα από την οθόνη. Το μηδενίζουμε. */
.gccgr-inner { width: 100%; max-width: min(1200px, 100%); }

.gccgr-inner, .gccgr-view, .gccgr-view-main, .gccgr-view-prefs,
.gccgr-text, .gccgr-actions, .gccgr-prefs-head, .gccgr-prefs-body,
.gccgr-cat, .gccgr-cat-head { min-width: 0; }

/* Μεγάλες λέξεις / σύνδεσμοι σπάνε αντί να ξεχειλίζουν δεξιά */
.gccgr-title, .gccgr-msg, .gccgr-cat-label, .gccgr-cat-desc,
.gccgr-msg a { overflow-wrap: anywhere; word-break: break-word; }

.gccgr-btn { min-width: 0; max-width: 100%; }

/* 2) Top/Bottom bar: σωστό responsive ROW. Διορθώνει το τεράστιο κενό ~360px
   που προέκυπτε επειδή το .gccgr-view είναι flex-column και το flex-basis:360px
   του .gccgr-text μετατρεπόταν σε ΥΨΟΣ. Μόνο η κύρια όψη γίνεται row· η όψη
   "Προτιμήσεις" παραμένει column (σωστή στοίβαξη). */
.gccgr-banner.gccgr-pos-top .gccgr-view-main,
.gccgr-banner.gccgr-pos-bottom .gccgr-view-main {
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 18px;
}
.gccgr-banner.gccgr-pos-top .gccgr-view-main .gccgr-text,
.gccgr-banner.gccgr-pos-bottom .gccgr-view-main .gccgr-text {
	flex: 1 1 320px;
	min-width: 0;
}
.gccgr-banner.gccgr-pos-top .gccgr-view-main .gccgr-actions,
.gccgr-banner.gccgr-pos-bottom .gccgr-view-main .gccgr-actions {
	flex: 0 1 auto;
}

/* 3) safe-area (notch / home indicator) — σωστή τοποθέτηση σε όλα τα κινητά,
   ακόμη και σε landscape με εγκοπή. */
@supports (padding: max(0px)) {
	.gccgr-banner.gccgr-pos-top .gccgr-inner {
		padding-left: max(18px, env(safe-area-inset-left));
		padding-right: max(18px, env(safe-area-inset-right));
		padding-top: max(12px, env(safe-area-inset-top));
	}
	.gccgr-banner.gccgr-pos-bottom .gccgr-inner {
		padding-left: max(18px, env(safe-area-inset-left));
		padding-right: max(18px, env(safe-area-inset-right));
		padding-bottom: max(12px, env(safe-area-inset-bottom));
	}
}

/* 4) Mobile (≤640px): στοίβαξη + κουμπιά πλήρους πλάτους — ίδιο μοτίβο με το
   κεντραρισμένο popup, χωρίς καμία πιθανότητα overflow δεξιά. */
@media (max-width: 640px) {
	.gccgr-inner { padding: 12px 14px; gap: 10px; }

	.gccgr-banner.gccgr-pos-top .gccgr-view-main,
	.gccgr-banner.gccgr-pos-bottom .gccgr-view-main {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
	}
	/* Σε column context το flex-basis γίνεται ΥΨΟΣ — το μηδενίζουμε ώστε το
	   κείμενο να πιάνει το φυσικό του ύψος (αλλιώς δημιουργείται τεράστιο κενό). */
	.gccgr-banner.gccgr-pos-top .gccgr-view-main .gccgr-text,
	.gccgr-banner.gccgr-pos-bottom .gccgr-view-main .gccgr-text {
		flex: 0 0 auto;
	}

	.gccgr-actions {
		width: 100%;
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}
	.gccgr-actions .gccgr-btn {
		width: 100%;
		flex: 0 0 auto;
		text-align: center;
		white-space: normal; /* μεγάλες ετικέτες σπάνε σε 2 γραμμές αντί να κόβονται */
	}
	/* Ο σύνδεσμος "Ρυθμίσεις" μένει διακριτικός, όχι κουμπί πλήρους πλάτους */
	.gccgr-actions .gccgr-btn-link { width: auto; align-self: center; }

	.gccgr-prefs-body { max-height: 50vh; }
}

/* 5) Πολύ στενές συσκευές (≤360px) — ελαφρώς μικρότερα paddings/γραμματοσειρά. */
@media (max-width: 360px) {
	.gccgr-inner { padding: 11px 12px; }
	.gccgr-title { font-size: 13.5px; }
	.gccgr-msg { font-size: 12.5px; }
}
