:root{
  --yellow:#ffd166; --green:#06d6a0; --blue:#118ab2;
  --pink:#ef476f; --purple:#9b5de5; --ink:#14141a; --paper:#f5f5f8;
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-top:env(safe-area-inset-top,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  margin:0;font-family:"Trebuchet MS",system-ui,-apple-system,sans-serif;
  background:var(--paper);color:var(--ink);min-height:100vh;
}
.hidden{display:none !important}
.muted{color:#6b6b76}.small{font-size:12px}
.lbl{display:block;font-weight:700;margin:14px 0 6px;font-size:14px}
.err{color:var(--pink);font-weight:700;margin-top:10px;text-align:center}
.center{text-align:center}
.fineprint{font-size:12px;color:#7a7a85;margin-top:14px;text-align:center;line-height:1.5}
.logo{font-family:Impact,"Arial Black",sans-serif;font-size:62px;line-height:1;
  letter-spacing:2px;text-shadow:3px 3px 0 #fff}

input,textarea{
  width:100%;border:2.5px solid var(--ink);border-radius:12px;padding:12px;
  font-size:16px;font-family:inherit;background:#fff;
}
textarea{resize:vertical}
input[type="file"]{display:block;width:100%;padding:14px;border:2.5px dashed var(--ink);
  border-radius:12px;background:#fff;font-family:inherit;font-size:14px;cursor:pointer}

.btn{display:inline-block;text-align:center;cursor:pointer;border:2.5px solid var(--ink);
  background:var(--green);color:var(--ink);font-weight:800;font-size:16px;
  padding:13px 18px;border-radius:12px;box-shadow:3px 3px 0 var(--ink);
  text-decoration:none;transition:transform .05s;font-family:inherit}
.btn:active{transform:translate(3px,3px);box-shadow:0 0 0 var(--ink)}
.btn.big{width:100%;margin-top:16px;font-size:19px;background:var(--pink);color:#fff}
.btn.ghost{background:#fff}
.btn.gold{background:var(--yellow)}
.btn.full{width:100%;margin-top:14px}
.row{display:flex;gap:10px;margin-top:14px}
.row .btn{flex:1}

.card{background:#fff;border:3px solid var(--ink);border-radius:18px;
  padding:18px;margin-bottom:16px;box-shadow:5px 5px 0 var(--ink)}
.pill{display:inline-block;background:#fff;border:2.5px solid var(--ink);
  border-radius:999px;padding:5px 13px;font-weight:800;font-size:14px;box-shadow:2px 2px 0 var(--ink)}

/* ---------- AUTH ---------- */
.auth-screen{min-height:100vh;display:flex;flex-direction:column;
  background:linear-gradient(160deg,var(--yellow),var(--pink) 60%,var(--purple));
  padding:calc(28px + var(--safe-top)) 20px 28px}
.auth-hero{text-align:center;color:var(--ink);margin:18px 0 24px}
.auth-tag{font-size:22px;margin:14px 0 4px;font-weight:700;line-height:1.3}
.auth-tag b{color:#fff;text-shadow:2px 2px 0 var(--ink)}
.auth-sub{font-size:15px;opacity:.9;margin:4px 0 0}
.auth-card{background:#fff;border:3px solid var(--ink);border-radius:20px;
  padding:22px;box-shadow:6px 6px 0 var(--ink);max-width:460px;width:100%;margin:0 auto}
.seg{display:flex;gap:0;border:2.5px solid var(--ink);border-radius:12px;overflow:hidden;margin-bottom:6px}
.seg-btn{flex:1;border:0;background:#fff;padding:12px;font-weight:800;font-family:inherit;
  font-size:15px;cursor:pointer;color:var(--ink)}
.seg-btn.active{background:var(--purple);color:#fff}

/* ---------- APP SHELL ---------- */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  background:var(--yellow);border-bottom:3px solid var(--ink);
  padding:calc(10px + var(--safe-top)) 16px 10px}
.brand{font-family:Impact,"Arial Black",sans-serif;font-size:30px;letter-spacing:1px}
#main{max-width:560px;margin:0 auto;padding:16px 16px calc(96px + var(--safe-bottom))}
.tab-title{font-size:24px;margin:4px 0 16px}
.sec-title{font-size:17px;margin:22px 0 12px}
.nudge-note{margin:-4px 0 8px}

/* output + visibility toggles */
.toggle{display:flex;gap:8px;margin-top:6px}
.toggle .opt,.toggle .vopt{flex:1;cursor:pointer;border:2.5px solid var(--ink);background:#fff;
  border-radius:12px;padding:11px;font-weight:800;font-family:inherit;font-size:14px}
.toggle .opt.active{background:var(--purple);color:#fff;box-shadow:3px 3px 0 var(--ink)}
.toggle.vis .vopt{font-size:13px;padding:10px 4px}
.toggle.vis .vopt.active{background:var(--blue);color:#fff;box-shadow:3px 3px 0 var(--ink)}

/* length pick */
.len-block{margin-top:6px}
.chips-pick{display:flex;gap:8px}
.chips-pick .pickc{flex:1;cursor:pointer;border:2.5px solid var(--ink);background:#fff;
  border-radius:12px;padding:12px 4px;font-weight:800;font-family:inherit;font-size:15px;text-align:center}
.chips-pick .pickc.active{background:var(--green);box-shadow:3px 3px 0 var(--ink)}
.chips-pick .pickc.rec{position:relative}
.chips-pick .pickc.rec::after{content:"★";position:absolute;top:-9px;right:-4px;font-size:14px;color:var(--pink)}
.rec-line{margin:10px 0 0;font-weight:800;font-size:13px;color:var(--purple)}

/* progress */
.progress{width:100%;height:14px;background:#eee;border:2.5px solid var(--ink);
  border-radius:999px;overflow:hidden;margin:14px 0 8px}
.progress-bar{height:100%;width:2%;background:var(--green);transition:width .4s ease}
.spinner{width:48px;height:48px;border:6px solid #eee;border-top-color:var(--pink);
  border-radius:50%;margin:6px auto 10px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.comic{width:100%;border:3px solid var(--ink);border-radius:12px;margin:10px 0;display:block}
video.comic{background:#000}
.upsell{margin-top:16px;padding-top:14px;border-top:2px dashed #ccc;text-align:center}

.thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.thumbs .thumb{position:relative;width:68px;height:68px;border:2.5px solid var(--ink);
  border-radius:10px;overflow:hidden;background:#000}
.thumbs .thumb img,.thumbs .thumb video{width:100%;height:100%;object-fit:cover;display:block}
.thumbs .thumb .x{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;
  background:#000;color:#fff;font-size:12px;line-height:18px;text-align:center;cursor:pointer;
  border:2px solid #fff;font-weight:900}

/* ---------- FEED CARDS ---------- */
.feed{display:flex;flex-direction:column;gap:16px}
.post{background:#fff;border:3px solid var(--ink);border-radius:18px;overflow:hidden;
  box-shadow:4px 4px 0 var(--ink)}
.post .phead{display:flex;align-items:center;gap:10px;padding:12px 14px}
.avatar{width:38px;height:38px;border-radius:50%;border:2.5px solid var(--ink);object-fit:cover;
  background:var(--yellow);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px}
.pname{font-weight:800;font-size:15px;line-height:1.1}
.phandle{font-size:12px;color:#7a7a85}
.post .pmedia{width:100%;display:block;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);background:#000}
.post .pcap{padding:10px 14px 4px;font-size:14px}
.post .pacts{display:flex;align-items:center;gap:14px;padding:8px 14px 14px}
.like-btn{cursor:pointer;border:0;background:none;font-size:20px;font-family:inherit;font-weight:800;
  display:flex;align-items:center;gap:6px;color:var(--ink)}
.like-btn.liked{color:var(--pink)}
.like-btn .lc{font-size:14px}
.share-btn{cursor:pointer;border:0;background:none;font-size:18px}
.feed-empty{text-align:center;color:#7a7a85;padding:30px 10px;font-size:15px}
.feed-empty b{display:block;font-size:18px;color:var(--ink);margin-bottom:6px}

/* friend request rows */
.req-row{display:flex;align-items:center;gap:10px;background:#fff;border:2.5px solid var(--ink);
  border-radius:14px;padding:10px 12px;margin-bottom:10px;box-shadow:3px 3px 0 var(--ink)}
.req-row .pname{flex:1}

/* ---------- PROFILE ---------- */
.profile-head{background:#fff;border:3px solid var(--ink);border-radius:18px;padding:20px;
  text-align:center;box-shadow:5px 5px 0 var(--ink);margin-bottom:16px}
.profile-head .big-av{width:84px;height:84px;border-radius:50%;border:3px solid var(--ink);
  margin:0 auto 10px;object-fit:cover;background:var(--purple);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:900;font-size:34px}
.profile-head h2{margin:4px 0 2px;font-size:22px}
.profile-head .ph{color:#7a7a85;font-size:14px}
.profile-head .bio{margin:10px 0 0;font-size:14px}
.profile-head .stats{display:flex;justify-content:center;gap:24px;margin:14px 0 4px;font-size:13px}
.profile-head .stats b{display:block;font-size:18px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid .gcell{position:relative;border:2.5px solid var(--ink);border-radius:12px;overflow:hidden;
  background:#000;aspect-ratio:1;box-shadow:3px 3px 0 var(--ink)}
.grid .gcell img,.grid .gcell video{width:100%;height:100%;object-fit:cover;display:block}
.grid .gcell .vis-tag{position:absolute;top:5px;left:5px;font-size:11px;background:#000c;color:#fff;
  padding:2px 6px;border-radius:6px;font-weight:700}
.grid-empty{grid-column:1/-1;text-align:center;color:#7a7a85;padding:24px 8px}

/* ---------- BOTTOM NAV ---------- */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;
  background:#fff;border-top:3px solid var(--ink);padding-bottom:var(--safe-bottom)}
.nav-btn{flex:1;border:0;background:none;font-family:inherit;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 0 8px;
  font-size:11px;font-weight:800;color:#9a9aa3}
.nav-btn span{font-size:22px;line-height:1}
.nav-btn.active{color:var(--purple)}
.toast{position:fixed;left:50%;bottom:calc(80px + var(--safe-bottom));transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:10px 18px;border-radius:999px;font-weight:700;
  font-size:14px;z-index:50;box-shadow:0 4px 14px #0005;opacity:0;transition:opacity .25s;pointer-events:none}
.toast.show{opacity:1}
