.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1.5rem;padding:.85rem 1.5rem;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f1f5f9cc;border-bottom:1px solid rgba(148,163,184,.25);box-shadow:0 6px 18px #0f172a0d;width:100%;left:0;right:0}.topbar__menu-toggle{display:none;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:none;border-radius:999px;background:linear-gradient(135deg,#1e40afeb,#0ea5e9d9);color:#f8fafc;cursor:pointer;box-shadow:0 12px 24px #2563eb40;transition:transform .15s ease,box-shadow .2s ease}.topbar__menu-toggle:hover,.topbar__menu-toggle:focus-visible{transform:translateY(-1px);box-shadow:0 16px 32px #2563eb4d;outline:none}.topbar__menu-icon{position:relative;width:1.4rem;height:.16rem;background:currentColor;border-radius:999px;transition:background .2s ease,transform .2s ease}.topbar__menu-icon:before,.topbar__menu-icon:after{content:"";position:absolute;left:0;width:100%;height:100%;background:currentColor;border-radius:999px;transition:transform .2s ease}.topbar__menu-icon:before{transform:translateY(-.4rem)}.topbar__menu-icon:after{transform:translateY(.4rem)}.topbar--menu-open .topbar__menu-icon{background:transparent}.topbar--menu-open .topbar__menu-icon:before{transform:translateY(0) rotate(45deg)}.topbar--menu-open .topbar__menu-icon:after{transform:translateY(0) rotate(-45deg)}.topbar__brand{font-weight:700;font-size:1.1rem;letter-spacing:.04em;color:#0f172a}.topbar__links{display:flex;align-items:center;gap:1rem;font-size:.95rem;color:#334155}.topbar__links a{position:relative;padding-bottom:.25rem}.topbar__links a:after{content:"";position:absolute;inset:auto 0 -.35rem;height:2px;background:linear-gradient(90deg,#38bdf8,#6366f1);transform:scaleX(0);transform-origin:center;transition:transform .2s ease}.topbar__links a:hover:after,.topbar__links a:focus-visible:after{transform:scaleX(1)}.topbar__account{margin-left:auto;display:flex;align-items:center;gap:1rem;font-size:.9rem;color:#475569}.topbar__user{display:flex;gap:.35rem;align-items:baseline}.topbar__user span{color:#2563eb;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.topbar__logout,.topbar__login{border:none;border-radius:999px;padding:.45rem 1.1rem;font-size:.85rem;font-weight:600;background:linear-gradient(120deg,#2563eb,#38bdf8);color:#f8fafc;box-shadow:0 10px 20px #2563eb40;transition:transform .15s ease,box-shadow .2s ease}.topbar__logout:hover,.topbar__logout:focus-visible,.topbar__login:hover,.topbar__login:focus-visible{transform:translateY(-1px);box-shadow:0 12px 24px #2563eb4d;outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(max-width:900px){.topbar{gap:1rem}.topbar__links{flex-wrap:wrap}}@media(max-width:720px){.topbar{flex-wrap:wrap;gap:.5rem}.topbar__menu-toggle{display:inline-flex}.topbar__links{order:3;width:100%;display:none;flex-direction:column;align-items:flex-start;gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(148,163,184,.25)}.topbar--menu-open .topbar__links{display:flex}.topbar__links a{width:100%}.topbar__account{order:2;margin-left:auto;width:auto;justify-content:flex-end;gap:.6rem;white-space:nowrap;min-width:0}.topbar__user{font-size:.85rem}.topbar__user span{font-size:.75rem}.topbar__logout,.topbar__login{padding:.4rem .95rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:3rem 1.5rem;font-family:Inter,Segoe UI,sans-serif;background:radial-gradient(circle at top,#38bdf829,#0ea5e90f),linear-gradient(180deg,#f8fafcf2,#f1f5f9d9)}.login-card{width:min(420px,100%);background:#fffffff2;border-radius:20px;padding:2.5rem 2.25rem;box-shadow:0 24px 48px #0f172a29;border:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;gap:2rem;color:#0f172a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-header{display:flex;flex-direction:column;gap:.5rem;text-align:left}.login-eyebrow{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#0ea5e9}.login-title{margin:0;font-size:clamp(1.75rem,2vw + 1.5rem,2.25rem);font-weight:600}.login-subtitle{margin:0;color:#475569;font-size:.98rem;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-field{display:flex;flex-direction:column;gap:.45rem}.form-field label{font-size:.9rem;font-weight:600;color:#0f172a}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper input{width:100%;padding:.85rem 1rem;border-radius:12px;border:1px solid rgba(148,163,184,.35);background:#ffffffe6;font-size:1rem;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.input-wrapper input:focus{outline:none;border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 4px #0ea5e926}.login-actions{display:flex;flex-direction:column;gap:.75rem}.login-button{appearance:none;border:none;border-radius:999px;padding:.9rem 1rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#38bdf8,#0ea5e9);cursor:pointer;box-shadow:0 18px 30px #0ea5e947;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 22px 40px #0ea5e952}.login-button:disabled{cursor:not-allowed;filter:grayscale(.2);opacity:.8}.login-assist{font-size:.85rem;color:#64748b}.login-message{margin:0;font-size:.92rem;padding:.75rem .9rem;border-radius:12px;border:1px solid transparent;display:flex;align-items:center;gap:.5rem;background:#94a3b81a}.login-message:before{content:attr(data-icon);font-size:1.1rem}.login-message--loading{color:#0c4a6e;border-color:#0ea5e940;background:#38bdf81f}.login-message--error{color:#b91c1c;border-color:#f8717159;background:#fee2e2b3}.login-message--success{color:#166534;border-color:#4ade804d;background:#dcfce7b3}@media(max-width:600px){.login-card{padding:2rem 1.75rem;gap:1.75rem}.login-title{font-size:1.9rem}}.tracker{flex:1;display:flex;justify-content:center;padding:clamp(1.5rem,4vw,3rem)}.tracker__card{width:min(960px,100%);display:flex;flex-direction:column;gap:2rem;background:#f8fafce0;border-radius:28px;padding:clamp(1.75rem,3vw,2.75rem);box-shadow:0 30px 60px #0f172a1f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.25)}.tracker__header{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.tracker__eyebrow{text-transform:uppercase;font-size:.75rem;font-weight:600;letter-spacing:.26em;color:#64748b;margin:0 0 .35rem}.tracker__title{margin:0;font-size:clamp(1.85rem,4vw,2.35rem);font-weight:700;color:#0f172a}.tracker__date{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;font-weight:600;color:#475569}.tracker__date input{appearance:none;border:1px solid rgba(148,163,184,.5);border-radius:14px;padding:.65rem 1rem;font-size:.95rem;color:#0f172a;background:#ffffffd9;box-shadow:inset 0 1px 2px #0f172a0d}.tracker__table{display:flex;flex-direction:column;gap:1rem}.tracker__table-head{display:grid;grid-template-columns:minmax(200px,1.6fr) minmax(90px,.7fr) 48px;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:#94a3b8;padding:0 .25rem}.tracker__table-body{display:flex;flex-direction:column;gap:.85rem}.tracker__row{display:grid;grid-template-columns:minmax(200px,1.6fr) minmax(90px,.7fr) 48px;gap:.85rem;align-items:center;padding:.75rem .85rem;border-radius:16px;background:#ffffffbf;box-shadow:0 12px 24px #94a3b82e}.tracker__party-selector{display:flex;flex-direction:column;gap:.5rem}.tracker__party-label{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;font-weight:600;color:#475569}.tracker__table-head-actions{text-align:right}.tracker__control{width:100%;border:1px solid rgba(148,163,184,.45);border-radius:12px;padding:.6rem .75rem;font-size:.95rem;background:#ffffffe6;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease}.tracker__control:focus-visible{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf84d}.tracker__control--qty{text-align:center}.tracker__icon-button{border:none;border-radius:14px;width:36px;height:36px;display:grid;place-items:center;font-size:1rem;font-weight:600;background:#e2e8f0e6;color:#ef4444;cursor:pointer;transition:transform .15s ease,background .2s ease}.tracker__icon-button:hover,.tracker__icon-button:focus-visible{outline:none;transform:translateY(-1px);background:#fee2e2e6}.tracker__add{align-self:flex-start;display:inline-flex;align-items:center;gap:.5rem;border:none;border-radius:999px;padding:.6rem 1.1rem;font-size:.9rem;font-weight:600;color:#2563eb;background:#dbeafeb3;box-shadow:inset 0 0 0 1px #2563eb1a;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.tracker__add span{font-size:1.1rem;display:grid;place-items:center;width:1.65rem;height:1.65rem;border-radius:999px;background:linear-gradient(120deg,#2563eb,#38bdf8);color:#fff}.tracker__add:hover,.tracker__add:focus-visible{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #2563eb40,0 14px 28px #2563eb26;outline:none}.tracker__debtor{display:flex;flex-wrap:wrap;gap:1rem 1.5rem;align-items:center;padding:1rem 1.25rem;border-radius:18px;background:#e2e8f073}.tracker__checkbox{display:flex;align-items:center;gap:.65rem;font-size:.9rem;font-weight:600;color:#334155}.tracker__checkbox input{width:18px;height:18px;accent-color:#2563eb}.tracker__paid{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;color:#475569}.tracker__paid-label{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;font-weight:600}.tracker__paid-due{font-size:.8rem;color:#b91c1c;white-space:nowrap}.tracker__paid input{border:1px solid rgba(148,163,184,.5);border-radius:10px;padding:.45rem .75rem;background:#ffffffe6;font-size:.9rem}.tracker__footer{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between}.tracker__total{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.25rem;border-radius:20px;background:linear-gradient(135deg,#1d4ed8,#38bdf8);color:#f8fafc;box-shadow:0 18px 32px #1d4ed840}.tracker__total span{font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;opacity:.85}.tracker__total strong{font-size:clamp(1.3rem,3vw,1.6rem);font-weight:700}.tracker__actions{display:flex;flex-wrap:wrap;gap:.8rem}.tracker__button{border:none;border-radius:16px;padding:.8rem 1.8rem;font-size:.95rem;font-weight:600;background:linear-gradient(120deg,#2563eb,#6366f1);color:#f8fafc;cursor:pointer;box-shadow:0 18px 32px #4f46e540;transition:transform .15s ease,box-shadow .2s ease}.tracker__button:hover,.tracker__button:focus-visible{outline:none;transform:translateY(-1px);box-shadow:0 22px 36px #4f46e547}.tracker__message{display:flex;align-items:center;gap:.85rem;margin:0;padding:1rem 1.25rem;border-radius:18px;border:1px solid rgba(148,163,184,.25);background:#e2e8f08c;color:#0f172a;font-size:.95rem;box-shadow:0 16px 32px #94a3b82e}.tracker__message-icon{display:grid;place-items:center;width:2.35rem;height:2.35rem;border-radius:16px;font-size:1.2rem;font-weight:600;background:#fffc;box-shadow:inset 0 0 0 1px #94a3b840}.tracker__message-body{flex:1;line-height:1.5}.tracker__message--loading{background:linear-gradient(120deg,#e2e8f0b3,#e2e8f066);border-color:#94a3b873}.tracker__message--success{background:linear-gradient(120deg,#bbf7d0d9,#a7f3d0a6);border-color:#10b98159;color:#065f46}.tracker__message--success .tracker__message-icon{background:#ecfdf5e6;box-shadow:inset 0 0 0 1px #10b9814d}.tracker__message--error{background:linear-gradient(120deg,#fee2e2d9,#fecacaa6);border-color:#f8717173;color:#991b1b}.tracker__message--error .tracker__message-icon{background:#fef2f2f2;box-shadow:inset 0 0 0 1px #f8717159}.tracker__history{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem 1.75rem;border-radius:22px;background:#ffffffc7;border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 32px #94a3b82e}.tracker__history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.tracker__history-title{margin:0;font-size:clamp(1.35rem,3vw,1.8rem);font-weight:700;color:#0f172a}.tracker__history-subtitle{margin:.35rem 0 0;font-size:.9rem;color:#475569;max-width:32rem}.tracker__history-badge{align-self:flex-start;padding:.35rem .8rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#2563eb;background:#dbeafed9;box-shadow:inset 0 0 0 1px #2563eb2e}.tracker__history-table-wrapper{border-radius:20px;border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 32px #94a3b82e;background:#f8fafcd9;overflow:hidden;overflow-x:auto}.tracker__history-table{width:100%;min-width:680px;border-collapse:separate;border-spacing:0}.tracker__history-table thead{background:#0f172a0d}.tracker__history-table thead th{padding:.95rem 1.2rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#64748b}.tracker__history-row{--tracker-history-row-bg: rgba(255, 255, 255, .96)}.tracker__history-table tbody tr{background:var(--tracker-history-row-bg, rgba(255, 255, 255, .96));transition:transform .15s ease,box-shadow .2s ease}.tracker__history-table tbody tr:first-child{border-top:none}.tracker__history-table tbody tr+tr{border-top:1px solid rgba(148,163,184,.18)}.tracker__history-table tbody tr:hover{transform:translateY(-1px);box-shadow:0 12px 24px #94a3b833}.tracker__history-row--due .tracker__history-cell--due{color:#b91c1c}.tracker__history-row--group-0{--tracker-history-row-bg: rgba(240, 249, 255, .96)}.tracker__history-row--group-1{--tracker-history-row-bg: rgba(238, 242, 255, .95)}.tracker__history-row--group-2{--tracker-history-row-bg: rgba(245, 243, 255, .95)}.tracker__history-row--group-3{--tracker-history-row-bg: rgba(240, 249, 255, .95)}.tracker__history-cell--order{font-variant-numeric:tabular-nums;font-weight:600;color:#334155}.tracker__history-cell{padding:.95rem 1.2rem;font-size:.95rem;color:#0f172a;vertical-align:middle}.tracker__history-cell--qty,.tracker__history-cell--amount,.tracker__history-cell--due{font-variant-numeric:tabular-nums;font-weight:600;color:#1e293b}.tracker__history-cell--amount,.tracker__history-cell--due{text-align:right}.tracker__history-due-button{border:none;background:transparent;color:inherit;font:inherit;font-weight:700;cursor:pointer;padding:.15rem .35rem;border-radius:10px;transition:background .2s ease,transform .15s ease}.tracker__history-due-button:hover,.tracker__history-due-button:focus-visible{outline:none;background:#f8717126;transform:translateY(-1px)}.tracker__history-status{margin:0;padding:.75rem 1rem;border-radius:14px;background:#e2e8f08c;color:#0f172a;font-size:.9rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.tracker__history-status button{border:none;border-radius:999px;padding:.4rem .95rem;font-size:.8rem;font-weight:600;color:#2563eb;background:#dbeafee6;cursor:pointer;box-shadow:inset 0 0 0 1px #2563eb33;transition:background .2s ease,transform .15s ease}.tracker__history-status button:hover,.tracker__history-status button:focus-visible{outline:none;background:#bfdbfee6;transform:translateY(-1px)}.tracker__history-status--error{background:#fee2e2a6;color:#991b1b}.tracker__history-status--error button{color:#b91c1c;background:#fed7d7e6;box-shadow:inset 0 0 0 1px #f8717133}.tracker__history-status--error button:hover,.tracker__history-status--error button:focus-visible{background:#fecacaf2}@media(max-width:900px){.tracker__table-head,.tracker__row{grid-template-columns:minmax(140px,1.4fr) minmax(80px,.7fr) minmax(160px,1.2fr) 40px}}@media(max-width:720px){.tracker{padding:1.25rem}.tracker__table-head{display:none}.tracker__row{grid-template-columns:1fr;padding:1rem;gap:.65rem}.tracker__icon-button{justify-self:flex-end}.tracker__history{padding:1.25rem}.tracker__history-table{min-width:600px}}@media(max-width:480px){.tracker__card{padding:1.25rem;border-radius:22px}.tracker__footer{flex-direction:column;align-items:stretch}.tracker__total{align-items:center}.tracker__actions{flex-direction:column}}.tracker__dialog{position:fixed;inset:0;background:#0f172a66;display:grid;place-items:center;padding:1.5rem;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tracker__dialog-card{width:min(420px,100%);display:flex;flex-direction:column;gap:1.25rem;padding:1.75rem;border-radius:20px;background:#f8fafcf5;border:1px solid rgba(148,163,184,.3);box-shadow:0 24px 48px #0f172a40}.tracker__dialog-title{margin:0;font-size:1.35rem;font-weight:700;color:#0f172a}.tracker__dialog-description{margin:0;font-size:.95rem;color:#475569;line-height:1.6}.tracker__dialog-description p{margin:.25rem 0}.tracker__dialog-field{display:flex;flex-direction:column;gap:.55rem}.tracker__dialog-field label{font-size:.9rem;font-weight:600;color:#1e293b}.tracker__dialog-field-input{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;border-radius:14px;background:#f1f5f9d9;border:1px solid rgba(148,163,184,.45)}.tracker__dialog-field-input input{flex:1;border:none;background:transparent;font-size:1rem;font-weight:600;color:#0f172a;outline:none}.tracker__dialog-field-input input:disabled{color:#0f172a99}.tracker__dialog-field-input span{font-size:.85rem;font-weight:600;color:#475569}.tracker__dialog-field-hint{margin:0;font-size:.8rem;color:#64748b}.tracker__dialog-error{margin:0;padding:.6rem .85rem;border-radius:12px;background:#fee2e2cc;color:#b91c1c;font-size:.85rem}.tracker__dialog-buttons{display:flex;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.tracker__dialog-buttons--stack{flex-direction:column;align-items:stretch}.tracker__dialog-button{border:none;border-radius:14px;padding:.75rem 1.35rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,opacity .2s ease}.tracker__dialog-button:disabled{opacity:.65;cursor:not-allowed}.tracker__dialog-button--primary{background:linear-gradient(120deg,#2563eb,#6366f1);color:#f8fafc;box-shadow:0 18px 32px #4f46e540}.tracker__dialog-button--primary:hover:not(:disabled),.tracker__dialog-button--primary:focus-visible:not(:disabled){transform:translateY(-1px);box-shadow:0 22px 36px #4f46e547;outline:none}.tracker__dialog-button--secondary{background:#e2e8f0d9;color:#334155;box-shadow:inset 0 0 0 1px #94a3b859}.tracker__dialog-button--secondary:hover:not(:disabled),.tracker__dialog-button--secondary:focus-visible:not(:disabled){transform:translateY(-1px);box-shadow:inset 0 0 0 1px #94a3b873;outline:none}.tracker__dialog-button--accent{background:#f472b62e;color:#be185d;box-shadow:inset 0 0 0 1px #ec489959}.tracker__dialog-button--accent:hover:not(:disabled),.tracker__dialog-button--accent:focus-visible:not(:disabled){transform:translateY(-1px);box-shadow:inset 0 0 0 1px #db277773;outline:none}.admin-dashboard{padding:2.5rem;display:flex;flex-direction:column;gap:2rem;font-family:Inter,Segoe UI,sans-serif;background-color:#f8fafc;min-height:100vh;color:#0f172a}.admin-loading,.admin-error{padding:2.5rem;font-family:Inter,Segoe UI,sans-serif;color:#0f172a}.admin-error{color:#dc2626}.dashboard-header h2{font-size:1.875rem;font-weight:600;margin-bottom:.25rem}.dashboard-subtitle{color:#475569;font-size:.95rem}.summary-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{background:linear-gradient(135deg,#fff,#f1f5f9);border-radius:14px;padding:1.25rem 1.5rem;box-shadow:0 15px 30px #0f172a0d;border:1px solid rgba(148,163,184,.25);transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0ea5e92e}.summary-card__title{font-size:.9rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.summary-card__value{margin-top:.5rem;font-size:1.75rem;font-weight:600;color:#0369a1}.chart-card,.table-card{background:#fff;border-radius:18px;padding:1.75rem;box-shadow:0 18px 36px #0f172a14;border:1px solid rgba(148,163,184,.25)}.card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.25rem}.card-header h3{font-size:1.2rem;font-weight:600;color:#0f172a}.card-meta{font-size:.85rem;color:#64748b}.chart-wrapper{width:100%;height:320px}.tables-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.dashboard-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.95rem;color:#0f172a}.dashboard-table thead{background:linear-gradient(135deg,#0ea5e91f,#0ea5e905)}.dashboard-table th,.dashboard-table td{padding:.85rem 1rem;border-bottom:1px solid rgba(226,232,240,.8)}.dashboard-table tbody tr:hover{background-color:#0ea5e914}.dashboard-table tbody tr:last-child td{border-bottom:none}.empty-row td{text-align:center;color:#94a3b8;font-style:italic}@media(max-width:768px){.admin-dashboard{padding:1.5rem}.chart-wrapper{height:260px}}:root{--party-bg: #f7f9fc;--party-border: #d9e0ea;--party-primary: #0f8cf2;--party-primary-dark: #0c6cc1;--party-danger: #dc3545;--party-danger-dark: #b02a37;--party-text: #1f2933;--party-muted: #5a6a7d;--party-radius-lg: 24px;--party-radius-md: 12px;--party-shadow: 0 18px 40px rgba(15, 140, 242, .08);--party-shadow-soft: 0 16px 32px rgba(15, 23, 42, .08)}.admin-parties-page{padding:48px 24px 64px;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(160deg,#eef5ff,#fff 40%);min-height:100vh;box-sizing:border-box}.admin-parties-shell{margin:0 auto;max-width:1080px}.admin-parties-card{background:#ffffffe0;border-radius:var(--party-radius-lg);border:1px solid rgba(15,23,42,.06);box-shadow:var(--party-shadow-soft);padding:40px;display:flex;flex-direction:column;gap:32px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.party-header{display:flex;flex-direction:column;gap:20px}@media(min-width:640px){.party-header{flex-direction:row;align-items:center;justify-content:space-between}}.party-heading{display:flex;flex-direction:column;gap:6px}.party-subtitle{font-size:.75rem;letter-spacing:.48em;text-transform:uppercase;color:#2f74c0;font-weight:600}.party-title{margin:0;font-size:clamp(1.9rem,2.4vw,2.4rem);font-weight:600;color:var(--party-text)}.admin-parties-page .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-size:.95rem;border-radius:999px;padding:12px 20px;border:none;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;box-shadow:none}.admin-parties-page .btn:disabled{cursor:not-allowed;opacity:.6}.admin-parties-page .btn--pill{padding:12px 24px;box-shadow:var(--party-shadow)}.admin-parties-page .btn--primary{background:var(--party-primary);color:#fff}.admin-parties-page .btn--primary:hover{background:var(--party-primary-dark);transform:translateY(-1px);box-shadow:0 16px 28px #0f8cf23d}.admin-parties-page .btn--secondary{background:#fff;color:var(--party-muted);border:1px solid var(--party-border)}.admin-parties-page .btn--secondary:hover{background:#f3f6fb;color:var(--party-text)}.admin-parties-page .btn--danger{background:var(--party-danger);color:#fff;box-shadow:0 10px 24px #dc354533}.admin-parties-page .btn--danger:hover{background:var(--party-danger-dark)}.modal-title{font-size:1.1rem;margin:0;font-weight:600;color:var(--party-text)}.modal-close{border:none;background:transparent;border-radius:50%;padding:6px;color:var(--party-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.modal-close:hover{background:#0f8cf21f;color:var(--party-primary)}.party-form{display:flex;flex-direction:column;gap:18px}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:.85rem;font-weight:600;color:var(--party-muted)}.required{color:var(--party-danger);margin-left:4px}.form-input,.form-textarea{border-radius:12px;border:1px solid var(--party-border);padding:12px 14px;font-size:.95rem;font-family:inherit;color:var(--party-text);background:#fff;transition:border .14s ease,box-shadow .14s ease}.form-input:focus,.form-textarea:focus{border-color:var(--party-primary);box-shadow:0 0 0 3px #0f8cf22e;outline:none}.form-textarea{resize:vertical;min-height:120px}.field-grid{display:grid;gap:18px}@media(min-width:720px){.field-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.form-actions{display:flex;justify-content:flex-end}.party-table-card{border-radius:20px;border:1px solid rgba(15,23,42,.08);background:#fffffff0;overflow:hidden}.party-table-wrapper{width:100%;overflow-x:auto}.party-table{width:100%;border-collapse:collapse;min-width:720px}.party-table thead{background:#f2f6fb;color:var(--party-muted);text-transform:uppercase;font-size:.78rem;letter-spacing:.08em}.party-table th,.party-table td{padding:18px 20px;text-align:left;border-bottom:1px solid rgba(15,23,42,.06);background:transparent}.party-table td:last-child,.party-table th:last-child,.text-center{text-align:center}.party-table tbody tr:hover{background:#0f8cf20f}.party-table tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600;color:var(--party-text)}.cell-link{color:var(--party-primary-dark)}.cell-link::selection{background:#0f8cf23d;color:#fff}.table-actions{display:flex;justify-content:center;align-items:center;gap:12px}.icon-button{width:40px;height:40px;border-radius:50%;border:1px solid rgba(15,140,242,.25);background:#fff;color:var(--party-primary-dark);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease,background .15s ease,color .15s ease,border .15s ease}.icon-button:hover{transform:translateY(-1px);background:#0f8cf21a}.icon-button--danger{border-color:#dc35454d;color:var(--party-danger)}.icon-button--danger:hover{background:#dc35451f}.icon{width:18px;height:18px}.party-table-empty{text-align:center;padding:48px 20px;color:var(--party-muted);font-size:.95rem}.status-message{display:flex;align-items:center;gap:12px;border-radius:16px;padding:14px 18px;font-size:.95rem;font-weight:500;color:var(--party-text);border:1px solid rgba(15,23,42,.08);background:#0f172a0d;box-shadow:0 12px 24px #0f172a0d}.status-message__icon{font-size:1.2rem;line-height:1}.status-message__text{flex:1}.status-message--success{background:#22c55e1f;color:#166534;border-color:#22c55e47;box-shadow:0 12px 24px #22c55e1f}.status-message--error{background:#ef44441f;color:#b91c1c;border-color:#ef44444d;box-shadow:0 12px 24px #ef444424}.status-message--loading{background:#0f8cf224;color:var(--party-primary-dark);border-color:#0f8cf252;box-shadow:0 12px 24px #0f8cf22e}.status-message--info{background:#0f172a0f;color:var(--party-text)}.confirm-dialog{display:flex;flex-direction:column;gap:24px}.confirm-copy{font-size:.95rem;color:var(--party-muted);line-height:1.6}.confirm-strong{font-weight:600;color:var(--party-text)}.confirm-actions{display:flex;justify-content:flex-end;gap:12px}@media(max-width:640px){.admin-parties-card{padding:28px 22px}.party-table{min-width:640px}.admin-parties-page .btn--pill{width:100%;justify-content:center}.party-header{gap:16px}}:root{--products-bg: #f5f9ff;--products-border: #d9e0ea;--products-primary: #2563eb;--products-primary-dark: #1d4ed8;--products-success: #16a34a;--products-danger: #dc2626;--products-accent: #0ea5e9;--products-accent-strong: #0369a1;--products-text: #1f2937;--products-muted: #64748b;--products-card-bg: rgba(255, 255, 255, .92);--products-radius-lg: 24px;--products-radius-md: 12px;--products-shadow: 0 18px 40px rgba(37, 99, 235, .12);--products-shadow-soft: 0 22px 44px rgba(15, 23, 42, .12)}.admin-products-page{padding:48px 24px 64px;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;background:linear-gradient(160deg,#e2ecff,#fff 45%);box-sizing:border-box}.admin-products-shell{margin:0 auto;max-width:1080px}.admin-products-card{background:var(--products-card-bg);border-radius:var(--products-radius-lg);border:1px solid rgba(15,23,42,.06);box-shadow:var(--products-shadow-soft);padding:40px;display:flex;flex-direction:column;gap:28px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.products-header{display:flex;flex-direction:column;gap:18px}@media(min-width:640px){.products-header{flex-direction:row;align-items:center;justify-content:space-between}}.products-controls{display:flex;flex-wrap:wrap;gap:12px}.products-heading{display:flex;flex-direction:column;gap:6px}.products-subtitle{font-size:.75rem;letter-spacing:.46em;text-transform:uppercase;color:#1d4ed8;font-weight:600}.products-title{margin:0;font-size:clamp(1.9rem,2.4vw,2.4rem);font-weight:600;color:var(--products-text)}.status-banner{border-radius:var(--products-radius-md);padding:14px 18px;background:#2563eb14;color:var(--products-text);font-weight:500}.status-banner.error{background:#dc262614;color:var(--products-danger)}.products-table-wrapper{width:100%;overflow-x:auto}.products-table{width:100%;border-collapse:collapse;background:#ffffffe6;border-radius:var(--products-radius-md);overflow:hidden;box-shadow:var(--products-shadow);min-width:640px}.products-name{font-weight:600;color:var(--products-text)}.products-brand{color:var(--products-muted);font-size:.9rem;margin-top:4px}.products-sku{color:var(--products-muted);font-size:.85rem;margin-top:2px}.products-table thead{background:#2563eb14;color:var(--products-text)}.products-table th,.products-table td{padding:16px 20px;text-align:left;border-bottom:1px solid rgba(15,23,42,.06)}.products-table tbody tr:last-child td{border-bottom:none}.products-table tbody tr:hover{background:#2563eb0a}.products-qty{font-variant-numeric:tabular-nums;font-weight:600;color:var(--products-text)}.products-actions-header,.products-actions-cell{text-align:center}.products-actions-header{display:flex;align-items:center;justify-content:center}.products-actions-cell{display:flex;justify-content:center}.products-actions{display:grid;gap:12px;justify-content:center;width:min(100%,560px);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.products-actions .btn{width:100%}@media(max-width:479px){.products-actions{width:100%;grid-template-columns:minmax(0,1fr)}}@media(min-width:1024px){.products-actions{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:max-content;width:max-content}.products-actions .btn{width:auto;min-width:0}}.admin-products-page .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-size:.95rem;border-radius:999px;padding:11px 20px;border:none;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;box-shadow:none;background:#eff3fb;color:var(--products-text)}.admin-products-page .btn:disabled{cursor:not-allowed;opacity:.6}.admin-products-page .btn--primary{background:var(--products-primary);color:#fff;box-shadow:0 16px 32px #2563eb2e}.admin-products-page .btn--primary:hover{background:var(--products-primary-dark);transform:translateY(-1px)}.admin-products-page .btn--secondary{background:#fff;color:var(--products-muted);border:1px solid var(--products-border)}.admin-products-page .btn--secondary:hover{background:#f3f6fb;color:var(--products-text)}.admin-products-page .btn--accent{background:#0ea5e91f;color:var(--products-accent-strong);border:1px solid rgba(14,165,233,.28)}.admin-products-page .btn--accent:hover{background:var(--products-accent);color:#fff;box-shadow:0 16px 32px #0ea5e933;transform:translateY(-1px)}.admin-products-page .btn--danger{background:#dc262614;color:var(--products-danger);border:1px solid rgba(220,38,38,.18)}.admin-products-page .btn--danger:hover{background:var(--products-danger);color:#fff;box-shadow:0 16px 32px #dc26262e;transform:translateY(-1px)}.products-empty{padding:24px;text-align:center;color:var(--products-muted);font-weight:500}.loading-block{padding:32px;text-align:center;color:var(--products-muted);font-weight:600}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:30;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-dialog{width:min(520px,100%);background:#fff;border-radius:20px;box-shadow:0 28px 60px #0f172a2e;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(15,23,42,.08)}.modal-title{font-size:1.1rem;margin:0;font-weight:600;color:var(--products-text)}.modal-close{border:none;background:transparent;border-radius:50%;padding:6px;color:var(--products-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.modal-close:hover{background:#2563eb1f;color:var(--products-primary)}.modal-body{padding:24px}.stock-form,.product-form{display:flex;flex-direction:column;gap:18px}.stock-form .field-group,.product-form .field-group{display:flex;flex-direction:column;gap:6px}.stock-form label,.product-form label{font-weight:600;color:var(--products-text)}.stock-form input,.stock-form textarea,.product-form input{padding:12px 14px;border-radius:12px;border:1px solid rgba(15,23,42,.1);font-size:1rem;font-family:inherit;color:var(--products-text)}.stock-form textarea{min-height:90px;resize:vertical}.stock-form input:focus,.stock-form textarea:focus,.product-form input:focus{outline:2px solid rgba(37,99,235,.4);border-color:transparent}.stock-form-actions,.product-form-actions{display:flex;gap:10px;justify-content:flex-end}.form-row{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.form-message{margin-top:16px;color:var(--products-muted);font-weight:500}.form-message.error{color:var(--products-danger)}.delete-confirm{display:flex;flex-direction:column;gap:14px;color:var(--products-text)}.delete-confirm p{margin:0;line-height:1.5}.delete-modal-actions{display:flex;justify-content:flex-end;gap:12px}.confirm-panel{margin-top:20px;padding:18px;border-radius:var(--products-radius-md);border:1px solid rgba(37,99,235,.18);background:#2563eb0f;display:flex;flex-direction:column;gap:12px}.confirm-panel strong{color:var(--products-text)}.confirm-panel-buttons{display:flex;gap:12px;justify-content:flex-end}.history-list{display:flex;flex-direction:column;gap:14px}.history-entry{padding:16px 18px;border-radius:var(--products-radius-md);border:1px solid rgba(15,23,42,.08);background:#fffffff0;display:grid;gap:6px}.history-entry .history-meta{display:flex;justify-content:space-between;font-size:.9rem;color:var(--products-muted)}.history-entry .history-delta{font-weight:700;font-size:1.1rem}.history-entry .history-delta.positive{color:var(--products-success)}.history-entry .history-delta.negative{color:var(--products-danger)}.history-entry .history-note{color:var(--products-text)}.history-empty{text-align:center;padding:24px 18px;color:var(--products-muted)}.history-loading{text-align:center;padding:24px 18px;color:var(--products-muted);font-weight:500}@media(max-width:640px){.products-table{min-width:0}.products-table th,.products-table td{padding:12px 14px}.form-row{grid-template-columns:1fr}}:root{--users-bg: radial-gradient( circle at top, #e0f2fe 0%, #eef2ff 55%, #f8fafc 100% );--users-card-bg: rgba(255, 255, 255, .94);--users-border: rgba(15, 23, 42, .08);--users-primary: #2563eb;--users-primary-dark: #1d4ed8;--users-success: #16a34a;--users-danger: #dc2626;--users-text: #0f172a;--users-muted: #64748b;--users-radius-lg: 28px;--users-radius-md: 14px;--users-shadow: 0 30px 60px rgba(37, 99, 235, .12)}.admin-users-page{min-height:100vh;background:var(--users-bg);padding:clamp(40px,6vw,72px) 20px 80px;display:flex;justify-content:center;box-sizing:border-box;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}.admin-users-shell{width:min(1100px,100%)}.admin-users-card{background:var(--users-card-bg);border:1px solid var(--users-border);border-radius:var(--users-radius-lg);box-shadow:var(--users-shadow);padding:clamp(32px,5vw,48px);display:flex;flex-direction:column;gap:32px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.users-header{display:flex;flex-direction:column;gap:24px}@media(min-width:860px){.users-header{flex-direction:row;justify-content:space-between;align-items:flex-end}}.users-heading{display:flex;flex-direction:column;gap:10px}.users-subtitle{text-transform:uppercase;font-size:.75rem;letter-spacing:.42em;font-weight:600;color:var(--users-primary-dark)}.users-title{margin:0;font-size:clamp(2rem,3vw,2.8rem);font-weight:600;color:var(--users-text)}.users-lead{margin:0;color:var(--users-muted);max-width:480px;line-height:1.6}.users-controls{display:flex;flex-wrap:wrap;gap:16px}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;color:var(--users-muted);font-weight:600}.control-input{min-height:44px;border-radius:var(--users-radius-md);border:1px solid var(--users-border);padding:0 16px;font-size:1rem;background:#f8fafcf2;color:var(--users-text);transition:border .2s ease,box-shadow .2s ease}.control-input:focus{outline:none;border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb33}.users-banner{border-radius:var(--users-radius-md);padding:14px 18px;font-weight:500;display:flex;align-items:center;gap:10px;background:#2563eb1a;color:var(--users-primary-dark)}.users-banner.error{background:#dc26261f;color:var(--users-danger)}.users-banner.success{background:#16a34a1f;color:var(--users-success)}.users-table-wrapper{border-radius:var(--users-radius-md);border:1px solid var(--users-border);overflow:hidden;background:#fffffff5}.users-table{width:100%;border-collapse:collapse;min-width:640px}.users-table thead{background:#2563eb14;color:var(--users-text)}.users-table th,.users-table td{padding:18px 22px;text-align:left;border-bottom:1px solid rgba(15,23,42,.06);vertical-align:middle}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover{background:#2563eb0d}.users-row--current,.users-table tbody tr.users-row--current:hover{background:#2563eb1f}.users-row--current .user-name{color:var(--users-primary-dark)}.user-pill{display:inline-flex;align-items:center;justify-content:center;margin-top:6px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;background:#2563eb24;color:var(--users-primary-dark);width:fit-content}.user-primary{display:flex;flex-direction:column;gap:6px}.user-name{font-weight:600;font-size:1rem;color:var(--users-text)}.user-email{color:var(--users-muted);font-size:.9rem}.role-select{min-width:160px;border-radius:var(--users-radius-md);border:1px solid var(--users-border);padding:10px 14px;font-size:.95rem;background:#f1f5f9f2;color:var(--users-text)}.role-select:disabled{opacity:.6;cursor:not-allowed}.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:999px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.status-pill--active{background:#16a34a1f;color:var(--users-success)}.status-pill--inactive{background:#dc26261a;color:var(--users-danger)}.users-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:var(--users-radius-md);font-weight:600;font-size:.95rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;border:none;background:transparent}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn--ghost{background:#0f172a0a;color:var(--users-text)}.btn--ghost:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #0f172a1f}.btn--outline{border:1px solid rgba(37,99,235,.4);color:var(--users-primary-dark);background:#ffffffe6}.btn--outline:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 24px #2563eb2e}.users-empty td{text-align:center;padding:32px 24px;color:var(--users-muted);font-weight:500}.column-actions{width:220px}@media(max-width:720px){.users-table{min-width:100%}.users-table-wrapper{overflow-x:auto}.column-actions{width:auto}}.invoice-generator{padding:32px 40px 56px;width:min(100%,1200px);margin:0 auto;color:#0f172a;min-width:0}.invoice-generator__header h1{margin:0 0 8px;font-size:28px;font-weight:700;letter-spacing:-.01em}.invoice-generator__header p{margin:0;color:#475569;line-height:1.6}.invoice-generator__panel{margin-top:32px;background:#fff;border-radius:24px;border:1px solid rgba(148,163,184,.25);box-shadow:0 18px 40px #0f172a14;padding:32px;width:100%}.invoice-generator__controls{display:flex;flex-direction:column}.invoice-generator__controls>*+*{margin-top:32px}.invoice-generator__field-group{display:grid;gap:24px;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr)}.invoice-generator__field{display:flex;flex-direction:column;gap:10px}.invoice-generator__field label{font-weight:600;font-size:15px;color:#0f172a}.invoice-generator__field input[type=search],.invoice-generator__field input[type=number]{height:52px;border-radius:14px;border:1px solid rgba(148,163,184,.35);padding:0 16px;font-size:15px;color:inherit;background:#f8fafc;transition:border-color .2s ease,box-shadow .2s ease}.invoice-generator__field input[type=search]:focus,.invoice-generator__field input[type=number]:focus{outline:none;border-color:#0ea5e9b3;box-shadow:0 0 0 3px #0ea5e926}.invoice-generator__hint{font-size:13px;color:#64748b}.invoice-generator__manual-row{display:flex;gap:12px;align-items:center}.invoice-generator__manual-row input{flex:1}.invoice-generator__button,.invoice-generator__primary,.invoice-generator__secondary,.invoice-generator__danger{border:none;border-radius:999px;font-weight:600;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;font-size:15px}.invoice-generator__primary,.invoice-generator__secondary,.invoice-generator__danger{padding:0 28px}.invoice-generator__primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;box-shadow:0 12px 24px #0ea5e940}.invoice-generator__primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.invoice-generator__primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 16px 32px #0ea5e94d}.invoice-generator__secondary{background:#0ea5e91f;color:#0369a1;border:1px solid rgba(14,165,233,.4)}.invoice-generator__secondary:disabled{opacity:.45;cursor:not-allowed}.invoice-generator__secondary:not(:disabled):hover{background:#0ea5e92e;border-color:#0ea5e98c}.invoice-generator__danger{background:linear-gradient(135deg,#f87171,#dc2626);color:#fff;border:none;padding:0 28px;box-shadow:0 12px 24px #ef444433}.invoice-generator__danger:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.invoice-generator__danger:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 16px 32px #ef444440}.invoice-generator__link{padding:8px 18px;background:#0ea5e91f;color:#0369a1;border-radius:999px}.invoice-generator__link:hover{background:#0ea5e933;color:#0f172a;box-shadow:inset 0 0 0 1px #0ea5e94d;cursor:pointer}.invoice-generator__selection{background:#f8fafc;border-radius:18px;border:1px solid rgba(148,163,184,.25);padding:20px 24px}.invoice-generator__selection-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;color:#0f172a}.invoice-generator__chips{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:12px}.invoice-generator__chip{display:inline-flex;align-items:center;gap:8px;background:#0ea5e91f;color:#0369a1;padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-weight:600}.invoice-generator__chip:hover{background:#0ea5e92e}.invoice-generator__empty{color:#64748b;font-size:14px}.invoice-generator__layout h3{margin:0 0 12px}.invoice-generator__layout-options{display:flex;flex-wrap:wrap;gap:12px}.invoice-generator__layout-option{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border-radius:16px;border:1px solid rgba(148,163,184,.45);font-weight:600;color:#0f172a;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.invoice-generator__layout-option input{display:none}.invoice-generator__layout-option.is-active{border-color:#0ea5e9e6;box-shadow:0 12px 24px #0ea5e940;background:#0ea5e91f}.invoice-generator__layout-option.is-disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.invoice-generator__actions{display:flex;gap:16px;flex-wrap:wrap}.invoice-generator__results{margin-top:0}.invoice-generator__results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.invoice-generator__spinner{font-size:14px;color:#0ea5e9}.invoice-generator__results-table-wrapper{border:1px solid rgba(148,163,184,.25);border-radius:18px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;max-width:100%}.invoice-generator__results-table{width:100%;border-collapse:collapse;font-size:14px;min-width:480px}.invoice-generator__results-table thead{background:#f1f5f9;text-transform:uppercase;letter-spacing:.04em;font-size:12px}.invoice-generator__results-table th,.invoice-generator__results-table td{padding:14px 18px;border-bottom:1px solid rgba(148,163,184,.18);color:#1e293b}.invoice-generator__results-table tbody tr:hover{background:#0ea5e914}.invoice-generator__loading-row{text-align:center;color:#475569}.align-right{text-align:right}.invoice-generator__flash{margin-top:32px;padding:16px 20px;border-radius:18px;border:1px solid transparent;font-weight:600}.invoice-generator__flash--error{background:#fef2f2;color:#b91c1c;border-color:#ef444466}.invoice-generator__flash--success{background:#f0fdf4;color:#15803d;border-color:#22c55e59}.invoice-generator__flash--info{background:#eff6ff;color:#1d4ed8;border-color:#3b82f666}.invoice-generator__preview{margin-top:36px;background:#f8fafc;border-radius:24px;border:1px solid rgba(148,163,184,.25);padding:32px;overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0;width:100%}.invoice-generator__placeholder{text-align:center;padding:60px 20px;color:#64748b}.invoice-generator__placeholder h3{margin-bottom:12px;color:#0f172a}.invoice-print-pages{display:flex;flex-direction:column;gap:32px;min-width:0}.invoice-print-page{background:#fff;border-radius:24px;border:1px solid rgba(148,163,184,.35);padding:28px;box-shadow:0 25px 55px #0f172a26;aspect-ratio:210 / 297;display:flex;width:min(100%,960px);margin:0 auto;min-width:0}.invoice-print-page .invoice-print-grid{flex:1}.invoice-print-grid{display:grid;gap:24px;min-width:0}.invoice-print-grid.layout-1{grid-template-columns:minmax(0,1fr)}.invoice-print-grid.layout-2{grid-template-columns:minmax(0,1fr);grid-auto-rows:minmax(320px,1fr)}.invoice-print-grid.layout-4{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(300px,1fr)}.invoice-card--placeholder{visibility:hidden}.invoice-card{background:#fff;border-radius:20px;border:1px solid rgba(148,163,184,.25);box-shadow:0 18px 40px #0f172a1a;padding:24px;display:flex;flex-direction:column;gap:20px;min-width:0}.invoice-card__header{display:flex;justify-content:space-between;gap:24px}.invoice-card__header h3{margin:0 0 6px;font-size:22px}.invoice-card__header p{margin:4px 0 0;color:#64748b;font-size:13px}.invoice-card__meta{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.invoice-card__label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.invoice-card__value{font-weight:600;color:#0f172a}.invoice-card__badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;font-weight:600;font-size:12px}.invoice-card__badge--paid{background:#22c55e1f;color:#166534}.invoice-card__badge--due{background:#ef44441f;color:#b91c1c}.invoice-card__party{display:flex;justify-content:space-between;gap:24px}.invoice-card__party h4{margin:6px 0;font-size:18px}.invoice-card__party p{margin:4px 0 0;color:#475569;line-height:1.5}.invoice-card__contact span{display:inline-block}.invoice-card__summary ul{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:8px}.invoice-card__summary li{display:flex;justify-content:space-between;gap:12px;color:#334155}.invoice-card__summary strong{font-size:15px}.invoice-card__table-wrapper{border:1px solid rgba(148,163,184,.2);border-radius:16px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:#fff;max-width:100%}.invoice-card__table{width:100%;border-collapse:collapse;font-size:13px;min-width:400px}.invoice-card__table thead{background:#f1f5f9}.invoice-card__table th,.invoice-card__table td{padding:10px 12px;border-bottom:1px solid rgba(148,163,184,.2)}.invoice-card__table tbody tr:last-child td{border-bottom:none}.invoice-card__footer{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;padding-top:12px;border-top:1px solid rgba(148,163,184,.2)}@media(max-width:960px){.invoice-generator{padding:24px 24px 48px}.invoice-generator__preview{padding:24px}.invoice-generator__field-group{grid-template-columns:1fr}.invoice-card__header,.invoice-card__party{flex-direction:column;align-items:flex-start}.invoice-card__meta{align-items:flex-start}.invoice-card__footer{grid-template-columns:1fr}}@media(max-width:640px){.invoice-print-page,.invoice-card{padding:20px}.invoice-card__table{min-width:360px}}@media(max-width:480px){.invoice-generator{padding:20px 16px 40px}.invoice-generator__panel,.invoice-generator__preview{padding:20px}.invoice-generator__results-table{min-width:360px}.invoice-card__table{min-width:320px}}@media print{@page{size:A4 portrait;margin:12mm}body{background:#fff}.topbar,.invoice-generator__header,.invoice-generator__panel,.invoice-generator__flash{display:none!important}.invoice-generator{padding:0;margin:0}.invoice-generator__preview{border:none;padding:0;background:transparent;box-shadow:none}.invoice-print-pages{gap:0}.invoice-print-page{padding:0;margin:0;border:none;box-shadow:none;background:transparent;display:block;aspect-ratio:auto;page-break-after:always;break-after:page}.invoice-print-page:last-child{page-break-after:auto;break-after:auto}.invoice-print-grid{gap:8mm;grid-auto-flow:row;height:273mm}.invoice-print-page .invoice-print-grid{width:100%;flex:none}.invoice-print-grid.layout-1{grid-template-columns:1fr;grid-template-rows:1fr}.invoice-print-grid.layout-2{grid-template-columns:1fr;grid-template-rows:repeat(2,1fr)}.invoice-print-grid.layout-4{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.invoice-card{box-shadow:none;border:1px solid rgba(148,163,184,.35);height:100%;page-break-inside:avoid}.invoice-print-page.layout-4{font-size:12px}.invoice-print-page.layout-4 .invoice-card{padding:20px}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#e0f2fe,#f8fafc 40%,#e2e8f0);color:inherit}a{color:inherit;text-decoration:none}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit}
