/* image.sh — gallery white, ink type, cobalt accent, mono links */
:root {
  --paper: #ffffff;
  --ink: #14151a;
  --dim: #6b6f7b;
  --line: #e7e8ec;
  --accent: #2742f5;
  --accent-ink: #ffffff;
  --warn: #c2410c;
  --danger: #b91c1c;
  --term: #14151a;
  --term-ink: #e8eaf2;
  --ok: #34d399;
  --r: 10px;
  --mono: ui-monospace, "SF Mono", "Cascadia Mono", Menlo, Consolas, monospace;
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
html, body { height: 100%; }
body {
  margin: 0; background: var(--paper); color: var(--ink);
  font: 16px/1.55 "Archivo", system-ui, sans-serif;
  font-variation-settings: "wdth" 100;
  display: flex; flex-direction: column;
}
.nav, .footer { flex: 0 0 auto; }
main { flex: 1 1 auto; overflow-y: auto; min-height: 0; }
h1, h2, h3 { line-height: 1.1; letter-spacing: -0.02em; font-weight: 700; }
h1 { font-size: clamp(1.9rem, 4.5vw, 3.4rem); font-variation-settings: "wdth" 112; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.mono { font-family: var(--mono); }
.dim { color: var(--dim); }
.small { font-size: 0.84rem; }
.warn { color: var(--warn); }
.center { text-align: center; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* nav */
.nav { border-bottom: 1px solid var(--line); background: var(--paper); }
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  max-width: 1100px; margin: 0 auto; padding: 14px 20px;
}
.brand { color: var(--ink); font-weight: 700; font-size: 1.1rem; letter-spacing: -0.02em; }
.brand:hover { text-decoration: none; }
.brand-mark {
  font-family: var(--mono); background: var(--ink); color: #fff;
  border-radius: 6px; padding: 2px 6px; margin-right: 8px; font-size: 0.85em;
}
.brand-dot { color: var(--accent); }
.nav-right { display: flex; align-items: center; gap: 18px; }
.nav-link { color: var(--ink); font-weight: 500; }
.as-btn { background: none; border: 0; cursor: pointer; font: inherit; padding: 0; }
.avatar { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--line); }

/* buttons */
.btn {
  display: inline-block; background: var(--ink); color: #fff; border: 1px solid var(--ink);
  border-radius: 999px; padding: 9px 20px; font: inherit; font-weight: 600; cursor: pointer;
}
.btn:hover { background: var(--accent); border-color: var(--accent); text-decoration: none; color: #fff; }
.btn.ghost { background: transparent; color: var(--ink); }
.btn.ghost:hover { color: var(--accent); border-color: var(--accent); background: transparent; }
.mini {
  font: 600 0.78rem/1 "Archivo", sans-serif; padding: 5px 10px; border-radius: 999px;
  border: 1px solid var(--line); background: #fff; color: var(--ink); cursor: pointer;
}
.mini:hover { border-color: var(--accent); color: var(--accent); }
.mini.danger:hover { border-color: var(--danger); color: var(--danger); }

/* hero */
.hero { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: center; padding: 72px 20px; }
.eyebrow { color: var(--accent); font-size: 0.85rem; margin: 0 0 10px; letter-spacing: 0.04em; }
.hero h1 em { font-style: normal; color: var(--accent); }
.lede { font-size: 1.08rem; color: var(--dim); max-width: 46ch; }
.signin-block { margin-top: 28px; }
.signin-block .small { max-width: 40ch; margin-top: 10px; }

.term { background: var(--term); border-radius: 14px; box-shadow: 0 24px 60px rgba(20,21,26,.18); overflow: hidden; }
.term-bar { display: flex; gap: 6px; padding: 12px 14px; }
.term-bar span { width: 10px; height: 10px; border-radius: 50%; background: #3a3d47; }
.term-body { margin: 0; padding: 6px 18px 22px; color: var(--term-ink); font-size: 0.84rem; line-height: 1.7; overflow-x: auto; }
.ok { color: var(--ok); }
.cursor { animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .cursor { animation: none; } }

/* footer */
.footer { border-top: 1px solid var(--line); background: var(--paper); }
.footer-inner {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  max-width: 1100px; margin: 0 auto; padding: 18px 20px;
}
.footer-links a { color: var(--dim); margin-left: 14px; }
.footer-links a:first-child { margin-left: 0; }
.footer-links a:hover { color: var(--accent); }
.center-page { padding: 96px 20px; text-align: center; }

/* dropzone */
.dropzone {
  margin: 32px 0 8px; border: 2px dashed var(--line); border-radius: var(--r);
  padding: 40px 20px; text-align: center; cursor: pointer; transition: border-color .15s, background .15s;
}
.dropzone:hover, .dropzone.drag { border-color: var(--accent); background: #f5f7ff; }
.dz-title { font-weight: 600; font-size: 1.05rem; margin: 0 0 6px; }
.upload-list { display: flex; flex-direction: column; gap: 6px; margin: 10px 0; }
.upload-item { font-family: var(--mono); font-size: 0.82rem; color: var(--dim); }
.upload-item.err { color: var(--danger); }

/* library grid */
.lib-head { display: flex; align-items: baseline; justify-content: space-between; margin-top: 36px; flex-wrap: wrap; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 16px; margin: 16px 0 40px; }
.card { margin: 0; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; background: #fff; }
.card-link { display: block; aspect-ratio: 4/3; background: #f3f4f6; }
.card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card figcaption { padding: 10px 12px; }
.card-name { display: block; font-size: 0.78rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-meta { display: block; margin: 2px 0 8px; }
.card-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.card.hidden-img .card-link { opacity: 0.45; }

/* view page */
.view-page { display: grid; grid-template-columns: 1.4fr 0.6fr; gap: 36px; padding-top: 36px; align-items: start; }
.stage { margin: 0; }
.stage img { width: 100%; height: auto; border-radius: var(--r); border: 1px solid var(--line); background: #f3f4f6; }
.view-title { font-size: 1.25rem; word-break: break-word; margin: 0 0 4px; }
.links { margin-top: 18px; display: flex; flex-direction: column; gap: 10px; }
.link-row { display: grid; grid-template-columns: 78px 1fr auto; gap: 8px; align-items: center; }
.link-label { text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.66rem; }
.link-code {
  font-size: 0.74rem; background: #f6f7f9; border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 8px; white-space: nowrap; overflow-x: auto; scrollbar-width: none;
}
.owner-actions { margin-top: 22px; }

/* admin */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin: 12px 0 22px; flex-wrap: wrap; }
.tab {
  font: 600 0.9rem "Archivo", sans-serif; background: none; border: 0; cursor: pointer;
  padding: 10px 14px; color: var(--dim); border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.tab.active { color: var(--ink); border-bottom-color: var(--accent); }
.stat-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin: 8px 0 28px; }
.stat { border: 1px solid var(--line); border-radius: var(--r); padding: 14px 16px; }
.stat b { display: block; font-size: 1.5rem; letter-spacing: -0.02em; }
.stat span { color: var(--dim); font-size: 0.8rem; }
.spark { display: flex; align-items: flex-end; gap: 4px; height: 90px; padding: 8px 0 24px; }
.spark .bar { background: var(--accent); width: 100%; max-width: 38px; border-radius: 3px 3px 0 0; position: relative; min-height: 2px; }
.spark .bar i { position: absolute; bottom: -20px; left: 50%; transform: translateX(-50%); font-style: normal; font-size: 0.62rem; color: var(--dim); }
.search { width: 100%; max-width: 380px; font: inherit; padding: 9px 12px; border: 1px solid var(--line); border-radius: 8px; margin-bottom: 14px; }
.table-wrap { overflow-x: auto; }
table { border-collapse: collapse; width: 100%; font-size: 0.86rem; }
th { text-align: left; color: var(--dim); font-weight: 600; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; }
th, td { padding: 9px 10px; border-bottom: 1px solid var(--line); white-space: nowrap; vertical-align: top; }
td .thumb { width: 44px; height: 44px; object-fit: cover; border-radius: 6px; display: block; }
select.mini-sel, input.mini-in { font: inherit; font-size: 0.82rem; padding: 4px 6px; border: 1px solid var(--line); border-radius: 6px; }
input.mini-in { width: 80px; }
.settings-form, .invite-form { display: flex; flex-direction: column; gap: 14px; max-width: 460px; }
.settings-form label, .invite-form label { display: flex; flex-direction: column; gap: 5px; font-weight: 600; font-size: 0.88rem; }
.settings-form input:not([type=checkbox]),
.invite-form input:not([type=checkbox]) { font: inherit; padding: 9px 12px; border: 1px solid var(--line); border-radius: 8px; }
.settings-form .check { flex-direction: row; align-items: center; gap: 8px; }

/* invites */
.new-invite {
  margin-top: 18px; padding: 14px 16px; border: 1px solid var(--accent);
  border-radius: var(--r); background: #f5f7ff;
}
.invite-url-row { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.invite-url {
  flex: 1; font-size: 0.78rem; background: #fff; border: 1px solid var(--line);
  border-radius: 6px; padding: 7px 10px; white-space: nowrap; overflow-x: auto; scrollbar-width: none;
}
.pill {
  display: inline-block; font-size: 0.7rem; padding: 3px 9px; border-radius: 999px;
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
}
.pill-pending { background: #eef1ff; color: var(--accent); }
.pill-used    { background: #eef9f1; color: #166534; }
.pill-expired { background: #fdf1e8; color: var(--warn); }

/* legal pages */
.legal { max-width: 720px; margin: 0 auto; padding: 40px 24px 24px; }
.legal h1 { margin: 6px 0 4px; font-size: clamp(1.7rem, 3.5vw, 2.4rem); }
.legal h2 { margin-top: 32px; font-size: 1.1rem; }
.legal p { margin: 0.8em 0; }
.legal .updated { margin: 4px 0 24px; }
.legal ul { margin: 0.6em 0; padding-left: 20px; }
.legal li { margin: 0.35em 0; }
.legal code { font-size: 0.9em; }

/* Tablet — collapse 2-col layouts */
@media (max-width: 820px) {
  .hero { grid-template-columns: 1fr; padding: 44px 20px; gap: 28px; }
  .view-page { grid-template-columns: 1fr; }
  .link-row { grid-template-columns: 1fr auto; }
  .link-label { grid-column: 1 / -1; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-links a { margin-left: 0; margin-right: 14px; }
}

/* Phones */
@media (max-width: 640px) {
  .nav-inner { padding: 12px 16px; }
  .nav-right { gap: 12px; }
  .container { padding: 0 16px; }

  .hero { padding: 32px 16px; gap: 24px; }
  .lede { font-size: 1rem; }
  .term { box-shadow: 0 12px 28px rgba(20,21,26,.14); }
  .term-body { font-size: 0.78rem; padding: 6px 14px 18px; }

  .dropzone { padding: 28px 16px; margin-top: 20px; }
  .dz-title { font-size: 1rem; }

  .grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
  .card figcaption { padding: 8px 10px; }
  .card-name { font-size: 0.74rem; }
  .card-actions { gap: 4px; }
  .card-actions .mini { flex: 1; min-width: 0; padding: 8px 6px; font-size: 0.72rem; }

  .view-page { padding-top: 24px; gap: 24px; }
  .view-title { font-size: 1.1rem; }
  .link-code { font-size: 0.72rem; }

  .stat-row { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .stat { padding: 12px 14px; }
  .stat b { font-size: 1.25rem; }
  .tabs { gap: 0; overflow-x: auto; flex-wrap: nowrap; }
  .tab { padding: 9px 12px; font-size: 0.85rem; white-space: nowrap; }

  .legal { padding: 28px 18px 20px; }
  .legal h1 { font-size: clamp(1.5rem, 6vw, 2rem); }
  .legal h2 { font-size: 1.05rem; margin-top: 26px; }

  /* Tap target floor — buttons in tight rows shouldn't be tiny */
  .mini { padding: 7px 11px; }

  /* iOS zoom prevention: bump small inputs that would otherwise auto-zoom */
  .mini-in { font-size: 16px; width: 70px; }
  select.mini-sel { font-size: 16px; }
}

/* Small phones */
@media (max-width: 420px) {
  .nav-inner { padding: 10px 14px; }
  .brand { font-size: 1rem; }
  .brand-mark { font-size: 0.78em; padding: 1px 5px; margin-right: 6px; }
  .nav-right { gap: 10px; }
  .nav-link { font-size: 0.88rem; }
  .avatar { width: 26px; height: 26px; }

  h1 { font-size: clamp(1.6rem, 7.5vw, 2.4rem); }
  .container { padding: 0 14px; }

  .grid { grid-template-columns: 1fr 1fr; gap: 10px; }

  .stat-row { gap: 8px; }
  .stat { padding: 10px 12px; }
  .stat b { font-size: 1.1rem; }

  .link-row { grid-template-columns: 1fr; gap: 4px; }
  .link-row .mini { justify-self: start; }
}

/* iOS Safari auto-zooms <input> with font-size < 16px on focus — apply globally */
input[type="text"], input[type="email"], input[type="number"],
input[type="password"], input[type="search"], input[type="url"],
textarea, select { font-size: max(16px, 1rem); }
.search { font-size: 16px; }

/* ── video ────────────────────────────────────────────── */
.stage video { width: 100%; height: auto; border-radius: var(--r); border: 1px solid var(--line); background: #000; display: block; }
.stage-processing {
  width: 100%; aspect-ratio: 16/9; border-radius: var(--r); border: 1px solid var(--line);
  background: linear-gradient(135deg, #f3f4f6, #e7e8ec);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px;
}
.spinner {
  width: 36px; height: 36px; border-radius: 50%;
  border: 3px solid var(--line); border-top-color: var(--accent);
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .spinner { animation: none; } }

/* Card badges — play / processing / failed */
.card-link { position: relative; }
.card-badge {
  position: absolute; left: 8px; bottom: 8px;
  font: 600 0.7rem/1 "Archivo", sans-serif;
  padding: 4px 8px; border-radius: 999px;
  background: rgba(20,21,26,0.78); color: #fff;
  backdrop-filter: blur(2px);
}
.badge-processing { background: rgba(39,66,245,0.92); }
.badge-failed     { background: rgba(185,28,28,0.92); }
.card.processing .card-link {
  background: linear-gradient(135deg, #f3f4f6, #e7e8ec);
  display: flex; align-items: center; justify-content: center;
}
.card.processing .card-link::before {
  content: ""; width: 28px; height: 28px; border-radius: 50%;
  border: 3px solid var(--line); border-top-color: var(--accent);
  animation: spin 0.9s linear infinite; position: absolute;
}
.card.failed .card-link {
  background: repeating-linear-gradient(45deg, #fdf1e8, #fdf1e8 6px, #fce4d2 6px, #fce4d2 12px);
}

/* Admin pill for video media type */
.pill-video { background: #eef1ff; color: var(--accent); }

/* Admin settings form: section dividers */
.settings-form .form-group {
  margin: 8px 0 -4px; font-size: 0.7rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--dim); font-weight: 700;
}
