/* Master Light Theme for Projctr — fixed typos, modal aria, table base */
:root{
  --ink:#1c1f26;
  --muted:#666;
  --line:rgba(0,0,0,.1);
  --panel:rgba(255,255,255,.9);
  --brand1:#2253f4;
  --brand2:#5a78ff;
  --round:16px;
  --circle:rgba(0,0,0,1);
  --font-ui: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --font-title: ui-rounded, "SF Pro Display", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html,body{
  height:100%;margin:0;background:#f8f9fb;color:var(--ink);
  font:300 14px var(--font-ui);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
input,select,textarea,button{font-family:var(--font-ui)}

#app{display:flex;flex-direction:column;min-height:100vh}

/* ===== Titlebar & Toolbar ===== */
.app-titlebar{
  position:sticky;top:0;z-index:100;background:var(--brand1);
  padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.app-titlebar h1{margin:0;font-size:26px;font-weight:400;color:#f3f5f2;letter-spacing:-.01em;line-height:1.3;font-family:var(--font-title)}
.app-titlebar .app-logo{height:20px;width:auto;display:block}

.toolbar{
  position:sticky;top:0;z-index:99;display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:14px 18px;background:var(--brand1);backdrop-filter:blur(22px) saturate(160%);
  height:120px;color:#fff;
}
.sep{width:1px;height:24px;background:var(--line);margin:0 8px}

.btn{
  height:34px;border-radius:999px;border:none;background:var(--brand1);padding:0 12px;color:#f3f5f2;cursor:pointer;font-size:13px;
}
.btn.brand{background:var(--brand1);border:0;color:#fff}
.btn:hover{filter:brightness(1.06)}
#btnNewClient{margin-left:8px}

/* ===== Icon buttons ===== */
.actions-wrap{display:flex;align-items:center;justify-content:flex-end;gap:10px;height:100%}
.icon-btn{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:60px;min-height:60px;padding:6px 4px;background:transparent;border:0;border-radius:8px;cursor:pointer;
  text-align:center;transition:background .15s ease, transform .15s ease;vertical-align:middle;
}
.toolbar .icon-btn{margin:0 6px}
.icon-btn:hover{background:rgba(255,255,255,.08);transform:translateY(-1px)}
.icon-btn:active{transform:translateY(0)}
.icon-btn .icon svg{width:24px;height:24px;display:block;fill:#f3f5f2;transition:fill .15s ease}
.icon-btn:hover .icon svg{fill:#f3f5f2;opacity:.8}
.icon-btn .label{
  margin-top:4px;font-size:10px;font-weight:500;color:#f3f5f2;line-height:1.2;max-width:100%;
  white-space:normal;word-break:break-word;text-align:center;pointer-events:none;transition:color .15s ease;
}
.icon-btn:hover .label{color:#f3f5f2;opacity:.8}

/* ===== Tabs ===== */
.tabs{display:flex;gap:6px;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08)}
.tab{border:1px solid rgba(0,0,0,.12);background:rgba(255,255,255,.8);color:var(--ink);border-radius:12px;padding:6px 12px;cursor:pointer}
.tab.active{background:#eef1ff;border-color:rgba(125,139,255,.45)}

/* ===== Views ===== */
.view{display:none;padding:14px;opacity:0;pointer-events:none;transition:opacity .3s ease}
.view.active{display:block;opacity:1;pointer-events:auto}

/* ===== Projects table (base) ===== */
.projects-shell{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
table.projects{width:100%;border-collapse:separate;border-spacing:0}
table.projects thead th{
  text-align:left;font-weight:600;font-size:12px;color:#4d5562;
  padding:10px 12px;border-bottom:1px solid var(--line);background:#f3f6ff;
}
table.projects tbody td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
table.projects tbody tr:hover{background:#f8fbff}
table.projects td.ta-right{text-align:right}
table.projects td select{
  -webkit-appearance:none!important;appearance:none!important;background:transparent!important;border:none;padding:0;font:inherit;color:var(--ink);cursor:pointer;line-height:1.4;position:relative;
}
table.projects td select::-ms-expand{display:none}

/* ===== Status pills (generic) ===== */
.status-Pending{background:#FE9F0A20;color:#FE9F0A}
.status-InProgress{background:#0A84FF20;color:#0A84FF}
.status-OnHold{background:#BF5AF220;color:#BF5AF2}
.status-Complete{background:#30D15820;color:#30D158}
.status-Cancelled{background:#8E8E9320;color:#8E8E93}

/* ===== Modals (ARIA-driven) ===== */
.modal{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:30;
  background:rgba(255,255,255,.55);backdrop-filter:blur(28px) saturate(180%);
}
.modal[aria-hidden="true"]{display:none}
.modal[aria-hidden="false"]{display:flex}
.modal .scrim{position:absolute;inset:0}
.modal .card{
  position:relative;background:#fff;border-radius:20px;min-width:560px;max-width:760px;
  box-shadow:0 20px 60px rgba(0,0,0,.15);
}
.modal header{padding:22px 24px;border-bottom:1px solid rgba(0,0,0,.1);font-weight:500;font-size:20px;color:var(--ink)}
.modal section{padding:20px;display:grid;gap:14px}
.modal .grid2{grid-template-columns:1fr 1fr}
.modal .grid2 .full{grid-column:1 / -1}
.modal footer{padding:16px 20px;display:flex;justify-content:flex-end;gap:10px}

.field label,.form-group label{display:block;margin:0 0 6px;color:#555;font-size:12px;font-weight:500}
.field input,.field select{
  height:38px;border-radius:10px;border:none;font-size:14px;background:rgba(0,0,0,.04);color:var(--ink);padding:0 10px;width:100%;
}
.field textarea,#textarea,#pmNotes{
  width:100%;min-height:140px;border-radius:10px;border:none;background:rgba(0,0,0,.04);
  color:var(--ink);font-size:14px;line-height:1.5;padding:10px;resize:vertical;transition:border .2s ease, background .2s ease;
}
.field textarea:focus{outline:none;border:none;background:rgba(0,0,0,.06)}

/* keep text + checkbox on one line */
#pmAllowDupRow{display:inline-flex;align-items:center;gap:.5rem;line-height:1.2;margin-top:12px}
#pmAllowDupRow>span{white-space:nowrap}
#pmAllowDupRow>input[type="checkbox"]{margin:0;height:16px}

/* misc */
.inline{display:flex;gap:8px;align-items:center}
.small{font-size:12px;color:var(--muted)}

/* ===== Toast ===== */
.toast,.#toast{z-index:99}
.toast{
  display:inline-flex;align-items:center;gap:12px;padding:14px 22px;background:rgba(255,255,255,.9);
  border:1px solid rgba(0,0,0,.1);border-radius:14px;font-size:14px;color:var(--ink);backdrop-filter:blur(14px);
  box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(20px);opacity:0;pointer-events:none;transition:all .35s ease;
}
.toast.show{opacity:1;transform:translateY(0);pointer-events:all}
#toast{
  position:fixed;bottom:40px;left:50%;transform:translateX(-50%) translateY(20px);
  background:rgba(255,255,255,.92);backdrop-filter:blur(14px);padding:14px 22px;border-radius:16px;
  font-size:14px;font-weight:400;color:#111;display:flex;align-items:center;gap:10px;opacity:0;pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;box-shadow:0 8px 24px rgba(0,0,0,.1);
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}

/* ===== View toggle ===== */
.view-toggle{
  display:inline-flex;background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.1);border-radius:50px;padding:4px;
  backdrop-filter:blur(12px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);margin-right:16px;
}
.view-toggle .toggle-btn{
  flex:1;font-size:13px;font-weight:500;padding:8px 20px;background:transparent;border:none;color:#f3f5f2;cursor:pointer;border-radius:50px;transition:all .25s ease;
}
.view-toggle .toggle-btn.active{background:var(--brand1);color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.view-toggle .toggle-btn:hover:not(.active){background:rgba(255,255,255,.08)}

/* Theme toggle (shared) */
.theme-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.theme-toggle .label{font-size:14px;font-weight:500;color:var(--ink)}
.theme-toggle .toggle-pill{
  width:48px;height:26px;border-radius:999px;border:1px solid rgba(0,0,0,.16);background:rgba(0,0,0,.08);position:relative;cursor:pointer;
  transition:background .25s ease, border-color .25s ease;
}
.theme-toggle .toggle-pill::after{
  content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;
  transition:transform .25s ease, background .25s ease;
}
/* knob position via aria-checked (set in JS) */
.theme-toggle .toggle-pill[aria-checked="true"]::after{transform:translateX(22px)}

.save-check{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:8px;border-radius:99px;border:1px solid rgba(255,255,255,.08)}

/* Footer status */
.foundry-footer-status{
  position:fixed;bottom:12px;left:20px;font-size:.75rem;font-weight:300;letter-spacing:.3px;color:#f3f5f2;pointer-events:none;z-index:999;user-select:none;
  font-family:inherit;padding:8px;background:var(--brand1);border-radius:99px;
}

/* icon buttons with text */
.btn--icon{display:inline-flex;align-items:center;gap:.5rem}
.btn--icon svg{width:1em;height:1em;fill:currentColor;flex:0 0 auto}
