/* Purpose Crew booking prototype. Phone-first, big and plain for people who are not
   confident with technology. Brand: Lora headings, Karla body, pine/clay/paper. */
:root{
  --paper:#F4EFE6;--paper2:#EDE6D8;--pine:#2F4A3C;--pine-deep:#23382E;
  --clay:#C36A4B;--clay-dark:#a8543a;--charcoal:#2A2723;--sage:#8FA48B;
  --good:#3f7d52;--line:rgba(47,74,60,.16);
  --serif:"Lora",Georgia,serif;--sans:"Karla",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--charcoal);font-family:var(--sans);font-size:18px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--serif);color:var(--pine);margin:0}
h1{font-size:1.7rem;line-height:1.15}
h2{font-size:1.25rem}
h3{font-size:1.1rem}
p{margin:0 0 .7em}
a{color:var(--clay-dark)}
.wrap{max-width:640px;margin:0 auto;padding:0 18px}

/* App header */
.appbar{background:var(--pine-deep);color:#eae3d6}
.appbar .in{max-width:640px;margin:0 auto;padding:14px 18px;display:flex;align-items:center;gap:11px;justify-content:space-between}
.appbar .brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.appbar .brand img{width:32px;height:32px}
.appbar .brand span{font-family:var(--serif);font-weight:600;font-size:1.15rem;color:#fff}
.appbar .brand b{color:#f0c9b6;font-weight:600}
.appbar .who{font-size:.9rem;color:#cdd6cc}
.appbar .who a{color:#f0c9b6;text-decoration:none}

/* Buttons: large tap targets */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--clay);color:#fff;border:none;text-decoration:none;font-family:var(--sans);font-weight:700;font-size:1.05rem;padding:15px 22px;border-radius:14px;cursor:pointer;min-height:54px;width:100%;transition:background .15s}
.btn:hover{background:var(--clay-dark)}
.btn:disabled{background:#c7bfae;cursor:default}
.btn.sec{background:var(--pine)}
.btn.sec:hover{background:var(--pine-deep)}
.btn.ghost{background:transparent;color:var(--pine);border:2px solid var(--pine)}
.btn.small{width:auto;font-size:.95rem;padding:11px 16px;min-height:44px;border-radius:11px}
.btn.booked{background:var(--good)}

input,select,textarea{width:100%;font-family:var(--sans);font-size:1.05rem;padding:14px 14px;border:2px solid var(--line);border-radius:12px;background:#fff;color:var(--charcoal)}
input:focus,select,textarea:focus{outline:none;border-color:var(--clay)}
label{display:block;font-weight:700;color:var(--pine);margin:0 0 6px;font-size:.95rem}
.field{margin-bottom:14px}

/* Gate */
.gate{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px}
.gate .mark{width:64px;height:64px;margin-bottom:14px}
.gate .card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 22px;max-width:380px;width:100%;box-shadow:0 14px 40px rgba(35,56,46,.1)}
.gate h1{margin-bottom:.2em}
.gate p{color:#5a554d;font-size:.98rem}

/* Content sections */
.section{padding:22px 0}
.eyebrow{font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--clay);display:block;margin-bottom:.4em}
.muted{color:#6b665e;font-size:.92rem}

/* Tokens banner */
.tokens{background:var(--pine);color:#eae3d6;border-radius:16px;padding:18px 20px;margin:18px 0}
.tokens .big{font-family:var(--serif);font-size:2.2rem;color:#fff;line-height:1;display:flex;align-items:baseline;gap:8px}
.tokens .big small{font-size:1rem;color:#d4ddd2;font-family:var(--sans)}
.tokens .toward{margin-top:8px;font-size:.95rem;color:#d4ddd2}

/* Opportunity cards */
.opp{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;margin:14px 0;box-shadow:0 6px 18px rgba(35,56,46,.05)}
.opp h3{font-size:1.2rem;margin-bottom:.2em}
.opp .meta{font-size:.95rem;color:#3c3833;margin:.3em 0}
.opp .meta b{color:var(--pine)}
.opp .detail{font-size:.96rem;color:#4a453e;margin:.4em 0 .7em}
.reward-tag{display:inline-flex;align-items:center;gap:6px;background:var(--paper2);border-radius:999px;padding:5px 12px;font-size:.9rem;font-weight:600;color:var(--pine);margin:.2em 0 .7em}
.spots{display:flex;align-items:center;gap:10px;margin:.4em 0 .8em}
.spots .bar{flex:1;height:10px;background:#e6ddcd;border-radius:999px;overflow:hidden}
.spots .bar i{display:block;height:100%;background:var(--clay)}
.spots .n{font-size:.88rem;font-weight:700;color:var(--pine);white-space:nowrap}
.spots .full{color:var(--clay-dark)}

/* Rewards menu */
.rewards{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0}
.rw{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:.95rem}
.rw .cost{font-weight:700;color:var(--clay-dark)}
.rw.can{border-color:var(--good);background:#eef5ee}
.rw.can .cost{color:var(--good)}

/* Coordinator */
.tabs{display:flex;gap:8px;margin:14px 0}
.tab{flex:1;text-align:center;padding:11px;border-radius:11px;border:2px solid var(--line);background:#fff;font-weight:700;color:var(--pine);cursor:pointer}
.tab.on{background:var(--pine);color:#fff;border-color:var(--pine)}
.row{background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 16px;margin:12px 0}
.row h3{font-size:1.1rem}
.row .who{font-size:.92rem;color:#3c3833;margin:.35em 0}
.pill{display:inline-block;font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:999px;background:#e7eee6;color:var(--pine);text-transform:uppercase;letter-spacing:.04em}
.pill.closed{background:#f3e0d9;color:var(--clay-dark)}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

.msg{padding:12px 14px;border-radius:12px;margin:12px 0;font-weight:600;font-size:.95rem}
.msg.err{background:#f6e2da;color:var(--clay-dark)}
.msg.ok{background:#eef5ee;color:var(--good)}
.hide{display:none}
.foot{padding:26px 0 40px;text-align:center;color:#8a857c;font-size:.82rem}

/* Print noticeboard */
@media print{
  body{background:#fff;font-size:12pt}
  .noprint{display:none!important}
  .board .opp{box-shadow:none;border:1px solid #999;break-inside:avoid}
  @page{size:A4;margin:14mm}
}
