/* =====================================================================
   CrewMeet — design „Aurora Ops” (oklch, Space Grotesk + JetBrains Mono)
   Zgodny z makietą: gradienty cyan->niebieski, karty 16px, dane monospace.
   ===================================================================== */
:root{
  --bg:oklch(0.135 0.018 255);
  --card:oklch(0.205 0.025 255);
  --card-2:oklch(0.18 0.022 255);
  --card-3:oklch(0.19 0.022 255);
  --inp:oklch(0.155 0.02 255);
  --line:oklch(0.32 0.03 255 / 0.5);
  --line-2:oklch(0.34 0.03 255 / 0.6);
  --line-soft:oklch(0.3 0.03 255 / 0.32);
  --text:oklch(0.96 0.01 250);
  --text-dim:oklch(0.68 0.02 250);
  --text-muted:oklch(0.6 0.02 250);
  --text-faint:oklch(0.5 0.02 250);
  --head:oklch(0.62 0.03 255);
  --brand-a:oklch(0.84 0.12 195);
  --brand-b:oklch(0.66 0.16 258);
  --ink:oklch(0.14 0.02 255);
  --go:oklch(0.78 0.12 165);
  --go-bright:oklch(0.86 0.1 165);
  --go-soft:oklch(0.24 0.04 165);
  --go-line:oklch(0.4 0.08 165 / 0.6);
  --hold:oklch(0.80 0.1 80);
  --hold-soft:oklch(0.24 0.04 80);
  --data:oklch(0.95 0.02 200);
  --danger:oklch(0.66 0.16 18);
  --r-sm:7px; --r:10px; --r-md:13px; --r-lg:16px; --r-xl:22px;
  --shadow:0 18px 50px -14px oklch(0.05 0.02 255 / 0.7);
  --grad:linear-gradient(135deg,var(--brand-a),var(--brand-b));
  --glow:0 4px 14px oklch(0.66 0.16 258 / 0.28);
  --font:'Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  background:radial-gradient(1100px 560px at 50% -240px, oklch(0.30 0.07 230 / 0.45), transparent 70%), var(--bg);
  background-attachment:fixed;
}
::selection{background:oklch(0.80 0.13 195 / 0.30)}
::-webkit-scrollbar{height:10px;width:10px}
::-webkit-scrollbar-thumb{background:oklch(0.32 0.03 255);border-radius:8px;border:2px solid var(--bg)}
.hidden{display:none !important}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* kontrolki */
button{font-family:inherit;cursor:pointer}
.btn{background:var(--grad);color:var(--ink);border:none;border-radius:var(--r);padding:11px 20px;
  font-weight:700;font-size:14px;box-shadow:var(--glow);transition:transform .12s,filter .12s}
.btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.5;cursor:default;filter:none;transform:none}
.btn.sec{background:oklch(0.24 0.025 255);color:oklch(0.92 0.01 250);border:1px solid var(--line-2);box-shadow:none;font-weight:600}
.btn.sec:hover{filter:brightness(1.12)}
.btn.ghost{background:transparent;color:var(--text-dim);border:1px solid var(--line-2);box-shadow:none;font-weight:600}
.btn.ghost:hover{color:var(--text);border-color:var(--brand-a)}
.btn.sm{padding:8px 14px;font-size:13px}
.btn.danger{background:none;border:none;color:var(--danger);box-shadow:none;font-size:18px;line-height:1;padding:2px 6px}
.btn.danger:hover{filter:brightness(1.2)}
.btn.block{width:100%}

input,select{background:var(--inp);border:1px solid var(--line-2);color:var(--text);border-radius:var(--r);
  padding:11px 14px;font-size:15px;font-family:inherit;outline:none;width:100%;font-weight:500;
  transition:border-color .12s,box-shadow .12s;color-scheme:dark}
input::placeholder{color:var(--text-faint)}
input:focus,select:focus{border-color:var(--brand-a);box-shadow:0 0 0 3px oklch(0.80 0.12 200 / 0.16)}
select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%2390a0b8' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
label.fld{display:block;font:600 11px var(--font);letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-muted);margin:0 0 8px 2px}
/* dane „jak na tablicy” — mono */
table.roster input[data-f="3"],table.roster input[data-f="5"]{font-family:var(--mono);font-weight:600;text-transform:uppercase}
table.roster input[data-f="0"],table.roster input[data-f="4"],table.roster input[data-f="6"]{font-family:var(--mono);font-variant-numeric:tabular-nums}
input[type=range]{-webkit-appearance:none;appearance:none;height:6px;border-radius:6px;background:oklch(0.3 0.03 255);padding:0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--grad);cursor:pointer;border:3px solid var(--bg);box-shadow:0 0 0 1px oklch(0.5 0.06 220)}
input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--brand-a);cursor:pointer;border:3px solid var(--bg)}

/* ===================== AUTH ===================== */
#auth{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.login-card{width:100%;max-width:430px;position:relative;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r-xl);padding:34px 32px;box-shadow:var(--shadow);overflow:hidden}
.login-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-a),var(--brand-b),transparent)}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:42px;height:42px;border-radius:12px;background:var(--grad);display:flex;align-items:center;
  justify-content:center;font-size:21px;color:var(--ink);box-shadow:0 4px 14px oklch(0.66 0.16 258 / 0.3)}
.brand h1{font-size:22px;margin:0;letter-spacing:-.02em;font-weight:700}
.brand .sub{font-size:12px;color:var(--text-dim)}
.authtabs{display:flex;gap:5px;margin:24px 0 18px;background:var(--inp);padding:4px;border-radius:var(--r-md);border:1px solid var(--line)}
.authtabs button{flex:1;background:transparent;border:0;color:var(--text-dim);font-weight:600;font-size:13.5px;padding:10px;border-radius:9px;transition:.14s}
.authtabs button.active{background:oklch(0.26 0.03 255);color:var(--text)}
form.authform{display:flex;flex-direction:column;gap:14px}
.msg{font-size:13px;min-height:16px;line-height:1.5;font-weight:500}
.msg.err{color:var(--danger)}
.msg.ok{color:var(--go)}
.hint{margin-top:18px;font-size:12.5px;color:var(--text-dim);background:var(--inp);border:1px solid var(--line-soft);
  border-radius:var(--r-md);padding:13px 14px;line-height:1.6}
.hint b{color:var(--text);font-weight:600}
.hint code{font-family:var(--mono);background:oklch(0.12 0.02 255);border:1px solid var(--line);border-radius:6px;
  padding:1px 6px;font-size:11.5px;color:var(--brand-a)}

/* ===================== SHELL ===================== */
#app{max-width:1180px;margin:0 auto;padding:0 24px 24px}
header.top{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);background:oklch(0.15 0.02 255 / 0.82);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:13px 24px;margin:0 -24px 32px}
header .brand .logo{width:38px;height:38px;border-radius:11px;font-size:19px}
header .brand h1{font-size:19px;letter-spacing:-.015em}
nav.tabs{display:flex;gap:4px;background:oklch(0.18 0.02 255);border:1px solid var(--line);border-radius:var(--r-md);padding:4px}
nav.tabs button{background:transparent;border:0;color:var(--text-dim);font-weight:600;font-size:14px;padding:9px 17px;border-radius:9px;transition:.14s}
nav.tabs button.active{color:var(--text);background:oklch(0.26 0.03 255)}
nav.tabs button:hover{color:var(--text)}
.spacer{flex:1}
.whoami{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted)}
.whoami #whoEmail{font-family:var(--mono);font-size:12.5px;color:var(--text-muted)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--grad);display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:14px;color:var(--ink);text-transform:uppercase}

.page{animation:cmFade .35s ease both}
@keyframes cmFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
h2.title{font-size:31px;margin:4px 0 7px;letter-spacing:-.02em;font-weight:700}
p.lead{color:var(--text-dim);margin:0 0 26px;font-size:15px;max-width:680px;line-height:1.55}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;margin-bottom:18px}
.card h3{margin:0 0 16px;font:600 12px var(--font);letter-spacing:.14em;text-transform:uppercase;color:var(--head)}
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;align-items:start}
.note{font-size:12.5px;color:var(--text-faint);margin-top:9px;line-height:1.5}
.badge{font-family:var(--mono);font-size:11px;color:var(--go);background:var(--go-soft);border:1px solid var(--go-line);
  border-radius:999px;padding:3px 11px;font-weight:600}

/* PROFIL — avatar/dane */
#pAv,#pName{font-family:var(--font)}
#pEmailTxt{font-family:var(--mono);font-size:13px;color:var(--text-muted)}

/* tabela grafiku */
.tbl-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r-md)}
table.roster{border-collapse:collapse;width:100%;font-size:13px;min-width:760px}
table.roster th{background:var(--card-2);color:var(--text-faint);text-align:left;padding:10px;position:sticky;top:0;
  border-bottom:1px solid var(--line);white-space:nowrap;font:600 10.5px var(--font);letter-spacing:.1em;text-transform:uppercase;z-index:2}
table.roster td{padding:7px 8px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
table.roster tr:last-child td{border-bottom:0}
table.roster tr:hover td{background:oklch(0.66 0.16 258 / 0.05)}
table.roster input,table.roster select{padding:7px 9px;font-size:12.5px;border-radius:var(--r-sm);border-color:var(--line)}
td.day{white-space:nowrap}
td.dow{color:var(--text-faint);font:500 10.5px var(--mono);text-transform:uppercase;letter-spacing:.04em}
.pill{display:inline-block;padding:3px 9px;border-radius:999px;font:700 10px var(--mono);letter-spacing:.06em;text-transform:uppercase}
.pill.flight{background:oklch(0.66 0.16 258 / 0.18);color:oklch(0.82 0.09 250)}
.pill.bus{background:var(--hold-soft);color:var(--hold)}
.pill.off{background:var(--go-soft);color:var(--go-bright)}
.pill.reserve,.pill.standby{background:oklch(0.4 0.02 255 / 0.4);color:oklch(0.78 0.02 250)}
.pill.rest{background:oklch(0.3 0.02 255 / 0.4);color:var(--text-faint)}
.toolbar{display:flex;gap:11px;flex-wrap:wrap;align-items:flex-end;margin-bottom:16px}
.fldwrap{display:flex;flex-direction:column}
.drop{background:oklch(0.165 0.02 255);border:1.5px dashed oklch(0.36 0.03 255 / 0.7);border-radius:var(--r-md);
  padding:26px;color:var(--text-dim);transition:.15s;cursor:pointer;font:500 14.5px var(--font);text-align:center}
.drop:hover{border-color:var(--brand-a);color:var(--text)}
.drop.drag{border-color:var(--brand-a);background:oklch(0.66 0.16 258 / 0.08);color:var(--text)}
.drop u{color:oklch(0.82 0.1 200)}

/* podgląd */
.prev-day{border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:9px;overflow:hidden;background:var(--card-2)}
.prev-day .ph{display:flex;justify-content:space-between;align-items:center;background:oklch(0.22 0.025 255);
  padding:8px 13px;font:500 12px var(--mono);letter-spacing:.02em}
.prev-seg{display:grid;grid-template-columns:62px 1fr 56px 56px;gap:8px;padding:8px 13px;font-size:13px;align-items:center;border-top:1px solid var(--line-soft)}
.prev-seg .rt{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right;color:var(--text-dim)}
.arrow{color:var(--text-faint)}

/* ===================== SPOTKANIA ===================== */
.controls{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-end;margin-bottom:0;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}
.seg{display:flex;gap:4px;background:var(--inp);border:1px solid var(--line);border-radius:var(--r);padding:4px}
.seg button{background:transparent;border:0;color:var(--text-dim);font-weight:600;font-size:13px;padding:9px 15px;border-radius:8px;transition:.14s}
.seg button.active{background:oklch(0.27 0.03 255);color:var(--text)}
.slider{display:flex;align-items:center;gap:10px}
.slider input[type=range]{width:auto;flex:1;min-width:120px}
.slider span{font:500 11px var(--mono);color:var(--text-faint)}
#loadMsg{margin-top:14px;font-weight:500}
.stat{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:18px 0}
.stat .s{background:var(--card-3);border:1px solid var(--line);border-radius:var(--r-md);padding:18px}
.stat .s .n{font:700 28px var(--mono);color:var(--data);line-height:1;font-variant-numeric:tabular-nums}
.stat .s .l{font-size:12.5px;color:var(--text-muted);margin-top:8px;line-height:1.35}

/* karta spotkania — kafel-kod + treść */
.meet-card{display:flex;gap:16px;align-items:stretch;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:16px;margin-bottom:12px}
.meet-card .city{flex:none;width:74px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
.meet-card .city .code{width:64px;height:54px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font:700 19px var(--mono);color:var(--ink);background:var(--go);letter-spacing:.02em}
.meet-card .city .nm{font-size:11px;color:var(--text-muted);margin-top:6px}
.meet-card .body{flex:1;min-width:0}
.meet-card .when{font:700 16px var(--mono);font-variant-numeric:tabular-nums;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.meet-card .when span:last-child{color:oklch(0.8 0.02 250);font-weight:500;font-size:15px}
.meet-card .dur{display:inline-block;margin-top:10px;font:700 11px var(--mono);letter-spacing:.04em;text-transform:uppercase;
  color:var(--go-bright);background:var(--go-soft);border:1px solid var(--go-line);border-radius:999px;padding:4px 11px}
.meet-card .ctx{font-size:13.5px;color:var(--text-dim);margin-top:10px;line-height:1.45}
.nearmiss .city .code{background:var(--hold);color:var(--ink)}
.nearmiss .dur{color:var(--hold);background:var(--hold-soft);border-color:oklch(0.4 0.06 80 / 0.5)}
.empty{padding:30px;text-align:center;color:var(--text-dim);border:1px dashed var(--line);border-radius:var(--r-md);
  background:oklch(0.16 0.02 255);font-size:14px}

/* ranking „ja <-> wszyscy” */
.ov{display:flex;flex-direction:column;gap:12px}
.ov-row{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:15px 18px;flex-wrap:wrap;cursor:pointer;transition:.13s}
.ov-row:hover{border-color:var(--brand-a);transform:translateX(2px)}
.ov-row .rank{flex:none;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font:700 15px var(--mono);background:oklch(0.26 0.03 255);color:var(--text-dim)}
.ov-row.top .rank{background:var(--grad);color:var(--ink)}
.ov-row .who{flex:1;min-width:150px;font-weight:700;font-size:16px}
.ov-row .who small{display:block;font:400 12px var(--mono);color:var(--text-muted);margin-top:2px}
.ov-row .cities{display:flex;gap:6px;flex-wrap:wrap}
.ov-row .cities .cc{font:700 10px var(--mono);color:var(--ink);border-radius:6px;padding:3px 7px}
.ov-row .nums{display:flex;gap:22px;margin-left:auto}
.ov-row .nums .b{text-align:right}
.ov-row .nums .b .v{font:700 18px var(--mono);color:var(--go-bright)}
.ov-row .nums .b .v.alt{color:var(--data)}
.ov-row .nums .b .k{font-size:11px;color:var(--text-muted)}
.ov-row.zero{opacity:.55}
.ov-row.zero .nums .b .v{color:var(--text-faint)}

/* oś czasu (SVG) */
.tl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card-2);padding:6px}
.tl-legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.tl-legend .lg{display:inline-flex;align-items:center;gap:7px;font:500 11.5px var(--font);color:var(--text-dim);
  background:var(--inp);border:1px solid var(--line-soft);border-radius:20px;padding:5px 11px 5px 8px}
.tl-legend .sw{width:11px;height:11px;border-radius:4px;display:inline-block}

/* kalendarz */
.calx{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-md)}
table.cal{border-collapse:collapse;min-width:880px;width:100%;font-size:11px}
table.cal th,table.cal td{border:1px solid var(--line-soft);padding:0;text-align:center}
table.cal th{background:var(--card-2);color:var(--text-faint);padding:6px 0;font:500 10px var(--mono)}
table.cal td{height:36px;width:30px;position:relative;font:700 10px var(--mono)}
table.cal td.rowlbl{width:96px;background:var(--card-2);color:oklch(0.85 0.01 250);font:600 12px var(--font);padding:0 9px;text-align:left}
.cell{display:flex;align-items:center;justify-content:center;height:100%;width:100%;color:oklch(0.8 0.01 250);letter-spacing:.04em}
.cell.share{box-shadow:inset 0 0 0 1.5px var(--go)}
.cell.meet{background:var(--go-soft)}
.cell.near{background:var(--hold-soft)}
.star{position:absolute;top:1px;right:2px;font-size:9px;color:var(--go-bright)}

.foot{text-align:center;padding:30px 24px 40px;color:var(--text-faint);font:400 12.5px var(--mono)}
.spin{display:inline-block;width:13px;height:13px;border:2px solid var(--line);border-top-color:var(--brand-a);
  border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px;margin-right:6px}
@keyframes sp{to{transform:rotate(360deg)}}
:focus-visible{outline:2px solid var(--brand-a);outline-offset:2px}
@media(max-width:640px){
  header.top{padding:12px 16px;margin:0 -16px 24px}
  #app{padding:0 16px 24px}
  nav.tabs button{padding:8px 12px;font-size:13px}
  .whoami #whoEmail{display:none}
  h2.title{font-size:25px}
}
