@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap');
/* Personal Space avatar sizing */
#space-profile-card .avatar-field{ display:column; align-items:center; gap:16px; flex-wrap:wrap }
#space-profile-card .avatar-preview{ flex:1 1 300px }
#space-profile-card #space-avatar{ width:100%; height:auto; aspect-ratio:1/1; border-radius:12px; object-fit:cover; display:block }
@media(min-width:1024px){
  #space-profile-card #space-avatar{ width:15%; height:auto }
}
#space-profile-card .avatar-actions{ flex:0 0 auto }
@media(min-width:1024px){
  #space-profile-card .avatar-preview{ flex-basis:50% }
}

/* Comment tree visuals */
.comment-tree{ border-left:2px solid #333; margin-left:8px; padding-left:12px }
.comment-item{ margin:8px 0 }
.comment-item .reply-input{ background:#14161b; border:1px solid #1f222a; color:#eaeaea; padding:8px 10px; border-radius:8px }
/* Player widget */
.media-previews{ display:flex; gap:8px; flex-wrap:wrap }
.media-previews .chip{ position:relative; border:1px solid var(--border-color); border-radius:8px; padding:6px 8px; background:#0f1116; color:#eaeaea; display:flex; align-items:center; gap:6px }
.media-previews .chip img,.media-previews .chip video{ width:48px; height:48px; object-fit:cover; border-radius:6px }
.media-previews .chip .remove{ position:absolute; top:-6px; right:-6px; background:#222737; border-radius:50%; width:20px; height:20px; display:flex; align-items:center; justify-content:center; cursor:pointer }
.space-post-visual-slider{display:flex;gap:8px;overflow:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.space-post-preview-card{position:relative;flex:0 0 auto;width:120px;height:120px;border:1px solid var(--border-color);border-radius:10px;overflow:hidden;background:#0f1116}
.space-post-preview-card img,.space-post-preview-card video{width:100%;height:100%;object-fit:cover;display:block}
.space-post-preview-remove{position:absolute;top:6px;right:6px;width:22px;height:22px;border:none;border-radius:999px;background:rgba(16,20,28,.72);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}
.space-post-files-list{display:flex;flex-direction:column;gap:6px;margin-top:8px;width:100%}
.space-post-file-row{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--border-color);border-radius:8px;padding:6px 8px;background:#0f1116}
.space-post-file-remove{border:none;background:transparent;color:#cdd8ea;cursor:pointer}
#space-compose-card.dragover{
  border-color:#4da3ff !important;
  box-shadow:0 0 0 2px rgba(77,163,255,.22) inset;
}
#wave-upload-card.dragover{
  border-color:#4da3ff !important;
  box-shadow:0 0 0 2px rgba(77,163,255,.22) inset;
}
.post-media-block{margin-top:8px}
.post-media-visual-shell{display:block}
.post-media-visual-wrap{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;scroll-behavior:smooth;scroll-snap-type:x mandatory}
.post-media-visual-wrap::-webkit-scrollbar{height:0;width:0}
.post-media-visual-slider{display:flex;gap:8px}
.post-media-visual-item{flex:0 0 100%;min-width:100%;max-width:100%;scroll-snap-align:start;scroll-snap-stop:always}
.post-media-video-head{font-size:12px;color:#cfe0f7;opacity:.9;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-media-image{width:100%;height:min(62vh,540px);object-fit:contain;border-radius:12px;display:block;background:#0f1116}
.post-media-video{width:100%;height:min(62vh,540px);max-height:min(62vh,540px);object-fit:contain;border-radius:12px;background:#0f1116}
.post-media-files-list{display:flex;flex-direction:column;gap:8px;margin-top:8px;min-width:0}
.post-media-files-item{min-width:0;max-width:100%}
.post-save-visual-wrap{display:flex;justify-content:center;align-items:center}
.post-save-visual-btn{background:transparent !important;border:none !important;color:inherit;cursor:pointer;display:flex;justify-content:center;align-items:center;padding:8px;font-size:1.1rem;transition:transform .22s ease, opacity .2s ease;min-width:36px;min-height:36px}
.post-save-visual-btn:hover{opacity:.9}
.post-save-visual-btn[data-saved="1"]{color:var(--success-color,#4ade80)}
/* Playlist cards in posts - constrain to space, truncate names on mobile */
.post-playlist-card{min-width:0;max-width:100%;overflow:hidden}
.post-playlist-card>div:first-of-type{min-width:0}
.post-playlist-card>div>div{min-width:0;overflow:hidden}
.post-playlist-card>div>div>div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-media-audio-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.post-media-audio-head-text{display:flex;flex-direction:column;min-width:0;gap:2px}
.post-media-audio-cover{width:30px;height:30px;border-radius:8px;object-fit:cover;border:1px solid var(--border-color);background:#0f1116;flex:0 0 auto}
.post-media-audio-cover-fallback{display:inline-flex;align-items:center;justify-content:center;color:#c8d7ef}
.post-media-audio-title{font-size:13px;color:#dbe7ff;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.post-media-audio-by{font-size:11px;color:#9db0cf;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.post-media-audio-by-link{background:none;border:none;padding:0;cursor:pointer;text-align:left}
.post-media-dots{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px}
.post-media-dot{width:7px;height:7px;border-radius:999px;border:0;background:rgba(201,218,241,.35);padding:0;cursor:pointer;transition:all .16s ease}
.post-media-dot.active{width:16px;background:#9fc5ff}
.post-media-file-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border-color);border-radius:10px;background:#0f1116;color:#d8e2f3;text-decoration:none}
.post-media-file-chip:hover{text-decoration:none;opacity:.95}
.player-card{ background:#0f1116; border:1px solid var(--border-color); border-radius:12px; padding:8px; }
.player-media{ width:100%; border-radius:8px; background:#000 }
.player-bar{ display:flex; align-items:center; gap:10px; margin-top:6px }
.btn-icon{ background:transparent; border:none; color:#fff; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer }
.player-bar .progress{ position:relative; flex:1; height:6px; background:#1b1e28; border-radius:999px; overflow:hidden; cursor:pointer }
.player-bar .progress .fill{ position:absolute; left:0; top:0; bottom:0; width:0%; background:#ff6a00 }
.player-bar .progress .knob{ position:absolute; top:50%; transform:translate(-50%, -50%); width:12px; height:12px; background:#fff; border-radius:50%; box-shadow:0 0 0 2px rgba(255,255,255,.2) }
.player-bar .time{ font-size:12px; color:#ccc; min-width:60px; text-align:right }
.audio-wave-player{
  display:flex;
  align-items:center;
  gap:8px;
  background:#0f1724;
  border:1px solid #273247;
  border-radius:14px;
  padding:6px 10px;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
  overflow:hidden;
}
.audio-wave-play{
  width:28px;
  height:28px;
  border-radius:999px;
  border:none;
  background:#1b2a43;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
}
.audio-wave-bars{
  flex:1;
  min-width:0;
  display:flex;
  gap:1px;
  align-items:flex-end;
  height:22px;
  cursor:pointer;
  touch-action:none;
  overflow:hidden;
}
.audio-wave-bars .bar{
  flex:1 1 0;
  min-width:1px;
  border-radius:2px;
  background:#6e798b;
  opacity:.95;
  transition:background-color .08s linear;
}
.audio-wave-bars .bar.played{ background:#ffffff; }
.audio-wave-time{
  font-size:11px;
  color:#9da8bc;
  min-width:68px;
  max-width:78px;
  flex:0 0 auto;
  text-align:right;
  white-space:nowrap;
}
.wave-item-audio-host{ width:100%; }
.playlist-mini-btn{
  width: 28px;
  height: 28px;
  min-width: 28px;
  border: 1px solid #334056;
  border-radius: 8px;
  background: #1a2232;
  color: #dbe5f3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  font-size: 12px;
}
.playlist-mini-btn:hover{ background:#263248; }
.playlist-mini-btn.danger{ border-color:#4f3340; color:#f4c9d4; }
/* Global Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --app-font: "Montserrat", "Segoe UI", Roboto, Arial, sans-serif;
    --typewriter-font: "Courier Prime", "Courier New", "Lucida Console", monospace;
    --primary-bg: #000000;
    --secondary-bg: #111111;
    --tertiary-bg: #1a1a1a;
    --primary-text: #ffffff;
    --secondary-text: #cccccc;
    --accent-color: #00d4ff;
    --accent-hover: #00b8e6;
    --border-color: #333333;
    --success-color: #00ff88;
    --error-color: #ff4444;
    --warning-color: #ffaa00;
    --shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
    --shadow-hover: 0 8px 15px rgba(0, 0, 0, 0.4);
    --border-radius: 8px;
    --transition: all 0.3s ease;
    --icon-filter: brightness(0) invert(1);
}

body {
    font-family: var(--app-font);
    background: var(--primary-bg);
    color: var(--primary-text);
    line-height: 1.6;
    /* Allow natural page scrolling; prevent horizontal overflow */
    overflow-y: auto;
    overflow-x: hidden;
    min-height: 100vh;
}

/* Hide global scrollbars but allow internal containers to scroll */
* { -ms-overflow-style: none; scrollbar-width: none; }
*::-webkit-scrollbar { width:0; height:0; }

/* Common internal scroll containers */
.content-section, .settings-grid, .settings-card, .connections-list, .messages, #apps-grid, #space-feed, #video-library, #wave-library, main, .main, .page, .page-content, #dashboard, #personal-space, #feed {
    overflow-x: hidden;
}

/* Base page padding so text does not float at edges */
main, .main, .page, .page-content, #dashboard, #personal-space, #feed {
    padding: 14px 16px;
}

/* Hide scrollbars globally while preserving scroll */
* {
    -ms-overflow-style: none; /* IE and old Edge */
    scrollbar-width: none; /* Firefox */
}
*::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
}

/* Fit media/content by width to avoid horizontal scroll */
img, video, canvas, svg, iframe {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Sticky mini player (soundcloud-like) */
.mini-player{ position:fixed; left:8px; right:8px; bottom:72px; background:linear-gradient(180deg,#121722,#0c1018); border:1px solid #2b3445; border-radius:12px; box-shadow:0 14px 34px rgba(0,0,0,.45); padding:10px 12px; display:none; flex-direction:column; align-items:stretch; gap:8px; z-index:11080; transition:transform .22s ease, opacity .22s ease }
.mini-player.show{ display:flex; animation:miniRise .2s ease }
.mini-main-row{display:flex;align-items:center;gap:8px;min-width:0}
.mini-player .cover{ width:42px; height:42px; border-radius:8px; object-fit:cover; flex:0 0 42px }
.mini-meta{min-width:0;flex:1}
.mini-player .title-wrap{width:20ch;max-width:100%;overflow:hidden}
.mini-player .title{ font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:clip; }
.mini-player .by{ font-size:12px; color:#aaa; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.mini-player .title,
.mini-player .by,
.mini-progress-row .time{
  font-family: var(--typewriter-font);
}
.mini-controls{display:flex;align-items:center;gap:4px;flex:0 0 auto}
.mini-player .btn,
.mini-player .btn.secondary{
  background: transparent;
  border: none;
  color:#d6deeb;
  width:30px;
  height:30px;
  min-width:30px;
  padding:0;
  box-shadow:none;
  border-radius:8px;
  transition:none;
}
.mini-player .btn:hover{ background:transparent; transform:none; }
#mini-repeat[data-mode="off"]{ color:#d6deeb; opacity:.35; filter:brightness(.7); }
#mini-repeat[data-mode="all"]{ color:#d6deeb; opacity:.7; filter:brightness(.95); }
#mini-repeat[data-mode="one"]{ color:#d6deeb; opacity:1; filter:brightness(1.2); }
.mini-progress-row{display:flex;align-items:center;gap:10px}
.mini-progress-row .progress{position:relative;flex:1;height:6px;background:#1b1e28;border-radius:999px;overflow:hidden;cursor:pointer}
.mini-progress-row .fill{position:absolute;left:0;top:0;bottom:0;width:0%;background:#ff6a00}
.mini-progress-row .time{font-size:12px;color:#ccc;min-width:74px;text-align:right}
.mini-queue-panel{
  position:fixed;
  right:8px;
  bottom:126px;
  width:min(92vw,360px);
  max-height:42vh;
  overflow:auto;
  background:#0f1724;
  border:1px solid #2b3445;
  border-radius:12px;
  z-index:11090;
  box-shadow:0 14px 34px rgba(0,0,0,.45);
  padding:8px;
}
.mini-queue-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:6px;border-bottom:1px solid #2b3445;margin-bottom:8px}
.mini-queue-item{padding:8px;border-radius:8px;color:#d6deeb}
.mini-queue-item.active{background:#1b2638}
@keyframes miniRise{
  from{ transform:translateY(10px); opacity:.5; }
  to{ transform:translateY(0); opacity:1; }
}
@media (min-width: 769px){
  .mini-player{
    left: 35vw;
    right: 35vw;
    bottom: 18px;
  }
  .mini-queue-panel{
    right: 35vw;
    bottom: 74px;
    width: min(34vw, 420px);
    max-height: 52vh;
    z-index: 11095;
  }
}

/* Micro-interactions */
.post-actions .fa-heart,.post-actions .fa-retweet,.post-actions .fa-comment,.post-actions .post-menu{ transition: transform .12s ease, color .12s ease }
.post-actions .fa-heart:active,.post-actions .fa-retweet:active,.post-actions .fa-comment:active{ transform: scale(1.15) }
.post-actions .fa-heart.active{ color:#ff4d4f }
.post-actions .fa-retweet.active{ color:#22c55e }

.icon-btn:hover,.btn-icon:hover{ filter: brightness(1.1) }

.comment-tree{ transition: max-height .2s ease }

/* Double-tap like pulse */
@keyframes liber-like-pulse{
  0%{ transform: scale(0.6); opacity: 0.0 }
  40%{ transform: scale(1.0); opacity: 0.9 }
  100%{ transform: scale(1.2); opacity: 0.0 }
}
.dbl-like-pulse{ position:absolute; left:50%; top:40%; transform:translate(-50%,-50%); pointer-events:none; color:#ff4d4f; font-size:56px; opacity:0; animation: liber-like-pulse .6s ease forwards }
.post-item{ position:relative }
.post-head{min-width:0}
.post-head button[data-user-preview]{min-width:0}
.post-head button[data-user-preview] span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wave-item .audio-title,
.wave-item .audio-byline{
  font-family: var(--typewriter-font);
}

/* Desktop adaptive post tiling (masonry) */
@media (min-width: 1024px){
  #global-feed,
  #global-suggestions,
  #space-suggestions,
  #space-feed,
  #preview-feed{
    width:100%;
    column-width:300px;
    column-gap:12px;
  }
  #global-feed .post-item,
  #global-suggestions .post-item,
  #space-suggestions .post-item,
  #space-feed .post-item,
  #preview-feed .post-item{
    display:inline-block;
    vertical-align:top;
    margin:0 0 12px 0 !important;
    width:100%;
    max-width:none;
    break-inside:avoid;
    -webkit-column-break-inside:avoid;
  }
  .player-card{
    max-width:none;
  }
  /* WaveConnect desktop: normal flow, only audio Upload + Library in one row */
  #wave-audio-pane{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns:minmax(320px, 1fr) minmax(320px, 1fr);
    gap:16px;
    align-items:start;
  }
  #wave-video-pane{
    width:100%;
    max-width:none;
    display:block;
  }
  #wave-audio-pane > .section-header{
    grid-column:1 / -1;
  }
  #wave-audio-pane > .settings-grid{
    grid-column:1;
    grid-row:2;
    margin:0;
  }
  #wave-audio-pane > .settings-grid .settings-card{
    margin:0;
  }
  /* Direct sibling after upload block is "My Library" */
  #wave-audio-pane > .settings-grid + .settings-card{
    grid-column:2;
    grid-row:2;
    margin-top:0 !important;
  }
  #wave-audio-pane > .settings-grid + .settings-card ~ .settings-card{
    grid-column:1 / -1;
  }
  #wave-video-pane > .settings-grid{
    margin:0 0 16px 0;
  }
  /* Keep WaveConnect content in normal full-width column flow inside cards */
  #wave-library,
  #wave-playlists,
  #wave-results{
    display:block;
    width:100%;
    max-width:100%;
  }
  #wave-library .wave-item{
    max-width:100%;
    width:100%;
    margin:8px 0 !important;
  }
}

/* WaveConnect: videos, pictures, buttons on small screens */
.video-item{
  max-width:100%;
  min-width:0;
  overflow:hidden;
  box-sizing:border-box;
}
.video-item img:not([alt="cover"]):not([alt="author"]),
.video-item video,
.video-item .liber-lib-video{
  max-width:100% !important;
  width:100% !important;
  box-sizing:border-box;
  object-fit:contain;
}
#waveconnect-section .video-item,
#waveconnect-section [id$="-library"] .video-item{
  max-width:100%;
}
#waveconnect-section .video-item img,
#waveconnect-section .video-item video,
#waveconnect-section .video-item .liber-lib-video,
#video-library img,
#video-library video,
#picture-library img,
#picture-library video{
  max-width:100% !important;
  box-sizing:border-box;
  object-fit:contain;
}
.video-item-header{ position:relative; z-index:1 }
.video-item-actions{ pointer-events:auto }

@media (max-width: 767px){
  #waveconnect-section .section-header{
    flex-wrap:wrap;
    gap:8px;
  }
  #waveconnect-section .section-header .tabs,
  #waveconnect-section .section-header > div[style*="display:flex"]{
    flex-wrap:wrap;
    gap:6px;
  }
  #waveconnect-section .btn{
    padding:8px 10px;
    font-size:13px;
  }
  #waveconnect-section .btn i{ margin-right:4px }
  #wave-video-pane .btn,
  #wave-pictures-pane .btn{
    padding:8px 10px;
    font-size:12px;
    min-width:auto;
  }
  #wave-video-pane > .settings-card > div[style*="display:flex"],
  #wave-pictures-pane > .settings-card > div[style*="display:flex"]{
    flex-wrap:wrap !important;
    gap:6px !important;
  }
  #waveconnect-section .video-item,
  #video-library .video-item,
  #picture-library .video-item,
  #video-library > div,
  #picture-library > div{
    padding:8px;
    width:100%;
    max-width:100%;
    min-width:0;
    box-sizing:border-box;
  }
  #waveconnect-section .video-item{
    max-width:min(calc(100vw - 24px), 360px);
    margin-left:auto;
    margin-right:auto;
  }
  .video-item{
    padding:8px;
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .video-item-header{
    flex-direction:column;
    align-items:flex-start;
    padding-right:0 !important;
    margin-bottom:8px;
  }
  .video-item-header > div{
    width:100%;
  }
  .video-item-actions{
    position:static !important;
    width:100%;
    justify-content:flex-start;
    margin-top:4px;
    padding-top:6px;
    border-top:1px solid var(--border-color,#2b3240);
  }
  #waveconnect-section .video-item img[data-fullscreen-image="1"],
  #waveconnect-section .video-item video,
  #waveconnect-section .video-item .liber-lib-video,
  #video-library img,
  #video-library video,
  #picture-library img,
  #picture-library video{
    max-width:100% !important;
    max-height:min(50vh,240px) !important;
    width:auto !important;
    height:auto !important;
    object-fit:contain;
  }
  .video-item img[data-fullscreen-image="1"],
  .video-item video{
    max-width:100% !important;
    max-height:min(50vh,280px) !important;
    width:auto !important;
    height:auto !important;
    object-fit:contain;
  }
  #video-library,
  #picture-library,
  #wave-video-pane,
  #wave-pictures-pane{
    max-width:100%;
    min-width:0;
    overflow:hidden;
  }
  #wave-library .player-card,
  #wave-playlists .player-card,
  #wave-results .player-card{
    max-width:none;
    width:100%;
  }
}

@media (max-width: 767px){
  .post-head{
    align-items:flex-start !important;
    gap:6px !important;
  }
  .post-head button[data-user-preview]{
    max-width:60%;
    overflow:hidden;
  }
  .post-head button[data-user-preview] span{
    max-width:100%;
    display:inline-block;
  }
  .post-head .post-head-meta{
    margin-left:auto;
    white-space:nowrap;
    font-size:10px !important;
    line-height:1.2;
    text-align:right;
    flex:0 0 auto;
  }

  .playlist-head{
    flex-direction:column;
    align-items:stretch !important;
    gap:8px !important;
  }
  .playlist-head-main{
    width:100%;
    min-width:0;
  }
  .playlist-head-actions{
    width:100%;
    display:grid !important;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:6px !important;
  }
  .playlist-head-actions .btn{
    width:100%;
    justify-content:center;
    padding:10px 8px;
    font-size:12px;
  }
  .playlist-row{
    grid-template-columns:minmax(0,1fr) auto !important;
    align-items:flex-start !important;
  }
  .playlist-row-actions{
    display:grid !important;
    grid-auto-flow:column;
    grid-auto-columns:minmax(26px,auto);
    gap:4px !important;
  }
  /* Post audio player: keep time readable without clipping bars. */
  .post-media-files-item .audio-wave-player{
    display:grid;
    grid-template-columns:28px minmax(0,1fr) auto;
    align-items:center;
    gap:6px;
  }
  .post-media-files-item .audio-wave-bars{
    min-width:0;
    overflow:hidden;
  }
  .post-media-files-item .audio-wave-time{
    min-width:56px;
    max-width:none;
    font-size:10px;
    text-align:right;
    white-space:nowrap;
    letter-spacing:-0.1px;
  }
}

table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
}

th, td {
    word-break: break-word;
    overflow-wrap: anywhere;
}

pre, code {
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

/* Loading Screen */
.loading-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--primary-bg);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    transition: opacity 0.5s ease;
}

.loading-screen.hidden {
    opacity: 0;
    pointer-events: none;
}

.loading-spinner {
    width: 50px;
    height: 50px;
    border: 3px solid var(--border-color);
    border-top: 3px solid var(--accent-color);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 20px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Utility Classes */
.hidden {
    display: none !important;
}

/* Hidden overlays should not intercept taps/scroll */
.modal-overlay.hidden { pointer-events: none; }

.fade-in {
    animation: fadeIn 0.5s ease-in;
}

/* Shared smooth dissolve-out animation for removed elements */
.liber-dissolve-out{
  opacity:0 !important;
  transform:scale(.985) translateY(2px) !important;
  filter:blur(1px);
  transition:opacity .22s ease, transform .22s ease, filter .22s ease;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Buttons */
.btn {
    background: var(--accent-color);
    color: var(--primary-bg);
    border: none;
    padding: 12px 24px;
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    transition: var(--transition);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.btn:hover {
    background: var(--accent-hover);
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}

.btn:active {
    transform: translateY(0);
}

.btn-secondary {
    background: var(--tertiary-bg);
    color: var(--primary-text);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover {
    background: var(--secondary-bg);
    border-color: var(--accent-color);
}

.btn-danger {
    background: var(--error-color);
    color: var(--primary-text);
}

.btn-danger:hover {
    background: #ff2222;
}

/* Inputs */
input, textarea, select {
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    color: var(--primary-text);
    font-family: var(--app-font);
    padding: 12px 16px;
    border-radius: var(--border-radius);
    font-size: 14px;
    transition: var(--transition);
    width: 100%;
}

input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.1);
}

input::placeholder {
    color: var(--secondary-text);
    font-family: var(--typewriter-font);
}

textarea::placeholder {
    color: var(--secondary-text);
    font-family: var(--typewriter-font);
}

/* Cards */
.card {
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 20px;
    box-shadow: var(--shadow);
    transition: var(--transition);
}

.card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--secondary-bg);
}

::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--accent-color);
}

/* Selection */
::selection {
    background: var(--accent-color);
    color: var(--primary-bg);
}

/* Focus styles for accessibility */
*:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
}

/* Responsive container */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Grid system */
.grid {
    display: grid;
    gap: 20px;
}

.grid-2 {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Flexbox utilities */
.flex {
    display: flex;
}

.flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
}

.flex-between {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.flex-column {
    display: flex;
    flex-direction: column;
}

/* Text utilities */
.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.text-muted {
    color: var(--secondary-text);
}

.text-accent {
    color: var(--accent-color);
}

.text-success {
    color: var(--success-color);
}

.text-error {
    color: var(--error-color);
}

.text-warning {
    color: var(--warning-color);
}

/* Spacing utilities */
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.p-1 { padding: 8px; }
.p-2 { padding: 16px; }
.p-3 { padding: 24px; }

/* Status indicators */
.status-online {
    color: var(--success-color);
}

.status-offline {
    color: var(--error-color);
}

.status-warning {
    color: var(--warning-color);
}

/* Animations */
@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.slide-in {
    animation: slideIn 0.3s ease-out;
}

.slide-up {
    animation: slideUp 0.3s ease-out;
}
