:root{--alpyme-royal:#0c2461;--alpyme-royal-mid:#1e3799;--alpyme-royal-light:#4a69bd;--alpyme-royal-soft:#e8eef9;--alpyme-white:#fff;--alpyme-page:#f4f6f9;--alpyme-border:#e2e8f0;--alpyme-text:#1e293b;--alpyme-text-muted:#64748b;--alpyme-shadow:0 1px 3px #0c246114;--alpyme-shadow-md:0 4px 14px #0c24611a;--alpyme-radius:6px;--alpyme-sidebar-w:240px;--font-sans:"Source Sans 3", system-ui, "Segoe UI", Roboto, sans-serif}*,:before,:after{box-sizing:border-box}html{font-family:var(--font-sans);color:var(--alpyme-text);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}body{background:var(--alpyme-page);min-height:100vh;margin:0}#root{text-align:left;border:none;width:100%;max-width:none;min-height:100vh;margin:0}.app-root{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--alpyme-white);border-bottom:3px solid var(--alpyme-royal);height:56px;box-shadow:var(--alpyme-shadow);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 1.25rem;display:flex}.app-header__brand{align-items:center;gap:.75rem;display:flex}.app-header__logo{border-radius:var(--alpyme-radius);background:linear-gradient(145deg, var(--alpyme-royal), var(--alpyme-royal-mid));width:40px;height:40px;color:var(--alpyme-white);letter-spacing:.02em;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.app-header__title{color:var(--alpyme-royal);letter-spacing:-.02em;margin:0;font-size:1.125rem;font-weight:600}.app-header__subtitle{color:var(--alpyme-text-muted);margin:0;font-size:.75rem}.app-header__actions{align-items:center;gap:.75rem;display:flex}.app-top-nav{align-items:center;gap:.35rem;margin:0 1rem;display:flex}.app-top-nav__btn{color:var(--alpyme-text);border-radius:var(--alpyme-radius);cursor:pointer;background:0 0;border:1px solid #0000;padding:.45rem .75rem;font-family:inherit;font-size:.92rem;font-weight:600}.app-top-nav__btn:hover{background:var(--alpyme-royal-soft);color:var(--alpyme-royal)}.app-top-nav__btn.is-active{background:var(--alpyme-royal);color:var(--alpyme-white)}.app-body{flex:1;min-height:0;display:flex}.app-sidebar{width:var(--alpyme-sidebar-w);background:var(--alpyme-white);border-right:1px solid var(--alpyme-border);flex-direction:column;flex-shrink:0;padding:1rem 0;display:flex}.app-sidebar__user{border-bottom:1px solid var(--alpyme-border);margin:0 .75rem 1rem;padding:.75rem 1rem 1rem;font-size:.875rem}.app-sidebar__user-name{color:var(--alpyme-royal);font-weight:600}.app-sidebar__user-role{color:var(--alpyme-text-muted);font-size:.75rem}.app-sidebar__section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--alpyme-text-muted);margin:0 1rem .35rem;font-size:.75rem;font-weight:700}.app-nav{flex-direction:column;gap:.25rem;padding:0 .5rem;display:flex}.app-nav__btn{border-radius:var(--alpyme-radius);width:100%;color:var(--alpyme-text);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.65rem .85rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex}.app-nav__btn:hover{background:var(--alpyme-royal-soft);color:var(--alpyme-royal)}.app-nav__btn.is-active{background:var(--alpyme-royal);color:var(--alpyme-white)}.app-nav__icon{opacity:.85;font-size:.95rem}.app-main{background:var(--alpyme-page);flex:1;padding:1.5rem;overflow:auto}@media (width<=900px){.app-header{flex-wrap:wrap;gap:.75rem;height:auto;padding:.75rem}.app-top-nav{flex-wrap:wrap;width:100%;margin:0}.app-top-nav__btn{flex:auto}.app-body{flex-direction:column}.app-sidebar{border-right:none;border-bottom:1px solid var(--alpyme-border);flex-flow:wrap;align-items:center;width:100%;padding:.75rem}.app-sidebar__user{width:100%;margin:0 0 .5rem;padding:.5rem .75rem}.app-nav{flex-flow:wrap;width:100%}.app-nav__btn{flex:auto;min-width:140px}}.panel{background:var(--alpyme-white);border-radius:var(--alpyme-radius);border:1px solid var(--alpyme-border);box-shadow:var(--alpyme-shadow);margin-bottom:1.25rem;overflow:hidden}.panel__header{background:var(--alpyme-white);border-bottom:1px solid var(--alpyme-border);color:var(--alpyme-royal);padding:.85rem 1.25rem;font-size:.95rem;font-weight:600}.panel__body{padding:1.25rem}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:start;gap:.75rem;margin-bottom:1rem;display:grid}.client-modal-form{flex-direction:column;gap:0;display:flex}.client-modal-form__rfc-name{grid-template-columns:minmax(9.5rem,12.5rem) minmax(0,1fr);align-items:start;gap:.75rem;margin-bottom:.75rem;display:grid}.client-modal-form__trade-street{grid-template-columns:2fr 8fr;align-items:start;gap:.75rem;margin-bottom:1rem;display:grid}.client-modal-form .form-grid{margin-bottom:1rem}@media (width<=640px){.client-modal-form__rfc-name,.client-modal-form__trade-street{grid-template-columns:1fr}}.form-legend{color:var(--alpyme-text-muted);margin:0 0 .75rem;font-size:.85rem;line-height:1.45}.form-legend strong{color:var(--alpyme-text);font-weight:600}.form-field{flex-direction:column;gap:.3rem;min-width:0;display:flex}.form-field__label{color:var(--alpyme-text);font-size:.8rem;font-weight:600}.form-field__req{color:#b45309;margin-left:.15rem;font-weight:700}.form-field__hint{color:var(--alpyme-text-muted);margin-left:.25rem;font-size:.72rem;font-weight:400}.input,.select{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-white);width:100%;color:var(--alpyme-text);padding:.55rem .75rem;font-family:inherit;font-size:.9rem}.input:focus,.select:focus{border-color:var(--alpyme-royal-light);box-shadow:0 0 0 3px var(--alpyme-royal-soft);outline:none}.btn{border-radius:var(--alpyme-radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.35rem;padding:.55rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s,box-shadow .15s;display:inline-flex}.btn--primary{background:var(--alpyme-royal);color:var(--alpyme-white)}.btn--primary:hover{background:var(--alpyme-royal-mid);box-shadow:var(--alpyme-shadow-md)}.btn--ghost{color:var(--alpyme-royal);border:1px solid var(--alpyme-border);background:0 0}.btn--ghost:hover{background:var(--alpyme-royal-soft)}.btn--danger{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;font-weight:600}.btn--danger:hover{background:#fee2e2}.table-list{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);overflow:hidden}.table-list__row{border-bottom:1px solid var(--alpyme-border);background:var(--alpyme-white);justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1rem;font-size:.9rem;display:flex}.table-list__row:last-child{border-bottom:none}.table-list__row:nth-child(2n){background:#fafbfc}.dual-role-badge{background:var(--alpyme-royal-soft);color:var(--alpyme-royal);letter-spacing:.01em;vertical-align:middle;border:1px solid #c9d6f0;border-radius:999px;align-items:center;gap:.25rem;margin-left:.5rem;padding:.08rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.dual-role-badge--button{cursor:pointer;font-family:inherit}.dual-role-badge--button:hover{background:#dce7fb}.catalog-toolbar{grid-template-columns:minmax(120px,15%) minmax(140px,15%) minmax(320px,1fr) minmax(130px,10%);align-items:center;gap:.75rem;margin-bottom:1rem;display:grid}.catalog-toolbar__create-btn{min-height:38px}.catalog-toolbar--clients{grid-template-columns:minmax(100px,10rem) minmax(0,1fr) max-content}.catalog-toolbar--clients .catalog-toolbar__create-btn{white-space:nowrap;justify-self:end;width:auto;min-width:0;max-width:11rem;padding-inline:.85rem}@media (width<=1100px){.catalog-toolbar{grid-template-columns:1fr 1fr 1fr}.catalog-toolbar__create-btn{grid-column:1/-1;justify-self:end;min-width:170px;width:auto!important}.catalog-toolbar--clients{grid-template-columns:minmax(0,.42fr) minmax(0,1fr) auto}.catalog-toolbar--clients .catalog-toolbar__create-btn{grid-column:auto;min-width:0;max-width:10.5rem}}@media (width<=680px){.catalog-toolbar{grid-template-columns:1fr}.catalog-toolbar__create-btn{grid-column:auto;justify-self:stretch;min-width:0;width:100%!important}.catalog-toolbar--clients{grid-template-columns:1fr}.catalog-toolbar--clients .catalog-toolbar__create-btn{justify-self:start;max-width:12rem;width:auto!important}}.alert{border-radius:var(--alpyme-radius);margin-top:1rem;padding:.75rem 1rem;font-size:.875rem}.alert--info{background:var(--alpyme-royal-soft);color:var(--alpyme-royal);border:1px solid #c9d6f0}.alert--danger{color:#912018;background:#fef3f2;border:1px solid #fecdca}.alert--success{color:#1e5c3a;background:#ecf8f0;border:1px solid #b8dfc8}.sat-inbox-toolbar{flex-wrap:wrap;align-items:center;gap:.55rem;margin-bottom:.75rem;display:flex}.sat-inbox-filters{grid-template-columns:minmax(280px,1fr) 170px 170px 150px;gap:.55rem;margin-bottom:.75rem;display:grid}.sat-inbox-meta{color:var(--alpyme-text-muted);margin-top:.3rem;font-size:.84rem}.sat-status-badge{color:var(--alpyme-royal);background:var(--alpyme-royal-soft);border:1px solid #c9d6f0;border-radius:999px;align-items:center;padding:.12rem .5rem;font-size:.76rem;font-weight:700;display:inline-flex}.sat-inbox-line-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:.45rem;display:grid}.sat-inbox-pagination{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-royal-soft);justify-content:space-between;align-items:center;gap:.5rem;margin-top:.75rem;padding:.55rem .75rem;display:flex}@media (width<=960px){.sat-inbox-filters{grid-template-columns:1fr 1fr}.sat-inbox-line-grid{grid-template-columns:1fr}}@media (width<=640px){.sat-inbox-filters{grid-template-columns:1fr}}.login-page{background:linear-gradient(165deg, var(--alpyme-royal-soft) 0%, var(--alpyme-page) 45%, var(--alpyme-white) 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;max-width:880px;display:grid}.login-card{background:var(--alpyme-white);border:1px solid var(--alpyme-border);box-shadow:var(--alpyme-shadow-md);border-radius:8px;overflow:hidden}.login-card__head{background:var(--alpyme-royal);color:var(--alpyme-white);padding:1rem 1.25rem;font-size:1rem;font-weight:600}.login-card__body{padding:1.25rem}.login-card__body .form-grid{margin-bottom:0}.login-brand{text-align:center;margin-bottom:2rem}.login-brand__badge{background:linear-gradient(145deg, var(--alpyme-royal), var(--alpyme-royal-mid));width:56px;height:56px;color:var(--alpyme-white);border-radius:12px;justify-content:center;align-items:center;margin-bottom:.75rem;font-size:1.1rem;font-weight:800;display:inline-flex}.login-brand h1{color:var(--alpyme-royal);letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.login-brand p{color:var(--alpyme-text-muted);margin:0;font-size:.95rem}.login-brand__company{color:var(--alpyme-royal);letter-spacing:.06em;text-transform:uppercase;margin:.65rem 0 0;font-size:1rem;font-weight:700;line-height:1.35}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--alpyme-white);border-radius:var(--alpyme-radius);width:100%;max-width:520px;max-height:min(90vh,720px);box-shadow:var(--alpyme-shadow-md);border:1px solid var(--alpyme-border);flex-direction:column;display:flex}.modal-dialog--catalog{max-width:920px}.modal-dialog--customer-invoice{width:min(96vw,1280px);max-width:min(96vw,1280px);min-height:0;max-height:min(92vh,900px)}.modal-dialog--customer-invoice .modal-dialog__body{min-height:0}.modal-dialog__header{border-bottom:1px solid var(--alpyme-border);background:linear-gradient(180deg, var(--alpyme-royal-soft), var(--alpyme-white));flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1.1rem;display:flex}.modal-dialog__header h2{color:var(--alpyme-royal);margin:0;font-size:1.05rem;font-weight:600}.modal-dialog__close{border-radius:var(--alpyme-radius);width:2rem;height:2rem;color:var(--alpyme-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.35rem;line-height:1;display:inline-flex}.modal-dialog__close:hover{background:var(--alpyme-border);color:var(--alpyme-text)}.modal-dialog__body{flex:1;padding:1rem 1.1rem;overflow:auto}.modal-dialog__footer{border-top:1px solid var(--alpyme-border);background:var(--alpyme-page);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:.5rem;padding:.85rem 1.1rem;display:flex}.customer-invoices-panel{flex-direction:column;width:100%;max-width:none;min-height:calc(100vh - 7.5rem);margin-bottom:0;display:flex}.customer-invoices-panel .customer-invoices-panel__body{flex-direction:column;flex:auto;gap:.75rem;min-height:0;display:flex}.customer-invoices-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem .75rem;display:flex}.customer-invoices-list-wrap{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-page);flex:auto;min-height:12rem;max-height:min(52vh,520px);overflow:auto}.customer-invoices-modal-inner{flex-direction:column;gap:.75rem;min-height:0;display:flex}.supplier-invoices-draft-list-wrap{border-radius:var(--alpyme-radius);max-height:min(52vh,480px);overflow-y:auto}button.customer-invoices-list-row.table-list__row{flex-direction:column;justify-content:flex-start;align-items:flex-start}.customer-invoices-lines{flex:auto;min-height:14rem;overflow:auto}.customer-invoices-lines-table{--ci-line-cols:minmax(10rem, 13rem) minmax(11rem, 1fr) 4.75rem 6.25rem 6.75rem minmax(9.5rem, 12rem);grid-template-columns:var(--ci-line-cols);align-items:start;gap:.65rem .75rem;width:100%;min-width:min(100%,46rem);display:grid}.customer-invoices-lines-table--editable{--ci-line-cols:minmax(10rem, 13rem) minmax(11rem, 1fr) 4.75rem 6.25rem 6.75rem minmax(9.5rem, 12rem) 4.5rem}@supports not (grid-template-columns:subgrid){.customer-invoices-lines-table{flex-direction:column;gap:.65rem;display:flex}.customer-invoice-line-head,.customer-invoice-line-row{grid-column:unset;grid-template-columns:var(--ci-line-cols)}}.customer-invoice-line-head,.customer-invoice-line-row{grid-template-columns:subgrid;grid-column:1/-1;align-items:start;display:grid}.customer-invoice-line-head{text-transform:uppercase;letter-spacing:.03em;color:var(--alpyme-text-muted);padding:0 .15rem .2rem;font-size:.78rem;font-weight:600}.customer-invoice-line-head__num{text-align:right}.customer-invoice-line-head__action{text-align:center}.customer-invoice-line-row>div{min-width:0}.customer-invoice-line-row__desc-input{width:100%;min-height:6.5rem;max-height:22rem;font:inherit;resize:vertical;border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-white);color:var(--alpyme-text);padding:.5rem .6rem;font-size:.92rem;line-height:1.45}.customer-invoice-line-row__desc-input:disabled{background:var(--alpyme-page);color:var(--alpyme-text-muted)}.customer-invoice-line-row__select,.customer-invoice-line-row__input{width:100%;max-width:100%;font:inherit;border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);padding:.35rem .45rem;font-size:.9rem}.customer-invoice-line-row__input--qty,.customer-invoice-line-row__input--price{text-align:right}.customer-invoice-line-row__amount{font-variant-numeric:tabular-nums;min-height:2rem;color:var(--alpyme-text);border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-page);justify-content:flex-end;align-items:center;padding:.35rem .45rem;font-size:.9rem;font-weight:600;display:flex}@media (width<=1100px){.customer-invoices-lines-table{min-width:0;display:block}.customer-invoice-line-head{display:none}.customer-invoice-line-row{border-bottom:1px solid var(--alpyme-border);grid-column:auto;padding-bottom:.75rem;display:block}.customer-invoice-line-row:last-child{border-bottom:none;padding-bottom:0}.customer-invoice-line-row .customer-invoice-line-row__field-label{color:var(--alpyme-text-muted);margin-bottom:.2rem;font-size:.78rem;font-weight:600;display:block}}@media (width>=1101px){.customer-invoice-line-row .customer-invoice-line-row__field-label{display:none}}.pyg-summary-grid{grid-template-columns:repeat(auto-fill,minmax(11.5rem,1fr));gap:.75rem;display:grid}.pyg-summary-card{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-white);flex-direction:column;gap:.25rem;padding:.75rem .85rem;display:flex}.pyg-summary-card--highlight{border-color:var(--alpyme-primary);background:color-mix(in srgb, var(--alpyme-primary) 6%, var(--alpyme-white))}.pyg-summary-card__label{color:var(--alpyme-text-muted);text-transform:uppercase;letter-spacing:.02em;font-size:.8rem}.pyg-summary-card__value,.pyg-amount{color:var(--alpyme-text);font-size:1.15rem;font-weight:700}.pyg-summary-card__meta{color:var(--alpyme-text-muted);font-size:.78rem}.pyg-amount--positive{color:#0d6b3a}.pyg-amount--negative{color:var(--alpyme-danger,#b42318)}.pyg-table{border-collapse:collapse;width:100%;font-size:.9rem}.pyg-table th,.pyg-table td{border-bottom:1px solid var(--alpyme-border);text-align:left;padding:.45rem .55rem}.pyg-table th{color:var(--alpyme-text-muted);font-size:.8rem;font-weight:600}.pyg-table__total td{background:var(--alpyme-page);border-bottom:none}
