/* Reset & Base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body {
  font-family: 'Poppins', sans-serif;
  background: #fff;
  color: #333;
  line-height: 1.6;
}


.yellow-bold {
  color: #f4d35e;  /* Κίτρινο */
  font-weight: 700; /* Bold */
}

.white-bold {
  color: #fff;     /* Άσπρο */
  font-weight: 700; /* Bold */
}


/* Header Fade-In + Slide Down */
.main-header {
  opacity: 0;
  transform: translateY(-20px);
  animation: headerIn 0.8s forwards 0.2s;
  background: #111;
  padding: 1rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@keyframes headerIn {
  to { opacity:1; transform:translateY(0); }
}

/* Logo & Nav */
.header-left {
  display: flex;
  align-items: center;
}
.logo { height: 80px; width: auto; }
.logo-text {
  color: #fff;
  font-weight: 600;
  font-size: 3.2rem;
  margin-left: 2rem;
  border-bottom: none;
  /* υπερισχύουν οι προηγούμενες ιδιότητες (font-weight, font-family κτλ) */
  font-weight: 900;        /* extra‐bold */
  font-style: italic;      /* italic */
  
  /* διπλό περίγραμμα (double‐struck) με text‐shadow */
  text-shadow:
    1px 1px 0 #111,
   -1px -1px 0 #111,
    1px -1px 0 #111,
   -1px 1px 0 #111;
}
.logo-highlight { color: #f4d35e; }

nav ul {
  display: flex;
  gap: 1.5rem;
  list-style: none;
}
nav a {
  padding: 0.2rem 0.4rem;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  transition: color 0.3s ease;
}
nav a:hover {
  color: #f4d35e;
  text-shadow:
    0 0 4px #f4d35e,
    0 0 8px #f4d35e,
    0 0 12px #f4d35e,
    0 0 16px rgba(244,211,94,0.5);
}

/* HERO */
.hero {
  background: #111;
  color: #fff;
  padding: 0 5rem 3rem; /* λιγότερο κενό κάτω */
  text-align: center;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-content {
  max-width: 800px;
  z-index: 2;
}
.hero-content h1 {
  font-size: 2.8rem;
  margin-bottom: 1rem;
}
.hero-content .brand { color: #f4d35e; }
.hero-content p {
  font-size: 1.2rem;
  color: #ccc;
  margin-bottom: 2rem;
}
.hero-buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
}

/* Buttons */
.btn {
  padding: 0.75rem 1.5rem;
  border-radius: 30px;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.3s, background 0.3s, color 0.3s;
}
.btn.primary {
  background: #f4d35e;
  color: #111;
}
.btn.primary:hover {
  background: #e6c84d;
  transform: translateY(-2px);
}
.btn.secondary {
  background: transparent;
  border: 2px solid #f4d35e;
  color: #f4d35e;
}
.btn.secondary:hover {
  background: #f4d35e;
  color: #111;
  transform: translateY(-2px);
}

.hero-bottom {
  background: #fff;
  padding: 5rem 2rem 7rem; /* top 6rem, sides 2rem, bottom 10rem */
  text-align: center;
}

.hero-bottom-content {
  max-width: 700px;
  margin: 0 auto;
}
.hero-bottom-content h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}
.hero-bottom-content p {
  font-size: 1.1rem;
  line-height: 1.8;
  max-width: 600px;
  margin: 0 auto;
}
/* ======================
   SERVICES SECTION
   ====================== */
.services {
  background: #111;
  padding: 4rem 2rem 6rem;
  text-align: center;
}

.services-title {
  color: #ffffff;
  font-size: 2.5rem;
  margin-bottom: 2.5rem;
}

/* grid-like flex container */
.services-container {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
}

/* Modern “glass” cards */
.service-card {
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(8px);
  border: none;
  border-radius: 16px;
  padding: 2.5rem 1.5rem;
  width: 300px;
  max-width: 90%;
  color: #fff;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.service-card .service-icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: #f4d35e;
}

.service-card h3 {
  font-size: 1.4rem;
  margin: 0.5rem 0 1rem;
   color: #f4d35e;
}

.service-card p {
  font-size: 1rem;
  line-height: 1.6;
  color: #ccc;
  margin: 0;
}

.service-card:hover {
  transform: translateY(-10px) scale(1.03);
  box-shadow: 0 8px 20px rgba(0,0,0,0.5);
  background: rgba(244,211,94,0.1);
}

/* Scroll-reveal */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.fade-in.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
.delay-1.visible { transition-delay: 0.4s; }
.delay-2.visible { transition-delay: 0.8s; }
.delay-3.visible { transition-delay: 1.2s; }
.delay-4.visible { transition-delay: 1.6s; }

/* Responsive */
@media (max-width: 768px) {
  .services-container {
    flex-direction: column;
    gap: 1.5rem;
  }
  .service-card {
    width: 100%;
    max-width: 400px;
  }
}
/* remove underline from service-card links */
.services-container a.service-card {
  text-decoration: none;
  color: inherit; /* για να μην αλλάζει το χρώμα του κειμένου στο hover */
}

/* αν θες επιπλέον να διασφαλίσεις ότι ούτε οι τίτλοι ούτε τα παραγράφοι παίρνουν underline */
.services-container a.service-card h3,
.services-container a.service-card p {
  text-decoration: none;
}
/* ——————————————————————
   Background image στις κάρτες
   —————————————————————— */

/* Κοινό στυλ για όλες τις κάρτες αν θέλεις εικόνα */
.services-container .service-card {
  position: relative;
  overflow: hidden;
}

/* Εδώ ορίζεις ποια κάρτα παίρνει ποια εικόνα:
   nth-child(1) → πρώτη, nth-child(2) → δεύτερη, κ.ο.κ. */
/* ————————————————————————————————
   Background‐image + overlay στις 3 κάρτες
   ———————————————————————————————— */

/* Κοινά για όλες τις κάρτες */
.services-container .service-card {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

/* Ψευδοστοιχείο ::before με την εικόνα φόντου */
.services-container .service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.4);
  transition: filter 0.3s ease;
  z-index: 0;
}

/* 1η κάρτα */
.services-container .service-card:nth-child(1)::before {
  background-image: url('../images/example.1.png');
  
}

/* 2η κάρτα */
.services-container .service-card:nth-child(2)::before {
  background-image: url('../images/example2.png');
}

/* 3η κάρτα */
.services-container .service-card:nth-child(3)::before {
  background-image: url('../images/example4.png');
}



/* 1η κάρτα */
.services-container .service-card:nth-child(4)::before {
  background-image: url('../images/example10.png');
  
}
/* Βάζουμε το εικονίδιο, τίτλο και παράγραφο πάνω από το ::before */
.services-container .service-card > * {
  position: relative;
  z-index: 1;
}

/* Hover‐εφέ στην κάρτα (background & shadow) */
.services-container .service-card:hover {
  background-color: rgba(255,255,255,0.1);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}

/* Όταν κάνουμε hover, φωτίζουμε και το φόντο‐εικόνα */
.services-container .service-card:hover::before {
  filter: brightness(0.6);
}
/* Εφαρμόζουμε το scroll-reveal και στις κάρτες υπηρεσιών */
.services-container .service-card {
  /* αρχικά κρυφές & κάτω */
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

/* όταν μπαίνουν στο viewport */
.services-container .service-card.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* διατηρούμε τις ήδη καθορισμένες καθυστερήσεις */
.services-container .service-card.delay-2.visible { transition-delay: 0.8s; }
.services-container .service-card.delay-3.visible { transition-delay: 1.2s; }
.services-container .service-card.delay-4.visible { transition-delay: 1.6s; }

/* Σωστή ευθυγράμμιση bullets & κειμένου */
.services-container .service-card ul {
  padding-left: 1.2rem; /* ίδια αρχή για όλα */
  margin: 0;
}

.services-container .service-card ul li {
  position: relative;
  padding-left: 0.8rem; /* απόσταση κειμένου από bullet */
  color: #fff; /* λευκό κείμενο */
  line-height: 1.6;
  
}

.services-container .service-card ul li::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0.1em; /* ώστε να κάθεται στο ίδιο ύψος με το κείμενο */
  color: #f4d35e; /* κίτρινο bullet */
  font-size: 1.1em;
  line-height: 1.6;
   content: none !important; /* καταργεί τις κουκκίδες */
}


/* Zoom μόνο στην εικόνα φόντου */
.services-container .service-card::before {
  transition: transform 0.4s ease;
}

.services-container .service-card:hover::before {
  transform: scale(1.1);
}


/* ===== FORM SECTION ===== */
.form-section {
  background: #fff;
  padding: 3rem 2rem;
  text-align: center;
}

.form-toggle {
  margin-bottom: 1rem;
}

/* αρχικά κρυφό το iframe-container */
.form-container {
  display: none;
  max-width: 500px;      /* μικρότερο παράθυρο */
  width: 100%;           /* ώστε να συρρικνώνεται στο container */
  margin: 0 auto;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  border-radius: 8px;
  overflow: hidden;
}

/* στυλ για το ίδιο το iframe */
.form-container iframe {
  width: 100%;
  height: 600px;         /* σταθερό ύψος παραθύρου */
  border: none;
}


/* ——————————————————————————————
   Modern Contact Section
   —————————————————————————————— */
.contact-section {
  background: #111;
  color: #fff;
  padding: 4rem 2rem;
  text-align: center;
}
.contact-container {
  max-width: 600px;
  margin: 0 auto;
}
.contact-section h2 {
  font-size: 2.4rem;
  margin-bottom: 0.25rem;
}
.contact-section p {
  color: #ccc;
  margin-bottom: 1.5rem;
}

/* Social icons */
.social-links {
  margin-bottom: 2rem;
}
.social-links a {
  display: inline-block;
  margin: 0 0.5rem;
  font-size: 1.6rem;
  color: #f4d35e;
  transition: transform 0.2s, color 0.2s;
}
.social-links a:hover {
  color: #fff;
  transform: scale(1.2);
}
/* —————————————————————————————————————————————————————
   Contact Form (Καθαρισμένο)
   ————————————————————————————————————————————————————— */

/* Box-sizing */
*, *::before, *::after {
  box-sizing: border-box;
}
/* ————————————————
   Floating‐label replacement
   ———————————————— */

.contact-form {
  max-width: 600px;
  margin: 2rem auto;
  background: #1a1a1a;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.7);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.form-row {
  display: flex;
  gap: 1rem;
}
@media (max-width: 600px) {
  .form-row { flex-direction: column; }
}
/* Input/textarea χωρίς placeholder, με label πάντα από πάνω */
.input-group {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.input-group.full {
  width: 100%;
}
.input-group label {
  margin-bottom: 0.5rem;
  color: #f4d35e;
  font-size: 0.9rem;
}
.input-group input,
.input-group textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  background: #222;
  border: 1px solid #333;
  border-radius: 6px;
  color: #fff;
  font-size: 1rem;
  line-height: 1.4;
  transition: border-color 0.2s, background 0.2s;
}
.input-group input:focus,
.input-group textarea:focus {
  border-color: #f4d35e;
  background: #2a2a2a;
  outline: none;
}
/* Σταθερό ύψος textarea */
.input-group textarea {
  resize: none;
  height: 150px;
}

/* Υπόλοιπα (κουμπί, reveal κ.λπ.) παραμένουν ίδια */


/* Button */
.contact-form button {
  align-self: center;
  padding: 0.75rem 2.5rem;
  background: #f4d35e;
  color: #111;
  border: none;
  border-radius: 30px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: background 0.2s, transform 0.2s;
}

.contact-form button:hover {
  background: #e6c84d;
  transform: translateY(-2px);
}

.contact-form button i {
  transition: transform 0.2s;
}
.contact-form button:hover i {
  transform: translateX(4px);
}

/* Scroll‐reveal */
.contact-section,
.contact-form,
.contact-form button {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.contact-section.visible,
.contact-form.visible,
.contact-form button.visible {
  opacity: 1;
  transform: translateY(0);
}
/* 1. Γενικό reset placeholder (αφαιρούμε placeholders) */
/* ––––––––––––––––––––––––––––––––––––––––––––––––––––––*/
/* (έχουμε ήδη αφαιρέσει ό,τι placeholder attribute υπήρχε) */

/* 2. Override browser-autofill styling */
input:-webkit-autofill,
textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #222 inset !important;
  box-shadow: 0 0 0px 1000px #222 inset !important;
  -webkit-text-fill-color: #fff !important;
}

/* 3. Σταθερό styling των πεδίων */
.input-group input,
.input-group textarea {
  background: #222;
  border: 1px solid #333;
  /* υπόλοιπα όπως είχες */
}
/* ==========================================================================
   Footer & Scroll-to-Top Button
   ========================================================================== */

/* ————————————————————————— 
   Footer styles 
   ————————————————————————— */
.site-footer {
  background: #fff;
  border-top: 1px solid #eee;
  padding: 1.5rem 1rem;
}
.site-footer .footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1rem 2rem;
}
.site-footer .footer-copy {
  position: relative;
  color: #333;
  font-size: 0.9rem;
  font-weight: 700;
  padding-right: 1.5rem;
}
.site-footer .footer-copy::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 1px;
  height: 1.2rem;
  background: #ddd;
}
.site-footer .footer-contact a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: #333;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.3s ease;
}
.site-footer .footer-contact a i {
  transition: color 0.3s ease, transform 0.3s ease;
}
.site-footer .footer-contact a:hover {
  color: #f4d35e;
}
.site-footer .footer-contact a:hover i {
  color: #f4d35e;
  transform: translateY(-2px);
}

/* ————————————————————————— 
   Scroll-to-top button 
 /* ————————————————————————— 
   Scroll-to-top button as top-rounded pill
   ————————————————————————— */
.scroll-top {
  position: fixed;
  right: 1.5rem;
  bottom: 2rem;
  /* pill shape, μόνο πάνω γωνίες στρογγυλεμένες */
  width: 3.5rem;
  height: 4.5rem;
  background: rgba(255,255,255,0.9);
  border: none;
  border-top-left-radius: 2rem;
  border-top-right-radius: 2rem;
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  color: #333;
  font-size: 1.5rem;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: 
    opacity 0.4s ease,
    transform 0.3s ease,
    background 0.3s ease,
    color 0.3s ease;
  z-index: 999;
}
.scroll-top.show {
  opacity: 1;
  visibility: visible;
}
.scroll-top i {
  transition: transform 0.3s ease;
}
/* hover: μετατρέπουμε το background σε κίτρινο και ανυψώνουμε ελαφρώς */
.scroll-top:hover {
  background: #f4d35e;
  color: #111;
  transform: translateY(-3px) scale(1.05);
}
.scroll-top:hover i {
  transform: translateY(-2px);
}


/* ————————————————————————— 
   Responsive tweaks 
   ————————————————————————— */
@media (max-width: 600px) {
  .site-footer .footer-inner {
    flex-direction: column;
    gap: 0.75rem;
  }
}

/* ——————————————————————
   Transform Widget: compact card style
   —————————————————————— */
.transform-widget {
  background: #fff;
  padding: 3rem 2rem;
}
.transform-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
  align-items: center;
}
/* ————————————————————————————————
   Transform Widget: περιορισμός πλάτους & στυλ
   ———————————————————————————————— */
.transform-widget .transform-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  padding: 4rem 1rem;
}

/* Κουτί του slider: μικρότερο max-width */
.transform-slider {
  max-width: 350px;         /* εσύ ρύθμισε το όσο θες */
  width: 100%;
  overflow: visible;        /* για να φαίνονται οι γείτονες */
}

/* swiper-wrapper */
.transform-slider .swiper-wrapper {
  overflow: visible;
  display: flex;
  align-items: center;
}

/* κάθε slide: δίνει minimum width αλλά επιτρέπει shrink/expand */
.transform-slider .swiper-slide {
  flex: 0 0 auto;
  width: 100%;              /* το slide παίρνει όλο το διαθέσιμο πλάτος (max 500px) */
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

/* εικόνα γεμίζει πλήρως το slide χωρίς να στρεβλώνει */
.transform-slider .swiper-slide img {
  display: block;
  width: 100%;
  height: 450px;            /* σταθερό ύψος — ρύθμισέ το ό,τι θες */
  object-fit: cover;
}

/* navigation arrows styling */
.transform-slider .swiper-button-prev,
.transform-slider .swiper-button-next {
  color: #f4d35e;
}

/* pagination bullets */
.transform-slider .swiper-pagination-bullet {
  background: #ddd;
  opacity: 1;
}
.transform-slider .swiper-pagination-bullet-active {
  background: #f4d35e;
}

/* το κείμενο δίπλα */
.transform-text {
  max-width: 350px;
  text-align: left;
}


/* Responsive */
@media (max-width: 800px) {
  .transform-container {
    grid-template-columns: 1fr;
  }
}
 /* ημερομηνία πάνω αριστερά */
.slide-date {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: rgba(0,0,0,0.6);
  color: #fff;
  font-size: 0.8rem;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
}

/* TEXT CARD */
.transform-text {
  flex: 1 1 0;
}
.about-card {
  background: #f8f8f8;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.05);
}
.about-card h3 {
  font-size: 1.75rem;
  margin-bottom: 1rem;
}
.about-card p {
  font-size: 1rem;
  line-height: 1.6;
}

/* desktop → slider + κείμενο δίπλα
   mobile/tablet → stack */
@media (max-width: 768px) {
  .transform-container {
    flex-direction: column;
  }
  .transform-slider,
  .transform-text {
    width: 100%;
  }
  .transform-text {
    margin-top: 1.5rem;
  }
}

/* fade-in classes */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}
/* delays */
.delay-1 { transition-delay: 0.2s }
.delay-2 { transition-delay: 0.4s }
.delay-3 { transition-delay: 0.6s }
.delay-4 { transition-delay: 0.8s }
.delay-5 { transition-delay: 1s }

/* Dropdown container */
nav ul li.dropdown {
  position: relative;
}

/* Dropdown menu */
nav ul li .dropdown-menu {
  position: absolute;
  top: calc(100% + 5px); /* Μικρό κενό από το μενού */
  left: 0;
  background: rgba(17, 17, 17, 0.9); /* Ελαφρώς πιο σκούρο ημιδιάφανο */
  backdrop-filter: blur(8px); /* Θολό background */
  padding: 0.25rem 0; /* Μικρό padding */
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.3);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  transition: opacity 0.25s ease, transform 0.25s ease;
  list-style: none;
  min-width: 140px; /* Πιο μικρό πλάτος */
  z-index: 999;
  display: flex;
  flex-direction: column; /* Κάθετη στοίχιση */
  align-items: flex-start;
}

/* Κάθε στοιχείο */
nav ul li .dropdown-menu li {
  display: block;
  width: 100%;
}
/* Links του dropdown - μικρότερο κενό */
nav ul li .dropdown-menu li a {
  display: block;
  padding: 0.25rem 0.5rem; /* μικρότερο κάθετο padding */
  font-size: 0.85rem;
  line-height: 0.2; /* πιο κοντά οι γραμμές */
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  transition: all 0.2s ease;
  position: relative;
  white-space: nowrap;
}

/* Εφέ hover με κίτρινη γραμμή αριστερά */
nav ul li .dropdown-menu li a:hover {
  color: #f4d35e;
  text-shadow: 0 0 4px #f4d35e;
}

nav ul li .dropdown-menu li a::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 3px;
  height: 100%;
  background: #f4d35e;
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.3s ease;
}

nav ul li .dropdown-menu li a:hover::before {
  transform: scaleY(1);
}

/* Εμφάνιση dropdown */
nav ul li.dropdown:hover .dropdown-menu {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* iOS: μην “φουσκώνει” fonts αυτόματα */
html { -webkit-text-size-adjust: 100%; }

/* ===============================
   UNIFORM MOBILE HERO (improved)
   =============================== */
@media (max-width: 768px) {
  /* “κουμπιά” για ενιαία κλίμακα */
  :root{
    --m-col: min(88vw, 24rem);      /* σταθερό πλάτος στήλης */
    --hero-top: max(1.2rem, env(safe-area-inset-top));
  }

  /* Header (ασφαλής ζώνη για iPhone) */
  .main-header{
    padding: calc(.6rem + var(--hero-top)) 1rem .8rem !important;
  }
  /* ΔΙΟΡΘΩΣΗ clamp (σωστή σειρά: min, preferred, max) */
  .main-header .logo-text{
    font-size: clamp(2.2rem, 2.8vw + 1rem, 3.1rem) !important;
    margin-left: 1rem !important;
  }

  /* HERO wrapper: ίδιο κέντρο/ύψος παντού */
  .hero{
    padding: 2rem 1rem 2.4rem env(safe-area-inset-right) !important;
    min-height: 68vh !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Ίδια “στήλη” σε όλα τα κινητά */
  .hero-content{
    width: var(--m-col) !important;
    max-width: var(--m-col) !important;
    margin-inline: auto !important;
  }

  /* Τίτλος */
  .hero-content h1{
    font-size: clamp(2.1rem, 4.4vw + .9rem, 2.6rem) !important;
    line-height: 1.22 !important;
    margin-bottom: 1rem !important;
    letter-spacing: .2px;
  }

  /* Brand μέσα στο H1 */
  .hero .logo-text{
    font-size: clamp(2.2rem, 4.8vw + .8rem, 2.7rem) !important;
    line-height: 1.1 !important;
    display: inline-block;
  }

  /* Υπότιτλος */
  .hero-content p{
    font-size: clamp(.98rem, 1.8vw + .6rem, 1.06rem) !important;
    margin-bottom: 1.2rem !important;
  }

  /* Κουμπιά: ίδια διάσταση/μάσκα */
  .hero-buttons{
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: .9rem !important;
    flex-wrap: wrap;
  }
  .hero-buttons .btn{
    min-width: 8.2rem !important;
    padding: .78rem 1.32rem !important;
    font-size: 1rem !important;
    border-radius: 999px !important;
    text-align: center;
  }
}

/* Πολύ στενά (320–360px): κρατάμε αναλογίες */
@media (max-width: 380px){
  :root{ --m-col: min(92vw, 22rem); }
  .hero-content h1{
    font-size: clamp(1.9rem, 5.2vw + .7rem, 2.25rem) !important;
  }
  .hero .logo-text{
    font-size: clamp(2rem, 5.6vw + .6rem, 2.3rem) !important;
  }
}

/* High‑DPI smoothing (ιδίως σε iOS) */
@media (min-resolution: 2dppx) and (max-width: 768px){
  .hero{ -webkit-font-smoothing: antialiased; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero, .hero *{ animation: none !important; transition: none !important; }
}


@media (max-width: 768px) {
  .hero-content h1 { text-align: center !important; } /* Κείμενο κεντραρισμένο */
  .hero-content h1 .logo-text {
    display: block;
    text-align: left;       /* Μόνο το brand πάει αριστερά */
    margin-left: 5.2rem;      /* Απόσταση από την άκρη */
  }
}

