/* ===========================================================
   Boxxpro Marketing UI Kit
   Reusable primitives rebuilt from the real app screenshots.
   Brand blue #0090DF + semantic accent pops.
   =========================================================== */

:root{
  /* Brand */
  --bx-blue:        #0090DF;
  --bx-blue-600:    #0078c4;
  --bx-blue-700:    #0064a8;
  --bx-blue-tint:   #E6F4FC;
  --bx-blue-tint2:  #D2EBFA;

  /* Accents */
  --bx-amber:       #E8920C;
  --bx-amber-tint:  #FDF0DC;
  --bx-green:       #15A05C;
  --bx-green-tint:  #E0F5EA;
  --bx-coral:       #F05A3C;
  --bx-coral-tint:  #FDE8E2;
  --bx-purple:      #6B4FA8;

  /* Neutrals */
  --bx-ink:         #0E1B2A;
  --bx-ink-2:       #334155;
  --bx-muted:       #6B7A8D;
  --bx-faint:       #95A3B3;
  --bx-line:        #EAEEF3;
  --bx-line-2:      #F1F4F8;
  --bx-paper:       #FFFFFF;
  --bx-page:        #F6F8FB;

  /* Shapes */
  --bx-r-sm: 10px;
  --bx-r:    16px;
  --bx-r-lg: 22px;
  --bx-shadow:    0 18px 40px -18px rgba(13,40,70,.28), 0 4px 12px -6px rgba(13,40,70,.12);
  --bx-shadow-lg: 0 40px 80px -28px rgba(8,30,60,.45), 0 10px 26px -12px rgba(8,30,60,.22);
  --bx-font: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
}

/* ---- Scene shells -------------------------------------------------- */
.bx-scene{
  position:relative; width:100%; height:100%;
  font-family:var(--bx-font);
  color:var(--bx-ink);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
.bx-scene *{ box-sizing:border-box; }

.bx-scene--blue{
  background:
    radial-gradient(120% 90% at 12% 8%, #1AA6F0 0%, transparent 55%),
    radial-gradient(130% 120% at 92% 100%, #004f9e 0%, transparent 60%),
    linear-gradient(150deg, #0a4d96 0%, #073a78 48%, #06305f 100%);
}
.bx-scene--light{
  background:
    radial-gradient(90% 70% at 80% 0%, #EAF4FD 0%, transparent 55%),
    linear-gradient(160deg, #F8FAFD 0%, #EEF3F9 100%);
}
.bx-scene--sky{
  background:
    radial-gradient(100% 80% at 15% 10%, #E9F5FE 0%, transparent 60%),
    linear-gradient(155deg, #DCEEFB 0%, #C7E2F6 100%);
}
/* transparent "bare" variant — section provides the background */
.bx-scene--bare{ background:transparent; height:auto; overflow:visible; }

/* ---- MacBook Pro mockup -------------------------------------------------- */
.mbp{ position:relative; filter: drop-shadow(0 42px 70px rgba(8,30,60,.30)); }
.mbp__lid{
  background:#0d0d0f;
  border-radius:26px;
  padding:15px;
  box-shadow: inset 0 0 0 2px #34343a, inset 0 0 0 7px #15151a;
}
.mbp__cam{
  position:absolute; top:7px; left:50%; transform:translateX(-50%);
  width:7px; height:7px; border-radius:50%; background:#26262b;
  box-shadow:0 0 0 2px #1c1c20, inset 0 0 2px #3a6ea5; z-index:3;
}
.mbp__screen{ border-radius:11px; overflow:hidden; background:var(--bx-page); position:relative; }
.mbp__base{
  position:relative;
  width: calc(100% + 132px);
  margin-left:-66px;
  height:26px;
  background:linear-gradient(180deg,#e6eaef 0%, #c7cdd5 40%, #aab1bb 72%, #c4cad2 100%);
  border-radius:0 0 16px 16px;
  box-shadow: inset 0 2px 2px rgba(255,255,255,.6);
}
.mbp__notch{
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:172px; height:14px;
  background:linear-gradient(180deg,#a7aeb8,#cdd2da);
  border-radius:0 0 14px 14px;
}

/* soft glow blobs for depth */
.bx-blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.55; pointer-events:none; }

/* floating wrapper: shadow + optional tilt */
.bx-float{ position:absolute; box-shadow:var(--bx-shadow-lg); border-radius:var(--bx-r); }

/* ---- Card -------------------------------------------------- */
.bx-card{
  background:var(--bx-paper);
  border:1px solid var(--bx-line);
  border-radius:var(--bx-r);
  box-shadow:var(--bx-shadow);
}
.bx-card__pad{ padding:22px 24px; }

.bx-card-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.bx-card-title{ font-size:21px; font-weight:800; letter-spacing:-.01em; color:var(--bx-ink); }
.bx-card-sub{ font-size:13px; color:var(--bx-muted); margin-top:3px; font-weight:500; }
.bx-allbtn{ display:inline-flex; align-items:center; gap:6px; font-size:13.5px; font-weight:700; color:var(--bx-muted); }
.bx-allbtn svg{ width:15px; height:15px; }

/* ---- KPI stat card -------------------------------------------------- */
.bx-kpi{
  background:var(--bx-paper);
  border:1px solid var(--bx-line);
  border-radius:var(--bx-r);
  box-shadow:var(--bx-shadow);
  padding:18px 20px;
  display:flex; align-items:center; gap:15px;
}
.bx-kpi__txt{ min-width:0; }
.bx-kpi__icon{
  width:46px; height:46px; border-radius:13px; flex:0 0 auto;
  display:grid; place-items:center; color:var(--bx-blue);
  background:var(--bx-blue-tint);
}
.bx-kpi__icon svg{ width:22px; height:22px; }
.bx-kpi__label{ font-size:11px; font-weight:800; letter-spacing:.06em; color:var(--bx-faint); text-transform:uppercase; white-space:nowrap; }
.bx-kpi__value{ font-size:27px; font-weight:800; letter-spacing:-.02em; margin-top:3px; font-variant-numeric:tabular-nums; white-space:nowrap; }
.bx-kpi__value small{ font-size:18px; font-weight:700; color:var(--bx-muted); margin-right:2px; }

/* ---- Pills / tags -------------------------------------------------- */
.bx-pill{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; line-height:1;
  padding:7px 12px; border-radius:999px;
}
.bx-pill svg{ width:14px; height:14px; }
.bx-pill--sent{   background:var(--bx-blue-tint);  color:var(--bx-blue-700); }
.bx-pill--paid{   background:var(--bx-green-tint); color:var(--bx-green); }
.bx-pill--remind{ background:var(--bx-amber-tint); color:var(--bx-amber); }
.bx-pill--over{   background:var(--bx-coral-tint); color:var(--bx-coral); }

.bx-tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:12.5px; font-weight:700; line-height:1;
  padding:6px 11px; border-radius:8px;
}
.bx-tag--hoog{ background:var(--bx-amber-tint); color:var(--bx-amber); }
.bx-tag--proj{
  background:#fff; color:var(--bx-ink-2); border:1px solid var(--bx-line);
}
.bx-tag--proj .dot{ width:7px; height:7px; border-radius:50%; background:var(--bx-blue); }

/* ---- Avatars -------------------------------------------------- */
.bx-av{
  width:30px; height:30px; border-radius:50%; flex:0 0 auto;
  display:grid; place-items:center; color:#fff; font-size:11px; font-weight:800;
  border:2px solid #fff; letter-spacing:.02em;
}
.bx-av-stack{ display:flex; }
.bx-av-stack .bx-av + .bx-av{ margin-left:-9px; }
.bx-av--green{ background:#2C8B5B; }
.bx-av--navy{  background:#1F4E79; }
.bx-av--purple{background:#6B4FA8; }
.bx-av--blue{  background:var(--bx-blue); }
.bx-av--slate{ background:#475569; }

/* ---- Table rows -------------------------------------------------- */
.bx-tbl{ width:100%; }
.bx-tbl__head{
  display:grid; align-items:center;
  font-size:11.5px; font-weight:800; letter-spacing:.07em; color:var(--bx-faint);
  text-transform:uppercase; padding:0 4px 12px; border-bottom:1px solid var(--bx-line);
}
.bx-row{
  display:grid; align-items:center;
  padding:15px 4px; border-bottom:1px solid var(--bx-line-2);
  font-size:15px;
}
.bx-row:last-child{ border-bottom:0; }
.bx-row__nr{ color:var(--bx-blue); font-weight:700; font-variant-numeric:tabular-nums; }
.bx-row__name{ font-weight:700; color:var(--bx-ink); }
.bx-row__amt{ font-weight:800; text-align:right; font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.bx-row__due{ display:inline-flex; align-items:center; gap:7px; font-weight:700; }
.bx-row__due svg{ width:15px; height:15px; }
.bx-due-red{ color:var(--bx-coral); }
.bx-due-ink{ color:var(--bx-ink-2); }

.bx-client{ display:flex; align-items:center; gap:11px; }

/* ---- Buttons -------------------------------------------------- */
.bx-btn{
  display:inline-flex; align-items:center; gap:9px;
  font-size:14.5px; font-weight:700; padding:12px 18px; border-radius:12px;
  background:var(--bx-blue); color:#fff; border:none;
  box-shadow:0 10px 22px -8px rgba(0,144,223,.6);
}
.bx-btn svg{ width:17px; height:17px; }
.bx-btn--ghost{
  background:#fff; color:var(--bx-ink-2); border:1px solid var(--bx-line);
  box-shadow:var(--bx-shadow);
}
.bx-btn--ghost svg{ color:var(--bx-blue); }

/* ---- Progress -------------------------------------------------- */
.bx-bar{ height:10px; border-radius:999px; background:var(--bx-blue-tint); overflow:hidden; }
.bx-bar__fill{ height:100%; border-radius:999px; background:var(--bx-blue); }
.bx-bar--split{ background:var(--bx-coral-tint); }
.bx-bar--split .bx-bar__fill{ background:linear-gradient(90deg,#15A05C,#1bbd6d); }
.bx-bar--over .bx-bar__fill{ background:var(--bx-coral); }

/* ---- Kanban -------------------------------------------------- */
.bx-kcol{
  width:286px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14); border-radius:18px;
  padding:14px; backdrop-filter:blur(4px);
}
.bx-kcol__head{ display:flex; align-items:center; gap:9px; padding:4px 6px 14px; }
.bx-kcol__dot{ width:9px; height:9px; border-radius:50%; }
.bx-kcol__name{ font-size:15px; font-weight:800; color:#fff; }
.bx-kcol__count{ margin-left:auto; font-size:12.5px; font-weight:700; color:rgba(255,255,255,.6); font-variant-numeric:tabular-nums; }
/* light column variant for transparent boards */
.bx-kcol--light{ background:#F4F7FB; border:1px solid var(--bx-line); backdrop-filter:none; }
.bx-kcol--light .bx-kcol__name{ color:var(--bx-ink); }
.bx-kcol--light .bx-kcol__count{ color:var(--bx-muted); }
.bx-kcard{
  background:#fff; border-radius:13px; padding:15px 16px; margin-bottom:11px;
  box-shadow:0 8px 20px -10px rgba(6,28,55,.35);
}
.bx-kcard__title{ font-size:15px; font-weight:700; color:var(--bx-ink); line-height:1.35; margin-bottom:12px; }
.bx-kcard__foot{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; row-gap:8px; }
.bx-kcard__date{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:700; color:var(--bx-coral); }
.bx-kcard__date svg{ width:13px; height:13px; }
.bx-kcard__av{ margin-left:auto; }

/* ---- Calendar -------------------------------------------------- */
.bx-cal{ display:grid; grid-template-columns:repeat(7,1fr); gap:7px; }
.bx-cal__dow{ font-size:11px; font-weight:800; letter-spacing:.06em; color:var(--bx-faint); text-transform:uppercase; padding-bottom:4px; }
.bx-cal__cell{
  min-height:104px; border:1px solid var(--bx-line); border-radius:11px; padding:8px;
  background:#fff; display:flex; flex-direction:column; gap:4px;
}
.bx-cal__num{ font-size:13px; font-weight:700; color:var(--bx-ink-2); }
.bx-cal__cell--mut{ background:var(--bx-page); }
.bx-cal__cell--mut .bx-cal__num{ color:var(--bx-faint); }
.bx-cal__cell--hl{ background:#FFF7ED; border-color:#FBE2BD; }
.bx-cal__cell--hl .bx-cal__num{ color:var(--bx-amber); }
.bx-cal__cell--sel{ border-color:var(--bx-blue); box-shadow:0 0 0 2px var(--bx-blue-tint2); }
.bx-cal__evts{ display:flex; flex-direction:column; gap:3px; }
.bx-cal__chip{
  font-size:10px; font-weight:800; padding:3px 6px; border-radius:6px;
  display:flex; align-items:center; gap:5px; white-space:nowrap; overflow:hidden;
  background:var(--bx-blue-tint); color:var(--bx-blue-700);
}
.bx-cal__chip span:last-child{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bx-cal__dot{ width:5px; height:5px; border-radius:50%; background:currentColor; flex:0 0 auto; }
.bx-cal__chip--blue{ background:var(--bx-blue-tint); color:var(--bx-blue-700); }
.bx-cal__chip--green{ background:var(--bx-green-tint); color:var(--bx-green); }
.bx-cal__chip--amber{ background:var(--bx-amber-tint); color:var(--bx-amber); }
.bx-cal__chip--purple{ background:#ECE6F7; color:#6B4FA8; }
.bx-cal__chip--coral{ background:var(--bx-coral-tint); color:var(--bx-coral); }

/* ---- Donut + bar chart -------------------------------------------------- */
.bx-donut{ width:150px; height:150px; border-radius:50%; position:relative; }
.bx-donut::after{
  content:''; position:absolute; inset:26px; background:#fff; border-radius:50%;
  box-shadow:inset 0 1px 4px rgba(0,0,0,.04);
}
.bx-legend{ display:flex; flex-direction:column; gap:10px; }
.bx-legend__row{ display:flex; align-items:center; gap:9px; font-size:13.5px; font-weight:700; color:var(--bx-ink-2); }
.bx-legend__dot{ width:11px; height:11px; border-radius:3px; }
.bx-legend__val{ margin-left:auto; color:var(--bx-muted); font-variant-numeric:tabular-nums; }

.bx-bars{ display:flex; align-items:flex-end; gap:14px; height:160px; }
.bx-bars__col{ flex:1; display:flex; flex-direction:column; align-items:center; gap:8px; justify-content:flex-end; height:100%; }
.bx-bars__stack{ width:100%; display:flex; flex-direction:column; justify-content:flex-end; gap:3px; height:100%; }
.bx-bars__b{ width:100%; border-radius:6px 6px 4px 4px; }
.bx-bars__b--paid{ background:var(--bx-blue); }
.bx-bars__b--open{ background:var(--bx-blue-tint2); }
.bx-bars__lab{ font-size:11px; font-weight:700; color:var(--bx-faint); }

/* ---- Logo lockup -------------------------------------------------- */
.bx-logo{ display:inline-flex; align-items:center; gap:11px; }
.bx-logo__mark{
  width:38px; height:38px; border-radius:11px;
  background:linear-gradient(150deg,#13a3ed,#0072c4);
  display:grid; place-items:center; box-shadow:0 6px 16px -6px rgba(0,144,223,.7);
}
.bx-logo__mark span{ width:16px; height:16px; border-radius:50%; border:3.5px solid #fff; }
.bx-logo__name{ font-size:19px; font-weight:800; letter-spacing:-.01em; color:var(--bx-ink); }
.bx-logo__v{ font-size:11px; font-weight:800; color:var(--bx-muted); background:var(--bx-page); border:1px solid var(--bx-line); padding:2px 7px; border-radius:8px; }

/* small floating chips */
.bx-chip{
  display:inline-flex; align-items:center; gap:11px; background:#fff;
  border-radius:16px; padding:15px 20px; box-shadow:var(--bx-shadow-lg);
  font-size:15px; font-weight:700; color:var(--bx-ink);
}
.bx-chip__ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; flex:0 0 auto; }
.bx-chip small{ display:block; font-size:12px; font-weight:700; color:var(--bx-faint); letter-spacing:.04em; text-transform:uppercase; white-space:nowrap; }
.bx-chip b{ font-size:19px; font-weight:800; letter-spacing:-.01em; font-variant-numeric:tabular-nums; }

/* large chip variant */
.bx-chip--lg{ padding:19px 26px; border-radius:18px; gap:14px; }
.bx-chip--lg .bx-chip__ic{ width:54px; height:54px; border-radius:15px; }
.bx-chip--lg small{ font-size:13px; }
.bx-chip--lg b{ font-size:23px; }

/* extra-large chip variant */
.bx-chip--xl{ padding:26px 34px; border-radius:22px; gap:18px; }
.bx-chip--xl .bx-chip__ic{ width:70px; height:70px; border-radius:19px; }
.bx-chip--xl .bx-chip__ic svg{ width:32px; height:32px; }
.bx-chip--xl small{ font-size:14.5px; }
.bx-chip--xl b{ font-size:29px; }

/* xxl chip variant */
.bx-chip--xxl{ padding:30px 40px; border-radius:24px; gap:20px; }
.bx-chip--xxl .bx-chip__ic{ width:82px; height:82px; border-radius:22px; }
.bx-chip--xxl .bx-chip__ic svg{ width:38px; height:38px; }
.bx-chip--xxl small{ font-size:15.5px; }
.bx-chip--xxl b{ font-size:34px; }

/* eyebrow for blue scenes */
.bx-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.bx-eyebrow .d{ width:7px; height:7px; border-radius:50%; background:#39c0ff; box-shadow:0 0 0 4px rgba(57,192,255,.22); }
.bx-headline{ color:#fff; font-weight:800; letter-spacing:-.02em; line-height:1.05; }
.bx-sub-w{ color:rgba(255,255,255,.74); font-weight:500; line-height:1.5; }

