@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;500;700&display=swap');

/* ασπρόμαυρη παλέτα + καθαρές αποστάσεις */
:root {
  --bg: #fff;
  --fg: #111;
  --muted: #555;
  --rule: #e6e6e6;
  --maxw: 80rem;
  --space: 3.5rem;   /* κατακόρυφη απόσταση ανά ενότητα */

  /* νέο: ύψος header για υπολογισμό του full-screen intro */
  --header-h: 64px;

  /* ===== σταθερό φόντο εικόνας με blur ===== */
  --bg-img: url('C:/Users/georg/Desktop/g2/static/images/Rentals/43.jpg'); /* άλλαξε εδώ με τη δική σου εικόνα */
  --bg-blur: 4px;                          /* ποσότητα blur */
  --bg-dim: 0.28;                          /* φωτεινότητα overlay (0=καμία, 1=λευκό) */
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

/* ===== ΣΤΑΘΕΡΟ BACKGROUND IMAGE ΜΕ BLUR & ΚΑΛΥΨΗ ===== */
html::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background-image: var(--bg-img);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.04);
  filter: blur(var(--bg-blur));
  will-change: transform;
}
html::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background: rgba(255,255,255,var(--bg-dim));
}

@media (forced-colors: active) {
  html::before, html::after { display: none; }
}
@media (prefers-reduced-transparency: reduce) {
  html::after { background: rgba(255,255,255,.5); }
}

body {
  margin: 0;
  font-family: 'Montserrat', system-ui, sans-serif;
  line-height: 1.6;
  background: transparent;
  color: var(--fg);
}

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 1rem; }

:target { scroll-margin-top: calc(var(--header-h) + 12px); }

.skip {
  position: absolute; left: -9999px; top: 0;
  background: #000; color: #fff; padding: .5rem .75rem; z-index: 1000;
}
.skip:focus { left: .5rem; }

.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

.header {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: var(--header-h);
  padding: 0 1rem;
  background: rgba(255,255,255,.88);
  border-bottom: 1px solid var(--rule);
  backdrop-filter: saturate(140%) blur(6px);
  -webkit-backdrop-filter: saturate(140%) blur(6px);
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
}

.brand a { color: inherit; text-decoration: none; font-weight: 700; letter-spacing: .4px; }

.nav { list-style: none; display: flex; gap: 1rem; margin: 0; padding: 0; }
.nav a {
  color: inherit; text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 0% 2px;
  background-position: 0 100%;
  transition: background-size .25s ease, color .25s ease;
  min-width: 24px; min-height: 24px;
  padding: .5rem .75rem;
  display: inline-flex; align-items: center;
}
.nav a:hover,
.nav a:focus { background-size: 100% 2px; }

a:focus-visible,
button:focus-visible,
video:focus-visible {
  outline: 2px solid #000;
  outline-offset: 2px;
}

h1, h2 { margin: 0 0 0.75rem; line-height: 1.25; }
p { margin: 0 0 1rem; color: var(--muted); }

.section { padding: var(--space) 0; border-top: 1px solid var(--rule); }
.section:first-of-type { border-top: 0; padding-top: 1.5rem; }

/* ===================== */
/* FULL-SCREEN INTRO VIDEO */
/* ===================== */

.section--intro {
  padding: 0;
  border-top: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.intro-video {
  display: block;
  width: 100vw;
  height: calc(100vh - var(--header-h));
  height: calc(100svh - var(--header-h));
  max-height: none;
  border: none;
  object-fit: cover;
  object-position: center;
  transition: box-shadow .25s ease, transform .25s ease;
}
.intro-video:hover { box-shadow: 0 12px 28px rgba(0,0,0,.08); transform: translateY(-1px); }

.lede { margin: .85rem auto 1.25rem; max-width: var(--maxw); padding: 0 1rem; }

.v-wrap { position: relative; }
.intro-video { pointer-events: none; }

.v-toggle {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  min-width: 44px; min-height: 44px;
  border: 1px solid var(--rule);
  background: rgba(255,255,255,.85);
  color: #111;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: inline-flex; align-items: center; justify-content: center;
  font: 500 16px/1 'Montserrat', system-ui, sans-serif;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.v-toggle:hover,
.v-toggle:focus-visible { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(0,0,0,.08); }
.v-toggle.is-paused { background: rgba(0,0,0,.85); color: #fff; border-color: rgba(255,255,255,.35); }

.gallery {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem; padding: 0; list-style: none;
}
figure { margin: 0; }
img {
  width: 100%; height: auto; display: block; border: 1px solid var(--rule);
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
img:hover { transform: scale(1.015); box-shadow: 0 10px 22px rgba(0,0,0,.08); filter: saturate(105%); }

.reel-video {
  width: 100%; border: 1px solid var(--rule); border-radius: 2px;
  transition: box-shadow .25s ease, transform .25s ease;
}
.reel-video:hover { box-shadow: 0 12px 28px rgba(0,0,0,.08); transform: translateY(-1px); }

.footer { padding: 1.25rem 1rem; border-top: 1px solid var(--rule); text-align: center; font-size: .95rem; color: var(--muted); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation: none !important; transition: none !important; }
}

@media (forced-colors: active) {
  .header { background: Canvas; border-bottom: 1px solid CanvasText; }
  a:focus-visible, button:focus-visible, video:focus-visible { outline: 2px solid Highlight; }
  .intro-video, .reel-video, img { border: 1px solid CanvasText; }
}

.a11y-btn {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 101;
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  background: rgba(255,255,255,.92);
  color: #111;
  font: 700 18px/1 'Montserrat', system-ui, sans-serif;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}
.a11y-btn:hover,
.a11y-btn:focus-visible { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(0,0,0,.12); }

#a11yPanel::backdrop { background: rgba(0,0,0,.5); }
#a11yPanel {
  border: none;
  padding: 0;
  max-width: min(92vw, 520px);
  border-radius: 12px;
  overflow: hidden;
}
.a11y-panel {
  background: #fff;
  color: #111;
  padding: 1rem 1rem 0.75rem;
}
.a11y-panel h2 {
  margin: 0 0 .75rem 0;
  font-size: 1.1rem;
}
.a11y-row {
  display: flex; gap: .6rem; align-items: center;
  padding: .5rem 0;
}
.a11y-actions {
  display: flex; gap: .75rem; justify-content: flex-end;
  padding: .75rem 0 1rem;
}
.a11y-actions button {
  min-width: 44px; min-height: 44px;
  padding: .5rem .9rem;
  border: 1px solid var(--rule);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
}
.a11y-actions button:focus-visible { outline: 2px solid #000; outline-offset: 2px; }

body.a11y-lgtext { font-size: 112%; }
body.a11y-contrast {
  --bg: #ffffff;
  --fg: #000000;
  --muted: #222;
  --rule: #000;
  background: var(--bg);
  color: var(--fg);
}
body.a11y-contrast .header { background: #fff; border-bottom-color: #000; }
body.a11y-contrast img,
body.a11y-contrast .reel-video,
body.a11y-contrast .intro-video { border: 1px solid #000 !important; }

body.a11y-reduced { }
body.a11y-reduced * { transition: none !important; animation: none !important; }
body.a11y-spacing p { line-height: 1.85; letter-spacing: .2px; }

body.a11y-lgtext .nav a { padding: .6rem 1rem; }

.contact-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem 0;
  display: grid;
  gap: .6rem;
}
.contact-list a {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: inherit;
  text-decoration: none;
  min-height: 24px;
  padding: .25rem .25rem;
}
.contact-list a:hover,
.contact-list a:focus-visible { text-decoration: underline; }

.icon { display: inline-flex; }
.icon svg { display: block; }

.socials {
  display: flex;
  gap: 1rem;
  margin-top: .75rem;
}
.socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: #111;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.socials a:hover,
.socials a:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
}

h1, h2, .lede { text-align: center; }

.section > p,
#works > p,
#reel > p,
#about > p,
#contact > p,
details > p {
  text-align: center;
  max-width: 68ch;
  margin-left: auto;
  margin-right: auto;
}

figcaption { text-align: center; }

.contact-list { justify-items: center; }
.contact-list a { text-align: center; }
.socials { justify-content: center; }
details > summary { text-align: center; }

html.a11y-invert {
  filter: invert(1) hue-rotate(180deg);
}

html.a11y-invert body,
html.a11y-invert p,
html.a11y-invert h1,
html.a11y-invert h2,
html.a11y-invert h3,
html.a11y-invert h4,
html.a11y-invert h5,
html.a11y-invert h6,
html.a11y-invert a,
html.a11y-invert li,
html.a11y-invert span {
  color: #ff0000 !important;
}

/* ===== ΚΑΡΤΕΣ ΚΑΤΗΓΟΡΙΩΝ (για το #works) ===== */
.grid-3{
  display:grid;
  gap:1.25rem;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin:1.5rem 0 0;
}

.cat-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
  border:1px solid var(--rule);
  border-radius:1rem;
  overflow:hidden;
  background:#fff;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.cat-card:hover,
.cat-card:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(0,0,0,.10);
  border-color:rgba(0,0,0,.08);
}

.cat-media{
  aspect-ratio:16/10;
  background-size:cover;
  background-position:center;
}

.cat-body{ padding:1rem 1rem 1.25rem; }
.cat-body h3{ margin:.25rem 0 0; font-size:1.1rem; text-align:center; }

.grant-badge {
  position: fixed;
  bottom: 15px;   /* απόσταση από κάτω */
  left: 15px;     /* απόσταση από αριστερά */
  width: 500px;   /* προσαρμόζεις ανάλογα το μέγεθος */
  height: auto;
  z-index: 9999;  /* να μην το καλύπτει άλλο στοιχείο */
}

/* ===================================================== */
/* ==================  ΜΟΝΟ ΓΙΑ ΚΙΝΗΤΑ  ================= */
/* ===================================================== */
.hamburger{ /* default: κρυφό σε desktop */
  display:none;
  width:44px; height:44px;
  border:1px solid var(--rule);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  position:relative;
}
.hamburger::before,
.hamburger::after,
.hamburger span{
  content:"";
  position:absolute; left:50%; transform:translateX(-50%);
  width:20px; height:2px; background:var(--fg); border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
.hamburger::before{ top:14px }
.hamburger span{ top:21px }
.hamburger::after{ top:28px }
.hamburger[aria-expanded="true"]::before{ transform:translateX(-50%) rotate(45deg) }
.hamburger[aria-expanded="true"]::after{  transform:translateX(-50%) rotate(-45deg) }
.hamburger[aria-expanded="true"] span{ opacity:0 }

/* Drawer (κουρτίνα) */
.mobile-drawer{
  position:fixed; inset:0; z-index:1000;
  background: rgba(255, 255, 255, 0.568); /* αντί για #fff */
  transform:translateX(-100%);
  transition:transform .28s ease-out;
  display:flex; flex-direction:column;
  contain:layout paint;
}

.mobile-drawer.open{ transform:translateX(0) }

.drawer-head{
  height:var(--header-h);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 18px;
  border-bottom:1px solid var(--rule);
}
.drawer-title{ font-weight:700 }
.drawer-close{
  width:44px; height:44px; border:1px solid var(--rule);
  border-radius:12px; background:#fff; position:relative; cursor:pointer;
}
.drawer-close::before,
.drawer-close::after{
  content:""; position:absolute; left:50%; top:50%;
  width:20px; height:2px; background:var(--fg); border-radius:2px;
  transform-origin:center;
}
.drawer-close::before{ transform:translate(-50%,-50%) rotate(45deg) }
.drawer-close::after{  transform:translate(-50%,-50%) rotate(-45deg) }

.drawer-body{ padding:18px; overflow:auto; -webkit-overflow-scrolling:touch; }

.mnav{ list-style:none; padding:0; margin:0; display:grid; gap:18px; }
.mnav a{
  display:flex; align-items:center; justify-content:space-between;
  font-weight:600; font-size:28px; line-height:1.2;
  padding:8px 4px; color:inherit; text-decoration:none;
}

/* scroll lock όταν ανοίγει το menu (θα προστίθεται από JS) */
body.no-scroll{ height:100vh; overflow:hidden; }

/* Απόκρυψη της κλασικής navbar και εμφάνιση hamburger μόνο σε κινητά */
@media (max-width: 991px){
  .nav{ display:none; }
  .hamburger{ display:inline-block; order: 1; }
  .header{ gap:.75rem; }
  .grant-badge{ width: 160px; } /* να μη σκεπάζει περιεχόμενο σε μικρές οθόνες */
}

/* ===== ABOUT section (εικόνα + κείμενο) ===== */
.about h2 { text-align: left; }

.about-wrap{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:1.5rem;
}

.about-text{
  flex:1 1 340px;
  text-align:left;
}

#about > p{ /* ακύρωση global centering μόνο εδώ */
  text-align:left;
  margin-left:0;
  margin-right:0;
}

/* ===== ABOUT PHOTO (slideshow, ποιότητα-first) ===== */
.about-photo{
  flex: 0 0 auto;
  position: relative;
  overflow: hidden;
  width: min(340px, 42vw);   /* κράτα το ≤ από το φυσικό πλάτος εικόνας */
  border-radius: 12px;
  border: 1px solid var(--rule);
  box-shadow: 0 6px 18px rgba(0,0,0,.10);
}

/* Κόλπο: το container παίρνει ύψος από την ενεργή εικόνα */
.about-photo img{
  display: block;
  width: 100%;
  height: auto;              /* φυσική αναλογία -> καθαρότερα */
  border: 0;
}

/* Στοίβαγμα και slide χωρίς να χαλάει το ύψος */
.about-photo{
  display: grid;
}
.about-photo img{
  grid-area: 1 / 1;          /* όλες στην ίδια “στοίβα” */
  opacity: 0;
  transform: translateX(100%);
  transition: transform 700ms ease, opacity 700ms ease;
  will-change: transform, opacity;
}
.about-photo img.active{
  opacity: 1;
  transform: translateX(0);
  z-index: 1;
}
.about-photo img.prev{
  opacity: 0;
  transform: translateX(-100%);
  z-index: 0;
}

/* Ακύρωση global hover εφέ μόνο εδώ */
.about-photo img:hover{
  transform: none !important;
  box-shadow: none !important;
  filter: none !important;
}

/* Mobile */
@media (max-width: 768px){
  .about-photo{ width: min(360px, 100%); }
}
