/* 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;
}
.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 (max-width: 640px) {
	.gccgr-inner { padding: 12px 14px; gap: 12px; }
	.gccgr-actions { width: 100%; }
	.gccgr-actions .gccgr-btn { flex: 1 1 auto; text-align: center; }
}

@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; }
