/* ===================================================================
   GigCove — Glass Morphism Design System
   =================================================================== */

/* Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ---------- Theme tokens ---------- */
:root{
  /* Colors */
  --accent-blue:#0e2f5a;
  --accent-blue-hover:#0c2546;
  --accent-blue-light:#13204a;
  --neutral-light:#f7f7f8;
  --neutral-border:#e6e9ee;

  /* Glass Morphism */
  --glass-bg:linear-gradient(135deg, rgba(255,255,255,0.09) 0%, rgba(255,255,255,0.04) 100%);
  --glass-border:rgba(255,255,255,0.15);
  --glass-border-top:rgba(255,255,255,0.25);
  --glass-blur:blur(30px) saturate(180%) brightness(1.05);

  /* Typography */
  --font-main:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --fs-body:16px;
  --fs-label:13px;
  --fs-button:14px;

  /* Buttons - Cyan theme matching logo/graphs */
  --btn-bg:linear-gradient(135deg, #00d4ff 0%, #0099ff 100%);
  --btn-bg-hover:linear-gradient(135deg, #00ffff 0%, #00b8ff 100%);
  --btn-color:#0f1419;
  --btn-radius:10px;
  --btn-shadow:0 4px 12px rgba(0, 212, 255, 0.3);

  /* Icon "X" buttons - Glass style */
  --x-bg:rgba(255,255,255,0.08);
  --x-bg-hover:rgba(255,255,255,0.15);
  --x-color:#fff;
  --x-size:28px;
  --x-font-size:16px;
  --x-shadow:none;

  /* Layout */
  --header-padding:10px 20px 14px; /* remembered preference */
  --section-gap:28px;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:var(--fs-body)/1.55 var(--font-main);
  color:#ffffff;
  background:linear-gradient(135deg, #0f1419 0%, #1a1f2e 50%, #252d3d 100%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
}

/* Background glow effect */
body::before{
  content:'';
  position:fixed;
  top:-50%;
  left:-50%;
  width:200%;
  height:200%;
  background:radial-gradient(circle at 20% 30%, rgba(14,47,90,0.15) 0%, transparent 50%),
              radial-gradient(circle at 80% 70%, rgba(100,80,200,0.08) 0%, transparent 50%),
              radial-gradient(circle at 50% 50%, rgba(40,44,52,0.3) 0%, transparent 70%);
  pointer-events:none;
  z-index:0;
}

a{color:rgba(255,255,255,0.9);text-decoration:none}
a:hover{color:#ffffff;text-decoration:underline;text-underline-offset:2px}

/* ---------- Header (Glass Morphism) ---------- */
.topbar{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(135deg, rgba(255,255,255,0.09) 0%, rgba(255,255,255,0.04) 100%);
  backdrop-filter:blur(40px) saturate(180%) brightness(1.05);
  -webkit-backdrop-filter:blur(40px) saturate(180%) brightness(1.05);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,0.15);
  box-shadow:0 8px 32px rgba(0,0,0,0.3),
              inset 0 1px 0 rgba(255,255,255,0.15);
  transition:all 0.3s ease;
}
.topbar__inner{
  max-width:1200px;
  margin:0 auto;
  padding:16px 32px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.topbar__logo{
  display:flex;
  align-items:center;
  gap:12px;
  transition:transform 0.2s ease;
}
.topbar__logo:hover{
  transform:scale(1.02);
}
.brand__logo{
  display:block;
  height:56px;
  width:auto;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,0.2));
}
.topnav{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:auto;
}
.topbar__link{
  color:#fff!important;
  font-weight:500;
  font-size:15px;
  line-height:1.3;
  padding:8px 16px;
  border-radius:8px;
  transition:all 0.2s ease;
  position:relative;
}
.topbar__link::after{
  content:'';
  position:absolute;
  bottom:4px;
  left:16px;
  right:16px;
  height:2px;
  background:rgba(255,255,255,0.8);
  transform:scaleX(0);
  transition:transform 0.2s ease;
  border-radius:2px;
}
.topbar__link:hover{
  background:rgba(255,255,255,0.1);
  text-decoration:none;
  transform:translateY(-1px);
}
.topbar__link:hover::after{
  transform:scaleX(1);
}
.topbar .user-email{
  color:rgba(255,255,255,0.8)!important;
  font-weight:500;
  font-size:14px;
  line-height:1.3;
  padding:8px 16px;
  background:rgba(255,255,255,0.08);
  border-radius:8px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  backdrop-filter:blur(8px);
}
.user-email::before{
  content:"👤";
  font-size:16px;
  margin:0;
}
.topbar .btn{
  background:linear-gradient(135deg, #00d4ff 0%, #0099ff 100%);
  color:#0f1419;
  border:0;
  padding:8px 20px;
  font-weight:700;
  font-size:14px;
  backdrop-filter:blur(8px);
  transition:all 0.2s ease;
  box-shadow:0 2px 8px rgba(0, 212, 255, 0.3);
}
.topbar .btn:hover{
  background:linear-gradient(135deg, #00ffff 0%, #00b8ff 100%);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0, 212, 255, 0.5);
}
.topbar .btn--muted{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.2);
  color:#ffffff;
  box-shadow:none;
}
.topbar .btn--muted:hover{
  background:rgba(255,255,255,0.15);
  border-color:rgba(255,255,255,0.3);
  box-shadow:0 2px 8px rgba(0,0,0,0.2);
}
@media (max-width:768px){
  .topbar__inner{
    padding:12px 20px;
  }
  .brand__logo{
    height:48px;
  }
  .topnav{
    gap:4px;
  }
  .topbar__link{
    padding:6px 12px;
    font-size:14px;
  }
}

/* ---------- Page frame & gating ---------- */
.frame{max-width:1200px;margin:20px auto 40px;padding:0 20px;overflow:visible;position:relative;z-index:1}

/* Remove legacy separators per your request */
.hairline{display:none!important;height:0}

/* Auth gating (body.auth = logged in) */
#appSection{display:none}
body.auth #appSection{display:block}
#authSection{display:none}
body:not(.auth) #authSection{display:grid}

/* ---------- Top stats (mast) ---------- */
.mast{display:none}
body.auth .mast{display:block}
.topbar + .mast{margin-top:var(--section-gap)}
.mast{margin-bottom:var(--section-gap);padding:6px 20px}
.mast__stats{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;max-width:1200px;margin:0 auto;
}
.stat{
  background:#fff;border:1px solid #e9eef6;border-radius:12px;
  padding:10px 14px;text-align:center;
  box-shadow:0 12px 32px rgba(16,24,40,.06);
}
.stat__label{font:600 var(--fs-label)/1.4 var(--font-main);color:rgba(255,255,255,0.7);margin-bottom:4px}
.stat__num{font:800 15px/1.2 var(--font-main);color:#ffffff}
.stat__num--lg{font:900 22px/1.2 var(--font-main)}
.stat--actions .stat__buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
@media (max-width:980px){.mast__stats{grid-template-columns:1fr}}

/* ---------- Grid ---------- */
.grid{display:grid;gap:28px}
.grid--2{grid-template-columns:1fr 1fr}
.col{min-width:0}
@media (max-width:980px){.grid--2{grid-template-columns:1fr}}

/* ---------- Cards (Glass Morphism) ---------- */
.card{
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-top:1px solid var(--glass-border-top);
  border-radius:20px;
  box-shadow:0 8px 32px rgba(0,0,0,0.3),
              inset 0 1px 0 rgba(255,255,255,0.15);
  overflow:hidden;
  position:relative;
}
.card::before{
  content:'';
  position:absolute;
  top:-2px;
  left:10%;
  right:10%;
  height:70px;
  background:radial-gradient(ellipse at top, rgba(255,255,255,0.18) 0%, transparent 70%);
  filter:blur(15px);
  pointer-events:none;
}
.card__hd{padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,0.1);position:relative;z-index:1}
.card__hd h2{margin:0;font:700 1.375rem/1.25 var(--font-main);color:#ffffff;letter-spacing:-0.01em}
.card__sub{margin:8px 0 0;color:rgba(255,255,255,0.7);font-weight:500;font-size:0.9375rem}
.card__bd{padding:20px 24px 24px;position:relative;z-index:1}
.col .card + .card{margin-top:24px}
.mb-4{margin-bottom:24px}

/* ---------- Buttons ---------- */
.btn,
button,
a.btn,
input[type="button"].btn,
input[type="submit"].btn{
  -webkit-appearance:none;appearance:none;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-main);font-size:var(--fs-button);line-height:1.25;font-weight:700;
  color:var(--btn-color);background:var(--btn-bg);
  padding:8px 18px;border:0;border-radius:var(--btn-radius);
  box-shadow:var(--btn-shadow);
  cursor:pointer;text-decoration:none;
  transition:all .2s ease;
}
.btn:hover{background:var(--btn-bg-hover);transform:translateY(-1px);box-shadow:0 6px 16px rgba(0, 212, 255, 0.4)}
.btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(0, 212, 255, 0.3)}
.btn--muted{background:var(--btn-bg);color:#fff}
.btn--sm{font-size:13px;padding:4px 10px}

/* Small nudges - only for form buttons, not header */
#saveSetBtn,#addSongForm .btn{position:relative;top:-3px}
#applyGapBtn{position:relative;top:2px}

/* ---------- Forms (Glass Theme) ---------- */
.field{display:grid;gap:8px;position:relative}
.field__label{font:600 var(--fs-label)/1.4 var(--font-main);color:rgba(255,255,255,0.9)}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
textarea,
select{
  width:100%;
  background:rgba(255,255,255,0.08);
  color:#ffffff;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:12px;
  padding:12px 16px;
  outline:none;
  transition:all .2s ease;
  font-size:14px;
  line-height:1.4;
  font-family:var(--font-main);
}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,0.4);font-style:normal}
input:hover,textarea:hover,select:hover{
  border-color:rgba(255,255,255,0.3);
  background:rgba(255,255,255,0.1);
}
input:focus,textarea:focus,select:focus{
  border-color:rgba(255,255,255,0.4);
  background:rgba(255,255,255,0.12);
  box-shadow:0 0 0 3px rgba(255,255,255,0.1);
}
textarea{min-height:110px;resize:vertical}
select{cursor:pointer}

/* Field with inline clear “✕” */
.field--withClear{position:relative;display:block}
.field--withClear .field__label{display:block;margin:0 0 8px}
.field--withClear input{display:block;width:100%;padding-right:48px;min-width:0}
.field--withClear .field__clear{
  position:absolute;right:12px;top:50%;
  transform:translateY(-50%); /* perfectly centered */
  width:var(--x-size);height:var(--x-size);
  border:1px solid rgba(255,255,255,0.15);border-radius:50%;
  background:var(--x-bg);color:var(--x-color);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  font-size:var(--x-font-size);font-weight:400;line-height:1;cursor:pointer;z-index:2;
  transition:all .2s ease;
}
.field--withClear .field__clear:hover{
  background:var(--x-bg-hover);
  border-color:rgba(255,255,255,0.3);
  transform:translateY(-50%) scale(1.1);
}

/* Inline chips (ALL CAPS, numbers, etc.) */
.inline-chips{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.chip__label{font:600 var(--fs-label)/1.4 var(--font-main);color:rgba(255,255,255,0.7)}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:10px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  font-weight:600;
  color:#ffffff;
  transition:all .2s ease;
  cursor:pointer;
}
.chip:hover{
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.3);
}
.chip input[type="checkbox"],.chip input[type="radio"]{
  width:16px;height:16px;
  accent-color:#00d4ff;
  cursor:pointer;
}
.chip span{font-size:14px;color:#ffffff}

/* Chip groups with labels (Position: Left/Center) */
.chip-group{
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 14px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:12px;
  flex-wrap:nowrap;
}
.chip-group .chip__label{
  font-weight:600;
  font-size:13px;
  color:rgba(255,255,255,0.9);
  margin-right:4px;
  white-space:nowrap;
  flex-shrink:0;
}
.chip-group input[type="text"]{
  width:60px;
  padding:4px 8px;
  font-size:13px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.2);
  color:#ffffff;
  border-radius:8px;
  height:26px;
  line-height:1;
  text-align:center;
  font-weight:600;
  box-sizing:border-box;
}
.chip-group input[type="text"]:focus{
  background:rgba(255,255,255,0.12);
  border-color:#00d4ff;
  outline:none;
}

/* Settings layout */
.grid--settings-top{
  display:grid;
  grid-template-columns:1.2fr 1.2fr .7fr .9fr auto;
  gap:12px 14px;align-items:end;
}
.grid--settings-bottom{
  display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center;margin-top:12px;
}

/* Input widths */
#bandName,#venueName,#setName{max-width:30ch}
#eventDate{max-width:19ch}
@media (max-width:1100px){
  #bandName,#venueName,#setName,#eventDate{max-width:100%}
}

/* “Time Between Songs” */
.gap-setting{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:nowrap}
.gap-setting .gap-label{font-weight:600;font-size:13px;color:rgba(255,255,255,0.9);white-space:nowrap}
.gap-setting input[type="text"]{width:92px;flex:0 0 auto;text-align:center;height:36px;line-height:36px;padding:0 10px}

/* Responsive collapse for settings */
@media (max-width:1100px){
  .grid--settings-top{grid-template-columns:1fr 1fr}
  .grid--settings-top .w-260{grid-column:1 / -1}
  .grid--settings-top .actions-wrap{grid-column:1 / -1;justify-content:flex-start;gap:10px}
}
@media (max-width:640px){
  .grid--settings-top{grid-template-columns:1fr}
  .grid--settings-top .w-260,
  .grid--settings-top .actions-wrap,
  .grid--settings-top .field{grid-column:1 / -1}
}

/* Add Song row */
#addSongForm.grid--addsong{
  display:grid;grid-template-columns:minmax(240px,1fr) 120px auto;
  column-gap:12px;row-gap:8px;align-items:end;
}

/* ---------- Lists (library & setlist cards) - Glass ---------- */
.list{display:grid;gap:14px}
.item{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;
  padding:14px 16px;
  background:linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  backdrop-filter:blur(15px);
  -webkit-backdrop-filter:blur(15px);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;
  transition:all .2s cubic-bezier(0.4, 0, 0.2, 1);
}
.item:hover{
  border-color:rgba(255,255,255,0.25);
  box-shadow:0 6px 20px rgba(0,0,0,0.25);
  background:linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.04) 100%);
  transform:translateY(-2px);
}
.item strong{font-weight:700;letter-spacing:.05px;color:#ffffff}
.item .meta{color:rgba(255,255,255,0.65);font-size:13px}
.dragHandle{cursor:grab;user-select:none;color:rgba(255,255,255,0.5);padding:0 6px;font-size:18px}

/* Remove button (X) within list items */
.item .row .rmBtn{
  all:unset;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--x-bg);color:var(--x-color);
  width:var(--x-size);height:var(--x-size);
  border-radius:50%;font-size:var(--x-font-size);font-weight:700;line-height:1;
  cursor:pointer;box-shadow:var(--x-shadow);
  transition:background .2s ease,transform .05s ease;
}
.item .row .rmBtn:hover{background:var(--x-bg-hover)}

/* Gap inputs (song + encore) */
#setList .row input.gap,
#setList .row input.sepTime{width:9ch;text-align:center;font-family:monospace;padding:2px 6px}
#setList .row input.gap::placeholder,
#setList .row input.sepTime::placeholder{font-style:normal;color:rgba(255,255,255,0.4)}

/* ---------- Preview & Print (screen preview only) ---------- */
.preview{background:#fff;border:1px solid #e6e9ee;border-radius:10px;padding:12px}

/* Authoritative preview canvas — locks to 8.5:11 and 550px max width */
@media screen{
  #printSurface{
    aspect-ratio:8.5 / 11;
    width:100%;
    max-width:550px;
    margin:0 auto;
    position:relative;
    display:flex;
    flex-direction:column;
    overflow:hidden; /* keep content inside */
    background:#fff;
  }
}

/* Header & footer black bars (preview + print colors retained) */
#printMeta,
#printFooter{
  background:#000;color:#fff;font-weight:800;text-align:center;
  border-radius:6px;line-height:1.2;
}
#printMeta{padding:6px 10px;margin:0 0 10px}
#printFooter{padding:6px 10px;margin-top:10px;font-size:10pt}

/* Encore line (within list) */
.encore-line{
  text-align:center;background:#eef1f6;color:#0e1420;
  font-weight:900;margin:10px 0;padding:7px 0 8px;border-radius:10px;letter-spacing:.6px;display:block;
}

/* Keep black bars solid on real printers */
@media print{
  #printMeta,#printFooter{
    -webkit-print-color-adjust:exact;print-color-adjust:exact;
  }
}

/* List inside the preview surface — JS controls sizing/fit */
.preview__list,
#printList{
  list-style:none;padding:0;margin:0;
  white-space:nowrap;width:100%;box-sizing:border-box;
  text-align:center; /* Default center, JavaScript can override */
}
.preview__list li,
#printList li{
  white-space:nowrap;word-break:keep-all;margin:0;
}

/* ---------- Auth / Landing visuals ---------- */
#authSection{margin-top:18px}
#authSection .card{margin-bottom:20px}
.auth-hero{
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
  background:linear-gradient(135deg,#f9fafc 0%,#f0f4ff 100%);
}
.auth-hero__inner{
  display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;padding:28px;
}
.fancy-hero{max-width:720px}
.fancy-hero .hero-eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:6px}
.fancy-hero h1{margin:0 0 10px;color:#ffffff}
.fancy-hero .hero-lead{font-size:16px;color:rgba(255,255,255,0.85);margin:0 0 18px}
.hero-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0 18px}
.kpi{background:#fff;border:1px solid rgba(19,32,74,.12);border-radius:12px;padding:12px 14px;box-shadow:0 6px 16px rgba(0,0,0,.04)}
.kpi-num{font-weight:800;font-size:17px;color:#ffffff;line-height:1.1}
.kpi-label{font-size:12px;color:rgba(255,255,255,0.7)}
.checklist{list-style:none;margin:6px 0 14px;padding:0;display:grid;gap:8px}
.checklist li{position:relative;padding-left:28px;font-size:14px;color:rgba(255,255,255,0.9)}
.checklist li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:#13204a;box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.checklist li::after{
  content:"";position:absolute;left:5px;top:8px;width:8px;height:4px;border:2px solid #fff;border-top:0;border-right:0;transform:rotate(-45deg);
}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px}
.badge{font-size:12px;color:#ffffff;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);padding:6px 10px;border-radius:999px}
.auth-hero__art{height:220px}
.auth-hero__art img{
  display:block;width:92%;height:100%;margin-left:auto;border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.18);
  object-fit:cover;object-position:right center;filter:brightness(.9) contrast(1.05) saturate(1.05);
}
#authSection .grid.grid--2{display:grid;grid-template-columns:1fr 1fr;gap:20px;border-top:1px solid rgba(0,0,0,.06);padding-top:20px}
#authSection .card__hd h2{margin:0}
#authSection .card__bd{padding-top:14px}
.form-gap{height:12px}
#authSection .auth-links{margin-top:10px}
#authSection .auth-links .topbar__link{color:rgba(255,255,255,0.9);text-decoration:none;font-weight:600}
#authSection .auth-links .topbar__link:hover{text-decoration:underline}

/* ---------- Auth responsive ---------- */
@media (max-width:980px){
  .auth-hero__inner{grid-template-columns:1fr;gap:18px;padding:22px}
  .auth-hero__art{height:180px}
  #authSection .grid.grid--2{grid-template-columns:1fr;gap:18px}
}
@media (max-width:560px){
  .hero-kpis{grid-template-columns:1fr}
  .auth-hero__copy h1{font-size:24px}
  .auth-hero__art{height:160px}
}

/* =======================================================================
   Setlist Preview — minimal, non-destructive fixes (appended at end)
   - Locks preview surface to true US Letter ratio (8.5:11)
   - Keeps width at 550px max, centers content vertically
   - Prevents upstream min-height rules from stretching the box
   - Adds graceful fallback for browsers without `aspect-ratio`
   ======================================================================= */
#printSurface{
  /* Letter shape and max width */
  aspect-ratio: 8.5 / 11;
  width: 100%;
  max-width: 550px;
  margin: 0 auto;

  /* Ensure the preview body sits in the middle when there's spare space */
  display: flex;
  flex-direction: column;
  justify-content: center;   /* vertical centering */
  align-items: center;       /* horizontal centering safeguard */

  /* Neutralize any inherited stretches */
  min-height: 0 !important;
  height: auto !important;

  /* If content grows too long, don't stretch the canvas—contain it */
  overflow: hidden;
}

/* Fallback for browsers lacking aspect-ratio: compute height from width */
@supports not (aspect-ratio: 1) {
  #printSurface{
    height: calc( min(100%, 550px) * (11 / 8.5) );
  }
}

/* Keep the list tight and centered inside the preview */
#printSurface .preview__list{
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;
  white-space: nowrap;
}

/* Make sure header/footer bars rendered inside the preview don't force growth */
#printSurface .preview__header,
#printSurface .preview__footer{
  flex: 0 0 auto;
}

/* =====================================================================
   Fix: Center preview content vertically inside printSurface
   ===================================================================== */
#printSurface {
  display: flex;
  flex-direction: column;
  justify-content: center; /* Centers header/songs/footer vertically */
  align-items: center;      /* Centers horizontally */
  position: relative;
}

#printSurface .preview__list {
  display: flex;
  flex-direction: column;
  justify-content: center; /* Ensures song list sits in the middle */
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

#printSurface .preview__header,
#printSurface .preview__footer {
  flex-shrink: 0;
}
