:root{
  --paper:#f5eddd;
  --paper-2:#efe4cf;
  --cream:#fbf6ec;
  --ink:#2b211c;
  --ink-soft:#5a4f47;
  --green:#3f6a48;
  --green-deep:#33573b;
  --brick:#9c3b2e;
  --brick-deep:#7c2c22;
  --saffron:#e0a52e;
  --walnut:#6b4c3b;
  --line:rgba(43,33,28,.14);
  --shadow:0 1px 2px rgba(43,33,28,.06), 0 18px 50px -26px rgba(43,33,28,.55);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
[hidden]{display:none !important;}   /* author display rules must not defeat the hidden attribute */
html,body{height:100%;overflow-x:hidden;overscroll-behavior-x:none;}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(63,106,72,.10), transparent 60%),
    var(--paper);
  color:var(--ink);
  font-family:"Inter", system-ui, -apple-system, sans-serif;
  display:flex;
  flex-direction:column;
  min-height:100dvh;
  overscroll-behavior:none;
}

/* ---------- top bar ---------- */
.bar{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  padding:max(12px, env(safe-area-inset-top)) 16px 12px;
  padding-left:max(16px, env(safe-area-inset-left));
  padding-right:max(16px, env(safe-area-inset-right));
  background:rgba(245,237,221,.86);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
}
.bar-brand{display:flex;align-items:center;gap:10px;}
.bar-dot{
  width:22px;height:22px;border-radius:7px;flex:0 0 auto;
  background:var(--green);
  box-shadow:inset 0 0 0 2px rgba(251,246,236,.55);
  position:relative;
}
.bar-dot::after{
  content:"";position:absolute;inset:0;margin:auto;
  width:11px;height:6px;border-left:2.4px solid var(--cream);border-bottom:2.4px solid var(--cream);
  transform:translateY(-1px) rotate(-45deg);transform-origin:center;
}
.bar-title{
  font-family:"Fraunces", Georgia, serif;font-weight:600;font-size:19px;letter-spacing:.2px;
}
.bar-meta{display:flex;align-items:center;gap:8px;}
.queue-count{font-size:13px;color:var(--ink-soft);font-variant-numeric:tabular-nums;white-space:nowrap;}
.icon-btn{
  appearance:none;border:1px solid var(--line);background:var(--cream);
  color:var(--ink-soft);width:38px;height:38px;border-radius:11px;
  font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .08s ease, background .15s ease;
}
.icon-btn:active{transform:scale(.92);}

/* ---------- buttons ---------- */
.btn{
  appearance:none;border:0;cursor:pointer;font-family:inherit;font-weight:600;
  font-size:16px;border-radius:13px;padding:13px 18px;width:100%;
  transition:transform .08s ease, filter .15s ease;
}
.btn:active{transform:scale(.98);}
.btn-primary{background:var(--green);color:var(--cream);}
.btn-primary:hover{filter:brightness(1.05);}
.btn-ghost{background:var(--cream);color:var(--ink);border:1px solid var(--line);}

/* ---------- token gate ---------- */
.gate{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:24px;}
.gate-card{
  width:min(380px,100%);background:var(--cream);border:1px solid var(--line);
  border-radius:20px;padding:28px 24px;box-shadow:var(--shadow);text-align:center;
}
.gate-dot{
  display:block;width:46px;height:46px;border-radius:13px;margin:0 auto 14px;
  background:var(--green);position:relative;box-shadow:inset 0 0 0 3px rgba(251,246,236,.5);
}
.gate-dot::after{
  content:"";position:absolute;inset:0;margin:auto;width:20px;height:11px;
  border-left:3px solid var(--cream);border-bottom:3px solid var(--cream);
  transform:translateY(-2px) rotate(-45deg);
}
.gate-card h1{font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:23px;margin:0 0 6px;}
.gate-card p{margin:0 0 18px;color:var(--ink-soft);font-size:14px;line-height:1.5;}
#gate-form{display:flex;flex-direction:column;gap:10px;}
#gate-token{
  font-family:inherit;font-size:16px;padding:13px 14px;border-radius:12px;
  border:1px solid var(--line);background:var(--paper);color:var(--ink);width:100%;
}
#gate-token:focus{outline:2px solid var(--green);outline-offset:1px;}
.gate-err{color:var(--brick);font-size:13px;margin:12px 0 0;font-weight:500;}

/* ---------- deck ---------- */
.deck{
  flex:1 1 auto;display:flex;flex-direction:column;align-items:center;
  width:100%;max-width:520px;margin:0 auto;padding:16px;gap:14px;min-height:0;
}
.stack{
  position:relative;width:100%;flex:1 1 auto;min-height:0;
  display:flex;align-items:stretch;justify-content:center;
}

/* ---------- card ---------- */
.card{
  position:absolute;inset:0;
  background:var(--cream);border:1px solid var(--line);border-radius:22px;
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;overflow:hidden;
  will-change:transform;user-select:none;
  /* pan-y: browser may scroll vertically (so long cards still scroll), but
     horizontal movement is delivered to our swipe handler, never the page */
  touch-action:pan-y;
}
.card-top{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:16px 18px 12px;
}
.badge{
  font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;color:var(--cream);
}
.badge-idea{background:var(--green);}
.badge-story{background:var(--walnut);}
.badge-reply{background:var(--saffron);color:#3a2a0c;}
.card-cat{font-size:13px;color:var(--ink-soft);font-weight:500;text-align:right;}
.card-body{
  padding:4px 18px 14px;overflow-y:auto;flex:1 1 auto;-webkit-overflow-scrolling:touch;
  touch-action:pan-y;
}
.card-quote{
  font-family:"Fraunces",Georgia,serif;font-weight:500;font-size:21px;line-height:1.42;
  margin:6px 0 16px;color:var(--ink);
}
.card-meta{display:flex;flex-direction:column;gap:7px;font-size:14px;color:var(--ink-soft);}
.card-meta .row{display:flex;gap:8px;align-items:baseline;}
.card-meta .k{font-weight:600;color:var(--ink);min-width:78px;flex:0 0 auto;}
.card-meta a{color:var(--green-deep);font-weight:600;text-decoration:none;}
.card-meta a:hover{text-decoration:underline;}
.card-foot{
  padding:10px 18px;border-top:1px solid var(--line);
  font-size:12px;color:var(--ink-soft);display:flex;justify-content:space-between;gap:10px;
}

/* stamps */
.stamp{
  position:absolute;top:22px;font-family:"Fraunces",Georgia,serif;font-weight:700;
  font-size:30px;letter-spacing:1px;padding:6px 14px;border-radius:10px;border:3px solid;
  opacity:0;transition:opacity .05s linear;pointer-events:none;text-transform:uppercase;
}
.stamp-yes{left:18px;color:var(--green);border-color:var(--green);transform:rotate(-12deg);}
.stamp-no{right:18px;color:var(--brick);border-color:var(--brick);transform:rotate(12deg);}

/* ---------- controls ---------- */
.controls{
  flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:14px;
  padding-bottom:max(4px, env(safe-area-inset-bottom));
}
.ctl{
  appearance:none;border:0;cursor:pointer;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);transition:transform .08s ease, filter .15s ease;
  font-size:24px;line-height:1;color:var(--cream);
}
.ctl:active{transform:scale(.9);}
.ctl:disabled{opacity:.4;cursor:default;}
.ctl-reject{width:62px;height:62px;background:var(--brick);font-size:26px;}
.ctl-approve{width:62px;height:62px;background:var(--green);font-size:26px;}
.ctl-skip{width:50px;height:50px;background:var(--saffron);color:#4a3410;}
.ctl-undo{width:50px;height:50px;background:var(--cream);color:var(--ink-soft);border:1px solid var(--line);box-shadow:none;}

.hint{flex:0 0 auto;font-size:12.5px;color:var(--ink-soft);text-align:center;margin:0;}

/* ---------- empty / loading ---------- */
.empty,.loading{
  flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;text-align:center;padding:30px;color:var(--ink-soft);
}
.empty-check{
  width:64px;height:64px;border-radius:50%;background:var(--green);color:var(--cream);
  display:inline-flex;align-items:center;justify-content:center;font-size:34px;
}
.empty h2{font-family:"Fraunces",Georgia,serif;font-weight:600;color:var(--ink);margin:0;font-size:22px;}
.empty p{margin:0;}
.empty .btn{width:auto;margin-top:6px;}
.spinner{
  width:34px;height:34px;border-radius:50%;
  border:3px solid var(--line);border-top-color:var(--green);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));transform:translateX(-50%);
  background:var(--ink);color:var(--cream);padding:11px 18px;border-radius:12px;
  font-size:14px;font-weight:500;z-index:40;box-shadow:var(--shadow);
  max-width:90vw;text-align:center;opacity:0;transition:opacity .2s ease, transform .2s ease;
  pointer-events:none;
}
.toast.show{opacity:1;}
.toast.err{background:var(--brick-deep);}
