/* NTP V2 Forum Demo — light web3 style */
:root{
  --bg: #f7f8fb;
  --panel: rgba(255,255,255,.78);
  --panel2: rgba(255,255,255,.92);
  --stroke: rgba(20, 28, 38, .10);
  --stroke2: rgba(20, 28, 38, .14);
  --text: #0a0d15;
  --muted:#4f5a6f;
  --muted2:#7a879f;
  --brand:#2563eb;
  --brand2:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;
  --shadow: 0 18px 50px rgba(15, 23, 42, .12);
  --shadow2: 0 10px 24px rgba(15, 23, 42, .10);
  --r16: 16px;
  --r20: 20px;
  --r24: 24px;
  --sans:
    ui-sans-serif, -apple-system, system-ui, "Segoe UI", Helvetica,
    "Apple Color Emoji", Arial, sans-serif, "Segoe UI Emoji", "Segoe UI Symbol";
  --mono:
    ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;
}

/* Concept banner */
.concept-banner{
  position: sticky;
  top: 0;
  z-index: 100;
  background: linear-gradient(135deg, rgba(37,99,235,.15), rgba(34,197,94,.12));
  border-bottom: 1px solid rgba(20,28,38,.10);
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  padding: 10px 16px;
}

/* Connect screen */
.connect-screen{
  min-height: calc(100vh - 50px);
  display: grid;
  place-items: center;
  padding: 24px;
}
.connect-card{
  width: min(440px, 100%);
  padding: 24px;
  border-radius: 22px;
  border: 1px solid rgba(20,28,38,.12);
  background: rgba(255,255,255,.95);
  box-shadow: var(--shadow);
}
.connect-brand{
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.connect-mark{
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(37,99,235,.12);
  border: 1px solid rgba(37,99,235,.2);
  font-weight: 700;
  font-size: 22px;
}
.connect-title{ font-weight: 800; font-size: 18px; }
.connect-sub{ font-size: 13px; color: var(--muted2); margin-top: 2px; }
.connect-notice{
  margin-bottom: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.25);
  color: var(--danger);
  font-size: 13px;
}
.connect-form{ display: flex; flex-direction: column; gap: 16px; }
.field__hint{ font-size: 11px; color: var(--muted2); margin-top: 4px; }
.input--mono{ font-family: var(--mono); }
.btn--block{ width: 100%; }
.connect-screen.hidden{ display: none !important; }
.main-app.hidden{ display: none !important; }

*{box-sizing:border-box}
a,button,a:hover,a:focus,button:hover,button:focus{text-decoration:none}
html,body{height:100%}
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--text);
  background: var(--bg);
}

.wrap{max-width: 1680px; margin: 0 auto; padding: 22px}
main.wrap{padding-top: 4px}
.topbar{
  position: sticky; top:0; z-index: 20;
  background: #fff;
  border-bottom: 1px solid rgba(20,28,38,.08);
}
.topbar__in{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding-top:4px; padding-bottom:4px;
}

.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit}
.brand__mark{
  width:36px; height:36px; display:grid; place-items:center;
  border-radius: 12px;
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.18);
  font-weight:700;
}
.brand__name{font-weight:700; letter-spacing:-.02em}
.pill{
  font-size:12px; font-weight:600;
  padding:4px 10px; border-radius: 999px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.6);
  color: var(--muted);
}
.pill--ghost{background: rgba(255,255,255,.45)}

.nav{display:flex; gap:10px; align-items:center}
.nav__link{
  text-decoration:none;
  color: var(--text);
  font-size:14px;
  padding:10px 12px;
}
.nav__link:hover{color:var(--text); background: rgba(255,255,255,.6); border-color: var(--stroke)}

.actions{display:flex; align-items:center; gap:12px}

.wallet{
  display:flex; align-items:center; gap:10px;
  padding:10px 10px 10px 12px;
  border-radius: 999px;
}
.wallet__meta{display:flex; flex-direction:column; line-height:1.1}
.wallet__label{font-size:11px; color:var(--muted2); font-weight:600}
.wallet__value{font-size:13px; font-weight:700}
.wallet__sep{width:1px; height:26px; background: rgba(20,28,38,.12)}
.unit{font-weight:700; color:var(--muted)}
.btn{
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.80);
  color: var(--text);
  padding:10px 12px;
  border-radius: 12px;
  cursor:pointer;
  transition: background .12s ease;
}
.btn--primary{
  background: linear-gradient(135deg, rgba(37,99,235,.98), rgba(96,165,250,.92));
  border-color: rgba(37,99,235,.35);
  color: white;
}
.btn--ghost{
  background: rgba(255,255,255,.55);
}
.btn--sm{
  padding: 8px 10px;
  font-size: 12px;
}
.iconbtn{
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.75);
  border-radius: 12px;
  padding:8px 10px;
  cursor:pointer;
}

.notice{
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,.78);
  border: 1px solid var(--stroke);
  border-radius: 14px;
  color: var(--muted);
  word-break: break-word;
}
.notice b{color: var(--text)}

.app{margin-top: 4px}

.hero{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 520px);
  gap:12px;
}
.card{
  padding: 18px;
}
.card--topics{
  max-width: 520px;
  width: 100%;
  justify-self: stretch;
}
.card--tight{padding: 14px}
.card__head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom: 12px;
}
.card__collapse{margin:0}
.card__collapse summary{
  list-style:none;
  cursor:pointer;
  outline:none;
}
.card__collapse summary::-webkit-details-marker{display:none}
.card__collapse:not([open]) .card__head{margin-bottom:0}
.h1{font-size: 22px; font-weight: 800; letter-spacing:-.02em; margin:0}
.h2{font-size: 16px; font-weight: 800; letter-spacing:-.02em; margin:0}
.p{margin:8px 0; color: var(--muted); line-height:1.55}
.small{font-size: 12px; color: var(--muted2)}
.mini{font-size: 12px; color: var(--muted2); line-height:1.4}
.kpis{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin-top: 14px}
.kpi{
  display:grid; grid-template-columns: 1fr 1fr; gap:10px; margin-bottom: 12px;
}
.kpi__item{
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.70);
  border:1px solid rgba(20,28,38,.10);
}
.kpi__label{font-size: 12px; color: var(--muted2); font-weight:700}
.kpi__value{font-size: 18px; font-weight: 900; letter-spacing:-.02em}

.badge{
  font-size: 12px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 999px;
  border: none;
  background: none;
  color: var(--muted);
}
.badge--ok{color: #0b5d2b}
.badge--lock{color: #7a4b00}
.badge--danger{color: #7a1212}
.badge--compact{
  font-size: 11px;
  padding: 4px 8px;
}

.table{
  width:100%;
  border-collapse: separate;
  border-spacing:0;
  overflow:hidden;
  border-radius: 18px;
  border:1px solid rgba(20,28,38,.10);
  background: rgba(255,255,255,.72);
}
.table th, .table td{padding: 12px 12px; text-align:left; font-size: 13px}
.table th{color: var(--muted2); border-bottom:1px solid rgba(20,28,38,.10)}
.table td{border-bottom:1px solid rgba(20,28,38,.08)}
.table tr:last-child td{border-bottom: none}

.section-cell{vertical-align: top}
.section-cell__line + .section-cell__line{margin-top: 8px}

.policy-cell{position: relative; display: inline-block}
.policy-icon{
  cursor: pointer;
  font-size: 16px;
  padding: 4px;
  border: none;
  background: none;
  list-style: none;
  user-select: none;
}
.policy-icon::-webkit-details-marker{display: none}
.policy-icon::marker{content: none}
.policy-icon:hover{opacity: .85}
.policy-cell__content{
  position: absolute;
  left: 0;
  top: 100%;
  margin-top: 4px;
  padding: 8px 10px;
  font-size: 12px;
  font-family: var(--mono);
  white-space: nowrap;
  background: var(--panel2);
  border: 1px solid var(--stroke);
  border-radius: 10px;
  box-shadow: var(--shadow2);
  z-index: 10;
}

.link{
  text-decoration:none;
  color: var(--text);
  font-weight: 800;
}
.link:hover{color: var(--brand)}
.link--strong{display:inline-flex; align-items:center; gap:6px}
.link--strong::after{content:"→"; color: var(--muted2)}
.actionsRow{display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top: 12px;}

.pagination-wrap{margin-top: 16px;}
.pagination{display:flex; align-items:center; gap:8px; flex-wrap:wrap;}
.pagination__link{font-size: 13px; padding: 6px 10px; border-radius: 10px; background: rgba(37,99,235,.08); color: var(--brand); text-decoration: none; transition: background .15s;}
.pagination__link:hover{background: rgba(37,99,235,.15)}
.pagination__current{font-size: 13px; font-weight: 700; padding: 6px 10px; color: var(--text);}

.reply-form{margin-top: 20px; padding: 16px; border: 1px solid var(--stroke); border-radius: 16px;}
.reply-form__head{display:flex; justify-content:space-between; align-items:center; margin-bottom: 12px;}

.new-topic__events{margin-top: 20px !important; display: block;}
.hr{height:1px; background: rgba(20,28,38,.10); margin: 14px 0}

.field{display:flex; flex-direction:column; gap:8px; margin-top: 10px}
.field__label{font-size: 12px; color: var(--muted2)}
.input, .textarea, .select{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(20,28,38,.12);
  background: rgba(255,255,255,.85);
  outline:none;
  font-family: inherit;
}
.textarea{min-height: 140px; resize: vertical}
.select{appearance:none}
.row2{display:grid; grid-template-columns: 1fr 1fr; gap:10px}

.paywall-bar{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(245, 158, 11, .08);
  border: 1px solid rgba(245, 158, 11, .25);
}
.paywall-bar__label{
  font-size: 13px;
  font-weight: 700;
  color: var(--warn);
}
.unlock-chip{
  font-size: 12px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 10px;
  border: 1px solid rgba(37, 99, 235, .3);
  background: rgba(37, 99, 235, .1);
  color: var(--brand);
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, border-color .15s;
}
.unlock-chip:hover{
  background: rgba(37, 99, 235, .18);
  border-color: rgba(37, 99, 235, .45);
}
.unlock-chip--primary{
  background: linear-gradient(135deg, rgba(37,99,235,.92), rgba(96,165,250,.85));
  border-color: rgba(37,99,235,.4);
  color: #fff;
}
.unlock-chip--primary:hover{
  background: linear-gradient(135deg, rgba(37,99,235,.98), rgba(96,165,250,.92));
}

.callout{
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(37,99,235,.20);
  background: rgba(37,99,235,.08);
}
.callout__title{font-weight:900; margin-bottom:6px}
.callout__text{color: var(--muted); line-height:1.5; word-break: break-word}

.tag{
  display: inline-flex;
  font-size: 12px;
  text-decoration: none;
  color: var(--text);
}
.tag--link{cursor:pointer}
.tag--link:hover{color: var(--brand); border-color: rgba(37,99,235,.35)}
.tag--link.is-active{
  color: var(--brand);
  border-color: rgba(37,99,235,.35);
  background: rgba(37,99,235,.10);
}
.list{margin: 10px 0 0 18px; color: var(--muted); line-height:1.55}
.list li{margin: 6px 0}
code{font-family: var(--mono); font-size: 12px; padding:2px 6px; border-radius: 10px; background: rgba(15,23,42,.06); border:1px solid rgba(15,23,42,.10); word-break: break-word}

.modal::backdrop{background: rgba(2,6,23,.35)}
.modal{
  border:none;
  padding:0;
  background: transparent;
}
.modal__card{
  width:min(720px, calc(100vw - 28px));
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.50);
  background: rgba(255,255,255,1);
  overflow:hidden;
}
.modal__head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 14px 16px;
  border-bottom:1px solid rgba(20,28,38,.10);
  background: rgba(255,255,255,1);
}
.modal__title{font-weight: 900}
.modal__body{padding: 14px 16px}
.modal__foot{
  padding: 14px 16px;
  border-top:1px solid rgba(20,28,38,.10);
  background: rgba(255,255,255,1);
  display:flex; justify-content:flex-end; gap:10px;
}

.section-header__body{display: flex; flex-direction: column; gap: 0}
.section-header__line + .section-header__line{margin-top: 8px}

.subsectionRow{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-bottom: 12px;
  margin-top: 12px;
}
.subsectionRow__tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.split{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 12px;
}

.topicsGrid{
  display:grid;
  gap:12px;
}
.topicCard{
  padding: 16px;
  border-radius: 20px;
  border:1px solid rgba(20,28,38,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.70));
  display:grid;
  gap:10px;
  width: 100%;
  min-width: 0;
}
.topicCard:hover{
  border-color: rgba(37,99,235,.18);
}
.topicCard__head{
  display:grid;
  gap:6px;
}
.topicCard__titleRow{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  min-width: 0;
}
.topicCard__title{
  font-weight: 900;
  font-size: 16px;
  margin:0;
  display:block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.topicCard__badge{flex-shrink:0}
.topicCard__tagRow{display:flex; flex-wrap:wrap; gap:8px}
.topicCard__excerpt{
  color: var(--muted);
  font-size: 13px;
  line-height:1.55;
  word-break: break-word;
}
.topicCard__meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  color: var(--muted2);
  font-size: 12px;
  font-weight:700;
}
.topicMeta{
  margin-top: 6px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  color: var(--muted2);
  font-size: 12px;
  font-weight:700;
}
.metaItem{display:inline-flex; align-items:center; gap:6px}
.metaIcon{font-size: 14px; line-height:1}
.topic__body{
  margin-top:10px;
  color: var(--muted);
  line-height:1.6;
  padding: 14px;
  border-radius: 16px;
  border:1px solid rgba(20,28,38,.08);
  background: rgba(255,255,255,.85);
  word-break: break-word;
}
.topic__footer{
  margin-top: 10px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.post{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border:1px solid rgba(20,28,38,.10);
  background: rgba(255,255,255,.78);
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.post__avatar{
  width: 36px;
  height: 36px;
  border-radius: 50px;
  display:grid;
  place-items:center;
  color: var(--avatar-color, #1e3a8a);
  background: var(--avatar-bg, rgba(37,99,235,.12));
  border:1px solid var(--avatar-border, rgba(37,99,235,.20));
  flex-shrink:0;
}
.post__content{flex:1; min-width:0}
.post__head{display:flex; justify-content:space-between; gap:10px; color:var(--muted2); font-size:12px;}
.post__text{margin-top:8px; color:var(--muted); line-height:1.55; word-break: break-word}
.post__head span{white-space:nowrap}
.post__actions{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.reactions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.reactionButton{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius: 999px;
  border:1px solid rgba(20,28,38,.12);
  background: rgba(255,255,255,.85);
  font-size:12px;
  cursor:pointer;
  color: var(--muted);
}
.reactionButton:hover{
  border-color: rgba(37,99,235,.24);
  color: var(--text);
}
.reactionButton__icon{font-size:14px}
.reactionButton__count{font-weight:700}
.quote{
  margin: 8px 0;
  padding: 10px 12px;
  border-left: 3px solid rgba(37,99,235,.45);
  border-radius: 12px;
  background: rgba(37,99,235,.08);
  color: var(--muted);
  line-height:1.5;
}

.muted{color: var(--muted)}
.right{justify-self:end}
@media (max-width: 980px){
  .wrap{padding: 16px}
  .topbar__in{flex-wrap:wrap; padding: 8px 16px}
  .hero{grid-template-columns: 1fr}
  .split{grid-template-columns:1fr}
  .card--topics{max-width: none}
  .nav{display:none}
  .actions{width:100%; justify-content:flex-end; flex-wrap:wrap}
  .wallet{flex:1 1 auto; justify-content:flex-end; padding: 8px 0}
  .wallet__meta{display:none}
  .wallet__sep{display:none}
  .kpis{grid-template-columns: 1fr}
  .kpi{grid-template-columns: 1fr}
  .row2{grid-template-columns: 1fr}
  .table{display:block; overflow:auto; overflow-x: auto; -webkit-overflow-scrolling: touch}
  .table th, .table td{white-space:nowrap}
  .topicCard__title{white-space: normal}
  .topicMeta{gap:8px; flex-wrap: wrap}
  .topicCard__meta{gap:8px; flex-wrap: wrap}
  .modal__foot{flex-direction:column; align-items:stretch}
  .modal__card{width: min(720px, calc(100vw - 16px))}
}
@media (max-width: 640px){
  .brand__mark{width:32px; height:32px}
  .brand__name{font-size: 14px}
  .btn{padding: 8px 10px}
  .card{padding: 14px}
  .connect-screen{padding: 16px; min-height: calc(100vh - 50px)}
  .connect-card{width: 100%; padding: 18px}
  .connect-brand{flex-wrap: wrap}
}

@media (max-width: 480px){
  .concept-banner{font-size: 12px; padding: 8px 12px}
  .wrap{padding: 16px}
  .connect-card{padding: 16px}
}
