/* ─── FUN Padel Portal — Shared Design System ──────────────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{color:inherit;text-decoration:none}

:root{
  --bg:oklch(0.984 0.003 255);
  --surface:#ffffff;
  --ink:oklch(0.24 0.012 262);
  --ink-soft:oklch(0.46 0.009 262);
  --ink-faint:oklch(0.62 0.007 262);
  --line:oklch(0.915 0.005 262);
  --line-soft:oklch(0.955 0.004 262);
  --graphite:oklch(0.28 0.013 262);
  --graphite-700:oklch(0.34 0.013 262);
  --mine-tint:oklch(0.975 0.006 262);

  --best-ink:oklch(0.50 0.14 150);--best-bg:oklch(0.955 0.045 150);--best-bd:oklch(0.86 0.07 150);
  --high-ink:oklch(0.54 0.17 27); --high-bg:oklch(0.962 0.04 27);  --high-bd:oklch(0.88 0.07 27);
  --warn-ink:oklch(0.58 0.13 70); --warn-bg:oklch(0.962 0.05 80);  --warn-bd:oklch(0.86 0.08 80);
  --accent:oklch(0.47 0.08 245);  --accent-bg:oklch(0.955 0.025 245);
  --violet-ink:oklch(0.50 0.12 290);--violet-bg:oklch(0.96 0.03 290);
  --equal-ink:oklch(0.48 0.05 200);--equal-bg:oklch(0.965 0.02 200);
  --oos-ink:oklch(0.62 0.005 262);--oos-bg:oklch(0.962 0.003 262);

  --shadow-sm:0 1px 3px oklch(0 0 0/.07),0 1px 2px oklch(0 0 0/.04);
  --shadow-md:0 4px 12px oklch(0 0 0/.08),0 2px 4px oklch(0 0 0/.04);
  --shadow-lg:0 8px 24px oklch(0 0 0/.10),0 4px 8px oklch(0 0 0/.05);

  --hdr:64px;
  --r-card:16px;
  --r-btn:10px;
  --r-pill:8px;
}

body{
  font-family:'Manrope',system-ui,sans-serif;
  font-size:14px;line-height:1.5;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
.mono{font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums}
.soft{color:var(--ink-soft)}.faint{color:var(--ink-faint)}

/* ── Header .pbar ─────────────────────────────────────────────────────────── */
.pbar{
  position:sticky;top:0;z-index:100;
  background:oklch(1 0 0/.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  height:var(--hdr);
}
.pbar__inner{
  max-width:1240px;margin:0 auto;padding:0 32px;
  height:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.pbar__left{display:flex;align-items:center;gap:10px}

/* ← Портал button */
.pback{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 13px;
  border:1px solid var(--line);border-radius:var(--r-btn);
  background:var(--surface);
  font-family:'Manrope',system-ui,sans-serif;
  font-size:13px;font-weight:500;color:var(--ink-soft);
  cursor:pointer;transition:border-color .15s,color .15s,background .15s;
  flex-shrink:0;white-space:nowrap;
}
.pback:hover{border-color:var(--graphite);color:var(--ink)}

/* Brand */
.hdr-brand{display:flex;align-items:center;gap:10px}
.hdr-logo{
  width:38px;height:38px;
  background:var(--graphite);color:#fff;
  font-weight:800;font-size:13px;letter-spacing:.5px;
  border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.hdr-title{font-size:15px;font-weight:700;line-height:1.2;color:var(--ink)}
.hdr-sub{font-size:12px;color:var(--ink-faint)}

/* Right side */
.pbar__right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.hdr-divider{width:1px;height:28px;background:var(--line);flex-shrink:0}

/* Clock */
.hdr-clock{text-align:right}
.hdr-time{
  font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums;
  font-size:15px;font-weight:500;color:var(--ink);line-height:1;
}
.hdr-date{font-size:12px;color:var(--ink-faint);margin-top:2px}

/* Profile */
.hdr-profile{display:flex;align-items:center;gap:8px}
.hdr-avatar{
  width:32px;height:32px;
  background:var(--graphite);color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;
}
.hdr-name{font-size:13px;font-weight:600;line-height:1.2}
.hdr-role{font-size:11.5px;color:var(--ink-faint)}

/* ── Breadcrumbs .pcrumb ──────────────────────────────────────────────────── */
.pcrumb{
  font-size:13px;color:var(--ink-faint);
  display:flex;align-items:center;gap:6px;
  margin-bottom:4px;
}
.pcrumb a{color:var(--accent);font-weight:500}
.pcrumb a:hover{text-decoration:underline}
.pcrumb__sep{color:var(--line)}

/* ── KPI Card .kpi ────────────────────────────────────────────────────────── */
.kpi{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:18px 18px 16px 22px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  display:block;
  transition:box-shadow .15s,transform .15s;
}
a.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.kpi__marker{
  position:absolute;left:0;top:18px;bottom:18px;
  width:3px;border-radius:0 3px 3px 0;
}
.kpi--graphite .kpi__marker{background:var(--graphite)}
.kpi--accent   .kpi__marker{background:var(--accent)}
.kpi--win      .kpi__marker{background:var(--best-ink)}
.kpi--high     .kpi__marker{background:var(--high-ink)}
.kpi--warn     .kpi__marker{background:var(--warn-ink)}

.kpi__label{
  font-size:11.5px;font-weight:600;color:var(--ink-faint);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;
}
.kpi__value{
  font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums;
  font-size:24px;font-weight:600;line-height:1;margin-bottom:5px;color:var(--ink);
}
.kpi--accent .kpi__value{color:var(--accent)}
.kpi--win    .kpi__value{color:var(--best-ink)}
.kpi--high   .kpi__value{color:var(--high-ink)}
.kpi--warn   .kpi__value{color:var(--warn-ink)}

.kpi__sub{font-size:12px;color:var(--ink-faint)}
.kpi__delta{font-weight:700}
.kpi__delta--up{color:var(--best-ink)}
.kpi__delta--dn{color:var(--high-ink)}

/* ── Content container .wrap ──────────────────────────────────────────────── */
.wrap{
  max-width:1240px;margin:0 auto;
  padding:30px 32px 72px;
  display:flex;flex-direction:column;gap:28px;
}

/* ── Hero section ─────────────────────────────────────────────────────────── */
.hero{padding:4px 0 0}
.hero__greeting{font-size:28px;font-weight:800;letter-spacing:-.3px;margin-bottom:6px}
.hero__sub{font-size:15px;color:var(--ink-soft)}

/* ── KPI strip ────────────────────────────────────────────────────────────── */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}

/* ── Module grid ──────────────────────────────────────────────────────────── */
.modules{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

.mod{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:22px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .15s,transform .15s,border-color .15s;
  text-decoration:none;color:var(--ink);
}
a.mod.live:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.mod.soon{opacity:.72;cursor:default}

.mod__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.mod__icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  background:var(--line-soft);color:var(--ink-faint);
}
a.mod.live .mod__icon{background:var(--graphite);color:#fff}

.mod__badge{
  padding:3px 9px;border-radius:6px;
  font-size:11px;font-weight:700;letter-spacing:.3px;
  white-space:nowrap;
}
.mod__badge--live{background:var(--best-bg);color:var(--best-ink)}
.mod__badge--soon{background:var(--line-soft);color:var(--ink-faint)}

.mod__body{flex:1}
.mod__title{font-size:14.5px;font-weight:700;margin-bottom:4px}
.mod__desc{font-size:13px;color:var(--ink-soft);line-height:1.5}

.mod__footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:8px;border-top:1px solid var(--line-soft);
}
.mod__stat{font-size:12.5px;color:var(--ink-faint)}
.mod__stat strong{color:var(--ink);font-weight:700}
.mod__cta{
  font-size:13px;font-weight:600;color:var(--graphite);
  opacity:0;transition:opacity .15s;
}
a.mod.live:hover .mod__cta{opacity:1}

/* ── Section heading ──────────────────────────────────────────────────────── */
.section-title{font-size:17px;font-weight:700;margin-bottom:4px}

/* ── Empty state (stubs) ──────────────────────────────────────────────────── */
.empty-state{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:80px 32px;gap:20px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-card);box-shadow:var(--shadow-sm);
}
.empty-state__icon{
  width:64px;height:64px;border-radius:18px;
  background:var(--line-soft);color:var(--ink-faint);
  display:flex;align-items:center;justify-content:center;
}
.empty-state__title{font-size:20px;font-weight:700}
.empty-state__sub{font-size:15px;color:var(--ink-soft);max-width:420px;line-height:1.6}
.empty-state__list{
  list-style:none;text-align:left;font-size:14px;color:var(--ink-soft);
  display:flex;flex-direction:column;gap:8px;
}
.empty-state__list li{display:flex;align-items:flex-start;gap:8px}
.empty-state__list li::before{
  content:'';display:block;width:6px;height:6px;border-radius:50%;
  background:var(--line);margin-top:7px;flex-shrink:0;
}
.btn-portal{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 20px;
  background:var(--graphite);color:#fff;
  border:none;border-radius:var(--r-btn);
  font-family:'Manrope',system-ui,sans-serif;
  font-size:14px;font-weight:600;cursor:pointer;
  transition:background .15s;text-decoration:none;
}
.btn-portal:hover{background:var(--graphite-700)}

/* ── Skeleton placeholders ────────────────────────────────────────────────── */
.skeleton-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.skeleton-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-card);padding:18px 18px 16px 22px;
  box-shadow:var(--shadow-sm);opacity:.55;
}
.skel{background:var(--line-soft);border-radius:6px}
.skel--sm{height:10px;width:60%;margin-bottom:10px}
.skel--lg{height:28px;width:45%;margin-bottom:8px}
.skel--xs{height:9px;width:40%}

/* ── Roles: hide profit columns for staff ─────────────────────────────────── */
[data-role="staff"] .kpi--profit,
[data-role="staff"] .owner-only{display:none}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .kpis{grid-template-columns:repeat(3,1fr)}
  .modules{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:820px){
  .modules{grid-template-columns:repeat(2,1fr)}
  .skeleton-strip{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .pbar__inner{padding:0 16px}
  .hdr-sub,.hdr-clock,.hdr-role{display:none}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .modules{grid-template-columns:1fr}
  .wrap{padding:20px 16px 48px}
  .skeleton-strip{grid-template-columns:repeat(2,1fr)}
}
