/* Crew Slot Marketplace — server-rendered, no client JS */
:root{
  --ink:#0A0F1C; --panel:#111A2E; --line:#243049; --soft:#E9EDF6; --muted:#8492AD;
  --amber:#FFB020; --teal:#34D0B4; --cyan:#5BC8FF; --rose:#FB7185;
}
*{box-sizing:border-box}
html{background:var(--ink)}
body{
  margin:0; color:var(--soft); background:var(--ink);
  font-family:"Noto Sans Thai",Inter,system-ui,-apple-system,sans-serif;
  font-size:15px; line-height:1.5; -webkit-text-size-adjust:100%;
}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(60% 40% at 50% -10%,rgba(255,176,32,.10),transparent 70%)}
a{color:inherit;text-decoration:none}
.mono{font-family:"IBM Plex Mono",ui-monospace,monospace}
::selection{background:var(--amber);color:var(--ink)}
.wrap{position:relative;z-index:1;max-width:720px;margin:0 auto;padding:0 16px 110px}

/* header */
.header{position:sticky;top:0;z-index:20;background:rgba(10,15,28,.85);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header .bar{max-width:720px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:18px;letter-spacing:-.01em}
.logo{display:grid;place-items:center;width:28px;height:28px;border-radius:6px;background:var(--amber);color:var(--ink);font-weight:700;font-size:14px}
.brand .slot{color:var(--amber)}
.brand .mk{font-size:10px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-left:4px}
.usr{display:flex;align-items:center;gap:8px}
.usr a.who{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:4px 12px 4px 4px;font-size:14px;color:var(--soft)}
.usr a.out{color:var(--muted);font-size:14px;padding:6px}

/* tabs (desktop) */
.tabs{max-width:720px;margin:0 auto;padding:8px 16px 0;display:none;gap:4px}
@media(min-width:640px){.tabs{display:flex}}
.tabs a{position:relative;border-radius:999px;padding:6px 16px;font-size:14px;color:var(--muted)}
.tabs a.on{border:1px solid var(--line);background:var(--panel);color:var(--soft)}

/* bottom nav (mobile) */
.bnav{position:fixed;inset:auto 0 0 0;z-index:20;border-top:1px solid var(--line);
  background:rgba(10,15,28,.96);backdrop-filter:blur(8px)}
@media(min-width:640px){.bnav{display:none}}
.bnav .row{max-width:720px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr)}
.bnav a{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 0;font-size:11px;color:var(--muted)}
.bnav a.on{color:var(--amber)}
.bnav .ic{font-size:18px;line-height:1}
.badge{position:absolute;top:2px;right:24%;min-width:16px;height:16px;display:grid;place-items:center;
  padding:0 4px;border-radius:999px;background:var(--rose);color:var(--ink);font-size:10px;font-weight:700}
.tabs .badge{top:-2px;right:6px}

main{padding-top:16px}

/* cards & bits */
.card{border:1px solid var(--line);background:var(--panel);border-radius:14px;padding:14px}
.muted{color:var(--muted)}
.small{font-size:13px}
.h2{font-size:18px;font-weight:600;margin:0 0 10px}
.sec-h{display:flex;align-items:flex-end;gap:8px;margin:18px 0 0}
.sec-h .n{font-family:"IBM Plex Mono",monospace;font-weight:600;color:var(--amber)}
.sec-h .t{font-size:16px;font-weight:600;color:#fff}
.rule{height:1.5px;background:var(--amber);opacity:.5;margin:6px 0 12px;border:0}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{display:inline-block;border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:6px 12px;font-size:12px}
.chip.on{background:var(--amber);color:var(--ink);border-color:var(--amber);font-weight:500}

/* side cards */
.sides{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.side{border:1px solid var(--line);background:var(--panel);border-radius:16px;padding:16px}
.side .ttl{font-size:18px;font-weight:600;color:var(--soft)}
.side .sub{font-size:12px;color:var(--muted);margin-top:2px}
.side.offer.on{border-color:var(--amber);background:rgba(255,176,32,.10)}
.side.offer.on .ttl,.side.offer.on .sub{color:var(--amber)}
.side.want.on{border-color:var(--cyan);background:rgba(91,200,255,.10)}
.side.want.on .ttl,.side.want.on .sub{color:var(--cyan)}
.sub-row{display:flex;align-items:center;justify-content:space-between;padding:8px 4px 0}
.sub-row .l{font-size:12px}
.sub-row .l.on{color:var(--amber)} .sub-row .l.off{color:var(--muted)}
.note-neutral{font-size:11px;color:var(--muted)}

/* segmented + filter card */
.seg{display:flex;border:1px solid var(--line);border-radius:10px;padding:2px;margin-bottom:12px}
.seg a{flex:1;text-align:center;padding:7px 0;border-radius:8px;font-size:14px;color:var(--muted)}
.seg a.on{background:var(--amber);color:var(--ink);font-weight:500}
.daterow{display:flex;gap:8px;margin-bottom:12px}
input[type=date],input[type=number],input[type=text],input[type=email],input[type=password],select,textarea{
  width:100%;border:1px solid var(--line);background:rgba(10,15,28,.6);color:var(--soft);
  border-radius:10px;padding:9px 12px;font-size:14px;font-family:inherit;color-scheme:dark}
input.mono{font-family:"IBM Plex Mono",monospace}
textarea{resize:vertical}
.field{margin-bottom:14px}
.field>label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* buttons */
.btn{display:inline-block;border:0;border-radius:10px;padding:10px 16px;font-size:15px;font-family:inherit;cursor:pointer}
.btn-amber{width:100%;background:var(--amber);color:var(--ink);font-weight:500}
.btn-line{border:1px solid var(--line);background:transparent;color:var(--muted)}
.btn-sm{padding:7px 12px;font-size:13px}

/* board rows */
.day-h{display:flex;align-items:center;gap:8px;margin:0 0 8px}
.day-h .d{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.day-h .ln{flex:1;height:1px;background:var(--line)}
.day-h .c{font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--muted)}
.rows{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:20px}
.row{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row:nth-child(odd){background:rgba(255,255,255,.015)}
.code{display:grid;place-items:center;width:48px;flex:none;background:rgba(10,15,28,.7);border-radius:6px;
  padding:5px 0;font-family:"IBM Plex Mono",monospace;font-size:11px;font-weight:600;color:var(--soft)}
.row .mid{min-width:0;flex:1}
.row .mid .l1{display:flex;align-items:center;gap:8px}
.row .mid .nm{font-size:14px;color:var(--soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .mid .l2{display:flex;align-items:center;gap:6px;margin-top:4px}
.row .mid .who{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .rt{flex:none;text-align:right}
.row .rt .pr{font-family:"IBM Plex Mono",monospace;font-size:14px;font-weight:600;color:var(--soft)}
.tag{flex:none;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:500}
.tag.offer{background:rgba(255,176,32,.12);color:var(--amber)}
.tag.want{background:rgba(91,200,255,.12);color:var(--cyan)}
.pill{display:inline-block;border:1px solid var(--line);border-radius:5px;padding:2px 6px;font-size:10px;margin-top:3px}
.st-av{color:var(--teal);border-color:rgba(52,208,180,.4);background:rgba(52,208,180,.1)}
.st-rs{color:var(--amber);border-color:rgba(255,176,32,.4);background:rgba(255,176,32,.1)}
.st-dn{color:var(--muted);background:rgba(255,255,255,.05)}
.st-cx{color:var(--muted);text-decoration:line-through}
.det{border-top:1px solid var(--line);background:rgba(10,15,28,.4);padding:12px;font-size:13px}
.det .ac{display:inline-block;border:1px solid var(--line);border-radius:4px;padding:2px 6px;
  font-family:"IBM Plex Mono",monospace;font-size:10px;color:var(--muted);margin:0 4px 4px 0}

/* avatar */
.av{flex:none;border-radius:50%;border:1px solid var(--line);object-fit:cover;background:rgba(10,15,28,.7);
  display:inline-grid;place-items:center;color:var(--muted)}

/* calendar */
.cal-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-h .m{font-weight:600;font-size:14px}
.cal-h a{border:1px solid var(--line);border-radius:8px;padding:4px 12px;color:var(--soft)}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.cal .wd{padding:4px 0;font-size:11px;color:var(--muted)}
.cal .cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;border-radius:10px;
  border:1px solid transparent;padding:4px 2px;font-size:12px;color:var(--soft)}
.cal .cell.has{border-color:var(--line);background:rgba(10,15,28,.4)}
.cal .cell .t{font-size:12px}
.cal .cell .t.today{color:var(--amber);font-weight:700}
.cal .cell .dots{margin-top:auto;display:flex;align-items:center;gap:3px}
.dot{width:6px;height:6px;border-radius:50%}.dot.a{background:var(--amber)}.dot.c{background:var(--cyan)}
.cal .cell .num{font-family:"IBM Plex Mono",monospace;font-size:10px;color:var(--muted)}
.cal-legend{display:flex;gap:16px;justify-content:center;margin-top:12px;font-size:11px;color:var(--muted)}
.cal-legend span{display:flex;align-items:center;gap:4px}

/* prices */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:640px){.price-grid{grid-template-columns:1fr 1fr 1fr}}
.pcard{border:1px solid var(--line);background:var(--panel);border-radius:14px;padding:12px}
.pcard.on{border-color:rgba(255,176,32,.6);background:rgba(255,176,32,.05)}
.pcard .top{display:flex;align-items:center;justify-content:space-between}
.pcard .nm{font-size:12px;color:var(--soft)}
.pcard .avg{font-family:"IBM Plex Mono",monospace;font-size:16px;font-weight:600;margin-top:4px}
.pcard .n{font-family:"IBM Plex Mono",monospace;font-size:10px;color:var(--muted)}
.trend{font-family:"IBM Plex Mono",monospace;font-size:11px}
.trend.up{color:var(--rose)}.trend.down{color:var(--teal)}.trend.flat{color:var(--muted)}
.stat3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px;text-align:center}
.stat3 .b{border:1px solid var(--line);background:rgba(10,15,28,.4);border-radius:10px;padding:8px}
.stat3 .v{font-family:"IBM Plex Mono",monospace;font-weight:600}
.stat3 .k{font-size:10px;color:var(--muted)}

/* callout / empty / flash */
.callout{border:1px solid var(--line);border-left:3px solid var(--amber);background:rgba(255,176,32,.08);
  border-radius:10px;padding:10px 12px;font-size:13px;margin:10px 0}
.callout.warn{border-left-color:var(--rose);background:rgba(251,113,133,.08)}
.empty{border:1px dashed var(--line);background:rgba(17,26,46,.4);border-radius:14px;padding:36px 16px;text-align:center}
.empty .t{color:var(--soft)} .empty .s{color:var(--muted);font-size:14px;margin-top:4px}
.flash{border-radius:10px;padding:10px 12px;font-size:14px;margin-bottom:14px}
.flash.ok{border:1px solid rgba(52,208,180,.4);color:var(--teal);background:rgba(52,208,180,.08)}
.flash.err{border:1px solid rgba(251,113,133,.4);color:var(--rose);background:rgba(251,113,133,.08)}
.flash.warn{border:1px solid rgba(255,176,32,.4);color:var(--amber);background:rgba(255,176,32,.08)}

/* mine listing controls */
.mine-item{border:1px solid var(--line);background:var(--panel);border-radius:14px;padding:12px;margin-bottom:8px}
.mine-item .top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.mine-ctrls{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px}
.mine-ctrls form{display:flex;align-items:center;gap:6px;margin:0}
.inline-price{width:96px}
.inline-status{width:auto;padding:6px 8px}

/* auth */
.auth-tabs{display:flex;gap:8px;margin-bottom:14px}
.auth-tabs a{flex:1;text-align:center;border-radius:10px;padding:9px 0;font-size:14px;border:1px solid var(--line);color:var(--muted)}
.auth-tabs a.on{background:var(--amber);color:var(--ink);border-color:var(--amber)}

/* welcome */
.welcome{max-width:420px;margin:8vh auto 0;border:1px solid rgba(255,176,32,.4);border-radius:18px;overflow:hidden;text-align:center}
.welcome .hd{background:linear-gradient(to bottom,rgba(255,176,32,.15),transparent);padding:32px 24px 8px}
.welcome .em{font-size:40px}
.welcome .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--amber);margin-top:10px}
.welcome .big{font-size:30px;font-weight:700;margin:8px 0 0}
.welcome .bd{padding:16px 24px 24px}
.welcome .bd p{color:var(--muted);font-size:14px}

/* cover band (setup page) */
.setup{max-width:560px;margin:16vh auto 0;text-align:center;padding:24px}
.setup .em{font-size:40px}.setup h1{font-size:20px;margin:.5em 0}.setup p{color:var(--muted);line-height:1.7}
.setup code{color:var(--amber)}

/* native <details> rows (no JS) */
details>summary{list-style:none;cursor:pointer}
details>summary::-webkit-details-marker{display:none}
.rows>details{border-bottom:1px solid var(--line)}
.rows>details:last-child{border-bottom:0}
.rows>details:nth-child(odd){background:rgba(255,255,255,.015)}
summary.row{border-bottom:0}
details[open]>summary.row{background:rgba(255,255,255,.02)}

/* toast (lite) */
.toast{position:fixed;left:50%;bottom:88px;transform:translateX(-50%);z-index:60;border-radius:999px;
  padding:10px 16px;font-size:14px;border:1px solid;background:var(--panel);box-shadow:0 8px 24px rgba(0,0,0,.4)}
@media(min-width:640px){.toast{bottom:24px}}
.toast.ok{border-color:rgba(52,208,180,.5);color:var(--teal)}
.toast.err{border-color:rgba(251,113,133,.5);color:var(--rose)}
.toast.warn{border-color:rgba(255,176,32,.5);color:var(--amber)}
#view:empty::after{content:"กำลังโหลด…";display:block;text-align:center;color:var(--muted);padding:40px}

/* LINE contact link */
.line-link{display:inline-flex;align-items:center;gap:6px;color:#06C755;font-weight:600;text-decoration:none}
.line-badge{display:inline-grid;place-items:center;background:#06C755;color:#04331a;font-size:9px;font-weight:800;
  letter-spacing:.03em;padding:2px 5px;border-radius:5px;line-height:1}

/* ticker (ตัวหนังสือวิ่งประกาศระบบ) */
.ticker{overflow:hidden;background:rgba(255,176,32,.10);border-bottom:1px solid var(--line)}
.ticker-track{display:inline-flex;white-space:nowrap;animation:ticker 24s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{padding:8px 40px;color:var(--amber);font-size:14px;font-weight:500}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}.ticker-track span:last-child{display:none}}
