:root{
  --g1:#c9d7b3;
  --g2:#93a86b;
  --g3:#637a3f;
  --g4:#39501e;
  --ink:#10130e;
  --paper:#f6f7f2;
  --shadow: 0 16px 40px rgba(0,0,0,.20);
  --radius: 16px;
  --radius2: 12px;
  --max: 1120px;
}

*{ box-sizing:border-box; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(201,215,179,.85), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(147,168,107,.55), transparent 55%),
    linear-gradient(180deg, #f4f6ee, #e9efe0);
}

.wrap{ max-width: var(--max); margin: 0 auto; padding: 16px; }

.toolbox-header{
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.08);
  margin: 16px;
  background: linear-gradient(180deg, rgba(57,80,30,.92), rgba(57,80,30,.86));
}

.toolbox-lid{
  padding: 14px;
  color: #fff;
  display:flex;
  gap: 12px;
  align-items: center;
}

.brand{ display:flex; gap: 12px; align-items: center; min-width: 220px; }
.brand img{
  width: 44px; height: 44px; object-fit: cover;
  border-radius: 12px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
}
.brand-title{ display:flex; flex-direction: column; gap: 2px; }
.brand-title strong{ font-size: 18px; letter-spacing: .2px; line-height: 1.1; }
.brand-title span{ font-size: 12.5px; opacity: .92; }

.top-actions{ margin-left:auto; display:flex; gap: 10px; flex-wrap: wrap; align-items:center; }

.chip{
  display:inline-flex; align-items:center;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  font-size: 13px;
}

.btn{
  appearance:none;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color: #fff;
  padding: 9px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 650;
  text-decoration: none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn:hover{ filter: brightness(1.05); }
.btn.secondary{ background: rgba(255,255,255,.18); }

.toolbox-band{
  background: linear-gradient(180deg, rgba(201,215,179,.88), rgba(201,215,179,.78));
  border-top: 1px solid rgba(255,255,255,.22);
  padding: 10px 14px 12px;
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
}

.subtitle{ font-size: 13.5px; color: rgba(16,19,14,.80); flex: 1; min-width: 240px; }
.pill{
  display:inline-flex; align-items:center;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(201,215,179,.22);
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 650;
  color: rgba(16,19,14,.82);
}

.drawer{
  margin-top: 14px;
  background: rgba(246,247,242,.92);
  border: 1px solid rgba(0,0,0,.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.drawer-head{
  background: linear-gradient(180deg, rgba(147,168,107,.42), rgba(147,168,107,.18));
  border-bottom: 1px solid rgba(0,0,0,.08);
  padding: 12px 14px;
  display:flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.drawer-head h2{ margin:0; font-size: 16px; letter-spacing: .2px; }
.drawer-head .hint{ margin-left:auto; color: rgba(16,19,14,.65); font-size: 12.5px; }
.drawer-body{ padding: 14px; }

.grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 12px;
}

.app-card{
  border-radius: var(--radius2);
  border: 1px solid rgba(0,0,0,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,247,242,.92));
  box-shadow: 0 8px 22px rgba(0,0,0,.10);
  overflow:hidden;
  display:flex;
  flex-direction: column;
  min-height: 160px;
}
.app-top{
  padding: 12px;
  display:flex;
  gap: 10px;
  align-items: center;
  border-bottom: 1px solid rgba(0,0,0,.06);
  background: linear-gradient(180deg, rgba(201,215,179,.60), rgba(201,215,179,.22));
}
.badge{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--g3), var(--g4));
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.28);
  flex: 0 0 auto;
}
.app-title{ display:flex; flex-direction: column; gap: 2px; min-width: 0; }
.app-title strong{ font-size: 14.5px; line-height: 1.2; }
.app-title span{
  font-size: 12.5px;
  color: rgba(16,19,14,.70);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-body{ padding: 12px; display:flex; flex-direction: column; gap: 10px; flex: 1; }
.app-desc{ margin:0; font-size: 13.5px; color: rgba(16,19,14,.78); line-height: 1.35; flex: 1; }

.app-actions{ display:flex; gap: 8px; flex-wrap: wrap; align-items:center; }
.app-actions a, .app-actions button{
  border: 1px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.92);
  padding: 8px 10px;
  border-radius: 999px;
  cursor:pointer;
  text-decoration:none;
  color: var(--ink);
  font-weight: 650;
  font-size: 13px;
}
.app-actions a:hover, .app-actions button:hover{ background: rgba(201,215,179,.35); }

.coming .badge{ background: linear-gradient(135deg, #9aa39a, #cfd5cf); }
.coming .app-actions button{ opacity: .6; cursor: not-allowed; }

.box{
  border:1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  padding: 12px;
}

.field{ display:grid; gap: 6px; margin-top: 10px; }
label{ font-size: 13px; color: rgba(16,19,14,.75); }

input, textarea, select{
  font-family: inherit;
  font-size: 14px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.16);
  background: #fff;
  width: 100%;
}
textarea{ resize: vertical; }

.row{ display:flex; gap: 10px; flex-wrap: wrap; align-items:center; margin-top: 12px; }

.primary{
  border: 1px solid rgba(0,0,0,.16);
  background: linear-gradient(135deg, var(--g3), var(--g4));
  color: #fff;
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 750;
}
.primary:hover{ filter: brightness(1.05); }

.muted{ color: rgba(16,19,14,.68); font-size: 12.8px; line-height: 1.35; }

.suggest-list{ display:grid; gap: 10px; margin-top: 12px; }
.suggest-item{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  padding: 12px;
  display:grid;
  gap: 8px;
}
.suggest-head{ display:flex; gap: 10px; flex-wrap: wrap; align-items:center; }
.suggest-title{ font-weight: 800; }
.vote-box{ margin-left:auto; display:flex; gap: 8px; align-items:center; }
.vote-btn{
  border: 1px solid rgba(0,0,0,.14);
  background: rgba(246,247,242,.92);
  padding: 8px 10px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 750;
  min-width: 72px;
  text-align:center;
}
.vote-btn:hover{ background: rgba(201,215,179,.35); }
.score{ font-weight: 900; min-width: 40px; text-align:center; }

.footer{
  padding: 14px 0 28px;
  color: rgba(16,19,14,.65);
  font-size: 12.8px;
  text-align: center;
}

/* Modal */
.overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 16px;
  z-index: 50;
}
.modal{
  width: min(560px, 100%);
  border-radius: 18px;
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.14);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modal-head{
  background: linear-gradient(180deg, rgba(57,80,30,.92), rgba(57,80,30,.86));
  color: #fff;
  padding: 14px;
  display:flex;
  align-items:center;
  gap: 10px;
}
.modal-head button{
  margin-left:auto;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  color: #fff;
  padding: 8px 10px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 650;
}
.modal-body{ padding: 14px; }