:root{
  --paper:#F4F3EE; --card:#FFFFFF; --ink:#1B2620; --muted:#5E6B63;
  --line:#E3E0D7; --grass:#2F7A52; --grass-soft:#E7F1EB; --amber:#C0762B;
  --amber-soft:#F6ECDD; --slate:#243029;
  --shadow:0 1px 2px rgba(27,38,32,.06),0 6px 20px rgba(27,38,32,.05);
}
*{box-sizing:border-box}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:1.5}
.wrap{max-width:1060px;margin:0 auto;padding:0 20px}
.eyebrow{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);margin:0 0 4px}
h2{font-size:20px;margin:0 0 16px}
.ec-muted{font-size:13px;color:var(--muted)}
section{padding:26px 0}

header{background:var(--slate);color:#EFF2EE;border-bottom:3px solid var(--grass)}
.head{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;padding:18px 20px;max-width:1060px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:40px;height:40px;border-radius:9px;background:var(--grass);display:grid;place-items:center;font-size:20px}
.brand h1{font-size:17px;margin:0}.brand p{margin:0;font-size:12px;color:#9FB0A6}
.brain{display:flex;align-items:center;gap:10px}
.brain label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:#9FB0A6}
.brain select{background:#2C3A32;color:#EFF2EE;border:1px solid #3E4E45;border-radius:8px;padding:7px 11px;font-size:14px;font-weight:600;cursor:pointer}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:999px}
.pill.live{background:var(--grass-soft);color:#1E5E3D}.pill.rig{background:var(--amber-soft);color:#8A5012}
.logoutBtn{padding:7px 14px;border:1px solid #3E4E45;border-radius:8px;background:#2C3A32;color:#EFF2EE;font-size:13px;font-weight:600;cursor:pointer}

nav{background:#1B241F;border-bottom:1px solid #34423A}
.navin{display:flex;gap:4px;max-width:1060px;margin:0 auto;padding:0 20px}
.navbtn{background:none;border:none;color:#9FB0A6;padding:13px 16px;font-size:14px;font-weight:600;cursor:pointer;border-bottom:3px solid transparent}
.navbtn.on{color:#fff;border-bottom-color:var(--grass)}

.feedhead{display:flex;align-items:center;justify-content:space-between}
.adminbtn{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border:none;border-radius:999px;background:var(--slate);color:#fff;font-size:11.5px;font-weight:700;cursor:pointer}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:14px 16px;margin-bottom:14px}
.cardhead{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.cardhead h3{margin:0;font-size:16px}
.cardact{margin-left:auto;display:flex;align-items:center;gap:8px}
.cardicon{font-size:18px}
.entersite{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border:none;border-radius:999px;background:var(--amber);color:#fff;font-size:11.5px;font-weight:700;cursor:pointer}
.entersite:hover{background:#A5641F}

.feedrow{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line)}
.feedtext{flex:1}
.tag{font-size:10px;font-weight:700;padding:3px 6px;border-radius:6px;text-transform:uppercase}
.tag-ai{background:#E6EEF6;color:#2A567E}.tag-news{background:var(--grass-soft);color:#1E5E3D}.tag-event{background:var(--amber-soft);color:#8A5012}

.libcat{display:flex;align-items:center;gap:10px;margin:24px 0 12px;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);font-weight:700}
.libcat:after{content:"";flex:1;height:1px;background:var(--line)}
.lib{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px}
.sector{position:relative;display:flex;flex-direction:column;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:var(--shadow);min-height:132px}
.sector .ic{font-size:26px;height:34px;line-height:34px;display:flex;align-items:center}
.sector h3{margin:6px 0 2px;font-size:14px;min-height:34px;display:flex;align-items:flex-start}
.sector .state{font-size:11px;font-weight:700;color:var(--grass);margin-bottom:8px;text-transform:capitalize}
.sector .entersite{margin-top:auto}
.sector .price{position:absolute;top:10px;right:10px;font-size:13px;font-weight:800;color:var(--ink)}
.sector .price .permo{font-size:9px;font-weight:600;color:var(--muted)}
.sector.mock .price{color:var(--muted)}

.backbtn{padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:var(--card);color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;margin-bottom:16px}

.ec-app{text-align:center;max-width:520px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:var(--shadow)}
.ec-app-icon{font-size:34px}
.ec-stat{font-size:14px;color:var(--muted);margin:8px 0}.ec-stat b{font-size:24px;color:var(--ink)}
.ec-ask{display:flex;gap:8px;margin-top:16px}
.ec-ask input{flex:1;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#FCFBF7}
.ec-ask button{background:var(--grass);color:#fff;border:none;border-radius:10px;padding:11px 18px;font-weight:600;cursor:pointer}
.ec-answer{margin-top:14px;text-align:left;font-size:14px}
.ec-by{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:6px}

#login{position:fixed;inset:0;z-index:100;background:radial-gradient(1200px 600px at 50% -10%, #EAF1EC 0%, var(--paper) 55%);display:flex;align-items:flex-start;justify-content:center;padding:10vh 24px 24px}
.loginCard{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:30px 26px;text-align:center}
.loginCard .logo{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:28px;margin:0 auto 14px;background:var(--grass-soft);border:1px solid #BFD8C9}
.loginCard h1{margin:0 0 4px;font-size:22px}
.loginCard .sub{margin:0 0 22px;font-size:13px;color:var(--muted)}
.loginField{text-align:left;margin-bottom:14px}
.loginField label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px}
.loginField input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#FCFBF7}
.loginBtn{width:100%;padding:13px;border:none;border-radius:10px;background:var(--grass);color:#fff;font-size:15px;font-weight:700;cursor:pointer}
.loginNote{margin-top:18px;font-size:12px;color:#9FB0A6}
.loginMsg{margin-top:10px;font-size:13px;color:#A8442F;min-height:18px}

/* ---- Admin view ---- */
.lock{display:inline-flex;gap:8px;align-items:center;background:var(--grass-soft);color:#1E5E3D;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;margin-bottom:6px}
.banner{border-radius:12px;padding:12px 14px;display:flex;gap:10px;align-items:flex-start;margin:8px 0 0;font-size:13.5px}
.banner.slate{background:#EAEEEA;border:1px solid #D5DDD6}
.card.bench .you{font-weight:700}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
th{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
td.num,th.num{text-align:right}
.pos{font-weight:700;font-size:13px;padding:2px 8px;border-radius:6px}
.pos.over{background:#F6E4E0;color:#A8442F}.pos.under{background:var(--grass-soft);color:#1E5E3D}
.hidden-row td{color:var(--muted);font-style:italic}
.gap{color:var(--amber);font-weight:600}
.tag{font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px}
.tag.real{background:var(--grass-soft);color:#1E5E3D}.tag.test{background:#EEF0F3;color:#5A6470}
.card h3{margin:0 0 4px;font-size:17px}

/* ---- Live view ---- */
.accbtn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:none;border:none;padding:12px 0;font-size:15px;cursor:pointer;text-align:left;color:var(--ink)}
.accbtn:hover{color:var(--grass)}
.shelfhead{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}
.docrow{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line)}
.docrow .dt{font-weight:600;font-size:14px;flex:1}
.doctype{flex:none;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:3px 6px;border-radius:6px;margin-top:2px}
.t-know{background:#E6EEF6;color:#2A567E}
.trust{font-size:10px;font-weight:700;padding:2px 6px;border-radius:5px;margin-left:6px;vertical-align:middle}
.trust.verified{background:var(--grass-soft);color:#1E5E3D}

/* ---- Shelf / five-part system ---- */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.fbtn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;font-size:12.5px;cursor:pointer}
.fbtn.on{background:var(--grass);color:#fff;border-color:var(--grass)}
.partlbl{font-size:12px;font-weight:700;letter-spacing:.3px;color:var(--muted);margin:4px 0 8px}
.databox{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-top:14px;background:#FCFBF7}
.databox .dbhead{font-size:14px;margin-bottom:6px}
.dchip{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;margin-left:6px;vertical-align:middle}
.dchip.ext{background:#E7EEF6;color:#1B4965}.dchip.mesh{background:var(--grass-soft);color:#1E5E3D}
.anlist{margin:6px 0 4px;padding-left:18px}.anlist li{font-size:13px;margin:5px 0;color:var(--ink)}
.trust.draft{background:#F3E6D8;color:#8A5012}
.noteArea{width:100%;min-height:120px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;background:#FCFBF7;color:var(--ink);resize:vertical}
.sqlbtn{padding:8px 14px;border:1px solid var(--grass-soft);border-radius:8px;background:var(--grass-soft);color:#1E5E3D;font-size:13px;font-weight:700;cursor:pointer}
.pebble{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink)}
.pebble.sql{background:var(--grass-soft);border-color:var(--grass-soft);color:#1E5E3D}
.t-rule{background:#F6E4E0;color:#A8442F}.t-ref{background:var(--grass-soft);color:#1E5E3D}
.t-mine{background:var(--amber-soft);color:#8A5012}.t-gloss{background:#EFE9F4;color:#6B4A86}
.t-eg{background:#EAEFE9;color:#3E5A3A}.t-diet{background:#FBF1DA;color:#8A6B12}
.xbtn{flex:none;width:22px;height:22px;border-radius:6px;border:1px solid var(--line);background:#fff;color:#A8442F;font-size:12px;font-weight:700;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0;margin-top:1px}
.docrow.removed{opacity:.5}.docrow.removed .dt{text-decoration:line-through}
.sqlbox{margin-top:10px;background:#0F1A14;color:#CFE6D8;border-radius:10px;padding:12px 14px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;line-height:1.5;overflow:auto;max-height:220px;white-space:pre}

/* ---- app card sub-category + ready state ---- */
.sector .subcat{font-size:10px;color:var(--muted);margin:0 0 4px;text-transform:uppercase;letter-spacing:.4px}

/* ---- done (built/bought) apps greyed in place ---- */
.sector.done{opacity:.55;background:#F4F4F1}
.sector.done .ic{filter:grayscale(0.3)}
.sector.done .price{color:var(--muted)}

/* ---- + Add button on preview ---- */
.addbtn{background:var(--grass);color:#fff;border:none;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer}
.addbtn:hover{background:#256544}

/* ---- Mesh: collapsed rows + pop-up results page ---- */
.mesh-row{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:var(--card);overflow:hidden}
.mesh-head{width:100%;display:flex;align-items:center;gap:12px;padding:14px;background:#F8F7F2;border:none;cursor:pointer}
.mesh-head:hover{background:#F2F1EA}
.mesh-rowbody{padding:0 14px 14px}
.mesh-pop{position:fixed;inset:0;background:var(--bg,#FAF9F5);z-index:1000;overflow-y:auto}
.mesh-pop-bar{position:sticky;top:0;display:flex;align-items:center;gap:14px;padding:14px 18px;background:#fff;border-bottom:1px solid var(--line);z-index:1}
.mesh-back{background:var(--grass);color:#fff;border:none;border-radius:999px;padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer}
.mesh-pop-title{font-weight:700;font-size:15px}
.mesh-pop-body{padding:18px;max-width:760px;margin:0 auto}

/* ---- tighten first section + light-green mesh ask box ---- */
.wrap > section:first-child,
#view-mesh section:first-child,
#view-admin section:first-child,
#view-live section:first-child,
#view-apps section:first-child{padding-top:8px}
.mesh-ask input{background:#EFF6EF;border:1px solid #CFE3CF}
.mesh-ask input:focus{background:#fff;border-color:var(--grass);outline:none}

/* ---- Open real app button ---- */
.ec-open-btn{display:block;width:100%;margin:14px 0;background:var(--grass);color:#fff;border:none;border-radius:12px;padding:14px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.ec-open-btn:hover{background:#256544}
