:root{
  --ptr-bg:#f8f9ff;--ptr-surface:#ffffff;--ptr-surface-2:#f1f5ff;--ptr-surface-3:#e5eeff;--ptr-ink:#0b1c30;--ptr-muted:#64748b;--ptr-muted-2:#94a3b8;--ptr-line:#e2e8f0;--ptr-line-2:#cbd5e1;--ptr-primary:#3525cd;--ptr-primary-2:#4f46e5;--ptr-primary-soft:#e2dfff;--ptr-sidebar:#111827;--ptr-sidebar-2:#1f2937;--ptr-success:#00714d;--ptr-success-bg:#dcfce7;--ptr-warning:#92400e;--ptr-warning-bg:#fef3c7;--ptr-danger:#ba1a1a;--ptr-danger-bg:#fee2e2;--ptr-shadow:0 4px 6px -1px rgba(15,23,42,.06),0 2px 4px -2px rgba(15,23,42,.05);--ptr-shadow-lg:0 20px 25px -5px rgba(15,23,42,.12),0 8px 10px -6px rgba(15,23,42,.08);--ptr-radius:16px;--ptr-radius-sm:12px;--ptr-sidebar-w:264px
}
*{box-sizing:border-box}html{font-size:16px}.ptr-body{margin:0;background:var(--ptr-bg);color:var(--ptr-ink);font-family:"Nunito Sans",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased}.ptr-body a{color:var(--ptr-primary);text-decoration:none}.ptr-app{min-height:100vh}.ptr-loading{min-height:100vh;display:grid;place-items:center;color:var(--ptr-muted);font-weight:700}.ptr-login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 0%,#eef2ff 0,#f8f9ff 36%,#fff 100%)}.ptr-login-card{width:min(460px,100%);background:rgba(255,255,255,.92);border:1px solid rgba(226,232,240,.9);box-shadow:var(--ptr-shadow-lg);border-radius:24px;padding:32px}.ptr-login-icon{width:56px;height:56px;border-radius:18px;background:var(--ptr-primary);color:#fff;display:grid;place-items:center;font-size:28px;margin-bottom:18px}.ptr-login-card h1{font-size:28px;line-height:1.1;letter-spacing:-.03em;margin:0 0 8px}.ptr-login-card p{color:var(--ptr-muted);line-height:1.55;margin:0 0 22px}.ptr-login-card label{display:block;font-size:13px;font-weight:800;margin-bottom:7px;color:#334155}.ptr-login-card input[type=text],.ptr-login-card input[type=password]{width:100%;min-height:44px;border:1px solid var(--ptr-line);border-radius:12px;background:#fff;padding:10px 12px;font-size:15px;color:var(--ptr-ink);outline:0}.ptr-login-card input:focus{border-color:var(--ptr-primary);box-shadow:0 0 0 3px rgba(53,37,205,.12)}.ptr-login-card .button,.ptr-btn{appearance:none;border:0;border-radius:12px;background:var(--ptr-primary);color:#fff;min-height:40px;padding:10px 14px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.08);transition:.15s ease;text-decoration:none;white-space:nowrap}.ptr-login-card .button:hover,.ptr-btn:hover{background:var(--ptr-primary-2);transform:translateY(-1px);color:#fff}.ptr-btn.secondary{background:#fff;color:var(--ptr-ink);border:1px solid var(--ptr-line);box-shadow:none}.ptr-btn.secondary:hover{border-color:var(--ptr-primary);color:var(--ptr-primary);background:#fff}.ptr-btn.ghost{background:transparent;color:var(--ptr-muted);box-shadow:none}.ptr-btn.danger{background:var(--ptr-danger)}.ptr-btn.small{min-height:34px;padding:8px 10px;font-size:13px}.ptr-brand-credit{margin-top:22px;font-size:13px;color:var(--ptr-muted)}
.ptr-body button,.ptr-body input,.ptr-body select,.ptr-body textarea,.ptr-body table{font-family:"Nunito Sans",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.ptr-body strong,.ptr-body b{font-family:inherit}
.ptr-shell{min-height:100vh;display:grid;grid-template-columns:var(--ptr-sidebar-w) 1fr}.ptr-sidebar{height:100vh;position:sticky;top:0;background:linear-gradient(180deg,#111827,#172033);color:#fff;padding:18px 14px;display:flex;flex-direction:column;gap:14px}.ptr-logo{display:flex;gap:10px;align-items:center;padding:2px 6px 8px}.ptr-mark{width:38px;height:38px;border-radius:13px;background:#fff;color:var(--ptr-primary);display:grid;place-items:center;font-size:20px;font-weight:850}.ptr-logo strong{display:block;font-size:16px;line-height:1.15;font-weight:800;letter-spacing:-.02em}.ptr-logo span{display:block;font-size:12px;color:#cbd5e1;margin-top:2px;font-weight:650}.ptr-project-select{width:100%;min-height:42px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(255,255,255,.08);color:#fff;padding:9px 10px;outline:0}.ptr-project-select option{color:#111827}.ptr-nav{display:grid;gap:3px}.ptr-nav button{width:100%;border:0;background:transparent;color:#cbd5e1;border-radius:11px;padding:8px 10px;display:flex;align-items:center;gap:9px;font-weight:650;font-size:14px;line-height:1.25;text-align:left;cursor:pointer}.ptr-nav button:hover{background:rgba(255,255,255,.08);color:#fff}.ptr-nav button.active{background:#fff;color:#111827}.ptr-nav .ico{width:20px;display:inline-grid;place-items:center;font-size:15px}.ptr-user{margin-top:auto;padding:14px 6px 4px;border-top:1px solid rgba(255,255,255,.12);color:#cbd5e1;font-size:13px;display:grid;gap:10px}.ptr-user strong{display:block;color:#fff;margin-bottom:2px}.ptr-user a{display:inline-flex;align-items:center;justify-content:center;min-height:34px;border-radius:10px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff;font-weight:750;text-decoration:none}.ptr-main{min-width:0;padding:30px 32px 40px}.ptr-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.ptr-title h1{font-size:24px;line-height:1.18;letter-spacing:-.025em;margin:0 0 4px;font-weight:800}.ptr-title p{margin:0;color:var(--ptr-muted);font-size:14px}.ptr-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.ptr-card{background:var(--ptr-surface);border:1px solid var(--ptr-line);border-radius:var(--ptr-radius);box-shadow:var(--ptr-shadow);padding:20px;margin-bottom:18px}.ptr-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.ptr-card-head h2{font-size:18px;line-height:1.2;margin:0}.ptr-card-head p{margin:4px 0 0;color:var(--ptr-muted);font-size:14px}.ptr-grid{display:grid;gap:16px}.ptr-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.ptr-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.ptr-kpi{background:var(--ptr-surface);border:1px solid var(--ptr-line);border-radius:var(--ptr-radius);box-shadow:var(--ptr-shadow);padding:20px;min-height:132px;display:flex;flex-direction:column;justify-content:space-between}.ptr-kpi-top{display:flex;align-items:center;justify-content:space-between}.ptr-kpi span{display:block;color:var(--ptr-muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.ptr-kpi .kico{width:38px;height:38px;border-radius:12px;background:var(--ptr-primary-soft);color:var(--ptr-primary);display:grid;place-items:center;font-size:18px}.ptr-kpi strong{font-size:28px;line-height:1.05;letter-spacing:-.04em;font-variant-numeric:tabular-nums}.ptr-kpi small{color:var(--ptr-muted);font-weight:700}.ptr-muted{color:var(--ptr-muted)}.ptr-data{font-variant-numeric:tabular-nums}.ptr-section-title{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:0 0 14px}.ptr-section-title h2{font-size:18px;margin:0}.ptr-filterbar{display:grid;grid-template-columns:1.5fr repeat(4,minmax(130px,1fr));gap:10px;margin-bottom:14px}.ptr-input,.ptr-select,.ptr-textarea{width:100%;min-height:42px;border:1px solid var(--ptr-line);border-radius:12px;background:#fff;padding:10px 12px;font-size:14px;color:var(--ptr-ink);outline:0}.ptr-textarea{min-height:98px;resize:vertical}.ptr-input:focus,.ptr-select:focus,.ptr-textarea:focus{border-color:var(--ptr-primary);box-shadow:0 0 0 3px rgba(53,37,205,.11)}.ptr-table-wrap{overflow:auto;border:1px solid var(--ptr-line);border-radius:var(--ptr-radius);background:#fff}.ptr-table{width:100%;border-collapse:separate;border-spacing:0;min-width:880px}.ptr-table th,.ptr-table td{padding:14px 16px;border-bottom:1px solid var(--ptr-line);vertical-align:middle;text-align:left}.ptr-table th{background:#f8fafc;color:var(--ptr-muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:900}.ptr-table tr:last-child td{border-bottom:0}.ptr-table tbody tr{transition:.12s ease}.ptr-table tbody tr:hover{background:#f8fafc}.ptr-table .row-main{font-weight:900;color:var(--ptr-ink)}.ptr-table .row-sub{display:block;margin-top:3px;color:var(--ptr-muted);font-size:12px}.ptr-click-row{cursor:pointer}.ptr-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#eef2ff;color:var(--ptr-primary);font-size:12px;font-weight:900}.ptr-pill.ok{background:var(--ptr-success-bg);color:#166534}.ptr-pill.warn{background:var(--ptr-warning-bg);color:var(--ptr-warning)}.ptr-pill.danger{background:var(--ptr-danger-bg);color:var(--ptr-danger)}.ptr-icon-btn{border:1px solid var(--ptr-line);background:#fff;border-radius:10px;min-width:34px;min-height:34px;padding:7px 9px;cursor:pointer;font-weight:900;color:#334155}.ptr-icon-btn:hover{border-color:var(--ptr-primary);color:var(--ptr-primary)}.ptr-chart-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:16px}.ptr-chart-card{height:360px}.ptr-chart-card canvas{max-height:280px}.ptr-report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.ptr-progress{display:grid;gap:14px}.ptr-progress-row{display:grid;gap:7px}.ptr-progress-top{display:flex;justify-content:space-between;gap:10px;font-size:13px;font-weight:800}.ptr-bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.ptr-fill{height:100%;width:0;background:linear-gradient(90deg,var(--ptr-primary),#7c3aed);border-radius:999px}.ptr-empty{padding:36px;text-align:center;color:var(--ptr-muted)}.ptr-empty strong{display:block;color:var(--ptr-ink);font-size:18px;margin-bottom:6px}.ptr-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.ptr-field.full{grid-column:1/-1}.ptr-field label{display:block;font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#475569;margin:0 0 6px}.ptr-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.46);display:grid;place-items:center;padding:22px;z-index:99999}.ptr-modal{width:min(880px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:22px;box-shadow:var(--ptr-shadow-lg);padding:22px}.ptr-modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.ptr-modal-head h2{font-size:21px;margin:0;letter-spacing:-.02em}.ptr-close{border:0;background:#f1f5f9;color:#0f172a;border-radius:12px;width:38px;height:38px;font-size:23px;cursor:pointer}.ptr-drawer-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.28);z-index:99990;display:flex;justify-content:flex-end}.ptr-drawer{width:min(480px,100%);height:100%;overflow:auto;background:#fff;box-shadow:var(--ptr-shadow-lg);padding:24px}.ptr-drawer-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:18px;border-bottom:1px solid var(--ptr-line);margin-bottom:18px}.ptr-drawer-head h2{margin:0;font-size:22px;letter-spacing:-.03em}.ptr-detail-list{display:grid;gap:12px}.ptr-detail-item{padding:13px 0;border-bottom:1px solid var(--ptr-line)}.ptr-detail-item span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ptr-muted);font-weight:900;margin-bottom:5px}.ptr-detail-item strong,.ptr-detail-item div{font-size:15px;line-height:1.45}.ptr-file-list{display:grid;gap:8px;margin-top:10px}.ptr-file-list a{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--ptr-line);border-radius:12px;padding:10px 12px;background:#f8fafc;color:var(--ptr-ink);font-weight:800}.ptr-toast{position:fixed;right:20px;bottom:20px;background:#111827;color:#fff;padding:13px 16px;border-radius:14px;box-shadow:var(--ptr-shadow-lg);z-index:999999;font-weight:800}.ptr-tabs-inline{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.ptr-tab-chip{border:1px solid var(--ptr-line);background:#fff;color:var(--ptr-muted);border-radius:999px;padding:8px 12px;font-weight:900;cursor:pointer}.ptr-tab-chip.active{background:var(--ptr-primary);border-color:var(--ptr-primary);color:#fff}.ptr-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.ptr-mobile-menu{display:none}.ptr-brand-mini{display:none}
@media(max-width:1100px){.ptr-grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.ptr-chart-grid,.ptr-report-grid,.ptr-settings-grid{grid-template-columns:1fr}.ptr-filterbar{grid-template-columns:1fr 1fr}}
@media(max-width:860px){.ptr-shell{grid-template-columns:1fr}.ptr-sidebar{position:relative;height:auto;border-radius:0 0 22px 22px}.ptr-nav{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.ptr-main{padding:20px 16px 30px}.ptr-topbar{display:grid}.ptr-actions{justify-content:flex-start}.ptr-title h1{font-size:26px}.ptr-chart-card{height:320px}}
@media(max-width:620px){.ptr-login-card{padding:24px}.ptr-sidebar{padding:16px}.ptr-logo{padding-left:0}.ptr-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.ptr-nav button{font-size:13px;padding:10px}.ptr-grid.cols-4,.ptr-grid.cols-3,.ptr-filterbar,.ptr-form-grid{grid-template-columns:1fr}.ptr-kpi{min-height:116px}.ptr-kpi strong{font-size:24px}.ptr-card{padding:16px}.ptr-btn{width:100%}.ptr-actions{width:100%}.ptr-table{min-width:760px}.ptr-modal{padding:18px;border-radius:18px}.ptr-drawer{padding:18px}.ptr-chart-card{height:300px}}

/* v0.2.2 UI polish */
.ptr-main{background:linear-gradient(180deg,#f8f9ff 0,#f4f7fb 100%)}
.ptr-sidebar{box-shadow:12px 0 30px rgba(15,23,42,.08)}
.ptr-logo{margin-bottom:2px}.ptr-logo strong{letter-spacing:-.02em}.ptr-logo span{line-height:1.25}.ptr-project-select{box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.ptr-nav button{letter-spacing:-.01em}.ptr-nav button.active{box-shadow:0 10px 24px rgba(0,0,0,.12)}
.ptr-topbar{padding-bottom:4px}.ptr-title h1{font-weight:900}.ptr-title p{font-weight:650}.ptr-actions .ptr-btn.secondary{background:rgba(255,255,255,.9)}
.ptr-hero{display:grid;grid-template-columns:1fr 260px;gap:24px;align-items:stretch;background:radial-gradient(circle at 15% 0%,rgba(79,70,229,.23),transparent 34%),linear-gradient(135deg,#111827,#202a44 52%,#3525cd);border-radius:24px;color:#fff;padding:28px;margin-bottom:18px;box-shadow:0 24px 50px rgba(17,24,39,.16);overflow:hidden;position:relative}.ptr-hero:after{content:"";position:absolute;right:-120px;top:-130px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.08)}.ptr-hero-copy,.ptr-hero-meter{position:relative;z-index:1}.ptr-eyebrow{display:inline-flex;align-items:center;gap:7px;color:#64748b;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.09em;margin-bottom:7px}.ptr-hero .ptr-eyebrow,.ptr-report-hero .ptr-eyebrow{color:#c7d2fe}.ptr-hero h2{font-size:34px;line-height:1.06;letter-spacing:-.045em;margin:0 0 10px}.ptr-hero p{max-width:620px;margin:0;color:#dbeafe;line-height:1.6;font-weight:600}.ptr-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.ptr-hero-actions .ptr-btn.secondary{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.12);color:#fff}.ptr-hero-meter{display:grid;place-items:center;text-align:center;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.09);border-radius:22px;padding:20px}.ptr-hero-meter strong{display:block;margin-top:12px;font-size:15px}.ptr-hero-meter small{display:block;margin-top:4px;color:#dbeafe;font-weight:750}.ptr-ring{--value:0;width:132px;height:132px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(#fff calc(var(--value)*1%),rgba(255,255,255,.18) 0);position:relative}.ptr-ring:before{content:"";position:absolute;inset:12px;background:#172033;border-radius:50%}.ptr-ring span{position:relative;font-size:25px;font-weight:950;letter-spacing:-.04em}.ptr-kpi-row{margin-bottom:18px}.ptr-kpi{position:relative;overflow:hidden}.ptr-kpi:after{content:"";position:absolute;right:-24px;bottom:-28px;width:86px;height:86px;border-radius:50%;background:var(--ptr-primary-soft);opacity:.58}.ptr-kpi-top,.ptr-kpi strong,.ptr-kpi small{position:relative;z-index:1}.ptr-soft-label{display:inline-flex;align-items:center;min-height:28px;padding:6px 10px;border-radius:999px;background:#eef2ff;color:var(--ptr-primary);font-size:12px;font-weight:950}.ptr-mini-list{display:grid;gap:10px}.ptr-mini-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left;border:1px solid var(--ptr-line);background:#fff;border-radius:14px;padding:13px 14px;cursor:pointer}.ptr-mini-row:hover{border-color:var(--ptr-primary);box-shadow:0 10px 22px rgba(53,37,205,.08);transform:translateY(-1px)}.ptr-mini-row strong{display:block;color:var(--ptr-ink);font-size:14px}.ptr-mini-row small{display:block;color:var(--ptr-muted);margin-top:3px}.ptr-mini-row b{white-space:nowrap;font-variant-numeric:tabular-nums}.ptr-empty-compact{padding:24px!important}.ptr-expense-card{padding:0;overflow:hidden}.ptr-expense-head{padding:22px 22px 0;margin-bottom:16px}.ptr-filterbar-polished{padding:0 22px 18px;margin-bottom:0}.ptr-search-wrap{position:relative}.ptr-search-wrap span{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-weight:900;color:var(--ptr-muted)}.ptr-search-wrap .ptr-input{padding-left:34px}.ptr-expense-table-wrap{border-left:0;border-right:0;border-bottom:0;border-radius:0}.ptr-expense-table th{background:#fbfcff}.ptr-expense-table .ptr-click-row td:first-child{min-width:280px}.ptr-report-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#111827,#27334d);color:#fff;border-radius:22px;padding:24px;margin-bottom:18px;box-shadow:var(--ptr-shadow)}.ptr-report-hero h2{margin:0 0 6px;font-size:28px;letter-spacing:-.04em}.ptr-report-hero p{margin:0;color:#dbeafe;font-weight:650}.ptr-matrix-card .ptr-table{min-width:640px}.ptr-detail-item div{word-break:break-word}.ptr-modal{border:1px solid rgba(226,232,240,.92)}.ptr-modal-head{position:sticky;top:-22px;background:#fff;z-index:1;padding-top:2px}.ptr-toast{animation:ptrToastIn .18s ease-out}@keyframes ptrToastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:980px){.ptr-hero{grid-template-columns:1fr}.ptr-hero-meter{place-items:start;text-align:left}.ptr-ring{width:112px;height:112px}.ptr-report-hero{display:grid}.ptr-filterbar-polished{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.ptr-hero{padding:22px;border-radius:20px}.ptr-hero h2{font-size:27px}.ptr-hero-actions .ptr-btn{width:100%}.ptr-report-hero{padding:20px;border-radius:18px}.ptr-report-hero .ptr-btn{width:100%}.ptr-filterbar-polished{grid-template-columns:1fr;padding:0 16px 16px}.ptr-expense-head{padding:18px 16px 0}.ptr-mini-row{align-items:flex-start;display:grid}.ptr-mini-row b{justify-self:start}}

/* v0.2.3 extra UI polish */
.ptr-sidebar-label{display:block;margin:14px 2px 7px;color:#94a3b8;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.11em}.ptr-sidebar-divider{height:1px;background:rgba(148,163,184,.18);margin:14px 0 12px}.ptr-nav{gap:7px}.ptr-nav button{position:relative;overflow:hidden}.ptr-nav button:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:999px;background:transparent}.ptr-nav button.active:before{background:#fff}.ptr-nav .ico{width:24px;height:24px;display:inline-grid;place-items:center;border-radius:9px;background:rgba(255,255,255,.06);font-size:14px}.ptr-nav button.active .ico{background:rgba(255,255,255,.18)}.ptr-user{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.045);border-radius:18px;padding:14px}.ptr-user a{display:inline-flex;margin-top:10px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.08);text-decoration:none}.ptr-user a:hover{background:rgba(255,255,255,.14)}.ptr-topbar{position:sticky;top:0;z-index:20;margin:-18px -26px 18px;padding:18px 26px 10px;background:linear-gradient(180deg,rgba(248,249,255,.98),rgba(248,249,255,.86));backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.6)}.ptr-title h1{letter-spacing:-.045em}.ptr-title p:before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;margin-right:8px;vertical-align:middle}.ptr-btn.ghost{background:#fff;color:#475569;border-color:var(--ptr-line);box-shadow:none}.ptr-btn.ghost:hover{border-color:var(--ptr-primary);color:var(--ptr-primary)}.ptr-expense-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:0 22px 18px}.ptr-mini-stat{border:1px solid var(--ptr-line);border-radius:16px;padding:14px;background:linear-gradient(180deg,#fff,#fbfdff)}.ptr-mini-stat span{display:block;color:var(--ptr-muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.ptr-mini-stat strong{display:block;margin-top:6px;color:var(--ptr-ink);font-size:20px;letter-spacing:-.035em;font-variant-numeric:tabular-nums}.ptr-mini-stat small{display:block;margin-top:2px;color:#64748b;font-weight:700}.ptr-reset-filter{min-height:42px;white-space:nowrap}.ptr-click-row{transition:background .15s ease,transform .15s ease}.ptr-click-row:hover{background:#f8f9ff;transform:translateX(2px)}.ptr-expense-table td,.ptr-expense-table th{padding-top:15px;padding-bottom:15px}.ptr-pill{box-shadow:inset 0 0 0 1px rgba(255,255,255,.38)}.ptr-pill.warn{background:#fff7ed;color:#c2410c}.ptr-pill.ok{background:#ecfdf5;color:#047857}.ptr-modal{padding:0;overflow:hidden}.ptr-modal-head{top:0;padding:20px 22px;margin:0;border-bottom:1px solid var(--ptr-line);background:#fff}.ptr-modal-head .ptr-eyebrow{margin-bottom:4px}.ptr-modal-body{padding:20px 22px 0}.ptr-modal-actions{padding:18px 22px 22px;margin-top:0;background:#f8fafc;border-top:1px solid var(--ptr-line);justify-content:flex-end}.ptr-field label{color:#334155}.ptr-input:focus,.ptr-select:focus,.ptr-textarea:focus{outline:0;border-color:var(--ptr-primary);box-shadow:0 0 0 4px rgba(53,37,205,.10)}.ptr-drawer{border-left:1px solid rgba(226,232,240,.75)}.ptr-drawer-head{position:sticky;top:0;background:#fff;z-index:1;padding-top:4px}.ptr-detail-item{border-bottom:1px dashed #e2e8f0}.ptr-file-list a:hover{border-color:var(--ptr-primary);background:#eef2ff}.ptr-tabs-inline{position:sticky;top:74px;z-index:12;background:rgba(248,249,255,.86);backdrop-filter:blur(10px);padding:8px 0}.ptr-tab-chip{transition:all .15s ease}.ptr-tab-chip:hover{border-color:var(--ptr-primary);color:var(--ptr-primary)}.ptr-settings-grid>.ptr-card{box-shadow:none;background:#fbfdff}.ptr-table-wrap{box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
@media(max-width:1100px){.ptr-expense-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.ptr-topbar{margin:-16px -18px 16px;padding:16px 18px 10px}}
@media(max-width:860px){.ptr-topbar{position:relative;top:auto}.ptr-tabs-inline{position:relative;top:auto}.ptr-sidebar-label,.ptr-sidebar-divider{display:none}.ptr-user{margin-top:10px}.ptr-expense-strip{padding:0 16px 16px}}
@media(max-width:620px){.ptr-expense-strip{grid-template-columns:1fr}.ptr-mini-stat strong{font-size:18px}.ptr-modal-actions{display:grid}.ptr-topbar{margin:-10px -16px 16px;padding:10px 16px}.ptr-title p:before{display:none}}


/* v0.2.4 onboarding, reports and settings polish */
.ptr-setup-card{display:grid;grid-template-columns:1fr minmax(280px,520px);gap:18px;align-items:start;background:linear-gradient(135deg,#fff,#f6f7ff);border:1px solid var(--ptr-line);border-radius:22px;padding:22px;margin:0 0 18px;box-shadow:var(--ptr-shadow)}
.ptr-setup-card h2{margin:0 0 6px;font-size:22px;letter-spacing:-.035em}.ptr-setup-card p{margin:0;color:var(--ptr-muted);font-weight:650;line-height:1.55}.ptr-setup-steps{display:grid;gap:8px}.ptr-setup-step{display:flex;gap:10px;align-items:flex-start;border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:10px 12px}.ptr-setup-step>span{width:24px;height:24px;border-radius:999px;background:#eef2ff;color:var(--ptr-primary);display:grid;place-items:center;font-weight:950;flex:0 0 auto}.ptr-setup-step.done>span{background:#ecfdf5;color:#047857}.ptr-setup-step strong{display:block;font-size:13px;color:var(--ptr-ink)}.ptr-setup-step small{display:block;color:var(--ptr-muted);font-weight:650;margin-top:2px}.ptr-setup-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.ptr-settings-hero{display:grid;grid-template-columns:1fr minmax(320px,520px);gap:18px;align-items:center;background:radial-gradient(circle at 0 0,rgba(53,37,205,.12),transparent 35%),#fff;border:1px solid var(--ptr-line);border-radius:22px;padding:22px;margin-bottom:12px;box-shadow:var(--ptr-shadow)}.ptr-settings-hero h2{font-size:26px;letter-spacing:-.04em;margin:0 0 6px}.ptr-settings-hero p{margin:0;color:var(--ptr-muted);font-weight:650;line-height:1.55}.ptr-settings-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.ptr-settings-stats .ptr-mini-stat{margin:0;background:#fff}.ptr-settings-content{margin-top:10px}.ptr-management-card{overflow:hidden}.ptr-count-badge{display:inline-flex;margin-bottom:7px;padding:5px 9px;border-radius:999px;background:#eef2ff;color:var(--ptr-primary);font-size:12px;font-weight:950}.ptr-empty-action p{margin:0 0 16px;color:var(--ptr-muted)}.ptr-report-hero .ptr-actions{width:auto}.ptr-report-hero .ptr-btn.secondary{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.24)}.ptr-report-hero .ptr-btn.secondary:hover{background:rgba(255,255,255,.18);color:#fff}.ptr-empty-action .ptr-btn{margin-top:2px}
@media print{.ptr-sidebar,.ptr-topbar,.ptr-report-hero .ptr-actions,.ptr-tabs-inline,.ptr-actions .ptr-btn,.ptr-icon-btn{display:none!important}.ptr-shell{display:block}.ptr-main{padding:0;background:#fff}.ptr-card,.ptr-kpi,.ptr-report-hero{box-shadow:none!important;break-inside:avoid}.ptr-report-hero{color:#111827;background:#fff;border:1px solid #e2e8f0}.ptr-report-hero p{color:#475569}.ptr-chart-card{height:310px}.ptr-table{font-size:12px}.ptr-body{background:#fff}}
@media(max-width:980px){.ptr-setup-card,.ptr-settings-hero{grid-template-columns:1fr}.ptr-settings-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.ptr-setup-actions{justify-content:flex-start}}
@media(max-width:620px){.ptr-settings-stats{grid-template-columns:1fr}.ptr-setup-card,.ptr-settings-hero{padding:18px;border-radius:18px}.ptr-setup-actions .ptr-btn{width:100%}.ptr-report-hero .ptr-actions{width:100%}}


/* v0.2.5 final UX polish: mobile shell, loading, toasts and print metadata */
.ptr-mobile-bar{display:none}.ptr-sidebar-overlay{display:none}.ptr-loading-rich{background:radial-gradient(circle at 15% 0%,#eef2ff 0,#f8f9ff 36%,#fff 100%);text-align:center}.ptr-loading-rich>div{width:min(360px,calc(100% - 40px));background:rgba(255,255,255,.78);border:1px solid rgba(226,232,240,.86);border-radius:24px;box-shadow:var(--ptr-shadow-lg);padding:28px}.ptr-loading-rich strong{display:block;font-size:20px;color:var(--ptr-ink);letter-spacing:-.03em}.ptr-loading-rich span{display:block;margin-top:6px;color:var(--ptr-muted)}.ptr-loader-logo{width:56px;height:56px;margin:0 auto 16px;border-radius:18px;background:var(--ptr-primary);color:#fff;display:grid;place-items:center;font-size:27px;box-shadow:0 14px 34px rgba(53,37,205,.22)}.ptr-skeleton-line{height:10px;border-radius:999px;margin:20px auto 0;background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:220% 100%;animation:ptrShimmer 1.4s infinite;width:88%}.ptr-skeleton-line.short{width:58%;margin-top:9px}@keyframes ptrShimmer{0%{background-position:220% 0}100%{background-position:-220% 0}}.ptr-toast-stack{position:fixed;right:20px;bottom:20px;z-index:100000;display:grid;gap:10px;width:min(360px,calc(100vw - 40px))}.ptr-toast{position:relative;right:auto;bottom:auto;display:flex;align-items:flex-start;gap:10px;background:#0f172a;color:#fff;border-radius:16px;padding:13px 14px;box-shadow:var(--ptr-shadow-lg);font-size:14px}.ptr-toast span{width:24px;height:24px;border-radius:999px;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:0 0 auto}.ptr-toast strong{font-weight:800;line-height:1.35}.ptr-toast.error{background:#7f1d1d}.ptr-toast.leaving{opacity:0;transform:translateY(8px);transition:.2s ease}.ptr-btn:disabled{opacity:.72;cursor:not-allowed;transform:none!important}.ptr-spinner{width:15px;height:15px;border-radius:50%;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;display:inline-block;animation:ptrSpin .75s linear infinite}@keyframes ptrSpin{to{transform:rotate(360deg)}}.ptr-report-meta{display:block;margin-top:8px;color:#cbd5e1;font-weight:750}.ptr-mobile-toggle{border:1px solid var(--ptr-line);background:#fff;border-radius:14px;min-width:42px;height:42px;font-weight:950;color:var(--ptr-ink);box-shadow:var(--ptr-shadow)}.ptr-mobile-brand strong{display:block;letter-spacing:-.03em}.ptr-mobile-brand span{display:block;color:var(--ptr-muted);font-size:12px;font-weight:750;margin-top:2px}.ptr-field .ptr-input[type=number]{font-variant-numeric:tabular-nums}.ptr-empty{background:linear-gradient(180deg,#fff,#fbfdff)}.ptr-table td:last-child{text-align:right}.ptr-table th:last-child{text-align:right}.ptr-file-list a{transition:.15s ease}.ptr-drawer-backdrop,.ptr-modal-backdrop{animation:ptrFade .12s ease-out}.ptr-drawer,.ptr-modal{animation:ptrPanelIn .16s ease-out}@keyframes ptrFade{from{opacity:0}to{opacity:1}}@keyframes ptrPanelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:860px){.ptr-mobile-bar{display:flex;position:sticky;top:0;z-index:60;align-items:center;gap:12px;background:rgba(248,249,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.8);padding:10px 14px}.ptr-shell{display:block;min-height:calc(100vh - 63px)}.ptr-sidebar{position:fixed;left:0;top:0;bottom:0;width:min(302px,86vw);height:100vh;z-index:80;transform:translateX(-105%);transition:transform .2s ease;border-radius:0 22px 22px 0}.ptr-shell.sidebar-open .ptr-sidebar{transform:translateX(0)}.ptr-shell.sidebar-open .ptr-sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:70}.ptr-nav{grid-template-columns:1fr}.ptr-user{margin-top:auto}.ptr-main{padding-top:18px}.ptr-topbar{margin-top:0}.ptr-toast-stack{left:14px;right:14px;bottom:14px;width:auto}}
@media(max-width:620px){.ptr-mobile-brand strong{font-size:15px}.ptr-mobile-brand span{font-size:11px}.ptr-toast{border-radius:14px}.ptr-report-meta{color:#64748b}.ptr-drawer,.ptr-modal{animation:none}.ptr-modal-backdrop{padding:12px}.ptr-modal{max-height:94vh}.ptr-table td:last-child,.ptr-table th:last-child{text-align:left}}
@media print{.ptr-mobile-bar,.ptr-toast-stack,.ptr-report-meta{display:none!important}.ptr-report-hero:after{content:"Troškovi - Nanovo rođeni";display:block;margin-top:10px;color:#64748b;font-size:12px;font-weight:700}}

/* v0.2.7 sidebar and typography polish */
.ptr-logo span,.ptr-mobile-brand span{font-weight:650}
.ptr-user-email{display:block;color:#e5e7eb;font-weight:650;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ptr-logout-btn:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.24)}
.ptr-sidebar-label{opacity:.88}
.ptr-project-select{min-height:39px;padding:8px 10px;font-size:13px;font-weight:650}
.ptr-nav button.active{font-weight:750}
.ptr-nav button:hover{transform:none}
.ptr-title h1{max-width:680px}
.ptr-card-head h2,.ptr-section-title h2{font-weight:800;letter-spacing:-.015em}

/* v0.2.7 final sidebar overrides */
.ptr-sidebar{padding:18px 14px!important;gap:14px!important}
.ptr-logo{padding:2px 6px 8px!important;gap:10px!important}
.ptr-logo strong{font-size:16px!important;font-weight:800!important;letter-spacing:-.02em!important}
.ptr-logo span{font-size:12px!important;font-weight:650!important}
.ptr-sidebar-label{font-size:10px!important;font-weight:750!important;letter-spacing:.08em!important;margin:8px 6px -2px!important}
.ptr-sidebar-divider{margin:8px 6px 8px!important}
.ptr-nav{gap:3px!important}
.ptr-nav button{padding:8px 10px!important;gap:9px!important;font-size:14px!important;font-weight:650!important;line-height:1.25!important;border-radius:11px!important}
.ptr-nav button.active{font-weight:750!important}
.ptr-nav .ico{width:20px!important;height:20px!important;font-size:14px!important;border-radius:8px!important}
.ptr-user{padding:12px!important;border-radius:15px!important;gap:9px!important}
.ptr-user a{margin-top:0!important;min-height:34px!important;padding:7px 10px!important;border-radius:10px!important;font-size:13px!important}
.ptr-title h1{font-size:24px!important;line-height:1.18!important;letter-spacing:-.025em!important;font-weight:800!important}
.ptr-title p{font-size:14px!important}
.ptr-topbar{padding-top:14px!important;padding-bottom:9px!important;margin-bottom:16px!important}


/* v0.2.8 logo and sidebar polish */
.ptr-logo{align-items:center!important;gap:12px!important;padding:4px 6px 10px!important}
.ptr-logo-media{width:84px;min-width:84px;height:64px;border-radius:16px;background:#fff;display:grid;place-items:center;padding:8px;box-shadow:0 12px 28px rgba(15,23,42,.18);overflow:hidden}
.ptr-logo-media img{display:block;max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain}
.ptr-logo-copy{min-width:0}
.ptr-logo strong{font-size:16px!important;font-weight:780!important;letter-spacing:-.02em!important}
.ptr-logo span{font-size:12px!important;font-weight:600!important;color:#cbd5e1!important}
.ptr-nav{gap:4px!important}
.ptr-nav button{padding:11px 13px!important;gap:11px!important;font-size:15px!important;font-weight:600!important;line-height:1.35!important;border-radius:12px!important}
.ptr-nav button.active{font-weight:700!important}
.ptr-nav .ico{width:22px!important;height:22px!important;font-size:15px!important;border-radius:8px!important}
.ptr-nav button:before{top:10px!important;bottom:10px!important}
.ptr-user{padding:12px 13px!important;border-radius:16px!important}
@media(max-width:860px){.ptr-logo-media{width:78px;min-width:78px;height:58px}.ptr-nav button{padding:12px 13px!important;font-size:15px!important}}
@media(max-width:620px){.ptr-logo{gap:10px!important}.ptr-logo-media{width:72px;min-width:72px;height:54px;padding:7px}.ptr-nav button{padding:11px 12px!important;font-size:14px!important}}

/* v0.2.9 typography system polish
   Practical SaaS scale: body 14/20, table 14/20, section titles 18/24,
   page title 22/28, navigation 15/20. Avoid heavy 900 weights except rare KPI numbers. */
.ptr-app,
.ptr-app *{font-family:"Nunito Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important}
.ptr-body{font-family:"Nunito Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;font-size:14px!important;line-height:1.45!important;font-weight:400!important;color:var(--ptr-ink)!important;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.ptr-main{font-size:14px!important;line-height:1.45!important}

/* Topbar / page headings */
.ptr-title h1{font-size:22px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:-.025em!important;margin-bottom:3px!important}
.ptr-title p{font-size:13px!important;line-height:1.4!important;font-weight:500!important;color:#64748b!important}
.ptr-card-head h2,.ptr-section-title h2{font-size:18px!important;line-height:1.3!important;font-weight:700!important;letter-spacing:-.015em!important}
.ptr-card-head p{font-size:13px!important;line-height:1.45!important;font-weight:400!important}
.ptr-eyebrow{font-size:11px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.08em!important}

/* Sidebar */
.ptr-logo strong{font-size:16px!important;line-height:1.18!important;font-weight:700!important;letter-spacing:-.015em!important}
.ptr-logo span,.ptr-mobile-brand span{font-size:12px!important;line-height:1.25!important;font-weight:500!important}
.ptr-sidebar-label{font-size:10.5px!important;line-height:1.2!important;font-weight:700!important;letter-spacing:.09em!important}
.ptr-nav{gap:5px!important}
.ptr-nav button{min-height:44px!important;padding:11px 13px!important;font-size:15px!important;line-height:1.35!important;font-weight:500!important;letter-spacing:0!important}
.ptr-nav button.active{font-weight:650!important}
.ptr-nav .ico{font-size:15px!important;font-weight:500!important}
.ptr-project-select{font-size:14px!important;line-height:1.35!important;font-weight:500!important}
.ptr-user-email{font-size:13px!important;line-height:1.35!important;font-weight:500!important}
.ptr-logout-btn,.ptr-user a{font-size:13px!important;line-height:1.35!important;font-weight:600!important}

/* Buttons, filters and form controls */
.ptr-btn,.ptr-icon-btn,.ptr-tab-chip{font-size:14px!important;line-height:1.35!important;font-weight:650!important;letter-spacing:0!important}
.ptr-input,.ptr-select,.ptr-textarea{font-size:14px!important;line-height:1.4!important;font-weight:400!important}
.ptr-field label{font-size:11.5px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.055em!important}
.ptr-filterbar .ptr-input,.ptr-filterbar .ptr-select{font-size:14px!important;font-weight:400!important}

/* Expenses page / table */
.ptr-table{font-size:14px!important;line-height:1.45!important}
.ptr-table th{font-size:11px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.055em!important;color:#64748b!important}
.ptr-table td{font-size:14px!important;line-height:1.45!important;font-weight:400!important;color:#334155!important}
.ptr-table .row-main{font-size:14px!important;line-height:1.35!important;font-weight:650!important;color:#0f172a!important;letter-spacing:0!important}
.ptr-table .row-sub{font-size:12.5px!important;line-height:1.35!important;font-weight:400!important;color:#64748b!important}
.ptr-pill{font-size:12px!important;line-height:1.2!important;font-weight:650!important;letter-spacing:0!important}
.ptr-mini-stat span{font-size:11px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.055em!important}
.ptr-mini-stat strong{font-size:19px!important;line-height:1.2!important;font-weight:700!important;letter-spacing:-.02em!important}
.ptr-mini-stat small{font-size:12px!important;line-height:1.35!important;font-weight:500!important}

/* KPI and cards */
.ptr-kpi span{font-size:11.5px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.055em!important}
.ptr-kpi strong{font-size:26px!important;line-height:1.1!important;font-weight:750!important;letter-spacing:-.035em!important}
.ptr-kpi small{font-size:13px!important;line-height:1.35!important;font-weight:500!important}
.ptr-card,.ptr-empty,.ptr-detail-item strong,.ptr-detail-item div{font-size:14px!important;line-height:1.45!important;font-weight:400!important}
.ptr-empty strong{font-size:17px!important;font-weight:700!important;line-height:1.3!important}

/* Modal / drawer typography */
.ptr-modal-head h2,.ptr-drawer-head h2{font-size:20px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:-.02em!important}
.ptr-detail-item span{font-size:11px!important;line-height:1.25!important;font-weight:700!important;letter-spacing:.06em!important}
.ptr-file-list a{font-size:14px!important;line-height:1.35!important;font-weight:600!important}
.ptr-toast{font-size:14px!important;line-height:1.35!important;font-weight:600!important}

/* Responsive typography */
@media(max-width:860px){
  .ptr-title h1{font-size:21px!important}
  .ptr-nav button{font-size:15px!important;min-height:46px!important}
}
@media(max-width:620px){
  .ptr-body,.ptr-main{font-size:14px!important}
  .ptr-title h1{font-size:20px!important}
  .ptr-card-head h2,.ptr-section-title h2{font-size:17px!important}
  .ptr-kpi strong{font-size:24px!important}
  .ptr-mini-stat strong{font-size:18px!important}
  .ptr-table td{font-size:13.5px!important}
}


/* v0.3.1 search UX: manual apply instead of rerender on every character */
.ptr-search-wrap{display:flex;align-items:center;gap:8px}
.ptr-search-wrap>span{left:12px!important}
.ptr-search-wrap .ptr-input{min-width:0;flex:1}
.ptr-search-btn{min-height:42px;border:1px solid var(--ptr-line);border-radius:12px;background:#fff;color:#334155;padding:0 13px;font-family:inherit;font-size:14px;font-weight:650;cursor:pointer;white-space:nowrap}
.ptr-search-btn:hover{border-color:var(--ptr-primary);color:var(--ptr-primary);background:#f8f9ff}
@media(max-width:620px){.ptr-search-wrap{display:grid;grid-template-columns:1fr}.ptr-search-wrap>span{top:21px!important}.ptr-search-btn{width:100%}}

/* v0.3.2 expenses filter and attachment UX */
.ptr-filterbar-polished{grid-template-columns:minmax(280px,1.6fr) repeat(4,minmax(128px,1fr)) 46px!important;align-items:center!important}
.ptr-reset-filter{width:42px!important;height:42px!important;min-height:42px!important;border:0!important;border-radius:13px!important;background:#111827!important;color:#fff!important;display:inline-grid!important;place-items:center!important;font-size:22px!important;line-height:1!important;font-weight:600!important;cursor:pointer!important;box-shadow:0 10px 20px rgba(15,23,42,.16)!important;transition:transform .14s ease,background .14s ease,box-shadow .14s ease!important;padding:0!important}
.ptr-reset-filter:hover{background:#1f2a44!important;transform:translateY(-1px);box-shadow:0 14px 26px rgba(15,23,42,.22)!important}
.ptr-file-picker{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:54px;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:12px 14px;cursor:pointer;transition:.15s ease;color:#334155}
.ptr-file-picker:hover{border-color:var(--ptr-primary);background:#eef2ff;color:var(--ptr-primary)}
.ptr-file-picker input{display:none}
.ptr-file-picker span{font-size:14px;font-weight:700;letter-spacing:0;text-transform:none;color:inherit;margin:0}
.ptr-file-picker small{display:block;color:#64748b;font-size:12px;font-weight:500;text-align:right;line-height:1.3}
@media(max-width:1180px){.ptr-filterbar-polished{grid-template-columns:1fr 1fr 1fr!important}.ptr-reset-filter{width:100%!important}}
@media(max-width:720px){.ptr-filterbar-polished{grid-template-columns:1fr!important}.ptr-reset-filter{width:100%!important}.ptr-file-picker{display:grid}.ptr-file-picker small{text-align:left}}


/* v0.3.3 expenses layout: filters first, stats second, pagination and footer export */
.ptr-expense-head{padding-bottom:0!important;margin-bottom:14px!important}
.ptr-expense-head .ptr-btn{display:none!important}
.ptr-filterbar-polished{padding-bottom:14px!important}
.ptr-expense-strip{padding-top:0!important;padding-bottom:18px!important}
.ptr-expense-strip-5{grid-template-columns:repeat(5,minmax(0,1fr))!important}
.ptr-expense-export{display:flex;justify-content:center;padding:18px 22px 22px;border-top:1px solid var(--ptr-line);background:#fbfdff}
.ptr-expense-export .ptr-btn{min-width:180px}
.ptr-pagination{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 22px;border-top:1px solid var(--ptr-line);background:#fff}
.ptr-pagination-left,.ptr-pagination-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:#64748b;font-size:13px;font-weight:650}
.ptr-pagination-left label{display:flex;align-items:center;gap:8px}
.ptr-pagination .ptr-select.small{width:auto;min-height:36px;padding:7px 32px 7px 10px;border-radius:10px;font-size:13px}
.ptr-pagination .ptr-icon-btn:disabled{opacity:.42;cursor:not-allowed;background:#f8fafc;color:#94a3b8}
@media(max-width:1180px){.ptr-expense-strip-5{grid-template-columns:repeat(3,minmax(0,1fr))!important}}
@media(max-width:760px){.ptr-expense-strip-5{grid-template-columns:1fr!important}.ptr-pagination{display:grid}.ptr-pagination-actions{justify-content:space-between}.ptr-expense-export{padding:16px}.ptr-expense-export .ptr-btn{width:100%}}

/* v0.3.4 expense screen and form polish */
.ptr-expense-strip .ptr-mini-stat{
  border-color:rgba(255,255,255,.12)!important;
  background:radial-gradient(circle at 0 0,rgba(79,70,229,.22),transparent 34%),linear-gradient(135deg,#111827,#202a44 58%,#2b236f)!important;
  color:#fff!important;
  box-shadow:0 16px 34px rgba(17,24,39,.14)!important;
}
.ptr-expense-strip .ptr-mini-stat span{color:#c7d2fe!important;font-weight:700!important}
.ptr-expense-strip .ptr-mini-stat strong{color:#fff!important}
.ptr-expense-strip .ptr-mini-stat small{color:#dbeafe!important}
.ptr-expense-export .ptr-btn.secondary{
  background:linear-gradient(135deg,#111827,#202a44 58%,#3525cd)!important;
  border-color:rgba(255,255,255,.12)!important;
  color:#fff!important;
  box-shadow:0 14px 28px rgba(17,24,39,.18)!important;
}
.ptr-expense-export .ptr-btn.secondary:hover{background:linear-gradient(135deg,#0f172a,#1f2a44 58%,#2f22b8)!important;color:#fff!important;transform:translateY(-1px)}
.ptr-date-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.ptr-date-today{min-height:42px;border:1px solid var(--ptr-line);background:#f8fafc;color:#334155;border-radius:12px;padding:9px 12px;font-weight:700;cursor:pointer;transition:.15s ease}
.ptr-date-today:hover{border-color:var(--ptr-primary);color:var(--ptr-primary);background:#eef2ff}
.ptr-field-hint{display:block;margin-top:6px;color:#64748b;font-size:12px;font-weight:500;line-height:1.35}
.ptr-amount-wrap{position:relative}
.ptr-amount-wrap .ptr-input{padding-right:54px}
.ptr-amount-wrap span{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:800;color:#475569;letter-spacing:.04em}
.ptr-file-picker{justify-content:center!important;text-align:center!important;min-height:62px!important}
.ptr-file-picker span{width:100%;text-align:center!important;font-size:15px!important;font-weight:750!important}
.ptr-file-picker small{display:none!important}
@media(max-width:620px){.ptr-date-row{grid-template-columns:1fr}.ptr-date-today{width:100%}}


/* v0.3.5 expense screen button and compact table polish */
.ptr-expense-action,
.ptr-expense-action.ptr-btn,
.ptr-reset-filter.ptr-expense-action{
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 10px 24px rgba(15,23,42,.22)!important;
  font-weight:700!important;
}
.ptr-expense-action:hover,
.ptr-expense-action.ptr-btn:hover,
.ptr-reset-filter.ptr-expense-action:hover{
  background:linear-gradient(180deg,#1e3155,#111827)!important;
  color:#fff!important;
  transform:translateY(-1px);
}
.ptr-reset-filter.ptr-expense-action{
  min-width:42px;
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  font-size:20px;
  line-height:1;
  cursor:pointer;
}
.ptr-csv-export{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:9px!important;
  min-width:148px;
}
.ptr-excel-badge{
  width:20px;
  height:20px;
  border-radius:5px;
  display:inline-grid;
  place-items:center;
  background:rgba(255,255,255,.16);
  color:#fff;
  font-size:12px;
  font-weight:800;
  border:1px solid rgba(255,255,255,.24);
  line-height:1;
}
.ptr-expense-table th,
.ptr-expense-table td{
  padding-top:10px!important;
  padding-bottom:10px!important;
}
.ptr-expense-table .row-main,
.ptr-expense-title{
  display:block;
  max-width:360px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:650!important;
}
.ptr-expense-table .ptr-pill{
  padding:4px 9px;
  font-size:11.5px;
}
.ptr-expense-table .ptr-icon-btn{
  min-width:30px;
  min-height:30px;
  padding:5px 8px;
}
.ptr-nowrap{white-space:nowrap}
@media(max-width:620px){.ptr-expense-table th,.ptr-expense-table td{padding-top:9px!important;padding-bottom:9px!important}.ptr-expense-title{max-width:220px}}


/* v0.3.6 real Excel icon for CSV export */
.ptr-excel-icon{width:24px;height:24px;display:inline-block;object-fit:contain;flex:0 0 24px}
.ptr-csv-export{gap:10px!important}


/* v0.3.7 expense screen fixes: CSV label, responsive table, HR date and selected attachment */
.ptr-expense-table{min-width:0!important;table-layout:auto}
.ptr-expense-table-wrap{overflow-x:hidden!important}
.ptr-expense-table th:nth-child(1),.ptr-expense-table td:nth-child(1){width:28%}
.ptr-expense-table th:nth-child(2),.ptr-expense-table td:nth-child(2){width:120px}
.ptr-expense-table th:nth-child(5),.ptr-expense-table td:nth-child(5){width:105px}
.ptr-expense-table th:nth-child(6),.ptr-expense-table td:nth-child(6){width:120px;white-space:nowrap}
.ptr-expense-table th:last-child,.ptr-expense-table td:last-child{width:46px}
@media(max-width:980px){.ptr-expense-table{min-width:760px!important}.ptr-expense-table-wrap{overflow-x:auto!important}}
.ptr-csv-export{min-width:178px!important;background:linear-gradient(135deg,#111827,#172033)!important;color:#fff!important;border-color:rgba(255,255,255,.12)!important}
.ptr-csv-export:hover{background:linear-gradient(135deg,#0f172a,#1e2a44)!important;color:#fff!important}
.ptr-date-row-hr{grid-template-columns:1fr auto auto;position:relative}
.ptr-date-native{position:absolute;right:0;bottom:0;width:1px;height:1px;opacity:0;pointer-events:none}
.ptr-date-pick{min-height:42px;border:1px solid var(--ptr-line);background:#f8fafc;color:#334155;border-radius:12px;padding:9px 11px;font-weight:700;cursor:pointer;transition:.15s ease}
.ptr-date-pick:hover{border-color:var(--ptr-primary);color:var(--ptr-primary);background:#eef2ff}
.ptr-file-picker{display:grid!important;justify-items:center!important;gap:5px!important;text-align:center!important}
.ptr-file-picker .ptr-file-label{width:auto!important;text-align:center!important;font-size:15px!important;font-weight:750!important}
.ptr-file-picker .ptr-file-name{display:block;width:100%;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#64748b!important;font-size:12.5px!important;font-weight:650!important;text-transform:none!important;letter-spacing:0!important}
.ptr-file-picker.has-file{border-style:solid!important;border-color:#16a34a!important;background:#ecfdf5!important;color:#166534!important}
.ptr-file-picker.has-file .ptr-file-name{color:#166534!important}
@media(max-width:620px){.ptr-date-row-hr{grid-template-columns:1fr}.ptr-date-pick,.ptr-date-today{width:100%}}

/* v0.3.8 expense table sorting and ZIP export */
.ptr-expense-head .ptr-card-head p{display:none!important}
.ptr-sort-btn{appearance:none;border:0;background:transparent;color:inherit;display:inline-flex;align-items:center;gap:6px;padding:0;margin:0;font:inherit;font-weight:760;text-transform:inherit;letter-spacing:inherit;cursor:pointer;white-space:nowrap}
.ptr-sort-btn b{font-size:12px;line-height:1;color:#94a3b8;font-weight:800;min-width:12px;text-align:center}
.ptr-sort-btn:hover span,.ptr-sort-btn.active span{color:#0f172a}
.ptr-sort-btn:hover b,.ptr-sort-btn.active b{color:var(--ptr-primary)}
.ptr-expense-export{gap:12px;flex-wrap:wrap}
.ptr-zip-export{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:9px!important;min-width:178px!important;background:linear-gradient(135deg,#111827,#172033)!important;color:#fff!important;border-color:rgba(255,255,255,.12)!important}
.ptr-zip-export:hover{background:linear-gradient(135deg,#0f172a,#1e2a44)!important;color:#fff!important;transform:translateY(-1px)}
.ptr-zip-ico{width:24px;height:24px;border-radius:7px;display:inline-grid;place-items:center;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);font-size:13px;line-height:1}
.ptr-expense-table th{user-select:none}
@media(max-width:620px){.ptr-expense-export{display:grid}.ptr-expense-export .ptr-btn{width:100%}}


/* v0.3.9 cleaner sorting indicators and balanced expense columns */
.ptr-sort-btn{gap:5px!important}
.ptr-sort-btn b{color:var(--ptr-primary)!important;font-size:13px!important;min-width:auto!important}
.ptr-sort-btn:not(.active) b{display:none!important}
.ptr-expense-table{table-layout:fixed!important;width:100%!important}
.ptr-expense-table .ptr-col-expense{width:24%}
.ptr-expense-table .ptr-col-date{width:13%}
.ptr-expense-table .ptr-col-source{width:18%}
.ptr-expense-table .ptr-col-category{width:16%}
.ptr-expense-table .ptr-col-status{width:13%}
.ptr-expense-table .ptr-col-amount{width:12%}
.ptr-expense-table .ptr-col-action{width:4%}
.ptr-expense-table th,.ptr-expense-table td{overflow:hidden;text-overflow:ellipsis}
.ptr-expense-table th:nth-child(1),.ptr-expense-table td:nth-child(1),
.ptr-expense-table th:nth-child(2),.ptr-expense-table td:nth-child(2),
.ptr-expense-table th:nth-child(5),.ptr-expense-table td:nth-child(5),
.ptr-expense-table th:nth-child(6),.ptr-expense-table td:nth-child(6),
.ptr-expense-table th:last-child,.ptr-expense-table td:last-child{width:auto!important}
.ptr-expense-table .ptr-click-row td:first-child{min-width:0!important}
.ptr-expense-table td:nth-child(3),.ptr-expense-table td:nth-child(4){white-space:nowrap}
.ptr-expense-table th:last-child,.ptr-expense-table td:last-child{text-align:right}
@media(max-width:980px){.ptr-expense-table{table-layout:auto!important;min-width:760px!important}.ptr-expense-table th,.ptr-expense-table td{overflow:visible;text-overflow:clip}}

/* v0.4.0 expense table actions, unified export menu and drawer action colors */
.ptr-expense-table .ptr-col-amount{width:10%}
.ptr-expense-table .ptr-col-action{width:6%}
.ptr-expense-table th:last-child,
.ptr-expense-table td:last-child,
.ptr-expense-table .ptr-action-cell{
  overflow:visible!important;
  text-overflow:clip!important;
  text-align:center!important;
  padding-left:10px!important;
  padding-right:16px!important;
}
.ptr-expense-table .ptr-action-cell .ptr-edit-icon{
  margin-right:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.ptr-expense-export{position:relative!important;padding-top:16px!important;padding-bottom:20px!important}
.ptr-export-menu-wrap{position:relative;display:inline-flex;justify-content:center}
.ptr-export-toggle{
  min-width:0!important;
  min-height:36px!important;
  padding:8px 12px!important;
  font-size:13px!important;
  border-radius:11px!important;
  gap:8px!important;
}
.ptr-export-toggle b{font-size:11px;line-height:1;color:#e2e8f0;font-weight:850}
.ptr-export-menu{
  position:absolute;
  left:50%;
  bottom:calc(100% + 8px);
  transform:translateX(-50%);
  width:214px;
  background:#fff;
  border:1px solid var(--ptr-line);
  border-radius:14px;
  box-shadow:var(--ptr-shadow-lg);
  padding:7px;
  z-index:40;
}
.ptr-export-menu[hidden]{display:none!important}
.ptr-export-menu:after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-6px;
  width:12px;
  height:12px;
  transform:translateX(-50%) rotate(45deg);
  background:#fff;
  border-right:1px solid var(--ptr-line);
  border-bottom:1px solid var(--ptr-line);
}
.ptr-export-menu button{
  position:relative;
  z-index:1;
  width:100%;
  border:0;
  background:transparent;
  border-radius:10px;
  min-height:40px;
  padding:8px 10px;
  display:flex;
  align-items:center;
  gap:9px;
  color:#0f172a;
  font-family:inherit;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  text-align:left;
}
.ptr-export-menu button:hover{background:#f1f5f9;color:var(--ptr-primary)}
.ptr-export-menu .ptr-excel-icon{width:22px;height:22px;flex:0 0 22px}
.ptr-export-menu .ptr-zip-ico{width:22px;height:22px;flex:0 0 22px;background:#eef2ff;color:var(--ptr-primary);border-color:#dbeafe}
.ptr-drawer-actions{
  justify-content:flex-start!important;
  margin-bottom:18px!important;
  gap:9px!important;
}
.ptr-drawer-actions .ptr-btn{
  min-height:38px!important;
  padding:9px 12px!important;
  border-radius:11px!important;
  font-size:13px!important;
  font-weight:750!important;
}
.ptr-mark-paid-btn{
  background:linear-gradient(180deg,#16a34a,#15803d)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.14)!important;
  box-shadow:0 10px 22px rgba(21,128,61,.22)!important;
}
.ptr-mark-paid-btn:hover{background:linear-gradient(180deg,#22c55e,#166534)!important;color:#fff!important}
.ptr-drawer-edit-btn{
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 10px 22px rgba(15,23,42,.18)!important;
}
.ptr-drawer-edit-btn:hover{background:linear-gradient(180deg,#1e3155,#111827)!important;color:#fff!important}
.ptr-drawer-delete-btn{
  background:linear-gradient(180deg,#991b1b,#7f1d1d)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:0 10px 22px rgba(127,29,29,.20)!important;
}
.ptr-drawer-delete-btn:hover{background:linear-gradient(180deg,#b91c1c,#7f1d1d)!important;color:#fff!important}
@media(max-width:620px){
  .ptr-expense-table th:last-child,.ptr-expense-table td:last-child,.ptr-expense-table .ptr-action-cell{text-align:center!important;padding-right:10px!important}
  .ptr-export-menu{bottom:auto;top:calc(100% + 8px)}
  .ptr-export-menu:after{bottom:auto;top:-6px;border:0;border-left:1px solid var(--ptr-line);border-top:1px solid var(--ptr-line)}
  .ptr-drawer-actions{display:grid!important;grid-template-columns:1fr!important}
}

/* v0.4.1 modern custom dropdowns and expense-table left alignment */
.ptr-custom-select{position:relative;min-width:0}
.ptr-custom-select-toggle{width:100%;min-height:42px;border:1px solid var(--ptr-line);border-radius:12px;background:#fff;color:var(--ptr-ink);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:inherit;font-size:14px;font-weight:500;line-height:1.25;cursor:pointer;box-shadow:0 1px 0 rgba(15,23,42,.02);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}
.ptr-custom-select-toggle:hover{border-color:#cbd5e1;background:#fbfdff}
.ptr-custom-select-toggle:focus{outline:0;border-color:var(--ptr-primary);box-shadow:0 0 0 4px rgba(53,37,205,.10)}
.ptr-custom-select-toggle span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}
.ptr-custom-select-toggle b{font-size:12px;color:#64748b;line-height:1;transition:transform .16s ease}
.ptr-custom-select:has(.ptr-custom-select-menu:not([hidden])) .ptr-custom-select-toggle b{transform:rotate(180deg)}
.ptr-custom-select-menu{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:80;background:#fff;border:1px solid var(--ptr-line);border-radius:16px;box-shadow:0 22px 50px rgba(15,23,42,.18);padding:7px;display:grid;gap:3px;max-height:280px;overflow:auto;min-width:190px;animation:ptrDropdownIn .12s ease-out}
.ptr-custom-select-menu[hidden]{display:none!important}
.ptr-custom-select-menu:before{content:"";position:absolute;top:-6px;left:22px;width:10px;height:10px;background:#fff;border-left:1px solid var(--ptr-line);border-top:1px solid var(--ptr-line);transform:rotate(45deg)}
.ptr-custom-select-menu button{position:relative;border:0;background:transparent;color:#334155;border-radius:11px;padding:10px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:inherit;font-size:14px;font-weight:600;text-align:left;cursor:pointer;z-index:1}
.ptr-custom-select-menu button:hover{background:#f1f5f9;color:var(--ptr-primary)}
.ptr-custom-select-menu button.active{background:#eef2ff;color:var(--ptr-primary)}
.ptr-custom-select-menu button b{font-size:13px;color:var(--ptr-primary)}
.ptr-custom-select-dark .ptr-custom-select-toggle{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.ptr-custom-select-dark .ptr-custom-select-toggle:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22)}
.ptr-custom-select-dark .ptr-custom-select-toggle:focus{border-color:rgba(255,255,255,.35);box-shadow:0 0 0 4px rgba(255,255,255,.10)}
.ptr-custom-select-dark .ptr-custom-select-toggle b{color:#cbd5e1}
.ptr-project-custom .ptr-custom-select-menu{right:auto;width:100%;min-width:220px}
.ptr-filter-custom{width:100%}
.ptr-expense-table th:first-child,
.ptr-expense-table td:first-child{padding-left:22px!important}
@media(max-width:620px){.ptr-custom-select-menu{position:relative;top:auto;margin-top:7px;max-height:220px}.ptr-custom-select-menu:before{display:none}.ptr-expense-table th:first-child,.ptr-expense-table td:first-child{padding-left:16px!important}}


/* v0.4.2 ZIP icon and export filename polish */
.ptr-export-menu .ptr-zip-icon{width:22px;height:22px;flex:0 0 22px;display:inline-block;object-fit:contain;border-radius:5px}
.ptr-export-menu .ptr-zip-ico{display:none!important}


/* v0.4.3 HR decimal input and modal primary button polish */
.ptr-amount-input{
  font-variant-numeric:tabular-nums;
}
.ptr-modal-actions #ptrSave{
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 10px 24px rgba(15,23,42,.22)!important;
}
.ptr-modal-actions #ptrSave:hover{
  background:linear-gradient(180deg,#1e3155,#111827)!important;
  color:#fff!important;
  transform:translateY(-1px);
}
.ptr-modal-actions #ptrSave:disabled{
  opacity:.72;
  transform:none!important;
}


/* v0.4.4 amount validation and footer credit */
.ptr-amount-input.invalid{
  border-color:#b91c1c!important;
  box-shadow:0 0 0 4px rgba(185,28,28,.10)!important;
  background:#fff7f7!important;
}
.ptr-app-footer{
  margin:24px 0 4px;
  padding:16px 0 4px;
  text-align:center;
  color:#94a3b8;
  font-size:12px;
  font-weight:700;
}
.ptr-app-footer a{
  color:#64748b;
  text-decoration:none;
  font-weight:850;
}
.ptr-app-footer a:hover{
  color:var(--ptr-primary);
  text-decoration:underline;
}


/* v0.4.5: align search button with primary dark-blue action style and tighten footer spacing */
.ptr-search-btn{
  border:0!important;
  background:#111827!important;
  color:#fff!important;
  box-shadow:0 10px 20px rgba(15,23,42,.16)!important;
  font-weight:800!important;
}
.ptr-search-btn:hover{
  background:#1f2a44!important;
  color:#fff!important;
  transform:translateY(-1px);
  box-shadow:0 14px 26px rgba(15,23,42,.22)!important;
}
.ptr-app-footer{
  margin:12px 0 2px!important;
  padding:8px 0 2px!important;
}

/* v0.4.9 redesigned operational dashboard */
.ptr-dashboard-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 260px;
  gap:22px;
  align-items:stretch;
  border-radius:24px;
  padding:26px;
  margin-bottom:18px;
  color:#fff;
  background:radial-gradient(circle at 94% 0%,rgba(109,92,255,.45),transparent 35%),linear-gradient(135deg,#0f172a,#1f2a44 54%,#3525cd);
  box-shadow:0 18px 42px rgba(15,23,42,.18);
  overflow:hidden;
}
.ptr-dashboard-hero .ptr-eyebrow{color:#cbd5e1!important}
.ptr-dashboard-hero h2{margin:4px 0 6px;font-size:30px!important;line-height:1.1!important;font-weight:750!important;letter-spacing:-.04em;color:#fff}
.ptr-dashboard-hero p{margin:0;color:#dbe4ff;font-weight:550;max-width:720px}
.ptr-finance-triplet{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:20px;max-width:820px}
.ptr-finance-metric{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.10);border-radius:18px;padding:14px 15px;backdrop-filter:blur(8px)}
.ptr-finance-metric span{display:block;color:#cbd5e1;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.ptr-finance-metric strong{display:block;margin-top:7px;color:#fff;font-size:23px;line-height:1.1;font-weight:800;letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.ptr-finance-metric small{display:block;margin-top:4px;color:#dbe4ff;font-weight:600}
.ptr-dashboard-actions{justify-content:flex-start;margin-top:20px}
.ptr-dashboard-action{background:linear-gradient(135deg,#0f172a,#1f2a44 60%,#3525cd)!important;color:#fff!important;border:0!important;box-shadow:0 10px 22px rgba(15,23,42,.18)!important}
.ptr-dashboard-action:hover{background:linear-gradient(135deg,#111827,#273653 60%,#4f46e5)!important;color:#fff!important}
.ptr-dashboard-meter-card{display:grid;place-items:center;text-align:center;align-content:center;gap:8px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.10);border-radius:22px;padding:20px;min-height:220px}
.ptr-dashboard-meter-card strong{font-size:14px;color:#fff}
.ptr-dashboard-meter-card small{color:#dbe4ff;font-weight:650}
.ptr-dashboard-kpis{margin-bottom:18px}
.ptr-dashboard-kpis .ptr-kpi{background:linear-gradient(135deg,#0f172a,#1f2a44 62%,#312e81)!important;color:#fff!important;border-color:rgba(255,255,255,.08)!important;box-shadow:0 14px 34px rgba(15,23,42,.16)!important;min-height:124px!important}
.ptr-dashboard-kpis .ptr-kpi span,.ptr-dashboard-kpis .ptr-kpi small{color:#cbd5e1!important}
.ptr-dashboard-kpis .ptr-kpi strong{color:#fff!important}
.ptr-dashboard-kpis .ptr-kpi .kico{background:rgba(255,255,255,.12)!important;color:#fff!important}
.ptr-dashboard-main-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);gap:16px;margin-bottom:0}
.ptr-dashboard-category-card{height:390px}
.ptr-dashboard-category-card canvas{max-height:305px}
.ptr-dashboard-attention{min-height:390px}
.ptr-attention-list{display:grid;gap:10px}
.ptr-attention-row{appearance:none;border:1px solid var(--ptr-line);background:#fff;border-radius:15px;padding:13px 14px;text-align:left;display:grid;grid-template-columns:1fr auto;gap:4px 12px;cursor:pointer;transition:.15s ease;color:var(--ptr-ink)}
.ptr-attention-row:hover{border-color:var(--ptr-primary);background:#f8f9ff;transform:translateY(-1px)}
.ptr-attention-row span{font-weight:750;color:var(--ptr-ink)}
.ptr-attention-row strong{grid-row:1/3;grid-column:2;align-self:center;min-width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#eef2ff;color:var(--ptr-primary);font-size:16px;font-weight:850}
.ptr-attention-row.is-active strong{background:#fff7ed;color:#c2410c}
.ptr-attention-row small{color:var(--ptr-muted);font-weight:550}
.ptr-dashboard-lists{margin-top:0}
.ptr-dashboard-latest{margin-bottom:18px}
.ptr-mini-list{display:grid;gap:8px}
.ptr-mini-row{width:100%;border:1px solid var(--ptr-line);background:#fff;border-radius:14px;padding:11px 13px;display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;cursor:pointer;transition:.14s ease;color:var(--ptr-ink)}
.ptr-mini-row:hover{border-color:var(--ptr-primary);background:#f8f9ff;transform:translateX(2px)}
.ptr-mini-row strong{display:block;font-size:14px;font-weight:750;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px}
.ptr-mini-row small{display:block;margin-top:2px;color:var(--ptr-muted);font-size:12px;font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px}
.ptr-mini-row b{font-size:13px;font-weight:800;font-variant-numeric:tabular-nums;white-space:nowrap}
.ptr-empty-compact{padding:24px!important;border-radius:16px!important}
@media(max-width:1180px){.ptr-dashboard-hero{grid-template-columns:1fr}.ptr-dashboard-meter-card{min-height:180px}.ptr-dashboard-main-grid{grid-template-columns:1fr}.ptr-finance-triplet{max-width:none}}
@media(max-width:760px){.ptr-dashboard-hero{padding:20px;border-radius:20px}.ptr-finance-triplet{grid-template-columns:1fr}.ptr-dashboard-kpis{grid-template-columns:1fr!important}.ptr-dashboard-lists{grid-template-columns:1fr!important}.ptr-dashboard-actions .ptr-btn{width:100%}.ptr-dashboard-hero h2{font-size:25px!important}}


/* v0.5.0 dashboard hero: dark container with light summary cards */
.ptr-dashboard-hero-with-cards{
  grid-template-columns:minmax(0,1fr) 260px!important;
  gap:24px!important;
  padding:28px!important;
  align-items:stretch!important;
  min-height:258px;
}
.ptr-dashboard-hero-cards{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  align-content:center;
}
.ptr-dashboard-hero-stat{
  position:relative;
  overflow:hidden;
  background:#fff;
  color:#0f172a;
  border:1px solid rgba(226,232,240,.92);
  border-radius:18px;
  padding:18px 20px;
  min-height:112px;
  box-shadow:0 16px 34px rgba(15,23,42,.18);
}
.ptr-dashboard-hero-stat:after{
  content:"";
  position:absolute;
  right:-24px;
  bottom:-28px;
  width:86px;
  height:86px;
  border-radius:50%;
  background:#ede9fe;
  opacity:.82;
}
.ptr-dashboard-hero-stat-top{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.ptr-dashboard-hero-stat span{
  display:block;
  color:#64748b;
  font-size:11.5px;
  line-height:1.25;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.ptr-dashboard-hero-stat .kico{
  width:36px;
  height:36px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#ede9fe;
  color:#3525cd;
  font-size:17px;
  font-weight:850;
}
.ptr-dashboard-hero-stat strong{
  position:relative;
  z-index:1;
  display:block;
  margin-top:12px;
  color:#0f172a;
  font-size:26px;
  line-height:1.08;
  font-weight:780;
  letter-spacing:-.04em;
  font-variant-numeric:tabular-nums;
}
.ptr-dashboard-hero-stat small{
  position:relative;
  z-index:1;
  display:block;
  margin-top:6px;
  color:#64748b;
  font-size:13px;
  line-height:1.35;
  font-weight:550;
}
@media(max-width:1180px){
  .ptr-dashboard-hero-with-cards{grid-template-columns:1fr!important;min-height:0}
  .ptr-dashboard-hero-cards{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media(max-width:980px){
  .ptr-dashboard-hero-cards{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:620px){
  .ptr-dashboard-hero-with-cards{padding:20px!important;border-radius:20px!important}
  .ptr-dashboard-hero-cards{grid-template-columns:1fr}
  .ptr-dashboard-hero-stat{min-height:104px;padding:16px}
}

/* v0.5.1 dashboard hero: combined intro + light metric cards */
.ptr-dashboard-hero-combo{
  grid-template-columns:minmax(0,1fr) 260px!important;
  gap:28px!important;
  padding:28px!important;
  align-items:stretch!important;
  min-height:270px;
}
.ptr-dashboard-hero-copy{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}
.ptr-dashboard-hero-combo .ptr-eyebrow{
  margin-bottom:8px!important;
  color:#cbd5e1!important;
}
.ptr-dashboard-hero-combo h2{
  margin:0 0 8px!important;
  color:#fff!important;
  font-size:30px!important;
  line-height:1.08!important;
  font-weight:780!important;
  letter-spacing:-.045em!important;
}
.ptr-dashboard-hero-combo p{
  margin:0!important;
  color:#dbe4ff!important;
  font-weight:650!important;
  max-width:760px!important;
}
.ptr-dashboard-hero-cards-light{
  margin-top:22px;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  align-content:initial!important;
  max-width:900px;
}
.ptr-dashboard-hero-cards-light .ptr-dashboard-hero-stat{
  min-height:112px;
  box-shadow:0 16px 34px rgba(15,23,42,.18);
}
.ptr-dashboard-meter-card-accent{
  position:relative;
  overflow:hidden;
  z-index:1;
}
.ptr-dashboard-meter-card-accent:after{
  content:"";
  position:absolute;
  right:-78px;
  top:-92px;
  width:230px;
  height:230px;
  border-radius:50%;
  background:rgba(255,255,255,.10);
  pointer-events:none;
}
.ptr-dashboard-meter-card-accent .ptr-ring,
.ptr-dashboard-meter-card-accent strong,
.ptr-dashboard-meter-card-accent small{
  position:relative;
  z-index:1;
}
@media(max-width:1180px){
  .ptr-dashboard-hero-combo{grid-template-columns:1fr!important;min-height:0}
  .ptr-dashboard-hero-cards-light{grid-template-columns:repeat(3,minmax(0,1fr))!important;max-width:none}
  .ptr-dashboard-meter-card-accent{min-height:180px}
}
@media(max-width:860px){
  .ptr-dashboard-hero-cards-light{grid-template-columns:1fr!important}
}
@media(max-width:620px){
  .ptr-dashboard-hero-combo{padding:20px!important;border-radius:20px!important}
  .ptr-dashboard-hero-combo h2{font-size:25px!important}
}


/* v0.5.2 dashboard refinements */
.ptr-dashboard-bottom-grid{margin-top:0;margin-bottom:18px}
.ptr-attention-pending{margin-top:14px;padding-top:14px;border-top:1px solid var(--ptr-line)}
.ptr-attention-subhead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.ptr-attention-subhead strong{font-size:13px;font-weight:850;color:var(--ptr-ink);letter-spacing:-.01em}
.ptr-attention-subhead span{font-size:11px;font-weight:800;color:var(--ptr-muted);text-transform:uppercase;letter-spacing:.06em;background:#f1f5f9;border:1px solid var(--ptr-line);border-radius:999px;padding:5px 8px}
.ptr-dashboard-attention .ptr-empty-compact{padding:18px!important}
@media(max-width:760px){.ptr-dashboard-bottom-grid{grid-template-columns:1fr!important}}

/* v0.5.3 dashboard UX polish */
.ptr-topbar .ptr-actions .ptr-expense-action,
.ptr-dashboard-action.ptr-expense-action{
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 10px 24px rgba(15,23,42,.22)!important;
  font-weight:700!important;
}
.ptr-topbar .ptr-actions .ptr-expense-action:hover,
.ptr-dashboard-action.ptr-expense-action:hover{
  background:linear-gradient(180deg,#1e3155,#111827)!important;
  color:#fff!important;
  transform:translateY(-1px);
}
.ptr-dashboard-attention .ptr-card-head{margin-bottom:14px!important}
.ptr-attention-row{cursor:pointer}
.ptr-attention-row:focus-visible{outline:3px solid rgba(53,37,205,.18);outline-offset:2px}
.ptr-attention-modal{max-width:760px!important}
.ptr-attention-modal .ptr-modal-head p{margin:6px 0 0;color:#64748b;font-weight:600;line-height:1.45}
.ptr-attention-results{display:grid;gap:9px}
.ptr-attention-expense-row{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  text-align:left;border:1px solid var(--ptr-line);background:#fff;border-radius:14px;
  padding:12px 14px;cursor:pointer;transition:.15s ease;color:var(--ptr-ink)
}
.ptr-attention-expense-row:hover{border-color:var(--ptr-primary);background:#f8f9ff;box-shadow:0 10px 20px rgba(53,37,205,.08);transform:translateY(-1px)}
.ptr-attention-expense-row strong{display:block;font-size:14px;font-weight:750;color:#0f172a;line-height:1.25}
.ptr-attention-expense-row small{display:block;margin-top:4px;font-size:12.5px;color:#64748b;font-weight:550;line-height:1.35}
.ptr-attention-expense-row b{white-space:nowrap;font-variant-numeric:tabular-nums;color:#0f172a;font-weight:800}
.ptr-attention-source-row{cursor:default}
.ptr-attention-source-row:hover{transform:none;background:#fff;border-color:var(--ptr-line);box-shadow:none}
.ptr-attention-note{margin:12px 2px 0;color:#64748b;font-size:13px;font-weight:600}
@media(max-width:620px){.ptr-attention-expense-row{display:grid}.ptr-attention-expense-row b{justify-self:start}.ptr-attention-modal{max-width:100%!important}}

/* v0.5.4 dashboard grid alignment + category pie chart */
.ptr-dashboard-main-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:stretch!important;
  gap:18px!important;
}
.ptr-dashboard-category-card,
.ptr-dashboard-attention{
  min-height:390px!important;
  height:auto!important;
}
.ptr-dashboard-category-card canvas{
  max-height:300px!important;
  margin-top:4px;
}
@media(max-width:1180px){
  .ptr-dashboard-main-grid{grid-template-columns:1fr!important;}
}


/* v0.5.5 dashboard pie spacing + attention modal polish */
.ptr-dashboard-category-card .ptr-card-head{
  margin-bottom:24px!important;
}
.ptr-dashboard-category-card canvas{
  margin-top:24px!important;
  max-height:286px!important;
}
.ptr-attention-modal .ptr-modal-body{
  padding-bottom:24px!important;
}
.ptr-attention-modal .ptr-attention-results{
  margin-bottom:6px!important;
}

/* v0.5.6 dashboard category chart fills available space better */
.ptr-dashboard-category-card{
  min-height:430px!important;
}
.ptr-dashboard-category-card .ptr-card-head{
  margin-bottom:10px!important;
}
.ptr-dashboard-category-card canvas{
  display:block;
  width:100%!important;
  height:345px!important;
  max-height:345px!important;
  margin-top:12px!important;
}
@media(max-width:620px){
  .ptr-dashboard-category-card{min-height:390px!important;}
  .ptr-dashboard-category-card canvas{height:300px!important;max-height:300px!important;}
}


/* v0.5.7 app-wide primary button alignment and dashboard category cleanup */
.ptr-btn.ptr-app-primary-btn,
.ptr-actions .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn),
.ptr-card-head .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn),
.ptr-empty-action .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn),
.ptr-modal-actions .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn){
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 10px 24px rgba(15,23,42,.20)!important;
  font-weight:700!important;
}
.ptr-btn.ptr-app-primary-btn:hover,
.ptr-actions .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn):hover,
.ptr-card-head .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn):hover,
.ptr-empty-action .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn):hover,
.ptr-modal-actions .ptr-btn:not(.secondary):not(.ghost):not(.danger):not(.ptr-mark-paid-btn):not(.ptr-drawer-delete-btn):hover{
  background:linear-gradient(180deg,#1e3155,#111827)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.16)!important;
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(15,23,42,.24)!important;
}
.ptr-dashboard-category-card .ptr-card-head{
  padding-right:0!important;
}

/* v0.5.8 settings tabs and source attachments */
.ptr-settings-tabs-card{
  background:#fff;
  border:1px solid var(--ptr-line);
  border-radius:22px;
  box-shadow:var(--ptr-shadow);
  padding:0;
  overflow:hidden;
}
.ptr-settings-tabs-card .ptr-settings-content{
  margin-top:0!important;
  padding:18px;
  background:#fff;
  border-top:1px solid var(--ptr-line);
}
.ptr-settings-tabs{
  position:relative!important;
  top:auto!important;
  z-index:1!important;
  display:flex!important;
  gap:8px!important;
  flex-wrap:wrap!important;
  margin:0!important;
  padding:14px 16px 0!important;
  background:linear-gradient(180deg,#f8fafc,#fff)!important;
  backdrop-filter:none!important;
}
.ptr-settings-tabs .ptr-tab-chip{
  min-height:42px;
  border-radius:14px 14px 0 0!important;
  border:1px solid transparent!important;
  border-bottom:0!important;
  padding:10px 15px!important;
  background:transparent!important;
  color:#475569!important;
  font-weight:750!important;
  box-shadow:none!important;
  transform:none!important;
}
.ptr-settings-tabs .ptr-tab-chip:hover{
  background:#eef2ff!important;
  color:#0f172a!important;
  border-color:#dbe3f0!important;
}
.ptr-settings-tabs .ptr-tab-chip.active{
  background:linear-gradient(180deg,#15233f,#0f172a)!important;
  color:#fff!important;
  border-color:#15233f!important;
  box-shadow:0 10px 22px rgba(15,23,42,.16)!important;
  position:relative;
  z-index:2;
}
.ptr-settings-tabs .ptr-tab-chip.active:hover{
  background:linear-gradient(180deg,#1e3155,#111827)!important;
  color:#fff!important;
}
.ptr-settings-tabs-card .ptr-management-card{
  margin-bottom:0!important;
  box-shadow:none!important;
  border-radius:18px!important;
}
.ptr-existing-files{
  display:grid;
  gap:8px;
  border:1px solid var(--ptr-line);
  background:#f8fafc;
  border-radius:14px;
  padding:12px;
}
.ptr-existing-files>span{
  display:block;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:#64748b;
}
.ptr-existing-files a{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:8px 10px;
  border-radius:11px;
  background:#fff;
  border:1px solid #e2e8f0;
  color:#0f172a;
  font-weight:750;
  text-decoration:none;
}
.ptr-existing-files a:hover{
  border-color:var(--ptr-primary);
  background:#eef2ff;
  color:var(--ptr-primary);
}
@media(max-width:720px){
  .ptr-settings-tabs-card .ptr-settings-content{padding:14px;}
  .ptr-settings-tabs{display:grid!important;grid-template-columns:1fr!important;padding:12px 12px 0!important;}
  .ptr-settings-tabs .ptr-tab-chip{border-radius:12px!important;border:1px solid var(--ptr-line)!important;}
}

/* v0.5.9 enhanced reports */
.ptr-report-hero-modern{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  background:#fff;
  border:1px solid var(--ptr-line);
  border-radius:22px;
  padding:20px;
  box-shadow:var(--ptr-shadow);
  margin-bottom:16px;
}
.ptr-report-hero-modern h2{margin:3px 0 6px;font-size:24px;line-height:1.15;color:#0f172a}
.ptr-report-hero-modern p{margin:0;color:#64748b;font-weight:650;max-width:680px}
.ptr-report-meta{display:block;margin-top:9px;color:#64748b;font-weight:750}
.ptr-report-filter-card{margin-bottom:16px;padding:18px 20px!important}
.ptr-report-filter-title h2{margin:4px 0 4px;font-size:18px}.ptr-report-filter-title p{margin:0;color:#64748b;font-weight:650}
.ptr-report-filterbar{display:grid;grid-template-columns:minmax(180px,240px) minmax(180px,240px) auto;gap:12px;align-items:end;margin-top:14px}
.ptr-report-filterbar .ptr-field{margin:0}.ptr-report-filter-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ptr-report-kpi-secondary{margin-top:-4px;margin-bottom:16px}
.ptr-report-chart-card{min-height:390px}.ptr-report-chart-card canvas{min-height:300px!important}
.ptr-report-source-list{display:grid;gap:13px;padding:6px 2px 2px}
.ptr-report-source-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.ptr-report-source-row strong{display:block;font-size:14px;color:#0f172a}.ptr-report-source-row small{display:block;margin-top:3px;color:#64748b;font-weight:700}.ptr-report-source-row>b{font-size:13px;color:#334155}.ptr-report-source-row .ptr-bar{grid-column:1/-1;height:9px}
.ptr-control-list{display:grid;gap:10px}.ptr-control-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:14px;padding:12px 13px}.ptr-control-row.is-active{background:#fff7ed;border-color:#fed7aa}.ptr-control-row strong{display:block;color:#0f172a}.ptr-control-row small{display:block;margin-top:3px;color:#64748b;font-weight:650}.ptr-control-row>b{min-width:36px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#eef2ff;color:#312e81;font-weight:900}.ptr-control-row.is-active>b{background:#ffedd5;color:#9a3412}
.ptr-report-detail-wrap{max-height:440px;overflow:auto}.ptr-report-detail-table th,.ptr-report-detail-table td{font-size:13px}.ptr-report-detail-table td{vertical-align:middle}.ptr-report-detail-table .ptr-pill{white-space:nowrap}
@media(max-width:980px){.ptr-report-hero-modern{display:grid}.ptr-report-filterbar{grid-template-columns:1fr}.ptr-report-filter-actions .ptr-btn{width:100%}}

/* v0.6.1 reports/date UX and category chart polish */
.ptr-report-kpi-main{margin-bottom:16px!important}
.ptr-report-filterbar .ptr-field-hint{display:none}
.ptr-report-filterbar .ptr-date-row-hr{grid-template-columns:1fr auto auto}
.ptr-report-category-card{min-height:430px!important;height:auto!important}
.ptr-report-category-card .ptr-card-head{margin-bottom:10px!important}
.ptr-report-category-card canvas{display:block;width:100%!important;height:345px!important;max-height:345px!important;margin-top:12px!important}
@media(max-width:620px){.ptr-report-category-card{min-height:390px!important}.ptr-report-category-card canvas{height:300px!important;max-height:300px!important}}
.ptr-report-filterbar{grid-template-columns:minmax(280px,1fr) minmax(280px,1fr) auto!important}
@media(max-width:980px){.ptr-report-filterbar{grid-template-columns:1fr!important}}


/* v0.6.2 reports date filter spacing */
.ptr-report-filterbar{
  grid-template-columns:240px 240px auto!important;
  column-gap:30px!important;
  row-gap:14px!important;
  justify-content:start;
}
.ptr-report-filterbar .ptr-date-row-hr{
  grid-template-columns:minmax(104px,1fr) 42px auto!important;
  gap:7px!important;
}
.ptr-report-filterbar .ptr-date-pick{
  width:42px;
  min-width:42px;
  padding:9px 0;
}
.ptr-report-filterbar .ptr-date-today{
  padding:9px 10px;
  min-width:58px;
}
.ptr-report-filter-actions{
  margin-left:4px;
  gap:10px!important;
}
@media(max-width:980px){
  .ptr-report-filterbar{grid-template-columns:1fr!important;column-gap:0!important}
  .ptr-report-filter-actions{margin-left:0}
}

/* v0.6.3 reports alignment, clickable control reports and settings tables */
.ptr-report-top-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:stretch;
}
.ptr-report-top-grid>.ptr-card{
  min-width:0;
}
.ptr-report-top-grid .ptr-report-chart-card{
  width:100%;
}
.ptr-control-row{
  width:100%;
  text-align:left;
  font-family:inherit;
  cursor:pointer;
  transition:background .15s ease,border-color .15s ease,transform .15s ease,box-shadow .15s ease;
}
.ptr-control-row:hover{
  border-color:var(--ptr-primary)!important;
  background:#f8f9ff!important;
  box-shadow:0 10px 22px rgba(15,23,42,.06);
  transform:translateY(-1px);
}
.ptr-control-row.is-active:hover{
  background:#fff7ed!important;
  border-color:#fbbf24!important;
}
.ptr-report-control-modal .ptr-modal-head small{
  display:block;
  margin-top:7px;
  font-weight:750;
}
.ptr-settings-tabs-card .ptr-table-wrap{
  overflow-x:auto;
}
.ptr-settings-tabs-card .ptr-table{
  width:100%!important;
  min-width:0!important;
  table-layout:fixed!important;
}
.ptr-settings-tabs-card .ptr-table th,
.ptr-settings-tabs-card .ptr-table td{
  overflow:hidden;
  text-overflow:ellipsis;
}
.ptr-settings-tabs-card .ptr-table th:last-child,
.ptr-settings-tabs-card .ptr-table td:last-child{
  width:92px!important;
  text-align:right!important;
  white-space:nowrap;
}
.ptr-settings-tabs-card .ptr-table td:first-child,
.ptr-settings-tabs-card .ptr-table th:first-child{
  padding-left:18px!important;
}
.ptr-settings-tabs-card .ptr-table .row-sub{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
@media(max-width:980px){
  .ptr-report-top-grid{grid-template-columns:1fr!important;}
  .ptr-settings-tabs-card .ptr-table{min-width:720px!important;table-layout:auto!important;}
}


/* v0.6.4: izvještaji - klikabilni detaljni dnevnik i centriran korisnik u sidebaru */
.ptr-report-detail-table tbody tr[data-drawer]{cursor:pointer;}
.ptr-report-detail-table tbody tr[data-drawer]:hover{background:#f8f9ff;}
.ptr-user-email{text-align:center!important;}
.ptr-user{text-align:center;}

/* v0.6.5: Postavke - čisti akcijski stupac bez trotočke iza olovčice */
.ptr-settings-tabs-card .ptr-settings-action-head,
.ptr-settings-tabs-card .ptr-settings-action-cell{
  width:120px!important;
  min-width:120px!important;
  max-width:120px!important;
  overflow:visible!important;
  text-overflow:clip!important;
  white-space:nowrap!important;
  text-align:right!important;
  padding-right:18px!important;
}
.ptr-settings-action-cell{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}
.ptr-settings-action-cell .ptr-icon-btn{
  flex:0 0 auto;
}
.ptr-settings-tabs-card .ptr-table th:last-child,
.ptr-settings-tabs-card .ptr-table td:last-child{
  overflow:visible!important;
  text-overflow:clip!important;
}

/* v0.6.6: Postavke - tablice bez nepotrebnog horizontalnog scrolla + audit trail */
@media(min-width:981px){
  .ptr-settings-tabs-card .ptr-table-wrap{
    overflow-x:hidden!important;
  }
  .ptr-settings-tabs-card .ptr-table{
    width:100%!important;
    min-width:0!important;
    table-layout:fixed!important;
  }
  .ptr-settings-tabs-card .ptr-table th,
  .ptr-settings-tabs-card .ptr-table td{
    white-space:normal!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    word-break:break-word;
  }
  .ptr-settings-tabs-card .ptr-settings-action-head,
  .ptr-settings-tabs-card .ptr-settings-action-cell,
  .ptr-settings-tabs-card .ptr-table th:last-child,
  .ptr-settings-tabs-card .ptr-table td:last-child{
    width:106px!important;
    min-width:106px!important;
    max-width:106px!important;
    padding-left:8px!important;
    padding-right:14px!important;
    text-align:right!important;
    overflow:visible!important;
    text-overflow:clip!important;
    white-space:nowrap!important;
  }
}
.ptr-settings-action-cell{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:6px!important;
}
.ptr-settings-action-cell .ptr-icon-btn{
  min-width:32px!important;
  width:32px!important;
  min-height:32px!important;
  height:32px!important;
  padding:0!important;
  display:inline-grid!important;
  place-items:center!important;
}
.ptr-audit-table-wrap{overflow-x:auto!important;}
.ptr-audit-table{min-width:920px!important;table-layout:fixed!important;}
.ptr-audit-date{width:150px}.ptr-audit-action{width:170px}.ptr-audit-expense{width:220px}.ptr-audit-user{width:160px}.ptr-audit-details{width:auto}
.ptr-audit-table td,.ptr-audit-table th{white-space:normal!important;overflow:hidden;text-overflow:ellipsis;}

/* v0.6.7: demo import + audit time polish */
.ptr-demo-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px}
.ptr-demo-note{margin-top:18px!important;align-items:flex-start!important;text-align:left!important}
.ptr-demo-note p{margin:6px 0 0;color:#64748b}
.ptr-audit-table td:first-child{font-variant-numeric:tabular-nums}

/* v0.6.8: demo tab only for owner, safer project delete UI and responsive polish */
.ptr-project-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
.ptr-danger-outline-btn{
  background:#7f1d1d!important;
  border-color:#7f1d1d!important;
  color:#fff!important;
  box-shadow:0 12px 24px rgba(127,29,29,.18)!important;
}
.ptr-danger-outline-btn:hover{
  background:#991b1b!important;
  border-color:#991b1b!important;
  color:#fff!important;
  transform:translateY(-1px);
}
.ptr-settings-tabs-card .ptr-settings-action-cell{
  display:table-cell!important;
  vertical-align:middle!important;
  text-align:right!important;
  width:104px!important;
  min-width:104px!important;
  max-width:104px!important;
  padding-right:16px!important;
  white-space:nowrap!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
.ptr-settings-actions-wrap{
  display:inline-flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
  white-space:nowrap;
}
.ptr-settings-actions-wrap .ptr-icon-btn{
  min-width:32px!important;
  width:32px!important;
  min-height:32px!important;
  height:32px!important;
  padding:0!important;
  display:inline-grid!important;
  place-items:center!important;
}
@media(min-width:981px){
  .ptr-settings-tabs-card .ptr-table-wrap{overflow-x:hidden!important;}
  .ptr-settings-tabs-card .ptr-table{width:100%!important;min-width:0!important;table-layout:fixed!important;}
  .ptr-settings-tabs-card .ptr-table th:last-child,
  .ptr-settings-tabs-card .ptr-table td:last-child{width:104px!important;min-width:104px!important;max-width:104px!important;}
}
@media(max-width:1180px){
  .ptr-report-top-grid,.ptr-report-grid,.ptr-dashboard-main-grid,.ptr-dashboard-bottom-grid{grid-template-columns:1fr!important;}
  .ptr-report-category-card,.ptr-dashboard-category-card{min-height:420px;}
}
@media(max-width:860px){
  .ptr-topbar{gap:12px;}
  .ptr-card-head{display:grid;grid-template-columns:1fr;}
  .ptr-card-head .ptr-actions,.ptr-project-actions{justify-content:flex-start;}
  .ptr-settings-tabs-card .ptr-table{min-width:680px!important;}
  .ptr-project-actions .ptr-btn{width:100%;}
}
@media(max-width:620px){
  .ptr-main{padding-left:14px!important;padding-right:14px!important;}
  .ptr-card{padding:15px!important;border-radius:18px!important;}
  .ptr-settings-tabs-card .ptr-settings-content{padding:12px!important;}
  .ptr-report-filterbar,.ptr-filterbar-polished,.ptr-dashboard-hero-cards-light{grid-template-columns:1fr!important;}
  .ptr-report-category-card,.ptr-dashboard-category-card{min-height:390px!important;}
  .ptr-table-wrap{border-radius:16px;}
}


/* v0.7.0 attention/report pop-up scrolling + expense table without edit column */
.ptr-attention-modal,
.ptr-report-control-modal{
  display:flex!important;
  flex-direction:column!important;
  max-height:86vh!important;
  overflow:hidden!important;
}
.ptr-attention-modal .ptr-modal-head,
.ptr-report-control-modal .ptr-modal-head{
  flex:0 0 auto!important;
}
.ptr-attention-modal .ptr-modal-body,
.ptr-report-control-modal .ptr-modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  padding-bottom:24px!important;
}
.ptr-attention-modal .ptr-modal-actions,
.ptr-report-control-modal .ptr-modal-actions{
  flex:0 0 auto!important;
}
.ptr-attention-results{
  max-height:none!important;
}
.ptr-expense-table .ptr-col-expense{width:28%!important}
.ptr-expense-table .ptr-col-date{width:13%!important}
.ptr-expense-table .ptr-col-source{width:18%!important}
.ptr-expense-table .ptr-col-category{width:17%!important}
.ptr-expense-table .ptr-col-status{width:12%!important}
.ptr-expense-table .ptr-col-amount{width:12%!important}
.ptr-expense-table th:last-child,
.ptr-expense-table td:last-child{
  text-align:right!important;
  padding-right:22px!important;
}
.ptr-expense-table-wrap{overflow-x:hidden!important}
.ptr-expense-table{min-width:0!important;width:100%!important;table-layout:fixed!important}
@media(max-width:980px){
  .ptr-expense-table{min-width:760px!important;table-layout:auto!important}
  .ptr-expense-table-wrap{overflow-x:auto!important}
}
@media(max-width:620px){
  .ptr-attention-modal,
  .ptr-report-control-modal{max-height:94vh!important}
}

/* v0.7.3 due-date emphasis in attention popups */
.ptr-due-alert{
  display:block;
  margin-top:7px;
  color:#b91c1c;
  font-style:normal;
  font-weight:750;
  font-size:12.5px;
  line-height:1.25;
}
.ptr-due-alert.is-overdue{
  color:#991b1b;
}


/* v0.7.4 login screen branding */
.ptr-login-card-branded{text-align:center;padding:34px 34px 30px}
.ptr-login-logo-wrap{display:flex;justify-content:center;align-items:center;margin:0 auto 18px}
.ptr-login-logo{display:block;width:min(172px,72%);height:auto;object-fit:contain;background:#fff;border-radius:18px;padding:10px;border:1px solid rgba(226,232,240,.85);box-shadow:0 10px 28px rgba(15,23,42,.08)}
.ptr-login-card-branded .ptr-login-icon{display:none!important}
.ptr-login-card-branded h1{text-align:center;margin:0 0 10px;font-size:29px;font-weight:850;color:#101827;letter-spacing:-.035em}
.ptr-login-card-branded p{text-align:center;margin:0 auto 24px;max-width:340px;color:#64748b;font-size:14px;line-height:1.55}
.ptr-login-card-branded form{text-align:left}
.ptr-login-card-branded .login-remember{display:flex;align-items:center;justify-content:center;margin:14px 0 16px;text-align:center}
.ptr-login-card-branded .login-remember label{display:flex;align-items:center;gap:8px;margin:0;color:#475569;font-weight:750}
.ptr-login-card-branded .login-submit{text-align:center;margin:4px 0 0}
.ptr-login-card-branded .button,.ptr-login-card-branded .button-primary{min-width:148px;min-height:42px;border-radius:12px;background:var(--ptr-primary)!important;border:1px solid var(--ptr-primary)!important;color:#fff!important;font-family:inherit;font-size:14px;font-weight:850;box-shadow:0 10px 22px rgba(53,37,205,.18);text-shadow:none!important}
.ptr-login-card-branded .button:hover,.ptr-login-card-branded .button-primary:hover,.ptr-login-card-branded .button:focus,.ptr-login-card-branded .button-primary:focus{background:var(--ptr-primary-2)!important;border-color:var(--ptr-primary-2)!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 12px 24px rgba(53,37,205,.22)}
.ptr-login-card-branded .ptr-brand-credit{text-align:center;margin-top:18px;padding-top:16px;border-top:1px solid rgba(226,232,240,.8);font-size:13px;color:#64748b}
.ptr-login-card-branded .ptr-brand-credit a{font-weight:800;color:var(--ptr-primary)}
@media(max-width:620px){.ptr-login-card-branded{padding:26px 22px 24px}.ptr-login-logo{width:min(154px,78%)}.ptr-login-card-branded h1{font-size:26px}.ptr-login-card-branded .button,.ptr-login-card-branded .button-primary{width:100%}}

/* v0.7.5 login form alignment: keep branding centered, but form fields left-aligned */
.ptr-login-card-branded > p{text-align:center;margin:0 auto 24px;max-width:340px;color:#64748b;font-size:14px;line-height:1.55}
.ptr-login-card-branded form{text-align:left!important}
.ptr-login-card-branded form p:not(.login-submit):not(.login-remember){text-align:left!important;margin:0 0 18px!important;max-width:none!important;color:inherit!important}
.ptr-login-card-branded form label{text-align:left!important}
.ptr-login-card-branded .login-remember{justify-content:flex-start!important;text-align:left!important;margin:12px 0 18px!important}
.ptr-login-card-branded .login-remember label{justify-content:flex-start!important;text-align:left!important}
.ptr-login-card-branded .login-submit{text-align:center!important;margin:6px 0 0!important}
