:root{--green:#1d8a63;--green-dark:#13674a;--green-light:#e8f6ef;--ink:#10241c;--slate:#46584f;--muted:#7a8a82;--line:#e4ebe7;--bg:#ffffff;--bg-soft:#f6faf8;--pro:#1d8a63;--perso:#8a93b0;--danger:#d6453b;--amber:#f5b50a;--radius:14px;--shadow:0 18px 40px -20px rgba(16,36,28,.28);--shadow-sm:0 8px 24px -12px rgba(16,36,28,.18);--side-w:248px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--bg-soft);-webkit-font-smoothing:antialiased;line-height:1.55}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--side-w);flex-shrink:0;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;height:100vh;z-index:40}.app-body{flex:1;margin-left:var(--side-w);display:flex;flex-direction:column;min-width:0}.app-logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;padding:20px 22px;letter-spacing:-.02em}.logo-mark{width:30px;height:30px;border-radius:8px;background:var(--green);display:grid;place-items:center;box-shadow:var(--shadow-sm);color:#fff;font-weight:800;font-size:13px;letter-spacing:-.02em}.side-nav{display:flex;flex-direction:column;padding:8px 12px;gap:2px;flex:1}.side-nav a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:10px;font-weight:500;font-size:14.5px;color:var(--slate);transition:.15s}.side-nav a .ic{width:18px;text-align:center;font-size:15px}.side-nav a:hover{background:var(--bg-soft);color:var(--ink)}.side-nav a.active{background:var(--green-light);color:var(--green-dark);font-weight:600}.side-foot{padding:14px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}.side-back{font-size:13px;color:var(--muted)}.side-back:hover{color:var(--green-dark)}.btn-reset{background:none;border:1px solid var(--line);border-radius:8px;padding:7px;font-size:12.5px;color:var(--muted)}.btn-reset:hover{border-color:var(--danger);color:var(--danger)}.side-foot-row{display:flex;gap:8px}.side-foot-row .btn-reset{flex:1}#logoutBtn:hover{border-color:var(--green);color:var(--green-dark)}.app-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:0 28px;height:64px}.menu-btn{display:none;background:none;border:none;font-size:22px;color:var(--ink)}.topbar-title{font-weight:700;font-size:18px;letter-spacing:-.01em}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:14px}.user-chip{display:flex;align-items:center;gap:8px}.avatar{width:32px;height:32px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}.user-name{font-size:14px;font-weight:500}.premium-pill{font-size:11px;font-weight:700;color:#8a6d00;background:linear-gradient(135deg,#ffe08a,#f5c542);padding:3px 9px;border-radius:999px;letter-spacing:.02em;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:600;font-size:14px;border-radius:9px;padding:9px 16px;border:1.5px solid transparent;transition:.16s;white-space:nowrap}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}.btn-ghost{background:#fff;color:var(--slate);border-color:var(--line)}.btn-ghost:hover{border-color:var(--green);color:var(--green-dark)}.btn-danger{background:#fff;color:var(--danger);border-color:#f0cfcc}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 11px;font-size:13px}.btn-block{width:100%}.btn-icon{background:none;border:none;color:var(--muted);font-size:15px;padding:6px;border-radius:7px}.btn-icon:hover{background:var(--bg-soft);color:var(--ink)}.btn-icon.del:hover{color:var(--danger)}.app-main{padding:28px;max-width:1180px;width:100%}.view-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.view-head h1{font-size:24px;letter-spacing:-.02em}.view-head p{color:var(--muted);font-size:14px;margin-top:3px}.view-actions{display:flex;gap:10px;flex-wrap:wrap}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}.kpi .k-label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px}.kpi .k-val{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-top:6px}.kpi .k-sub{font-size:12.5px;color:var(--muted);margin-top:2px}.kpi.accent{background:var(--green);border-color:var(--green);color:#fff}.kpi.accent .k-label,.kpi.accent .k-sub{color:#ffffffd9}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-head h2{font-size:17px}.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:20px}.chart{display:flex;align-items:flex-end;gap:10px;height:180px;padding-top:10px}.chart .bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.chart .bar{width:100%;max-width:34px;border-radius:6px 6px 0 0;background:var(--green-light);position:relative;transition:.3s}.chart .bar .seg-pro{position:absolute;bottom:0;left:0;right:0;background:var(--green);border-radius:6px 6px 0 0}.chart .bar-lbl{font-size:11px;color:var(--muted)}.chart .bar-val{font-size:11px;font-weight:600;color:var(--slate)}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:14px}table.data th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}table.data td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}table.data tr:last-child td{border-bottom:none}table.data tr:hover td{background:var(--bg-soft)}.t-num{text-align:right;font-variant-numeric:tabular-nums}.t-strong{font-weight:600}.t-sub{font-size:12px;color:var(--muted)}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:4px 9px;border-radius:999px;letter-spacing:.02em}.pill.pro{background:var(--green-light);color:var(--green-dark)}.pill.perso{background:#eef0f5;color:var(--perso)}.pill.auto{background:#eaf3ff;color:#2a6fd0}.pill.manual{background:#f3f1ea;color:#8a7a4a}.cat-toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.cat-toggle button{background:#fff;border:none;padding:5px 10px;font-size:12px;font-weight:600;color:var(--muted)}.cat-toggle button.on.pro{background:var(--green);color:#fff}.cat-toggle button.on.perso{background:var(--perso);color:#fff}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:600;color:var(--slate);margin-bottom:6px}.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:10px 12px;font:inherit;font-size:14px;color:var(--ink);background:#fff;transition:.15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-light)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.hint{font-size:12px;color:var(--muted);margin-top:4px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}.seg{display:inline-flex;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:3px;gap:3px}.seg button{background:none;border:none;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted)}.seg button.on{background:#fff;color:var(--green-dark);box-shadow:var(--shadow-sm)}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty .e-ico{font-size:38px;margin-bottom:12px}.empty h3{color:var(--ink);font-size:17px;margin-bottom:6px}.list-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}.list-item:last-child{border-bottom:none}.li-ico{width:42px;height:42px;border-radius:11px;background:var(--green-light);display:grid;place-items:center;font-size:18px;flex-shrink:0}.li-main{flex:1;min-width:0}.li-main strong{font-size:14.5px;display:block}.li-main small{font-size:12.5px;color:var(--muted)}.li-actions{display:flex;gap:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10241c73;display:grid;place-items:center;z-index:80;padding:20px;animation:fade .15s}.modal-backdrop[hidden]{display:none}.modal{background:#fff;border-radius:18px;width:100%;max-width:520px;max-height:90vh;overflow:auto;box-shadow:var(--shadow);animation:pop .18s}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}.modal-head h3{font-size:18px}.modal-close{background:none;border:none;font-size:18px;color:var(--muted);padding:4px 8px;border-radius:7px}.modal-close:hover{background:var(--bg-soft);color:var(--ink)}.modal-body{padding:24px}@keyframes pop{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fade{0%{opacity:0}to{opacity:1}}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 22px;border-radius:10px;font-size:14px;font-weight:500;z-index:90;box-shadow:var(--shadow);animation:up .25s}.toast[hidden]{display:none}@keyframes up{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.rec-banner{display:flex;align-items:center;gap:14px;background:var(--green);color:#fff;border-radius:var(--radius);padding:16px 20px;margin-bottom:20px}.rec-dot{width:12px;height:12px;border-radius:50%;background:#fff;animation:blink 1s infinite}@keyframes blink{50%{opacity:.3}}.rec-banner .rec-info{flex:1}.rec-banner strong{font-size:15px}.rec-banner small{display:block;opacity:.85;font-size:12.5px}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}.filters select,.filters input{border:1.5px solid var(--line);border-radius:9px;padding:8px 11px;font:inherit;font-size:13.5px;background:#fff}.muted{color:var(--muted)}.right{text-align:right}.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}@media (max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}@media (max-width:760px){.sidebar{transform:translate(-100%);transition:.2s;box-shadow:var(--shadow)}.app-shell.nav-open .sidebar{transform:translate(0)}.app-body{margin-left:0}.menu-btn{display:block}.app-main{padding:18px}.user-name{display:none}.field-row{grid-template-columns:1fr}}@media (max-width:520px){.kpi-grid{grid-template-columns:1fr}.topbar-actions #quickAdd{display:none}}@media print{.sidebar,.app-topbar,.view-actions,.filters,.menu-btn,.no-print{display:none!important}.app-body{margin-left:0}body{background:#fff}.app-main{padding:0;max-width:100%}.card{border:none;box-shadow:none;padding:0}table.data th{color:#000}}
