:root{
  --bg:#111214;
  --card:#f2f2f2;
  --text:#ffffff;
  --muted:#bfbfbf;
  --accent:#e2e2e2;
  --pill:#ffffff;
  --badge:#e8b2b9;
  --brand:#ffffff;
  --shadow:0 2px 10px rgba(0,0,0,.25);
  --radius:14px;
}

:root.theme-light{
  --bg:#f5f6f8;
  --card:#ffffff;
  --text:#121212;
  --muted:#666;
  --accent:#222;
  --pill:#101113;
  --badge:#ffccd2;
  --brand:#101113;
}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;transition:background .2s ease,color .2s ease}

.page{max-width:360px;margin:0 auto;padding:12px}

.top{
  padding:12px;
  background:#1b1c1f;
  border-radius:24px;
  box-shadow:var(--shadow);
}
.app-title{font-weight:700;font-size:20px;margin-bottom:12px}

.stats{display:flex;flex-direction:column;gap:12px;margin:8px 0 6px}
.stat{background:#16171a;border-radius:16px;padding:10px 12px}
.row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.label{color:var(--muted);font-size:12px}
.value{color:var(--brand);font-size:12px}
.bar{height:2px;background:#2b2d33;border-radius:99px;overflow:hidden}
.fill{height:100%;width:0;background:#9e9e9e}

.actions{display:flex;gap:12px;margin:12px 0}
.btn{appearance:none;border:0;background:var(--pill);color:#111;padding:12px 14px;border-radius:14px;box-shadow:var(--shadow);position:relative;flex:1;font-weight:600}
.btn:active{transform:translateY(1px)}
.btn-pill{border-radius:14px}
.badge{position:absolute;right:-6px;top:-6px;background:var(--badge);color:#222;border-radius:999px;padding:4px 7px;font-size:12px;line-height:1;border:2px solid #1b1c1f}

/* segmented removed */

.content{padding:16px 8px}
.section-title{font-size:16px;margin:0 0 10px}

.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.card{background:#1B1B1B;color:#1B1B1B; border:0px solid #1B1B1B;border-radius:14px;padding:14px;display:grid;grid-template-columns:1fr 12px 20px;align-items:center;column-gap:10px;overflow:hidden;box-shadow:inset 0 1px 0 rgba(0, 0, 0, 0)}
.name-wrap{display:flex;align-items:center;gap:8px}
.status-dot{width:10px;height:10px;border-radius:50%;margin:0;background:#3ddc97;justify-self:end}
.status-dot.vacation{background:#f5a623}
.status-dot.dayoff{background:#7da2ff}
.name{font-size:14px;color:#f5f5f5}
.name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.status-chip{display:none}
.status-dot{justify-self:end}
.chev{width:20px;height:20px;display:grid;place-items:center;color:#ffffff}
.chev svg{width:16px;height:16px}
.
/* Right side wrapper to keep status aligned before chevron */
/* removed right-wrap; using grid columns for alignment */

@media (prefers-color-scheme: light){
  :root{--bg:#f2f2f7;--text:#111;--brand:#111}
  .top{background:#fff}
  .badge{border-color:#fff}
}

/* Safe-area paddings for iOS */
.page{padding-left:calc(12px + env(safe-area-inset-left));padding-right:calc(12px + env(safe-area-inset-right));}

/* Modal */
.modal{position:fixed;inset:0;display:grid;place-items:end;z-index:50}
.modal.hidden{display:none}
.backdrop{position:absolute;inset:0;background:#000;opacity:0;transition:opacity .22s ease}
.modal.open .backdrop{opacity:.5}
.sheet{position:relative;width:100%;max-width:420px;margin:0 auto;background:#1b1c1f;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:var(--shadow);padding:12px 12px 24px;transform:translateY(24px);opacity:.0;transition:transform .22s ease, opacity .22s ease;max-height:calc(100dvh - 24px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.modal.open .sheet{transform:translateY(0);opacity:1}
.sheet-header{display:flex;justify-content:space-between;align-items:center}
.icon-btn{background:transparent;border:0;color:#fff;font-size:20px;line-height:1;padding:8px;border-radius:10px}
.icon-btn:active{transform:translateY(1px)}
.sheet-body{padding:8px}
.profile-top{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:8px}
.avatar{display:none}
/* initials removed */

/* pointer cursor for clickable UI on desktop */
button, .btn, .btn-pill { cursor: pointer; }
.card { cursor: pointer; }
.profile-name{font-weight:700}
.profile-top .status-chip{display:inline-flex;align-items:center;justify-content:center}
.status-chip{margin-top:6px;padding:6px 12px;border-radius:999px;font-size:12px;line-height:1;background:#c8f7e2;color:#0c5132;text-align:center}
.status-chip.vacation{background:#ffe4bf;color:#7a4a00}
.status-chip.dayoff{background:#dfe8ff;color:#143c8c}
.sheet-actions{display:flex;gap:12px;width:100%;margin-top:6px}
.info-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.info-item{display:flex;justify-content:space-between;align-items:center;background:#16171a;color:#ddd;padding:12px;border-radius:12px}
.info-key{color:#b8b8b8;font-size:12px}
.info-value{color:#e5e5e5;font-size:12px}
.sheet-footer{margin-top:12px}
.btn.danger{width:100%;background:transparent;color:#fff;border:2px solid #fff;border-radius:14px;padding:12px}

/* Form */
.form{display:flex;flex-direction:column;gap:10px}
.field{display:block}
.control{width:100%;background:#1f2024;color:#eaeaea;border:1px solid #2f3238;border-radius:12px;padding:12px 14px;font-size:14px;outline:none}
.control::placeholder{color:#8f9198}
.select select.control,.field.select .control{appearance:none;background:#1f2024 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="%238f9198" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"/></svg>') no-repeat right 12px center;background-size:18px}
.inph{display:block;color:#8f9198;font-size:11px;margin:6px 4px 0}
.field.date{position:relative}
.label-float{position:absolute;left:16px;top:10px;color:#8f9198;font-size:12px;background:transparent;pointer-events:none}
.field.date .control{padding-top:26px;padding-bottom:10px}
.label-top{color:#b8b8b8;font-size:12px;margin:0 0 6px 4px}
.hint{color:#777;font-size:11px;margin:6px 4px 0}
.textarea{min-height:96px;resize:vertical}

/* Requests */
.req-list{display:flex;flex-direction:column;gap:16px}
.req-card{background:#1B1B1B;border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.04);box-shadow:0 1px 0 rgba(0,0,0,.2) inset}
.req-row{display:flex;justify-content:space-between;align-items:center;margin:10px 0}
.req-key{color:#b9b9b9;font-size:12px}
.req-val{color:#e7e7e7;font-size:12px}
.req-actions{display:flex;gap:14px;margin-top:12px}
.btn-outline{background:transparent;border:1px solid #fff;color:#fff;border-radius:12px;padding:10px 14px}
.empty-hint{color:#b3b3b3;text-align:center;background:#1B1B1B;border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.04)}

/* Team loader */
.team-loader{display:flex;justify-content:center;align-items:center;background:#1B1B1B;border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.04)}
.spinner-emoji{display:inline-block;font-size:22px;animation:spin 1s linear infinite}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}


/* Requests: collapsible history */
.fake-select{display:flex;justify-content:space-between;align-items:center;background:#1f2024;border:1px solid #2f3238;border-radius:14px;padding:14px 16px;min-height:48px;color:#e7e7e7;font-size:14px;margin-top:8px;margin-bottom:12px;cursor:pointer}
.fake-select svg{transform:rotate(0);transition:transform .2s ease}
.fake-select.open svg{transform:rotate(180deg)}
.req-collaps{display:none;background:#16171a;border:1px solid #2a2d33;border-radius:14px;padding:12px 14px;margin-top:8px;margin-bottom:12px}
.req-collaps.open{display:block}
.req-subcard{background:#1f2024;border:1px solid #2f3238;border-radius:12px;padding:12px 14px;margin-top:8px}
.req-subrow{display:flex;justify-content:space-between;align-items:center;margin:8px 0}
.req-subkey{color:#b9b9b9;font-size:12px}
.req-subval{color:#e7e7e7;font-size:12px}
.req-subhint{color:#9a9a9a;font-size:12px}


