/* ============ TOKENS · Premium Light OS / Liquid Glass ============ */
  :root{
    --ink-1:#1A1D2B;          /* cool near-black */
    --ink-2:#565D71;
    --ink-3:#888FA3;
    --accent:#5B5BF0;         /* refined indigo-violet */
    --accent-2:#8A6CF2;
    --accent-deep:#4A48D8;
    --accent-soft:rgba(91,91,240,.12);
    --pos:#119A6F;
    --pos-soft:rgba(17,154,111,.12);
    --warn:#C2841E;
    --warn-soft:rgba(194,132,30,.14);
    --neg:#DD5248;
    /* glass */
    --glass:rgba(255,255,255,.58);
    --glass-strong:rgba(255,255,255,.72);
    --glass-border:rgba(255,255,255,.65);
    --glass-hi:inset 0 1px 0 rgba(255,255,255,.85);
    --blur:saturate(180%) blur(30px);
    --shadow-sm:0 2px 10px rgba(40,46,110,.07);
    --shadow-md:0 10px 34px rgba(40,46,110,.12), 0 2px 8px rgba(40,46,110,.06);
    --shadow-lg:0 24px 60px rgba(40,46,110,.18), 0 6px 16px rgba(40,46,110,.08);
    --radius:20px;
    --radius-sm:13px;
    --sidebar-w:240px;
    --ease:cubic-bezier(.16,1,.3,1);
  }
  *{ box-sizing:border-box; margin:0; padding:0; }
  html,body{ height:100%; }
  body{
    font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Manrope",system-ui,sans-serif;
    color:var(--ink-1); -webkit-font-smoothing:antialiased; font-size:14px; line-height:1.45; font-weight:500;
    position:relative; min-height:100vh; overflow-x:hidden;
  }
  /* soft aurora wallpaper — gives the glass something to refract */
  body::before{
    content:''; position:fixed; inset:-10%; z-index:0;
    background:
      radial-gradient(50% 50% at 12% 8%, rgba(120,140,255,.55), transparent 60%),
      radial-gradient(46% 46% at 88% 6%, rgba(176,130,255,.5), transparent 60%),
      radial-gradient(50% 50% at 80% 92%, rgba(120,220,200,.42), transparent 60%),
      radial-gradient(48% 48% at 18% 96%, rgba(255,176,150,.4), transparent 60%),
      linear-gradient(135deg,#EAECF7,#F1EEFA 50%,#EAF2F4);
    filter:saturate(112%);
  }
  .tnum{ font-variant-numeric:tabular-nums; }

  .app{ display:grid; grid-template-columns:var(--sidebar-w) 1fr; min-height:100vh; position:relative; z-index:1; padding:14px; gap:14px; }

  /* ============ SIDEBAR (glass) ============ */
  .sidebar{ background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); border:1px solid var(--glass-border); border-radius:24px; box-shadow:var(--shadow-md), var(--glass-hi); display:flex; flex-direction:column; padding:18px 14px 14px; position:sticky; top:14px; height:calc(100vh - 28px); }
  .brand{ display:flex; align-items:center; gap:10px; padding:6px 8px 20px; }
  .brand-mark{ width:29px; height:29px; border-radius:9px; background:linear-gradient(150deg,var(--accent-2),var(--accent-deep)); display:grid; place-items:center; color:#fff; font-weight:800; font-size:15px; box-shadow:0 4px 12px rgba(74,72,216,.45), inset 0 1px 0 rgba(255,255,255,.4); }
  .brand-name{ font-weight:700; font-size:16px; letter-spacing:-.02em; }
  .nav-group{ display:flex; flex-direction:column; gap:2px; }
  .nav-label{ font-size:11px; font-weight:700; color:var(--ink-3); text-transform:uppercase; letter-spacing:.07em; padding:15px 8px 6px; }
  .nav-item{ display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:11px; color:var(--ink-2); font-weight:600; font-size:13.5px; cursor:pointer; transition:.16s var(--ease); border:none; background:none; width:100%; text-align:left; text-decoration:none; }
  .nav-item svg{ width:17px; height:17px; stroke-width:1.9; flex-shrink:0; opacity:.8; }
  .nav-item:hover{ background:rgba(255,255,255,.55); color:var(--ink-1); }
  .nav-item.active{ background:rgba(255,255,255,.85); color:var(--accent-deep); box-shadow:0 2px 8px rgba(40,46,110,.1), inset 0 1px 0 rgba(255,255,255,.9); }
  .nav-item.active svg{ opacity:1; }
  .nav-badge{ margin-left:auto; font-size:11px; font-weight:700; color:var(--ink-3); background:rgba(255,255,255,.6); border-radius:20px; padding:1px 7px; }
  .nav-item.active .nav-badge{ background:var(--accent-soft); color:var(--accent-deep); }
  .sidebar-foot{ margin-top:auto; }
  .profile{ display:flex; align-items:center; gap:10px; padding:8px; border-radius:13px; cursor:pointer; transition:.16s var(--ease); }
  .profile:hover{ background:rgba(255,255,255,.55); }
  .avatar{ width:31px; height:31px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700; font-size:11px; flex-shrink:0; box-shadow:inset 0 1px 0 rgba(255,255,255,.4); }
  .profile-meta{ line-height:1.25; min-width:0; }
  .profile-name{ font-weight:700; font-size:13px; }
  .profile-plan{ font-size:11px; color:var(--ink-3); }
  .profile-chev{ margin-left:auto; color:var(--ink-3); }

  /* ============ MAIN ============ */
  .main{ display:flex; flex-direction:column; min-width:0; }
  .topbar{ display:flex; align-items:center; gap:14px; padding:12px 16px; border-radius:18px; background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); border:1px solid var(--glass-border); box-shadow:var(--shadow-sm), var(--glass-hi); position:sticky; top:14px; z-index:6; margin-bottom:14px; }
  .search{ display:flex; align-items:center; gap:9px; flex:1; max-width:420px; background:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.7); border-radius:12px; padding:9px 13px; color:var(--ink-3); cursor:text; transition:.15s; }
  .search:hover{ background:rgba(255,255,255,.7); }
  .search svg{ width:15px; height:15px; }
  .search span{ font-size:13px; }
  .kbd{ margin-left:auto; font-size:11px; font-weight:700; color:var(--ink-3); background:rgba(255,255,255,.7); border:1px solid rgba(255,255,255,.8); border-radius:6px; padding:1px 6px; }
  .topbar-actions{ display:flex; align-items:center; gap:8px; margin-left:auto; }
  .icon-btn{ width:37px; height:37px; border-radius:11px; border:1px solid rgba(255,255,255,.7); background:rgba(255,255,255,.5); display:grid; place-items:center; cursor:pointer; color:var(--ink-2); transition:.15s; position:relative; }
  .icon-btn:hover{ background:rgba(255,255,255,.8); color:var(--ink-1); }
  .icon-btn svg{ width:17px; height:17px; stroke-width:1.9; }
  .dot{ position:absolute; top:8px; right:9px; width:7px; height:7px; border-radius:50%; background:var(--accent); border:1.5px solid #fff; }
  .btn-primary{ display:flex; align-items:center; gap:7px; background:linear-gradient(180deg,var(--accent-2),var(--accent-deep)); color:#fff; border:none; border-radius:12px; padding:9px 16px; font-weight:700; font-size:13.5px; cursor:pointer; box-shadow:0 4px 14px rgba(74,72,216,.4), inset 0 1px 0 rgba(255,255,255,.35); transition:transform .12s var(--ease), box-shadow .15s, filter .15s; }
  .btn-primary:hover{ filter:brightness(1.06); box-shadow:0 8px 22px rgba(74,72,216,.46); }
  .btn-primary:active{ transform:translateY(1px); }
  .btn-primary svg{ width:16px; height:16px; stroke-width:2.2; }

  .content{ max-width:1240px; width:100%; padding-bottom:30px; }
  .head-row{ display:flex; align-items:flex-start; justify-content:space-between; gap:20px; margin-bottom:20px; padding:0 4px; }
  .greeting{ font-size:27px; font-weight:800; letter-spacing:-.03em; }
  .subgreet{ color:var(--ink-2); font-size:14px; margin-top:4px; font-weight:500; }
  .range{ display:flex; align-items:center; gap:7px; background:var(--glass-strong); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); border:1px solid var(--glass-border); border-radius:12px; padding:9px 14px; font-size:13px; font-weight:600; color:var(--ink-1); cursor:pointer; transition:.15s; box-shadow:var(--shadow-sm); flex-shrink:0; }
  .range svg{ width:15px; height:15px; color:var(--ink-3); }

  /* ============ AI INSIGHT ============ */
  .insight{ display:flex; align-items:center; gap:14px; padding:15px 17px; border-radius:18px; margin-bottom:14px; background:linear-gradient(100deg, rgba(245,198,82,.94), rgba(231,168,52,.92)); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); border:1px solid rgba(255,255,255,.55); box-shadow:0 12px 30px rgba(200,144,38,.3), inset 0 1px 0 rgba(255,255,255,.62); color:var(--ink-1); position:relative; overflow:hidden; }
  .insight::after{ content:''; position:absolute; right:-30px; top:-50px; width:200px; height:160px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.42),transparent 70%); pointer-events:none; }
  .insight-ic{ width:34px; height:34px; border-radius:11px; flex-shrink:0; display:grid; place-items:center; color:#fff; background:linear-gradient(145deg,#BD7E16,#915E0C); box-shadow:0 4px 12px rgba(140,92,16,.4); position:relative; }
  .insight-ic svg{ width:18px; height:18px; }
  .insight-txt{ font-size:14px; color:var(--ink-1); line-height:1.5; position:relative; }
  .insight-txt b{ font-weight:700; color:var(--ink-1); }
  .insight-txt .accent{ color:var(--ink-1); font-weight:800; }
  .insight-cta{ margin-left:auto; font-size:12.5px; font-weight:700; color:var(--ink-1); white-space:nowrap; padding:8px 15px; border-radius:11px; border:1px solid rgba(0,0,0,.12); background:rgba(255,255,255,.72); cursor:pointer; transition:.15s; flex-shrink:0; position:relative; }
  .insight-cta:hover{ background:#fff; }

  /* ============ glass card base ============ */
  .glass{ background:var(--glass-strong); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); border:1px solid var(--glass-border); box-shadow:var(--shadow-md), var(--glass-hi); }

  /* ============ KPI STRIP · solid-colour glass tiles ============ */
  .kpis{ display:grid; grid-template-columns:1.55fr 1fr 1fr 1fr; gap:14px; margin-bottom:14px; }
  .kpi{ border-radius:var(--radius); padding:18px 19px; transition:box-shadow .22s var(--ease), transform .22s var(--ease); position:relative; overflow:hidden; color:#fff; border:1px solid rgba(255,255,255,.32); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur); box-shadow:0 10px 30px rgba(40,46,110,.16), inset 0 1px 0 rgba(255,255,255,.5); }
  .kpi::after{ content:''; position:absolute; right:-50px; top:-62px; width:175px; height:175px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.32),transparent 70%); pointer-events:none; }
  .kpi:hover{ transform:translateY(-3px); box-shadow:0 18px 46px rgba(40,46,110,.26), inset 0 1px 0 rgba(255,255,255,.55); }
  .kpi.c-violet{ background:linear-gradient(155deg, rgba(140,118,246,.92), rgba(84,66,214,.9)); box-shadow:0 12px 32px rgba(84,66,214,.34), inset 0 1px 0 rgba(255,255,255,.5); }
  .kpi.c-red{ background:linear-gradient(155deg, rgba(201,74,62,.95), rgba(164,38,31,.95)); box-shadow:0 12px 32px rgba(164,38,31,.32), inset 0 1px 0 rgba(255,255,255,.5); }
  .kpi.c-blue{ background:linear-gradient(155deg, rgba(82,128,228,.94), rgba(50,92,200,.94)); box-shadow:0 12px 32px rgba(50,92,200,.32), inset 0 1px 0 rgba(255,255,255,.5); }
  .kpi.c-teal{ background:linear-gradient(155deg, rgba(38,156,122,.95), rgba(20,116,90,.95)); box-shadow:0 12px 32px rgba(20,116,90,.32), inset 0 1px 0 rgba(255,255,255,.5); }
  .kpi-label{ font-size:11.5px; font-weight:700; color:rgba(255,255,255,.92); text-transform:uppercase; letter-spacing:.06em; display:flex; align-items:center; gap:7px; }
  .kpi-label .ic{ width:15px; height:15px; color:rgba(255,255,255,.9); stroke-width:2; }
  .kpi-val{ font-size:27px; font-weight:800; letter-spacing:-.035em; margin-top:12px; color:#fff; }
  .kpi.hero .kpi-val{ font-size:39px; letter-spacing:-.04em; }
  .kpi-sub{ display:flex; align-items:center; gap:8px; margin-top:9px; font-size:12.5px; position:relative; }
  .delta{ display:inline-flex; align-items:center; gap:3px; font-weight:700; padding:1px 8px; border-radius:20px; background:rgba(255,255,255,.26); color:#fff; }
  .delta svg{ width:12px; height:12px; stroke-width:2.8; }
  .kpi-sub .muted{ color:rgba(255,255,255,.78); font-weight:500; }
  .goal{ margin-top:15px; position:relative; }
  .goal-top{ display:flex; justify-content:space-between; font-size:11.5px; color:rgba(255,255,255,.8); margin-bottom:6px; font-weight:600; }
  .goal-bar{ height:7px; border-radius:20px; background:rgba(255,255,255,.26); overflow:hidden; }
  .goal-fill{ height:100%; border-radius:20px; background:rgba(255,255,255,.96); width:0; }
  .spark{ margin-top:13px; height:30px; width:100%; display:block; }

  /* ============ BENTO ============ */
  .bento{ display:grid; grid-template-columns:1.62fr 1fr; gap:14px; }
  .col{ display:flex; flex-direction:column; gap:14px; }
  .card{ border-radius:var(--radius); overflow:hidden; transition:box-shadow .22s var(--ease); }
  .card:hover{ box-shadow:var(--shadow-lg), var(--glass-hi); }
  .card-head{ display:flex; align-items:center; justify-content:space-between; padding:17px 19px 12px; }
  .card-title{ font-size:15px; font-weight:700; letter-spacing:-.01em; }
  .card-sub{ font-size:12px; color:var(--ink-3); margin-top:2px; font-weight:500; }
  .card-action{ font-size:12.5px; color:var(--accent-deep); font-weight:700; cursor:pointer; padding:5px 10px; border-radius:9px; transition:background .15s; }
  .card-action:hover{ background:var(--accent-soft); }
  .mini-range{ display:flex; gap:2px; background:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.6); border-radius:10px; padding:2px; }
  .mini-range button{ border:none; background:none; font:inherit; font-size:12px; font-weight:700; color:var(--ink-2); padding:4px 10px; border-radius:8px; cursor:pointer; transition:.15s; }
  .mini-range button.on{ background:#fff; color:var(--ink-1); box-shadow:var(--shadow-sm); }

  .chart-wrap{ padding:6px 10px 12px; position:relative; }
  #revChart{ width:100%; height:190px; display:block; }
  .chart-legend{ display:flex; gap:16px; padding:0 19px 4px; }
  .lg{ display:flex; align-items:center; gap:6px; font-size:11.5px; color:var(--ink-2); font-weight:600; }
  .lg i{ width:14px; height:3px; border-radius:2px; display:inline-block; }
  .chart-foot{ display:flex; justify-content:space-between; padding:6px 16px 4px; }
  .chart-foot span{ font-size:11px; color:var(--ink-3); font-weight:600; }
  .chart-tip{ position:absolute; pointer-events:none; opacity:0; transform:translate(-50%,-10px); background:var(--ink-1); color:#fff; font-size:12px; font-weight:700; padding:6px 10px; border-radius:9px; white-space:nowrap; transition:opacity .12s; box-shadow:var(--shadow-md); }
  .chart-tip::after{ content:''; position:absolute; left:50%; top:100%; transform:translateX(-50%); border:5px solid transparent; border-top-color:var(--ink-1); }

  .pipe{ padding:6px 19px 19px; display:flex; flex-direction:column; gap:14px; }
  .pipe-row{ display:flex; flex-direction:column; gap:6px; }
  .pipe-top{ display:flex; align-items:center; justify-content:space-between; font-size:13px; }
  .pipe-name{ display:flex; align-items:center; gap:8px; color:var(--ink-1); font-weight:600; }
  .pipe-pill{ font-size:11px; color:var(--ink-3); font-weight:700; background:rgba(255,255,255,.6); border-radius:20px; padding:1px 7px; }
  .pipe-val{ font-weight:700; }
  .pipe-bar{ height:8px; border-radius:20px; background:rgba(74,72,216,.1); overflow:hidden; }
  .pipe-fill{ height:100%; border-radius:20px; width:0; }

  .list{ padding:4px 9px 11px; }
  .li{ display:flex; align-items:center; gap:12px; padding:10px; border-radius:13px; transition:background .15s var(--ease); cursor:pointer; }
  .li:hover{ background:rgba(255,255,255,.55); }
  .check{ width:18px; height:18px; border-radius:6px; border:1.6px solid #C2C6D4; flex-shrink:0; display:grid; place-items:center; transition:.15s var(--ease); background:rgba(255,255,255,.7); }
  .check svg{ width:11px; height:11px; opacity:0; stroke:#fff; stroke-width:3; transition:opacity .12s; }
  .li.done .check{ background:var(--accent); border-color:var(--accent); }
  .li.done .check svg{ opacity:1; }
  .li.done .li-title{ color:var(--ink-3); text-decoration:line-through; }
  .li-body{ min-width:0; flex:1; }
  .li-title{ font-size:13.5px; font-weight:600; transition:.15s; }
  .li-meta{ font-size:12px; color:var(--ink-3); margin-top:1px; font-weight:500; }
  .li-chip{ font-size:11px; font-weight:700; padding:2px 8px; border-radius:20px; flex-shrink:0; }
  .chip-due{ color:var(--warn); background:var(--warn-soft); }
  .chip-today{ color:var(--accent-deep); background:var(--accent-soft); }
  .li-amt{ font-weight:700; font-size:13px; flex-shrink:0; }
  .av{ width:31px; height:31px; border-radius:10px; flex-shrink:0; display:grid; place-items:center; color:#fff; font-weight:700; font-size:11px; box-shadow:inset 0 1px 0 rgba(255,255,255,.35); }
  .av.rnd{ border-radius:50%; }

  /* ============ COMMAND PALETTE ============ */
  .cmdk-overlay{ position:fixed; inset:0; background:rgba(26,29,43,.28); backdrop-filter:blur(4px); display:none; align-items:flex-start; justify-content:center; padding-top:14vh; z-index:50; }
  .cmdk-overlay.open{ display:flex; }
  .cmdk{ width:560px; max-width:92vw; background:rgba(255,255,255,.82); backdrop-filter:saturate(180%) blur(40px); -webkit-backdrop-filter:saturate(180%) blur(40px); border:1px solid rgba(255,255,255,.8); border-radius:20px; box-shadow:var(--shadow-lg), var(--glass-hi); overflow:hidden; animation:pop .18s var(--ease); }
  @keyframes pop{ from{ transform:scale(.97) translateY(-6px); opacity:0; } to{ transform:none; opacity:1; } }
  .cmdk-input{ display:flex; align-items:center; gap:11px; padding:16px 18px; border-bottom:1px solid rgba(0,0,0,.06); }
  .cmdk-input svg{ width:18px; height:18px; color:var(--ink-3); }
  .cmdk-input input{ border:none; outline:none; font:inherit; font-size:15px; width:100%; color:var(--ink-1); background:none; }
  .cmdk-list{ padding:7px; max-height:340px; overflow:auto; }
  .cmdk-sec{ font-size:11px; font-weight:700; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em; padding:9px 10px 5px; }
  .cmdk-item{ display:flex; align-items:center; gap:11px; padding:10px; border-radius:11px; cursor:pointer; font-size:13.5px; font-weight:600; }
  .cmdk-item svg{ width:16px; height:16px; color:var(--ink-2); stroke-width:1.9; }
  .cmdk-item.sel,.cmdk-item:hover{ background:var(--accent-soft); color:var(--accent-deep); }
  .cmdk-item.sel svg,.cmdk-item:hover svg{ color:var(--accent-deep); }
  .cmdk-item .ck{ margin-left:auto; font-size:11px; color:var(--ink-3); }

  /* accessibility: visible keyboard focus on every control */
  a,button,[tabindex],.nav-item,.li,.search,.range,.card-action,.cmdk-item,.mini-range button,.insight-cta{ outline:none; }
  :focus-visible{ outline:2.5px solid var(--accent); outline-offset:2px; border-radius:9px; }
  .reveal-init{ opacity:0; transform:translateY(14px); }

  @media (max-width:1080px){ .kpis{ grid-template-columns:1fr 1fr; } .bento{ grid-template-columns:1fr; } }
  @media (max-width:720px){ .app{ grid-template-columns:1fr; } .sidebar{ display:none; } .kpis{ grid-template-columns:1fr; } .insight{ flex-wrap:wrap; } }
  @media (prefers-reduced-motion:reduce){ *{ transition:none!important; animation:none!important; } }

/* ============ PAGE HEADER (non-dashboard pages) ============ */
.page-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:20px; padding:0 4px; }
.page-title{ font-size:24px; font-weight:800; letter-spacing:-.03em; }
.page-sub{ color:var(--ink-2); font-size:14px; margin-top:4px; font-weight:500; }
.seg{ display:flex; gap:2px; background:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.6); border-radius:11px; padding:3px; backdrop-filter:var(--blur); }
.seg button{ border:none; background:none; font:inherit; font-size:13px; font-weight:600; color:var(--ink-2); padding:6px 13px; border-radius:8px; cursor:pointer; transition:.15s; }
.seg button.on{ background:#fff; color:var(--ink-1); box-shadow:var(--shadow-sm); }

/* ============ SUMMARY MINI-TILES ============ */
.sumrow{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:16px; }
.sumtile{ border-radius:16px; padding:15px 17px; color:#fff; position:relative; overflow:hidden; border:1px solid rgba(255,255,255,.3); box-shadow:0 10px 28px rgba(40,46,110,.15), inset 0 1px 0 rgba(255,255,255,.5); }
.sumtile::after{ content:''; position:absolute; right:-40px; top:-50px; width:140px; height:140px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.3),transparent 70%); }
.sumtile .sl{ font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.9); }
.sumtile .sv{ font-size:24px; font-weight:800; letter-spacing:-.03em; margin-top:7px; }
.sumtile .sm{ font-size:12px; color:rgba(255,255,255,.8); margin-top:3px; font-weight:500; }
.s-teal{ background:linear-gradient(155deg, rgba(38,156,122,.95), rgba(20,116,90,.95)); }
.s-amber{ background:linear-gradient(155deg, rgba(199,118,42,.95), rgba(162,86,22,.95)); }
.s-red{ background:linear-gradient(155deg, rgba(201,74,62,.95), rgba(164,38,31,.95)); }

/* ============ KANBAN BOARD (Pipeline) ============ */
.board{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; align-items:start; }
.board-col{ border-radius:18px; padding:12px; background:rgba(255,255,255,.4); backdrop-filter:var(--blur); border:1px solid rgba(255,255,255,.5); box-shadow:var(--shadow-sm), var(--glass-hi); min-height:300px; }
.board-colhead{ display:flex; align-items:center; justify-content:space-between; padding:6px 8px 12px; }
.board-coltitle{ display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--ink-1); }
.col-dot{ width:9px; height:9px; border-radius:50%; }
.board-count{ font-size:11px; font-weight:700; color:var(--ink-3); background:rgba(255,255,255,.7); border-radius:20px; padding:1px 8px; }
.board-sum{ font-size:11.5px; color:var(--ink-3); font-weight:600; padding:0 8px 10px; }
.deal{ background:var(--surface); border:1px solid var(--border); border-radius:13px; padding:13px; margin-bottom:10px; box-shadow:var(--shadow-sm); cursor:grab; transition:box-shadow .18s var(--ease), transform .18s var(--ease); }
.deal:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px); }
.deal:active{ cursor:grabbing; }
.deal-top{ display:flex; align-items:center; gap:9px; margin-bottom:10px; }
.deal-name{ font-size:13.5px; font-weight:700; }
.deal-co{ font-size:11.5px; color:var(--ink-3); }
.deal-val{ font-size:16px; font-weight:800; letter-spacing:-.02em; }
.deal-meta{ display:flex; align-items:center; justify-content:space-between; margin-top:9px; }
.deal-tag{ font-size:10.5px; font-weight:700; padding:2px 8px; border-radius:20px; }
.deal-days{ font-size:11px; color:var(--ink-3); font-weight:600; }

/* ============ TABLE (Invoices) ============ */
.tbl-wrap{ overflow:hidden; }
.tbl{ width:100%; border-collapse:collapse; }
.tbl th{ text-align:left; font-size:11px; font-weight:700; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em; padding:12px 18px; border-bottom:1px solid var(--border); }
.tbl th.r,.tbl td.r{ text-align:right; }
.tbl td{ padding:14px 18px; border-bottom:1px solid var(--border); font-size:13.5px; }
.tbl tr:last-child td{ border-bottom:none; }
.tbl tbody tr{ transition:background .15s; cursor:pointer; }
.tbl tbody tr:hover{ background:rgba(255,255,255,.55); }
.cellc{ display:flex; align-items:center; gap:11px; }
.inv-id{ font-weight:700; }
.stat{ display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; padding:3px 10px; border-radius:20px; }
.stat i{ width:6px; height:6px; border-radius:50%; }
.stat.paid{ color:var(--pos); background:var(--pos-soft); } .stat.paid i{ background:var(--pos); }
.stat.due{ color:var(--warn); background:var(--warn-soft); } .stat.due i{ background:var(--warn); }
.stat.over{ color:var(--neg); background:rgba(221,82,72,.13); } .stat.over i{ background:var(--neg); }

/* ============ CLIENT DETAIL ============ */
.client-hero{ display:flex; align-items:center; gap:18px; padding:22px; margin-bottom:14px; border-radius:var(--radius); }
.client-av{ width:64px; height:64px; border-radius:20px; display:grid; place-items:center; color:#fff; font-weight:800; font-size:24px; flex-shrink:0; box-shadow:inset 0 1px 0 rgba(255,255,255,.35); }
.client-h-name{ font-size:21px; font-weight:800; letter-spacing:-.02em; }
.client-h-meta{ color:var(--ink-2); font-size:13.5px; margin-top:3px; display:flex; gap:14px; flex-wrap:wrap; }
.client-h-meta span{ display:flex; align-items:center; gap:5px; }
.client-h-meta svg{ width:14px; height:14px; color:var(--ink-3); }
.client-stat{ margin-left:auto; display:flex; gap:26px; text-align:right; }
.client-stat .cs-v{ font-size:20px; font-weight:800; letter-spacing:-.02em; }
.client-stat .cs-l{ font-size:11px; color:var(--ink-3); font-weight:600; text-transform:uppercase; letter-spacing:.05em; margin-top:2px; }
.timeline{ padding:6px 20px 18px; }
.tl{ display:flex; gap:14px; padding:11px 0; position:relative; }
.tl::before{ content:''; position:absolute; left:15px; top:30px; bottom:-11px; width:1.5px; background:var(--border-strong); }
.tl:last-child::before{ display:none; }
.tl-dot{ width:32px; height:32px; border-radius:50%; flex-shrink:0; display:grid; place-items:center; color:#fff; z-index:1; box-shadow:inset 0 1px 0 rgba(255,255,255,.3); }
.tl-dot svg{ width:15px; height:15px; stroke-width:2; }
.tl-body{ flex:1; padding-top:3px; }
.tl-title{ font-size:13.5px; font-weight:600; }
.tl-meta{ font-size:12px; color:var(--ink-3); margin-top:1px; }
.tl-amt{ font-weight:700; font-size:13.5px; }

/* ============ MOBILE FRAME ============ */
.stage{ min-height:100vh; display:grid; place-items:center; padding:40px; position:relative; z-index:1; }
.phone{ width:390px; height:840px; border-radius:54px; background:#0E1018; padding:11px; box-shadow:0 40px 90px rgba(40,46,110,.34), 0 0 0 2px rgba(255,255,255,.5), inset 0 0 0 2px rgba(0,0,0,.6); position:relative; }
.phone-screen{ width:100%; height:100%; border-radius:44px; overflow:hidden; position:relative; background:linear-gradient(135deg,#EAECF7,#F1EEFA 50%,#EAF2F4); }
.phone-notch{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:122px; height:32px; background:#0E1018; border-radius:0 0 18px 18px; z-index:10; }
.m-aurora{ position:absolute; inset:0; background:radial-gradient(60% 40% at 15% 6%, rgba(120,140,255,.5), transparent 60%),radial-gradient(50% 36% at 92% 4%, rgba(176,130,255,.45), transparent 60%),radial-gradient(54% 40% at 84% 96%, rgba(120,220,200,.4), transparent 60%); }
.m-scroll{ position:absolute; inset:0; overflow:auto; padding:54px 16px 28px; }
.m-status{ display:flex; justify-content:space-between; align-items:center; font-size:13px; font-weight:700; color:var(--ink-1); padding:0 6px 10px; }
.m-hello{ font-size:22px; font-weight:800; letter-spacing:-.02em; padding:4px 4px 2px; }
.m-sub{ font-size:13px; color:var(--ink-2); padding:0 4px 16px; font-weight:500; }
.m-hero{ border-radius:22px; padding:20px; color:#fff; background:linear-gradient(155deg, rgba(140,118,246,.95), rgba(84,66,214,.95)); box-shadow:0 14px 30px rgba(84,66,214,.4), inset 0 1px 0 rgba(255,255,255,.4); margin-bottom:13px; position:relative; overflow:hidden; }
.m-hero::after{ content:''; position:absolute; right:-30px; top:-40px; width:150px; height:150px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.28),transparent 70%); }
.m-hero .ml{ font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.9); }
.m-hero .mv{ font-size:36px; font-weight:800; letter-spacing:-.035em; margin-top:8px; }
.m-hero .md{ font-size:12.5px; color:rgba(255,255,255,.85); margin-top:6px; }
.m-row2{ display:grid; grid-template-columns:1fr 1fr; gap:11px; margin-bottom:13px; }
.m-tile{ border-radius:18px; padding:15px; color:#fff; box-shadow:0 8px 20px rgba(40,46,110,.18), inset 0 1px 0 rgba(255,255,255,.4); }
.m-tile .ml{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:rgba(255,255,255,.9); }
.m-tile .mv{ font-size:21px; font-weight:800; letter-spacing:-.02em; margin-top:6px; }
.m-card{ background:var(--glass-strong); backdrop-filter:var(--blur); border:1px solid var(--glass-border); border-radius:18px; box-shadow:var(--shadow-sm), var(--glass-hi); padding:15px; margin-bottom:13px; }
.m-card-h{ display:flex; align-items:center; justify-content:space-between; font-size:13.5px; font-weight:700; margin-bottom:11px; }
.m-card-h a{ font-size:12px; color:var(--accent-deep); font-weight:700; }
.m-tab{ position:absolute; bottom:0; left:0; right:0; height:74px; background:rgba(255,255,255,.7); backdrop-filter:var(--blur); border-top:1px solid var(--glass-border); display:flex; justify-content:space-around; align-items:center; padding-bottom:14px; }
.m-tab a{ display:flex; flex-direction:column; align-items:center; gap:3px; font-size:10px; font-weight:600; color:var(--ink-3); }
.m-tab a.on{ color:var(--accent-deep); }
.m-tab svg{ width:22px; height:22px; stroke-width:1.9; }

/* ============ CoverTurn prototype banner ============ */
.cv-banner{
  position:sticky; top:0; left:0; right:0; z-index:9999;
  display:flex; align-items:center; justify-content:center; gap:16px;
  padding:10px 20px;
  background:#FAF8F4;
  border-bottom:1px solid rgba(26,29,43,0.09);
  box-shadow:0 1px 0 rgba(26,29,43,0.02);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Manrope",system-ui,sans-serif;
  font-size:12.5px; font-weight:500; line-height:1.4; letter-spacing:0.005em;
  color:#1A1D2B;
}
.cv-banner__dot{ width:7px; height:7px; border-radius:50%; background:#C9501F; flex-shrink:0; }
.cv-banner__text{ color:#565D71; }
.cv-banner__text strong{ color:#1A1D2B; font-weight:600; }
.cv-banner__link{
  color:#C9501F; text-decoration:none; font-weight:600;
  border-bottom:1px solid rgba(201,80,31,0.3); padding-bottom:1px;
  transition:border-color .2s ease;
}
.cv-banner__link:hover{ border-bottom-color:#C9501F; }
@media (max-width:600px){
  .cv-banner{ padding:8px 14px; font-size:11.5px; gap:10px; }
  .cv-banner__link{ display:none; }
}
