/* client-portal/styles.css
   Matches the look/feel of jrichmond.tech main site
   (dark glass + purple accent, clean spacing, mobile-first)
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap');

:root{
  --bg:#070a18;
  --bg2:#050816;
  --text:#eaf0ff;
  --muted:rgba(234,240,255,.72);

  --border:rgba(148,163,184,.18);
  --border2:rgba(139,92,246,.35);

  --accent:#8b5cf6;
  --accent2:#a78bfa;
  --accent3:#22d3ee;

  --card:rgba(12,16,35,.60);
  --card2:rgba(6,8,20,.55);

  --r:18px;
  --shadow:0 28px 80px rgba(0,0,0,.55);
  --shadow-sm:0 10px 28px rgba(0,0,0,.35);

  --font:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --display:"Space Grotesk",Inter,system-ui,sans-serif;

  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  line-height:1.55;
  background:
    radial-gradient(900px 520px at 18% -10%, rgba(56,189,248,.14), transparent 55%),
    radial-gradient(820px 520px at 95% 5%, rgba(167,139,250,.16), transparent 60%),
    radial-gradient(650px 420px at 10% 110%, rgba(34,211,238,.12), transparent 60%),
    radial-gradient(circle at top, rgba(30,41,59,.55) 0, rgba(7,10,24,1) 55%),
    linear-gradient(180deg, var(--bg) 0, var(--bg2) 100%);
  min-height:100vh;
}

a{color:var(--accent2);text-decoration:none}
a:hover{color:var(--accent3)}
img{max-width:100%;height:auto}
code,kbd,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}

.shell{max-width:var(--max);margin:0 auto;padding:1.25rem 1rem 3.5rem}
@media (min-width:900px){ .shell{padding:1.5rem 1.25rem 4rem} }

.top-nav{
  position:sticky; top:0; z-index:20;
  backdrop-filter:saturate(180%) blur(16px);
  background:rgba(20,24,44,.62);
  border:1px solid rgba(255,255,255,.06);
  border-radius:999px;
  padding:.65rem .75rem;
  box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
}

.brand{
  display:flex;align-items:center;gap:.75rem;
  min-width:0;
}
.brand-logo{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(139,92,246,.95), rgba(34,211,238,.55));
  color:#061021;
  font-weight:800;
  letter-spacing:.02em;
  flex:0 0 auto;
}
.brand-stack{min-width:0}
.brand-title{
  font-family:var(--display);
  font-weight:700;
  font-size:1.02rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.brand-sub{
  color:var(--muted);
  font-size:.86rem;
  margin-top:.05rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.nav-toggle{
  display:inline-flex;
  align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text);
  cursor:pointer;
}
.nav-toggle:hover{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.06)}
.nav-toggle:focus{outline:2px solid rgba(139,92,246,.55);outline-offset:2px}

.nav{
  display:none;
  align-items:center;
  gap:.5rem;
}
.nav a{color:rgba(234,240,255,.88)}
.nav a:hover{color:#fff}

@media (min-width:900px){
  .nav-toggle{display:none}
  .nav{display:flex}
}

body.nav-open .nav{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  position:absolute;
  top:calc(100% + .55rem);
  right:.75rem;
  width:min(340px, calc(100vw - 2rem));
  padding:.65rem;
  background:rgba(20,24,44,.82);
  backdrop-filter:saturate(180%) blur(16px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  box-shadow:var(--shadow);
}
body.nav-open .nav a{
  padding:.75rem .85rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.03);
}
body.nav-open .nav a:hover{
  border-color:rgba(139,92,246,.30);
  background:rgba(139,92,246,.10);
}

.page-header{margin:1.25rem .15rem 1.1rem}
.badge{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.38rem .65rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:rgba(234,240,255,.85);
  font-size:.9rem;
}
.badge-dot{width:8px;height:8px;border-radius:99px;background:var(--accent3);box-shadow:0 0 0 6px rgba(34,211,238,.14)}
.page-title{
  font-family:var(--display);
  font-size:clamp(1.55rem, 3.1vw, 2.15rem);
  line-height:1.15;
  margin:.65rem 0 .35rem;
}
.page-subtitle{color:var(--muted);max-width:68ch;margin:0}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r);
  box-shadow:var(--shadow);
}
.card.pad{padding:1rem}
@media(min-width:900px){ .card.pad{padding:1.25rem} }

hr.sep{
  border:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  margin:1rem 0;
}

.btn, .btn-ghost, .btn-small, button.button-primary, button[type="submit"]{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.75rem 1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:var(--text);
  cursor:pointer;
  font-weight:700;
}
.btn:hover, .btn-small:hover, button.button-primary:hover, button[type="submit"]:hover{
  border-color:rgba(139,92,246,.40);
  background:rgba(139,92,246,.14);
}
.btn-primary, button.button-primary, button[type="submit"]{
  background:linear-gradient(135deg, rgba(139,92,246,.95), rgba(167,139,250,.72));
  border-color:rgba(139,92,246,.55);
  color:#0b1020;
}
.btn-primary:hover, button.button-primary:hover, button[type="submit"]:hover{
  filter:saturate(1.05) brightness(1.02);
  background:linear-gradient(135deg, rgba(167,139,250,.95), rgba(34,211,238,.45));
}
.btn-ghost{background:rgba(255,255,255,.03)}
.btn-small{padding:.55rem .85rem;font-weight:700;font-size:.92rem}

.hint{color:var(--muted);font-size:.92rem}

.kpi{display:grid;gap:.75rem;margin-top:1rem}
@media(min-width:900px){ .kpi{grid-template-columns:repeat(3,1fr)} }
.kpi .item{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:.9rem;
}
.kpi .label{color:var(--muted);font-size:.9rem}
.kpi .value{font-family:var(--display);font-size:1.25rem;margin-top:.2rem}

.layout{display:grid;gap:1rem;align-items:start}
@media(min-width:1000px){ .layout{grid-template-columns: 1.35fr .65fr} }

.card-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
  padding:1rem 1rem .25rem;
}
.card-title{margin:0;font-family:var(--display);font-size:1.2rem}
.card-subtitle{color:var(--muted);font-size:.92rem}
.card-body{padding:0 1rem 1rem}

.status-chip{
  display:inline-flex;align-items:center;gap:.45rem;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  padding:.35rem .6rem;
  border-radius:999px;
  color:rgba(234,240,255,.88);
  font-size:.9rem;
}
.status-dot{width:8px;height:8px;border-radius:99px;background:var(--accent);box-shadow:0 0 0 6px rgba(139,92,246,.14)}

.checklist{margin:.75rem 0 0;padding:0;list-style:none;display:grid;gap:.5rem}
.check-item{
  display:flex;gap:.6rem;align-items:flex-start;
  padding:.65rem .75rem;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.03);
  border-radius:14px;
}
.check-icon{
  width:26px;height:26px;border-radius:10px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  font-weight:900;
}
.check-icon.done{color:#0b1020;background:rgba(34,211,238,.90);border-color:rgba(34,211,238,.55)}
.check-icon.todo{color:rgba(234,240,255,.85)}

.action-grid{display:grid;gap:.75rem;margin-top:.75rem}
@media(min-width:900px){ .action-grid{grid-template-columns:repeat(2,1fr)} }
.action-tile{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:.9rem;
  display:flex;gap:.75rem;align-items:flex-start;
}
.action-icon{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(139,92,246,.16);
  border:1px solid rgba(139,92,246,.25);
}
.action-title{margin:0;font-weight:800}
.action-desc{margin:.2rem 0 0;color:var(--muted);font-size:.92rem}
.action-tag{
  margin-top:.55rem;
  display:inline-flex;
  padding:.25rem .5rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  color:rgba(234,240,255,.85);
  font-size:.82rem;
}

table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
th,td{
  padding:.85rem .9rem;
  border-bottom:1px solid rgba(255,255,255,.06);
  text-align:left;
  vertical-align:top;
}
th{font-size:.9rem;color:rgba(234,240,255,.85);background:rgba(255,255,255,.03)}
tr:last-child td{border-bottom:0}

input, select, textarea{
  width:100%;
  padding:.78rem .9rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.20);
  color:var(--text);
  outline:none;
}
textarea{min-height:120px;resize:vertical}
input:focus, select:focus, textarea:focus{
  border-color:rgba(139,92,246,.55);
  box-shadow:0 0 0 4px rgba(139,92,246,.14);
}
label{display:block;font-weight:700;margin:.35rem 0 .35rem}
.required{color:rgba(167,139,250,.95)}

.grid{display:grid;gap:.85rem}
.grid-2{display:grid;gap:.85rem}
@media(min-width:900px){ .grid-2{grid-template-columns:repeat(2,1fr)} }

.section{
  margin-top:1rem;
  padding:1rem;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
}
.section-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
  margin-bottom:.5rem;
}
.section-pill{
  display:inline-flex;align-items:center;
  padding:.25rem .55rem;
  border-radius:999px;
  border:1px solid rgba(139,92,246,.25);
  background:rgba(139,92,246,.10);
  color:rgba(234,240,255,.9);
  font-weight:800;
  font-size:.82rem;
}
.section-title{
  margin:.2rem 0 0;
  font-family:var(--display);
  font-size:1.15rem;
}
.section-description{margin:.15rem 0 0;color:var(--muted);font-size:.92rem}

.form-footer{
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  margin-top:1rem;flex-wrap:wrap;
}
.footer-note{color:var(--muted);font-size:.92rem}

.notice{
  border:1px solid rgba(34,211,238,.25);
  background:rgba(34,211,238,.10);
  padding:.75rem .9rem;
  border-radius:16px;
  color:rgba(234,240,255,.92);
}

.error{
  border:1px solid rgba(239,68,68,.35);
  background:rgba(239,68,68,.12);
  padding:.75rem .9rem;
  border-radius:16px;
  color:rgba(254,226,226,.96);
}

.small{font-size:.92rem;color:var(--muted)}
