:root{
    --bg:#EDEEF0;
    --card:#FFFFFF;
    --ink:#16181D;
    --ink-soft:#5B6472;
    --line:#DFE1E6;
    --accent:#E8174A;
    --accent-ink:#B0103A;
    --section-bg:#F0F1F4;
    --bar-bg:rgba(237,238,240,.85);
    --toast-bg:#16181D;
    --tab-size:15px;
    --shadow:0 1px 2px rgba(20,24,29,.06), 0 8px 30px rgba(20,24,29,.08);
  }
  :root[data-theme="dark"]{
    --bg:#15171C;
    --card:#1E2127;
    --ink:#E7E9EE;
    --ink-soft:#9AA3B2;
    --line:#2C313B;
    --accent:#FF4D6D;
    --accent-ink:#FF6B85;
    --section-bg:#262B33;
    --bar-bg:rgba(21,23,28,.85);
    --toast-bg:#2A2F38;
    --shadow:0 1px 2px rgba(0,0,0,.4), 0 8px 30px rgba(0,0,0,.5);
  }

  *{box-sizing:border-box}
  html,body{margin:0}
  body{
    background:var(--bg);
    color:var(--ink);
    font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
    -webkit-font-smoothing:antialiased;
    line-height:1.5;
    overflow-x:hidden;
    transition:background .2s, color .2s;
  }

  /* ---------- top wordmark + input ---------- */
  .shell{max-width:880px;margin:0 auto;padding:28px 20px 80px}

  .brandrow{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:22px}
  .wordmark{
    font-family:'Anton',Impact,sans-serif;
    font-size:34px;letter-spacing:.5px;line-height:1;
    text-transform:uppercase;margin:0;
  }
  .wordmark .dot{color:var(--accent)}
  .tagline{color:var(--ink-soft);font-size:14px}

  .get-btn{
    font:700 15px 'Inter',sans-serif;
    color:#fff;background:var(--accent);
    border:none;border-radius:12px;
    padding:0 22px;cursor:pointer;white-space:nowrap;
    transition:background .15s,transform .05s;
  }
  .get-btn:hover{background:var(--accent-ink)}
  .get-btn:active{transform:translateY(1px)}
  .get-btn:disabled{opacity:.6;cursor:wait}
  .get-btn:focus-visible{outline:3px solid rgba(232,23,74,.4);outline-offset:2px}

  .paste-card{background:var(--card);border:1px solid var(--line);border-radius:14px;
    box-shadow:var(--shadow);padding:18px 18px 16px}
  .paste-label{display:block;font-weight:700;font-size:16px;margin-bottom:4px}
  .paste-help{margin:0 0 12px;font-size:13.5px;color:var(--ink-soft);line-height:1.55}
  .paste-card textarea{
    width:100%;height:130px;
    font:13px 'JetBrains Mono',monospace;
    background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:10px;padding:11px;resize:vertical;
  }
  .paste-card textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,23,74,.15)}
  .paste-btn{width:100%;margin-top:12px;padding:13px}
  .mini-btn{
    margin-top:8px;font:600 13px 'Inter';color:var(--ink);
    background:var(--card);border:1px solid var(--line);
    border-radius:9px;padding:8px 14px;cursor:pointer;
  }
  .mini-btn:hover{border-color:var(--accent);color:var(--accent)}

  /* ---------- status / empty ---------- */
  .status{margin-top:24px;font-size:14.5px;color:var(--ink-soft)}
  .status.error{color:var(--accent-ink)}
  .status .ex{color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:12.5px;word-break:break-all}
  .spinner{
    display:inline-block;width:14px;height:14px;margin-right:8px;vertical-align:-2px;
    border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;
    animation:spin .7s linear infinite;
  }
  @keyframes spin{to{transform:rotate(360deg)}}

  /* ---------- result ---------- */
  .result{margin-top:26px;display:none}
  .result.show{display:block}

  .controlbar{
    position:sticky;top:0;z-index:5;
    display:flex;align-items:center;gap:14px;flex-wrap:wrap;
    background:var(--bar-bg);backdrop-filter:blur(8px);
    border:1px solid var(--line);border-radius:12px;
    padding:10px 14px;margin-bottom:14px;
  }
  .nowplaying{display:flex;flex-direction:column;min-width:0;margin-right:auto}
  .np-song{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
  .np-artist{font-size:12.5px;color:var(--ink-soft)}
  .ctl-group{display:flex;align-items:center;gap:6px}
  .ctl{
    font:600 13px 'Inter';color:var(--ink);
    background:var(--card);border:1px solid var(--line);border-radius:9px;
    padding:7px 11px;cursor:pointer;transition:.12s;
  }
  .ctl:hover{border-color:var(--accent);color:var(--accent)}
  .ctl.on{background:var(--accent);border-color:var(--accent);color:#fff}
  .ctl:focus-visible{outline:3px solid rgba(232,23,74,.4);outline-offset:1px}
  .speed{width:90px;accent-color:var(--accent)}
  .ctl-label{font-size:11.5px;color:var(--ink-soft)}

  .secnav{display:none;gap:6px;overflow-x:auto;padding:0 0 12px;margin-top:-2px;-webkit-overflow-scrolling:touch}
  .secnav.show{display:flex}
  .secnav::-webkit-scrollbar{height:0}
  .secchip{flex:0 0 auto;font:600 12px 'Inter';color:var(--ink-soft);background:var(--section-bg);
    border:1px solid var(--line);border-radius:999px;padding:6px 12px;cursor:pointer;white-space:nowrap}
  .secchip:hover{border-color:var(--accent);color:var(--accent)}

  .meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
  .chip{
    font:600 12px 'JetBrains Mono',monospace;
    background:var(--section-bg);color:var(--ink-soft);
    border:1px solid var(--line);border-radius:999px;padding:5px 11px;
  }
  .chip b{color:var(--ink);font-weight:700}

  .sheet{
    background:var(--card);border:1px solid var(--line);border-radius:14px;
    box-shadow:var(--shadow);padding:24px 22px;
  }
  .tab-body{
    margin:0;
    font:500 var(--tab-size)/1.7 'JetBrains Mono','SFMono-Regular',Consolas,monospace;
    white-space:pre;            /* preserve chord/lyric alignment exactly */
    overflow-x:auto;
    color:var(--ink);
    tab-size:4;
  }
  /* width-preserving so chords stay aligned above lyrics */
  .chord{color:var(--accent);font-weight:700}
  .section{
    display:inline-block;font-weight:700;color:var(--ink);
    border-left:3px solid var(--accent);padding-left:8px;margin:4px 0;
  }

  /* ---------- library ---------- */
  .library-btn{
    margin-left:auto;align-self:center;
    font:700 13px 'Inter';color:var(--ink);
    background:var(--card);border:1px solid var(--line);border-radius:10px;
    padding:9px 14px;cursor:pointer;transition:.12s;
  }
  .library-btn:hover{border-color:var(--accent);color:var(--accent)}
  .library-btn .count{color:var(--accent);font-weight:700}

  .authbar{margin:-6px 0 22px}
  .auth-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  .auth-input{font:500 14px 'Inter';color:var(--ink);background:var(--card);
    border:1px solid var(--line);border-radius:10px;padding:9px 12px;min-width:0;flex:1 1 150px}
  .auth-input:focus{outline:none;border-color:var(--accent)}
  .auth-btn{font:700 13px 'Inter';color:var(--ink);background:var(--card);
    border:1px solid var(--line);border-radius:10px;padding:9px 14px;cursor:pointer;white-space:nowrap}
  .auth-btn:hover{border-color:var(--accent);color:var(--accent)}
  .auth-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
  .auth-btn.primary:hover{background:var(--accent-ink);color:#fff}
  .auth-who{font-size:13.5px;color:var(--ink-soft);margin-right:auto}
  .auth-who b{color:var(--ink)}

  .library{display:none;margin-top:16px;background:var(--card);border:1px solid var(--line);
    border-radius:14px;box-shadow:var(--shadow);padding:16px 16px 18px}
  .library.show{display:block}
  .lib-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
  .lib-title{font-weight:700;font-size:15px;margin-right:auto}
  .lib-search{flex-basis:100%;order:3;font:500 14px 'Inter';border:1px solid var(--line);
    border-radius:10px;padding:9px 12px;margin-top:6px;background:var(--card);color:var(--ink)}
  .lib-search:focus{outline:none;border-color:var(--accent)}
  .lib-list{display:grid;gap:8px}
  .lib-empty{color:var(--ink-soft);font-size:13.5px;padding:6px 2px;line-height:1.55}
  .lib-card{display:flex;align-items:center;gap:8px;flex-wrap:wrap;border:1px solid var(--line);
    border-radius:11px;padding:11px 13px;transition:.12s}
  .lib-card:hover{border-color:var(--accent)}
  .lib-card .info{flex:1 1 150px;min-width:0;cursor:pointer}
  .lib-card .tune{flex:0 0 auto;font:600 12px 'Inter';border:1px solid var(--line);
    border-radius:8px;padding:6px 8px;background:var(--card);color:var(--ink-soft);max-width:46vw}
  .lib-group{display:flex;align-items:center;gap:8px;margin:16px 2px 6px;
    font:700 11.5px 'Inter';text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft)}
  .lib-group:first-child{margin-top:2px}
  .lib-group .gcount{color:var(--accent)}
  .lib-card .s{font-weight:700;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .lib-card .a{font-size:12.5px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .lib-card .open{font:600 12.5px 'Inter';color:#fff;background:var(--accent);border:none;
    border-radius:8px;padding:7px 13px;cursor:pointer}
  .lib-card .open:hover{background:var(--accent-ink)}
  .lib-card .del{font:600 12.5px 'Inter';color:var(--ink-soft);background:none;border:1px solid var(--line);
    border-radius:8px;padding:7px 11px;cursor:pointer}
  .lib-card .del:hover{color:var(--accent-ink);border-color:var(--accent)}

  .ctl.saved{background:var(--accent);border-color:var(--accent);color:#fff}

  .toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);
    background:var(--toast-bg);color:#fff;font:600 13.5px 'Inter';padding:11px 18px;border-radius:10px;
    box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;pointer-events:none;transition:.25s;z-index:50}
  .toast b{color:#fff}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

  footer{margin-top:34px;font-size:12px;color:#9aa1ad;line-height:1.6}
  footer a{color:var(--ink-soft)}

  @media (max-width:600px){
    .shell{padding:18px 14px 70px}
    .wordmark{font-size:26px}
    .tagline{flex-basis:100%;font-size:13px}
    .get-btn{padding:0 16px}
    .controlbar{gap:10px 12px;padding:9px 11px}
    .nowplaying{flex-basis:100%;margin-right:0}
    .np-song{max-width:100%}
    .sheet{padding:16px 12px}
    .meta{gap:6px}
    .lib-head .mini-btn{flex:1 1 auto}
    .lib-card .tune{max-width:none;flex:1 1 100%;order:3}
  }
  @media (prefers-reduced-motion:reduce){
    .spinner{animation:none}
  }

  /* ---------- print: just the tab ---------- */
  @media print{
    body{background:#fff}
    .brandrow,.authbar,.paste-card,.library,.status,.controlbar,.secnav,.toast,footer{display:none !important}
    .shell{max-width:none;padding:0}
    .sheet{border:none;box-shadow:none;padding:0}
    .meta{margin-bottom:8px}
    .print-title{display:block !important}
  }
  .print-title{display:none;font-family:'Anton',sans-serif;font-size:22px;text-transform:uppercase;margin-bottom:4px}
  .print-artist{display:none}
  @media print{.print-artist{display:block;color:#444;margin-bottom:12px}}