:root{
  --bg0:#050615;
  --bg1:#0B1026;
  --card:rgba(255,255,255,.07);
  --line:rgba(255,255,255,.12);
  --text:#EAF0FF;
  --muted:#9FB0D0;

  --neonPink:#FB7185;
  --neonCyan:#22D3EE;
  --neonViolet:#7C3AED;
  --neonGreen:#22C55E;
  --neonRed:#FF2D2D;

  --shadow: 0 24px 70px rgba(0,0,0,.6);
  --radius:18px;
}

*{ box-sizing:border-box; }
html{
  height: 100%;
  background:
    radial-gradient(900px 620px at 10% 0%, rgba(124,58,237,.35) 0%, transparent 55%),
    radial-gradient(900px 620px at 90% 10%, rgba(34,211,238,.25) 0%, transparent 55%),
    radial-gradient(700px 520px at 70% 90%, rgba(251,113,133,.14) 0%, transparent 55%),
    linear-gradient(180deg,var(--bg0),var(--bg1));
  background-attachment: fixed; /* ✅ κρατάει σταθερό το gradient */
}

body{
  min-height: 100dvh;          /* ✅ σωστό ύψος σε mobile */
  margin:0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);

  background: transparent;     /* ✅ για να μην “διπλώνει” */
  overflow-y:auto;
  overflow-x:hidden;

  padding: env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
}




/* Topbar */
.topbar{
  height:58px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(14px);
  position: sticky;
  top: 0;
  z-index: 25;

  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
}
.brand{ display:flex; align-items:center; gap:10px; min-width:0; }
.brand-badge{
  width:34px;height:34px;border-radius:12px;
  background: linear-gradient(135deg, rgba(124,58,237,.9), rgba(34,211,238,.85));
  box-shadow: 0 0 24px rgba(34,211,238,.18);
  flex:0 0 auto;
}
.brand-text{
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 12px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.topbar-center{ display:flex; justify-content:center; }

.burger{
  justify-self:end;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-size: 22px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
.burger:active{ transform: translateY(1px); }

/* Drawer */
.backdrop{
  position:fixed; inset:0;
  background: rgba(0,0,0,.55);
  opacity:0; pointer-events:none;
  transition: .18s ease;
  z-index: 40;
}
.backdrop.open{ opacity:1; pointer-events:auto; }

.drawer{
  position:fixed; top:0; right:0; height:100%;
  width: 290px;
  transform: translateX(100%);
  transition: .22s ease;
  z-index: 50;
  background:rgba(10,12,28,.92) ;
  border-left: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(18px);
  padding: 14px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.drawer.open{ transform: translateX(0); }

.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding: 10px 10px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.drawer-title{
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(234,240,255,.9);
}
.drawer-close{
  width:40px;height:40px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color:#fff;
  cursor:pointer;
  font-size: 18px;
}

.menu-item{
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  font-weight: 850;
  letter-spacing:.02em;
  display:flex;
  align-items:center;
  justify-content:space-between;
  -webkit-tap-highlight-color: transparent;
}
.menu-item small{
  color: var(--muted);
  font-weight: 700;
  letter-spacing:.08em;
  text-transform: uppercase;
}
.menu-item.active{
  border-color: rgba(34,211,238,.35);
  background: linear-gradient(135deg, rgba(124,58,237,.20), rgba(34,211,238,.10));
  box-shadow: 0 0 0 1px rgba(34,211,238,.10) inset;
}

/* Pages */
.pages{ flex:1 1 auto; }
.page{
  padding: 18px 16px 30px;
  display:none;
	
}
.page.active{ display:block; }

/* Head */
.stations-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 12px;
}
.h-title{
  margin:0;
  font-weight: 950;
  letter-spacing: -0.02em;
  font-size: 18px;
}
.h-sub{
  margin:0;
  color: var(--muted);
  font-weight: 700;
  font-size: 12px;
}

/* ON AIR */
.onair{
  width: fit-content;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--neonRed);
  text-shadow: 0 0 14px rgba(255,45,45,.55);
  box-shadow: 0 0 0 1px rgba(255,45,45,.12) inset;
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
}
.onair--mini{
  padding: 6px 10px;
  font-size: 11px;
  letter-spacing: .14em;
  background: rgba(0,0,0,.28);
}
.pulse{
  width:10px;height:10px;border-radius:999px;
  background: var(--neonRed);
  box-shadow: 0 0 0 6px rgba(255,45,45,.14);
  animation: pulse 1.25s infinite;
}
.onair--mini .pulse{ width:8px; height:8px; }
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(255,45,45,.18); }
  70%{ box-shadow: 0 0 0 12px rgba(255,45,45,0); }
  100%{ box-shadow: 0 0 0 0 rgba(255,45,45,0); }
}

/* Stations GRID:
   - Phones: 2 columns
   - Big phones/landscape: 3 columns
   - Desktop: 5 columns
*/
.rail{
  display:grid;
  gap:14px;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* ✅ κινητά: 2 */
}
@media (min-width: 430px){
  .rail{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .rail{ grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

.station-card{
  border-radius: 22px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  padding: 14px;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  -webkit-tap-highlight-color: transparent;
}
.station-card::before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(220px 120px at 20% 20%, rgba(34,211,238,.22), transparent 60%),
    radial-gradient(220px 120px at 80% 10%, rgba(124,58,237,.25), transparent 60%),
    radial-gradient(240px 140px at 60% 90%, rgba(251,113,133,.14), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.station-card > *{ position:relative; z-index:1; }

.logo-wrap{
  width: 96px;
  height: 96px;
  border-radius: 999px;
  margin: 0 auto 12px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 0 1px rgba(34,211,238,.08) inset, 0 18px 44px rgba(0,0,0,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.logo-wrap img{
  width: 88%;
  height: 88%;
  object-fit: cover;
  border-radius: 999px;
  display:block;
  background: rgba(255,255,255,.08);
}
@keyframes spinFast { from{ transform: rotate(0deg);} to{ transform: rotate(360deg);} }
.spin{ animation: spinFast .65s linear; }

.station-title{
  text-align:center;
  font-weight: 950;
  font-size: 14px;
  margin: 0;
  line-height:1.15;
  letter-spacing: .03em;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--neonCyan), var(--neonViolet), var(--neonPink));
  -webkit-background-clip: text;
  background-clip:text;
  color: transparent;
  text-shadow: 0 0 18px rgba(34,211,238,.12);
}
.station-slogan{
  text-align:center;
  margin: 8px 0 0;
  color: rgba(234,240,255,.80);
  font-weight: 750;
  font-size: 12px;
  line-height:1.2;
}
.station-card.active{
  border-color: rgba(34,211,238,.35);
  box-shadow: 0 0 0 1px rgba(34,211,238,.10) inset, 0 26px 70px rgba(0,0,0,.65);
}

/* Player */
.player{
  position:fixed;
  left:0; right:0; bottom:0;
  height: 104px;
  padding: 12px 12px calc(12px + env(safe-area-inset-bottom));
  background: rgba(0,0,0,.55);
  border-top:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(16px);
  z-index: 30;
	margin-bottom: 0px;

}
.player-inner{
  max-width: 980px;
  margin: 0 auto;
  height:100%;
  display:grid;
  grid-template-columns: 62px 62px 1fr 54px;
  align-items:center;
  gap: 10px;
}
.pbtn{
  width:62px;height:62px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  color: var(--text);
  font-size: 22px;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
.pbtn:active{ transform: translateY(1px); }
.pbtn.play{
  background: linear-gradient(135deg, rgba(124,58,237,.92), rgba(34,211,238,.86));
  color:#051018;
  border: 0;
  font-weight: 900;
  box-shadow: 0 14px 36px rgba(0,0,0,.40);
}
.pbtn.stop{
  background: rgba(255,45,45,.16);
  border-color: rgba(255,45,45,.28);
  color: #FFD6D6;
}
.pmeta{ min-width:0; display:flex; flex-direction:column; gap:6px; }
.p-title{
  margin:0;
  font-weight: 950;
  font-size: 14px;
  letter-spacing:.04em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
  background: linear-gradient(90deg, var(--neonPink), var(--neonCyan), var(--neonViolet));
  -webkit-background-clip: text;
  background-clip:text;
  color: transparent;
  text-shadow: 0 0 18px rgba(124,58,237,.10);
}
.p-slogan{
  margin:0;
  color: rgba(234,240,255,.78);
  font-weight: 750;
  font-size: 12px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.share-btn{
  width:54px;height:54px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  color: var(--text);
  font-size: 20px;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
  display:flex;align-items:center;justify-content:center;
}

/* Share modal */
.modal{
  position:fixed; inset:0;
  display:none;
  align-items:flex-start;
  justify-content:center;
  z-index: 60;
  padding-top: calc(58px + 12px + env(safe-area-inset-top));
}
.modal.open{ display:flex; }
.modal .sheet{
  width: min(520px, 92vw);
  border-radius: 22px;
  background: rgba(10,12,28,.92);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 70px rgba(0,0,0,.65);
  backdrop-filter: blur(18px);
  padding: 14px;
}
.sheet-head{ display:flex; align-items:center; justify-content:space-between; padding: 10px 8px; }
.sheet-title{
  font-weight: 950;
  letter-spacing:.12em;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--neonCyan), var(--neonViolet), var(--neonPink));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.sheet-close{
  width:44px;height:44px;border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:#fff;
  font-size: 18px;
  cursor:pointer;
}
.share-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 8px;
}
@media (min-width: 900px){
  .share-grid{ grid-template-columns: repeat(5, 1fr); }
}

.share-tile{
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  padding: 12px 10px;
  text-align:center;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
.share-tile .ic{ font-size: 22px; }
.share-tile .tx{
  margin-top:8px;
  font-weight: 850;
  font-size: 12px;
  color: rgba(234,240,255,.9);
  letter-spacing:.02em;
}

/* Panels + Contact form */
.panel{
  background: rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 14px;
  box-shadow: var(--shadow);
}
.panel h2{ margin:0 0 8px; font-weight: 950; letter-spacing:-0.02em; }
.panel p{ margin:0 0 12px; color: var(--muted); font-weight: 700; line-height: 1.35; }

.contact-form{ display:flex; flex-direction:column; gap:12px; margin-top: 10px; }
.form-row{ display:flex; flex-direction:column; gap:6px; }
.form-row label{ color: rgba(234,240,255,.85); font-weight: 850; font-size: 12px; letter-spacing:.06em; text-transform: uppercase; }
.form-row input, .form-row textarea{
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color: var(--text);
  padding: 12px 12px;
  font-size: 14px;
  outline: none;
}
.form-submit{
  border:0;
  border-radius: 16px;
  padding: 14px 12px;
  font-weight: 950;
  letter-spacing:.04em;
  text-transform: uppercase;
  cursor:pointer;
  color:#051018;
  background: linear-gradient(135deg, rgba(124,58,237,.92), rgba(34,211,238,.86));
}
.form-hint{ margin:0; font-size: 12px; color: rgba(159,176,208,.85); }

/* Toast */
.toast{
  position:fixed;
  left:50%;
  bottom: 128px;
  transform:translateX(-50%);
  background: rgba(0,0,0,.72);
  border:1px solid rgba(255,255,255,.12);
  padding: 10px 12px;
  border-radius: 16px;
  font-weight: 850;
  font-size: 12px;
  opacity:0;
  transition:.18s;
  z-index: 80;
  max-width: 92vw;
  text-align:center;
  backdrop-filter: blur(12px);
}
.toast.show{ opacity:1; }

/* Scrollbar colors */
body::-webkit-scrollbar{ width:10px; }
body::-webkit-scrollbar-track{ background: rgba(255,255,255,.06); }
body::-webkit-scrollbar-thumb{
  background: rgba(34,211,238,.22);
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.35);
}
body::-webkit-scrollbar-thumb:hover{ background: rgba(124,58,237,.28); }
body{ scrollbar-width: thin; scrollbar-color: rgba(34,211,238,.22) rgba(255,255,255,.06); }

/* Mobile scaling (app feel) */
@media (max-width: 900px){
  body{ font-size: 18px; }
  .h-title{ font-size: 20px; }
  .h-sub{ font-size: 13px; }
  .station-title{ font-size: 15px; }
  .station-slogan{ font-size: 12.5px; }

  /* λίγο μικρότερα logos για να μη φουσκώνει */
  .logo-wrap{ width: 90px; height: 90px; }
  .station-card{ padding: 12px; }

  .player{ height: 112px; }
  .p-title{ font-size: 15px; }
  .p-slogan{ font-size: 13px; }
}
@media (max-width: 380px){
  .logo-wrap{ width: 84px; height: 84px; }
  .player-inner{ grid-template-columns: 56px 56px 1fr 50px; }
  .pbtn{ width:56px;height:56px;border-radius:16px; }
}
/* =========================
   SITE FOOTER (above player)
   ========================= */
.site-footer{
  margin: 18px 16px 18px; /* αφήνει χώρο πριν τον player */
  border-radius: 22px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  overflow:hidden;
  position: relative;
}

.site-footer::before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(320px 200px at 10% 20%, rgba(34,211,238,.16), transparent 60%),
    radial-gradient(320px 200px at 80% 0%, rgba(124,58,237,.18), transparent 60%),
    radial-gradient(340px 240px at 70% 100%, rgba(251,113,133,.10), transparent 60%);
  opacity: .95;
  pointer-events:none;
}

.sf-inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1fr 1fr auto; /* 2 στήλες + logo δεξιά */
  gap: 16px;
  padding: 18px 18px 14px;
  align-items: start;
}

.sf-title{
  margin:0 0 8px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  background: linear-gradient(90deg, var(--neonCyan), var(--neonViolet), var(--neonPink));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.sf-desc{
  margin:0;
  color: rgba(234,240,255,.82);
  font-weight: 750;
  line-height: 1.35;
  font-size: 13px;
}

.sf-logo{
  width: 88px;
  height: 88px;
  border-radius: 20px;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
}

.sf-logo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

.sf-bottom{
  position:relative;
  z-index:1;
  border-top: 1px solid rgba(255,255,255,.10);
  padding: 12px 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  color: rgba(159,176,208,.95);
  font-weight: 800;
  letter-spacing: .04em;
  font-size: 12px;
}

.sf-dot{ opacity:.6; }

/* Mobile: footer σε 1 στήλη + logo κάτω */
@media (max-width: 900px){
  .site-footer{ margin: 16px 16px 0px; }
  .sf-inner{
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .sf-logo{
    width: 72px;
    height: 72px;
    border-radius: 18px;
    justify-self: end; /* δεξιά */
  }
  .sf-desc{ font-size: 13.5px; }
}
