/*
  UpTime Invoice Pro - App Core Styles
  Split from public_html/app/index.html
  Version: 14.6
  Notes: Core app, mobile, portal, projects, recurring, payments, proof review and App Shell Polish Pro styles plus Dashboard Executive Pro styles.
  Services Command Center CSS stays separated in /assets/services-command-center.css
*/

:root{--bg:#070b14;--panel:#0d1424;--panel2:#111b30;--line:rgba(255,255,255,.1);--txt:#eef4ff;--muted:#8ea0bd;--brand:#25d6a2;--brand2:#60a5fa;--danger:#fb7185;--warn:#fbbf24;--ok:#34d399;--shadow:0 24px 70px rgba(0,0,0,.45);--r:24px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at 20% 10%,rgba(37,214,162,.16),transparent 26%),radial-gradient(circle at 90% 0,rgba(96,165,250,.14),transparent 30%),linear-gradient(135deg,#050814,#0a1020 48%,#050814);color:var(--txt);min-height:100vh}.glass,.panel{background:linear-gradient(180deg,rgba(17,27,48,.86),rgba(9,15,28,.94));border:1px solid var(--line);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.loginWrap{min-height:100vh;display:grid;place-items:center;padding:28px}.loginCard{width:min(480px,100%);border-radius:var(--r);padding:34px}.logo{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-weight:900;letter-spacing:-.06em;color:#001811;background:linear-gradient(135deg,var(--brand),#bef264)}.eyebrow{margin:0 0 8px;color:var(--brand);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.16em}.muted{color:var(--muted)}h1,h2,h3{margin:0 0 12px;letter-spacing:-.04em}h1{font-size:38px}.stack{display:grid;gap:14px}.footer{font-size:12px;color:var(--muted);margin-top:22px;line-height:1.45}label{display:grid;gap:7px;color:#c9d7ef;font-size:13px}input,select,textarea{width:100%;border:1px solid var(--line);background:#07101f;color:var(--txt);border-radius:14px;padding:12px 13px;outline:none}input:focus,select:focus,textarea:focus{border-color:rgba(37,214,162,.7);box-shadow:0 0 0 4px rgba(37,214,162,.1)}button{border:0;border-radius:14px;padding:11px 14px;font-weight:800;cursor:pointer;color:var(--txt);background:#17233a}.primary{background:linear-gradient(135deg,var(--brand),#2dd4bf);color:#062014}.ghost{background:rgba(255,255,255,.06);border:1px solid var(--line)}.tiny{padding:8px 10px;font-size:12px}.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh;gap:18px;padding:18px}.side{border-radius:var(--r);padding:18px;display:flex;flex-direction:column;gap:18px;position:sticky;top:18px;height:calc(100vh - 36px)}.brand{display:flex;gap:12px;align-items:center}.brand .logo{width:42px;height:42px;border-radius:14px}.brand span{display:block;color:var(--muted);font-size:12px;margin-top:2px}.nav{display:grid;gap:8px}.nav button{display:flex;gap:10px;align-items:center;justify-content:flex-start;background:transparent;color:#c6d4ed}.nav button.active,.nav button:hover{background:rgba(37,214,162,.12);color:white;border:1px solid rgba(37,214,162,.22)}.main{display:grid;gap:18px;align-content:start}.top{border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.topActions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.panel{border-radius:var(--r);padding:20px}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.two{display:grid;grid-template-columns:380px 1fr;gap:16px}.wide{grid-column:1/-1}.metric span{display:block;color:var(--muted);font-size:13px}.metric strong{font-size:28px;display:block;margin-top:8px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;border-bottom:1px solid var(--line);padding:12px 10px;vertical-align:top}th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em}.tableWrap{overflow:auto}.badge{display:inline-flex;border-radius:99px;padding:5px 9px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;background:rgba(96,165,250,.14);color:#bfdbfe}.badge.paid,.badge.approved,.badge.converted{background:rgba(52,211,153,.15);color:#bbf7d0}.badge.partial,.badge.sent,.badge.viewed{background:rgba(251,191,36,.14);color:#fde68a}.badge.overdue,.badge.rejected,.badge.cancelled{background:rgba(251,113,133,.14);color:#fecdd3}.actions{display:flex;gap:8px;flex-wrap:wrap}.danger{background:rgba(251,113,133,.14);border:1px solid rgba(251,113,133,.35);color:#fecdd3}.success{background:rgba(52,211,153,.14);border:1px solid rgba(52,211,153,.35);color:#bbf7d0}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:12px}.searchBox{max-width:360px}.toast{position:fixed;right:18px;bottom:18px;z-index:20;max-width:430px;border-radius:18px;padding:14px 16px;background:#07101f;border:1px solid rgba(37,214,162,.35);box-shadow:var(--shadow)}.hidden{display:none!important}.alert{border:1px solid rgba(251,113,133,.35);background:rgba(251,113,133,.1);color:#fecdd3;border-radius:14px;padding:12px}.loading{position:fixed;inset:0;display:grid;place-items:center}.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.docWrap{min-height:100vh;padding:22px;display:grid;place-items:start center}.docCard{width:min(920px,100%);border-radius:24px;padding:24px}.docHead{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.docTotal{font-size:38px;font-weight:900;letter-spacing:-.05em}.docActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}@media(max-width:1000px){.app{grid-template-columns:1fr}.side{position:relative;height:auto}.grid{grid-template-columns:repeat(2,1fr)}.two{grid-template-columns:1fr}}@media(max-width:620px){.grid{grid-template-columns:1fr}.top{align-items:flex-start;flex-direction:column}.loginCard{padding:24px}h1{font-size:32px}.app{padding:10px}.split{grid-template-columns:1fr}}


    /* V9 Mobile App Responsive Fix */
    html,body{max-width:100%;overflow-x:hidden}
    img,svg,video,canvas{max-width:100%;height:auto}
    a,button,input,select,textarea{max-width:100%}
    .docCard,.panel,.glass{min-width:0}
    .tableWrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
    @media(max-width:760px){
      body{background:radial-gradient(circle at 0 0,rgba(37,214,162,.18),transparent 32%),linear-gradient(180deg,#081423,#070b14)}
      .docWrap{display:block;min-height:100vh;width:100%;padding:10px 10px 24px;place-items:unset}
      .docCard{width:100%;max-width:100%;border-radius:22px;padding:18px 16px;box-shadow:0 16px 44px rgba(0,0,0,.32)}
      .docHead{display:grid;grid-template-columns:1fr;gap:16px}
      .docHead>div{min-width:0}
      .docHead>div:last-child{text-align:left!important;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
      .docTotal{font-size:34px;line-height:1}
      .docActions{display:grid;grid-template-columns:1fr;gap:10px;width:100%}
      .docActions button,.docActions a{width:100%;text-align:center;justify-content:center}
      .split{grid-template-columns:1fr!important;gap:12px}
      .panel{border-radius:20px;padding:16px}
      h1{font-size:34px;line-height:1.06;word-break:break-word}
      h2{font-size:24px}h3{font-size:19px}
      .eyebrow{font-size:11px;letter-spacing:.14em}
      .logo{width:50px;height:50px;border-radius:17px}
      .muted{line-height:1.35}
      .app{display:block;padding:0}
      .side{position:relative;height:auto;border-radius:0 0 22px 22px;margin:0 0 12px;padding:14px}
      .nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
      .nav button{font-size:13px;padding:10px 9px;justify-content:center}
      .main{padding:0 10px 18px;gap:12px}
      .top{border-radius:22px;padding:16px}.topActions{width:100%}.topActions button{flex:1}
      .two{grid-template-columns:1fr!important}.grid{grid-template-columns:1fr!important;gap:10px}
      .toolbar{align-items:stretch}.toolbar .searchBox{max-width:none;width:100%}
      table{font-size:12px}
      th,td{padding:10px 8px}
      .actions{display:grid;grid-template-columns:1fr;gap:8px}.actions button,.actions a{width:100%}
      .toast{left:10px;right:10px;bottom:10px;max-width:none}
      /* Public estimate/invoice tables become mobile cards */
      .docCard table,.docCard thead,.docCard tbody,.docCard tr,.docCard th,.docCard td{display:block;width:100%}
      .docCard thead{display:none}
      .docCard tr{border:1px solid var(--line);border-radius:16px;padding:10px;margin:0 0 12px;background:rgba(255,255,255,.025)}
      .docCard td{border:0;padding:6px 4px;overflow-wrap:anywhere}
      .docCard td:nth-child(1){font-weight:900;color:var(--txt)}
      .docCard td:nth-child(2){color:var(--muted);line-height:1.35}
      .docCard td:nth-last-child(-n+3){display:flex;justify-content:space-between;gap:12px}
      .docCard td:nth-child(3)::before{content:'Qty';color:var(--muted);font-weight:800}
      .docCard td:nth-child(4)::before{content:'Price';color:var(--muted);font-weight:800}
      .docCard td:nth-child(5)::before{content:'Total';color:var(--muted);font-weight:800}
    }
    @media(max-width:390px){
      .docCard{padding:16px 12px;border-radius:18px}
      h1{font-size:30px}.docTotal{font-size:30px}
      .panel{padding:14px}.nav button{font-size:12px}
    }



    /* V10.5 App UI Button Polish + Mobile Pro + Logo Fix */
    .logo{overflow:hidden;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 10px 26px rgba(37,214,162,.18)}
    .logo img{display:block;width:100%;height:100%;object-fit:contain;object-position:center;border-radius:inherit}
    .side .brand .logo{width:50px;height:50px;border-radius:18px;background:linear-gradient(135deg,rgba(37,214,162,.18),rgba(190,242,100,.12));padding:0}
    .side .brand .logo img{object-fit:cover;object-position:center top;transform:scale(1.28);transform-origin:center top}
    .brand strong{font-size:17px;line-height:1.1;letter-spacing:-.03em}
    button,.button,a.tiny,a.ghost,a.success,a.primary{appearance:none;-webkit-appearance:none;text-decoration:none!important;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.11);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));color:#eaf2ff;font-weight:900;line-height:1;white-space:nowrap;box-shadow:0 10px 22px rgba(0,0,0,.16);transition:transform .15s ease,border-color .15s ease,background .15s ease,box-shadow .15s ease}
    button:hover,a.tiny:hover,a.ghost:hover,a.success:hover,a.primary:hover{transform:translateY(-1px);border-color:rgba(37,214,162,.35);box-shadow:0 14px 28px rgba(0,0,0,.22)}
    button:active,a.tiny:active,a.ghost:active,a.success:active,a.primary:active{transform:translateY(0) scale(.98)}
    .primary,a.primary{background:linear-gradient(135deg,#25d6a2,#2dd4bf);color:#041914;border-color:rgba(37,214,162,.65)}
    .success,a.success{background:linear-gradient(135deg,rgba(37,214,162,.22),rgba(20,184,166,.15));color:#bbf7d0;border-color:rgba(37,214,162,.42)}
    .ghost,a.ghost{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border-color:rgba(255,255,255,.13);color:#eaf2ff}
    .danger,a.danger{background:linear-gradient(135deg,rgba(251,113,133,.22),rgba(244,63,94,.12));border-color:rgba(251,113,133,.42);color:#fecdd3}
    .tiny{padding:9px 13px;font-size:12px;min-height:36px}
    .actions{gap:9px;align-items:center}
    .actions .primary,.actions .success,.actions .ghost,.actions .danger,.actions button,.actions a{margin:0}
    .tableWrap{border-radius:18px;overflow:auto;border:1px solid rgba(255,255,255,.055)}
    .tableWrap table{min-width:760px;background:rgba(255,255,255,.015)}
    th{background:rgba(255,255,255,.025)}
    td{background:rgba(255,255,255,.006)}
    tr:hover td{background:rgba(37,214,162,.025)}
    .panel h3{font-size:20px}
    .top{position:relative;overflow:hidden}.top:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 0,rgba(37,214,162,.12),transparent 36%);pointer-events:none}
    input,select,textarea{min-height:44px}

    @media(max-width:760px){
      .side .brand{gap:12px}.side .brand .logo{width:46px;height:46px;border-radius:16px}.brand strong{font-size:16px}
      .nav{display:flex;overflow:auto;padding-bottom:4px;gap:8px;scroll-snap-type:x proximity}
      .nav button{flex:0 0 auto;min-width:max-content;border-radius:999px;padding:10px 13px;scroll-snap-align:start}
      .side{gap:12px}.side .footer{display:none}
      .top{border-radius:20px;margin:0}.top h2{font-size:24px}
      .panel{border-radius:22px;padding:16px}
      .tableWrap{border:0;overflow:visible}
      .main .tableWrap table,.main .tableWrap thead,.main .tableWrap tbody,.main .tableWrap tr,.main .tableWrap th,.main .tableWrap td{display:block;width:100%;min-width:0}
      .main .tableWrap thead{display:none}
      .main .tableWrap tr{background:linear-gradient(180deg,rgba(17,27,48,.9),rgba(8,14,27,.96));border:1px solid rgba(255,255,255,.09);border-radius:20px;margin:0 0 12px;padding:13px;box-shadow:0 14px 34px rgba(0,0,0,.18)}
      .main .tableWrap td{border:0;padding:7px 4px;background:transparent!important;overflow-wrap:anywhere}
      .main .tableWrap td:first-child{font-size:16px;font-weight:900;color:#fff}
      .main .tableWrap td:nth-last-child(1){padding-top:12px}
      .main .tableWrap .actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;width:100%}
      .main .tableWrap .actions button,.main .tableWrap .actions a{width:100%;min-height:42px;padding:10px 8px;font-size:12px}
      .main .tableWrap .actions .primary,.main .tableWrap .actions .success{grid-column:auto}
      .two{gap:12px}.split{gap:10px}
      .searchBox{min-height:46px;border-radius:16px}
      .docActions{gap:9px}.docActions button,.docActions a{min-height:46px;border-radius:16px}
    }
    @media(max-width:420px){
      .main .tableWrap .actions{grid-template-columns:1fr}
      .topActions button{width:100%}.panel h3{font-size:18px}
    }


    /* V10.8 Smart Logo Auto Fit - main app header logo */
    .brandFree{
      display:flex!important;
      align-items:center!important;
      gap:12px!important;
      min-width:0!important;
      overflow:hidden!important;
    }
    .brandFree > div{
      min-width:0!important;
      overflow:hidden!important;
    }
    .brandFree strong{
      display:block!important;
      white-space:nowrap!important;
      overflow:hidden!important;
      text-overflow:ellipsis!important;
      line-height:1.08!important;
      font-size:17px!important;
    }
    .brandFree span{
      display:block!important;
      white-space:nowrap!important;
      overflow:hidden!important;
      text-overflow:ellipsis!important;
      font-size:12px!important;
      color:var(--muted)!important;
      margin-top:2px!important;
    }
    .brandLogoFree{
      width:52px!important;
      height:52px!important;
      max-width:52px!important;
      max-height:52px!important;
      min-width:52px!important;
      min-height:52px!important;
      flex:0 0 52px!important;
      object-fit:contain!important;
      object-position:center!important;
      display:block!important;
      background:transparent!important;
      border:0!important;
      outline:0!important;
      box-shadow:none!important;
      border-radius:0!important;
      padding:0!important;
      margin:0!important;
    }
    .brandFallback{
      width:52px!important;
      height:52px!important;
      flex:0 0 52px!important;
      display:grid!important;
      place-items:center!important;
      color:#062014!important;
      background:linear-gradient(135deg,var(--brand),#bef264)!important;
      border-radius:14px!important;
      font-weight:900!important;
    }
    @media(max-width:760px){
      .brandLogoFree{width:46px!important;height:46px!important;max-width:46px!important;max-height:46px!important;min-width:46px!important;min-height:46px!important;flex-basis:46px!important}
      .brandFree strong{font-size:16px!important}
    }

  

    /* V10.9 Mobile App Navigation */
    .mobileTop{display:none}
    .mobileBackdrop{display:none}
    .mobileMenuBtn{
      width:44px;height:44px;min-width:44px;border-radius:15px;
      display:grid;place-items:center;font-size:21px;
      background:rgba(255,255,255,.07);border:1px solid var(--line);
      box-shadow:0 12px 34px rgba(0,0,0,.22)
    }
    @media(max-width:1000px){
      body{overflow-x:hidden}
      .mobileTop{
        display:flex;align-items:center;gap:12px;
        position:sticky;top:0;z-index:80;
        margin:0;padding:10px 12px;
        border-radius:0 0 22px 22px;
        border-left:0;border-right:0;border-top:0;
        backdrop-filter:blur(18px)
      }
      .mobileTop .brandLogoFree{width:38px!important;height:38px!important;min-width:38px!important;min-height:38px!important;flex-basis:38px!important}
      .mobileTop .brandFree strong{font-size:15px!important}
      .mobileTop .brandFree span{font-size:11px!important;color:var(--brand)!important}
      .app{display:block;padding:12px;min-height:auto}
      .side{
        position:fixed!important;left:12px;top:12px;bottom:12px;z-index:100;
        width:min(315px,calc(100vw - 24px));height:auto!important;
        transform:translateX(calc(-100% - 24px));transition:transform .24s ease;
        border-radius:26px;padding:18px;overflow:auto;
        box-shadow:0 28px 80px rgba(0,0,0,.65)
      }
      .side.open{transform:translateX(0)}
      .mobileBackdrop.show{display:block;position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.58);backdrop-filter:blur(4px)}
      .side .nav{display:grid!important;grid-template-columns:1fr!important;overflow:visible!important;gap:9px!important;padding-bottom:0!important;scroll-snap-type:none!important}
      .side .nav button{
        width:100%!important;min-width:0!important;justify-content:flex-start!important;
        border-radius:17px!important;padding:13px 14px!important;font-size:15px!important;
        min-height:48px!important;scroll-snap-align:none!important;
        background:rgba(255,255,255,.04);border:1px solid transparent
      }
      .side .nav button.active{background:rgba(37,214,162,.14)!important;border-color:rgba(37,214,162,.28)!important}
      .main{gap:12px;margin-top:10px}
      .top{display:none!important}
      .footer{font-size:11px}
      .side #logout{min-height:48px;border-radius:17px;width:100%;margin-top:auto}
    }

  
    /* V11.0 Services Pro Editor Plus */
    .catPill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:900;letter-spacing:.05em;white-space:nowrap;border:1px solid rgba(255,255,255,.1)}
    .cat-it{background:rgba(52,211,153,.13);color:#bbf7d0}.cat-web{background:rgba(168,85,247,.14);color:#e9d5ff}.cat-linkroot{background:rgba(59,130,246,.15);color:#bfdbfe}.cat-evento{background:rgba(251,191,36,.14);color:#fde68a}.cat-seo{background:rgba(45,212,191,.14);color:#ccfbf1}.cat-design{background:rgba(244,114,182,.14);color:#fbcfe8}.cat-maint{background:rgba(34,197,94,.13);color:#bbf7d0}.cat-digi{background:rgba(99,102,241,.15);color:#c7d2fe}.cat-default{background:rgba(148,163,184,.13);color:#e2e8f0}
    .inlineServiceInput{border-radius:12px;padding:9px 10px;min-width:160px;background:rgba(7,16,31,.78);border:1px solid rgba(255,255,255,.1)}.inlinePrice{min-width:110px;max-width:130px}.usedPill{display:inline-flex;border-radius:999px;padding:5px 9px;background:rgba(255,255,255,.06);border:1px solid var(--line);color:#cbd5e1;font-size:12px;font-weight:800}.serviceCards{display:none}.serviceCard{border:1px solid var(--line);border-radius:20px;padding:14px;background:rgba(255,255,255,.035);display:grid;gap:11px}.serviceCard.isOff{opacity:.72}.serviceCardHead{display:flex;align-items:center;justify-content:space-between;gap:10px}.serviceCardBody{display:grid;gap:4px}.serviceStats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.serviceStats span{border-radius:14px;background:rgba(255,255,255,.05);padding:8px 9px;text-align:center;font-size:12px;color:#dbeafe;font-weight:800}.serviceActions button{white-space:nowrap}
    @media(max-width:820px){.serviceTable{display:none}.serviceCards{display:grid;gap:12px}.inlineServiceInput{min-width:0}.serviceStats{grid-template-columns:1fr 1fr 1fr}.serviceActions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.serviceActions button{width:100%}}

  
    /* V12.1 White Label Ready */
    .portalCard{--portal-brand:var(--brand)}
    .portalBrandLogo{width:54px;height:54px;object-fit:contain;display:block;flex:0 0 auto}
    .portalBrandText strong{font-size:18px}
    .portalBrandText span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
    .portalCard .eyebrow,.portalCard .docTotal{color:var(--portal-brand)}
    .portalCard .primary,.portalCard .success{background:var(--portal-brand)!important;color:#061411!important;border-color:transparent!important}


/* V12.3 Customer Portal true mobile cards fix */
.portalMobileList{display:none}.portalBalance{text-align:right}.portalSection{overflow:hidden}.portalTable{max-width:100%}.portalItemCard{border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border-radius:22px;padding:16px;display:grid;gap:14px;box-shadow:0 16px 40px rgba(0,0,0,.18)}.portalItemTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.portalItemTop strong{display:block;font-size:20px;letter-spacing:.02em}.portalItemTop span{display:block;color:var(--muted);font-weight:800;margin-top:3px}.portalInfoGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.portalInfoGrid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.portalInfoGrid div{border-radius:16px;background:rgba(3,9,20,.35);border:1px solid rgba(255,255,255,.07);padding:10px}.portalInfoGrid span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:900}.portalInfoGrid b{display:block;margin-top:5px;font-size:15px;word-break:break-word}.portalOpenBtn{display:inline-flex;align-items:center;justify-content:center;width:max-content;min-width:132px;border-radius:999px;padding:12px 18px;background:var(--portal-brand,var(--brand));color:#04130f;text-decoration:none;font-weight:950;box-shadow:0 12px 30px rgba(37,214,162,.15)}
@media(max-width:760px){
  html,body,#root{max-width:100%;overflow-x:hidden!important}.docWrap.portalWrap{padding:14px!important;align-items:stretch!important}.portalWrap .docCard{width:100%!important;max-width:100%!important;padding:18px!important;border-radius:26px!important;overflow:hidden!important}.portalWrap .docHead{display:grid!important;grid-template-columns:1fr!important;gap:16px!important}.portalBalance{text-align:left!important}.portalWrap .docTotal{font-size:36px!important}.portalMetrics{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}.portalMetrics .metric{padding:13px!important}.portalToolbar{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;align-items:start!important}.portalToolbar .tiny{width:max-content}.portalWrap .portalTable{display:none!important}.portalWrap .portalMobileList{display:grid!important;gap:12px!important}.portalSection{margin-bottom:22px!important;padding:16px!important;border-radius:24px!important}.portalSection h3{font-size:22px!important}.portalItemTop strong{font-size:24px!important}.portalInfoGrid,.portalInfoGrid.three{grid-template-columns:1fr!important}.portalOpenBtn{width:100%;min-width:0}.portalWrap table,.portalWrap thead,.portalWrap tbody,.portalWrap tr,.portalWrap td,.portalWrap th{display:revert}.portalWrap td::before{content:none!important;display:none!important}.portalWrap .tableWrap{overflow:visible!important}.portalWrap .brandFree{align-items:center!important}.portalBrandLogo{width:48px!important;height:48px!important}.portalBrandText strong{font-size:16px!important}.portalWrap h1{font-size:34px!important;line-height:1.05!important;word-break:break-word}.portalWrap .muted{line-height:1.45!important}.footer{word-break:break-word;overflow-wrap:anywhere}
}

    /* V14 Project Workspace */
    .projectGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
    .projectCard{border:1px solid var(--line);border-radius:20px;padding:16px;background:rgba(255,255,255,.035)}
    .projectMeta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
    .projectMeta div{border:1px solid var(--line);border-radius:14px;padding:10px;background:rgba(0,0,0,.12)}
    .projectMeta span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.projectMeta b{font-size:14px}
    @media(max-width:760px){.projectGrid{grid-template-columns:1fr}.projectMeta{grid-template-columns:1fr}.projectCard .actions{display:grid}.projectCard .actions>*{width:100%;text-align:center;justify-content:center}}

    /* V13 Recurring Billing Engine */
    .subStatus{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;background:rgba(96,165,250,.14);color:#bfdbfe}
    .subStatus.active{background:rgba(52,211,153,.15);color:#bbf7d0}.subStatus.paused{background:rgba(251,191,36,.14);color:#fde68a}.subStatus.cancelled{background:rgba(251,113,133,.14);color:#fecdd3}
    .planHint{border:1px solid rgba(37,214,162,.22);background:rgba(37,214,162,.07);border-radius:18px;padding:14px;color:#c9d7ef}
    .miniGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
    .miniGrid .panel{padding:14px;border-radius:18px;box-shadow:none}
    @media(max-width:760px){.miniGrid{grid-template-columns:1fr}.subscriptionCards{display:grid;gap:12px}.subscriptionCards .portalItemCard{display:block}.subscriptionTable{display:none!important}}
    @media(min-width:761px){.subscriptionCards{display:none}}


    .miniStats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:12px}
    .miniStats div{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px}
    .miniStats span{display:block;color:var(--muted);font-size:12px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}
    .miniStats strong{font-size:24px}
    .metric small{display:block;color:var(--muted);font-size:12px;margin-top:8px;font-weight:700}
    @media(max-width:760px){.miniStats{grid-template-columns:1fr}.miniStats strong{font-size:21px}}
  

    /* V13.5 Client Payment Actions + Proof Upload */
    .paymentActionGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0}
    .payActionCard{border:1px solid var(--line);border-radius:18px;padding:14px;background:rgba(255,255,255,.035)}
    .payActionCard b{display:block;margin-bottom:6px;color:#fff}
    .payActionCard span{display:block;color:var(--muted);font-size:12px;line-height:1.35}
    .proofForm{margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
    .proofForm .primary{width:100%}
    .proofResult{margin-top:10px;border-radius:14px;padding:12px;background:rgba(37,214,162,.10);border:1px solid rgba(37,214,162,.25);color:#bbf7d0;font-size:13px}
    @media(max-width:760px){.paymentActionGrid{grid-template-columns:1fr}.payActionCard{padding:13px}.proofForm .split{grid-template-columns:1fr!important}}

  
    /* V13.6 Proof Review Center */
    .proofGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}
    .proofCard{display:grid;gap:12px;border:1px solid var(--line);border-radius:20px;padding:16px;background:rgba(255,255,255,.035)}
    .proofTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
    .proofMeta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
    .proofMeta div{border:1px solid var(--line);border-radius:14px;padding:10px;background:rgba(0,0,0,.12)}
    .proofMeta span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;font-weight:900;letter-spacing:.08em}
    .proofMeta b{display:block;margin-top:4px;overflow-wrap:anywhere}
    .proofPreview{display:block;width:100%;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#050814;min-height:96px}
    .proofPreview img{width:100%;max-height:220px;object-fit:cover;display:block}
    .proofReviewActions{display:flex;gap:8px;flex-wrap:wrap}
    @media(max-width:900px){.proofGrid{grid-template-columns:1fr}.proofMeta{grid-template-columns:1fr}.proofReviewActions{display:grid}.proofReviewActions button,.proofReviewActions a{width:100%;text-align:center}}

/* V14.5 App Shell Polish Pro
   Purpose: premium app shell, global cards, tables, forms, mobile menu and loading polish.
   Scope: CSS only. No Supabase/PHP/DB logic changes.
*/
:root{
  --panelGlow:rgba(37,214,162,.13);
  --panelGlow2:rgba(96,165,250,.11);
  --softLine:rgba(255,255,255,.075);
  --strongLine:rgba(255,255,255,.14);
  --cardTop:rgba(17,27,48,.92);
  --cardBottom:rgba(7,12,24,.96);
  --appRadius:26px;
}
::selection{background:rgba(37,214,162,.32);color:#fff}
body{
  background:
    radial-gradient(circle at 8% -5%,rgba(37,214,162,.20),transparent 30%),
    radial-gradient(circle at 94% 2%,rgba(96,165,250,.18),transparent 34%),
    radial-gradient(circle at 65% 88%,rgba(168,85,247,.10),transparent 28%),
    linear-gradient(135deg,#040710,#08101f 44%,#050814);
}
body:before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.62),transparent 72%);
  z-index:-1;
}
.glass,.panel{
  background:linear-gradient(180deg,var(--cardTop),var(--cardBottom));
  border-color:var(--softLine);
  box-shadow:0 24px 70px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.045);
}
.app{
  gap:20px;
  padding:20px;
}
.side{
  border-radius:30px;
  padding:20px;
  background:
    radial-gradient(circle at 20% 0,rgba(37,214,162,.13),transparent 36%),
    linear-gradient(180deg,rgba(15,25,45,.94),rgba(6,11,22,.96));
  border-color:rgba(255,255,255,.105);
}
.side .brand{
  padding:10px;
  border-radius:22px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);
}
.side .brandFree span{color:rgba(142,160,189,.92)!important}
.side .footer{
  margin-top:auto;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.06);
  overflow-wrap:anywhere;
}
.nav{gap:10px}
.nav button{
  position:relative;
  min-height:46px;
  border-radius:18px;
  padding:12px 13px;
  border:1px solid transparent;
  color:#d7e3f8;
  background:rgba(255,255,255,.026);
  box-shadow:none;
}
.nav button span:first-child{
  width:28px;
  height:28px;
  display:inline-grid;
  place-items:center;
  border-radius:11px;
  background:rgba(255,255,255,.055);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.nav button.active{
  background:linear-gradient(135deg,rgba(37,214,162,.18),rgba(96,165,250,.075));
  border-color:rgba(37,214,162,.30);
  color:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.07);
}
.nav button.active:after{
  content:'';
  position:absolute;
  right:12px;
  width:7px;
  height:7px;
  border-radius:99px;
  background:var(--brand);
  box-shadow:0 0 18px rgba(37,214,162,.85);
}
.nav button:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.11);
}
.main{gap:16px;min-width:0}
.top{
  min-height:88px;
  border-radius:30px;
  padding:20px 22px;
  background:
    radial-gradient(circle at 88% 0,rgba(37,214,162,.14),transparent 34%),
    radial-gradient(circle at 55% 120%,rgba(96,165,250,.10),transparent 38%),
    linear-gradient(180deg,rgba(17,27,48,.94),rgba(8,14,27,.95));
  border-color:rgba(255,255,255,.09);
}
.top h2{
  margin-bottom:0;
  font-size:30px;
  line-height:1;
}
.top .eyebrow{margin-bottom:7px}
.topActions .ghost:before{content:'Live';font-size:10px;text-transform:uppercase;letter-spacing:.11em;color:var(--brand);padding-right:2px}
.panel{
  border-radius:26px;
  padding:22px;
  position:relative;
}
.panel:where(:not(.servicesCommandHero)):hover{
  border-color:rgba(255,255,255,.12);
}
.panel h3{
  font-size:21px;
  line-height:1.08;
}
.metric{
  overflow:hidden;
  min-height:132px;
}
.metric:after{
  content:'';
  position:absolute;
  width:125px;
  height:125px;
  right:-48px;
  top:-52px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(37,214,162,.16),transparent 68%);
  pointer-events:none;
}
.metric span{
  color:#a9b8d2;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.095em;
  font-weight:900;
}
.metric strong{
  color:#fff;
  font-size:30px;
  line-height:1.08;
}
.metric small{color:#93a6c5!important}
.toolbar{
  align-items:center;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.065);
}
.toolbar h3{margin-bottom:4px}
.searchBox{
  max-width:390px;
  background:rgba(4,10,21,.62);
  border-color:rgba(255,255,255,.11);
}
input,select,textarea{
  background:linear-gradient(180deg,rgba(4,10,21,.76),rgba(7,16,31,.86));
  border-color:rgba(255,255,255,.11);
  border-radius:16px;
  color:#f4f8ff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
input::placeholder,textarea::placeholder{color:rgba(142,160,189,.74)}
label{color:#d6e2f6;font-weight:700}
button,.button,a.tiny,a.ghost,a.success,a.primary{
  min-height:40px;
  letter-spacing:-.01em;
}
.primary,a.primary{
  box-shadow:0 14px 30px rgba(37,214,162,.16),inset 0 1px 0 rgba(255,255,255,.26);
}
.ghost,a.ghost{
  color:#ecf4ff;
}
.danger,a.danger{
  box-shadow:0 12px 24px rgba(251,113,133,.08);
}
.tableWrap{
  border-radius:22px;
  border-color:rgba(255,255,255,.075);
  background:linear-gradient(180deg,rgba(255,255,255,.024),rgba(255,255,255,.010));
}
.tableWrap table{background:transparent}
th{
  padding:14px 12px;
  color:#9fb1cf;
  background:rgba(255,255,255,.032);
}
td{
  padding:14px 12px;
  border-bottom-color:rgba(255,255,255,.066);
}
tr:last-child td{border-bottom:0}
tr:hover td{background:rgba(37,214,162,.035)}
.badge{
  border:1px solid rgba(255,255,255,.075);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}
.actions{gap:9px}
.toast{
  border-radius:20px;
  background:linear-gradient(180deg,rgba(10,19,36,.98),rgba(4,10,21,.98));
  border-color:rgba(37,214,162,.42);
  box-shadow:0 24px 80px rgba(0,0,0,.48),0 0 0 1px rgba(255,255,255,.035) inset;
}
.loading{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:#dffcf5;
  font-weight:900;
  letter-spacing:-.02em;
  background:
    radial-gradient(circle at 50% 42%,rgba(37,214,162,.18),transparent 24%),
    linear-gradient(135deg,#040710,#08101f 48%,#050814);
}
.loading:before{
  content:'';
  width:46px;
  height:46px;
  border-radius:999px;
  border:3px solid rgba(255,255,255,.12);
  border-top-color:var(--brand);
  animation:uptimeSpin .82s linear infinite;
  flex:0 0 auto;
}
@keyframes uptimeSpin{to{transform:rotate(360deg)}}
form.panel.stack{gap:13px}
form.panel.stack h3{
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.065);
}
.miniStats div,.projectCard,.payActionCard,.proofCard,.portalItemCard{
  border-color:rgba(255,255,255,.085)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
}
.alert{
  border-radius:18px;
}

@media(max-width:1000px){
  .mobileTop{
    background:linear-gradient(180deg,rgba(15,25,45,.92),rgba(7,13,25,.92));
    border-bottom:1px solid rgba(255,255,255,.09)!important;
    box-shadow:0 18px 46px rgba(0,0,0,.34);
  }
  .mobileMenuBtn{
    border-radius:16px;
    background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
  }
  .side{
    border-radius:28px!important;
    background:
      radial-gradient(circle at 20% 0,rgba(37,214,162,.16),transparent 38%),
      linear-gradient(180deg,rgba(15,25,45,.98),rgba(5,10,20,.98))!important;
    overflow:auto!important;
  }
  .side .brand{padding:9px}
  .main{margin-top:12px}
}
@media(max-width:760px){
  .app{padding:10px!important}
  .main{padding:0 0 18px!important;gap:12px!important}
  .panel{border-radius:24px;padding:17px}
  .grid{gap:12px!important}
  .metric{min-height:112px}
  .metric strong{font-size:25px}
  .toolbar{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    align-items:stretch!important;
  }
  .toolbar .searchBox{width:100%;max-width:none}
  .mobileTop{padding:10px 12px!important;border-radius:0 0 24px 24px!important}
  .side .footer{display:block!important}
  .nav button.active:after{right:14px}
  .tableWrap{border:0;background:transparent}
  .main .tableWrap tr{
    border-radius:22px!important;
    border-color:rgba(255,255,255,.105)!important;
    background:linear-gradient(180deg,rgba(16,27,49,.94),rgba(7,13,25,.98))!important;
  }
  .main .tableWrap td:first-child{font-size:17px!important}
  .actions button,.actions a{min-height:43px}
}
@media(max-width:420px){
  .panel{padding:15px;border-radius:21px}
  .metric strong{font-size:23px}
  .side{left:10px!important;right:10px!important;top:10px!important;bottom:10px!important;width:calc(100vw - 20px)!important}
}



/* V14.6 Dashboard Executive Pro */
.dashExecutive{display:grid;gap:16px}
.dashHero{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(260px,.55fr);
  align-items:stretch;
  gap:18px;
  padding:24px;
  background:
    radial-gradient(circle at 12% 0,rgba(37,214,162,.20),transparent 34%),
    radial-gradient(circle at 90% 10%,rgba(96,165,250,.16),transparent 32%),
    linear-gradient(135deg,rgba(19,31,55,.96),rgba(7,13,25,.98));
}
.dashHero:after{content:'';position:absolute;right:-80px;top:-90px;width:260px;height:260px;border-radius:50%;border:1px solid rgba(37,214,162,.16);box-shadow:0 0 80px rgba(37,214,162,.08);pointer-events:none}
.dashHeroCopy{position:relative;z-index:1;display:grid;align-content:center;gap:9px;min-width:0}
.dashHeroCopy h1{font-size:clamp(30px,4vw,48px);line-height:.98;margin:0;max-width:780px}
.dashHeroCopy .muted{max-width:720px;font-size:15px}
.dashQuickActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.dashHeroScore{
  position:relative;z-index:1;
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
  padding:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.028));
  display:grid;
  align-content:center;
  gap:10px;
  min-width:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 18px 44px rgba(0,0,0,.18);
}
.dashHeroScore span,.dashKpi span,.dashPanelHead p,.dashBarRow span,.dashListItem span,.dashActivity span{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.09em}
.dashHeroScore strong{font-size:54px;letter-spacing:-.06em;line-height:1;color:#fff}
.dashHeroScore small{color:#c6d4ed;font-weight:800;line-height:1.35}
.dashProgress{height:10px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.dashProgress i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand),var(--brand2));box-shadow:0 0 24px rgba(37,214,162,.28)}
.dashKpiGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.dashKpi{
  min-height:138px;
  border:1px solid rgba(255,255,255,.085);
  border-radius:24px;
  padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));
  box-shadow:0 18px 44px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.035);
  display:grid;
  align-content:space-between;
  gap:10px;
  min-width:0;
}
.dashKpi.primaryKpi{background:radial-gradient(circle at 20% 0,rgba(37,214,162,.20),transparent 46%),linear-gradient(180deg,rgba(37,214,162,.10),rgba(255,255,255,.020));border-color:rgba(37,214,162,.22)}
.dashKpi strong{display:block;font-size:clamp(23px,2.2vw,33px);line-height:1;letter-spacing:-.055em;color:#fff;overflow-wrap:anywhere}
.dashKpi small{color:#9fb1cf;font-weight:800;line-height:1.35}
.dashBoardGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dashPanel{padding:20px;min-width:0}
.dashWide{grid-column:1/-1}
.dashPanelHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.dashPanelHead h3{margin:0 0 4px;font-size:21px}
.dashPanelHead p{margin:0;text-transform:none;letter-spacing:0;font-weight:700;font-size:13px}
.dashList,.dashRevenueBars,.dashPlanList,.dashActivityGrid{display:grid;gap:10px}
.dashListItem,.dashActivity,.dashPlan{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  border:1px solid rgba(255,255,255,.075);
  border-radius:18px;
  padding:13px;
  background:rgba(255,255,255,.035);
  min-width:0;
}
.dashListItem div,.dashActivity div,.dashPlan div{min-width:0}
.dashListItem strong,.dashActivity strong,.dashPlan strong{display:block;color:#fff;font-size:15px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dashListItem small,.dashActivity small,.dashPlan span{display:block;color:#98a9c4;margin-top:4px;font-weight:750;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dashListItem em{font-style:normal;color:#dbeafe;font-size:12px;font-weight:900;white-space:nowrap}
.dashListItem.danger{border-color:rgba(251,113,133,.18);background:linear-gradient(135deg,rgba(251,113,133,.09),rgba(255,255,255,.025))}
.dashListItem.warn{border-color:rgba(251,191,36,.18);background:linear-gradient(135deg,rgba(251,191,36,.08),rgba(255,255,255,.025))}
.dashListItem.ok{border-color:rgba(37,214,162,.18);background:linear-gradient(135deg,rgba(37,214,162,.08),rgba(255,255,255,.025))}
.dashListItem.info{border-color:rgba(96,165,250,.18);background:linear-gradient(135deg,rgba(96,165,250,.08),rgba(255,255,255,.025))}
.dashBarRow{display:grid;gap:8px;border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:13px;background:rgba(255,255,255,.03)}
.dashBarRow>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px}.dashBarRow strong{color:#fff}
.dashPlan{justify-content:flex-start}.dashPlan b{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:rgba(37,214,162,.12);color:#bbf7d0;border:1px solid rgba(37,214,162,.18);flex:0 0 auto}
.dashActivity b{display:block;font-size:14px;color:#fff;margin-bottom:6px}.dashActivity .badge{justify-content:center}
.dashEmpty{border:1px dashed rgba(255,255,255,.14);border-radius:18px;padding:18px;color:var(--muted);background:rgba(255,255,255,.025);font-weight:800;text-align:center}
@media(max-width:1120px){.dashHero{grid-template-columns:1fr}.dashKpiGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashBoardGrid{grid-template-columns:1fr}.dashWide{grid-column:auto}}
@media(max-width:760px){
  .dashExecutive{gap:12px}.dashHero{padding:18px;border-radius:24px;gap:14px}.dashHeroCopy h1{font-size:32px}.dashHeroScore{padding:16px;border-radius:20px}.dashHeroScore strong{font-size:42px}.dashQuickActions{display:grid;grid-template-columns:1fr;gap:9px}.dashQuickActions button{width:100%}.dashKpiGrid{grid-template-columns:1fr;gap:10px}.dashKpi{min-height:112px;border-radius:21px;padding:16px}.dashKpi strong{font-size:27px}.dashPanel{padding:16px;border-radius:22px}.dashPanelHead{display:grid;gap:10px}.dashPanelHead button{width:100%}.dashListItem,.dashActivity{align-items:flex-start}.dashListItem strong,.dashActivity strong,.dashListItem small,.dashActivity small,.dashPlan strong,.dashPlan span{white-space:normal}.dashActivity{display:grid}.dashActivity>div:last-child{text-align:left!important}.dashBarRow>div:first-child{align-items:flex-start}.dashListItem em{font-size:11px}
}

/* V14.7 Clients 360 Pro */
.clients360{display:grid;gap:16px}
.clients360Hero{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(260px,.55fr);
  gap:18px;
  align-items:stretch;
  padding:24px;
  background:
    radial-gradient(circle at 12% 0,rgba(96,165,250,.20),transparent 35%),
    radial-gradient(circle at 88% 0,rgba(37,214,162,.16),transparent 30%),
    linear-gradient(135deg,rgba(16,27,49,.96),rgba(7,13,25,.98));
}
.clients360Hero:after{content:'';position:absolute;right:-95px;top:-95px;width:290px;height:290px;border-radius:50%;border:1px solid rgba(96,165,250,.15);box-shadow:0 0 80px rgba(96,165,250,.08);pointer-events:none}
.clients360Hero h3{font-size:clamp(30px,3.5vw,46px);line-height:1;margin:0 0 8px;letter-spacing:-.055em}
.clients360Hero .muted{max-width:760px;font-size:15px}
.clients360Quick{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.clients360HeroCard{
  position:relative;z-index:1;
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
  padding:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.030));
  display:grid;
  align-content:center;
  gap:8px;
  min-width:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 18px 44px rgba(0,0,0,.18);
}
.clients360HeroCard span,.client360Kpi span,.client360Money span,.client360HeroCard small,.client360Signal span{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.085em}
.clients360HeroCard strong{font-size:21px;color:#fff;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.clients360HeroCard b{font-size:38px;line-height:1;letter-spacing:-.055em;color:#fff}
.clients360HeroCard small{text-transform:none;letter-spacing:0;font-weight:800;line-height:1.35;color:#aebfd9}
.clients360StatsGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.client360Kpi{
  min-height:126px;
  border:1px solid rgba(255,255,255,.085);
  border-radius:24px;
  padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));
  box-shadow:0 18px 44px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.035);
  display:grid;
  align-content:space-between;
  gap:9px;
}
.client360Kpi strong{font-size:clamp(24px,2.2vw,32px);line-height:1;letter-spacing:-.055em;color:#fff;overflow-wrap:anywhere}
.client360Kpi small{color:#9fb1cf;font-weight:800;line-height:1.35}
.clients360Workspace{display:grid;grid-template-columns:minmax(320px,390px) minmax(0,1fr);gap:16px;align-items:start}
.client360Editor{position:sticky;top:18px;min-width:0}
.client360PanelHead,.client360LibraryHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:4px}
.client360PanelHead h3,.client360LibraryHead h3{margin:0 0 5px;font-size:22px}
.client360PanelHead .muted,.client360LibraryHead .muted{margin:0;line-height:1.35}
.client360Library{min-width:0}
.client360LibraryHead{align-items:center;margin-bottom:16px}
.client360LibraryHead .searchBox{max-width:360px;min-width:240px}
.clients360Cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.client360Card{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:13px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:24px;
  padding:16px;
  background:linear-gradient(180deg,rgba(16,27,49,.80),rgba(7,13,25,.94));
  box-shadow:0 18px 46px rgba(0,0,0,.17),inset 0 1px 0 rgba(255,255,255,.035);
  min-width:0;
}
.client360Card:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand2),var(--brand));opacity:.72}
.client360Card.risk:before{background:linear-gradient(180deg,var(--danger),#f97316);opacity:.9}
.client360Card.open:before{background:linear-gradient(180deg,var(--warn),var(--brand2));opacity:.85}
.client360Card.clean:before{background:linear-gradient(180deg,var(--brand),#bef264);opacity:.70}
.client360Card.isArchived{opacity:.72;filter:saturate(.78)}
.client360Top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;min-width:0}
.client360Identity{display:flex;align-items:center;gap:11px;min-width:0}
.client360Avatar{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;flex:0 0 auto;background:linear-gradient(135deg,rgba(37,214,162,.24),rgba(96,165,250,.18));border:1px solid rgba(255,255,255,.10);color:#eafff8;font-weight:950;letter-spacing:-.04em}
.client360Identity strong{display:block;color:#fff;font-size:18px;line-height:1.12;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}
.client360Identity small{display:block;color:#9fb1cf;margin-top:3px;font-weight:750;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}
.client360Contact{display:grid;gap:6px;color:#b8c7df;font-weight:750;line-height:1.35;font-size:13px}
.client360Contact span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.client360Money{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}
.client360Money div{border:1px solid rgba(255,255,255,.075);border-radius:17px;padding:10px;background:rgba(255,255,255,.035);min-width:0}
.client360Money span{display:block;font-size:10px;margin-bottom:7px}
.client360Money strong{display:block;color:#fff;font-size:17px;line-height:1;letter-spacing:-.035em;overflow-wrap:anywhere}
.client360Stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.client360Stats span{border:1px solid rgba(255,255,255,.075);border-radius:15px;padding:8px 9px;background:rgba(255,255,255,.030);color:#d7e4f8;font-weight:850;font-size:12px;text-align:center}
.client360Signal{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid rgba(255,255,255,.075);border-radius:17px;padding:10px 11px;background:rgba(255,255,255,.028)}
.client360Signal b{color:#fff;font-size:13px;line-height:1.25}.client360Signal span{text-transform:none;letter-spacing:0;font-size:12px;color:#9fb1cf;text-align:right}
.client360Signal.risk{border-color:rgba(251,113,133,.22);background:rgba(251,113,133,.075)}
.client360Signal.open{border-color:rgba(251,191,36,.20);background:rgba(251,191,36,.060)}
.client360Signal.clean{border-color:rgba(37,214,162,.18);background:rgba(37,214,162,.060)}
.client360Actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:2px}
.client360Actions .tiny{min-height:35px;padding:8px 11px}
.client360Missing{display:inline-flex;align-items:center;min-height:35px;border-radius:999px;padding:8px 11px;background:rgba(251,191,36,.09);border:1px solid rgba(251,191,36,.18);color:#fde68a;font-size:12px;font-weight:900}
.client360Empty{border:1px dashed rgba(255,255,255,.14);border-radius:22px;padding:28px;text-align:center;background:rgba(255,255,255,.025)}
.client360Empty h3{margin:0 0 8px}
@media(max-width:1180px){.clients360Workspace{grid-template-columns:1fr}.client360Editor{position:relative;top:auto}.clients360Cards{grid-template-columns:1fr}.client360LibraryHead .searchBox{max-width:none}}
@media(max-width:980px){.clients360Hero{grid-template-columns:1fr}.clients360StatsGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){
  .clients360{gap:12px}.clients360Hero{padding:18px;border-radius:24px;gap:14px}.clients360Hero h3{font-size:32px}.clients360Quick{display:grid;grid-template-columns:1fr;gap:9px}.clients360Quick button{width:100%}.clients360HeroCard{border-radius:21px;padding:16px}.clients360HeroCard b{font-size:31px}.clients360StatsGrid{grid-template-columns:1fr;gap:10px}.client360Kpi{min-height:110px;border-radius:21px;padding:16px}.client360LibraryHead,.client360PanelHead{display:grid;gap:10px}.client360LibraryHead .searchBox{width:100%;min-width:0}.client360Card{border-radius:22px;padding:15px}.client360Top{display:grid;gap:10px}.client360Identity strong,.client360Identity small{white-space:normal;max-width:none}.client360Contact span{white-space:normal}.client360Money{grid-template-columns:1fr}.client360Stats{grid-template-columns:1fr}.client360Signal{display:grid}.client360Signal span{text-align:left}.client360Actions{display:grid;grid-template-columns:1fr 1fr}.client360Actions button,.client360Actions a,.client360Missing{width:100%;justify-content:center}.client360Missing{grid-column:1/-1}
}
@media(max-width:420px){.client360Actions{grid-template-columns:1fr}.client360Avatar{width:39px;height:39px;border-radius:14px}.client360Identity{align-items:flex-start}}

/* V14.8 Estimates / Invoices Document Pro */
.docPro{display:grid;gap:16px}
.docProHero{
  position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.55fr);gap:18px;align-items:stretch;padding:24px;
  background:radial-gradient(circle at 12% 0,rgba(96,165,250,.20),transparent 34%),radial-gradient(circle at 86% 0,rgba(37,214,162,.16),transparent 30%),linear-gradient(135deg,rgba(16,27,49,.96),rgba(7,13,25,.985));
}
.docProHero.invoiceHero{background:radial-gradient(circle at 12% 0,rgba(37,214,162,.18),transparent 34%),radial-gradient(circle at 88% 0,rgba(251,191,36,.13),transparent 32%),linear-gradient(135deg,rgba(16,27,49,.96),rgba(7,13,25,.985))}
.docProHero:after{content:'';position:absolute;right:-105px;top:-105px;width:310px;height:310px;border-radius:50%;border:1px solid rgba(255,255,255,.12);box-shadow:0 0 90px rgba(96,165,250,.08);pointer-events:none}
.docProHero h3{font-size:clamp(30px,3.5vw,46px);line-height:1;margin:0 0 8px;letter-spacing:-.055em}.docProHero .muted{max-width:780px;font-size:15px;line-height:1.5}
.docProHeroActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.docProHeroCard{position:relative;z-index:1;border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.030));display:grid;align-content:center;gap:8px;min-width:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 18px 44px rgba(0,0,0,.18)}
.docProHeroCard span,.docProKpi span,.docProMoney span,.docProSignal span{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.085em}.docProHeroCard b{font-size:clamp(31px,3.2vw,43px);line-height:1;letter-spacing:-.055em;color:#fff;overflow-wrap:anywhere}.docProHeroCard small{color:#aebfd9;font-weight:800;line-height:1.35}
.docProStats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.docProKpi{min-height:126px;border:1px solid rgba(255,255,255,.085);border-radius:24px;padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));box-shadow:0 18px 44px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.035);display:grid;align-content:space-between;gap:9px}.docProKpi strong{font-size:clamp(24px,2.2vw,32px);line-height:1;letter-spacing:-.055em;color:#fff;overflow-wrap:anywhere}.docProKpi small{color:#9fb1cf;font-weight:800;line-height:1.35}.docProKpi.risk{border-color:rgba(251,113,133,.18);background:linear-gradient(180deg,rgba(251,113,133,.075),rgba(255,255,255,.02))}
.docProWorkspace{display:grid;grid-template-columns:minmax(320px,390px) minmax(0,1fr);gap:16px;align-items:start}.docProEditor{position:sticky;top:18px;min-width:0}.docProPanelHead,.docProLibraryHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:8px}.docProPanelHead h3,.docProLibraryHead h3{margin:0 0 5px;font-size:22px}.docProPanelHead .muted,.docProLibraryHead .muted{margin:0;line-height:1.35}.docProCheck{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:10px}.docProCheck input{width:auto;min-height:auto}.docProLibrary{min-width:0}.docProFull{width:100%}.docProLibraryHead{align-items:center;margin-bottom:16px}.docProLibraryHead .searchBox{max-width:380px;min-width:250px}
.docProCards{display:grid;gap:13px}.docProCard{position:relative;overflow:hidden;display:grid;gap:13px;border:1px solid rgba(255,255,255,.09);border-radius:24px;padding:16px;background:linear-gradient(180deg,rgba(16,27,49,.80),rgba(7,13,25,.94));box-shadow:0 18px 46px rgba(0,0,0,.17),inset 0 1px 0 rgba(255,255,255,.035);min-width:0}.docProCard:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand2),var(--brand));opacity:.78}.docProCard.ok:before{background:linear-gradient(180deg,var(--brand),#bef264)}.docProCard.info:before{background:linear-gradient(180deg,var(--brand2),var(--brand))}.docProCard.warn:before{background:linear-gradient(180deg,var(--warn),var(--brand2))}.docProCard.danger:before{background:linear-gradient(180deg,var(--danger),#f97316);opacity:.95}.docProCard.invoice:before{background:linear-gradient(180deg,var(--brand),var(--warn))}
.docProCardTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;min-width:0}.docProIdentity{display:flex;align-items:center;gap:11px;min-width:0}.docProIcon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;flex:0 0 auto;background:linear-gradient(135deg,rgba(96,165,250,.20),rgba(37,214,162,.14));border:1px solid rgba(255,255,255,.10);font-size:19px}.docProIdentity strong{display:block;color:#fff;font-size:18px;line-height:1.12;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:420px}.docProIdentity small{display:block;color:#9fb1cf;margin-top:4px;font-weight:750;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:420px}
.docProMoney{display:grid;grid-template-columns:1fr 1fr 1.25fr;gap:9px}.docProMoney.invoiceMoney{grid-template-columns:repeat(3,minmax(0,1fr))}.docProMoney div{border:1px solid rgba(255,255,255,.075);border-radius:17px;padding:10px;background:rgba(255,255,255,.035);min-width:0}.docProMoney span{display:block;font-size:10px;margin-bottom:7px}.docProMoney strong{display:block;color:#fff;font-size:17px;line-height:1;letter-spacing:-.035em;overflow-wrap:anywhere}.docProSignal{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(255,255,255,.075);border-radius:17px;padding:10px 11px;background:rgba(255,255,255,.028);min-width:0}.docProSignal span{text-transform:none;letter-spacing:0;font-size:12px;color:#9fb1cf}.docProSignal b{color:#fff;font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.docProActions{display:flex;gap:8px;flex-wrap:wrap;padding-top:2px}.docProActions .tiny{min-height:35px;padding:8px 11px}.docProEmpty{border:1px dashed rgba(255,255,255,.14);border-radius:22px;padding:28px;text-align:center;background:rgba(255,255,255,.025)}.docProEmpty h3{margin:0 0 8px}
@media(max-width:1180px){.docProWorkspace{grid-template-columns:1fr}.docProEditor{position:relative;top:auto}.docProLibraryHead .searchBox{max-width:none}.docProIdentity strong,.docProIdentity small{max-width:310px}}
@media(max-width:980px){.docProHero{grid-template-columns:1fr}.docProStats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.docPro{gap:12px}.docProHero{padding:18px;border-radius:24px;gap:14px}.docProHero h3{font-size:32px}.docProHeroActions{display:grid;grid-template-columns:1fr;gap:9px}.docProHeroActions button{width:100%}.docProHeroCard{border-radius:21px;padding:16px}.docProHeroCard b{font-size:31px}.docProStats{grid-template-columns:1fr;gap:10px}.docProKpi{min-height:110px;border-radius:21px;padding:16px}.docProLibraryHead,.docProPanelHead{display:grid;gap:10px}.docProLibraryHead .searchBox{width:100%;min-width:0}.docProCard{border-radius:22px;padding:15px}.docProCardTop{display:grid;gap:10px}.docProIdentity strong,.docProIdentity small{white-space:normal;max-width:none}.docProMoney,.docProMoney.invoiceMoney{grid-template-columns:1fr}.docProSignal{display:grid}.docProSignal b{white-space:normal;overflow-wrap:anywhere}.docProActions{display:grid;grid-template-columns:1fr 1fr}.docProActions button,.docProActions a,.docProActions .badge{width:100%;justify-content:center}.docProIcon{width:39px;height:39px;border-radius:14px}}
@media(max-width:420px){.docProActions{grid-template-columns:1fr}.docProIdentity{align-items:flex-start}}

/* V14.9 Payment Profile Pro */
.settingsShell{display:grid;gap:16px}
.paymentSettingsPanel{overflow:hidden;position:relative}
.paymentSettingsPanel:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 92% 0,rgba(37,214,162,.12),transparent 34%),radial-gradient(circle at 0 100%,rgba(96,165,250,.10),transparent 38%);pointer-events:none}
.paymentSettingsPanel>*{position:relative;z-index:1}
.settingsHero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border:1px solid rgba(255,255,255,.09);background:linear-gradient(135deg,rgba(37,214,162,.08),rgba(96,165,250,.055));border-radius:24px;padding:18px}
.settingsHero h3{margin-bottom:6px;font-size:24px}
.notice{border:1px solid rgba(37,214,162,.22);background:rgba(37,214,162,.075);border-radius:18px;padding:14px;color:#c9d7ef;line-height:1.45}
.paymentProfileGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:12px 0}
.paymentProfileCard{border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.028));border-radius:20px;padding:16px;box-shadow:0 16px 34px rgba(0,0,0,.16);min-width:0;position:relative;overflow:hidden}
.paymentProfileCard:before{content:'';position:absolute;right:-34px;top:-34px;width:90px;height:90px;border-radius:50%;background:rgba(37,214,162,.12)}
.paymentProfileCard span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.11em;font-weight:950;margin-bottom:9px}
.paymentProfileCard strong{display:block;color:#fff;font-size:18px;letter-spacing:.02em;overflow-wrap:anywhere}
.paymentProfileCard small{display:block;color:#94a3b8;margin-top:8px;line-height:1.35;font-weight:800}
.paymentProfileCard.klar:before{background:rgba(96,165,250,.14)}
.paymentProfileCard.bancomer:before{background:rgba(251,191,36,.12)}
.paymentIdentityBox{display:grid;grid-template-columns:1.1fr 2fr 1fr;gap:10px;border:1px solid rgba(255,255,255,.09);background:rgba(3,9,20,.22);border-radius:20px;padding:12px;margin-bottom:4px}
.paymentIdentityBox div{border-radius:16px;background:rgba(255,255,255,.045);padding:12px;min-width:0}
.paymentIdentityBox span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:950;margin-bottom:6px}
.paymentIdentityBox strong{display:block;color:#fff;overflow-wrap:anywhere;line-height:1.35}
.paymentFieldGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.paymentFieldGrid.twoCols{grid-template-columns:repeat(2,minmax(0,1fr))}
.paymentInstructionsText{white-space:pre-wrap;border:1px solid rgba(255,255,255,.08);background:rgba(3,9,20,.24);border-radius:18px;padding:14px;margin-top:12px!important;line-height:1.55}
@media(max-width:900px){.paymentProfileGrid,.paymentFieldGrid,.paymentFieldGrid.twoCols,.paymentIdentityBox{grid-template-columns:1fr}.settingsHero{display:grid}.paymentProfileCard strong{font-size:16px}}

/* V14.9.1 Public Invoice Payment Fix
   Purpose: fix cramped public invoice payment cards and improve payment profile readability.
   Scope: CSS + public invoice markup classes only. No Supabase/PHP/DB changes.
*/
.publicInvoiceTopGrid{
  grid-template-columns:minmax(280px,.82fr) minmax(360px,1.18fr);
  align-items:stretch;
}
.publicInvoiceBillPanel,
.publicInvoicePayPanel{
  min-width:0;
}
.publicInvoicePayPanel{
  overflow:hidden;
  position:relative;
}
.publicInvoicePayPanel:before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 100% 0,rgba(37,214,162,.11),transparent 34%),
    radial-gradient(circle at 0 100%,rgba(96,165,250,.08),transparent 42%);
  pointer-events:none;
}
.publicInvoicePayPanel>*{
  position:relative;
  z-index:1;
}
.publicInvoicePayHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.publicInvoicePayHead h3{
  margin:0;
}
.publicInvoicePayHead .eyebrow{
  margin:0 0 5px;
}
.publicInvoicePayHead .badge{
  white-space:nowrap;
}
.publicInvoicePayPanel .paymentProfileGrid{
  grid-template-columns:1fr;
  gap:10px;
  margin:12px 0;
}
.publicInvoicePayPanel .paymentProfileCard{
  display:grid;
  grid-template-columns:minmax(110px,.75fr) minmax(0,1.25fr);
  align-items:center;
  gap:6px 14px;
  padding:14px 16px;
  border-radius:18px;
  min-height:92px;
}
.publicInvoicePayPanel .paymentProfileCard span{
  grid-column:1;
  margin:0;
  font-size:10.5px;
}
.publicInvoicePayPanel .paymentProfileCard small{
  grid-column:1;
  margin:0;
  font-size:12px;
}
.publicInvoicePayPanel .paymentProfileCard strong{
  grid-column:2;
  grid-row:1 / span 2;
  justify-self:end;
  text-align:right;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:17px;
  line-height:1.18;
  letter-spacing:-.02em;
  max-width:100%;
  overflow-wrap:anywhere;
}
.publicInvoicePayPanel .paymentIdentityBox{
  grid-template-columns:1fr;
  gap:8px;
  padding:10px;
  margin:10px 0 0;
  border-radius:18px;
}
.publicInvoicePayPanel .paymentIdentityBox div{
  display:grid;
  grid-template-columns:minmax(116px,.6fr) minmax(0,1.4fr);
  align-items:center;
  gap:10px;
  padding:11px 12px;
}
.publicInvoicePayPanel .paymentIdentityBox span{
  margin:0;
  font-size:10.5px;
}
.publicInvoicePayPanel .paymentIdentityBox strong{
  text-align:right;
  font-size:13px;
}
.publicInvoicePayPanel .paymentInstructionsText{
  max-height:220px;
  overflow:auto;
  font-size:13px;
  line-height:1.55;
  padding:14px;
}
.publicInvoicePayPanel .docActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.publicInvoicePayPanel .docActions button,
.publicInvoicePayPanel .docActions a{
  width:100%;
}
@media(max-width:900px){
  .publicInvoiceTopGrid{
    grid-template-columns:1fr!important;
  }
  .publicInvoicePayPanel .paymentProfileCard{
    grid-template-columns:1fr;
    text-align:left;
  }
  .publicInvoicePayPanel .paymentProfileCard strong{
    grid-column:1;
    grid-row:auto;
    justify-self:start;
    text-align:left;
  }
  .publicInvoicePayPanel .paymentIdentityBox div{
    grid-template-columns:1fr;
    gap:6px;
  }
  .publicInvoicePayPanel .paymentIdentityBox strong{
    text-align:left;
  }
}
@media(max-width:520px){
  .publicInvoicePayHead{
    display:grid;
  }
  .publicInvoicePayPanel .docActions{
    grid-template-columns:1fr;
  }
  .publicInvoicePayPanel .paymentInstructionsText{
    max-height:none;
  }
}

/* V15.0 Public Payment Sync + Unified Public Logo */
.publicDocBrand{
  align-items:flex-start!important;
  gap:16px!important;
  margin:0!important;
}
.publicDocBrand .publicDocLogo,
.publicDocBrand .brandLogoFree{
  width:64px!important;
  height:64px!important;
  min-width:64px!important;
  min-height:64px!important;
  max-width:64px!important;
  max-height:64px!important;
  flex:0 0 64px!important;
  object-fit:contain!important;
  object-position:center!important;
}
.publicDocBrand .brandFallback{
  width:64px!important;
  height:64px!important;
  flex:0 0 64px!important;
}
.publicDocBrand h1{
  margin:0 0 10px!important;
  font-size:clamp(34px,4vw,46px)!important;
  line-height:.98!important;
  letter-spacing:-.055em!important;
}
.publicDocBrand .eyebrow{
  margin:2px 0 10px!important;
}
.publicDocBrand .muted{
  font-size:15px!important;
  line-height:1.45!important;
}
.publicInvoicePayPanel .paymentProfileCard strong{
  white-space:nowrap;
  overflow-wrap:normal;
  word-break:normal;
}
.publicInvoicePayPanel .paymentProfileCard strong:not(:empty){
  color:#ffffff;
}
.publicInvoicePayPanel .paymentProfileCard{
  background:
    linear-gradient(90deg,rgba(255,255,255,.075),rgba(255,255,255,.026)),
    rgba(9,15,28,.72);
}
.publicInvoicePayPanel .paymentIdentityBox{
  background:rgba(3,9,20,.20);
}
.publicInvoicePayPanel .paymentIdentityBox strong{
  font-size:14px;
  line-height:1.35;
}
.publicInvoicePayPanel .paymentInstructionsText{
  max-height:none!important;
  overflow:visible!important;
  white-space:normal!important;
  color:#aab8d1!important;
}
.publicInvoicePayPanel .paymentInstructionsText br{
  line-height:1.7;
}
@media(max-width:760px){
  .publicDocBrand{
    gap:12px!important;
  }
  .publicDocBrand .publicDocLogo,
  .publicDocBrand .brandLogoFree,
  .publicDocBrand .brandFallback{
    width:52px!important;
    height:52px!important;
    min-width:52px!important;
    min-height:52px!important;
    max-width:52px!important;
    max-height:52px!important;
    flex-basis:52px!important;
  }
  .publicDocBrand h1{
    font-size:32px!important;
  }
  .publicInvoicePayPanel .paymentProfileCard strong{
    white-space:normal;
    text-align:left;
  }
}
@media(max-width:420px){
  .publicDocBrand{
    display:grid!important;
  }
}


/* V15.0 Payments Center Pro
   Purpose: premium payments, receipts and proof review experience.
   Scope: visual/render refresh only. No Supabase/PHP/DB schema changes.
*/
.paymentsPro,.proofsPro{display:grid;gap:16px;min-width:0}
.paymentsHero,.proofsHero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:18px;align-items:stretch;padding:24px;border-radius:30px;background:linear-gradient(135deg,rgba(14,24,43,.94),rgba(7,13,26,.98));border-color:rgba(37,214,162,.16)}
.paymentsHero:before,.proofsHero:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 84% 4%,rgba(37,214,162,.17),transparent 32%),radial-gradient(circle at 0 100%,rgba(96,165,250,.10),transparent 34%);pointer-events:none}.paymentsHero>*,.proofsHero>*{position:relative;z-index:1}.paymentsHero h3,.proofsHero h3{font-size:clamp(30px,3vw,48px);line-height:.98;margin:0 0 10px}.paymentsHero .muted,.proofsHero .muted{max-width:760px;line-height:1.5}.paymentsHeroActions{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px}.paymentsHeroCard{display:grid;align-content:center;gap:10px;border:1px solid rgba(255,255,255,.10);border-radius:26px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 20px 50px rgba(0,0,0,.18)}.paymentsHeroCard span{color:var(--muted);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.10em}.paymentsHeroCard b{display:block;color:#fff;font-size:clamp(32px,3.4vw,48px);line-height:1;letter-spacing:-.06em;overflow-wrap:anywhere}.paymentsHeroCard small{color:#9fb1cf;font-weight:850;line-height:1.35}
.paymentsKpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.paymentsKpi{min-height:124px;border:1px solid rgba(255,255,255,.085);border-radius:24px;padding:17px;background:linear-gradient(180deg,rgba(255,255,255,.058),rgba(255,255,255,.022));box-shadow:0 18px 42px rgba(0,0,0,.14);display:grid;align-content:space-between;gap:8px;min-width:0}.paymentsKpi span{display:block;color:var(--muted);font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.095em}.paymentsKpi strong{display:block;color:#fff;font-size:clamp(24px,2vw,32px);line-height:1;letter-spacing:-.055em;overflow-wrap:anywhere}.paymentsKpi small{color:#9fb1cf;font-weight:800;line-height:1.35}.paymentsKpi.needsAttention{border-color:rgba(251,191,36,.22);background:linear-gradient(180deg,rgba(251,191,36,.09),rgba(255,255,255,.023))}.paymentsKpi.risk{border-color:rgba(251,113,133,.24);background:linear-gradient(180deg,rgba(251,113,133,.085),rgba(255,255,255,.022))}
.paymentsWorkspace{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:16px;align-items:start}.paymentStudio{position:sticky;top:18px;min-width:0;overflow:hidden}.paymentStudio:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 90% 0,rgba(37,214,162,.11),transparent 34%);pointer-events:none}.paymentStudio>*{position:relative;z-index:1}.payPanelHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:10px}.payPanelHead h3{margin:0 0 5px;font-size:22px}.payPanelHead .muted{margin:0;line-height:1.38}.paySafetyNote{display:grid;gap:4px;border:1px solid rgba(37,214,162,.22);background:rgba(37,214,162,.065);border-radius:18px;padding:13px}.paySafetyNote b{color:#d1fae5}.paySafetyNote span{color:#9fb1cf;font-size:12px;font-weight:750;line-height:1.35}.paymentsSideStack{display:grid;grid-template-columns:1fr 1fr;gap:16px;min-width:0}.paySnapshot,.payTimeline{min-width:0}.payMethodBars{display:grid;gap:11px;margin-top:12px}.payMethodRow{display:grid;gap:8px}.payMethodRow div{display:flex;align-items:center;justify-content:space-between;gap:10px}.payMethodRow span{color:var(--muted);font-weight:900}.payMethodRow b{color:#fff}.payMethodRow em{display:block;height:9px;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand2));box-shadow:0 8px 24px rgba(37,214,162,.18)}.payTimeline{display:grid;align-content:start}.payTimelineItem{display:grid;grid-template-columns:92px 1fr auto;gap:9px;align-items:center;border-top:1px solid rgba(255,255,255,.07);padding:10px 0}.payTimelineItem:first-of-type{border-top:0}.payTimelineItem span{color:var(--muted);font-size:12px;font-weight:900}.payTimelineItem strong{color:#fff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payTimelineItem b{color:#bbf7d0}.payLedgerPanel{min-width:0}.payLedgerGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.payLedgerCard{position:relative;overflow:hidden;display:grid;gap:12px;border:1px solid rgba(255,255,255,.09);border-radius:23px;padding:15px;background:linear-gradient(180deg,rgba(16,27,49,.82),rgba(7,13,25,.95));box-shadow:0 18px 44px rgba(0,0,0,.16);min-width:0}.payLedgerCard:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand),var(--brand2));opacity:.85}.payLedgerTop{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:11px;align-items:center}.payReceiptIcon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(37,214,162,.18),rgba(96,165,250,.14));border:1px solid rgba(255,255,255,.10)}.payLedgerTop strong{display:block;font-size:17px;color:#fff}.payLedgerTop span{display:block;color:#9fb1cf;font-weight:800;font-size:12px;margin-top:3px}.payLedgerTop b{font-size:20px;color:#fff;letter-spacing:-.04em}.payLedgerMeta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.payLedgerMeta div{border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:9px;background:rgba(255,255,255,.035);min-width:0}.payLedgerMeta span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:950;margin-bottom:6px}.payLedgerMeta b{display:block;color:#fff;overflow-wrap:anywhere}.payLedgerNote{margin:0;line-height:1.35}.payLedgerActions{display:flex;gap:8px;flex-wrap:wrap}.payLedgerActions .badge{align-items:center}.proofsHero{border-color:rgba(96,165,250,.18)}.proofKpis{grid-template-columns:repeat(4,minmax(0,1fr))}.proofQueuePanel{min-width:0}.proofQueueGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:13px}.proofCardPro{position:relative;overflow:hidden;border-radius:24px;background:linear-gradient(180deg,rgba(16,27,49,.82),rgba(7,13,25,.95));box-shadow:0 18px 44px rgba(0,0,0,.16);min-width:0}.proofCardPro:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--warn),var(--brand2));opacity:.86}.proofCardPro.approved:before{background:linear-gradient(180deg,var(--brand),#bef264)}.proofCardPro.rejected:before{background:linear-gradient(180deg,var(--danger),#f97316)}.proofPreviewPro{border-radius:18px;background:rgba(3,9,20,.45)}.proofPreviewPro img{max-height:180px;object-fit:cover}.proofMetaPro{grid-template-columns:repeat(2,minmax(0,1fr))}.proofNote{margin:0;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.026);border-radius:16px;padding:10px;white-space:pre-wrap;line-height:1.35}.proofActionsPro{padding-top:2px}.proofActionsPro .success{flex:1 1 190px}
@media(max-width:1180px){.paymentsWorkspace{grid-template-columns:1fr}.paymentStudio{position:relative;top:auto}.paymentsSideStack{grid-template-columns:1fr}.payLedgerGrid,.proofQueueGrid{grid-template-columns:1fr 1fr}}
@media(max-width:980px){.paymentsHero,.proofsHero{grid-template-columns:1fr}.paymentsKpis,.proofKpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.paymentsPro,.proofsPro{gap:12px}.paymentsHero,.proofsHero{padding:18px;border-radius:24px}.paymentsHero h3,.proofsHero h3{font-size:32px}.paymentsHeroActions{display:grid;grid-template-columns:1fr;gap:9px}.paymentsHeroActions button{width:100%}.paymentsHeroCard{border-radius:21px;padding:16px}.paymentsKpis,.proofKpis{grid-template-columns:1fr;gap:10px}.paymentsKpi{min-height:108px;border-radius:21px;padding:16px}.payPanelHead{display:grid;gap:10px}.payPanelHead button{width:100%}.paymentsSideStack{gap:12px}.payTimelineItem{grid-template-columns:1fr;gap:4px;border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:10px;background:rgba(255,255,255,.025);margin-bottom:8px}.payLedgerGrid,.proofQueueGrid{grid-template-columns:1fr}.payLedgerTop{grid-template-columns:auto 1fr;align-items:start}.payLedgerTop b{grid-column:1/-1}.payLedgerMeta,.proofMetaPro{grid-template-columns:1fr}.payLedgerActions,.proofActionsPro{display:grid;grid-template-columns:1fr}.payLedgerActions button,.payLedgerActions a,.payLedgerActions .badge,.proofActionsPro button,.proofActionsPro a{width:100%;justify-content:center}.paymentStudio{border-radius:24px}}

/* V15.1 Project Workspace Pro
   Purpose: premium project delivery command center.
   Scope: visual/render refresh only. No Supabase/PHP/DB schema changes.
*/
.projectsPro{display:grid;gap:16px;min-width:0}.projectsHero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:18px;align-items:stretch;padding:24px;border-radius:30px;background:linear-gradient(135deg,rgba(14,24,43,.94),rgba(7,13,26,.98));border-color:rgba(37,214,162,.16)}.projectsHero:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 84% 4%,rgba(37,214,162,.17),transparent 32%),radial-gradient(circle at 0 100%,rgba(168,85,247,.11),transparent 36%);pointer-events:none}.projectsHero>*{position:relative;z-index:1}.projectsHero h3{font-size:clamp(30px,3vw,48px);line-height:.98;margin:0 0 10px}.projectsHero .muted{max-width:760px;line-height:1.5}.projectsHealthCard{display:grid;align-content:center;gap:10px;border:1px solid rgba(255,255,255,.10);border-radius:26px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 20px 50px rgba(0,0,0,.18)}.projectsHealthCard span{color:var(--muted);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.10em}.projectsHealthCard b{display:block;color:#fff;font-size:clamp(36px,4vw,56px);line-height:1;letter-spacing:-.06em}.projectsHealthCard small{color:#9fb1cf;font-weight:850;line-height:1.35}.projectsKpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.projectBoard{padding:18px}.projectBoardGrid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:11px}.projectBoardCol{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.085);border-radius:20px;padding:15px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.023));min-width:0}.projectBoardCol:after{content:'';position:absolute;right:-22px;top:-28px;width:78px;height:78px;border-radius:999px;background:rgba(37,214,162,.10)}.projectBoardCol span{display:block;color:var(--muted);font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.095em}.projectBoardCol strong{display:block;margin-top:9px;color:#fff;font-size:30px;line-height:1;letter-spacing:-.055em}.projectsWorkspace{display:grid;grid-template-columns:minmax(320px,430px) minmax(0,1fr);gap:16px;align-items:start}.projectStudio{position:sticky;top:18px;overflow:hidden;min-width:0}.projectStudio:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 94% 0,rgba(37,214,162,.11),transparent 34%);pointer-events:none}.projectStudio>*{position:relative;z-index:1}.projectLibrary{min-width:0}.projectGridPro{grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.projectCardPro{position:relative;overflow:hidden;display:grid;gap:13px;border:1px solid rgba(255,255,255,.09);border-radius:24px;padding:16px;background:linear-gradient(180deg,rgba(16,27,49,.82),rgba(7,13,25,.95));box-shadow:0 18px 44px rgba(0,0,0,.16);min-width:0}.projectCardPro:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand),var(--brand2));opacity:.86}.projectCardPro.isOverdue{border-color:rgba(251,113,133,.28)}.projectCardPro.isOverdue:before{background:linear-gradient(180deg,var(--danger),#f97316)}.projectCardTop{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:start}.projectIcon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;font-size:20px;background:linear-gradient(135deg,rgba(37,214,162,.18),rgba(96,165,250,.14));border:1px solid rgba(255,255,255,.10)}.projectTitleBlock{min-width:0}.projectTitleBlock strong{display:block;color:#fff;font-size:18px;line-height:1.12;overflow-wrap:anywhere}.projectTitleBlock span{display:block;color:#9fb1cf;font-weight:800;font-size:12px;margin-top:5px;line-height:1.35}.projectProgress{display:grid;gap:8px}.projectProgress div{display:flex;align-items:center;justify-content:space-between;gap:10px}.projectProgress span{color:var(--muted);font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.projectProgress b{color:#fff}.projectProgress em{display:block;height:9px;max-width:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand2));box-shadow:0 8px 24px rgba(37,214,162,.18)}.projectMetaPro{grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin:0}.projectMetaPro div{background:rgba(255,255,255,.035);border-color:rgba(255,255,255,.075)}.projectMetaPro b{display:block;overflow-wrap:anywhere;color:#fff}.projectDescription{margin:0;line-height:1.42}.projectTaskPreview{display:grid;gap:8px;list-style:none;margin:0;padding:0}.projectTaskPreview li{display:grid;grid-template-columns:auto 1fr;gap:9px;align-items:center;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.026);border-radius:15px;padding:9px}.projectTaskPreview span{display:inline-flex;border-radius:999px;padding:4px 7px;background:rgba(96,165,250,.14);color:#bfdbfe;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.05em}.projectTaskPreview b{color:#fff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projectEmptyMini{border:1px dashed rgba(255,255,255,.12);border-radius:16px;padding:11px;color:#9fb1cf;font-size:12px;font-weight:800;line-height:1.35;background:rgba(255,255,255,.018)}.projectCardFooter{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#9fb1cf;font-size:12px;font-weight:850;border-top:1px solid rgba(255,255,255,.07);padding-top:11px}.projectCardFooter b{color:#bbf7d0}.projectCardFooter .projectRisk{color:#fecdd3}.projectActionsPro{padding-top:0}.projectActionsPro .success{flex:1 1 130px}
@media(max-width:1180px){.projectsWorkspace{grid-template-columns:1fr}.projectStudio{position:relative;top:auto}.projectGridPro{grid-template-columns:1fr 1fr}}
@media(max-width:980px){.projectsHero{grid-template-columns:1fr}.projectsKpis{grid-template-columns:repeat(2,minmax(0,1fr))}.projectBoardGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.projectGridPro{grid-template-columns:1fr}}
@media(max-width:760px){.projectsPro{gap:12px}.projectsHero{padding:18px;border-radius:24px}.projectsHero h3{font-size:32px}.projectsHealthCard{border-radius:21px;padding:16px}.projectsKpis{grid-template-columns:1fr;gap:10px}.projectBoard{border-radius:24px;padding:16px}.projectBoardGrid{grid-template-columns:1fr}.projectsWorkspace{gap:12px}.projectStudio{border-radius:24px}.projectCardPro{border-radius:22px;padding:15px}.projectCardTop{grid-template-columns:auto 1fr}.projectCardTop .badge{grid-column:1/-1;width:max-content}.projectMetaPro{grid-template-columns:1fr}.projectTaskPreview li{grid-template-columns:1fr}.projectTaskPreview b{white-space:normal}.projectCardFooter{display:grid;gap:6px}.projectActionsPro{display:grid;grid-template-columns:1fr}.projectActionsPro button,.projectActionsPro a,.projectActionsPro .badge{width:100%;justify-content:center}.projectsWorkspace .payPanelHead{display:grid}.projectsWorkspace .payPanelHead button,.projectsWorkspace .searchBox{width:100%;max-width:none}}


/* V15.2 Settings / Business Profile Pro */
.settingsProShell{display:grid;gap:16px}
.settingsProForm{display:grid;gap:16px}
.settingsProHero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);gap:18px;align-items:stretch;padding:24px;background:radial-gradient(circle at 8% 0,rgba(37,214,162,.18),transparent 34%),radial-gradient(circle at 88% 0,rgba(96,165,250,.16),transparent 32%),linear-gradient(135deg,rgba(16,27,49,.96),rgba(7,13,25,.985))}
.settingsProHero:after{content:'';position:absolute;right:-120px;top:-120px;width:330px;height:330px;border-radius:50%;border:1px solid rgba(255,255,255,.12);box-shadow:0 0 90px rgba(37,214,162,.08);pointer-events:none}.settingsProHero>*{position:relative;z-index:1}
.settingsProHero h3{font-size:clamp(32px,3.5vw,48px);line-height:1;margin:0 0 8px;letter-spacing:-.06em}.settingsProHero .muted{max-width:780px;font-size:15px;line-height:1.5}
.settingsProActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.settingsProBrandCard{--settings-brand:var(--brand);border:1px solid rgba(255,255,255,.10);border-radius:26px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.030));box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 18px 44px rgba(0,0,0,.18);display:grid;gap:8px;align-content:center;min-width:0;position:relative;overflow:hidden}.settingsProBrandCard:before{content:'';position:absolute;right:-55px;top:-55px;width:145px;height:145px;border-radius:50%;background:color-mix(in srgb,var(--settings-brand) 28%,transparent)}
.settingsProBrandTop{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;z-index:1}.settingsProLogo{width:58px;height:58px;object-fit:contain;display:block;flex:0 0 auto}.settingsProFallback{width:58px!important;height:58px!important;flex:0 0 58px!important}.settingsProBrandCard strong{font-size:26px;letter-spacing:-.04em;color:#fff;overflow-wrap:anywhere;position:relative;z-index:1}.settingsProBrandCard span:not(.badge){color:#dbeafe;font-weight:900;position:relative;z-index:1}.settingsProBrandCard small{color:#9fb1cf;font-weight:800;line-height:1.35;position:relative;z-index:1;overflow-wrap:anywhere}
.settingsProStats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.settingsProStats div{min-height:126px;border:1px solid rgba(255,255,255,.085);border-radius:24px;padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));box-shadow:0 18px 44px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.035);display:grid;align-content:space-between;gap:9px;min-width:0}.settingsProStats span,.settingsProMiniList span{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.085em}.settingsProStats strong{font-size:clamp(20px,2.2vw,29px);line-height:1;letter-spacing:-.045em;color:#fff;overflow-wrap:anywhere}.settingsProStats small{color:#9fb1cf;font-weight:800;line-height:1.35}
.settingsProWorkspace{display:grid;grid-template-columns:minmax(290px,360px) minmax(0,1fr);gap:16px;align-items:start}.settingsProPreview{position:sticky;top:18px;display:grid;gap:14px;min-width:0}.settingsProPreviewCard{--settings-brand:var(--brand);border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:16px;background:radial-gradient(circle at 92% 0,color-mix(in srgb,var(--settings-brand) 22%,transparent),transparent 35%),linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));display:grid;gap:13px;min-width:0}.settingsProPreviewCard .brand{min-width:0}.settingsProPreviewTotal{font-size:38px;line-height:1;letter-spacing:-.06em;font-weight:950;color:#fff;overflow-wrap:anywhere}.settingsProMiniList{display:grid;gap:10px}.settingsProMiniList div{border:1px solid rgba(255,255,255,.075);border-radius:17px;padding:11px;background:rgba(255,255,255,.032);min-width:0}.settingsProMiniList b{display:block;color:#eaf2ff;font-size:13px;line-height:1.35;margin-top:6px;overflow-wrap:anywhere}
.settingsProMain{display:grid;gap:16px;min-width:0}.settingsProCard{position:relative;overflow:hidden;display:grid;gap:14px;min-width:0}.settingsProCard:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 96% 0,rgba(37,214,162,.08),transparent 32%);pointer-events:none}.settingsProCard>*{position:relative;z-index:1}.settingsProSectionHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(255,255,255,.075);padding-bottom:12px}.settingsProSectionHead h3{font-size:23px;margin:0}.settingsProSectionHead .eyebrow{margin-bottom:5px}.settingsProGrid{display:grid;gap:12px}.settingsProGrid.twoCols{grid-template-columns:repeat(2,minmax(0,1fr))}.settingsProGrid.threeCols{grid-template-columns:repeat(3,minmax(0,1fr))}.settingsProGrid label,.settingsProCard label{min-width:0}.settingsProCard textarea{resize:vertical}.settingsProFooterActions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.settingsProCard .paymentProfileGrid{margin:0}.settingsProCard .paymentIdentityBox{margin:0}.settingsProCard .notice{margin:0}
@media(max-width:1180px){.settingsProWorkspace{grid-template-columns:1fr}.settingsProPreview{position:relative;top:auto}.settingsProStats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.settingsProHero{grid-template-columns:1fr}.settingsProGrid.twoCols,.settingsProGrid.threeCols{grid-template-columns:1fr}.settingsProSectionHead{display:grid}.settingsProStats{grid-template-columns:1fr}.settingsProFooterActions,.settingsProActions{display:grid;grid-template-columns:1fr}.settingsProFooterActions button,.settingsProActions button{width:100%}.settingsProBrandCard{border-radius:22px}.settingsProPreviewTotal{font-size:32px}}
@media(max-width:520px){.settingsProHero{padding:18px;border-radius:24px}.settingsProHero h3{font-size:32px}.settingsProBrandCard,.settingsProPreviewCard,.settingsProStats div{border-radius:21px;padding:16px}.settingsProLogo,.settingsProFallback{width:50px!important;height:50px!important;flex-basis:50px!important}.settingsProBrandCard strong{font-size:22px}.settingsProCard{padding:16px}.settingsProSectionHead h3{font-size:20px}}


/* V15.3 Customer Portal Pro
   Scope: Public client portal visual refresh only. No PHP/Auth/DB logic changes in frontend.
*/
.portalProWrap{padding:22px;align-items:start center;background:radial-gradient(circle at 10% 0,rgba(37,214,162,.13),transparent 32%),radial-gradient(circle at 92% 4%,rgba(96,165,250,.13),transparent 34%),linear-gradient(135deg,#050814,#07101f 50%,#050814)}
.portalProShell{width:min(1180px,100%);padding:24px;border-radius:30px;overflow:hidden;position:relative}.portalProShell:before{content:'';position:absolute;right:-170px;top:-190px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(37,214,162,.13),transparent 66%);pointer-events:none}.portalProShell>*{position:relative;z-index:1}
.portalProHero{border:1px solid rgba(255,255,255,.10);border-radius:28px;padding:20px;background:radial-gradient(circle at 0 0,rgba(37,214,162,.16),transparent 32%),radial-gradient(circle at 100% 0,rgba(96,165,250,.14),transparent 34%),linear-gradient(135deg,rgba(15,24,43,.96),rgba(7,13,25,.985));box-shadow:0 24px 70px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.05);margin-bottom:15px}.portalProBrandLine{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.portalProBrand .brandLogoFree,.portalProLogo{width:52px!important;height:52px!important;min-width:52px!important;min-height:52px!important;flex-basis:52px!important}.portalProBrand strong{font-size:18px!important}.portalProBrand span{color:var(--portal-brand,var(--brand))!important}.portalProSecure{display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(37,214,162,.24);background:rgba(37,214,162,.09);color:#bbf7d0;border-radius:999px;padding:9px 12px;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.portalProSecure:before{content:'●';font-size:9px;color:var(--portal-brand,var(--brand))}
.portalProHeroGrid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:18px;align-items:stretch}.portalProIntro{min-width:0}.portalProIntro h1{font-size:clamp(34px,4.5vw,56px);line-height:.98;letter-spacing:-.065em;margin:0 0 12px}.portalProIntro .muted{font-size:15px;line-height:1.55;max-width:760px}.portalProClientLine{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.portalProClientLine span{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);border-radius:999px;padding:8px 11px;color:#dbeafe;font-size:12px;font-weight:850}.portalProHeroActions{margin-top:16px}.portalProHeroActions a{text-decoration:none!important}
.portalProBalanceCard{border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.028));display:grid;align-content:center;gap:8px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}.portalProBalanceCard span,.portalProMetrics span,.portalProMiniPanel span,.portalProSectionHead .eyebrow,.portalProDocType,.portalProAmountGrid span,.portalProReceiptCard span{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:950}.portalProBalanceCard>strong{font-size:clamp(36px,4.2vw,52px);line-height:1;letter-spacing:-.065em;color:#fff;overflow-wrap:anywhere}.portalProBalanceCard small{color:#aebfd9;font-weight:850}.portalProBalanceMeta{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:8px}.portalProBalanceMeta div{border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.12);border-radius:16px;padding:10px;min-width:0}.portalProBalanceMeta b{display:block;color:#fff;font-size:16px;overflow-wrap:anywhere}.portalProBalanceMeta em{display:block;color:var(--muted);font-size:11px;font-style:normal;margin-top:4px;font-weight:850}
.portalProMetrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:15px 0}.portalProMetrics article{border:1px solid rgba(255,255,255,.085);border-radius:22px;padding:16px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));box-shadow:0 16px 42px rgba(0,0,0,.14);min-width:0}.portalProMetrics strong{display:block;color:#fff;font-size:clamp(22px,2.4vw,32px);line-height:1;margin:9px 0 6px;letter-spacing:-.055em;overflow-wrap:anywhere}.portalProMetrics small{color:#9fb1cf;font-weight:800;line-height:1.3}.portalProOverview{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;margin-bottom:15px}.portalProMiniPanel{border:1px solid rgba(255,255,255,.09);border-radius:22px;padding:17px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020));min-width:0}.portalProMiniPanel.support{background:linear-gradient(135deg,rgba(37,214,162,.075),rgba(96,165,250,.045))}.portalProMiniPanel strong{display:block;color:#fff;font-size:20px;margin:7px 0 8px;overflow-wrap:anywhere}.portalProMiniPanel p{margin:0;line-height:1.45}
.portalProSection{box-shadow:none!important;margin-bottom:15px;border-radius:26px!important;padding:18px!important;background:linear-gradient(180deg,rgba(17,27,48,.70),rgba(8,14,27,.90))!important}.portalProSectionHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.portalProSectionHead h3{margin:0 0 5px;font-size:25px;letter-spacing:-.04em}.portalProSectionHead .muted{margin:0;line-height:1.4}.portalProDocGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.portalProDocCard{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.09);border-radius:22px;padding:15px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.022));display:grid;gap:12px;min-width:0}.portalProDocCard:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--portal-brand,var(--brand)),var(--brand2));opacity:.85}.portalProDocCard.invoice.warn:before{background:linear-gradient(180deg,var(--warn),var(--brand2))}.portalProDocCard.invoice.danger:before{background:linear-gradient(180deg,var(--danger),#f97316)}.portalProDocCard.isClosed{opacity:.72}.portalProDocTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.portalProDocTop strong{display:block;color:#fff;font-size:20px;line-height:1.1;letter-spacing:-.035em;overflow-wrap:anywhere}.portalProDocTop small{display:block;color:#9fb1cf;margin-top:5px;line-height:1.35;font-weight:800}.portalProAmountGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.portalProAmountGrid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.portalProAmountGrid div{border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:10px;background:rgba(255,255,255,.035);min-width:0}.portalProAmountGrid span{display:block;font-size:10px;margin-bottom:7px}.portalProAmountGrid b{display:block;color:#fff;font-size:16px;line-height:1.1;overflow-wrap:anywhere}.portalProActions{display:flex;gap:8px;flex-wrap:wrap}.portalProActions a{text-decoration:none!important}.portalProPaymentPanel .paymentProfileGrid{margin:0 0 12px}.portalProPaymentPanel .paymentIdentityBox{margin:0}.portalProReceipts{display:grid;gap:10px}.portalProReceiptCard{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:center;border:1px solid rgba(255,255,255,.085);border-radius:20px;padding:13px;background:rgba(255,255,255,.035);min-width:0}.portalProReceiptCard strong{display:block;color:#fff;font-size:16px;margin-top:4px;overflow-wrap:anywhere}.portalProReceiptCard small{display:block;color:#9fb1cf;margin-top:4px;font-weight:800}.portalProReceiptCard>b{font-size:20px;color:#fff;letter-spacing:-.04em}.portalProEmpty{border:1px dashed rgba(255,255,255,.16);border-radius:22px;padding:24px;background:rgba(255,255,255,.025);display:grid;gap:6px;text-align:center}.portalProEmpty strong{font-size:18px;color:#fff}.portalProEmpty span{color:var(--muted);line-height:1.4}
@media(max-width:980px){.portalProHeroGrid,.portalProOverview{grid-template-columns:1fr}.portalProMetrics{grid-template-columns:repeat(2,minmax(0,1fr))}.portalProDocGrid{grid-template-columns:1fr}.portalProShell{padding:18px}.portalProHero{padding:18px}.portalProReceiptCard{grid-template-columns:1fr}.portalProReceiptCard>b{justify-self:start}.portalProSectionHead{display:grid}.portalProPaymentPanel .paymentProfileGrid,.portalProPaymentPanel .paymentIdentityBox{grid-template-columns:1fr!important}}
@media(max-width:760px){.portalProWrap{padding:10px!important}.portalProShell{padding:14px!important;border-radius:24px!important}.portalProHero{border-radius:23px;padding:16px;margin-bottom:12px}.portalProBrandLine{display:grid;gap:12px}.portalProSecure{width:max-content;max-width:100%}.portalProBrand .brandLogoFree,.portalProLogo{width:46px!important;height:46px!important;min-width:46px!important;min-height:46px!important;flex-basis:46px!important}.portalProIntro h1{font-size:34px;line-height:1.04}.portalProHeroActions{display:grid;grid-template-columns:1fr}.portalProHeroActions a{width:100%;min-height:46px}.portalProBalanceCard{border-radius:21px;padding:16px}.portalProBalanceCard>strong{font-size:35px}.portalProMetrics{grid-template-columns:1fr;gap:10px}.portalProOverview{gap:10px}.portalProSection{border-radius:22px!important;padding:15px!important;margin-bottom:12px!important}.portalProDocCard{border-radius:20px;padding:14px}.portalProDocTop{display:grid}.portalProAmountGrid,.portalProAmountGrid.three{grid-template-columns:1fr}.portalProActions{display:grid;grid-template-columns:1fr}.portalProActions a{width:100%;min-height:42px}.portalProClientLine{display:grid}.portalProClientLine span{width:100%;justify-content:center}.portalProMetrics article{border-radius:20px;padding:15px}.portalProMiniPanel{border-radius:20px}.portalProSectionHead h3{font-size:22px}.portalProReceiptCard{border-radius:18px}}


/* V15.3.1 App Shell Sync Fix
   Scope: admin app layout guardrails after Customer Portal Pro.
   Fixes sidebar brand/logo clipping, keeps the logo style consistent with the app shell,
   and prevents public portal/mobile rules from visually compressing the private sidebar.
*/
.app{
  grid-template-columns:300px minmax(0,1fr);
  width:100%;
  max-width:1780px;
  margin:0 auto;
}
.side{
  min-width:0;
  overflow:hidden;
}
.side > .brand.brandFree{
  min-height:82px!important;
  padding:13px 14px!important;
  align-items:center!important;
  gap:13px!important;
  overflow:visible!important;
  border-radius:24px!important;
  background:
    radial-gradient(circle at 0 0,rgba(37,214,162,.16),transparent 42%),
    linear-gradient(135deg,rgba(255,255,255,.065),rgba(255,255,255,.026))!important;
  border:1px solid rgba(37,214,162,.16)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 14px 34px rgba(0,0,0,.14)!important;
}
.side > .brand.brandFree > div{
  min-width:0!important;
  display:grid!important;
  gap:3px!important;
  overflow:hidden!important;
}
.side > .brand.brandFree .brandLogoFree{
  width:58px!important;
  height:58px!important;
  min-width:58px!important;
  min-height:58px!important;
  max-width:58px!important;
  max-height:58px!important;
  flex:0 0 58px!important;
  object-fit:contain!important;
  object-position:center!important;
  overflow:visible!important;
  filter:drop-shadow(0 0 16px rgba(37,214,162,.24));
}
.side > .brand.brandFree .brandFallback{
  width:58px!important;
  height:58px!important;
  min-width:58px!important;
  min-height:58px!important;
  flex:0 0 58px!important;
  border-radius:18px!important;
}
.side > .brand.brandFree strong{
  font-size:18px!important;
  line-height:1.03!important;
  letter-spacing:-.035em!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  color:#f4f8ff!important;
}
.side > .brand.brandFree span{
  font-size:12px!important;
  line-height:1.2!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  color:var(--brand)!important;
  margin-top:0!important;
}
.nav{
  min-width:0;
}
.nav button{
  width:100%;
  min-width:0;
}
.nav button span:first-child{
  flex:0 0 28px;
}
.main{
  min-width:0;
}
.dashHero{
  min-width:0;
}

@media(max-width:1180px){
  .app{grid-template-columns:280px minmax(0,1fr);padding:14px;gap:14px}
  .side > .brand.brandFree .brandLogoFree,
  .side > .brand.brandFree .brandFallback{
    width:52px!important;height:52px!important;min-width:52px!important;min-height:52px!important;max-width:52px!important;max-height:52px!important;flex-basis:52px!important;
  }
  .side > .brand.brandFree strong{font-size:16px!important}
}
@media(max-width:1000px){
  .app{display:block;max-width:none;margin:0;padding:12px}
  .side{overflow:auto!important}
  .side > .brand.brandFree{min-height:74px!important}
  .mobileTop .brandFree{overflow:hidden!important}
  .mobileTop .brandLogoFree{width:38px!important;height:38px!important;min-width:38px!important;min-height:38px!important;max-width:38px!important;max-height:38px!important;flex-basis:38px!important}
}
@media(max-width:760px){
  .side > .brand.brandFree{padding:11px!important;border-radius:21px!important}
  .side > .brand.brandFree .brandLogoFree,
  .side > .brand.brandFree .brandFallback{
    width:48px!important;height:48px!important;min-width:48px!important;min-height:48px!important;max-width:48px!important;max-height:48px!important;flex-basis:48px!important;
  }
  .side > .brand.brandFree strong{font-size:15px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
}


/* V15.4 Public Documents Pro
   Purpose: final polish for public estimate/invoice views and document consistency.
   Scope: public views only. No Supabase/PHP/DB changes.
*/
.publicDocWrap{padding:28px 14px;background:radial-gradient(circle at 15% 0,rgba(37,214,162,.10),transparent 30%),radial-gradient(circle at 92% 12%,rgba(96,165,250,.10),transparent 34%),linear-gradient(135deg,#050814,#091527 48%,#050814)}
.publicDocShell{position:relative;overflow:hidden;width:min(1160px,100%);padding:30px;border-radius:34px;background:linear-gradient(180deg,rgba(15,25,45,.95),rgba(7,13,25,.98));border-color:rgba(255,255,255,.10)}
.publicDocShell:before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(37,214,162,.075),transparent 38%),radial-gradient(circle at 94% 0,rgba(37,214,162,.14),transparent 30%);pointer-events:none}.publicDocShell>*{position:relative;z-index:1}
.publicDocHero{display:grid;grid-template-columns:minmax(0,1fr) minmax(250px,330px);gap:22px;align-items:stretch;margin-bottom:22px}.publicDocHero .publicDocBrand{height:100%;align-items:center!important}.publicDocHero .publicDocBrand h1{font-size:clamp(38px,5vw,58px)!important}.publicDocHero .publicDocLogo,.publicDocHero .brandLogoFree{filter:drop-shadow(0 14px 30px rgba(37,214,162,.16))}
.publicDocTotalPanel{display:grid;align-content:center;justify-items:end;gap:8px;border:1px solid rgba(255,255,255,.11);border-radius:28px;padding:22px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.026));box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 22px 60px rgba(0,0,0,.20);min-width:0}.publicDocTotalPanel strong{font-size:clamp(38px,4.4vw,62px);line-height:.96;letter-spacing:-.065em;color:#fff}.publicDocTotalPanel small{color:#9fb1cf;font-weight:900}.publicDocTotalPanel .badge{margin-bottom:6px}.publicDocMiniTotals{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;margin-top:8px}.publicDocMiniTotals div{border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:10px;background:rgba(3,9,20,.24)}.publicDocMiniTotals span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:950}.publicDocMiniTotals b{display:block;color:#fff;margin-top:4px}
.publicDocTopGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:18px}.publicDocTopGrid.compact{margin-bottom:16px}.publicDocWorkspace{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:16px;align-items:start}.publicDocWorkspace.invoice{grid-template-columns:minmax(0,1fr) minmax(360px,460px)}.publicDocMainColumn{display:grid;gap:16px;min-width:0}.publicDocSideRail{display:grid;gap:16px;min-width:0;align-content:start}
.publicDocInfoCard,.publicDocQrPanel,.publicDocNote{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.10);border-radius:26px;padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.022));box-shadow:0 18px 46px rgba(0,0,0,.16);min-width:0}.publicDocInfoCard{display:grid;grid-template-columns:auto 1fr;gap:13px;align-items:start}.publicDocInfoIcon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(37,214,162,.18),rgba(96,165,250,.14));border:1px solid rgba(255,255,255,.10)}.publicDocInfoCard span,.publicDocQrPanel span,.publicDocNote span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.095em;font-weight:950;margin-bottom:7px}.publicDocInfoCard strong,.publicDocQrPanel strong{display:block;color:#fff;font-size:18px;line-height:1.15}.publicDocInfoCard p,.publicDocQrPanel p,.publicDocNote p{margin:6px 0 0;color:#aab8d1;line-height:1.42}.publicDocInfoCard .docActions{margin-top:13px;display:flex;gap:9px;flex-wrap:wrap}.publicDocInfoCard.action{border-color:rgba(37,214,162,.18);background:linear-gradient(180deg,rgba(37,214,162,.075),rgba(255,255,255,.022))}
.publicDocQrPanel{display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center}.publicDocQrPanel img{width:96px;height:96px;border-radius:18px;background:white;padding:7px;box-shadow:0 12px 28px rgba(0,0,0,.20)}
.publicDocSectionHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.publicDocSectionHead h3{margin:0;font-size:24px}.publicDocSectionHead .eyebrow{margin:0 0 6px}.publicDocItemsPanel{overflow:hidden}.publicDocTableWrap{border-radius:22px;border-color:rgba(255,255,255,.08)}.publicDocItemsTable{min-width:0!important}.publicDocItemsTable th{font-size:10px}.publicDocItemsTable td{vertical-align:middle}.publicDocItemsTable td:first-child strong{display:block;color:#fff}.publicDocItemsTable td:first-child small{display:block;margin-top:4px;color:#91a4c3;line-height:1.35}.publicDocItemsTable td:nth-child(2),.publicDocItemsTable td:nth-child(3),.publicDocItemsTable td:nth-child(4){white-space:nowrap}.publicDocItemsCards{display:none}.publicDocItemCard{border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:13px;background:rgba(255,255,255,.035);display:grid;gap:10px}.publicDocItemCard strong{display:block;color:#fff}.publicDocItemCard span{display:block;color:#91a4c3;line-height:1.35}.publicDocItemMeta{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.publicDocItemMeta span{border:1px solid rgba(255,255,255,.075);border-radius:14px;padding:8px;color:var(--muted);font-size:11px;text-transform:uppercase;font-weight:950}.publicDocItemMeta b{display:block;color:#fff;margin-top:4px;text-transform:none;font-size:13px}
.publicDocTotalsBox{display:grid;justify-content:end;gap:8px;margin-top:16px}.publicDocTotalsBox div{display:grid;grid-template-columns:130px 150px;gap:12px;align-items:center}.publicDocTotalsBox span{color:var(--muted);font-weight:850}.publicDocTotalsBox strong{text-align:right;color:#fff}.publicDocTotalsBox .grand{border-top:1px solid rgba(255,255,255,.10);padding-top:10px;margin-top:2px}.publicDocTotalsBox .grand strong{font-size:24px;letter-spacing:-.05em;color:#fff}.publicDocNote{white-space:pre-wrap}.publicDocPaymentRail{position:sticky;top:18px;border-radius:28px!important;padding:20px!important;min-width:0}.publicDocPaymentRail .paymentProfileGrid{display:grid!important;grid-template-columns:1fr!important}.publicDocPaymentRail .paymentProfileCard{min-height:auto}.publicDocPaymentRail .paymentProfileCard strong{font-size:16px!important;white-space:normal!important;text-align:right}.publicDocPaymentRail .paymentIdentityBox{grid-template-columns:1fr!important}.publicDocPaymentRail .paymentInstructionsText{border-radius:20px;background:rgba(3,9,20,.30);border:1px solid rgba(255,255,255,.075);padding:14px!important;margin:12px 0 0!important}.publicProofPanel{border-color:rgba(96,165,250,.14)}.publicProofPanel form{margin-top:12px}.publicInvoiceWrap .publicDocTopGrid.compact{grid-template-columns:minmax(0,1fr) minmax(260px,360px)}
@media(max-width:1100px){.publicDocHero,.publicDocWorkspace,.publicDocWorkspace.invoice{grid-template-columns:1fr}.publicDocPaymentRail{position:relative;top:auto}.publicDocPaymentRail .paymentProfileGrid{grid-template-columns:repeat(3,minmax(0,1fr))!important}.publicDocPaymentRail .paymentIdentityBox{grid-template-columns:repeat(3,minmax(0,1fr))!important}.publicDocPaymentRail .paymentProfileCard strong{text-align:left}}
@media(max-width:760px){.publicDocWrap{padding:12px}.publicDocShell{padding:18px;border-radius:26px}.publicDocHero{gap:14px}.publicDocTotalPanel{justify-items:start;padding:18px;border-radius:23px}.publicDocMiniTotals{grid-template-columns:1fr 1fr}.publicDocTopGrid,.publicDocTopGrid.compact,.publicInvoiceWrap .publicDocTopGrid.compact{grid-template-columns:1fr}.publicDocInfoCard{grid-template-columns:1fr}.publicDocInfoCard .docActions{display:grid;grid-template-columns:1fr}.publicDocInfoCard .docActions>*{width:100%}.publicDocQrPanel{grid-template-columns:80px 1fr}.publicDocQrPanel img{width:80px;height:80px}.publicDocTableWrap{display:none!important}.publicDocItemsCards{display:grid;gap:10px}.publicDocTotalsBox{justify-content:stretch}.publicDocTotalsBox div{grid-template-columns:1fr auto}.publicDocPaymentRail .paymentProfileGrid,.publicDocPaymentRail .paymentIdentityBox{grid-template-columns:1fr!important}.publicDocPaymentRail .docActions{display:grid}.publicDocPaymentRail .docActions>*{width:100%}.publicDocItemMeta{grid-template-columns:1fr}.publicDocSectionHead{display:grid}.publicDocHero .publicDocBrand h1{font-size:34px!important}.publicDocTotalPanel strong{font-size:38px}}
@media(max-width:420px){.publicDocShell{padding:15px;border-radius:22px}.publicDocQrPanel{grid-template-columns:1fr}.publicDocQrPanel img{width:92px;height:92px}.publicDocMiniTotals{grid-template-columns:1fr}}


/* V15.4.2 Sidebar + Clients 360 Fix
   Scope: private app only. Restores visible sidebar info/footer and makes Client Portfolio cards readable.
   No Supabase/PHP/DB changes.
*/
@media(min-width:1001px){
  .app{
    grid-template-columns:300px minmax(0,1fr)!important;
    align-items:start;
  }
  .side{
    height:calc(100vh - 40px)!important;
    max-height:calc(100vh - 40px)!important;
    display:flex!important;
    flex-direction:column!important;
    gap:14px!important;
    overflow:hidden!important;
  }
  .side > .brand.brandFree{
    flex:0 0 auto!important;
    min-height:88px!important;
  }
  .side .nav{
    flex:1 1 auto!important;
    min-height:0!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    padding-right:3px!important;
    gap:9px!important;
    scrollbar-width:thin;
  }
  .side .nav::-webkit-scrollbar{width:5px}
  .side .nav::-webkit-scrollbar-thumb{background:rgba(37,214,162,.28);border-radius:999px}
  .side .nav button{
    min-height:56px!important;
    padding:12px 14px!important;
    border-radius:18px!important;
    flex:0 0 auto!important;
  }
  .side .nav button span:first-child{
    width:30px!important;
    height:30px!important;
    border-radius:12px!important;
  }
  .side #logout{
    flex:0 0 auto!important;
    width:100%!important;
    min-height:44px!important;
    margin-top:0!important;
  }
  .side .footer{
    display:block!important;
    flex:0 0 auto!important;
    margin-top:0!important;
    padding:11px 12px!important;
    border-radius:17px!important;
    font-size:11px!important;
    line-height:1.35!important;
    color:#9fb1cf!important;
    background:linear-gradient(180deg,rgba(37,214,162,.060),rgba(255,255,255,.026))!important;
    border:1px solid rgba(37,214,162,.12)!important;
  }
}

.clients360Workspace{
  grid-template-columns:minmax(340px,420px) minmax(0,1fr)!important;
  gap:18px!important;
}
.clients360Library{
  overflow:hidden!important;
}
.clients360Cards{
  grid-template-columns:1fr!important;
  gap:14px!important;
}
.client360Card{
  padding:18px!important;
  gap:14px!important;
}
.client360Money{
  grid-template-columns:repeat(3,minmax(120px,1fr))!important;
}
.client360Money strong{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  font-size:20px!important;
  letter-spacing:-.045em!important;
}
.client360Stats{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}
.client360Stats span{
  min-height:42px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  line-height:1.2!important;
}
.client360Actions{
  gap:9px!important;
}
.client360Actions .tiny{
  min-width:78px!important;
}
.client360LibraryHead{
  padding-bottom:12px!important;
  border-bottom:1px solid rgba(255,255,255,.075)!important;
  margin-bottom:18px!important;
}
.client360Contact span{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

@media(min-width:1380px){
  .client360Card{
    grid-template-columns:minmax(280px,.9fr) minmax(360px,1.15fr);
    align-items:start;
  }
  .client360Top,
  .client360Contact{
    grid-column:1;
  }
  .client360Money,
  .client360Stats,
  .client360Signal,
  .client360Actions{
    grid-column:2;
  }
  .client360Money{margin-top:0!important}
}

@media(max-width:1180px){
  .clients360Workspace{grid-template-columns:1fr!important}
  .clients360Cards{grid-template-columns:1fr!important}
}
@media(max-width:760px){
  .client360Card{display:grid!important;grid-template-columns:1fr!important;padding:15px!important}
  .client360Money{grid-template-columns:1fr!important}
  .client360Stats{grid-template-columns:1fr!important}
  .client360Contact span{white-space:normal!important}
  .client360Money strong{white-space:normal!important;overflow:visible!important;text-overflow:clip!important}
}


/* V15.4.3 Compact Sidebar Pro
   Scope: private app sidebar only. Makes the desktop navigation compact enough to avoid the inner scroll bar
   while keeping the brand, Sign out and footer visible.
*/
@media(min-width:1001px){
  .app{
    grid-template-columns:288px minmax(0,1fr)!important;
    gap:18px!important;
    padding:18px!important;
  }
  .side{
    height:calc(100vh - 36px)!important;
    max-height:calc(100vh - 36px)!important;
    padding:16px!important;
    gap:10px!important;
    border-radius:28px!important;
    overflow:hidden!important;
  }
  .side > .brand.brandFree{
    min-height:70px!important;
    padding:10px 11px!important;
    border-radius:21px!important;
    gap:10px!important;
  }
  .side > .brand.brandFree .brandLogoFree,
  .side > .brand.brandFree .brandFallback{
    width:50px!important;
    height:50px!important;
    min-width:50px!important;
    min-height:50px!important;
    max-width:50px!important;
    max-height:50px!important;
    flex-basis:50px!important;
  }
  .side > .brand.brandFree strong{
    font-size:16px!important;
    line-height:1.02!important;
  }
  .side > .brand.brandFree span{
    font-size:12px!important;
    line-height:1.1!important;
  }
  .side .nav{
    flex:0 0 auto!important;
    overflow:visible!important;
    padding-right:0!important;
    gap:6px!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    scrollbar-width:none!important;
  }
  .side .nav::-webkit-scrollbar{display:none!important;width:0!important;height:0!important}
  .side .nav button{
    min-height:43px!important;
    padding:8px 11px!important;
    border-radius:15px!important;
    gap:9px!important;
    font-size:14px!important;
    letter-spacing:-.015em!important;
  }
  .side .nav button span:first-child{
    width:25px!important;
    height:25px!important;
    flex-basis:25px!important;
    min-width:25px!important;
    border-radius:10px!important;
    font-size:14px!important;
  }
  .side .nav button.active:after{
    right:12px!important;
    width:7px!important;
    height:7px!important;
  }
  .side #logout{
    min-height:40px!important;
    padding:8px 12px!important;
    border-radius:16px!important;
    font-size:14px!important;
    margin-top:auto!important;
  }
  .side .footer{
    padding:9px 10px!important;
    border-radius:15px!important;
    font-size:10.5px!important;
    line-height:1.28!important;
    letter-spacing:.005em!important;
  }
}
@media(min-width:1001px) and (max-height:760px){
  .side{padding:13px!important;gap:7px!important}
  .side > .brand.brandFree{min-height:62px!important;padding:8px 10px!important}
  .side > .brand.brandFree .brandLogoFree,
  .side > .brand.brandFree .brandFallback{width:44px!important;height:44px!important;min-width:44px!important;min-height:44px!important;max-width:44px!important;max-height:44px!important;flex-basis:44px!important}
  .side > .brand.brandFree strong{font-size:14px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .side .nav{gap:5px!important}
  .side .nav button{min-height:38px!important;padding:7px 10px!important;font-size:13px!important;border-radius:14px!important}
  .side .nav button span:first-child{width:23px!important;height:23px!important;min-width:23px!important;flex-basis:23px!important;font-size:13px!important}
  .side #logout{min-height:36px!important;font-size:13px!important}
  .side .footer{padding:8px 9px!important;font-size:10px!important;line-height:1.18!important}
}
@media(min-width:1001px) and (max-width:1180px){
  .app{grid-template-columns:270px minmax(0,1fr)!important;gap:14px!important;padding:14px!important}
  .side{padding:14px!important;gap:8px!important}
  .side > .brand.brandFree{min-height:66px!important}
  .side .nav button{min-height:40px!important;font-size:13px!important}
}
