/* ==========================================================
   HabFM - Habbo-style CSS
   Pixel art, retro UI, chunky buttons, outlined windows
   ========================================================== */

:root{
  --bg:        #0f0b1e;
  --bg-elev:   #1a1530;
  --surface:   #231b42;
  --surface-2: #2d2454;
  --panel:     #f3ead6; /* habbo pergament kleur voor windows */
  --panel-border: #2a1f08;

  --border:        rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.16);
  --text:      #f5f2ff;
  --text-dark: #1a0b2e;
  --text-dim:  #b5abd6;
  --text-muted:#8276ad;

  --accent:     #ff6b2c;
  --accent-2:   #ffb627;
  --accent-3:   #ff3b8b;
  --sky:        #4fc3f7;
  --green:      #7fd962;
  --red:        #ef4444;

  --accent-soft:rgba(255,107,44,0.12);
  --radius:     8px;
  --radius-lg:  12px;

  --pixel-shadow-sm: 2px 2px 0 rgba(0,0,0,.5);
  --pixel-shadow:    4px 4px 0 rgba(0,0,0,.5);
  --pixel-shadow-lg: 6px 6px 0 rgba(0,0,0,.6);
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{overflow-x:hidden;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter', system-ui, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(1000px 600px at 15% 5%, rgba(255,107,44,0.18), transparent 55%),
    radial-gradient(900px 500px at 85% 15%, rgba(255,59,139,0.12), transparent 55%),
    radial-gradient(700px 500px at 50% 100%, rgba(124,58,237,0.2), transparent 60%);
  z-index:-3;pointer-events:none;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 24px 24px;
  z-index:-2;pointer-events:none;
  mask-image: radial-gradient(ellipse at center, black 20%, transparent 85%);
}

.pixel{image-rendering:pixelated;image-rendering:crisp-edges;}
.mono{font-family:'Press Start 2P', monospace;}

a{color:var(--accent-2);}
a:hover{color:var(--accent);}

.wrap{max-width:1240px;margin:0 auto;padding:0 24px;}

/* ========== NAV (Habbo toolbar) ========== */
nav.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(15,11,30,0.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:2px solid var(--border-strong);
}
nav .wrap{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 24px;gap:16px;
}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);}
.logo img{height:42px;width:auto;transition:transform .3s cubic-bezier(.2,.9,.3,1.4);}
.logo:hover img{transform:scale(1.06) rotate(-3deg);}
.logo-divider{width:1px;height:22px;background:var(--border-strong);}
.logo-by{display:flex;flex-direction:column;gap:3px;line-height:1;}
.logo-by small{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;}
.logo-by span{font-size:14px;font-weight:700;letter-spacing:-.2px;}

.nav-links{display:flex;align-items:center;gap:2px;flex-wrap:wrap;}
.nav-links a{
  color:var(--text-dim);text-decoration:none;
  font-size:13px;font-weight:600;
  padding:7px 12px;border-radius:8px;
  transition:all .15s;
}
.nav-links a:hover,
.nav-links a.active{color:var(--text);background:rgba(255,255,255,.08);}
.nav-links a.discord{
  background:#5865f2;color:#fff;
  box-shadow:0 3px 0 #3b4bd8;
}
.nav-links a.discord:hover{transform:translateY(-1px);box-shadow:0 4px 0 #3b4bd8;}
.nav-links a.discord:active{transform:translateY(2px);box-shadow:0 0 0 #3b4bd8;}

.live-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--surface);
  border:2px solid var(--border-strong);
  padding:7px 12px;border-radius:999px;
  font-family:'Press Start 2P',monospace;
  font-size:9px;letter-spacing:1.5px;
  white-space:nowrap;
}
.live-dot{
  width:8px;height:8px;background:#ef4444;
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.7);}
  50%{box-shadow:0 0 0 6px rgba(239,68,68,0);}
}

/* ========== HABBO WINDOW ========== */
.hab-window{
  background:var(--surface);
  border:2px solid var(--border-strong);
  border-radius:10px;
  box-shadow: var(--pixel-shadow-lg);
  position:relative;
  margin-bottom:24px;
  overflow:hidden;
}
.hab-window-title{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  background:linear-gradient(180deg, var(--accent) 0%, #e85a1c 100%);
  color:#fff;
  font-family:'Press Start 2P',monospace;
  font-size:11px;letter-spacing:1.5px;
  border-bottom:2px solid #000;
  text-shadow:2px 2px 0 rgba(0,0,0,.3);
}
.hab-window-title .title-left{display:flex;align-items:center;gap:10px;}
.hab-window-title .icon{
  width:22px;height:22px;
  background:var(--accent-2);
  border:2px solid #000;
  display:grid;place-items:center;
  color:#1a0b2e;
}
.hab-window-title .icon svg{width:12px;height:12px;}
.hab-window-title .status-badge{
  font-size:8px;padding:4px 8px;
  background:#000;color:var(--green);
  border-radius:4px;letter-spacing:1.5px;
}
.hab-window-title .status-badge.closed{color:var(--red);}
.hab-window-body{padding:20px;}

/* Pixel-edge variant */
.hab-window.pixel-edge{
  border:none;
  box-shadow:
    0 0 0 2px #000,
    0 0 0 4px var(--accent),
    var(--pixel-shadow-lg);
}

/* ========== BUTTONS (chunky Habbo) ========== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 20px;
  border-radius:8px;
  font-weight:700;font-size:14px;
  text-decoration:none;
  transition:all .15s cubic-bezier(.2,.9,.3,1);
  border:none;cursor:pointer;
  font-family:inherit;letter-spacing:-.1px;
  position:relative;
  line-height:1;
}
.btn svg{width:14px;height:14px;flex-shrink:0;}

.btn-primary{
  background:var(--accent);color:#fff;
  box-shadow: 0 4px 0 #c4451a, 0 8px 16px -4px rgba(255,107,44,.5);
}
.btn-primary:hover{background:#ff8347;transform:translateY(-1px);
  box-shadow:0 5px 0 #c4451a, 0 10px 20px -4px rgba(255,107,44,.6);}
.btn-primary:active{transform:translateY(3px);box-shadow:0 0 0 #c4451a;}

.btn-secondary{
  background:var(--surface);color:var(--text);
  border:2px solid var(--border-strong);
  box-shadow:0 4px 0 rgba(0,0,0,.35);
}
.btn-secondary:hover{background:var(--surface-2);transform:translateY(-1px);
  box-shadow:0 5px 0 rgba(0,0,0,.35);border-color:rgba(255,255,255,.22);}
.btn-secondary:active{transform:translateY(3px);box-shadow:0 0 0 rgba(0,0,0,.35);}

.btn-success{background:var(--green);color:#0f0b1e;box-shadow:0 4px 0 #4ea73d;}
.btn-success:hover{background:#95e87a;transform:translateY(-1px);box-shadow:0 5px 0 #4ea73d;}
.btn-success:active{transform:translateY(3px);box-shadow:0 0 0 #4ea73d;}

.btn-danger{background:var(--red);color:#fff;box-shadow:0 4px 0 #b83333;}
.btn-danger:hover{background:#ff6464;transform:translateY(-1px);box-shadow:0 5px 0 #b83333;}
.btn-danger:active{transform:translateY(3px);box-shadow:0 0 0 #b83333;}

.btn-sm{padding:7px 12px;font-size:12px;box-shadow:0 3px 0 rgba(0,0,0,.4);}
.btn-sm:active{transform:translateY(2px);box-shadow:0 0 0 rgba(0,0,0,.4);}

/* ========== FORMS ========== */
.field{margin-bottom:14px;}
.field label{
  display:block;
  font-family:'Press Start 2P',monospace;
  font-size:9px;letter-spacing:1.2px;
  color:var(--accent-2);margin-bottom:8px;
  text-transform:uppercase;
}
.field input[type=text],
.field input[type=password],
.field input[type=email],
.field input[type=time],
.field input[type=datetime-local],
.field input[type=number],
.field select,
.field textarea{
  width:100%;
  padding:10px 12px;
  background:var(--bg-elev);
  border:2px solid var(--border-strong);
  border-radius:8px;
  color:var(--text);
  font-family:inherit;font-size:14px;
  transition:border-color .15s, background .15s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:var(--surface);
}
.field textarea{min-height:120px;resize:vertical;}
.field .help{font-size:12px;color:var(--text-muted);margin-top:5px;}

/* ========== TABLES ========== */
.hab-table{
  width:100%;border-collapse:collapse;
  font-size:14px;
}
.hab-table th{
  background:var(--bg-elev);
  padding:10px 14px;
  text-align:left;
  font-family:'Press Start 2P',monospace;
  font-size:9px;letter-spacing:1.2px;
  color:var(--accent-2);
  text-transform:uppercase;
  border-bottom:2px solid var(--border-strong);
}
.hab-table td{
  padding:11px 14px;
  border-bottom:1px solid var(--border);
}
.hab-table tr:hover td{background:rgba(255,255,255,.03);}
.hab-table .actions{display:flex;gap:6px;flex-wrap:wrap;}

/* ========== ALERTS / FLASH ========== */
.alert{
  padding:12px 16px;border-radius:8px;margin-bottom:16px;
  font-weight:600;font-size:14px;
  border:2px solid;
}
.alert-success{background:rgba(127,217,98,.12);color:#b4ef98;border-color:rgba(127,217,98,.4);}
.alert-error{background:rgba(239,68,68,.12);color:#ff8a8a;border-color:rgba(239,68,68,.4);}
.alert-info{background:rgba(79,195,247,.12);color:#9cdcfb;border-color:rgba(79,195,247,.4);}

/* ========== BADGES ========== */
.badge-hab{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Press Start 2P',monospace;
  font-size:9px;letter-spacing:1.2px;
  padding:4px 9px;border-radius:6px;
  background:var(--surface);
  border:2px solid var(--border-strong);
  color:var(--text);
  text-transform:uppercase;
}
.badge-hab.green{background:var(--green);color:#0f0b1e;border-color:#000;}
.badge-hab.red{background:var(--red);color:#fff;border-color:#000;}
.badge-hab.orange{background:var(--accent);color:#fff;border-color:#000;}
.badge-hab.pink{background:var(--accent-3);color:#fff;border-color:#000;}
.badge-hab.sky{background:var(--sky);color:#0f0b1e;border-color:#000;}
.badge-hab.yellow{background:var(--accent-2);color:#0f0b1e;border-color:#000;}

/* ========== CUSTOM RADIO PLAYER ========== */
.habfm-player{
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border:2px solid var(--border-strong);
  border-radius:12px;
  padding:20px;
  box-shadow: var(--pixel-shadow);
  position:relative;
  overflow:hidden;
}
.habfm-player::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--accent-2), var(--accent), var(--accent-3), var(--sky));
}
.player-top{
  display:flex;align-items:center;gap:16px;margin-bottom:16px;
}
.player-disc{
  width:66px;height:66px;border-radius:50%;
  background:
    conic-gradient(from 0deg, #1a1a1a, #2d2d2d, #1a1a1a, #2d2d2d, #1a1a1a, #2d2d2d, #1a1a1a);
  position:relative;flex-shrink:0;
  box-shadow: 0 0 0 3px #000, 0 0 0 5px var(--accent-2);
  animation: spinner 8s linear infinite;
  animation-play-state: paused;
}
.habfm-player.playing .player-disc{animation-play-state: running;}
.player-disc::before{
  content:"";position:absolute;inset:22%;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, var(--accent-2), var(--accent) 60%, var(--accent-3));
}
.player-disc::after{
  content:"";position:absolute;inset:42%;border-radius:50%;
  background:#111;box-shadow:0 0 0 2px #333;
}
@keyframes spinner{to{transform:rotate(360deg);}}
.player-info{flex:1;min-width:0;}
.player-info .now-playing{
  font-family:'Press Start 2P',monospace;
  font-size:8px;color:var(--accent-2);
  letter-spacing:1.5px;margin-bottom:6px;
  text-transform:uppercase;
}
.player-info .track{
  font-size:15px;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:3px;
}
.player-info .dj{
  font-size:12px;color:var(--text-dim);
}
.player-controls{
  display:flex;align-items:center;gap:12px;
}
.player-btn{
  background:var(--accent);
  border:2px solid #000;
  border-radius:8px;
  color:#fff;
  width:46px;height:46px;
  display:grid;place-items:center;
  cursor:pointer;
  box-shadow:0 4px 0 #c4451a;
  transition:all .1s;
  flex-shrink:0;
}
.player-btn:hover{background:#ff8347;transform:translateY(-1px);box-shadow:0 5px 0 #c4451a;}
.player-btn:active{transform:translateY(3px);box-shadow:0 0 0 #c4451a;}
.player-btn svg{width:18px;height:18px;}
.player-btn.mute{background:var(--surface-2);box-shadow:0 4px 0 #1a1238;width:38px;height:38px;}
.player-btn.mute:hover{background:var(--surface);box-shadow:0 5px 0 #1a1238;}
.player-btn.mute:active{box-shadow:0 0 0 #1a1238;}
.player-btn.mute svg{width:16px;height:16px;}
.volume-wrap{
  flex:1;display:flex;align-items:center;gap:8px;
}
.volume-slider{
  flex:1;
  -webkit-appearance:none;appearance:none;
  height:12px;
  background:var(--bg-elev);
  border:2px solid #000;
  border-radius:4px;
  outline:none;
  cursor:pointer;
}
.volume-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;
  background:var(--accent-2);
  border:2px solid #000;
  cursor:pointer;
}
.volume-slider::-moz-range-thumb{
  width:18px;height:18px;
  background:var(--accent-2);
  border:2px solid #000;
  cursor:pointer;
}
.stream-fallback{margin-top:12px;}
.stream-fallback iframe{width:100%;border:0;border-radius:8px;}

/* Album art in player */
.player-art{
  width:80px;height:80px;
  border-radius:8px;
  object-fit:cover;
  border:2px solid #000;
  box-shadow: var(--pixel-shadow-sm);
  flex-shrink:0;
  background:var(--bg-elev);
  image-rendering:auto;
}
/* Hide small disc when art is visible - laat beide tonen; art wint visueel */
.habfm-player .player-disc{display:none;}

/* Progress bar */
.track-progress{margin-top:8px;}
.progress-bar{
  width:100%;height:8px;
  background:var(--bg-elev);
  border:2px solid #000;border-radius:4px;
  overflow:hidden;
}
.progress-fill{
  height:100%;
  background:linear-gradient(90deg, var(--accent-2), var(--accent), var(--accent-3));
  width:0%;
  transition:width .4s linear;
}
.progress-times{
  display:flex;justify-content:space-between;
  font-family:'Press Start 2P',monospace;
  font-size:8px;color:var(--text-muted);
  letter-spacing:1px;margin-top:4px;
}

/* Listeners badge */
.player-listeners{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--surface-2);
  border:2px solid var(--border-strong);
  padding:6px 10px;border-radius:6px;
  font-family:'Press Start 2P',monospace;
  font-size:9px;color:var(--accent-2);
  letter-spacing:1px;
}

/* Up next */
.up-next{
  margin-top:14px;
  background:var(--bg-elev);
  border:2px dashed var(--border-strong);
  border-radius:8px;padding:10px 12px;
}
.up-next-label{
  font-family:'Press Start 2P',monospace;
  font-size:8px;color:var(--accent-3);
  letter-spacing:1.5px;margin-bottom:8px;
}
.up-next-body{display:flex;align-items:center;gap:10px;}
.up-next-body img{width:40px;height:40px;border-radius:4px;border:2px solid #000;object-fit:cover;background:var(--bg);}
.up-next-track{font-weight:700;font-size:13px;}
.up-next-artist{font-size:11px;color:var(--text-dim);}

/* Mini heading in player */
.mini-head{
  font-family:'Press Start 2P',monospace;
  font-size:10px;color:var(--accent-2);
  letter-spacing:1.5px;margin:22px 0 12px;
  text-transform:uppercase;
}

/* ========== SECTIONS ========== */
section.block{padding:50px 0;position:relative;}
.section-head{max-width:720px;margin-bottom:32px;}
.section-head .label{
  font-family:'Press Start 2P',monospace;font-size:10px;
  color:var(--accent);letter-spacing:2px;
  margin-bottom:14px;display:inline-flex;align-items:center;gap:8px;
  text-transform:uppercase;
}
.section-head .label::before{content:".";}
.section-head h2{
  font-size:clamp(28px, 3.8vw, 42px);
  font-weight:800;line-height:1;letter-spacing:-1.5px;
  margin-bottom:12px;
}
.section-head h2 .accent{color:var(--accent-2);text-shadow:3px 3px 0 rgba(0,0,0,.35);}
.section-head p{color:var(--text-dim);font-size:16px;max-width:580px;}

/* ========== GRID LAYOUTS ========== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.split-player{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;}

/* ========== SHOUT / REQUEST BLOCKS ========== */
.shout-item, .request-item{
  background:var(--bg-elev);
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:12px 14px;margin-bottom:10px;
}
.shout-item .meta, .request-item .meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--text-muted);margin-bottom:6px;
}
.shout-item .name{font-weight:700;color:var(--accent-2);}
.shout-item .time{font-family:'Press Start 2P',monospace;font-size:8px;letter-spacing:1.2px;}
.shout-item .msg{font-size:14px;color:var(--text);}
.request-item .track{font-weight:700;}
.request-item .req-meta{font-size:12px;color:var(--text-dim);margin-top:3px;}

.shout-closed, .req-closed{
  padding:30px;text-align:center;
  background:var(--bg-elev);
  border:2px dashed var(--border-strong);
  border-radius:8px;
  color:var(--text-dim);
}
.shout-closed .mono, .req-closed .mono{
  display:block;font-size:12px;color:var(--red);
  margin-bottom:8px;letter-spacing:2px;
}

/* ========== ROOSTER ========== */
.rooster{
  display:grid;grid-template-columns:repeat(7, 1fr);gap:10px;
}
.rooster-day{
  background:var(--surface);
  border:2px solid var(--border-strong);
  border-radius:8px;
  padding:10px;
  min-height:120px;
}
.rooster-day h4{
  font-family:'Press Start 2P',monospace;
  font-size:9px;color:var(--accent-2);
  letter-spacing:1.2px;margin-bottom:10px;
  text-transform:uppercase;
  padding-bottom:6px;border-bottom:1px solid var(--border);
}
.rooster-slot{
  background:var(--accent);
  color:#fff;padding:6px 8px;border-radius:6px;
  margin-bottom:5px;font-size:12px;line-height:1.3;
  border:2px solid #000;
  box-shadow:var(--pixel-shadow-sm);
}
.rooster-slot .time{
  font-family:'Press Start 2P',monospace;
  font-size:8px;letter-spacing:1px;display:block;margin-bottom:2px;
}
.rooster-slot .dj{font-weight:700;}
.rooster-slot .show{font-size:11px;opacity:.9;}

/* ========== TOP10 ========== */
.top10 ol{list-style:none;counter-reset:top;}
.top10 li{
  counter-increment:top;
  display:flex;align-items:center;gap:14px;
  padding:12px 14px;
  background:var(--bg-elev);
  border:1px solid var(--border);
  border-radius:8px;
  margin-bottom:8px;
}
.top10 li::before{
  content:counter(top);
  font-family:'Press Start 2P',monospace;
  font-size:14px;color:var(--accent-2);
  width:32px;height:32px;
  display:grid;place-items:center;
  background:var(--surface);
  border:2px solid #000;border-radius:6px;
  flex-shrink:0;
}
.top10 li:nth-child(1)::before{background:var(--accent-2);color:#0f0b1e;}
.top10 li:nth-child(2)::before{background:#c0c0c0;color:#0f0b1e;}
.top10 li:nth-child(3)::before{background:#cd7f32;color:#fff;}
.top10 .song{flex:1;}
.top10 .song .t{font-weight:700;}
.top10 .song .a{font-size:12px;color:var(--text-dim);}
.top10 .plays{
  font-family:'Press Start 2P',monospace;font-size:9px;
  color:var(--text-muted);letter-spacing:1px;
}

/* ========== EMBED MODE ========== */
.embed-body{
  background:transparent;
  padding:8px;
}
.embed-body .hab-window{
  margin:0;box-shadow:none;
}

/* ========== FOOTER ========== */
footer{
  margin-top:60px;padding:40px 0 28px;
  border-top:1px solid var(--border);
  position:relative;
}
footer::before{
  content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  width:200px;height:3px;
  background:linear-gradient(90deg, transparent, var(--accent-2), var(--accent), var(--accent-3), transparent);
}
.footer-inner{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.footer-brand{display:flex;align-items:center;gap:16px;}
.footer-brand img{height:36px;}
.footer-meta{display:flex;flex-direction:column;line-height:1.4;}
.footer-meta strong{font-size:14px;font-weight:700;}
.footer-meta small{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text-muted);letter-spacing:1.5px;margin-top:3px;}
.footer-copy{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text-muted);letter-spacing:1.5px;}

/* ========== RESPONSIVE ========== */
@media (max-width: 960px){
  .split-player, .grid-2{grid-template-columns:1fr;}
  .grid-3{grid-template-columns:1fr;}
  .rooster{grid-template-columns:repeat(2, 1fr);}
  .nav-links{display:none;}
  .hab-table{font-size:13px;}
  .hab-table th, .hab-table td{padding:8px 10px;}
}
@media (max-width: 520px){
  .rooster{grid-template-columns:1fr;}
  .wrap{padding:0 16px;}
  .footer-inner{flex-direction:column;align-items:flex-start;}
  .player-top{flex-wrap:wrap;}
}
