@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --black: #080808;
  --panel: #100d0b;
  --panel-2: #16110d;
  --line: #2a221b;
  --line-gold: rgba(201, 168, 76, 0.28);
  --gold: #C9A84C;
  --gold-dim: #BA8231;
  --ivory: #EDE5D4;
  --bege: #8A8070;
  --serif: 'Cormorant Garamond', Garamond, serif;
  --sans: 'DM Sans', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--black);
  color: var(--ivory);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 32px; }

/* ---------- topbar ---------- */
.topbar {
  border-bottom: 1px solid var(--line);
  padding: 22px 0;
  display: flex;
  align-items: center;
  gap: 16px;
}
.topbar img { height: 44px; width: auto; }
.topbar .brand-block { flex: 1; }
.topbar h1 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 26px;
  letter-spacing: 0.04em;
  color: var(--ivory);
}
.topbar .sub {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bege);
  margin-top: 2px;
}
.dot {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; letter-spacing: 0.05em; color: var(--bege);
}
.dot::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: #4a3f30;
}
.dot.on::before { background: var(--gold); box-shadow: 0 0 8px var(--gold); }

/* ---------- section ---------- */
.eyebrow {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold-dim); margin: 40px 0 18px;
}

/* ---------- episode grid ---------- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 18px; }

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 22px;
  transition: border-color 0.2s;
  display: block;
}
.card:hover { border-color: var(--line-gold); }
.card h3 {
  font-family: var(--serif); font-weight: 400; font-size: 22px;
  letter-spacing: 0.01em; margin-bottom: 4px; color: var(--ivory);
}
.card .slug { font-size: 11px; letter-spacing: 0.06em; color: var(--bege); }
.card .stats { display: flex; gap: 20px; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); }
.stat { display: flex; flex-direction: column; gap: 2px; }
.stat .n { font-family: var(--serif); font-size: 30px; line-height: 1; color: var(--gold); }
.stat .l { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bege); }
.stat.off .n { color: #3a3128; }

/* ---------- add form ---------- */
.add {
  background: var(--panel-2);
  border: 1px dashed var(--line-gold);
  border-radius: 4px; padding: 22px;
  display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-end;
}
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bege); }
.field input {
  background: var(--black); border: 1px solid var(--line); color: var(--ivory);
  font-family: var(--sans); font-size: 14px; padding: 9px 12px; border-radius: 3px; min-width: 240px;
}
.field input:focus { outline: none; border-color: var(--gold-dim); }
.field.grow { flex: 1; }
.field.grow input { width: 100%; }

/* ---------- buttons ---------- */
.btn {
  font-family: var(--sans); font-size: 13px; font-weight: 400;
  letter-spacing: 0.04em; padding: 10px 18px; border-radius: 3px;
  border: 1px solid var(--gold-dim); background: transparent; color: var(--gold);
  cursor: pointer; transition: all 0.18s;
}
.btn:hover { background: var(--gold); color: var(--black); }
.btn.solid { background: var(--gold); color: var(--black); }
.btn.solid:hover { background: var(--gold-dim); border-color: var(--gold-dim); }
.btn.ghost { border-color: var(--line); color: var(--bege); }
.btn.ghost:hover { border-color: var(--gold-dim); color: var(--gold); background: transparent; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ---------- episode page ---------- */
.back { font-size: 12px; letter-spacing: 0.1em; color: var(--bege); margin: 28px 0 6px; display: inline-block; }
.back:hover { color: var(--gold); }
.ep-title { font-family: var(--serif); font-weight: 300; font-size: 40px; letter-spacing: 0.02em; margin-bottom: 6px; }
.ep-meta { font-size: 12px; letter-spacing: 0.08em; color: var(--bege); margin-bottom: 8px; }
.ep-meta a { color: var(--gold-dim); }

.panels { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 12px; }
@media (max-width: 860px) { .panels { grid-template-columns: 1fr; } }

.panel {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 4px; padding: 24px;
}
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.panel-head h2 { font-family: var(--serif); font-weight: 400; font-size: 24px; letter-spacing: 0.02em; }
.panel .status { font-size: 12px; color: var(--bege); margin-bottom: 18px; }
.panel .status b { color: var(--gold); font-weight: 400; }
.actions { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; }

.tline {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 4px;
  padding: 16px 20px; margin-top: 12px; display: flex; align-items: center;
  justify-content: space-between; gap: 16px;
}
.tline .lbl { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bege); }
.tline .val { font-family: var(--serif); font-size: 22px; color: var(--gold); }

/* slides gallery */
.slides { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 8px; }
.slides img { width: 100%; border-radius: 2px; border: 1px solid var(--line); display: block; }
.ver-label { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-dim); margin: 16px 0 8px; }
.reels { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.reels video { width: 100%; border-radius: 3px; border: 1px solid var(--line); background: #000; }
.reels .rname { font-size: 11px; color: var(--bege); margin-top: 4px; }

.empty { font-size: 13px; color: var(--bege); font-style: italic; padding: 20px 0; }

.cmd-box {
  background: var(--black); border: 1px solid var(--line-gold); border-radius: 3px;
  padding: 14px 16px; font-family: ui-monospace, monospace; font-size: 13px;
  color: var(--gold); margin-top: 14px; word-break: break-all; display: none;
}
.cmd-box.show { display: block; }

.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: var(--panel-2); border: 1px solid var(--line-gold); color: var(--ivory);
  padding: 14px 22px; border-radius: 4px; font-size: 14px; opacity: 0;
  transition: opacity 0.25s; pointer-events: none; z-index: 50;
}
.toast.show { opacity: 1; }

.footer { border-top: 1px solid var(--line); margin-top: 56px; padding: 24px 0 48px; font-size: 11px; letter-spacing: 0.12em; color: var(--bege); text-transform: uppercase; }

/* ---------- nav ---------- */
.nav { display: flex; gap: 22px; }
.nav a { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bege); padding-bottom: 3px; border-bottom: 1px solid transparent; }
.nav a:hover { color: var(--gold); }
.nav a.active { color: var(--gold); border-bottom-color: var(--gold-dim); }

/* ---------- brand page ---------- */
.muted { color: var(--bege); }
.bad-inline { color: #b5654d; font-size: 11px; }

.swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.swatch { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 12px; }
.swatch .chip { height: 56px; border-radius: 3px; border: 1px solid var(--line); margin-bottom: 10px; }
.swatch .sw-name { font-size: 13px; color: var(--ivory); }
.swatch .sw-hex { font-family: ui-monospace, monospace; font-size: 11px; color: var(--bege); margin-top: 2px; }

.type-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 700px) { .type-grid { grid-template-columns: 1fr; } }
.type-card { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 20px; display: flex; align-items: center; gap: 20px; }
.type-sample { color: var(--gold); line-height: 1; min-width: 70px; text-align: center; }
.type-meta { font-size: 13px; color: var(--ivory); line-height: 1.6; }
.type-meta b { font-weight: 500; color: var(--gold); }

.spec-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px; }
.spec { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 14px 16px; display: flex; flex-direction: column; gap: 4px; }
.spec .l { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bege); }
.spec .v { font-family: var(--serif); font-size: 20px; color: var(--gold); }

.voice { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 700px) { .voice { grid-template-columns: 1fr; } }
.voice-block { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 16px 18px; }
.vb-label { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-dim); margin-bottom: 10px; }
.tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: 12px; color: var(--ivory); background: var(--panel-2); border: 1px solid var(--line); border-radius: 999px; padding: 4px 11px; }
.tag.good { border-color: rgba(120,150,90,0.4); color: #b6c89a; }
.tag.bad { border-color: rgba(150,80,60,0.4); color: #c8a08f; }
.tag.gold { border-color: var(--line-gold); color: var(--gold); }

/* collapsible docs */
.doc { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; margin-bottom: 10px; }
.doc > summary { cursor: pointer; padding: 16px 20px; font-size: 14px; color: var(--ivory); list-style: none; display: flex; align-items: center; gap: 12px; }
.doc > summary::-webkit-details-marker { display: none; }
.doc > summary::before { content: '▸'; color: var(--gold-dim); transition: transform 0.15s; }
.doc[open] > summary::before { transform: rotate(90deg); }
.doc[open] > summary { border-bottom: 1px solid var(--line); }
.doc .doc-path { margin-left: auto; font-family: ui-monospace, monospace; font-size: 11px; color: var(--bege); }
.md { padding: 8px 26px 26px; color: var(--ivory); font-size: 14px; line-height: 1.7; max-width: 760px; }
.md h1, .md h2, .md h3 { font-family: var(--serif); font-weight: 400; color: var(--gold); margin: 22px 0 10px; line-height: 1.2; }
.md h1 { font-size: 26px; } .md h2 { font-size: 22px; } .md h3 { font-size: 18px; }
.md p { margin: 10px 0; } .md ul, .md ol { margin: 10px 0 10px 22px; } .md li { margin: 4px 0; }
.md a { color: var(--gold); text-decoration: underline; }
.md code { font-family: ui-monospace, monospace; font-size: 12px; background: var(--black); border: 1px solid var(--line); border-radius: 3px; padding: 1px 6px; color: var(--gold); }
.md blockquote { border-left: 2px solid var(--gold-dim); margin: 12px 0; padding: 4px 16px; color: var(--bege); font-style: italic; }
.md table { border-collapse: collapse; margin: 14px 0; font-size: 13px; }
.md th, .md td { border: 1px solid var(--line); padding: 6px 12px; text-align: left; }
.md th { color: var(--gold-dim); }
.md hr { border: none; border-top: 1px solid var(--line); margin: 22px 0; }

/* ---------- login ---------- */
.login-wrap { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 24px; }
.login-card { background: var(--panel); border: 1px solid var(--line); border-radius: 6px; padding: 44px 48px; text-align: center; width: 340px; max-width: 90vw; }
.login-logo { height: 64px; margin-bottom: 18px; }
.login-card h1 { font-family: var(--serif); font-weight: 300; font-size: 30px; letter-spacing: 0.04em; color: var(--ivory); }
.login-sub { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--bege); margin: 4px 0 28px; }
.login-card form { display: flex; flex-direction: column; gap: 12px; }
.pin-input {
  background: var(--black); border: 1px solid var(--line); color: var(--ivory);
  font-family: var(--serif); font-size: 30px; letter-spacing: 0.5em; text-align: center;
  padding: 14px 12px; border-radius: 4px; width: 100%;
}
.pin-input:focus { outline: none; border-color: var(--gold-dim); }
.login-card .btn { width: 100%; padding: 13px; font-size: 14px; }
.login-error { margin-top: 16px; font-size: 13px; color: #c8907c; }
.login-foot { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bege); }

/* ---------- step dots ---------- */
.step-dots { display: flex; gap: 10px; flex-wrap: wrap; margin: 28px 0 18px; }
.step-dots .sd { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bege); border: 1px solid var(--line); border-radius: 999px; padding: 5px 14px; }
.step-dots .sd.on { color: var(--gold); border-color: var(--line-gold); }

/* ---------- create form ---------- */
.create-hero { margin-top: 8px; }
.create-form { margin-top: 26px; display: flex; flex-direction: column; gap: 18px; max-width: 640px; }
.create-form .field input { width: 100%; }
.create-form .field input[type=url], .create-form .field input[name=note] { font-size: 15px; padding: 12px 14px; }
.checks { display: flex; gap: 12px; flex-wrap: wrap; }
.check {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 400; letter-spacing: normal; text-transform: none;
  color: var(--ivory); cursor: pointer;
  background: var(--panel); border: 1px solid var(--line); border-radius: 999px;
  padding: 8px 16px;
}
.check:has(input:checked) { border-color: var(--line-gold); color: var(--gold); }
.check input { accent-color: var(--gold); width: 15px; height: 15px; margin: 0; }
.create-form .btn { align-self: flex-start; padding: 12px 26px; }

/* ---------- job log ---------- */
.joblog { display: flex; flex-direction: column; gap: 6px; font-family: ui-monospace, monospace; font-size: 12.5px; }
.logline { display: flex; gap: 12px; color: var(--ivory); }
.logline .lt { color: var(--bege); min-width: 62px; }

/* ---------- angles ---------- */
.angles { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.angle-card { text-align: left; background: var(--panel); border: 1px solid var(--line); border-radius: 5px; padding: 20px; cursor: pointer; transition: border-color 0.18s, background 0.18s; font-family: inherit; }
.angle-card:hover { border-color: var(--line-gold); }
.angle-card.chosen { border-color: var(--gold); background: var(--panel-2); }
.angle-card:disabled { opacity: 0.5; cursor: default; }
.angle-card h3 { font-family: var(--serif); font-weight: 400; font-size: 21px; color: var(--gold); margin-bottom: 8px; }
.angle-card p { font-size: 13px; color: var(--ivory); line-height: 1.55; }

/* ---------- grid clean (slides, estilo preview editorial) ---------- */
.grid-clean { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
@media (max-width: 1100px) { .grid-clean { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 760px) { .grid-clean { grid-template-columns: repeat(2, 1fr); } }
.cc { display: flex; flex-direction: column; gap: 9px; }
.cc-label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bege); }
.cc-label .num { color: var(--gold); font-weight: 700; }
.cc img { width: 100%; border-radius: 3px; border: 1px solid var(--line); display: block; }

/* ---------- captions ---------- */
.captions { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 14px; }
.cap-block { background: var(--panel); border: 1px solid var(--line); border-radius: 5px; overflow: hidden; }
.cap-head { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--line); }
.cap-head span { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-dim); }
.cap-head .btn { padding: 5px 12px; font-size: 12px; }
.cap-text { padding: 16px; font-family: var(--sans); font-size: 13.5px; line-height: 1.65; color: var(--ivory); white-space: pre-wrap; word-wrap: break-word; }
