/* streett.link — site CSS (server-rendered pages) */

:root{
  --paper:#f9f9f7; --paper-2:#f4f4f2; --paper-3:#eeeeec; --paper-4:#e8e8e6;
  --ink:#181919; --ink-soft:#444748; --ink-faint:#747878;
  --hair:rgba(0,0,0,0.08); --hair-strong:rgba(0,0,0,0.14);
  --sage:#516257; --sage-soft:#d1e4d6; --sage-deep:#3a4b40;
  --rust:#b5642a; --rust-soft:#f4e6d2; --rust-deep:#72351c;
  --slate:#5b7083; --slate-soft:#e2e7ec;
  --danger:#ba1a1a; --danger-soft:#ffdad6;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-size:16px; line-height:1.6;
  color:var(--ink); background:var(--paper);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:var(--sage); text-decoration:none}
a:hover{text-decoration:underline}

/* ─── App layout (sidebar + main) ────────────────────────────────── */
.layout-app{display:grid; grid-template-columns:260px 1fr; min-height:100vh}
.sidebar{
  position:sticky; top:0;
  height:100vh;
  background:var(--paper-2);
  border-right:1px solid var(--hair);
  display:flex; flex-direction:column;
  padding:24px 18px;
}
.sidebar-head{margin-bottom:32px; padding:0 8px}
.brand{
  font-family:'Playfair Display',serif; font-weight:700;
  font-size:1.4rem; color:var(--ink); text-decoration:none;
  letter-spacing:-0.01em; display:block;
}
.brand-tag{
  margin:4px 0 0; font-size:0.7rem; text-transform:uppercase;
  letter-spacing:0.2em; color:var(--ink-faint); font-weight:500;
}
.sidebar-nav{display:flex; flex-direction:column; gap:2px; flex:1}
.sidebar-link{
  padding:9px 12px;
  font-size:0.92rem; font-weight:500;
  color:var(--ink-soft);
  border-radius:6px;
  text-decoration:none;
}
.sidebar-link:hover{background:var(--paper-3); color:var(--ink); text-decoration:none}
.sidebar-foot{
  padding-top:18px;
  border-top:1px solid var(--hair);
  display:flex; flex-direction:column; gap:10px;
}
.btn-primary{
  display:inline-block; text-align:center;
  background:var(--ink); color:#fff;
  padding:10px 14px;
  border-radius:6px;
  font-size:0.9rem; font-weight:500;
  border:none; cursor:pointer;
  text-decoration:none;
}
.btn-primary:hover{background:#000; color:#fff; text-decoration:none}
.btn-danger{
  display:inline-block; text-align:center;
  background:transparent; color:var(--danger);
  padding:10px 14px;
  border-radius:6px;
  font-size:0.9rem; font-weight:500;
  border:1px solid var(--danger-soft); cursor:pointer;
}
.btn-danger:hover{background:var(--danger-soft); color:var(--danger)}
.link-button{
  background:none; border:none; cursor:pointer;
  color:var(--sage); font-size:0.88rem; padding:4px 6px;
  font-family:inherit;
}
.link-button:hover{text-decoration:underline}
.logout-form{margin:0}

.app-main{display:flex; flex-direction:column; min-height:100vh}
.topbar{
  position:sticky; top:0;
  padding:14px 32px;
  background:rgba(249,249,247,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--hair);
  z-index:10;
}
.search-form{
  max-width:560px; margin:0 auto;
  display:flex; align-items:center;
  background:#fff;
  border:1px solid var(--hair);
  border-radius:999px;
  padding:6px 14px;
  transition:border-color .12s;
}
.search-form:focus-within{border-color:var(--sage)}
.search-form input{
  flex:1; border:none; outline:none; background:transparent;
  font-size:0.92rem; padding:6px 4px; color:var(--ink);
}
.search-form button{
  background:none; border:none; cursor:pointer;
  color:var(--ink-faint); font-size:1.1rem;
}
.app-content{padding:48px 32px 96px; max-width:980px; width:100%; margin:0 auto}
.app-foot{
  margin-top:auto;
  padding:24px 32px;
  border-top:1px solid var(--hair);
  font-size:0.82rem; color:var(--ink-faint);
  text-align:center;
}

/* ─── Headings + page headers ───────────────────────────────────── */
.hero h1, .page-head h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,4vw,2.8rem); line-height:1.15;
  font-weight:700; letter-spacing:-0.02em;
  margin:0 0 12px; color:var(--ink);
}
.hero, .page-head{margin-bottom:48px}
.hero .lead, .page-head .lead{
  font-size:1.1rem; color:var(--ink-soft);
  max-width:640px; margin:0;
}
.eyebrow{
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.2em;
  color:var(--sage); font-weight:600; margin:0 0 14px;
}
.eyebrow a{color:var(--sage)}
.section-head{margin-bottom:20px}
.section-head h2{
  font-family:'Playfair Display',serif;
  font-size:1.5rem; font-weight:600;
  margin:0; color:var(--ink); letter-spacing:-0.01em;
}
.section-head .section-sub{
  font-size:0.85rem; color:var(--ink-faint); margin:4px 0 0;
}
.recent, .categories{margin-bottom:56px}

/* ─── Cards (recent updates) ────────────────────────────────────── */
.card-grid{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:16px;
}
.card{
  background:#fff;
  border:1px solid var(--hair);
  border-radius:10px;
  overflow:hidden;
  transition:border-color .12s, transform .12s;
}
.card:hover{border-color:var(--hair-strong)}
.card a{
  display:block; padding:18px 20px;
  color:var(--ink); text-decoration:none;
}
.card-eyebrow{
  font-size:0.68rem; text-transform:uppercase; letter-spacing:0.16em;
  color:var(--sage); font-weight:600; margin:0 0 10px;
}
.card-title{
  font-family:'Playfair Display',serif;
  font-size:1.15rem; font-weight:600;
  margin:0 0 8px; line-height:1.3;
}
.card-dek{
  font-size:0.92rem; color:var(--ink-soft);
  margin:0 0 12px; line-height:1.55;
}
.card-meta{
  font-size:0.74rem; color:var(--ink-faint);
  text-transform:uppercase; letter-spacing:0.1em;
  margin:0;
}

/* ─── Category grid on home ─────────────────────────────────────── */
.category-grid{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:14px;
}
.category-card{
  background:var(--paper-2);
  border:1px solid var(--hair);
  border-radius:10px;
}
.category-card a{
  display:block; padding:18px 20px; color:var(--ink); text-decoration:none;
}
.category-card h3{
  font-family:'Playfair Display',serif;
  font-size:1.1rem; font-weight:600; margin:0 0 6px;
}
.category-card .count{
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em;
  color:var(--ink-faint); margin:0 0 10px;
}
.category-recent{
  list-style:none; padding:0; margin:0;
  font-size:0.85rem; color:var(--ink-soft);
}
.category-recent li{margin:4px 0; line-height:1.4}
.category-recent li::before{content:'· '; color:var(--ink-faint)}

/* ─── Note list (category index / search) ───────────────────────── */
.note-list{list-style:none; padding:0; margin:0}
.note-row{
  display:flex; align-items:flex-start; gap:24px;
  padding:22px 0;
  border-bottom:1px solid var(--hair);
}
.note-row:last-child{border-bottom:none}
.note-row-main{flex:1; min-width:0}
.note-row-actions{flex:0 0 auto}
.row-eyebrow{
  font-size:0.68rem; text-transform:uppercase; letter-spacing:0.16em;
  color:var(--sage); font-weight:600; margin:0 0 6px;
}
.note-row h3{
  font-family:'Playfair Display',serif;
  font-size:1.25rem; font-weight:600;
  margin:0 0 6px; line-height:1.3;
}
.note-row h3 a{color:var(--ink)}
.note-row .dek{color:var(--ink-soft); margin:0 0 10px; font-size:0.95rem}
.note-row .snippet{
  color:var(--ink-soft); margin:0 0 10px; font-size:0.9rem;
  background:var(--paper-2);
  padding:8px 12px; border-radius:6px;
  border-left:3px solid var(--sage);
}
.row-meta{
  display:flex; flex-wrap:wrap; align-items:center; gap:6px 14px;
  font-size:0.78rem; margin:0;
}
.row-date{
  color:var(--ink-faint); text-transform:uppercase; letter-spacing:0.1em; font-size:0.72rem;
}
.tag{
  display:inline-block; padding:2px 9px;
  background:var(--slate-soft); color:var(--slate);
  border-radius:999px; font-weight:500; font-size:0.72rem;
}
.empty{padding:24px 0; color:var(--ink-faint)}

/* ─── Forms ─────────────────────────────────────────────────────── */
.form-stack{display:flex; flex-direction:column; gap:18px; max-width:680px}
.field{display:flex; flex-direction:column; gap:6px}
.field-label{
  font-size:0.72rem; text-transform:uppercase; letter-spacing:0.14em;
  font-weight:600; color:var(--ink-soft);
}
.field-hint{
  text-transform:none; letter-spacing:0; color:var(--ink-faint);
  font-weight:400; font-size:0.75rem;
}
.field input, .field select, .field textarea{
  font-family:inherit;
  font-size:0.98rem;
  padding:10px 12px;
  border:1px solid var(--hair-strong);
  border-radius:6px;
  background:#fff;
  color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--sage);
}
.form-actions{
  display:flex; align-items:center; gap:12px;
  margin-top:12px; padding-top:16px;
  border-top:1px solid var(--hair);
}
.form-spacer{flex:1}

.meta-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:14px;
}
.field-tags{grid-column:1 / -1}

/* ─── Login screen ───────────────────────────────────────────────── */
.layout-login{
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  background:var(--paper-2);
}
.login-card{
  background:#fff;
  border:1px solid var(--hair);
  border-radius:12px;
  padding:48px 48px 40px;
  width:100%; max-width:380px;
}
.brand-large{
  font-family:'Playfair Display',serif; font-size:2rem;
  font-weight:700; margin:0; letter-spacing:-0.02em; color:var(--ink);
}
.login-tag{
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.2em;
  color:var(--ink-faint); margin:4px 0 28px;
}
.login-error{
  background:var(--danger-soft); color:var(--danger);
  padding:8px 12px; border-radius:6px;
  font-size:0.88rem; margin:0 0 18px;
}

/* ─── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 800px){
  .layout-app{grid-template-columns:1fr}
  .sidebar{position:relative; height:auto; flex-direction:row; padding:14px 18px; overflow-x:auto}
  .sidebar-head{margin:0 18px 0 0}
  .sidebar-nav{flex-direction:row; flex:1; align-items:center; gap:0}
  .sidebar-foot{padding-top:0; border:none; flex-direction:row; gap:8px}
  .app-content{padding:24px 18px 64px}
  .topbar{padding:10px 18px}
}
