/* Portal B2B — stiluri de bază */
*, *::before, *::after { box-sizing: border-box; }

body { font-family: system-ui, -apple-system, sans-serif; margin: 0; background: #f8f9fa; color: #212529; }

/* Navbar */
.navbar { display: flex; align-items: center; gap: 1.5rem; padding: .6rem 1.5rem;
    background: #1a3a5c; color: #fff; }
.navbar-brand a { color: #fff; font-size: 1.1rem; font-weight: 700; text-decoration: none; }
.navbar-links { display: flex; gap: 1rem; flex: 1; }
.navbar-links a { color: #cfe2f3; text-decoration: none; font-size: .9rem; }
.navbar-links a:hover { color: #fff; }
.navbar-user { display: flex; align-items: center; gap: 1rem; font-size: .85rem; }
.navbar-user a { color: #cfe2f3; text-decoration: none; }

/* Layout principal */
.main-content { max-width: 1200px; margin: 0 auto; padding: 1.5rem; }

/* Autentificare */
.auth-page { background: #eef2f7; min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.auth-container { width: 100%; max-width: 420px; }
.auth-card { background: #fff; border-radius: 8px; box-shadow: 0 2px 12px rgba(0,0,0,.12); padding: 2.5rem; }
.auth-card h1 { font-size: 1.4rem; color: #1a3a5c; margin: 0 0 .25rem; }
.auth-card h2 { font-size: 1rem; font-weight: 400; color: #6c757d; margin: 0 0 1.5rem; }
.form-group { margin-bottom: 1.2rem; }
.form-group label { display: block; font-size: .85rem; margin-bottom: .3rem; color: #495057; }
.form-control, .form-select { width: 100%; padding: .5rem .75rem; border: 1px solid #ced4da;
    border-radius: 4px; font-size: .95rem; }
.btn { display: inline-block; padding: .55rem 1.2rem; border: none; border-radius: 4px;
    cursor: pointer; font-size: .95rem; text-decoration: none; }
.btn-primary { background: #1a3a5c; color: #fff; }
.btn-primary:hover { background: #245180; }
.btn-secondary { background: #6c757d; color: #fff; }
.alert { padding: .75rem 1rem; border-radius: 4px; margin-bottom: 1rem; font-size: .9rem; }
.alert-success  { background: #d1e7dd; color: #0a3622; }
.alert-danger   { background: #f8d7da; color: #58151c; }
.alert-warning  { background: #fff3cd; color: #664d03; }

/* Dashboard */
.dashboard-carduri { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem; margin-top: 1.5rem; }
.dashboard-card { display: flex; flex-direction: column; gap: .4rem; padding: 1.5rem;
    background: #fff; border-radius: 8px; box-shadow: 0 1px 4px rgba(0,0,0,.08);
    text-decoration: none; color: inherit; transition: box-shadow .15s; }
.dashboard-card:hover { box-shadow: 0 3px 10px rgba(0,0,0,.15); }
.dashboard-card span:first-child { font-size: 2rem; }
.dashboard-card strong { font-size: 1rem; }

/* Client activ banner (Home) */
.client-activ-banner { display: flex; align-items: center; justify-content: space-between;
    gap: 1rem; padding: .75rem 1rem; background: #e8f0f7; border-radius: 6px;
    margin-bottom: 1.5rem; flex-wrap: wrap; }
.client-activ-info { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.client-activ-eticheta { font-size: .85rem; color: #6c757d; }

/* Selecție client */
.client-lista { display: flex; flex-direction: column; gap: .6rem; margin-top: 1.25rem; }
.client-card { display: flex; flex-direction: column; align-items: flex-start; gap: .15rem;
    padding: .9rem 1.1rem; background: #fff; border: 1px solid #dee2e6; border-radius: 6px;
    cursor: pointer; text-align: left; width: 100%; font-size: .95rem;
    transition: border-color .15s, box-shadow .15s; }
.client-card:hover { border-color: #1a3a5c; box-shadow: 0 2px 8px rgba(26,58,92,.12); }
.client-card strong { display: block; font-size: 1rem; color: #212529; }

/* Documente (Avize, Facturi) */
.doc-lista-info { font-size: .85rem; color: #6c757d; margin-bottom: .5rem; }
.doc-link { color: #1a3a5c; font-weight: 500; }
.doc-sumar td { font-weight: 600; background: #f1f3f5; border-top: 2px solid #dee2e6; }
.doc-antet { margin-bottom: 1.25rem; }
.doc-antet h2 { font-size: 1.2rem; font-weight: 600; margin: 0 0 .2rem; }
.doc-nav-inapoi { display: inline-block; margin-bottom: 1rem; color: #1a3a5c;
    text-decoration: none; font-size: .9rem; }
.doc-nav-inapoi:hover { text-decoration: underline; }

/* Butoane mici */
.btn-sm { padding: .3rem .7rem; font-size: .82rem; }

/* Selector punct de lucru (StocMinim, Inventar) */
.pdl-selector { max-width: 380px; margin-bottom: 1.25rem; }

/* Autocomplete (StocMinim, Inventar) */
.autocomplete-container { position: relative; }
.autocomplete-rezultate { position: absolute; z-index: 200; left: 0; right: 0;
    background: #fff; border: 1px solid #ced4da; border-top: none; border-radius: 0 0 4px 4px;
    max-height: 220px; overflow-y: auto; box-shadow: 0 4px 10px rgba(0,0,0,.1); }
.autocomplete-result-item { padding: .5rem .75rem; cursor: pointer; font-size: .9rem;
    border-bottom: 1px solid #f1f3f5; }
.autocomplete-result-item:last-child { border-bottom: none; }
.autocomplete-result-item:hover { background: #e8f0f7; }

/* Stoc minim — adăugare produs */
.stoc-adauga-produs { max-width: 450px; margin-bottom: 1.25rem; }
.stoc-adauga-produs label { display: block; font-size: .85rem; color: #495057; margin-bottom: .3rem; }

/* Stoc minim — celulă cantitate și confirmare */
.cantitate-input { max-width: 100px; display: inline-block; text-align: right; }
.stoc-cantitate-celula { display: flex; align-items: center; justify-content: flex-end; gap: .4rem; }
.stoc-confirmat { font-size: .82rem; color: #198754; font-weight: 600; }

/* Stoc minim — celula editabilă din grid (coloana Cantitate minimă) */
.celula-editabila { background: #fffbea; cursor: pointer; }
.celula-editabila:hover { background: #fff3c4; }
.celula-editabila::after { content: "✎"; color: #b8a24a; margin-left: .4rem; opacity: .55; }
.celula-editabila:has(input)::after { content: none; } /* fără creion cât timp celula e în editare */

/* Inventar — tab-uri */
.inventar-tab-nav { display: flex; gap: 0; border-bottom: 2px solid #dee2e6; margin-bottom: 1.25rem; }
.inventar-tab-btn { padding: .5rem 1.25rem; border: none; background: none; cursor: pointer;
    font-size: .9rem; color: #6c757d; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.inventar-tab-btn:hover { color: #1a3a5c; }
.inventar-tab-btn.activ { color: #1a3a5c; font-weight: 600; border-bottom-color: #1a3a5c; }
.inventar-tab-content { padding-top: .25rem; }

/* Inventar — text explicativ */
.alert-info { background: #cff4fc; color: #055160; }
.inventar-explicatii { font-size: .88rem; margin-bottom: 1rem; }
kbd { display: inline-block; padding: .1rem .4rem; font-size: .8rem; background: #f1f3f5;
    border: 1px solid #ced4da; border-radius: 3px; font-family: monospace; }

/* Inventar — selector dată comună */
.inventar-data-comuna { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
    padding: .65rem 1rem; background: #f8f9fa; border: 1px solid #dee2e6;
    border-radius: 6px; margin-bottom: 1rem; }
.inventar-data-comuna-label { display: flex; align-items: center; gap: .5rem;
    font-size: .88rem; cursor: pointer; flex: 1; min-width: 280px; }
.inventar-data-comuna-label input[type=checkbox] { flex-shrink: 0; }
.inventar-data-comuna-input { max-width: 210px; }

/* Inventar — opțiuni import */
.inventar-import-optiuni { margin-bottom: .75rem; }
.inventar-import-optiuni-label { display: flex; align-items: center; gap: .5rem;
    font-size: .88rem; cursor: pointer; }

/* Inventar — produs selectat manual */
.produs-selectat-card { display: flex; align-items: flex-end; gap: 1rem; flex-wrap: wrap;
    padding: 1rem; background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 6px;
    margin-bottom: 1rem; }
.produs-selectat-info { display: flex; flex-direction: column; gap: .15rem; flex: 1; min-width: 180px; }
.produs-selectat-info .isbn { font-size: .8rem; }
.produs-selectat-cantitate { display: flex; flex-direction: column; gap: .3rem; }
.produs-selectat-cantitate label { font-size: .82rem; color: #495057; }
.produs-selectat-cantitate .cantitate-input { max-width: 120px; }

/* Inventar — import Excel */
.import-sumar { display: flex; gap: 1rem; align-items: center; margin-bottom: .75rem;
    font-size: .9rem; flex-wrap: wrap; }
.import-gasit { color: #0a3622; background: #d1e7dd; padding: .25rem .65rem; border-radius: 4px; }
.import-negasit { color: #58151c; background: #f8d7da; padding: .25rem .65rem; border-radius: 4px; }
.import-rand-negasit td { background: #fff8f8; color: #9e9e9e; }
.import-status-ok { color: #198754; font-weight: 600; }
.import-status-lipsa { color: #dc3545; }

/* Catalog */
.catalog-filtru { display: flex; gap: .75rem; margin-bottom: 1rem; flex-wrap: wrap; }
.catalog-filtru .form-control { max-width: 360px; }
.catalog-filtru .form-select { max-width: 220px; }
.catalog-info { margin-bottom: .5rem; font-size: .85rem; }
.catalog-tabel { width: 100%; border-collapse: collapse; background: #fff; font-size: .9rem; }
.catalog-tabel th { padding: .5rem .75rem; background: #f1f3f5; text-align: left; border-bottom: 2px solid #dee2e6; }
.catalog-tabel td { padding: .5rem .75rem; border-bottom: 1px solid #f1f3f5; vertical-align: middle; }
.catalog-tabel .pret { text-align: right; white-space: nowrap; }
.catalog-tabel .isbn { font-size: .8rem; color: #6c757d; font-variant-numeric: tabular-nums; }
.catalog-tabel tr.indisponibil td { color: #9e9e9e; }
.badge-pachet { display: inline-block; font-size: .7rem; padding: .15rem .45rem;
    background: #e3f2fd; color: #0d47a1; border-radius: 10px; margin-left: .4rem; }
.text-muted { color: #6c757d; }

/* Pagini cu conținut larg (ex. ComandaLivrare) — anulează max-width pe container */
.main-content:has(.pagina-lata) { max-width: none; }

/* ComandaLivrare — bara de acțiuni deasupra gridului */
.comanda-livrare-actiuni { display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: .75rem; margin-bottom: .75rem; }
.comanda-livrare-butoane-salvare { display: flex; gap: .5rem; }

/* ComandaLivrare — text trunchiat în celule pentru rânduri uniforme ca înălțime */
.comanda-livrare-grid .k-table-td { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Cereri — toolbar cu butoane de adăugare */
.cereri-toolbar { display: flex; gap: .5rem; flex-wrap: wrap; }

/* Cereri — badge stare */
.cerere-stare { display: inline-block; font-size: .78rem; font-weight: 600;
    padding: .15rem .5rem; border-radius: 3px; }
.cerere-stare-d { background: #f0f0f0; color: #555; }
.cerere-stare-t { background: #cff4fc; color: #055160; }
.cerere-stare-p { background: #cfe2ff; color: #084298; }
.cerere-stare-o { background: #d1e7dd; color: #0a3622; }
.cerere-stare-r { background: #f8d7da; color: #58151c; }
.cerere-stare-a { background: #f8f9fa; color: #adb5bd; text-decoration: line-through; }

/* Cereri — rând anulat în tabel */
.cerere-anulata td { color: #adb5bd; }

/* Cereri detaliu — metadate header */
.cerere-detaliu-meta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: .4rem; font-size: .9rem; }
.cerere-detaliu-obs { margin-top: .4rem; font-size: .9rem; }
.cerere-detaliu-actiuni { margin: .75rem 0; display: flex; align-items: center; }

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}