/* Storyboard Studio guide — เว็บแอป reader (ธีมหนัง/cinema) */
:root{
  /* default = dark cinema */
  --bg:#0f0d0b; --surface:#1a1613; --text:#ece7df; --muted:#a89e90;
  --line:#2e2822; --accent:#e8a64e; --accent-2:#e0573a; --accent-soft:#2a2014;
  --code-bg:#1e1a14; --quote-bg:#1c1813; --sidebar:#141110;
  --max:46rem; --sidebar-w:18.5rem;
}
[data-theme="light"]{
  --bg:#faf7f2; --surface:#ffffff; --text:#221f1a; --muted:#6b645c;
  --line:#e7e0d6; --accent:#c2562f; --accent-2:#c2562f; --accent-soft:#f6e9e1;
  --code-bg:#f3efea; --quote-bg:#f7f3ee; --sidebar:#f3efe8;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:'Sarabun','Leelawadee UI','Tahoma',system-ui,sans-serif;
  font-size:18px; line-height:1.78; -webkit-font-smoothing:antialiased;
}
code,pre{font-family:'JetBrains Mono',ui-monospace,'Consolas',monospace}

/* progress bar */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:50;transition:width .1s}
.sitecredit{text-align:center;padding:1.4rem 1rem;color:var(--muted);font-size:.82rem;border-top:1px solid var(--line);background:var(--surface)}

/* topbar */
.topbar{
  position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:.7rem;
  padding:.6rem 1rem;background:var(--surface);border-bottom:1px solid var(--line);
}
.topbar .brand{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .brand-sub{color:var(--accent)}
.topbar #search{
  flex:1;min-width:6rem;max-width:22rem;margin-left:auto;padding:.45rem .7rem;
  border:1px solid var(--line);border-radius:.6rem;background:var(--bg);color:var(--text);font:inherit;font-size:.9rem;
}
.btn{
  display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .7rem;border:1px solid var(--line);
  border-radius:.6rem;background:var(--bg);color:var(--text);cursor:pointer;font:inherit;font-size:.9rem;text-decoration:none;white-space:nowrap;
}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1208;border-color:transparent;font-weight:700}
.btn.primary:hover{filter:brightness(1.08);color:#1a1208}
#menuBtn{display:none;font-size:1.2rem;background:none;border:none;color:var(--text);cursor:pointer}

/* layout */
.layout{display:flex;align-items:flex-start}
.sidebar{
  position:sticky;top:3.4rem;width:var(--sidebar-w);flex:0 0 var(--sidebar-w);height:calc(100vh - 3.4rem);
  overflow-y:auto;padding:1rem .6rem 3rem;background:var(--sidebar);border-right:1px solid var(--line);
}
.sidebar .navlink{
  display:flex;align-items:baseline;gap:.55rem;padding:.5rem .7rem;margin:.12rem 0;border-radius:.5rem;color:var(--muted);
  text-decoration:none;font-size:.92rem;line-height:1.4;
}
.sidebar .navlink .navnum{font-family:'JetBrains Mono',monospace;font-size:.72rem;opacity:.6;flex:0 0 auto}
.sidebar .navlink:hover{background:var(--accent-soft);color:var(--text)}
.sidebar .navlink.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1208;font-weight:700}
.sidebar .navlink.active .navnum{opacity:.85}
.sidebar .navlink.hide{display:none}

.content{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;padding:2rem 1.25rem 5rem}
.chapter{width:100%;max-width:var(--max)}
.chapter[hidden]{display:none}

/* hero card (หน้าแรก) */
.herocard{width:100%;max-width:var(--max);margin:0 0 1.8rem;padding:1.6rem 1.6rem;
  background:radial-gradient(120% 140% at 0% 0%,var(--accent-soft),var(--surface) 60%);
  border:1px solid var(--line);border-radius:1rem;box-shadow:0 6px 28px rgba(0,0,0,.22);overflow:hidden;position:relative}
.herocard[hidden]{display:none}
.hc-badge{display:inline-block;font-size:.74rem;font-weight:700;color:var(--accent);background:var(--surface);
  border:1px solid var(--line);border-radius:1rem;padding:.22rem .7rem;margin-bottom:.9rem}
.hc-h{font-size:1.7rem;font-weight:700;line-height:1.25;color:var(--text)}
.hc-sub{color:var(--muted);font-size:.98rem;margin:.6rem 0 1.2rem;line-height:1.6}
.hc-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-bottom:1.3rem}
.hc-step{display:flex;flex-direction:column;gap:.2rem;padding:.8rem .8rem;background:var(--surface);border:1px solid var(--line);border-radius:.7rem}
.hc-n{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1208;font-weight:700;font-size:.85rem}
.hc-step .hc-t{font-weight:700;font-size:.95rem;margin-top:.25rem}
.hc-step .hc-d{color:var(--muted);font-size:.78rem;line-height:1.4}
.hc-cta{display:flex;flex-wrap:wrap;gap:.7rem}
.hc-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.6rem 1.1rem;border-radius:.6rem;border:1px solid var(--line);
  background:var(--bg);color:var(--text);font:inherit;font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none}
.hc-btn:hover{border-color:var(--accent);color:var(--accent)}
.hc-btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1208;border-color:transparent;font-weight:700}
.hc-btn.primary:hover{filter:brightness(1.08);color:#1a1208}
.hc-note{margin-top:1.1rem;padding-top:.85rem;border-top:1px solid var(--line);color:var(--muted);font-size:.76rem;line-height:1.55}

/* typography */
.chapter h1{font-size:1.9rem;line-height:1.3;margin:.2rem 0 1.2rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent)}
.chapter h2{font-size:1.38rem;margin:2.2rem 0 .8rem}
.chapter h3{font-size:1.14rem;margin:1.6rem 0 .6rem;color:var(--accent)}
.chapter p{margin:.7rem 0}
.chapter a{color:var(--accent)}
.chapter hr{border:none;border-top:1px solid var(--line);margin:2rem 0}
.chapter ul,.chapter ol{padding-left:1.4rem}
.chapter li{margin:.3rem 0}
.chapter strong{font-weight:700}

/* callout blockquotes */
.chapter blockquote{
  margin:1rem 0;padding:.85rem 1.1rem;background:var(--quote-bg);
  border-left:4px solid var(--accent);border-radius:.4rem;color:var(--text);
}
.chapter blockquote p{margin:.3rem 0}

/* tables */
.chapter table{width:100%;border-collapse:collapse;margin:1.2rem 0;font-size:.92rem;display:block;overflow-x:auto}
.chapter th,.chapter td{border:1px solid var(--line);padding:.55rem .75rem;text-align:left;vertical-align:top}
.chapter thead th{background:var(--accent-soft)}
.chapter tbody tr:nth-child(even){background:var(--quote-bg)}

/* code */
.chapter :not(pre)>code{background:var(--code-bg);padding:.1rem .35rem;border-radius:.3rem;font-size:.86em}
.chapter pre{background:var(--code-bg);padding:1rem;border-radius:.6rem;overflow-x:auto;border:1px solid var(--line);font-size:.85rem;line-height:1.6}
.chapter pre code{background:none;padding:0}

/* search highlight */
mark{background:var(--accent);color:#1a1208;border-radius:.2rem;padding:0 .1rem}

/* chapter nav buttons */
.chapnav{width:100%;max-width:var(--max);display:flex;justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.chapnav button{flex:1;padding:.75rem;border:1px solid var(--line);border-radius:.6rem;background:var(--surface);color:var(--text);cursor:pointer;font:inherit}
.chapnav button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.chapnav button:disabled{opacity:.4;cursor:default}

/* mobile */
.scrim{display:none;position:fixed;inset:3.4rem 0 0;background:rgba(0,0,0,.5);z-index:30}
@media(max-width:860px){
  #menuBtn{display:block}
  .topbar .brand{font-size:.92rem}
  .topbar .brand-sub{display:none}
  .sidebar{position:fixed;left:0;top:3.4rem;z-index:35;transform:translateX(-100%);transition:transform .2s;box-shadow:2px 0 12px rgba(0,0,0,.3)}
  .sidebar.open{transform:translateX(0)}
  .scrim.show{display:block}
  body{font-size:17px}
  .hc-steps{grid-template-columns:1fr}
  .hc-h{font-size:1.4rem}
}
