/* Subtitle Converter — page styles (tokens come from /assets/tokens.css). */
.sc-wrap { max-width: 880px; margin: 0 auto; padding: 24px 20px 64px; }
.sc-hero { margin: 18px 0 14px; }
.sc-hero h1 { margin: 6px 0 8px; font-size: clamp(26px, 4vw, 34px); letter-spacing: -0.5px; }
.sc-tagline { color: var(--muted); max-width: 60ch; margin: 0; }

.sc-notice { display: flex; gap: 10px; align-items: flex-start; background: var(--card); border: 1px solid var(--hairline); border-radius: 12px; padding: 10px 14px; color: var(--muted); font-size: 14px; margin: 14px 0 18px; }
.sc-notice-ico { color: var(--ok, #4caf7d); font-weight: 700; }

.sc-drop { border: 1.5px dashed var(--hairline-strong, var(--hairline)); border-radius: 16px; background: var(--card); padding: 34px 18px; text-align: center; cursor: pointer; transition: border-color .15s, background .15s; }
.sc-drop:hover, .sc-drop:focus-visible, .sc-drop.drag { border-color: var(--accent); background: var(--card-hover, var(--card)); outline: none; }
.sc-drop-ico { font-size: 30px; color: var(--muted); margin-bottom: 8px; }
.sc-drop-title { font-weight: 600; margin: 0 0 4px; }
.sc-drop-sub { color: var(--muted); font-size: 13px; margin: 0; }

.sc-paste { margin: 12px 0 0; color: var(--muted); }
.sc-paste summary { cursor: pointer; font-size: 14px; }
.sc-paste textarea { width: 100%; margin: 10px 0 8px; background: var(--card); color: var(--text); border: 1px solid var(--hairline); border-radius: 10px; padding: 10px 12px; font: 13px/1.5 "DM Mono", monospace; resize: vertical; }

.sc-fileinfo { color: var(--muted); font-size: 14px; margin: 12px 0 0; }
.sc-error { color: var(--accent); font-size: 14px; margin: 12px 0 0; }

.sc-panel { background: var(--card); border: 1px solid var(--hairline); border-radius: 16px; padding: 18px; margin-top: 18px; }
.sc-detected { font-size: 14px; color: var(--muted); margin-bottom: 14px; }
.sc-detected strong { color: var(--text); text-transform: uppercase; }
.sc-cuecount { margin-left: 8px; }

.sc-opts { display: flex; flex-wrap: wrap; gap: 14px 18px; align-items: flex-end; }
.sc-field { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.sc-field select, .sc-field input { background: var(--bg); color: var(--text); border: 1px solid var(--hairline); border-radius: 10px; padding: 8px 10px; font-size: 14px; min-width: 150px; }
.sc-field input#shift { min-width: 90px; width: 110px; }
.sc-field input#startTc { min-width: 120px; width: 130px; }
.sc-check { display: flex; gap: 8px; align-items: center; font-size: 13px; color: var(--muted); padding-bottom: 9px; }
.sc-note { color: var(--muted); font-size: 13px; margin: 12px 0 0; min-height: 1em; }

.sc-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.sc-btn { background: var(--card); color: var(--text); border: 1px solid var(--hairline); border-radius: 10px; padding: 9px 16px; font-size: 14px; font-weight: 600; cursor: pointer; transition: border-color .15s, background .15s; }
.sc-btn:hover { border-color: var(--accent); }
.sc-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.sc-btn.primary:hover { filter: brightness(1.08); }
.sc-btn.ghost { background: transparent; }

.sc-preview { margin-top: 22px; }
.sc-h2 { font-size: 18px; margin: 0 0 10px; }
.sc-table-wrap { overflow-x: auto; border: 1px solid var(--hairline); border-radius: 12px; }
.sc-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.sc-table th, .sc-table td { text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--hairline); vertical-align: top; }
.sc-table th { color: var(--muted); font-weight: 600; background: var(--card); position: sticky; top: 0; }
.sc-table td:nth-child(1) { color: var(--muted); width: 40px; }
.sc-table td:nth-child(2), .sc-table td:nth-child(3) { font-family: "DM Mono", monospace; white-space: nowrap; }
.sc-table td:nth-child(4) { white-space: pre-line; }
.sc-more { color: var(--muted); font-size: 13px; margin: 8px 2px 0; }

.sc-content { margin-top: 44px; border-top: 1px solid var(--hairline); padding-top: 26px; }
.sc-content h2 { font-size: 19px; margin: 26px 0 8px; }
.sc-content p, .sc-content li { color: var(--muted); line-height: 1.65; }
.sc-steps { padding-left: 20px; }
.sc-faq details { border-bottom: 1px solid var(--hairline); padding: 10px 0; }
.sc-faq summary { cursor: pointer; font-weight: 600; color: var(--text); }
.sc-faq p { margin: 8px 0 2px; }
.sc-related a { color: var(--text); text-decoration: underline; text-underline-offset: 3px; }

@media (max-width: 560px) {
  .sc-opts { flex-direction: column; align-items: stretch; }
  .sc-field select, .sc-field input { width: 100%; }
}
