/* IVO v4 client area (ca-* design system) - scoped to WHMCS #main-body content.
   Dark, blue accent. Token values mirror ~/Desktop/ivo-new-v4 (data-mode=dark). */
#main-body{
  --bg:#08090b; --bg-2:#0d0f12;
  --panel:#101317; --panel-2:#161a20;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --ink:#f3f5f7; --ink-2:#aab0ba; --ink-3:#7b818d; --ink-4:#565c66;
  --accent:#5b8cff; --accent-bg:rgba(91,140,255,.14); --accent-text:#8fb0ff; --accent-line:rgba(91,140,255,.36);
  --green:#3ddc84; --green-bg:rgba(61,220,132,.14); --green-ink:#3ddc84;
  --amber:#ffc24d; --amber-bg:rgba(255,194,77,.14); --amber-ink:#ffc24d;
  --red:#ff6b6b; --red-bg:rgba(255,107,107,.14); --red-ink:#ff6b6b;
}

/* ---- layout ---- */
.ca{max-width:1180px;margin:0 auto;padding:4px 0 48px}
.ca-crumb{display:flex;gap:8px;align-items:center;color:var(--ink-3);font-size:13px;margin-bottom:10px}
.ca-crumb a{color:var(--ink-3)}.ca-crumb a:hover{color:var(--ink-2)}
.ca-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.ca-head h1{font-size:clamp(23px,3vw,31px);margin:0 0 4px;letter-spacing:-.02em;color:var(--ink)}
.ca-head p{color:var(--ink-3);margin:0;font-size:14px}
.ca-grid{display:grid;grid-template-columns:250px 1fr;gap:26px;align-items:start}
@media(max-width:900px){.ca-grid{grid-template-columns:1fr}.ca-side{position:static;order:-1}}

/* ---- sidebar nav ---- */
.ca-side{position:sticky;top:84px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:10px}
.ca-side nav{display:flex;flex-direction:column;gap:1px}
.ca-side-h{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);padding:14px 12px 6px}
.ca-side-a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:var(--ink-2);font-size:14px;font-weight:500;transition:.15s}
.ca-side-a svg{width:17px;height:17px;opacity:.75;flex:none}
.ca-side-a i{width:18px;font-size:14px;text-align:center;opacity:.7;flex:none}
.ca-side-a:hover{background:var(--panel-2);color:var(--ink)}
.ca-side-a.on{background:var(--accent-bg);color:var(--accent-text);font-weight:600}
.ca-side-a.on svg,.ca-side-a.on i{opacity:1;color:var(--accent)}

/* ---- main column ---- */
.ca-main{min-width:0;display:flex;flex-direction:column;gap:20px}
.ca-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 32px -26px rgba(0,0,0,.55)}
.ca-card-h{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,color-mix(in srgb,var(--panel-2) 55%,transparent),transparent)}
.ca-card-h h3{margin:0;font-size:15px;color:var(--ink)}
.ca-card-b{padding:20px}.ca-card-b.flush{padding:0}

/* ---- stat cards ---- */
.ca-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(176px,1fr));gap:16px}
.ca-stat{display:flex;align-items:flex-start;gap:13px;background:linear-gradient(180deg,var(--panel),color-mix(in srgb,var(--panel) 86%,var(--bg)));border:1px solid var(--line);border-radius:16px;padding:17px 18px;transition:transform .18s,border-color .18s,box-shadow .18s}
.ca-stat:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 28%,var(--line));box-shadow:0 14px 30px -20px rgba(0,0,0,.65)}
.ca-stat-ic{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;background:var(--panel-2);color:var(--ink-3);flex:none}
.ca-stat-ic svg{width:19px;height:19px}
.ca-stat-ic i{font-size:18px;line-height:1}
.ca-stat-tx{min-width:0;flex:1}
.ca-stat .lbl{display:block;color:var(--ink-3);font-size:12.5px;margin-bottom:7px}
.ca-stat b{display:block;font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums;color:var(--ink)}
.ca-stat small{display:block;color:var(--ink-4);font-size:12px;margin-top:6px}
.ca-stat.acc{border-color:color-mix(in srgb,var(--accent) 34%,var(--line))}
.ca-stat.acc .ca-stat-ic{background:var(--accent-bg);color:var(--accent)}
.ca-stat.acc b{color:var(--accent)}

/* ---- quick actions ---- */
.ca-quick{display:grid;grid-template-columns:repeat(auto-fit,minmax(152px,1fr));gap:12px}
.ca-quick-a{display:flex;align-items:center;gap:11px;padding:14px 16px;background:var(--panel);border:1px solid var(--line);border-radius:13px;color:var(--ink);font-weight:600;font-size:13.5px;transition:transform .18s,border-color .18s,background .18s}
.ca-quick-a:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));background:var(--panel-2);transform:translateY(-2px);color:var(--ink)}
.ca-quick-a svg{width:19px;height:19px;color:var(--accent);flex:none}
.ca-quick-a i{font-size:16px;color:var(--accent);width:20px;text-align:center;flex:none}

/* ---- tables ---- */
.ca-tablewrap{overflow-x:auto}
table.ca-table{width:100%;border-collapse:collapse;font-size:13.5px;margin:0}
.ca-table th{text-align:left;padding:12px 18px;color:var(--ink-4);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--line);white-space:nowrap;background:none}
.ca-table td{padding:13px 18px;border-bottom:1px solid var(--line-2);color:var(--ink-2);vertical-align:middle;background:none}
.ca-table tbody tr:last-child td{border-bottom:0}
.ca-table tbody tr:hover{background:var(--panel-2)}
.ca-table td a{color:var(--accent-text);font-weight:500}
.ca-table .num{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}

/* ---- pills ---- */
.ca .pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.5;border:1px solid transparent}
.ca .pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.ca .pill.ok{background:var(--green-bg);color:var(--green-ink);border-color:color-mix(in srgb,var(--green) 28%,transparent)}
.ca .pill.warn{background:var(--amber-bg);color:var(--amber-ink);border-color:color-mix(in srgb,var(--amber) 28%,transparent)}
.ca .pill.danger{background:var(--red-bg);color:var(--red-ink);border-color:color-mix(in srgb,var(--red) 28%,transparent)}
.ca .pill.info{background:var(--accent-bg);color:var(--accent-text);border-color:var(--accent-line)}
.ca .pill.mut{background:var(--panel-2);color:var(--ink-3);border-color:var(--line)}

/* ---- 2-col + notes ---- */
.ca-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:760px){.ca-2col{grid-template-columns:1fr}}
.ca-empty{text-align:center;padding:40px 20px;color:var(--ink-3);font-size:14px}
.ca-note{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:13px 16px;color:var(--ink-2);font-size:13.5px}

/* ---- dark-theme WHMCS default tables / datatables on inner client pages ---- */
#main-body .table{color:var(--ink-2);background:transparent}
#main-body .table thead th,#main-body table.dataTable thead th,#main-body .table-list thead th{background:var(--panel-2)!important;color:var(--ink-4)!important;border-color:var(--line)!important;border-bottom:1px solid var(--line)!important}
#main-body .table td,#main-body .table th{border-color:var(--line-2)!important;background-color:transparent!important}
#main-body .table tbody tr{background:transparent!important}
#main-body .table tbody tr:hover,#main-body .table-list tbody tr:hover{background:var(--panel-2)!important}
#main-body .table a{color:var(--accent-text)}
#main-body .dataTables_wrapper{color:var(--ink-3)}
#main-body .dataTables_wrapper label{color:var(--ink-3)}
#main-body .dataTables_filter input,#main-body .dataTables_length select,#main-body .form-control,#main-body select.form-control{background:var(--bg-2)!important;border:1px solid var(--line)!important;color:var(--ink)!important;border-radius:12px}
#main-body .dataTables_info{color:var(--ink-4)}
#main-body .dataTables_paginate .paginate_button{color:var(--ink-3)!important;border:0!important;background:transparent!important}
#main-body .dataTables_paginate .paginate_button.current,#main-body .dataTables_paginate .paginate_button:hover{background:var(--accent-bg)!important;color:var(--accent-text)!important;border-radius:7px!important}

/* ---- WHMCS status labels -> pill look ---- */
#main-body .label,#main-body span.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;border:1px solid transparent}
#main-body .label-success,#main-body .badge-success{background:var(--green-bg);color:var(--green-ink);border-color:color-mix(in srgb,var(--green) 28%,transparent)}
#main-body .label-warning,#main-body .badge-warning{background:var(--amber-bg);color:var(--amber-ink);border-color:color-mix(in srgb,var(--amber) 28%,transparent)}
#main-body .label-danger,#main-body .badge-danger{background:var(--red-bg);color:var(--red-ink);border-color:color-mix(in srgb,var(--red) 28%,transparent)}
#main-body .label-default,#main-body .badge-secondary{background:var(--panel-2);color:var(--ink-3);border-color:var(--line)}

/* ---- pagination (Bootstrap + dataTables) dark ---- */
#main-body .page-link,#main-body .pagination .page-link{background:var(--bg-2)!important;border-color:var(--line)!important;color:var(--ink-2)!important}
#main-body .page-item.active .page-link{background:var(--accent-bg)!important;border-color:var(--accent-line)!important;color:var(--accent-text)!important}
#main-body .page-item.disabled .page-link{color:var(--ink-4)!important;background:transparent!important;border-color:var(--line)!important}
#main-body .dataTables_paginate .paginate_button.previous,#main-body .dataTables_paginate .paginate_button.next{background:var(--bg-2)!important;border:1px solid var(--line)!important;border-radius:8px!important;color:var(--ink-2)!important}
/* ---- bootstrap-switch (security toggles) dark ---- */
#main-body .bootstrap-switch{border-color:var(--line)!important}
#main-body .bootstrap-switch-handle-off,#main-body .bootstrap-switch-label{background:var(--panel-2)!important;color:var(--ink-3)!important}

/* ---- mobile: rail collapses to a compact horizontal scroller ---- */
@media(max-width:991.98px){
  .ca-rail-col{margin-bottom:16px}
  .ca-side,.ca-side-rail{position:static;padding:6px}
  .ca-side nav,.ca-side-rail nav{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:4px;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .ca-side-h{display:none}
  .ca-side-a{white-space:nowrap;padding:8px 12px}
  .ca-stats{grid-template-columns:1fr 1fr}
}

/* ==========================================================================
   v5 refinement layer - polish on top of the ca-* system (dashboard + cards)
   ========================================================================== */

/* ---- accent-tinted stat icons (was flat low-contrast) ---- */
.ca-stat-ic{background:var(--accent-bg);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent)}
.ca-stat:hover .ca-stat-ic{background:color-mix(in srgb,var(--accent) 22%,transparent)}
.ca-stat.acc .ca-stat-ic{background:var(--amber-bg);color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,transparent)}

/* ---- native WHMCS home cards: rounded, separated headers, refined body ---- */
#main-body .client-home-cards .card{border-radius:16px;overflow:hidden;background:var(--panel)!important}
#main-body .client-home-cards .row{display:flex;flex-wrap:wrap;margin:0 -10px}
#main-body .client-home-cards [class*="col-"]{padding:0 10px}
#main-body .client-home-cards .card{margin-bottom:20px}
#main-body .client-home-cards .card-header{padding:15px 20px!important;border-bottom:1px solid var(--line)!important;background:linear-gradient(180deg,color-mix(in srgb,var(--panel-2) 55%,transparent),transparent)!important;display:flow-root}
#main-body .client-home-cards .card-title{font-size:14.5px!important;font-weight:600!important;letter-spacing:-.01em;color:var(--ink)!important;line-height:1.7;margin:0}
#main-body .client-home-cards .card-title i{color:var(--accent);opacity:.9;margin-right:2px}
#main-body .client-home-cards .card-title .float-right{margin-left:12px}
#main-body .client-home-cards .card-title .float-right i{color:inherit}
#main-body .client-home-cards .card-body{padding:18px 20px!important;color:var(--ink-2)}
#main-body .client-home-cards .card-footer:empty{display:none}

/* ---- in-card buttons: kill 0-radius sharp corners, refined pill look ---- */
#main-body .client-home-cards .btn,#main-body .card .btn.btn-xs,#main-body .card .btn-default{
  border-radius:9px!important;font-size:12.5px!important;font-weight:600!important;
  padding:7px 14px!important;line-height:1.2;border:1px solid var(--line-2)!important;
  background:var(--panel-2)!important;color:var(--ink-2)!important;
  transition:background .15s,border-color .15s,color .15s,transform .15s}
#main-body .client-home-cards .btn:hover,#main-body .card .btn.btn-xs:hover,#main-body .card .btn-default:hover{
  background:color-mix(in srgb,var(--accent) 14%,var(--panel-2))!important;
  border-color:var(--accent-line)!important;color:var(--ink)!important;transform:translateY(-1px)}
#main-body .client-home-cards .card-title .float-right .btn{margin-left:auto}
/* primary / coloured CTAs -> accent */
#main-body .client-home-cards .btn-primary,#main-body .card .btn-primary,
#main-body .client-home-cards .bg-color-gold,#main-body .client-home-cards .bg-color-blue{
  background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important}
#main-body .client-home-cards .btn-primary:hover,#main-body .card .btn-primary:hover,
#main-body .client-home-cards .bg-color-gold:hover,#main-body .client-home-cards .bg-color-blue:hover{
  background:color-mix(in srgb,var(--accent) 84%,#000)!important;border-color:transparent!important;color:#fff!important}

/* ---- list-group rows inside cards (services, tickets, news) ---- */
#main-body .client-home-cards .list-group{padding:6px}
#main-body .client-home-cards .list-group-item{background:transparent!important;border:0!important;border-radius:10px!important;color:var(--ink-2)!important;padding:11px 14px!important;font-size:13.5px;transition:background .15s}
#main-body .client-home-cards .list-group-item-action:hover{background:var(--panel-2)!important;color:var(--ink)!important}
#main-body .client-home-cards .list-group-item.active{background:var(--accent-bg)!important;color:var(--accent-text)!important}
#main-body .client-home-cards .list-group-item i{color:var(--ink-3);margin-right:8px}

/* ---- Projects (Beta) tab buttons ---- */
#main-body .client-home-cards .nav-pills .nav-link,#main-body .client-home-cards .btn-group .btn{border-radius:9px!important}

/* ---- MarketConnect "Recommended for you" promo: fit the dark theme ---- */
#main-body .promo-container{border-radius:16px!important;overflow:hidden;border:1px solid var(--line)!important;background:linear-gradient(180deg,var(--panel-2),var(--panel))!important;padding:22px 24px!important;box-shadow:none!important}
#main-body .promo-container h2,#main-body .promo-container h3{color:var(--ink)!important}
#main-body .promo-container .btn{border-radius:10px!important;background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important;font-weight:600!important;padding:9px 18px!important}
#main-body .promo-container .btn:hover{background:color-mix(in srgb,var(--accent) 84%,#000)!important;color:#fff!important}
#main-body .promo-container .close,#main-body .promo-container .carousel-control{color:var(--ink-3)!important;opacity:.7}

/* ---- pull the whole dash up a touch + smoother section rhythm ---- */
.ca-dash .ca-main{gap:22px}
.ca-dash .ca-head h1{font-weight:600}
