/* Music Education Editors' Circle — shared house style
   Derived from the v0.1 prototype. Edit colors in :root to retheme the whole site. */
:root{
  --ink:#1d2433; --muted:#5b6675; --line:#e3e7ee; --bg:#ffffff;
  --soft:#f6f8fb; --brand:#2a5b7e; --brand-dk:#1c3f59; --accent:#b5762f; --good:#2e7d56;
  --maxw:1100px; --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Georgia,'Times New Roman',serif;color:var(--ink);background:var(--bg);line-height:1.6}
h1,h2,h3,nav,.tag,button,th,.k,.brand,.pill,input,select,.btn{font-family:-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}
a{color:var(--brand)}

/* Header / nav */
header.top{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.93);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.bar{max-width:var(--maxw);margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.brand{font-weight:700;font-size:18px;color:var(--brand-dk);letter-spacing:.2px;text-decoration:none}
.brand small{display:block;font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.4px;text-transform:uppercase}
nav{margin-left:auto;display:flex;gap:16px;flex-wrap:wrap;font-size:14px}
nav a{color:var(--muted);text-decoration:none}
nav a:hover,nav a.active{color:var(--brand)}
nav a.active{font-weight:700}

/* Hero */
.hero{background:linear-gradient(160deg,var(--brand-dk),var(--brand));color:#fff;padding:64px 22px}
.hero .wrap{max-width:var(--maxw);margin:0 auto}
.hero h1{font-size:38px;margin:.1em 0 .3em;line-height:1.15}
.hero p{font-size:18px;max-width:760px;color:#e7eef4}
.tag{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;
     padding:5px 12px;border-radius:999px;font-size:12px;letter-spacing:.5px;text-transform:uppercase}

/* Sections */
section{max-width:var(--maxw);margin:0 auto;padding:48px 22px;border-bottom:1px solid var(--line)}
section h2{font-size:26px;color:var(--brand-dk);margin:0 0 6px}
.lead{color:var(--muted);font-size:17px;margin-top:0}
.pill{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
      color:var(--accent);background:#fbf3e8;border:1px solid #f0dcbf;padding:3px 9px;border-radius:999px;margin-bottom:10px}
.k{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}

/* Grids & cards */
.grid{display:grid;gap:20px;margin-top:24px}
.g2{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:repeat(3,1fr)} .g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.card h3{margin:0 0 6px;font-size:16px;color:var(--brand-dk)}
.card p{margin:0;color:var(--muted);font-size:14.5px}
.twocol{display:grid;grid-template-columns:1.4fr 1fr;gap:34px}
@media(max-width:820px){.twocol{grid-template-columns:1fr}}
blockquote{border-left:3px solid var(--accent);margin:0;padding:6px 0 6px 18px;color:var(--ink);font-size:18px}
ul.clean{list-style:none;padding:0;margin:14px 0}
ul.clean li{padding:9px 0 9px 26px;position:relative;border-bottom:1px solid var(--line);font-size:15px}
ul.clean li:before{content:"\203A";position:absolute;left:6px;color:var(--accent);font-weight:700}
.note{font-size:13px;color:var(--muted);background:#fbf3e8;border:1px solid #f0dcbf;padding:10px 14px;border-radius:8px;margin-top:14px}

/* Controls */
.controls{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;align-items:center}
input[type=text],input[type=search],select{font-family:-apple-system,'Segoe UI',sans-serif;font-size:15px;
   padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}
input[type=search]{min-width:280px;flex:1}
.btn,button{cursor:pointer;background:var(--brand);color:#fff;border:0;padding:10px 18px;border-radius:8px;
   font-size:14px;font-weight:600}
.btn:hover,button:hover{background:var(--brand-dk)}
.count{color:var(--muted);font-size:13px;font-family:-apple-system,sans-serif}

/* Journal directory entries */
.jrow{border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-top:14px;background:#fff}
.jrow h3{margin:0 0 2px;font-size:17px;color:var(--brand-dk);font-family:Georgia,serif}
.jrow .trans{color:var(--muted);font-size:14px;font-style:italic}
.jmeta{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.chip{font-family:-apple-system,sans-serif;font-size:11px;font-weight:600;letter-spacing:.3px;
   color:var(--brand-dk);background:var(--soft);border:1px solid var(--line);padding:3px 9px;border-radius:999px}
.chip.idx{color:var(--good);background:#eef7f1;border-color:#cfe9da}
.chip.flag{color:#a23b2e;background:#fbecea;border-color:#f0ccc6}
.jscope{font-size:14.5px;color:var(--ink);margin:6px 0 12px}
.jlinks{display:flex;gap:8px;flex-wrap:wrap}
.jlinks a{font-family:-apple-system,sans-serif;font-size:13px;font-weight:600;text-decoration:none;
   border:1px solid var(--line);border-radius:8px;padding:6px 11px;background:#fff;color:var(--brand)}
.jlinks a:hover{background:var(--soft)}
.jlinks a.disabled{color:#9aa6b2;border-style:dashed;pointer-events:none}
.jed{font-family:-apple-system,sans-serif;font-size:13px;color:var(--muted);margin-top:10px}
.conf{font-size:11px;font-family:-apple-system,sans-serif;color:#9aa6b2}

/* Table (resources / editors) */
table{width:100%;border-collapse:collapse;margin-top:16px;font-size:14px;font-family:-apple-system,sans-serif}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.4px}

/* Sticky toolbar (search + filters stay visible while browsing) */
.toolbar{position:sticky;top:58px;z-index:10;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-top:18px;
  display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* Tabs */
.tabs{display:flex;gap:6px;margin-top:22px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab{font-family:-apple-system,'Segoe UI',sans-serif;font-size:14px;font-weight:600;cursor:pointer;
  padding:10px 16px;border:1px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;color:var(--muted);background:none}
.tab:hover{color:var(--brand)}
.tab.active{color:var(--brand-dk);background:var(--soft);border-color:var(--line)}
.tabpane{display:none}
.tabpane.active{display:block}

/* Buttons (ghost variant for downloads) */
.btn.ghost{background:#fff;color:var(--brand);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--soft);color:var(--brand-dk)}
.dlbar{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 4px}
a.btn{text-decoration:none;display:inline-block}
.licen{background:#eef4f8;border-color:#d3e2ec}

/* Compact directory rows (browsable) */
details.jrow2{border:1px solid var(--line);border-radius:10px;margin-top:8px;background:#fff;overflow:hidden}
details.jrow2>summary{list-style:none;cursor:pointer;padding:12px 16px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
details.jrow2>summary::-webkit-details-marker{display:none}
details.jrow2>summary:hover{background:var(--soft)}
details.jrow2[open]>summary{border-bottom:1px solid var(--line);background:var(--soft)}
.jrow2 .jt{font-family:Georgia,serif;font-weight:600;color:var(--brand-dk);font-size:15.5px;flex:1;min-width:220px}
.jrow2 .caret{color:var(--accent);font-weight:700;transition:transform .15s}
details.jrow2[open] .caret{transform:rotate(90deg)}
.jrow2 .body{padding:14px 16px}

/* Accordion for editor history / integrity */
details.acc{border:1px solid var(--line);border-radius:10px;margin-top:10px;background:#fff;overflow:hidden}
details.acc>summary{list-style:none;cursor:pointer;padding:14px 16px;font-family:-apple-system,'Segoe UI',sans-serif;
  font-weight:700;color:var(--brand-dk);display:flex;align-items:center;gap:10px}
details.acc>summary::-webkit-details-marker{display:none}
details.acc>summary:hover{background:var(--soft)}
details.acc[open]>summary{border-bottom:1px solid var(--line);background:var(--soft)}
details.acc .caret{color:var(--accent);font-weight:700;transition:transform .15s;margin-left:auto}
details.acc[open] .caret{transform:rotate(90deg)}
details.acc .accbody{padding:6px 16px 16px}
.badge{font-family:-apple-system,sans-serif;font-size:11px;font-weight:700;color:#fff;background:var(--brand);
  border-radius:999px;padding:2px 9px}
.badge.soft{color:var(--brand-dk);background:var(--soft);border:1px solid var(--line)}
.mem{color:var(--accent);font-weight:700;font-size:12px;font-family:-apple-system,sans-serif}

/* Modal (license gate) */
.modal-ov{position:fixed;inset:0;background:rgba(20,40,60,.45);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal{background:#fff;border-radius:12px;max-width:470px;padding:24px 26px;box-shadow:0 20px 60px rgba(20,40,60,.3)}
.modal h3{margin:0 0 10px;color:var(--brand-dk)}
.modal p{color:var(--ink);font-size:15px;margin:0}
.modal-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
/* clickable filter chips */
.chip[data-tag]{cursor:pointer}
.chip[data-tag]:hover{border-color:var(--brand);color:var(--brand)}
#activeFilter{margin:10px 0 0;font-family:-apple-system,'Segoe UI',sans-serif;font-size:13px;color:var(--muted)}
#activeFilter a{margin-left:6px}

/* Footer */
footer{max-width:var(--maxw);margin:0 auto;padding:30px 22px;color:var(--muted);font-size:13px}
footer a{color:var(--muted)}
.hosted{display:flex;align-items:center;gap:8px;margin-top:8px;font-family:-apple-system,sans-serif}
