:root{
  --wine:#7E2E91; --wine-dark:#5C1E6B; --cream:#F5EFE6; --green:#4C8C6F;
  --charcoal:#222; --grey:#666; --white:#fff;
  --bg:#1c0c22; --surface:rgba(255,255,255,.06); --surface-2:rgba(255,255,255,.1);
  --serif:"Playfair Display",Georgia,serif; --sans:Inter,system-ui,-apple-system,sans-serif;
  --tab-h:64px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:var(--sans); color:var(--cream); background:var(--bg);
  background:radial-gradient(120% 80% at 50% -10%,#7E2E91 0%,#5C1E6B 38%,#2A0E33 78%,#1c0c22 100%) fixed;
  -webkit-font-smoothing:antialiased; overflow:hidden;
  display:flex; flex-direction:column; height:100dvh;
}
.app{flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:calc(env(safe-area-inset-top) + 6px) calc(18px + env(safe-area-inset-right)) calc(var(--tab-h) + 24px) calc(18px + env(safe-area-inset-left));
  max-width:560px; margin:0 auto; width:100%}
.screen{display:none; animation:fade .35s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 4px 8px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.3px}
.brand .the{color:var(--green)}
.brand-logo{height:30px;width:auto;display:block;filter:drop-shadow(0 1px 4px rgba(0,0,0,.25))}
.live-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(76,140,111,.18);color:#9fe7c4;border:1px solid rgba(76,140,111,.45);padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.5px}
.live-badge.off{background:rgba(255,255,255,.06);color:var(--grey);border-color:rgba(255,255,255,.12)}
.dot{width:7px;height:7px;border-radius:50%;background:#3ad17e;box-shadow:0 0 0 0 rgba(58,209,126,.6);animation:pulse 1.8s infinite}
.live-badge.off .dot{background:#777;animation:none;box-shadow:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,209,126,.5)}70%{box-shadow:0 0 0 9px rgba(58,209,126,0)}100%{box-shadow:0 0 0 0 rgba(58,209,126,0)}}

h1.screen-title{font-family:var(--serif);font-size:26px;margin:8px 4px 16px;font-weight:700}
.zone-pill{display:inline-block;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#e9c9f2;margin:2px 0}

/* Now Playing */
.cover-wrap{position:relative;width:min(78vw,360px);aspect-ratio:1;margin:6px auto 22px;border-radius:22px;overflow:hidden;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.08);background:var(--wine-dark);cursor:pointer}
.cover-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease,opacity .4s}
.cover-wrap.spin img{animation:none}
.np-meta{text-align:center;padding:0 8px}
.np-title{font-family:var(--serif);font-size:24px;line-height:1.25;margin:0 0 6px}
.np-artist{font-size:15px;color:#d9c4e0;margin:0 0 4px}

/* controls */
.controls{display:flex;align-items:center;justify-content:center;gap:26px;margin:26px 0 10px}
.play-btn{width:84px;height:84px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(145deg,#9a3bb0,#6a2280);color:#fff;
  box-shadow:0 14px 34px -10px rgba(126,46,145,.9),inset 0 1px 0 rgba(255,255,255,.25);
  display:grid;place-items:center;transition:transform .15s, box-shadow .2s}
.play-btn:active{transform:scale(.94)}
.play-btn svg{width:34px;height:34px;fill:#fff}
.icon-btn{background:var(--surface);border:1px solid rgba(255,255,255,.1);color:var(--cream);width:52px;height:52px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:.18s}
.icon-btn:active{transform:scale(.92)}
.icon-btn svg{width:22px;height:22px;fill:currentColor}
.icon-btn.liked{color:#ff6b9a;border-color:rgba(255,107,154,.4);background:rgba(255,107,154,.12)}

.volume{display:flex;align-items:center;gap:10px;max-width:280px;margin:18px auto 0;color:#cbb3d4}
.volume svg{width:18px;height:18px;fill:currentColor;flex:none}
input[type=range]{-webkit-appearance:none;appearance:none;height:4px;width:100%;border-radius:4px;background:rgba(255,255,255,.18);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--cream);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.4)}
input[type=range]::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--cream);cursor:pointer}

.buffering{font-size:12px;color:#caa9d4;text-align:center;height:16px;margin-top:6px;letter-spacing:.3px}

/* iOS: το Safari αγνοεί το audio.volume (το ελέγχουν τα φυσικά κουμπιά) — κρύβουμε τη μπάρα */
body.ios .volume{display:none}

/* cards / lists */
.card{background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px;margin-bottom:12px}
.list-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:10px;margin-bottom:10px}
.list-item img{width:54px;height:54px;border-radius:10px;object-fit:cover;flex:none;background:var(--wine-dark)}
.li-text{flex:1;min-width:0}
.li-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li-sub{font-size:12px;color:#cbb3d4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li-time{font-size:11px;color:var(--grey)}
.mini-like{background:none;border:none;cursor:pointer;color:#caa9d4;padding:6px}
.mini-like svg{width:20px;height:20px;fill:currentColor}
.mini-like.liked{color:#ff6b9a}

/* schedule */
.now-zone{background:linear-gradient(135deg,rgba(126,46,145,.55),rgba(76,140,111,.35));border:1px solid rgba(255,255,255,.14)}
.sched-row{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:14px;margin-bottom:10px;background:var(--surface);border:1px solid rgba(255,255,255,.07);cursor:pointer}
.sched-row.live{outline:2px solid var(--green);outline-offset:-2px}
.sched-time{font-variant-numeric:tabular-nums;font-weight:700;font-size:13px;color:#e9c9f2;min-width:96px}
.sched-name{font-family:var(--serif);font-size:16px;margin:0}
.sched-desc{font-size:12.5px;color:#cbb3d4;margin:3px 0 0}
.countdown{font-size:12px;color:#9fe7c4;margin-top:4px}
.day-tabs{display:flex;gap:8px;margin:0 0 14px}
.day-tabs button{flex:1;padding:9px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:var(--surface);color:var(--cream);font-size:13px;font-weight:600;cursor:pointer}
.day-tabs button.active{background:var(--wine);border-color:var(--wine)}

/* about */
.about p{color:#e3d2ea;line-height:1.6;font-size:14.5px}
.link-row{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;background:var(--surface);border:1px solid rgba(255,255,255,.07);margin-bottom:10px;color:var(--cream);text-decoration:none;font-weight:600;font-size:14px}
.link-row svg{width:22px;height:22px;fill:currentColor;flex:none}
.link-row .chev{margin-left:auto;opacity:.5}

/* favorites export/import tools */
.fav-tools{display:flex;gap:8px;margin:0 4px 10px}
.fav-tool{flex:1;padding:9px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:var(--surface);color:var(--cream);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--sans)}
.fav-tool:active{transform:scale(.97)}
.fav-hint{font-size:11.5px;color:#a98fb5;background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.14);border-radius:10px;padding:9px 12px;margin:0 4px 14px;line-height:1.5}

.empty{text-align:center;color:#cbb3d4;padding:50px 20px;font-size:14px;line-height:1.6}
.empty svg{width:48px;height:48px;fill:rgba(255,255,255,.18);margin-bottom:12px}

.toggle{display:flex;align-items:center;justify-content:space-between;padding:14px;background:var(--surface);border:1px solid rgba(255,255,255,.07);border-radius:14px;margin-bottom:10px;font-size:14px}
.switch{position:relative;width:48px;height:28px;flex:none}
.switch input{display:none}
.slider{position:absolute;inset:0;background:rgba(255,255,255,.18);border-radius:999px;transition:.25s;cursor:pointer}
.slider:before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s}
.switch input:checked + .slider{background:var(--green)}
.switch input:checked + .slider:before{transform:translateX(20px)}

/* tab bar */
.tabbar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tab-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:rgba(28,12,34,.86);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid rgba(255,255,255,.08);display:flex;max-width:560px;margin:0 auto;z-index:20}
.tab{flex:1;background:none;border:none;color:#9b86a6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10.5px;cursor:pointer;font-family:var(--sans);transition:.18s}
.tab svg{width:23px;height:23px;fill:currentColor}
.tab.active{color:var(--cream)}
.tab.active svg{filter:drop-shadow(0 0 10px rgba(154,59,176,.8))}

/* toast */
.toast{position:fixed;bottom:calc(var(--tab-h) + 18px);left:50%;transform:translateX(-50%) translateY(20px);
  background:rgba(34,34,34,.95);color:#fff;padding:11px 18px;border-radius:999px;font-size:13px;opacity:0;pointer-events:none;transition:.3s;z-index:40;border:1px solid rgba(255,255,255,.12)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* fullscreen artwork */
.fs-art{position:fixed;inset:0;background:rgba(20,8,26,.97);z-index:60;display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px;animation:fade .3s}
.fs-art.show{display:flex}
.fs-art img{width:min(86vw,460px);aspect-ratio:1;object-fit:cover;border-radius:20px;box-shadow:0 30px 70px -20px #000}
.fs-art .np-meta{margin-top:24px}
.fs-close{position:absolute;top:20px;right:20px;background:var(--surface-2);border:none;color:#fff;width:42px;height:42px;border-radius:50%;font-size:20px;cursor:pointer}
.section-label{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:#b594c1;margin:18px 4px 10px;font-weight:600}

/* iOS install hint banner — πάνω, ώστε να μην καλύπτει τα controls */
.ios-install{position:fixed;left:12px;right:12px;top:calc(env(safe-area-inset-top) + 56px);z-index:55;
  display:flex;align-items:center;gap:12px;padding:12px 38px 12px 14px;border-radius:16px;
  background:linear-gradient(145deg,#7E2E91,#5C1E6B);color:var(--cream);cursor:pointer;
  box-shadow:0 18px 40px -12px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.12);
  max-width:520px;margin:0 auto;animation:fade .4s ease}
.ios-install[hidden]{display:none}
.ios-install .ios-ic{width:42px;height:42px;border-radius:11px;flex:none;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.ios-install .ios-txt{flex:1;line-height:1.35;font-size:13px}
.ios-install .ios-txt b{display:block;font-size:14px;margin-bottom:2px}
.ios-install .ios-txt span{color:#e6d3ee}
.ios-install .shareglyph{width:15px;height:15px;vertical-align:-3px;fill:#9fe7c4}
.ios-install .ios-x{position:absolute;top:50%;right:8px;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:15px;cursor:pointer;width:28px;height:28px;border-radius:50%;line-height:1;display:grid;place-items:center}
.note{font-size:11.5px;color:#a98fb5;background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.14);border-radius:10px;padding:9px 12px;margin-bottom:12px;line-height:1.5}

/* ===== Landscape (phones) — δύο στήλες ώστε να χωρούν cover + controls ===== */
@media (orientation:landscape) and (max-height:560px){
  .app{max-width:760px}
  #now.active{
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    grid-template-areas:
      "top      top"
      "cover    meta"
      "cover    controls"
      "cover    volume"
      "cover    buffer";
    align-content:start; column-gap:24px;
  }
  #now .topbar{grid-area:top}
  #now .cover-wrap{grid-area:cover; align-self:center; width:min(46vh,200px); margin:4px 0}
  #now .np-meta{grid-area:meta; text-align:left; align-self:end; padding:0}
  #now .np-title{font-size:20px;margin-bottom:4px}
  #now .np-artist{font-size:14px}
  #now .controls{grid-area:controls; justify-content:flex-start; gap:18px; margin:10px 0 4px}
  #now .play-btn{width:66px;height:66px}
  #now .play-btn svg{width:27px;height:27px}
  #now .icon-btn{width:46px;height:46px}
  #now .volume{grid-area:volume; margin:8px 0 0; max-width:240px}
  #now .buffering{grid-area:buffer; text-align:left}
  .fs-art img{width:min(58vh,360px)}
  .fs-art .np-meta{margin-top:14px}
}
