  /* ============ Cornerstone Stores — "warm modern" tokens ============
     Base palette kept identical to the CS brand (flaxen / forrest / brick / sand / concrete).
     Everything else — type, radius, shadow, gradients — is a deliberate departure toward a
     2024-era warm fintech/app feel (Revolut/Monzo energy, CS colours). */
  :root{
    --flaxen:#FCFAF1;
    --flaxen-warm:#F5F0E0;
    --flaxen-cool:#EFEAD9;
    --forrest:#004645;
    --forrest-deep:#003433;
    --forrest-tint:#1F5E5C;
    --brick:#7E4E2C;
    --brick-deep:#5E3920;
    --brick-tint:#A47656;
    --sand:#C8B89A;
    --concrete:#9AA09B;
    --ink:#1A1A1A;
    --fg2:#2E4A48;
    --fg3:#6B7776;
    --hairline:rgba(0,70,69,0.14);
    --hairline-soft:rgba(0,70,69,0.08);

    /* semantic status — kept warm/earthy so they still feel like the brand, not stock traffic-lights */
    --ok:#2F6F4E;
    --ok-bg:#E4EEE4;
    --warn:#B4841F;
    --warn-bg:#F5ECD8;
    --bad:#B23B2E;
    --bad-bg:#F5E1DC;
    --info:#1F5E5C;
    --info-bg:#E1EBEA;
    --neutral-bg:#ECE7DC;

    /* new for the warm-modern pass: a lively terracotta "pop" accent + gradients + glows */
    --accent:#E2703D;
    --accent-deep:#B8552A;
    --accent-bg:#FCE6D8;
    --grad-forrest:linear-gradient(135deg,#0E7A73 0%,#004645 55%,#00302F 100%);
    --grad-brick:linear-gradient(135deg,#D98A54 0%,#7E4E2C 100%);
    --glow-forrest:0 10px 26px -8px rgba(0,70,69,0.45);
    --glow-accent:0 10px 24px -6px rgba(216,102,54,0.4);

    --font-display:"Plus Jakarta Sans","Inter",-apple-system,"Helvetica Neue",Arial,sans-serif;
    --font-body:"Plus Jakarta Sans","Inter",-apple-system,"Helvetica Neue",Arial,sans-serif;
    --font-hero:"Fraunces","Plus Jakarta Sans",Georgia,serif; /* used once, deliberately — the bank-balance hero figure only */

    --radius-card:20px;
    --radius-tile:16px;
    --radius-sm:12px;
    --radius-xs:8px;
    --radius-pill:999px;

    --ease:cubic-bezier(.16,1,.3,1);

    --shadow-1:0 1px 2px rgba(0,40,38,0.05), 0 1px 1px rgba(0,40,38,0.04);
    --shadow-2:0 10px 24px -8px rgba(0,60,58,0.16), 0 2px 8px rgba(0,60,58,0.06);
    --shadow-3:0 28px 64px -16px rgba(0,30,29,0.32), 0 10px 28px -6px rgba(0,30,29,0.14);
  }

  *{box-sizing:border-box;}
  html,body{height:100%;}
  body{
    margin:0;
    font-family:var(--font-body);
    background:var(--flaxen-cool);
    color:var(--ink);
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-family:var(--font-display);font-weight:700;color:var(--forrest);margin:0;letter-spacing:-0.02em;}
  a{color:inherit;}
  ::selection{background:var(--forrest);color:var(--flaxen);}

  /* visible keyboard focus everywhere — forrest ring on light surfaces, sand ring on the dark sidebar */
  :focus-visible{outline:2px solid var(--forrest);outline-offset:2px;border-radius:4px;}
  .sidebar :focus-visible{outline-color:var(--sand);}

  .canvas{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px;
    background:
      radial-gradient(circle at 15% 0%, rgba(0,70,69,0.06), transparent 55%),
      radial-gradient(circle at 85% 100%, rgba(216,102,54,0.05), transparent 50%),
      var(--flaxen-cool);
  }

  .app-shell{
    width:100%;
    max-width:1440px;
    height:min(920px, 94vh);
    background:var(--flaxen);
    border-radius:26px;
    box-shadow:var(--shadow-3);
    border:1px solid var(--hairline);
    display:flex;
    overflow:hidden;
  }

  /* ============ Sidebar ============ */
  .sidebar{
    width:248px;
    flex:0 0 248px;
    background:var(--forrest);
    color:var(--flaxen);
    display:flex;
    flex-direction:column;
    padding:26px 16px 18px;
    transition:width 220ms var(--ease), flex-basis 220ms var(--ease), transform 260ms var(--ease);
    overflow-x:hidden;
    position:relative;
  }
  .brand-lockup{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:8px;
    padding:4px 6px 24px 10px;
    border-bottom:1px solid rgba(252,250,241,0.14);
    margin-bottom:16px;
  }
  .brand-logo-img{
    height:40px;
    width:auto;
    display:block;
  }
  .brand-lockup .sub{
    display:block;
    margin-top:8px;
    font-family:var(--font-body);
    font-size:10.5px;
    font-weight:500;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--sand);
    white-space:nowrap;
  }
  .brand-mini{
    display:none;
    width:34px;height:34px;border-radius:10px;
    background:rgba(252,250,241,0.16);
    color:var(--flaxen);
    align-items:center;justify-content:center;
    flex:0 0 auto;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.16);
  }
  .brand-mini-img{
    max-width:23px;
    max-height:23px;
    width:auto;height:auto;
    object-fit:contain;
    display:block;
  }
  .topbar-logo{
    display:none;
    height:24px;
    width:auto;
  }
  .collapse-btn{
    width:28px;height:28px;border-radius:9px;flex:0 0 auto;
    border:1px solid rgba(252,250,241,0.2);
    background:rgba(252,250,241,0.06);
    color:rgba(252,250,241,0.8);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;margin-top:2px;
    transition:background 160ms var(--ease), color 160ms var(--ease), transform 160ms var(--ease);
  }
  .collapse-btn:hover{background:rgba(252,250,241,0.16);color:var(--flaxen);}
  .collapse-btn:active{transform:scale(0.9);}
  .collapse-btn svg{width:15px;height:15px;stroke-width:1.75px;}
  .menu-toggle{
    display:none;
    width:44px;height:44px;border-radius:var(--radius-pill);flex:0 0 auto;
    border:1px solid var(--hairline);background:var(--flaxen);
    color:var(--forrest);cursor:pointer;
    align-items:center;justify-content:center;
    position:relative;
    box-shadow:var(--shadow-1);
    transition:box-shadow 160ms var(--ease), transform 120ms var(--ease);
  }
  .menu-toggle:hover{box-shadow:var(--shadow-2);}
  .menu-toggle:active{transform:scale(0.92);}
  .menu-toggle svg{width:19px;height:19px;stroke-width:1.75px;}
  .menu-toggle .icon-menu-open,
  .menu-toggle .icon-menu-close{display:flex;align-items:center;justify-content:center;}
  .menu-toggle .icon-menu-close{display:none;}
  .menu-toggle.is-open .icon-menu-open{display:none;}
  .menu-toggle.is-open .icon-menu-close{display:flex;}
  .topbar-left{display:flex;align-items:center;gap:12px;}

  .sidebar-backdrop{
    display:none;
    position:fixed;inset:0;
    background:rgba(0,20,20,0.45);
    opacity:0;pointer-events:none;
    transition:opacity 220ms ease;
    z-index:900;
  }
  .sidebar-backdrop.visible{opacity:1;pointer-events:auto;}

  nav.nav{flex:1;display:flex;flex-direction:column;gap:3px;position:relative;}
  .nav-item{
    display:flex;
    align-items:center;
    gap:11px;
    padding:10px 12px;
    border-radius:var(--radius-sm);
    color:rgba(252,250,241,0.78);
    font-size:14px;
    font-weight:600;
    cursor:pointer;
    border:none;
    background:none;
    width:100%;
    text-align:left;
    transition:background 160ms var(--ease), color 160ms var(--ease), transform 120ms var(--ease), box-shadow 160ms var(--ease);
    position:relative;
  }
  .nav-item svg{width:17px;height:17px;stroke-width:1.75px;flex:0 0 auto;}
  .nav-item:hover{background:rgba(252,250,241,0.10);color:var(--flaxen);}
  .nav-item:active{transform:scale(0.98);}
  .nav-item.active{
    background:linear-gradient(135deg, rgba(252,250,241,0.20), rgba(252,250,241,0.09));
    color:var(--flaxen);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.12), 0 4px 14px -4px rgba(0,0,0,0.28);
  }
  .nav-item.active::before{
    content:"";
    position:absolute;left:-16px;top:8px;bottom:8px;width:3px;
    background:var(--accent);border-radius:0 3px 3px 0;
    box-shadow:0 0 10px 1px rgba(226,112,61,0.6);
  }
  .nav-label{flex:1;white-space:nowrap;}
  .nav-badge{
    min-width:19px;height:19px;padding:0 5px;
    border-radius:var(--radius-pill);
    background:var(--grad-brick);
    color:var(--flaxen);
    font-size:11px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    flex:0 0 auto;
    box-shadow:0 2px 6px rgba(0,0,0,0.2);
  }
  .nav-badge.bad{background:linear-gradient(135deg,#D9584A,var(--bad));}

  /* ---- collapsed rail (desktop/tablet minimise) ---- */
  .sidebar.collapsed{width:76px;flex:0 0 76px;padding-left:10px;padding-right:10px;}
  .sidebar.collapsed .brand-lockup{flex-direction:column;align-items:center;gap:10px;padding-left:0;padding-right:0;}
  .sidebar.collapsed .brand-full{display:none;}
  .sidebar.collapsed .brand-mini{display:flex;}
  .sidebar.collapsed .nav-item{justify-content:center;padding:11px;}
  .sidebar.collapsed .nav-item.active::before{left:-10px;}
  .sidebar.collapsed .nav-label{display:none;}
  .sidebar.collapsed .nav-badge{
    position:absolute;top:2px;right:6px;
    min-width:15px;height:15px;font-size:9px;padding:0 3px;
  }
  .sidebar.collapsed .sync-text,
  .sidebar.collapsed .user-chip .who,
  .sidebar.collapsed .user-chip .role{display:none;}
  .sidebar.collapsed .sync-pill{justify-content:center;padding:0;}
  .sidebar.collapsed .user-chip{justify-content:center;}
  .sidebar.collapsed .collapse-btn svg{transform:rotate(180deg);}

  .sidebar-footer{
    border-top:1px solid rgba(252,250,241,0.14);
    padding-top:14px;
    margin-top:10px;
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .sync-pill{
    display:flex;align-items:center;gap:7px;
    font-size:11px;color:rgba(252,250,241,0.6);
    padding:0 10px;
  }
  .sync-dot{width:6px;height:6px;border-radius:50%;background:#7FCB9E;flex:0 0 auto;}
  .sync-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .user-chip{
    display:flex;align-items:center;gap:10px;
    padding:8px 10px;border-radius:var(--radius-sm);
  }
  .avatar{
    width:32px;height:32px;border-radius:50%;
    background:linear-gradient(135deg,#E4D4B4,var(--sand));color:var(--forrest-deep);
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:13px;font-family:var(--font-body);
    flex:0 0 auto;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.4), 0 2px 6px rgba(0,0,0,0.12);
  }
  .user-chip .who{font-size:13px;font-weight:500;color:var(--flaxen);white-space:nowrap;}
  .user-chip .role{font-size:11px;color:rgba(252,250,241,0.55);white-space:nowrap;}

  /* ============ Main ============ */
  .main{
    flex:1;
    display:flex;
    flex-direction:column;
    min-width:0;
  }
  .topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:22px 32px 16px;
    border-bottom:1px solid var(--hairline);
    flex:0 0 auto;
  }
  .topbar h1{font-size:26px;font-weight:800;}
  .topbar .today{font-size:13px;color:var(--fg3);margin-top:3px;font-weight:500;}
  .topbar-right{display:flex;align-items:center;gap:14px;}
  .icon-btn{
    width:38px;height:38px;border-radius:50%;
    border:1px solid var(--hairline);background:linear-gradient(180deg,#fff,var(--flaxen-warm));
    display:flex;align-items:center;justify-content:center;
    color:var(--forrest);cursor:pointer;
    box-shadow:var(--shadow-1);
    transition:box-shadow 160ms var(--ease), transform 120ms var(--ease);
    position:relative;
  }
  .icon-btn:hover{box-shadow:var(--shadow-2);transform:translateY(-1px);}
  .icon-btn:active{transform:scale(0.92);box-shadow:var(--shadow-1);}
  .icon-btn svg{width:16px;height:16px;stroke-width:1.75px;}

  .views{flex:1;overflow-y:auto;padding:26px 32px 40px;}
  .view{display:none;}
  .view.active{display:block;animation:viewIn 320ms var(--ease);}
  @keyframes viewIn{
    from{opacity:0;transform:translateY(10px) scale(0.99);}
    to{opacity:1;transform:translateY(0) scale(1);}
  }

  .section-head{margin-bottom:20px;}
  .section-head h2{font-size:24px;font-weight:800;}
  .section-head p{margin:5px 0 0;font-size:13.5px;color:var(--fg3);max-width:60ch;line-height:1.5;}

  .eyebrow{
    font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent-deep);
    margin:0 0 4px;
  }

  /* ============ Cards / grid ============ */
  .grid{display:grid;gap:16px;}
  .grid-5{grid-template-columns:repeat(5,1fr);}
  .grid-4{grid-template-columns:repeat(4,1fr);}
  .grid-3{grid-template-columns:repeat(3,1fr);}
  .grid-2{grid-template-columns:1.3fr 1fr;}
  @media (max-width:1200px){
    .grid-5{grid-template-columns:repeat(3,1fr);}
    .grid-4{grid-template-columns:repeat(2,1fr);}
  }

  .card{
    background:linear-gradient(180deg,#ffffff 0%,#fffdf8 100%);
    border:1px solid var(--hairline-soft);
    border-radius:var(--radius-card);
    box-shadow:var(--shadow-1);
    padding:18px 18px 16px;
    transition:box-shadow 220ms var(--ease), transform 220ms var(--ease), border-color 220ms var(--ease);
  }
  .card.clickable{cursor:pointer;}
  .card.clickable:hover{box-shadow:var(--shadow-2);transform:translateY(-3px);border-color:transparent;}
  .card.clickable:active{transform:translateY(-1px) scale(0.99);box-shadow:var(--shadow-1);}

  .stat-card .icon-wrap{
    width:36px;height:36px;border-radius:11px;
    display:flex;align-items:center;justify-content:center;
    margin-bottom:12px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.5), 0 3px 8px -2px rgba(0,0,0,0.12);
  }
  .stat-card .icon-wrap svg{width:17px;height:17px;stroke-width:1.75px;}
  .tone-bad .icon-wrap{background:linear-gradient(150deg,#FBE2DA,var(--bad-bg));color:var(--bad);}
  .tone-warn .icon-wrap{background:linear-gradient(150deg,#FBF1DC,var(--warn-bg));color:var(--warn);}
  .tone-ok .icon-wrap{background:linear-gradient(150deg,#E9F5EA,var(--ok-bg));color:var(--ok);}
  .tone-info .icon-wrap{background:linear-gradient(150deg,#E7F1F0,var(--info-bg));color:var(--info);}
  .tone-brick .icon-wrap{background:linear-gradient(150deg,#F5E9DF,#F0E4DA);color:var(--brick);}

  .stat-card .label{font-size:12px;color:var(--fg3);font-weight:600;}
  .stat-card .value{font-family:var(--font-display);font-size:29px;font-weight:800;color:var(--forrest);margin-top:2px;line-height:1.1;letter-spacing:-0.02em;}
  .stat-card .sub{font-size:12.5px;color:var(--fg3);margin-top:6px;}
  .stat-card .sub.bad{color:var(--bad);font-weight:600;}
  .stat-card .sub.ok{color:var(--ok);font-weight:600;}

  .spark-wrap{margin-top:8px;height:34px;}
  .spark-wrap svg{width:100%;height:100%;display:block;}

  /* ============ KPI tiles (Overview — compact, information-dense) ============ */
  .kpi-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px;}
  .kpi-tile{
    padding:15px 15px 14px;display:flex;flex-direction:column;
    border-radius:var(--radius-tile);
    animation:kpiIn 480ms var(--ease) backwards;
  }
  .kpi-tile:nth-child(1){animation-delay:0ms;}
  .kpi-tile:nth-child(2){animation-delay:50ms;}
  .kpi-tile:nth-child(3){animation-delay:100ms;}
  .kpi-tile:nth-child(4){animation-delay:150ms;}
  .kpi-tile:nth-child(5){animation-delay:200ms;}
  .kpi-tile:nth-child(6){animation-delay:250ms;}
  @keyframes kpiIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
  .kpi-tile.tone-bad{background:linear-gradient(160deg,#fff 0%,var(--bad-bg) 160%);}
  .kpi-tile.tone-warn{background:linear-gradient(160deg,#fff 0%,var(--warn-bg) 160%);}
  .kpi-tile.tone-ok{background:linear-gradient(160deg,#fff 0%,var(--ok-bg) 160%);}
  .kpi-tile.tone-info{background:linear-gradient(160deg,#fff 0%,var(--info-bg) 160%);}
  .kpi-tile.tone-brick{background:linear-gradient(160deg,#fff 0%,#F5E9DF 160%);}
  .kpi-tile .icon-wrap{width:30px;height:30px;border-radius:9px;margin-bottom:9px;}
  .kpi-tile .icon-wrap svg{width:14px;height:14px;stroke-width:1.75px;}
  .kpi-label{font-size:10.5px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--fg3);}
  .kpi-value{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--forrest);line-height:1.15;margin-top:3px;letter-spacing:-0.02em;}
  .kpi-value.small{font-size:18px;}
  .kpi-value-of{font-family:var(--font-body);font-size:11.5px;color:var(--fg3);font-weight:600;}
  .kpi-sub{font-size:11.5px;color:var(--fg3);margin-top:5px;line-height:1.4;}
  .kpi-sub.bad{color:var(--bad);font-weight:700;}
  .kpi-sub.ok{color:var(--ok);font-weight:700;}
  .kpi-progress{height:6px;border-radius:4px;background:rgba(0,70,69,0.08);overflow:hidden;margin:8px 0 2px;}
  .kpi-progress-fill{height:100%;background:linear-gradient(90deg,var(--forrest-tint),var(--accent));border-radius:4px;transition:width 900ms var(--ease);}

  .trend{font-weight:700;}
  .trend.ok{color:var(--ok);}
  .trend.bad{color:var(--bad);}
  .trend-note{color:var(--fg3);font-weight:500;}

  /* ============ Needs-attention list (Overview) ============ */
  .attn-card{padding-top:16px;}
  .attn-list{display:flex;flex-direction:column;}
  .attn-item{
    display:flex;align-items:flex-start;gap:12px;
    padding:13px 8px;border-bottom:1px solid var(--hairline-soft);
    cursor:pointer;transition:background 160ms var(--ease), transform 120ms var(--ease);border-radius:var(--radius-xs);
  }
  .attn-item:last-child{border-bottom:none;}
  .attn-item:hover{background:var(--flaxen-warm);}
  .attn-item:active{transform:scale(0.99);}
  .attn-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:inset 0 1px 0 rgba(255,255,255,0.5);}
  .attn-icon svg{width:15px;height:15px;stroke-width:1.75px;}
  .attn-icon.bad{background:linear-gradient(150deg,#FBE2DA,var(--bad-bg));color:var(--bad);}
  .attn-icon.warn{background:linear-gradient(150deg,#FBF1DC,var(--warn-bg));color:var(--warn);}
  .attn-main{flex:1;min-width:0;}
  .attn-title{font-size:13.5px;font-weight:700;color:var(--forrest);}
  .attn-detail{font-size:12.5px;color:var(--fg3);margin-top:2px;}
  .attn-empty{font-size:13px;color:var(--fg3);padding:8px 4px;}

  /* ============ Badges ============ */
  .badge{
    display:inline-flex;align-items:center;gap:5px;
    font-size:11.5px;font-weight:700;
    padding:4px 10px;border-radius:var(--radius-pill);
    white-space:nowrap;
  }
  .badge.ok{background:var(--ok-bg);color:var(--ok);}
  .badge.warn{background:var(--warn-bg);color:var(--warn);}
  .badge.bad{background:var(--bad-bg);color:var(--bad);}
  .badge.info{background:var(--info-bg);color:var(--info);}
  .badge.neutral{background:var(--neutral-bg);color:var(--fg2);}
  .badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}

  .tag{
    font-size:10.5px;font-weight:600;letter-spacing:0.04em;
    padding:3px 8px;border-radius:5px;text-transform:uppercase;
  }
  .tag.tenant{background:var(--info-bg);color:var(--info);}
  .tag.supplier{background:#F0E4DA;color:var(--brick);}
  .tag.customer{background:var(--neutral-bg);color:var(--fg2);}

  /* ============ Legend note (GoFrontage / Xero) ============ */
  .source-legend{
    display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;
    background:linear-gradient(135deg,#fff,var(--flaxen-warm));
    border:1px solid var(--hairline);
    border-radius:var(--radius-sm);
    padding:12px 18px;
    margin-bottom:18px;
    font-size:12.5px;color:var(--fg2);
    box-shadow:var(--shadow-1);
  }
  .source-legend .item{display:flex;align-items:center;gap:7px;}
  .source-legend .swatch{width:9px;height:9px;border-radius:2px;}
  .source-legend .swatch.gf{background:var(--sand);}
  .source-legend .swatch.xero{background:var(--forrest-tint);}
  .source-legend em{font-style:normal;color:var(--fg3);}

  /* ============ Table (Tenants) ============ */
  .table-card{background:#fff;border:1px solid var(--hairline-soft);border-radius:var(--radius-card);box-shadow:var(--shadow-1);overflow:hidden;}
  table{width:100%;border-collapse:collapse;}
  thead th{
    text-align:left;font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
    color:var(--fg3);padding:13px 16px;border-bottom:1px solid var(--hairline);background:var(--flaxen-warm);
  }
  tbody td{padding:15px 16px;border-bottom:1px solid var(--hairline-soft);font-size:13.5px;vertical-align:middle;}
  tbody tr.tenant-row{cursor:pointer;transition:background 160ms var(--ease);}
  tbody tr.tenant-row:hover{background:var(--flaxen-warm);}
  tbody tr:last-child td{border-bottom:none;}
  .shop-pill{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:28px;height:23px;padding:0 7px;
    background:var(--grad-forrest);color:var(--flaxen);
    font-size:11px;font-weight:700;border-radius:var(--radius-pill);
    box-shadow:0 2px 6px rgba(0,70,69,0.25);
  }
  .tenant-name{font-weight:700;color:var(--forrest);font-size:14px;}
  .tenant-cat{font-size:12px;color:var(--fg3);}
  .chev{transition:transform 220ms var(--ease);color:var(--fg3);}
  .chev svg{width:16px;height:16px;stroke-width:1.75px;}
  tr.tenant-row.open .chev{transform:rotate(180deg);}

  .detail-row td{padding:0;border-bottom:1px solid var(--hairline-soft);}
  .detail-wrap{max-height:0;overflow:hidden;transition:max-height 260ms ease;}
  tr.tenant-row.open + tr.detail-row .detail-wrap{max-height:900px;}
  .detail-inner{
    display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
    padding:18px 22px 22px;background:var(--flaxen-warm);
  }
  .detail-inner .d-label{font-size:10.5px;text-transform:uppercase;letter-spacing:0.08em;color:var(--fg3);margin-bottom:4px;font-weight:600;}
  .detail-inner .d-value{font-size:13.5px;color:var(--ink);line-height:1.5;}
  .detail-inner .d-value.notes{font-size:13px;line-height:1.55;}

  .mobile-chev{display:none;}
  .table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}

  /* ============ Meetings ============ */
  .next-meeting-card{
    background:var(--grad-forrest);
    color:var(--flaxen);
    border-radius:var(--radius-card);
    padding:28px 30px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    box-shadow:var(--glow-forrest), var(--shadow-2);
    margin-bottom:22px;
    position:relative;overflow:hidden;
  }
  .next-meeting-card::after{
    content:"";position:absolute;top:-40%;right:-10%;width:280px;height:280px;border-radius:50%;
    background:radial-gradient(circle, rgba(226,112,61,0.25), transparent 70%);
    pointer-events:none;
  }
  .next-meeting-card .eyebrow{color:var(--sand);}
  .next-meeting-card h3{color:var(--flaxen);font-family:var(--font-display);font-size:23px;font-weight:800;margin-bottom:6px;letter-spacing:-0.02em;}
  .next-meeting-card .when{font-size:14px;color:rgba(252,250,241,0.85);}
  .countdown-chip{
    background:rgba(252,250,241,0.14);
    border:1px solid rgba(252,250,241,0.3);
    border-radius:var(--radius-pill);
    padding:10px 20px;font-size:13px;font-weight:700;white-space:nowrap;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.15);
    position:relative;
  }
  .attendees-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
  .attendee-chip{
    background:rgba(252,250,241,0.12);border-radius:var(--radius-pill);
    padding:5px 12px;font-size:12px;color:rgba(252,250,241,0.9);
  }

  .meeting-log-item{
    display:flex;gap:18px;padding:16px 4px;border-bottom:1px solid var(--hairline-soft);
  }
  .meeting-log-item:last-child{border-bottom:none;}
  .meeting-date{
    flex:0 0 96px;font-size:12.5px;color:var(--fg3);font-weight:600;padding-top:2px;
  }
  .meeting-body .attendees{font-size:13px;font-weight:600;color:var(--forrest);margin-bottom:3px;}
  .meeting-body .notes{font-size:13px;color:var(--fg2);line-height:1.5;}

  /* ============ Projects ============ */
  .project-card{display:flex;flex-direction:column;gap:10px;min-height:170px;}
  .project-card h3{font-size:16.5px;font-family:var(--font-body);font-weight:700;color:var(--forrest);}
  .project-card .timeline{font-size:12px;color:var(--fg3);}
  .project-card .notes{font-size:13px;color:var(--fg2);line-height:1.5;flex:1;}
  .status-row{display:flex;align-items:center;justify-content:space-between;}

  /* ============ Inbox ============ */
  .inbox-list{display:flex;flex-direction:column;}
  .inbox-item{
    display:flex;gap:14px;align-items:flex-start;
    padding:16px 6px;border-bottom:1px solid var(--hairline-soft);
    cursor:pointer;transition:background 160ms var(--ease);
  }
  .inbox-item:hover{background:var(--flaxen-warm);border-radius:var(--radius-sm);}
  .inbox-item:last-child{border-bottom:none;}
  .inbox-item.unread{background:linear-gradient(135deg,var(--flaxen-warm),#fff);border-radius:var(--radius-sm);padding:16px 12px;margin:0 -6px;box-shadow:var(--shadow-1);}
  .unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:6px;flex:0 0 auto;box-shadow:0 0 0 3px var(--accent-bg);}
  .unread-dot.hidden{background:transparent;box-shadow:none;}
  .inbox-avatar{
    width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#E4D4B4,var(--sand));color:var(--forrest-deep);
    display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12.5px;flex:0 0 auto;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.4);
  }
  .inbox-main{flex:1;min-width:0;}
  .inbox-top{display:flex;align-items:center;justify-content:space-between;gap:10px;}
  .inbox-sender{font-size:13.5px;font-weight:700;color:var(--forrest);}
  .inbox-email{font-size:12px;color:var(--fg3);font-weight:400;}
  .inbox-subject{font-size:13.5px;color:var(--ink);font-weight:500;margin-top:3px;}
  .inbox-snippet{font-size:12.5px;color:var(--fg3);margin-top:3px;}
  .inbox-meta{display:flex;align-items:center;gap:8px;flex:0 0 auto;}
  .flag-icon{color:var(--brick);}
  .flag-icon svg{width:14px;height:14px;}

  /* ============ Social & Reviews ============ */
  .post-card{display:flex;gap:12px;}
  .post-thumb{
    width:56px;height:56px;border-radius:var(--radius-xs);flex:0 0 auto;
    background:linear-gradient(150deg,#fff,var(--flaxen-warm));
    display:flex;align-items:center;justify-content:center;color:var(--brick);
    box-shadow:var(--shadow-1);
  }
  .post-thumb svg{width:20px;height:20px;stroke-width:1.75px;}
  .post-meta{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--fg3);margin-bottom:4px;}
  .post-caption{font-size:13px;color:var(--ink);line-height:1.5;}
  .platform-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--forrest);}
  .platform-icon svg{width:14px;height:14px;stroke-width:1.75px;}

  .review-card{display:flex;flex-direction:column;gap:8px;padding-bottom:14px;border-bottom:1px solid var(--hairline-soft);}
  .review-card:last-child{border-bottom:none;padding-bottom:0;}
  .review-top{display:flex;align-items:center;justify-content:space-between;}
  .stars{display:flex;gap:2px;color:var(--warn);}
  .stars svg{width:14px;height:14px;fill:var(--warn);stroke:none;}
  .review-name{font-size:13.5px;font-weight:700;color:var(--forrest);}
  .review-snippet{font-size:13px;color:var(--fg2);line-height:1.55;}
  .waiting-chip{font-size:11.5px;color:var(--bad);font-weight:700;background:var(--bad-bg);padding:3px 9px;border-radius:var(--radius-pill);white-space:nowrap;}

  /* ============ SEO ============ */
  .query-table td{font-size:13.5px;}
  .query-rank{
    width:23px;height:23px;border-radius:50%;background:linear-gradient(150deg,#fff,var(--flaxen-warm));color:var(--forrest);
    display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;box-shadow:var(--shadow-1);
  }
  .query-text{font-weight:600;color:var(--ink);}
  .ctr-bar-wrap{width:90px;height:6px;background:rgba(0,70,69,0.08);border-radius:4px;overflow:hidden;}
  .ctr-bar{height:100%;background:linear-gradient(90deg,var(--forrest-tint),var(--accent));border-radius:4px;transition:width 900ms var(--ease);}

  /* ============ Money bar chart ============ */
  .bar-chart{display:flex;align-items:flex-end;gap:14px;height:150px;padding:8px 4px 0;}
  .bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;gap:8px;}
  /* fixed-size track so the bar's height:% has a definite box to resolve against —
     without this, percentage-height inside an auto-sized flex column collapses to ~content size
     and every bar ends up rendering the same clamped height regardless of its data value */
  .bar-track{flex:1;width:100%;min-height:0;display:flex;align-items:flex-end;justify-content:center;}
  .bar{width:100%;max-width:38px;background:linear-gradient(180deg,var(--forrest-tint),var(--forrest));border-radius:8px 8px 3px 3px;position:relative;transition:height 700ms var(--ease);box-shadow:0 4px 10px -4px rgba(0,70,69,0.4);}
  .bar-col:last-child .bar{background:linear-gradient(180deg,var(--accent),var(--accent-deep));box-shadow:0 4px 12px -4px rgba(216,102,54,0.5);}
  .bar-value{font-size:11px;color:var(--fg3);font-weight:700;}
  .bar-label{font-size:11px;color:var(--fg3);margin-top:6px;font-weight:500;}

  .pnl-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--hairline-soft);}
  .pnl-row:last-child{border-bottom:none;}
  .pnl-label{font-size:13px;color:var(--fg2);font-weight:500;}
  .pnl-values{display:flex;gap:18px;align-items:baseline;}
  .pnl-this{font-size:15px;font-weight:800;color:var(--forrest);font-family:var(--font-display);}
  .pnl-last{font-size:12px;color:var(--fg3);}
  .pnl-delta{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:var(--radius-pill);}
  .pnl-delta.up{background:var(--ok-bg);color:var(--ok);}
  .pnl-delta.down{background:var(--bad-bg);color:var(--bad);}

  .receivable-row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--hairline-soft);}
  .receivable-row:last-child{border-bottom:none;}
  .rec-name{font-size:13.5px;font-weight:700;color:var(--forrest);}
  .rec-days{font-size:11.5px;color:var(--bad);font-weight:600;}
  .rec-amount{font-size:15px;font-weight:800;color:var(--ink);font-family:var(--font-display);}

  .balance-figure{font-family:var(--font-hero);font-size:42px;color:var(--forrest);font-weight:600;margin-top:6px;letter-spacing:-0.01em;}

  /* ============ Buttons (shared primary/secondary/ghost system) ============ */
  .btn-primary{
    display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
    background:linear-gradient(180deg,var(--forrest-tint),var(--forrest));
    color:var(--flaxen);font-weight:700;font-size:13.5px;font-family:var(--font-body);
    padding:11px 22px;border-radius:var(--radius-pill);border:none;cursor:pointer;
    box-shadow:0 6px 16px -6px rgba(0,70,69,0.5);
    transition:transform 140ms var(--ease), box-shadow 140ms var(--ease), filter 140ms ease;
  }
  .btn-primary svg{width:15px;height:15px;stroke-width:1.75px;}
  .btn-primary:hover{filter:brightness(1.08);box-shadow:0 8px 20px -6px rgba(0,70,69,0.6);}
  .btn-primary:active{transform:scale(0.96);box-shadow:0 3px 8px -4px rgba(0,70,69,0.4);}
  .btn-secondary{
    display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
    background:var(--flaxen-warm);color:var(--forrest);font-weight:700;font-size:13.5px;font-family:var(--font-body);
    padding:11px 22px;border-radius:var(--radius-pill);border:1px solid var(--hairline);cursor:pointer;
    transition:background 140ms var(--ease), transform 140ms var(--ease), box-shadow 140ms var(--ease);
  }
  .btn-secondary svg{width:15px;height:15px;stroke-width:1.75px;}
  .btn-secondary:hover{background:#fff;box-shadow:var(--shadow-1);}
  .btn-secondary:active{transform:scale(0.96);}
  .btn-sm{padding:7px 14px;font-size:12px;}
  .btn-sm svg{width:13px;height:13px;}
  .section-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}

  /* ============ Shared person avatar ============ */
  .person-avatar{
    width:26px;height:26px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;flex:0 0 auto;
    color:#fff;font-size:10.5px;font-weight:700;font-family:var(--font-body);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.3), 0 2px 5px rgba(0,0,0,0.15);
  }
  .person-avatar.lg{width:42px;height:42px;font-size:14px;}
  .tag.project{background:#EFE7D6;color:var(--brick-deep);}

  /* ============ Seen / activity indicators (woven through inbox, notes, maintenance) ============ */
  .seen-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;padding-top:9px;border-top:1px dashed var(--hairline-soft);}
  .seen-label{font-size:11.5px;color:var(--fg3);font-weight:600;}
  .seen-label.seen{color:var(--ok);}
  .mark-seen-btn{
    font-size:11px;font-weight:700;color:var(--forrest-tint);background:none;border:none;cursor:pointer;
    padding:5px 10px;border-radius:var(--radius-pill);transition:background 140ms ease,color 140ms ease;
  }
  .mark-seen-btn:hover{background:var(--flaxen-warm);color:var(--forrest);}

  .activity-strip{display:flex;flex-direction:column;}
  .activity-item{display:flex;align-items:center;gap:12px;padding:11px 6px;border-bottom:1px solid var(--hairline-soft);font-size:13px;color:var(--fg2);}
  .activity-item:last-child{border-bottom:none;}
  .activity-text{flex:1;min-width:0;}
  .activity-text strong{color:var(--forrest);font-weight:700;}
  .activity-time{font-size:11.5px;color:var(--fg3);white-space:nowrap;flex:0 0 auto;}

  /* ============ Tasks ============ */
  .task-list{display:flex;flex-direction:column;}
  .task-item{display:flex;align-items:flex-start;gap:14px;padding:14px 10px;border-bottom:1px solid var(--hairline-soft);border-radius:var(--radius-xs);transition:background 160ms var(--ease);}
  .task-item:last-child{border-bottom:none;}
  .task-item:hover{background:var(--flaxen-warm);}
  .task-item.done{opacity:0.55;}
  .task-check{
    width:25px;height:25px;border-radius:50%;flex:0 0 auto;margin-top:1px;
    border:2px solid var(--hairline);background:#fff;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:background 160ms var(--ease), border-color 160ms var(--ease), transform 120ms var(--ease);
  }
  .task-check:hover{border-color:var(--forrest-tint);}
  .task-check:active{transform:scale(0.88);}
  .task-check svg{width:14px;height:14px;stroke-width:3px;color:#fff;opacity:0;transition:opacity 120ms ease;}
  .task-item.done .task-check{background:var(--ok);border-color:var(--ok);}
  .task-item.done .task-check svg{opacity:1;}
  .task-main{flex:1;min-width:0;}
  .task-title{font-size:14px;font-weight:600;color:var(--forrest);line-height:1.4;}
  .task-item.done .task-title{text-decoration:line-through;color:var(--fg3);}
  .task-meta{display:flex;align-items:center;gap:10px;margin-top:7px;flex-wrap:wrap;}
  .task-due{font-size:12px;color:var(--fg3);font-weight:600;display:inline-flex;align-items:center;gap:4px;}
  .task-due svg{width:12px;height:12px;stroke-width:1.75px;}
  .task-due.due-soon{color:var(--bad);}

  /* ============ Notes ============ */
  .note-composer{margin-bottom:16px;}
  .composer-row{display:flex;align-items:flex-start;gap:12px;}
  .note-textarea{
    flex:1;resize:none;border:1px solid var(--hairline);border-radius:var(--radius-sm);
    padding:11px 14px;font-family:var(--font-body);font-size:13.5px;color:var(--ink);
    background:var(--flaxen-warm);transition:border-color 140ms ease, box-shadow 140ms ease, background 140ms ease;
  }
  .note-textarea:focus{outline:none;border-color:var(--forrest-tint);background:#fff;box-shadow:0 0 0 3px rgba(31,94,92,0.14);}
  .composer-actions{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:12px;}
  .composer-attach{display:flex;gap:6px;}
  .attach-btn{
    width:34px;height:34px;border-radius:50%;border:1px solid var(--hairline);background:#fff;color:var(--forrest-tint);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    transition:background 140ms ease, transform 120ms var(--ease), color 140ms ease;
  }
  .attach-btn svg{width:15px;height:15px;stroke-width:1.75px;}
  .attach-btn:hover{background:var(--flaxen-warm);color:var(--forrest);}
  .attach-btn:active{transform:scale(0.9);}
  .composer-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
  .composer-chip{
    display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--forrest);
    background:var(--flaxen-warm);border-radius:var(--radius-pill);padding:5px 8px 5px 10px;
  }
  .composer-chip button{border:none;background:none;color:var(--fg3);cursor:pointer;display:flex;padding:2px;}
  .composer-chip svg{width:12px;height:12px;}
  .note-list{display:flex;flex-direction:column;gap:16px;}
  .note-card{background:linear-gradient(180deg,#ffffff 0%,#fffdf8 100%);border:1px solid var(--hairline-soft);border-radius:var(--radius-card);box-shadow:var(--shadow-1);padding:16px 18px;}
  .note-head{display:flex;align-items:center;gap:10px;}
  .note-head-main{flex:1;display:flex;align-items:baseline;gap:8px;min-width:0;}
  .note-author{font-size:13.5px;font-weight:700;color:var(--forrest);}
  .note-time{font-size:11.5px;color:var(--fg3);}
  .note-text{font-size:13.5px;color:var(--ink);line-height:1.55;margin-top:10px;}
  .note-media{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}
  .note-media-tile{
    width:84px;height:84px;border-radius:var(--radius-xs);position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(150deg,var(--flaxen-warm),var(--sand));color:var(--forrest-deep);
    box-shadow:var(--shadow-1);
  }
  .note-media-tile svg{width:22px;height:22px;stroke-width:1.75px;}
  .note-media-tile.video{background:linear-gradient(150deg,#3a3a3a,#151515);color:#fff;}
  .video-duration{
    position:absolute;bottom:5px;right:5px;background:rgba(0,0,0,0.65);color:#fff;
    font-size:9.5px;font-weight:700;padding:2px 5px;border-radius:4px;letter-spacing:0.02em;
  }

  /* ============ Contacts ============ */
  .contact-group-head{display:flex;align-items:baseline;gap:10px;margin:22px 0 12px;}
  .contact-group-head:first-child{margin-top:0;}
  .contact-group-head h3{font-size:16px;font-weight:800;color:var(--forrest);}
  .contact-group-count{font-size:12px;color:var(--fg3);font-weight:600;}
  .contact-card{display:flex;flex-direction:column;}
  .contact-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
  .contact-info{flex:1;min-width:0;}
  .contact-name{font-weight:700;color:var(--forrest);font-size:14.5px;}
  .contact-company{font-size:12px;color:var(--fg3);margin-top:2px;}
  .contact-actions{display:flex;flex-direction:column;gap:2px;padding-top:10px;border-top:1px solid var(--hairline-soft);}
  .contact-link{
    display:flex;align-items:center;gap:9px;font-size:13px;color:var(--fg2);font-weight:600;
    padding:7px 6px;border-radius:var(--radius-xs);transition:background 140ms ease, color 140ms ease;
    text-decoration:none;
  }
  .contact-link:hover{background:var(--flaxen-warm);color:var(--forrest);}
  .contact-link svg{width:14px;height:14px;stroke-width:1.75px;color:var(--forrest-tint);flex:0 0 auto;}

  /* ============ Maintenance ============ */
  .maint-list{display:flex;flex-direction:column;gap:14px;}
  .maint-card{display:flex;flex-direction:column;}
  .maint-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;}
  .maint-title{font-size:14.5px;font-weight:700;color:var(--forrest);line-height:1.4;}
  .maint-meta-row{display:flex;align-items:center;gap:8px;margin-top:7px;flex-wrap:wrap;}
  .maint-supplier{font-size:12.5px;color:var(--fg3);font-weight:600;}
  .maint-details{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--hairline-soft);}
  .maint-detail{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--fg2);font-weight:500;}
  .maint-detail svg{width:14px;height:14px;stroke-width:1.75px;color:var(--forrest-tint);}

  /* ============ Modal / sheet system ============ */
  .modal-overlay{
    position:fixed;inset:0;background:rgba(0,20,20,0.5);backdrop-filter:blur(2px);
    display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;
    opacity:0;pointer-events:none;transition:opacity 200ms var(--ease);
  }
  .modal-overlay.visible{opacity:1;pointer-events:auto;}
  .modal-sheet{
    background:var(--flaxen);border-radius:var(--radius-card);box-shadow:var(--shadow-3);
    max-width:520px;width:100%;max-height:86vh;overflow-y:auto;padding:26px;
    transform:translateY(16px) scale(0.98);transition:transform 220ms var(--ease);
  }
  .modal-overlay.visible .modal-sheet{transform:translateY(0) scale(1);}
  .modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;}
  .modal-head h3{font-size:19px;font-weight:800;color:var(--forrest);}
  .modal-close{
    width:32px;height:32px;border-radius:50%;border:none;background:var(--flaxen-warm);color:var(--fg3);
    cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;
    transition:background 140ms ease, color 140ms ease;
  }
  .modal-close:hover{background:var(--hairline);color:var(--forrest);}
  .modal-close svg{width:16px;height:16px;stroke-width:1.75px;}
  .draft-context{background:var(--flaxen-warm);border-radius:var(--radius-xs);padding:12px 14px;font-size:12.5px;color:var(--fg2);line-height:1.55;margin-bottom:16px;}
  .form-field{margin-bottom:14px;display:flex;flex-direction:column;gap:6px;}
  .form-field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--fg3);}
  .form-field input, .form-field select, .form-field textarea{
    font-family:var(--font-body);font-size:14px;color:var(--ink);width:100%;
    padding:10px 13px;border-radius:var(--radius-xs);border:1px solid var(--hairline);
    background:#fff;transition:border-color 140ms ease, box-shadow 140ms ease;
  }
  .form-field textarea{resize:vertical;}
  .form-field input:focus, .form-field select:focus, .form-field textarea:focus{
    outline:none;border-color:var(--forrest-tint);box-shadow:0 0 0 3px rgba(31,94,92,0.15);
  }
  .modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;}

  /* ============ Inbox click-to-read sheet ============ */
  .email-body{font-size:13.5px;color:var(--ink);line-height:1.6;margin-top:10px;word-break:break-word;}
  .email-body img{max-width:100%;height:auto;}
  .email-body img.email-img-blocked{display:none;}
  .email-body a{color:var(--forrest-tint);}

  /* ============ Inbox draft-reply flow ============ */
  .inbox-actions{display:flex;align-items:center;gap:10px;margin-top:11px;flex-wrap:wrap;}

  /* scrollbar polish */
  .views::-webkit-scrollbar{width:8px;}
  .views::-webkit-scrollbar-thumb{background:var(--hairline);border-radius:8px;}

  /* ============================================================
     MOBILE (<=768px) — off-canvas sidebar, single-column reflow
     ============================================================ */
  @media (max-width:768px){
    .canvas{padding:0;align-items:stretch;}
    .app-shell{
      max-width:100%;
      width:100%;
      height:100vh;
      height:100dvh;
      border-radius:0;
      box-shadow:none;
      border:none;
    }

    .menu-toggle{display:flex;}
    .collapse-btn{display:none;}

    .sidebar{
      position:fixed;
      top:0;left:0;bottom:0;
      width:82%;
      max-width:300px;
      flex:0 0 auto;
      z-index:1000;
      transform:translateX(-100%);
      box-shadow:var(--shadow-3);
    }
    .sidebar.open{transform:translateX(0);}
    .sidebar.collapsed{width:82%;max-width:300px;padding-left:16px;padding-right:16px;} /* collapse is a desktop-only feature */
    .sidebar.collapsed .brand-full{display:flex;flex-direction:column;}
    .sidebar.collapsed .brand-mini{display:none;}
    .sidebar.collapsed .brand-lockup{flex-direction:row;align-items:flex-start;}
    .sidebar.collapsed .nav-item{justify-content:flex-start;padding:13px 12px;}
    .sidebar.collapsed .nav-label{display:inline;}
    .sidebar.collapsed .nav-badge{position:static;min-width:19px;height:19px;font-size:11px;padding:0 5px;}
    .sidebar.collapsed .sync-text,
    .sidebar.collapsed .user-chip .who,
    .sidebar.collapsed .user-chip .role{display:inline;}
    .sidebar.collapsed .sync-pill{justify-content:flex-start;}
    .sidebar.collapsed .user-chip{justify-content:flex-start;}

    .sidebar-backdrop{display:block;}

    .nav-item{min-height:46px;padding:12px 14px;font-size:15px;}
    .icon-btn{width:44px;height:44px;}

    .topbar{padding:14px 16px;}
    .topbar h1{font-size:21px;}
    .topbar-logo{display:block;}
    .views{padding:16px 16px 32px;}
    .section-head h2{font-size:19px;}

    /* single-column reflow for most card grids — but keep 2-up where the tiles are small
       enough to stay legible, so the phone screen carries real signal, not one stat per screen */
    .grid-5, .grid-3, .grid-2{grid-template-columns:1fr;}
    .grid-4{grid-template-columns:repeat(2,1fr);}
    .grid{gap:12px;}

    /* ---- KPI tiles stay 2-up on mobile: this is the core "more signal per screen" fix ---- */
    .kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
    .kpi-tile{padding:12px 12px 11px;}
    .kpi-value{font-size:21px;}
    .kpi-value.small{font-size:15px;}

    /* tighten the default card padding everywhere on phone — denser rhythm, less dead air */
    .card{padding:14px 14px 13px;}
    .stat-card{padding:14px 14px 12px;}
    .stat-card .icon-wrap{width:28px;height:28px;margin-bottom:8px;}
    .stat-card .icon-wrap svg{width:14px;height:14px;}
    .stat-card .value{font-size:22px;}

    .source-legend{flex-direction:column;align-items:flex-start;gap:8px;}

    /* ---- Tenants table -> stacked cards ---- */
    .table-card table, .table-card thead, .table-card tbody{display:block;width:100%;}
    .table-card thead{display:none;}
    .table-card tbody tr.tenant-row{
      display:block;position:relative;
      padding:14px 34px 14px 16px;
      border-bottom:1px solid var(--hairline-soft);
    }
    .table-card tbody tr.tenant-row td{
      display:flex;justify-content:space-between;align-items:center;
      gap:12px;padding:6px 0;border-bottom:none;text-align:right;
    }
    .table-card tbody tr.tenant-row td::before{
      content:attr(data-label);
      font-size:10.5px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
      color:var(--fg3);text-align:left;flex:0 0 auto;
    }
    .table-card tbody tr.tenant-row td[data-label]:first-child{padding-top:0;}
    .table-card tbody tr.tenant-row td.tenant-cell{justify-content:flex-start;padding-bottom:10px;}
    .table-card tbody tr.tenant-row td.tenant-cell::before{display:none;}
    .table-card tbody tr.tenant-row td.tenant-cell .tenant-name{font-size:15px;}
    .table-card tbody tr.tenant-row td.chev-cell{
      display:block;position:absolute;top:14px;right:10px;padding:0;
    }
    .table-card tbody tr.tenant-row td.chev-cell::before{display:none;}
    .table-card tbody tr.tenant-row td.chev-cell .chev{display:none;}
    .mobile-chev{
      display:flex;width:26px;height:26px;align-items:center;justify-content:center;
      color:var(--fg3);transition:transform 200ms ease;
    }
    .mobile-chev svg{width:16px;height:16px;stroke-width:1.75px;}
    tr.tenant-row.open .mobile-chev{transform:rotate(180deg);}
    tr.detail-row td{display:block;}
    .detail-inner{grid-template-columns:1fr;gap:16px;padding:16px;}

    /* ---- Money ---- */
    .balance-figure{font-size:28px;}
    .bar-chart{gap:6px;height:130px;}
    .bar{max-width:28px;}
    .bar-value{font-size:10px;}
    .bar-label{font-size:10px;}
    .receivable-row{flex-wrap:wrap;gap:4px;}
    .pnl-last{display:none;} /* the delta chip already gives the vs-last-month context — drop the redundant figure to stop wrapping */
    .pnl-values{gap:10px;}

    /* ---- Meetings ---- */
    .next-meeting-card{flex-direction:column;align-items:flex-start;gap:14px;padding:20px;}
    .countdown-chip{align-self:flex-start;}
    .meeting-log-item{gap:12px;}
    .meeting-date{flex-basis:76px;font-size:11.5px;}

    /* ---- Projects: don't force a tall min-height on phone, content sets the height ---- */
    .project-card{min-height:0;gap:8px;}

    /* ---- SEO query table: horizontal scroll instead of squeeze ---- */
    .query-table{min-width:560px;}

    /* ---- tap targets ---- */
    .card.clickable{min-height:44px;}
    .inbox-item{padding:14px 6px;}

    /* ---- New sections: task check target, note media, modal-as-bottom-sheet ---- */
    .task-check{width:28px;height:28px;}
    .note-media-tile{width:72px;height:72px;}
    .contact-group-head{margin:18px 0 10px;}
    .modal-overlay{align-items:flex-end;padding:0;}
    .modal-sheet{max-width:100%;border-radius:20px 20px 0 0;max-height:90vh;transform:translateY(100%);padding:22px 18px 26px;}
    .modal-overlay.visible .modal-sheet{transform:translateY(0);}
    .section-head-row{flex-direction:column;align-items:stretch;}
    .section-head-row .btn-primary{width:100%;justify-content:center;}
  }

  @media (min-width:769px) and (max-width:1024px){
    .grid-5{grid-template-columns:repeat(3,1fr);}
    .grid-4{grid-template-columns:repeat(2,1fr);}
  }

/* ============================================================
   REAL-APP ADDITIONS — login page, toasts, skeletons, source
   chips, empty states, uploads, settings row. Kept in the same
   token system as the mockup CSS above (nothing new invented).
   ============================================================ */

/* ---- Login page ---- */
.login-canvas{
  min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:
    radial-gradient(circle at 15% 0%, rgba(0,70,69,0.06), transparent 55%),
    radial-gradient(circle at 85% 100%, rgba(216,102,54,0.05), transparent 50%),
    var(--flaxen-cool);
}
.login-card{
  width:100%;max-width:380px;
  background:var(--flaxen);border:1px solid var(--hairline);border-radius:26px;
  box-shadow:var(--shadow-3);padding:34px 30px 30px;
  text-align:center;
}
.login-logo{height:44px;width:auto;margin:0 auto 6px;display:block;filter:invert(1) brightness(0.2);}
.login-card h1{font-size:19px;margin-top:14px;}
.login-card p.lede{font-size:13.5px;color:var(--fg3);margin:8px 0 22px;line-height:1.5;}
.login-form .form-field{text-align:left;}
.login-msg{font-size:13px;color:var(--fg3);margin-top:14px;min-height:18px;}
.login-msg.error{color:var(--bad);font-weight:600;}
.login-msg.ok{color:var(--ok);font-weight:600;}
.login-check{
  width:52px;height:52px;border-radius:50%;background:var(--ok-bg);color:var(--ok);
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;
}
.login-check svg{width:24px;height:24px;stroke-width:2px;}

/* ---- Source chip: LIVE vs sample data, woven into card headers ---- */
.source-chip{
  display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;
  letter-spacing:0.06em;text-transform:uppercase;padding:3px 9px;border-radius:var(--radius-pill);
}
.source-chip.live{background:var(--ok-bg);color:var(--ok);}
.source-chip.mock{background:var(--neutral-bg);color:var(--fg3);}
.source-chip .dot{width:5px;height:5px;border-radius:50%;background:currentColor;}
.eyebrow-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}

/* ---- Skeletons (loading state) ---- */
.skel{background:linear-gradient(90deg,var(--hairline-soft) 25%,var(--hairline) 37%,var(--hairline-soft) 63%);background-size:400% 100%;animation:skelShine 1.4s ease infinite;border-radius:var(--radius-xs);}
@keyframes skelShine{0%{background-position:100% 0;}100%{background-position:-100% 0;}}
.skel-line{height:12px;margin:6px 0;border-radius:6px;}
.skel-tile{height:96px;border-radius:var(--radius-tile);}
.skel-row{display:flex;gap:12px;align-items:center;padding:13px 8px;}
.skel-avatar{width:32px;height:32px;border-radius:50%;flex:0 0 auto;}

/* ---- Empty states ---- */
.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:34px 16px;color:var(--fg3);}
.empty-state .icon-wrap{width:44px;height:44px;border-radius:14px;background:var(--flaxen-warm);color:var(--forrest-tint);display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.empty-state .icon-wrap svg{width:20px;height:20px;stroke-width:1.75px;}
.empty-state .headline{font-size:14px;font-weight:700;color:var(--forrest);}
.empty-state .sub{font-size:12.5px;color:var(--fg3);margin-top:4px;max-width:36ch;}
.empty-state .btn-primary,.empty-state .btn-secondary{margin-top:14px;}

/* ---- Error banner (non-blocking, inline within a section) ---- */
.error-banner{
  display:flex;align-items:center;gap:10px;background:var(--bad-bg);color:var(--bad);
  border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;font-weight:600;margin-bottom:16px;
}
.error-banner svg{width:16px;height:16px;flex:0 0 auto;}

/* ---- Toasts ---- */
.toast-stack{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:3000;display:flex;flex-direction:column;gap:8px;align-items:center;width:100%;max-width:420px;padding:0 16px;pointer-events:none;}
.toast{
  pointer-events:auto;
  background:var(--forrest-deep);color:var(--flaxen);font-size:13px;font-weight:600;
  padding:12px 18px;border-radius:var(--radius-pill);box-shadow:var(--shadow-3);
  display:flex;align-items:center;gap:8px;
  opacity:0;transform:translateY(8px);transition:opacity 180ms var(--ease),transform 180ms var(--ease);
  max-width:100%;
}
.toast.visible{opacity:1;transform:translateY(0);}
.toast.error{background:var(--bad);}
.toast.ok{background:var(--ok);}

/* ---- Upload chips (real files, not mock placeholders) ---- */
.composer-chip.uploading{opacity:0.65;}
.composer-tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;}
.composer-tag-row select{
  font-family:var(--font-body);font-size:12.5px;color:var(--fg2);font-weight:600;
  padding:7px 10px;border-radius:var(--radius-pill);border:1px solid var(--hairline);background:#fff;
}
.note-media-tile img{width:100%;height:100%;object-fit:cover;}
.note-media-tile.pending{opacity:0.55;}

/* ---- Settings row (Overview — notification toggle) ---- */
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 4px;}
.settings-row .label-block .t{font-size:13.5px;font-weight:700;color:var(--forrest);}
.settings-row .label-block .s{font-size:12px;color:var(--fg3);margin-top:2px;}
.switch{position:relative;width:44px;height:26px;flex:0 0 auto;}
.switch input{opacity:0;width:0;height:0;position:absolute;}
.switch .track{position:absolute;inset:0;background:var(--hairline);border-radius:var(--radius-pill);cursor:pointer;transition:background 160ms ease;}
.switch .track::before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;box-shadow:var(--shadow-1);transition:transform 160ms var(--ease);}
.switch input:checked + .track{background:var(--ok);}
.switch input:checked + .track::before{transform:translateX(18px);}
.switch input:disabled + .track{opacity:0.45;cursor:not-allowed;}

/* ---- Small helpers ---- */
.hidden-file-input{display:none;}
.link-btn{background:none;border:none;color:var(--forrest-tint);font-weight:700;font-size:12.5px;cursor:pointer;padding:0;}
.link-btn:hover{color:var(--forrest);text-decoration:underline;}
.muted{color:var(--fg3);}
.text-right{text-align:right;}
.section-note{font-size:12px;color:var(--fg3);margin-top:8px;line-height:1.5;}
.inline-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px;}
.tenant-edit-btn{margin-top:14px;}
