* { box-sizing: border-box; }
body { margin: 0; font-family: "Segoe UI", system-ui, sans-serif;
  background: var(--ge-color-bg, #faf9f8); color: var(--ge-color-text, #201f1e);
  min-height: 100vh; display: flex; flex-direction: column; }
.hidden { display: none !important; }
.muted { color: var(--ge-color-text-secondary, #605e5c); }
.small { font-size: 12px; }
a { color: var(--ge-color-brand, #4f46e5); }

.mark { width: 30px; height: 30px; border-radius: 9px; flex: none;
  background: var(--ge-brand-gradient, linear-gradient(135deg, #4f46e5, #7c6cf0));
  color: #fff; font-weight: 800; display: grid; place-items: center; font-size: 17px; }
.mark.big { width: 56px; height: 56px; border-radius: 14px; font-size: 30px; }

.topbar { display: flex; align-items: center; justify-content: space-between;
  padding: 10px 18px; background: var(--ge-color-surface, #fff);
  border-bottom: 1px solid var(--ge-color-border, #e1dfdd); }
.brand { display: flex; align-items: center; gap: 8px; }
.who { font-size: 13px; }
.topnav { display: flex; align-items: center; gap: 14px; }
.navbtn { font-size: 13px; cursor: pointer; color: var(--ge-color-brand, #4f46e5); }
.navbtn:hover { text-decoration: underline; }
.adminview { flex: 1; padding: 18px 22px; overflow: auto; }
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; }
.stat { background: var(--ge-color-surface, #fff); border: 1px solid var(--ge-color-border, #e1dfdd);
  border-radius: var(--ge-radius-md, 8px); padding: 14px 16px; }
.stat .n { font-size: 26px; font-weight: 800; color: var(--ge-color-brand, #4f46e5); }
.stat .l { font-size: 12px; color: var(--ge-color-text-secondary, #605e5c); margin-top: 4px; }

.btn { display: inline-block; background: var(--ge-color-brand, #4f46e5); color: #fff;
  border: none; border-radius: var(--ge-radius-md, 8px); padding: 9px 16px;
  font-size: 14px; cursor: pointer; text-decoration: none; }
.btn.sm { padding: 6px 12px; font-size: 13px; }
.btn:hover { filter: brightness(1.05); }

.guest { max-width: 520px; margin: 8vh auto; text-align: center; padding: 0 20px; }
.guest .mark.big { margin: 0 auto 16px; }
.guest h1 { font-size: 26px; margin: 0 0 8px; }

.work { flex: 1; display: grid; grid-template-columns: 260px 1fr; min-height: 0; }
.sidebar { background: var(--ge-color-surface, #fff); border-right: 1px solid var(--ge-color-border, #e1dfdd); }
.side-head { padding: 14px 16px; font-weight: 700; font-size: 13px; text-transform: uppercase;
  letter-spacing: .04em; color: var(--ge-color-text-secondary, #605e5c); }
.projects { list-style: none; margin: 0; padding: 0; }
.projects li { padding: 10px 16px; cursor: pointer; font-size: 14px;
  border-left: 3px solid transparent; }
.projects li { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.projects li:hover { background: var(--ge-color-bg, #faf9f8); }
.ptag { font-size: 10px; padding: 1px 6px; border-radius: 999px; flex: none;
  background: var(--ge-color-bg, #f3f2f1); color: var(--ge-color-text-secondary, #605e5c);
  border: 1px solid var(--ge-color-border, #e1dfdd); }
.projects li.active { background: var(--ge-color-bg, #faf9f8);
  border-left-color: var(--ge-color-brand, #4f46e5); font-weight: 600; }

.content { padding: 18px 22px; overflow: auto; }
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--ge-color-border, #e1dfdd); margin-bottom: 14px; }
.tab { background: none; border: none; padding: 8px 14px; cursor: pointer; font-size: 14px;
  color: var(--ge-color-text-secondary, #605e5c); border-bottom: 2px solid transparent; }
.tab.active { color: var(--ge-color-brand, #4f46e5); border-bottom-color: var(--ge-color-brand, #4f46e5); font-weight: 600; }
.panel-head { font-size: 16px; margin-bottom: 12px; }
.add { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.add input { padding: 7px 10px; border: 1px solid var(--ge-color-border, #e1dfdd);
  border-radius: var(--ge-radius-sm, 6px); font-size: 13px; }
.add input[type=text], #tTitle { flex: 1; min-width: 200px; }

.tasks { display: flex; flex-direction: column; gap: 8px; }
.row { background: var(--ge-color-surface, #fff); border: 1px solid var(--ge-color-border, #e1dfdd);
  border-radius: var(--ge-radius-md, 8px); padding: 10px 14px; display: grid;
  grid-template-columns: 1fr auto auto auto; gap: 12px; align-items: center; }
.row .title { font-size: 14px; font-weight: 600; }
.row .dates { font-size: 12px; color: var(--ge-color-text-secondary, #605e5c); }
.row select, .row input[type=number] { padding: 4px 8px; border: 1px solid var(--ge-color-border, #e1dfdd);
  border-radius: 6px; font-size: 12px; }
.bar { height: 6px; background: var(--ge-color-border, #e1dfdd); border-radius: 999px; overflow: hidden; width: 90px; }
.bar > i { display: block; height: 100%; background: var(--ge-color-brand, #4f46e5); }
.empty { padding: 24px; text-align: center; color: var(--ge-color-text-secondary, #605e5c); }

footer { text-align: center; padding: 16px; font-size: 13px;
  color: var(--ge-color-text-secondary, #605e5c); border-top: 1px solid var(--ge-color-border, #e1dfdd); }
.err { background: #fde7e9; color: #a4262c; padding: 10px 14px; border-radius: 8px; margin-bottom: 12px; font-size: 13px; }
