:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#251b35;--purple-950:#241032;--purple-900:#371047;--purple-800:#4c1266;--purple-700:#651582;--purple-600:#7b1fa2;--purple-500:#8a05be;--purple-100:#f1e2fb;--purple-50:#faf5ff;--ink:#251b35;--muted:#75657f;--line:#eadff1;--surface:#fff;--success:#047857;--danger:#b42318;--shadow:0 18px 45px #3710471f;background:#f7f4fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}html,body{overflow-x:hidden}body{background:radial-gradient(circle at 0 0,#8a05be24,#0000 34rem),linear-gradient(#fbf7ff 0%,#f6f1fa 100%);min-width:320px;margin:0}button,input,select{font:inherit}button{background:var(--purple-500);color:#fff;cursor:pointer;border:0;border-radius:8px;min-height:38px;padding:0 14px;font-weight:700;transition:transform .16s,background .16s,box-shadow .16s;box-shadow:0 8px 18px #8a05be2e}button:hover{background:var(--purple-700);transform:translateY(-1px)}button:active{transform:translateY(0)}.button-with-icon{justify-content:center;align-items:center;gap:8px;display:inline-flex}.button-with-icon svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:17px;height:17px}.secondary-action{color:var(--purple-700);border:1px solid var(--line);box-shadow:none;background:#fff}.secondary-action:hover{background:var(--purple-50);color:var(--purple-800)}input,select{border:1px solid var(--line);width:auto;min-width:0;max-width:100%;min-height:38px;color:var(--ink);background:#fff;border-radius:8px;outline:none;padding:0 12px;box-shadow:0 1px #24103208}input[type=date]{width:100%;min-width:0;max-width:100%;line-height:38px}input:focus,select:focus{border-color:var(--purple-500);box-shadow:0 0 0 3px #8a05be1f}table{background:var(--surface);border-radius:10px;width:100%;overflow:hidden;box-shadow:0 10px 28px #3710470f;border:1px solid var(--line)!important}th{background:var(--purple-50);color:var(--purple-900);text-transform:uppercase;letter-spacing:0;font-size:12px;padding:12px 14px!important}td{border-bottom:1px solid #f0e7f5;padding:12px 14px!important}tbody tr:hover{background:#fcf8ff}tbody tr.selected-row{background:#f4e6fb}.row-actions{align-items:center;gap:8px;display:flex}.icon-button{border:1px solid var(--line);width:34px;min-width:34px;height:34px;min-height:34px;box-shadow:none;background:#fff;place-items:center;padding:0;display:inline-grid}.icon-button svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:17px;height:17px}.icon-button.inspect{color:var(--purple-700)}.icon-button.edit{color:#2563eb}.icon-button.delete{color:var(--danger)}.icon-button:hover{background:var(--purple-50);transform:none}.icon-button.delete:hover{background:#fff1f0}.pagination-controls{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:10px 0;font-size:13px;display:flex}.pagination-controls>div{align-items:center;gap:8px;display:flex}.pagination-controls strong{color:var(--ink);font-size:13px}.pagination-controls button{min-height:34px;box-shadow:none;padding:0 12px}button:disabled,button:disabled:hover{color:#fff;cursor:not-allowed;box-shadow:none;background:#d8cce0;transform:none}.toast-view{z-index:30;border:1px solid var(--line);width:min(360px,100vw - 28px);min-height:48px;color:var(--ink);background:#fff;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;font-weight:800;display:flex;position:fixed;top:20px;right:22px;box-shadow:0 18px 40px #3710472e}.toast-view-success{border-color:#04785733}.toast-view-error{border-color:#b4231838}.toast-view-loading{border-color:#8a05be38}.toast-dot{background:var(--success);border-radius:50%;flex:none;width:10px;height:10px}.toast-view-error .toast-dot{background:var(--danger)}.toast-spinner{border:2px solid var(--purple-100);border-top-color:var(--purple-500);border-radius:50%;flex:none;width:18px;height:18px;animation:.72s linear infinite toast-spin}.toast-close{background:var(--purple-50);width:28px;min-width:28px;height:28px;min-height:28px;color:var(--purple-700);box-shadow:none;border-radius:8px;margin-left:auto;padding:0}.toast-close:hover{background:var(--purple-100);transform:none}@keyframes toast-spin{to{transform:rotate(360deg)}}h2{color:var(--ink);margin:0 0 18px;font-size:24px}h3{margin-top:0}.auth-loading,.login-shell{place-items:center;min-height:100vh;padding:20px;display:grid}.auth-loading{color:var(--purple-800);font-weight:900}.login-shell{background:linear-gradient(135deg,#04785714,#0000 32rem),linear-gradient(#fbf7ff 0%,#f7f4fb 100%)}.login-panel{border:1px solid var(--line);width:min(440px,100%);box-shadow:var(--shadow);background:#fff;border-radius:12px;overflow:hidden}.login-brand{background:var(--purple-950);color:#fff;align-items:center;gap:12px;min-height:82px;padding:18px 20px;display:flex}.login-brand strong,.login-brand span{display:block}.login-brand span{color:#ffffffb8;font-size:12px;font-weight:700}.login-content{gap:16px;padding:22px;display:grid}.login-content h1{color:var(--ink);margin:0;font-size:24px}.google-login-slot{align-items:center;min-height:44px;display:flex}.google-login-slot span{color:var(--muted);font-size:13px;font-weight:800}.admin-login-form{box-shadow:none;background:0 0;border:0;gap:12px;padding:0;display:grid}.admin-login-form button{width:100%}.login-error{min-height:38px;color:var(--danger);background:#fff1f0;border:1px solid #b4231833;border-radius:8px;align-items:center;padding:9px 11px;font-size:13px;font-weight:800;display:flex}.app-shell{grid-template-rows:auto 1fr;grid-template-columns:280px minmax(0,1fr);width:100%;min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, var(--purple-950), var(--purple-800));color:#fff;flex-direction:column;grid-area:1/1/span 2;gap:22px;height:100vh;padding:22px;display:flex;position:sticky;top:0;box-shadow:18px 0 45px #37104733}.brand-block{align-items:center;gap:12px;min-height:52px;display:flex}.brand-mark,.avatar{border-radius:12px;flex:none;place-items:center;font-weight:900;display:grid}.brand-mark{width:46px;height:46px;color:var(--purple-700);background:#fff;box-shadow:0 14px 28px #00000029}.brand-block strong,.brand-block span{display:block}.brand-block strong{font-size:17px}.brand-block span,.sidebar-footer span{color:#ffffffb3;font-size:12px}.side-nav{flex-direction:column;gap:6px;display:flex}.side-nav button{color:#ffffffc7;width:100%;min-height:44px;box-shadow:none;background:0 0;border:1px solid #0000;justify-content:flex-start;align-items:center;gap:10px;padding:0 12px;display:flex}.side-nav button:hover,.side-nav button.active{color:#fff;background:#ffffff24;border-color:#ffffff24;transform:none}.nav-icon{background:#ffffff1f;border-radius:8px;place-items:center;width:28px;height:28px;font-size:12px;display:grid}.side-nav button.active .nav-icon{color:var(--purple-700);background:#fff}.nav-section{border-top:1px solid #ffffff1f;flex-direction:column;gap:8px;padding-top:14px;display:flex}.nav-section>span{color:#ffffff9e;text-transform:uppercase;letter-spacing:0;padding:0 12px;font-size:11px;font-weight:800}.side-nav-sub button{min-height:40px;padding-left:18px}.sidebar-footer{background:#ffffff14;border:1px solid #ffffff24;border-radius:12px;margin-top:auto;padding:14px}.sidebar-footer strong{margin-top:4px;display:block}.topbar{z-index:5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffd1;border-bottom:1px solid #eadff1eb;grid-area:1/2;justify-content:space-between;align-items:center;gap:16px;min-height:82px;padding:18px 28px;display:flex;position:sticky;top:0}.topbar h1{color:var(--ink);margin:2px 0 0;font-size:25px}.eyebrow{color:var(--purple-600);text-transform:uppercase;letter-spacing:0;font-size:12px;font-weight:800;display:block}.topbar-actions{align-items:center;gap:12px;display:flex}.account-summary,.user-menu{border:1px solid var(--line);background:#fff;border-radius:12px;align-items:center;gap:10px;min-height:48px;padding:8px 12px;display:flex;box-shadow:0 8px 24px #37104714}.account-summary{min-width:134px;display:block}.account-summary span,.user-menu span{color:var(--muted);font-size:12px;display:block}.account-summary strong,.user-menu strong{color:var(--ink);font-size:14px;display:block}.avatar{background:var(--purple-100);width:34px;height:34px;color:var(--purple-700);border-radius:50%}.content-area{grid-area:2/2;width:100%;min-width:0;padding:28px}.content-area>div{padding:0!important}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:16px;display:grid}.summary-card{border:1px solid var(--line);background:var(--surface);min-height:132px;box-shadow:var(--shadow);border-radius:12px;padding:18px}.summary-card h3{color:var(--muted);margin:0 0 18px;font-size:13px;font-weight:800}.summary-card p{color:var(--purple-900);margin:0;font-size:28px;font-weight:900}.summary-card span{color:var(--muted);margin-top:12px;font-size:12px;font-weight:700;line-height:1.35;display:block}.summary-card.featured{background:linear-gradient(135deg, var(--purple-800), var(--purple-500));color:#fff}.summary-card.featured h3,.summary-card.featured p,.summary-card.featured span{color:#fff}.module-heading{justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.module-heading h2{margin-bottom:0}.module-subtitle{color:var(--muted);margin:6px 0 0;font-size:14px;font-weight:700}.dashboard-filter-panel,.dashboard-chart-panel{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:12px;margin-bottom:16px;padding:16px}.period-tabs{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.period-tabs button{border:1px solid var(--line);min-height:38px;color:var(--purple-800);box-shadow:none;background:#fff;padding:9px 13px;font-size:13px}.period-tabs button.active{border-color:var(--purple-700);background:var(--purple-700);color:#fff}.date-range-picker{grid-template-columns:minmax(160px,220px) 52px minmax(160px,220px);align-items:end;gap:12px;margin-top:14px;display:grid}.date-range-picker label{gap:6px;display:grid}.date-range-picker span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:800}.date-route-line{height:40px;position:relative}.date-route-line:before{content:"";border-top:2px dashed var(--purple-200);position:absolute;top:50%;left:4px;right:4px}.date-route-line:after{content:"";border-top:2px solid var(--purple-600);border-right:2px solid var(--purple-600);width:10px;height:10px;position:absolute;top:calc(50% - 5px);right:2px;transform:rotate(45deg)}.period-readout{color:var(--muted);margin-top:12px;font-size:12px;font-weight:800;display:inline-flex}.dashboard-chart-panel h3{color:var(--purple-900);margin:0;font-size:16px}.dashboard-chart-panel p{color:var(--muted);margin:4px 0 0;font-size:13px;font-weight:700}.bar-chart{gap:14px;margin-top:18px;display:grid}.bar-row{grid-template-columns:110px minmax(120px,1fr) minmax(120px,auto);align-items:center;gap:12px;display:grid}.bar-row span,.bar-row strong{color:var(--ink);font-size:13px;font-weight:800}.bar-row strong{text-align:right}.bar-track{background:var(--purple-50);border-radius:999px;height:14px;overflow:hidden}.bar-fill{border-radius:inherit;background:#64748b;min-width:2px;height:100%}.bar-fill.primary{background:var(--purple-700)}.view-switch{align-items:center;gap:8px;display:flex}.view-switch button{min-height:36px;color:var(--purple-700);border:1px solid var(--line);box-shadow:none;background:#fff}.view-switch button.active{background:var(--purple-500);color:#fff;border-color:var(--purple-500)}.user-filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 12px;display:flex}.user-filter-bar label{color:var(--muted);align-items:center;gap:8px;font-size:13px;font-weight:800;display:inline-flex}.user-filter-bar input[type=checkbox]{width:16px;min-height:16px}.authorization-actions{flex-wrap:wrap;align-items:center;gap:10px;margin:0 0 14px;display:flex}.audit-filter-form{grid-template-columns:minmax(220px,2fr) minmax(140px,1fr) minmax(160px,1fr) minmax(160px,1fr) auto;align-items:end;gap:10px;margin-bottom:14px;display:grid!important}.audit-filter-form input,.audit-filter-form select{width:100%}.audit-cell-note{color:var(--muted);margin-top:3px;font-size:11px;font-weight:800;display:block}.audit-status{background:var(--purple-50);min-height:24px;color:var(--purple-800);border-radius:999px;align-items:center;padding:0 9px;font-size:12px;font-weight:900;display:inline-flex}.audit-status-success{color:var(--success);background:#ecfdf5}.audit-status-failure,.audit-status-denied{color:var(--danger);background:#fff1f0}.audit-details-row td{white-space:normal;background:#fcf8ff}.audit-details-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.audit-details-grid>div{min-width:0}.audit-details-grid strong{color:var(--purple-900);text-transform:uppercase;margin-bottom:6px;font-size:12px;display:block}.audit-details-grid pre{border:1px solid var(--line);max-height:260px;color:var(--ink);white-space:pre-wrap;word-break:break-word;background:#fff;border-radius:8px;margin:0;padding:10px;font-size:12px;line-height:1.45;overflow:auto}.authorization-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.authorization-group{border:1px solid var(--line);background:#fff;border-radius:8px;min-width:0;box-shadow:0 10px 28px #3710470f}.authorization-group h3{border-bottom:1px solid var(--line);color:var(--purple-900);text-transform:capitalize;margin:0;padding:12px 14px;font-size:14px}.permission-row{border-bottom:1px solid #f0e7f5;grid-template-columns:18px minmax(0,1fr);align-items:start;gap:10px;padding:10px 14px;display:grid}.permission-row:last-child{border-bottom:0}.permission-row input{width:16px;min-height:16px;margin-top:2px}.permission-row strong,.permission-row small{display:block}.permission-row strong{color:var(--ink);font-size:13px}.permission-row small{color:var(--muted);margin-top:3px;font-size:11px;font-weight:800}.permission-row.disabled{background:var(--purple-50);cursor:not-allowed}form{border:1px solid var(--line);background:#ffffffd1;border-radius:12px;padding:14px;box-shadow:0 10px 28px #3710470f}form>*{min-width:0}.form-actions{flex:1 0 100%;justify-content:flex-start;align-items:center;gap:8px;width:100%;margin-top:4px;display:flex}.form-actions button{min-width:112px}.master-detail-form{flex-direction:column}.form-section{border-top:1px solid var(--line);width:100%;padding:14px 0 0}.form-section:first-child{border-top:0;padding-top:0}.form-section h3{color:var(--purple-900);margin:0 0 12px;font-size:15px}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;display:grid}.form-field{gap:6px;min-width:0;display:grid}.form-field>span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.2}.form-field input,.form-field select{width:100%;min-width:0}.purchase-header-grid{gap:12px;display:grid}.purchase-header-row{align-items:start;gap:10px;display:grid}.purchase-header-row.row-main,.purchase-header-row.row-values,.purchase-header-row.row-extra{grid-template-columns:repeat(3,minmax(150px,1fr))}.note-attachment-control{grid-template-columns:minmax(0,1fr) 42px;gap:8px;display:grid}.icon-button.attach{cursor:pointer;color:var(--purple-700)}.icon-button.attach input{display:none}.attachment-summary{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:700;display:block;overflow:hidden}.attachment-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:12px;display:grid}.attachment-item{border:1px solid var(--line);background:#fff;border-radius:10px;grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;padding:8px;display:grid}.attachment-item img,.attachment-preview-placeholder,.attachment-item a{background:var(--purple-50);width:46px;height:46px;color:var(--purple-800);border-radius:8px;place-items:center;font-size:11px;font-weight:900;text-decoration:none;display:grid}.attachment-item img{object-fit:cover}.attachment-item span{min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:800;overflow:hidden}.attachment-item.pending{border-style:dashed}.attachment-actions{align-items:center;gap:6px;display:flex}.icon-button.download{color:var(--purple-700);text-decoration:none}.item-entry-grid{grid-template-columns:minmax(260px,2fr) minmax(120px,1fr) minmax(150px,1fr) minmax(120px,1fr) auto}.add-item-control{align-self:end}.add-item-button{background:var(--success);width:42px;min-width:42px;padding:0;font-size:24px;line-height:1}.add-item-button svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.add-item-button:hover{background:#046c4e}.item-edit-actions{margin-top:10px}@media (width<=920px){html,body,#root,.app-shell{width:100%;max-width:100vw;overflow-x:hidden}.app-shell{grid-template-rows:auto auto 1fr;grid-template-columns:1fr}.sidebar{border-radius:0 0 18px 18px;grid-area:2/1;gap:14px;width:100%;max-width:100vw;height:auto;padding:14px;position:relative;overflow:hidden;box-shadow:0 12px 28px #3710472e}.brand-block{min-height:42px}.brand-mark{border-radius:10px;width:38px;height:38px;font-size:13px}.brand-block strong{font-size:15px}.side-nav{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-direction:row;gap:8px;width:100%;min-width:0;max-width:100%;padding:0 0 4px;overflow-x:auto}.side-nav::-webkit-scrollbar{display:none}.side-nav button{white-space:nowrap;width:auto;min-width:max-content;min-height:40px;padding:0 10px}.nav-section{gap:6px;min-width:0;max-width:100%;padding-top:10px}.nav-section>span{padding:0 4px}.side-nav-sub button{padding-left:10px}.sidebar-footer{display:none}.topbar{flex-direction:column;grid-area:1/1;align-items:flex-start;width:100%;max-width:100vw;min-height:auto;padding:16px;position:relative}.topbar h1{font-size:22px}.topbar-actions{flex-wrap:wrap;justify-content:space-between;width:100%}.content-area{grid-area:3/1;width:100%;max-width:100vw;padding:18px;overflow-x:hidden}.toast-view{top:12px;right:14px}.content-area>div{width:100%;min-width:0}.module-heading{flex-direction:column;align-items:flex-start}form{grid-template-columns:repeat(auto-fit,minmax(min(220px,100%),1fr));width:100%;max-width:100%;gap:10px!important;margin-bottom:14px!important;display:grid!important}form input,form select,form button{min-width:0;width:100%!important}.form-actions{grid-column:1/-1;justify-content:flex-start}.form-actions button{min-width:112px;width:auto!important}.detail-grid,.item-entry-grid,.audit-filter-form,.audit-details-grid,.purchase-header-row,.purchase-header-row.row-main,.purchase-header-row.row-values,.purchase-header-row.row-extra,.date-range-picker{grid-template-columns:1fr}.date-route-line{display:none}.bar-row{grid-template-columns:1fr;gap:6px}.bar-row strong{text-align:left}.add-item-button{width:100%}input[type=date]{grid-column:1/-1;max-width:100%;font-size:16px;display:block;width:100%!important;min-width:0!important}table{white-space:nowrap;-webkit-overflow-scrolling:touch;border-radius:10px;min-width:0;max-width:100%;display:block;overflow-x:auto;width:100%!important}table thead,table tbody{width:100%;min-width:720px;display:table}}@media (width<=560px){body{background:#f7f4fb}.sidebar{border-radius:0 0 14px 14px}.side-nav{margin-left:-2px;margin-right:-2px}.side-nav button{gap:7px;min-height:38px;font-size:13px}.nav-icon{border-radius:7px;width:24px;height:24px;font-size:11px}.topbar{gap:12px;padding:14px}.topbar h1{font-size:20px}.user-menu{justify-content:flex-start;width:100%}.account-summary{display:none}.content-area{padding:14px}.content-area>div{width:100%;min-width:0}h2{margin-bottom:12px;font-size:20px}form{grid-template-columns:1fr;padding:12px}.form-actions{flex-direction:column;align-items:stretch}.form-actions button{width:100%!important}.summary-grid{grid-template-columns:1fr;gap:12px}.summary-card{min-height:106px;padding:14px}.summary-card h3{margin-bottom:10px;font-size:12px}.summary-card p{font-size:23px}.period-tabs{grid-template-columns:1fr 1fr;display:grid}.period-tabs button{width:100%;padding-left:8px;padding-right:8px}table thead,table tbody{min-width:620px}.pagination-controls{flex-direction:column;align-items:stretch}.pagination-controls>div{justify-content:space-between;width:100%}th,td{font-size:13px;padding:10px 12px!important}}@media (width<=380px){.brand-block span,.eyebrow,.user-menu span{display:none}.topbar h1{font-size:18px}.content-area{padding:10px}table thead,table tbody{min-width:540px}}
