/* site.css -- one page, many windows (steps 6 and 14).
   The chrome stays quiet so the content can be loud. */

:root {
  --ink: #26221b;
  --paper: #fbf8f1;
  --line: #d8d0bf;
  --accent: #8a3324;
  --quiet: #6f675a;
}

* { box-sizing: border-box; }

html { font-size: 17px; }

body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.6;
}

main {
  max-width: 42rem;
  margin: 0 auto;
  padding: 1rem 1.25rem 4rem;
}

header.chrome, footer.chrome {
  max-width: 42rem;
  margin: 0 auto;
  padding: 1rem 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 1.25rem;
  align-items: baseline;
}
header.chrome { border-bottom: 1px solid var(--line); }
footer.chrome { border-top: 1px solid var(--line); color: var(--quiet); }

.masthead {
  font-weight: bold;
  font-size: 1.25rem;
  text-decoration: none;
  color: var(--ink);
}
nav a { margin-right: .9rem; color: var(--accent); text-decoration: none; }
nav a.writer { color: var(--quiet); font-style: italic; }
nav a:hover, a:hover { text-decoration: underline; }
a { color: var(--accent); }

h1 { font-size: 1.7rem; line-height: 1.25; margin: 1.2rem 0 .4rem; }
.byline, .crumbs, time, .desc { color: var(--quiet); font-size: .9rem; }
.crumbs a { color: var(--quiet); }

article img { max-width: 100%; height: auto; }
blockquote { margin: 1rem 0; padding-left: 1rem;
             border-left: 3px solid var(--line); color: var(--quiet); }
pre, code { font-family: ui-monospace, Menlo, Consolas, monospace;
            font-size: .9em; }
pre { overflow-x: auto; padding: .8rem; background: #f1ecdf;
      border: 1px solid var(--line); }

.page-list { list-style: none; padding: 0; }
.page-list li { margin: 0 0 1.1rem; }
.page-list a { font-size: 1.1rem; }
.page-list time { margin-left: .5rem; }
.page-list .desc { display: block; }
.empty { color: var(--quiet); font-style: italic; }

/* ---- the writing surface ---- */
.meta-grid { display: grid; grid-template-columns: 1fr 1fr;
             gap: .6rem 1.2rem; margin-bottom: 1rem; }
.meta-grid label { display: flex; flex-direction: column;
                   font-size: .85rem; color: var(--quiet); }
.meta-grid label.check { flex-direction: row; align-items: center;
                         gap: .4rem; color: var(--ink); }
input, select, textarea, button {
  font: inherit; color: var(--ink);
  border: 1px solid var(--line); border-radius: 3px;
  padding: .35rem .5rem; background: #fff;
}
.toolbar { display: flex; flex-wrap: wrap; gap: .25rem;
           padding: .4rem; border: 1px solid var(--line);
           border-bottom: none; background: #f1ecdf;
           border-radius: 3px 3px 0 0; }
.toolbar button { padding: .15rem .55rem; cursor: pointer; }
.toolbar button:hover { background: var(--paper); }
.canvas { min-height: 18rem; border: 1px solid var(--line);
          border-radius: 0 0 3px 3px; padding: 1rem; background: #fff; }
.canvas:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
#raw-body { width: 100%; font-family: ui-monospace, Menlo, monospace;
            font-size: .85rem; line-height: 1.45; }
button.save { background: var(--accent); color: #fff; border: none;
              padding: .5rem 1.4rem; cursor: pointer; }
.error { color: var(--accent); font-weight: bold; }
.writer-tools { border-top: 1px dashed var(--line);
                margin-top: 2rem; padding-top: .6rem; font-style: italic; }

table.admin { border-collapse: collapse; width: 100%; font-size: .9rem; }
table.admin th, table.admin td { text-align: left; padding: .35rem .6rem;
                                 border-bottom: 1px solid var(--line); }
form.inline { display: inline; }
form.inline button { border: none; background: none; color: var(--accent);
                     cursor: pointer; padding: 0; text-decoration: underline; }

:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

@media (max-width: 640px) {
  html { font-size: 16px; }
  .meta-grid { grid-template-columns: 1fr; }
}

@media print {
  header.chrome nav, footer.chrome, .writer-tools { display: none; }
}
