@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── DARK (Eye‑friendly Warm) ── */
:root{
  --bg:#1e1e20;
  --sur:#252528;
  --sur2:#2c2c30;
  --b1:#3a3a3f;
  --b2:#4a4a50;
  --b3:#5a5a62;

  --ac:#e5b567;
  --ac-dim:rgba(229,181,103,0.08);
  --ac-glow:rgba(229,181,103,0.25);
  --ac2:#7fa998;
  --ac2-dim:rgba(127,169,152,0.1);
  --gr:#8c9a6e;
  --gr-dim:rgba(140,154,110,0.1);
  --ye:#dfb85c;
  --re:#d9706a;
  --re-dim:rgba(217,112,106,0.1);

  --tx:#e8e6e3;
  --tx2:#b0ada8;
  --mu:#8a8780;

  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --safe-b:env(safe-area-inset-bottom,0px);

  --r-sm:8px;
  --r-md:14px;
  --r-lg:18px;
  --r-xl:22px;

  --hdr-bg:rgba(30,30,32,0.85);
  --nav-bg:rgba(30,30,32,0.92);
  --overlay-bg:rgba(0,0,0,0.7);
  --d-overlay-bg:rgba(0,0,0,0.6);
}

/* ── LIGHT ── */
html.light{
  --bg:#f4f1e9;
  --sur:#ffffff;
  --sur2:#f9f7f1;
  --b1:#dcd8cf;
  --b2:#c4bfb5;
  --b3:#afa99e;

  --ac:#b5864c;
  --ac-dim:rgba(181,134,76,0.08);
  --ac-glow:rgba(181,134,76,0.2);
  --ac2:#5a8f7b;
  --ac2-dim:rgba(90,143,123,0.08);
  --gr:#6b8e4e;
  --gr-dim:rgba(107,142,78,0.08);
  --ye:#b98a3c;
  --re:#b55a4c;
  --re-dim:rgba(181,90,76,0.08);

  --tx:#2c2416;
  --tx2:#5c5346;
  --mu:#8c8272;

  --hdr-bg:rgba(244,241,233,0.88);
  --nav-bg:rgba(244,241,233,0.94);
  --overlay-bg:rgba(0,0,0,.4);
  --d-overlay-bg:rgba(0,0,0,.35);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%}
html,body,header,.bottom-nav,.modal,.d-sheet,.card,.pcard,.finput,.fselect,.ftextarea,.chip,.icon-btn,.gh-pill{
  transition:background .25s,border-color .25s,color .2s,box-shadow .25s;
}
body{
  background:var(--bg);color:var(--tx);
  font-family:var(--sans);font-size:15px;
  height:100%;display:flex;flex-direction:column;
  overscroll-behavior:none;
  -webkit-font-smoothing:antialiased;
}

/* ── THEME TOGGLE ── */
.theme-btn{
  background:var(--sur2);border:1px solid var(--b1);
  color:var(--mu);
  font-size:15px;width:34px;height:34px;
  border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s,color .15s,background .15s;
}
.theme-btn:active{background:var(--b1)}

/* ── HEADER ── */
header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 18px;height:56px;
  background:var(--hdr-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.05);
  position:sticky;top:0;z-index:50;
  padding-top:env(safe-area-inset-top,0);
}

.logo{
  font-family:var(--mono);font-size:13px;font-weight:600;
  letter-spacing:.18em;color:var(--tx);
  display:flex;align-items:center;gap:9px;
}
.logo-mark{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--ac),var(--ac2));
  position:relative;
  box-shadow:0 0 16px var(--ac-glow);
}
.logo-mark-inner{
  width:8px;height:8px;border-radius:50%;
  background:#fff;opacity:.9;
  transition:box-shadow .4s, opacity .4s;
}
.logo-mark.on .logo-mark-inner{
  box-shadow:0 0 10px #fff, 0 0 4px var(--gr);
}
.logo-text{color:var(--tx);opacity:.95}

.hdr-right{display:flex;align-items:center;gap:8px}
.gh-pill{
  font-family:var(--mono);font-size:10px;color:var(--mu);
  background:var(--sur2);
  border:1px solid var(--b1);
  border-radius:20px;
  padding:4px 11px;display:flex;align-items:center;gap:6px;
  max-width:130px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  transition:border-color .2s, color .2s;
}
.gh-pill.on{border-color:rgba(140,154,110,.25);color:var(--gr)}
.gh-pill-dot{width:5px;height:5px;border-radius:50%;background:var(--mu);flex-shrink:0;transition:background .2s}
.gh-pill-dot.on{background:var(--gr);box-shadow:0 0 6px var(--gr)}
.icon-btn{
  background:var(--sur2);border:1px solid var(--b1);
  color:var(--mu);
  font-size:16px;width:34px;height:34px;
  border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s, color .15s, background .15s;
}
.icon-btn:active{background:var(--b1);color:var(--tx)}

/* ── MAIN ── */
main{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding-bottom:calc(68px + var(--safe-b));
}
.view{display:none;padding:18px 16px}
.view.active{display:block}

/* ── BOTTOM NAV ── */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  height:calc(60px + var(--safe-b));
  background:var(--nav-bg);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid rgba(255,255,255,.05);
  display:flex;align-items:flex-start;padding-top:8px;
  z-index:50;
  padding-bottom:var(--safe-b);
}
.bnav-btn{
  flex:1;display:flex;flex-direction:column;align-items:center;
  gap:4px;background:none;border:none;color:var(--mu);
  font-family:var(--sans);font-size:10px;font-weight:500;
  cursor:pointer;padding:4px 0;
  border-radius:12px;transition:color .2s;
  position:relative;letter-spacing:.02em;
}
.bnav-btn .bico{
  font-size:19px;line-height:1;
  transition:transform .2s;
}
.bnav-btn.active .bico{transform:scale(1.08)}
.bnav-btn.active{color:var(--ac)}
.bnav-badge{
  position:absolute;top:-1px;right:calc(50% - 20px);
  background:var(--ye);color:#000;
  font-size:9px;font-weight:700;
  min-width:16px;height:16px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;
}

/* ── SECTION HEADER ── */
.sec-hdr{
  display:flex;align-items:baseline;gap:10px;
  margin-bottom:14px;
}
.sec-title{font-size:17px;font-weight:700;color:var(--tx)}
.sec-count{
  font-family:var(--mono);font-size:10px;color:var(--mu);
  letter-spacing:.06em;
}

/* ── SEARCH VIEW ── */
.search-wrap{
  display:flex;gap:8px;margin-bottom:14px;
}
.search-input-wrap{
  flex:1;position:relative;display:flex;align-items:center;
}
.search-icon{
  position:absolute;left:13px;color:var(--mu);font-size:15px;pointer-events:none;
}
.search-input{
  flex:1;width:100%;
  background:var(--sur2);border:1.5px solid var(--b1);
  color:var(--tx);font-family:var(--sans);font-size:15px;
  padding:11px 14px 11px 38px;border-radius:var(--r-md);outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.search-input:focus{
  border-color:var(--ac);
  box-shadow:0 0 0 3px var(--ac-dim);
}
.search-input::placeholder{color:var(--mu)}
.search-btn{
  background:var(--ac);color:#fff;border:none;
  font-family:var(--sans);font-size:13px;font-weight:600;
  padding:11px 17px;border-radius:var(--r-md);cursor:pointer;
  white-space:nowrap;min-width:46px;font-size:18px;
  transition:opacity .15s, box-shadow .15s;
  box-shadow:0 2px 12px var(--ac-glow);
}
.search-btn:active{opacity:.8}

.filter-row{
  display:flex;gap:6px;margin-bottom:16px;
  overflow-x:auto;padding-bottom:4px;scrollbar-width:none;
}
.filter-row::-webkit-scrollbar{display:none}
.chip{
  background:var(--sur2);border:1.5px solid var(--b1);
  color:var(--mu);font-size:12px;font-weight:500;
  padding:6px 14px;border-radius:20px;cursor:pointer;
  white-space:nowrap;transition:all .18s;
  flex-shrink:0;letter-spacing:.01em;
}
.chip:active{opacity:.75}
.chip.active{
  border-color:var(--ac);color:var(--ac);
  background:var(--ac-dim);
  box-shadow:0 0 0 1px var(--ac-dim);
}

.res-label{
  font-family:var(--mono);font-size:10px;color:var(--mu);
  margin-bottom:10px;letter-spacing:.06em;text-transform:uppercase;
}

/* ── CARDS ── */
.card{
  background:var(--sur);border:1px solid var(--b1);
  border-radius:var(--r-lg);padding:16px;margin-bottom:10px;
  cursor:pointer;
  transition:border-color .15s, background .15s, transform .1s;
  -webkit-user-select:none;user-select:none;
  position:relative;overflow:hidden;
}
.card::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(229,181,103,.04),transparent 60%);
  opacity:0;transition:opacity .2s;
}
.card:active{
  border-color:var(--b2);
  background:var(--sur2);
  transform:scale(.99);
}
.card:active::before{opacity:1}

.card-meta{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.cat-tag{
  font-family:var(--mono);font-size:9px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ac2);
  background:var(--ac2-dim);
  padding:3px 8px;border-radius:5px;
  border:1px solid rgba(127,169,152,.15);
}

.card-date{font-size:11px;color:var(--mu);font-family:var(--mono)}
.card-title{font-size:15px;font-weight:600;margin-bottom:6px;line-height:1.35;color:var(--tx)}
.card-snip{font-size:13px;color:var(--tx2);line-height:1.6}
.card-snip em{color:var(--ye);font-style:normal;font-weight:600;
  background:rgba(223,184,92,.1);padding:0 3px;border-radius:3px}
.card-arrow{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  color:var(--b3);font-size:14px;
}

.empty{text-align:center;padding:60px 20px;color:var(--mu)}
.empty-ico{font-size:32px;margin-bottom:12px;opacity:.5}
.empty-lbl{font-size:14px;color:var(--mu)}
.empty-hint{font-size:12px;color:var(--b3);margin-top:6px}

/* ── WRITE VIEW ── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.flabel{
  font-family:var(--mono);font-size:10px;color:var(--mu);
  text-transform:uppercase;letter-spacing:.1em;
}
.finput,.fselect,.ftextarea{
  background:var(--sur2);border:1.5px solid var(--b1);
  color:var(--tx);font-family:var(--sans);font-size:15px;
  padding:12px 14px;border-radius:var(--r-md);outline:none;
  transition:border-color .18s, box-shadow .18s;width:100%;
}
.finput:focus,.fselect:focus,.ftextarea:focus{
  border-color:var(--ac);
  box-shadow:0 0 0 3px var(--ac-dim);
}
.fselect{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8780' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}
.fselect option{background:var(--sur);color:var(--tx)}
.ftextarea{resize:vertical;min-height:140px;line-height:1.7}

/* ── SPINNER ── */
.spin{
  display:inline-block;width:12px;height:12px;
  border:2px solid var(--b2);border-top-color:var(--ac);
  border-radius:50%;animation:rot .6s linear infinite;
  vertical-align:middle;margin-right:6px;
}
@keyframes rot{to{transform:rotate(360deg)}}

/* ── REPO BUTTONS ── */
.repo-row{display:flex;gap:8px}
.repo-btn{
  flex:1;background:var(--sur2);border:1.5px solid var(--b1);
  color:var(--mu);font-family:var(--mono);font-size:13px;font-weight:600;
  padding:11px 10px;border-radius:var(--r-md);cursor:pointer;
  transition:all .15s;letter-spacing:.04em;
}
.repo-btn:active{opacity:.75}
.repo-btn.active{
  border-color:var(--ac);color:var(--ac);
  background:var(--ac-dim);
  box-shadow:0 0 0 1px var(--ac-dim);
}

/* ── STATUS BAR ── */
.sbar{
  font-family:var(--mono);font-size:11px;color:var(--mu);
  min-height:28px;padding:5px 0;letter-spacing:.02em;
}
.sbar.ok{color:var(--gr)}
.sbar.err{color:var(--re)}
.sbar.ld{color:var(--ye)}

/* ── ACTION ROW ── */
.act-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.btn{
  flex:1;color:#fff;border:none;
  font-family:var(--sans);font-size:13px;font-weight:600;
  padding:13px 10px;border-radius:var(--r-md);cursor:pointer;
  white-space:nowrap;text-align:center;
  transition:opacity .15s, transform .1s;
}
.btn:active{opacity:.8;transform:scale(.98)}
.btn:disabled{opacity:.35}
.btn-primary{background:var(--ac);box-shadow:0 2px 12px var(--ac-glow)}
.btn-ghost{background:var(--sur2);color:var(--tx2);border:1px solid var(--b2)}
.btn-ghost:active{background:var(--b1)}
.btn-dark{background:var(--b1);color:var(--tx2)}

/* ── PENDING VIEW ── */
.pend-hdr{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;
}
.pend-hdr-left h2{font-size:17px;font-weight:700;margin-bottom:2px}
.pend-ct{font-family:var(--mono);font-size:10px;color:var(--mu);letter-spacing:.06em}

.pcard{
  background:var(--sur);border:1px solid var(--b1);
  border-radius:var(--r-lg);padding:16px;margin-bottom:10px;
  transition:border-color .15s;
}
.pcard-title{font-size:15px;font-weight:600;margin-bottom:4px;color:var(--tx)}
.pcard-meta{
  font-size:10px;color:var(--mu);font-family:var(--mono);
  margin-bottom:10px;letter-spacing:.04em;text-transform:uppercase;
}
.pcard-preview{
  font-size:13px;color:var(--tx2);line-height:1.6;
  border-left:2px solid var(--b2);padding-left:12px;margin-bottom:13px;
}
.pcard-acts{display:flex;gap:7px;flex-wrap:wrap}
.pact{
  font-family:var(--sans);font-size:12px;font-weight:600;
  padding:8px 14px;border-radius:9px;cursor:pointer;border:none;
  transition:opacity .15s, transform .1s;
}
.pact:active{opacity:.75;transform:scale(.96)}
.pact-ok{
  background:var(--gr-dim);color:var(--gr);
  border:1px solid rgba(140,154,110,.25);
}
.pact-ed{
  background:none;border:1px solid var(--b2);color:var(--tx2);
}
.pact-no{
  background:var(--re-dim);color:var(--re);
  border:1px solid rgba(217,112,106,.2);
}

/* ── SETTINGS MODAL ── */
.overlay{
  display:none;position:fixed;inset:0;
  background:var(--overlay-bg);z-index:200;
  align-items:flex-end;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.overlay.open{display:flex}
.modal{
  background:var(--sur);
  border:1px solid var(--b2);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  padding:24px 20px calc(24px + var(--safe-b));
  width:100%;max-height:92vh;overflow-y:auto;
}
.modal-drag{
  width:36px;height:4px;background:var(--b3);
  border-radius:2px;margin:0 auto 20px;
}
.modal-title{font-size:17px;font-weight:700;margin-bottom:4px}
.modal-sub{font-size:12px;color:var(--mu);margin-bottom:20px;line-height:1.55}
.modal-acts{display:flex;gap:8px;margin-top:20px}

/* ── DETAIL SHEET ── */
.d-overlay{
  display:none;position:fixed;inset:0;
  background:var(--d-overlay-bg);z-index:150;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.d-overlay.open{display:block}
.d-sheet{
  position:fixed;bottom:0;left:0;right:0;
  max-height:88vh;
  background:var(--sur);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  border-top:1px solid var(--b2);
  overflow-y:auto;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.32,.72,0,1);
  z-index:160;
  padding-bottom:calc(24px + var(--safe-b));
}
.d-sheet.open{transform:translateY(0)}
.d-handle{
  width:36px;height:4px;background:var(--b2);
  border-radius:2px;margin:14px auto 0;
}
.d-inner{padding:18px 20px 20px}
.d-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.d-close{
  background:var(--b1);border:1px solid var(--b2);color:var(--mu);
  font-size:12px;font-weight:500;padding:6px 14px;
  border-radius:20px;cursor:pointer;
  transition:color .15s, border-color .15s;
}
.d-close:active{color:var(--tx);border-color:var(--b3)}
.d-inner h1{
  font-size:19px;font-weight:700;margin-bottom:8px;
  color:var(--tx);line-height:1.3;
}
.d-inner h2{
  font-size:14px;font-weight:600;margin:16px 0 7px;color:var(--ac);
  padding-left:10px;border-left:2px solid var(--ac);
}
.d-inner h3{font-size:13px;font-weight:600;margin:12px 0 5px;color:var(--ac2)}
.d-inner p{font-size:14px;line-height:1.75;color:var(--tx2);margin-bottom:11px}
.d-inner code{
  font-family:var(--mono);background:var(--b1);
  color:var(--ac);padding:2px 6px;border-radius:5px;font-size:12px;
  border:1px solid rgba(229,181,103,.1);
}
.d-inner pre{
  background:var(--bg);border:1px solid var(--b1);
  border-radius:12px;padding:15px;margin:11px 0;
  overflow-x:auto;font-family:var(--mono);font-size:12px;line-height:1.65;
}
.d-inner ul{margin:7px 0 11px 18px}
.d-inner li{font-size:14px;line-height:1.7;color:var(--tx2);margin-bottom:5px}
.d-title{font-size:20px;font-weight:700;color:var(--tx);line-height:1.3;margin:0 0 10px}
.d-meta{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--b1)}
.d-date{font-size:12px;color:var(--mu);margin-left:auto}
.d-body{padding-top:4px}
.d-body h1,.d-body h2,.d-body h3{margin-top:16px}
.d-body p{font-size:14px;line-height:1.8;color:var(--tx2);margin-bottom:10px}
.d-body strong{color:var(--tx);font-weight:600}
.d-body em{color:var(--ac2);font-style:italic}
.d-body code{font-family:var(--mono);background:var(--b1);color:var(--ac);padding:2px 6px;border-radius:5px;font-size:12px;border:1px solid rgba(229,181,103,.1)}
.d-body pre{background:var(--bg);border:1px solid var(--b1);border-radius:12px;padding:15px;margin:10px 0;overflow-x:auto;font-family:var(--mono);font-size:12px;line-height:1.65}
.d-body ul{margin:6px 0 10px 18px}
.d-body li{font-size:14px;line-height:1.7;color:var(--tx2);margin-bottom:4px}

/* ── DIVIDER ── */
.view-divider{
  height:1px;background:var(--b1);margin:18px 0;
}

/* scrollbar desktop */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.card{animation:fadeUp .2s ease both}
.card:nth-child(2){animation-delay:.04s}
.card:nth-child(3){animation-delay:.08s}
.card:nth-child(4){animation-delay:.12s}
.card:nth-child(5){animation-delay:.16s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}