.product-page{display:grid;gap:18px}.product-form-card,.product-import-card{width:100%;max-width:none}.product-form-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:18px 22px;align-items:start}.product-image-panel{grid-column:1 / -1}.form-actions{display:flex;gap:10px;align-items:center;justify-content:flex-start;margin-top:18px;flex-wrap:wrap}.image-dropzone,.file-dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;min-height:190px;border:2px dashed #adc6ff;border-radius:14px;background:#f5f8ff;color:var(--text);cursor:pointer;padding:18px;text-align:center;transition:border-color .15s ease,background .15s ease}.image-dropzone input,.file-dropzone input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}.image-dropzone span,.file-dropzone span{font-weight:800}.image-dropzone small,.file-dropzone small{color:var(--muted)}.image-dropzone img{display:block;max-width:100%;max-height:280px;border-radius:10px;object-fit:contain;background:#fff;border:1px solid var(--line)}.image-dropzone.is-dragging,.file-dropzone.is-dragging{border-color:var(--primary);background:#eff8ff}.table-scroll{width:100%;overflow:auto}.import-table{min-width:1120px}.import-table input{min-width:130px;padding:8px 9px}.import-table td:last-child{min-width:240px}.import-table .badge{margin:2px 3px 2px 0;white-space:normal}.row-has-errors{background:#fffafa}.import-review-form{margin-top:14px}@media(max-width:1100px){.product-form-grid{grid-template-columns:1fr}.product-image-panel{grid-column:auto}.image-dropzone,.file-dropzone{min-height:160px}}
:root{
    --bg:#f5f7fb;
    --panel:#ffffff;
    --text:#162033;
    --muted:#68758a;
    --line:#e5eaf2;
    --primary:#1f6feb;
    --primary-dark:#174ea6;
    --danger:#d92d20;
    --warning:#b54708;
    --success:#087443;
    --sidebar:#101828;
}
*{box-sizing:border-box} body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--text)}
a{color:var(--primary);text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:270px;background:var(--sidebar);color:white;padding:22px 18px;position:fixed;top:0;bottom:0;overflow:auto}.brand{font-size:26px;font-weight:800;letter-spacing:-.5px;margin-bottom:18px}.brand span,.login-card h1 span{color:#78a6ff}.userbox{padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:14px;margin-bottom:18px;background:rgba(255,255,255,.04)}.userbox small{display:block;color:#b9c1d2;margin-top:3px}.sidebar nav p{font-size:11px;text-transform:uppercase;color:#97a3b6;margin:18px 8px 6px}.sidebar nav a{display:block;color:#edf2f7;padding:9px 10px;border-radius:10px;margin:2px 0}.sidebar nav a:hover{background:rgba(255,255,255,.08)}.content{margin-left:270px;width:calc(100% - 270px);padding:28px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.topbar h1{margin:0;font-size:28px}.topbar small{color:var(--muted)}.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 10px 25px rgba(18,38,63,.04);margin-bottom:18px}.card h2{margin:0 0 14px}.card h3{margin:18px 0 8px}.card-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cards{display:grid;gap:14px}.stats-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.stat span{display:block;color:var(--muted);font-size:13px}.stat strong{display:block;font-size:30px;margin-top:6px}.stat.danger strong{color:var(--danger)}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:1fr 1fr}.grid.compact{gap:12px}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.search-form{display:flex;gap:8px;align-items:center}.wide-form{max-width:1100px}label{display:block;font-size:13px;font-weight:700;margin:12px 0 5px}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font:inherit}textarea{resize:vertical}.check{display:flex;gap:8px;align-items:center}.check input{width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--text);padding:10px 14px;border-radius:11px;cursor:pointer;font-weight:700;text-decoration:none}.btn:hover{background:#f8fafc}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.small{font-size:12px;padding:6px 9px;border-radius:9px}.alert{padding:12px 14px;border-radius:12px;margin-bottom:16px;border:1px solid var(--line);background:#fff}.alert-success{border-color:#abefc6;background:#ecfdf3;color:#075e3a}.alert-error{border-color:#fecdca;background:#fef3f2;color:#912018}.muted{color:var(--muted)}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px 8px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.badge{display:inline-block;border-radius:999px;padding:3px 8px;font-size:12px;background:#eef4ff;color:#3538cd;font-weight:700}.badge.critical,.badge.danger{background:#fef3f2;color:var(--danger)}.badge.high{background:#fff4e5;color:var(--warning)}.badge.medium{background:#eef4ff;color:#3538cd}.badge.low{background:#ecfdf3;color:var(--success)}.badge.primary{background:#eef4ff;color:#1f6feb}.primary-location{display:flex;gap:14px;align-items:center;flex-wrap:wrap;padding:14px;border:1px dashed #adc6ff;border-radius:14px;background:#f5f8ff}.primary-location span{font-size:22px;font-weight:800}.primary-location strong{font-size:22px;color:var(--primary)}.primary-location small{color:var(--muted)}.chips{display:flex;gap:8px;list-style:none;padding:0;margin:0;flex-wrap:wrap}.chips li{padding:8px 10px;border-radius:999px;background:#f2f4f7;font-weight:700}.chips small{font-weight:400;color:var(--muted)}.inline-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.inline-form input,.inline-form select{width:auto;min-width:110px;padding:7px 8px}.actions-cell{min-width:420px}.scanner-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.scanner-video{width:100%;max-height:260px;border-radius:14px;margin-top:12px;background:#000}.lookup-box{margin-top:8px;font-size:13px}.lookup-box.ok{color:var(--success)}.lookup-box.err{color:var(--danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#101828,#1f6feb)}.login-card{width:390px;background:white;padding:32px;border-radius:24px;box-shadow:0 24px 70px rgba(0,0,0,.25)}.login-card h1{font-size:32px;margin:0}.login-card p{color:var(--muted);margin:8px 0 24px}@media(max-width:1100px){.sidebar{position:static;width:100%;height:auto}.app-shell{display:block}.content{margin-left:0;width:100%;padding:18px}.stats-grid,.grid.two{grid-template-columns:1fr}.toolbar{display:block}.search-form{margin-bottom:10px}.actions-cell{min-width:0}}
.field-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:12px 0 5px}.field-row label{margin:0}.field-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.notice-stack{position:fixed;top:18px;right:18px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:10px;max-width:min(520px,calc(100vw - 36px));pointer-events:none}.notice-badge,.notice-inline{display:flex;align-items:flex-start;gap:9px;border:1px solid var(--line);border-left-width:5px;border-radius:12px;background:#fff;color:var(--text);box-shadow:0 14px 30px rgba(18,38,63,.12);padding:10px 12px;font-size:13px;line-height:1.35}.notice-badge{pointer-events:auto}.notice-badge strong,.notice-inline strong{font-size:10px;line-height:1.8;letter-spacing:.04em}.notice-success{border-color:#abefc6;border-left-color:var(--success);background:#ecfdf3;color:#075e3a}.notice-error{border-color:#fecdca;border-left-color:var(--danger);background:#fef3f2;color:#912018}.notice-warning{border-color:#fedf89;border-left-color:var(--warning);background:#fffaeb;color:#93370d}.notice-info{border-color:#b2ddff;border-left-color:var(--primary);background:#eff8ff;color:#175cd3}.notice-inline{box-shadow:none;margin-top:8px}@media(max-width:1100px){.notice-stack{top:10px;right:10px;max-width:calc(100vw - 20px)}}
.stock-search-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:18px}.stock-search-form{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center}.stock-product-head{display:flex;gap:14px;align-items:center;margin-bottom:18px}.stock-product-head img{width:78px;height:78px;border-radius:12px;object-fit:cover;border:1px solid var(--line);background:#fff}.stock-product-head h2{margin:0 0 4px}.stock-product-head p{margin:0;color:var(--muted)}.stock-area-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:18px}.stock-section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.stock-section-title h2{margin:0;font-size:15px;letter-spacing:.03em}.stock-zone{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--text);padding:14px;text-decoration:none}.stock-zone:hover{background:#f8fafc}.stock-zone span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.stock-zone strong{display:block;font-size:22px;margin-top:2px}.stock-zone small{display:block;color:var(--muted);margin-top:4px}.stock-zone b{font-size:28px;color:var(--primary)}.primary-zone{border-left:5px solid var(--primary)}.reserve-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.reserve-zone{border-left:5px solid var(--success)}.secondary-zones{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.secondary-zones span{border-radius:999px;background:#f2f4f7;padding:7px 10px;font-weight:800}.stock-detail-page{display:grid;gap:18px}.stock-detail-product{display:flex;gap:18px;align-items:flex-start;margin-top:14px}.stock-detail-product img,.stock-image-empty{width:180px;height:180px;border-radius:14px;border:1px solid var(--line);background:#fff;object-fit:cover}.stock-image-empty{display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:800}.stock-detail-product h2{margin:0 0 6px}.stock-detail-product p{margin:0;color:var(--muted)}.stock-detail-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.stock-detail-meta span,.stock-detail-meta strong{border-radius:999px;background:#f2f4f7;padding:8px 10px}.stock-detail-meta strong{background:#eef4ff;color:var(--primary)}.stock-action-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.btn.danger{border-color:var(--danger);color:var(--danger)}.btn.danger:hover{background:#fef3f2}.stock-scan-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-bottom:8px}.stock-modal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:rgba(16,24,40,.35);padding:18px}.stock-modal[hidden]{display:none}.stock-modal-panel{width:min(460px,100%);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 70px rgba(0,0,0,.24);padding:20px}.stock-modal-panel h2{margin:0 0 14px}.quantity-stepper{display:grid;grid-template-columns:56px minmax(0,1fr) 56px;gap:8px}.quantity-stepper input{text-align:center;font-size:28px;font-weight:800}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}@media(max-width:1100px){.stock-search-form{grid-template-columns:1fr}.reserve-grid{grid-template-columns:1fr}.stock-detail-product{display:block}.stock-detail-product img,.stock-image-empty{width:100%;height:240px;margin-bottom:14px}.stock-scan-row{grid-template-columns:1fr}}
.stock-mobile-search{display:none}
@media(min-width:761px){.stock-mobile-search{display:none!important}}
@media(max-width:760px){.content{padding-bottom:165px}.stock-search-card{display:none}.stock-mobile-search{position:fixed;left:0;right:0;bottom:0;z-index:900;display:grid!important;grid-template-columns:1fr;gap:8px;padding:12px;background:rgba(255,255,255,.96);border-top:1px solid var(--line);box-shadow:0 -14px 30px rgba(18,38,63,.12)}.stock-mobile-search input{height:46px}.stock-mobile-search .btn.primary{height:48px;font-size:15px}.stock-mobile-search .btn:not(.primary){height:42px}.stock-product-head{align-items:flex-start}.stock-zone{align-items:flex-start}.stock-zone b{font-size:24px}.stock-action-panel{grid-template-columns:1fr}.modal-actions{display:grid;grid-template-columns:1fr}.quantity-stepper{grid-template-columns:52px minmax(0,1fr) 52px}}
.zone-list{display:grid;gap:10px}.zone-row{display:grid;grid-template-columns:minmax(0,1fr) 72px auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;cursor:pointer}.zone-row:hover{background:#f8fafc}.zone-row strong{display:block;font-size:18px}.zone-qr-small{width:56px;height:56px}.zone-create-fixed{position:fixed;right:22px;bottom:22px;z-index:850;box-shadow:0 14px 30px rgba(18,38,63,.18)}.zone-print-grid{display:none}.zone-print-card{break-inside:avoid;border:1px solid #111;border-radius:5px;padding:6px;text-align:center;width:122px}.zone-print-card img{display:block;width:82px;height:82px;margin:0 auto 4px}.zone-print-card strong{display:block;font-size:11px;line-height:1.1}.zone-print-card span{display:block;margin-top:2px;font-size:9px}.zone-print-card small{display:none}
@media(max-width:760px){.zone-row{grid-template-columns:minmax(0,1fr) 56px}.zone-row .btn{grid-column:1 / -1}.zone-create-fixed{left:12px;right:12px;bottom:12px}}
@media print{body{background:#fff}.sidebar,.topbar,.notice-stack,.screen-only,.card,.zone-create-fixed,script,.stock-mobile-search{display:none!important}.content{margin:0!important;width:100%!important;padding:0!important}.zone-print-grid{display:grid;grid-template-columns:repeat(5,122px);gap:8px}.zone-print-card{display:block}.print-single-zone .zone-print-card{display:none}.print-single-zone .zone-print-card.is-print-target{display:block}}

.mobile-menu-btn{display:none}.product-thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;border:1px solid var(--line);background:#fff;display:inline-block}.product-thumb.empty{background:linear-gradient(135deg,#f2f4f7,#fff)}.auth-setup-card{max-width:900px}.auth-setup-grid{display:grid;grid-template-columns:260px minmax(0,1fr);gap:22px;align-items:start}.auth-qr{width:180px;height:180px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:8px}.permission-list{display:grid;gap:8px;margin-bottom:14px}.users-grid{align-items:start}.unplaced-groups{display:grid;gap:16px}.unplaced-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.unplaced-item{display:flex;gap:12px;align-items:center;border:1px solid var(--line);border-radius:10px;padding:10px;color:var(--text);background:#fff}.unplaced-item:hover{background:#f8fafc}.unplaced-item img,.unplaced-item .product-thumb{width:58px;height:58px;flex:0 0 auto}.unplaced-item strong{display:block}.unplaced-item small{display:block;color:var(--muted);margin-top:3px}.zone-qr-small{width:48px!important;height:48px!important}.zone-print-card{width:92px!important;padding:3px!important;font-size:8px!important}.zone-print-card img{width:58px!important;height:58px!important}.zone-print-card strong{font-size:8px!important;line-height:1.1}.zone-print-card span{font-size:7px!important;line-height:1.1}

@media(max-width:1100px){.mobile-menu-btn{display:inline-flex}.sidebar{position:fixed!important;top:0;bottom:0;left:0;width:min(84vw,310px)!important;height:100vh!important;z-index:1200;transform:translateX(-105%);transition:transform .18s ease;box-shadow:20px 0 50px rgba(16,24,40,.24)}body.nav-open .sidebar{transform:translateX(0)}body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(16,24,40,.35);z-index:1190}.content{margin-left:0!important;width:100%!important;padding:14px!important;padding-bottom:96px!important}.topbar{gap:10px;justify-content:flex-start;align-items:flex-start}.topbar h1{font-size:24px}.stock-search-card{display:none}.stock-mobile-search{display:grid!important;position:fixed;left:0;right:0;bottom:0;z-index:1000;background:#fff;border-top:1px solid var(--line);padding:10px;grid-template-columns:1fr 1fr;gap:8px;box-shadow:0 -12px 30px rgba(16,24,40,.08)}.stock-mobile-search input{grid-column:1 / -1}.unplaced-list{grid-template-columns:1fr}.auth-setup-grid{grid-template-columns:1fr}.card{padding:16px;border-radius:12px}.product-thumb{width:40px;height:40px}table{font-size:13px}.toolbar,.card-title{gap:10px;flex-wrap:wrap}.search-form{display:grid;grid-template-columns:1fr auto;width:100%}.users-grid{grid-template-columns:1fr!important}}

@media print{.zone-print-grid{grid-template-columns:repeat(7,92px)!important;gap:5px!important}.zone-print-card{width:92px!important;break-inside:avoid}.zone-print-card img{width:58px!important;height:58px!important}}

/* Patch layout 09/05: mobile-only search, compact zones, bounded product images. */
@media(min-width:761px){.stock-mobile-search{display:none!important}.stock-search-card{display:block!important}}
@media(max-width:760px){.stock-mobile-search{display:grid!important}.stock-search-card{display:none!important}}
.zone-list{display:grid!important;grid-template-columns:1fr!important;gap:8px!important}.zone-list .zone-row{display:grid!important;grid-template-columns:minmax(0,1fr) 46px auto!important;align-items:center!important;gap:10px!important;min-height:58px!important;padding:8px 10px!important}.zone-list .zone-row>div{display:flex!important;align-items:center!important;gap:8px!important;min-width:0!important}.zone-list .zone-row strong{font-size:16px!important;line-height:1.15!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.zone-list .zone-qr-small{width:42px!important;height:42px!important;display:block!important}.zone-list .zone-row .btn{white-space:nowrap!important}.product-thumb{width:38px!important;height:38px!important;max-width:38px!important;max-height:38px!important;object-fit:cover!important}.product-image-panel .image-dropzone img{max-height:220px!important;max-width:min(100%,520px)!important}.placement-actions{display:flex!important;gap:8px!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:wrap!important}
@media(max-width:760px){.zone-list .zone-row{grid-template-columns:minmax(0,1fr) 42px!important}.zone-list .zone-row .btn{grid-column:1 / -1!important}.placement-actions{justify-content:flex-start!important}}

/* Hard layout reset after asset versioning: keep desktop clean, mobile explicit. */
.topbar{justify-content:flex-start!important;gap:16px!important}.mobile-menu-btn{display:none!important}
@media(min-width:761px){.sidebar{width:270px!important;position:fixed!important;top:0!important;bottom:0!important;left:0!important;height:auto!important;transform:none!important}.app-shell{display:flex!important}.content{margin-left:270px!important;width:calc(100% - 270px)!important;padding:28px!important}.mobile-menu-btn{display:none!important}body.nav-open::after{display:none!important}}
@media(max-width:760px){.mobile-menu-btn{display:inline-flex!important}.sidebar{position:fixed!important;top:0!important;bottom:0!important;left:0!important;width:min(84vw,310px)!important;height:100vh!important;z-index:1200!important;transform:translateX(-105%)!important}.nav-open .sidebar{transform:translateX(0)!important}.content{margin-left:0!important;width:100%!important;padding:14px!important;padding-bottom:118px!important}.topbar{align-items:flex-start!important}.topbar h1{font-size:24px!important}}

.products-toolbar{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important}.products-search{display:grid!important;grid-template-columns:minmax(220px,420px) auto!important;gap:10px!important;margin:0!important}.products-card{overflow:hidden!important}.products-list{display:grid!important;gap:0!important}.products-row{display:grid!important;grid-template-columns:64px 92px 132px minmax(260px,1.3fr) minmax(110px,.6fr) minmax(120px,.6fr) 66px!important;gap:14px!important;align-items:center!important;padding:10px 6px!important;border-bottom:1px solid var(--line)!important;color:var(--text)!important}.products-row:last-child{border-bottom:0!important}.products-head{font-size:12px!important;text-transform:uppercase!important;font-weight:800!important;color:var(--muted)!important}.product-item-row:hover{background:#f8fafc!important}.product-image-cell{width:52px!important;height:52px!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important}.product-image-cell .product-thumb,.products-row .product-thumb{width:52px!important;height:52px!important;max-width:52px!important;max-height:52px!important;border-radius:8px!important;object-fit:cover!important;display:block!important}.products-row strong{font-size:14px!important;line-height:1.25!important;font-weight:700!important}

.zones-card{max-width:980px!important}.zone-compact-list{display:grid!important;grid-template-columns:1fr!important;gap:8px!important}.zone-compact-row{display:grid!important;grid-template-columns:minmax(0,1fr) 44px 92px!important;gap:10px!important;align-items:center!important;border:1px solid var(--line)!important;border-radius:10px!important;background:#fff!important;padding:8px 10px!important;min-height:62px!important}.zone-compact-row .zone-main{display:flex!important;align-items:center!important;gap:8px!important;min-width:0!important}.zone-compact-row strong{font-size:16px!important;line-height:1.15!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.zone-compact-row .zone-qr-small{width:44px!important;height:44px!important;max-width:44px!important;max-height:44px!important}.zone-compact-row .btn{width:92px!important;padding:7px 8px!important}
.placement-actions{display:flex!important;gap:8px!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:nowrap!important}.placement-actions form{margin:0!important;display:inline-flex!important}
@media(max-width:760px){.products-toolbar{display:grid!important;grid-template-columns:1fr!important}.products-search{grid-template-columns:1fr auto!important;width:100%!important}.products-card{padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important}.products-head{display:none!important}.products-list{gap:10px!important}.products-row{grid-template-columns:58px minmax(0,1fr) auto!important;gap:10px!important;background:#fff!important;border:1px solid var(--line)!important;border-radius:12px!important;padding:10px!important}.products-row span:nth-child(2),.products-row span:nth-child(3),.products-row span:nth-child(5),.products-row span:nth-child(6){display:none!important}.products-row strong{font-size:15px!important}.product-image-cell,.product-image-cell .product-thumb,.products-row .product-thumb{width:52px!important;height:52px!important}.zone-compact-row{grid-template-columns:minmax(0,1fr) 44px!important}.zone-compact-row .btn{grid-column:1 / -1!important;width:100%!important}.placement-actions{justify-content:flex-start!important;flex-wrap:wrap!important}}

.product-mobile-meta{display:none!important;color:var(--muted)!important;font-size:12px!important;font-weight:500!important;margin-top:3px!important}.stock-search-form{grid-template-columns:minmax(0,1fr) auto auto auto!important}.zone-actions{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:6px!important}.zone-actions form{display:inline-flex!important;margin:0!important}.zone-compact-row{grid-template-columns:minmax(0,1fr) 44px 270px!important}.zone-compact-row .zone-actions .btn{width:auto!important;min-width:0!important;white-space:nowrap!important}
.inventory-card{display:grid!important;gap:14px!important}.inventory-filters{display:grid!important;grid-template-columns:minmax(260px,1fr) 180px 220px auto auto!important;gap:10px!important;align-items:end!important}.inventory-meta{display:flex!important;gap:8px!important;align-items:center!important;color:var(--muted)!important}.inventory-meta strong{font-size:24px!important;color:var(--text)!important}.inventory-sheet{overflow:auto!important;border:1px solid var(--line)!important;border-radius:10px!important}.inventory-sheet table{min-width:1120px!important;background:#fff!important}.inventory-sheet th{position:sticky!important;top:0!important;background:#f8fafc!important;z-index:1!important}.inventory-sheet td:last-child,.inventory-sheet th:last-child{text-align:right!important}.pagination{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:10px!important}
.label-generate-form{display:grid!important;grid-template-columns:160px auto auto!important;gap:10px!important;align-items:end!important}.label-generate-form label{grid-column:1!important}.container-label-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))!important;gap:12px!important}.container-label{background:#fff!important;border:1px solid #111!important;border-radius:6px!important;padding:10px!important;text-align:center!important;break-inside:avoid!important}.container-label strong,.container-label span,.container-label b,.container-label small{display:block!important}.container-label img{display:block!important;max-width:100%!important;height:44px!important;margin:4px auto!important;object-fit:contain!important}.container-label b{font-size:18px!important;margin-top:4px!important}.container-label small{font-size:11px!important;color:#555!important}
@media(max-width:760px){.product-mobile-meta{display:block!important}.stock-search-form{grid-template-columns:1fr!important}.zone-compact-row{grid-template-columns:minmax(0,1fr) 44px!important}.zone-actions{grid-column:1 / -1!important;display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important}.zone-actions .btn,.zone-actions form,.zone-actions button{width:100%!important}.inventory-filters{grid-template-columns:1fr!important}.inventory-sheet table{min-width:880px!important}.pagination{justify-content:center!important;flex-wrap:wrap!important}.label-generate-form{grid-template-columns:1fr!important}.container-label-grid{grid-template-columns:1fr!important}}
@media print{.label-tool-card,.sidebar,.topbar,.notice-stack{display:none!important}.container-label-grid{display:grid!important;grid-template-columns:repeat(3,58mm)!important;gap:4mm!important}.container-label{width:58mm!important;min-height:34mm!important;padding:3mm!important}.container-label img{height:12mm!important}}

/* Gestione Stock mobile: ricerca in basso con scan full-width */
@media (max-width: 760px) {
    .content {
        padding-bottom: 210px !important;
    }

    .stock-mobile-search {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 1000 !important;
        background: #fff !important;
        border-top: 1px solid var(--line) !important;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom)) !important;
        box-shadow: 0 -12px 30px rgba(16, 24, 40, .10) !important;
    }

    .stock-mobile-search input,
    .stock-mobile-search .btn {
        width: 100% !important;
        min-height: 46px !important;
    }

    .stock-mobile-search input {
        grid-column: 1 / -1 !important;
    }

    .stock-mobile-search .btn.primary {
        grid-column: 1 / -1 !important;
        height: 50px !important;
        font-size: 15px !important;
    }

    .stock-mobile-search a.btn {
        grid-column: 1 / -1 !important;
        height: 46px !important;
    }
}

/* Stato vuoto Gestione Stock */
.stock-empty-state {
    min-height: 360px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-align: center;
    background: #fff;
    border: 1px dashed var(--line);
    border-radius: 18px;
    padding: 42px 24px;
    color: var(--text);
}

.stock-empty-illustration {
    width: 132px;
    height: 132px;
    border-radius: 50%;
    background: #f5f8ff;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 6px;
}

.stock-empty-illustration svg {
    width: 92px;
    height: 92px;
    fill: none;
    stroke: var(--primary);
    stroke-width: 7;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.stock-empty-state h2 {
    margin: 0;
    font-size: 22px;
}

.stock-empty-state p {
    margin: 0;
    max-width: 460px;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.5;
}

@media (max-width: 760px) {
    .stock-empty-state {
        min-height: calc(100vh - 290px);
        padding: 28px 18px;
        margin-top: 10px;
        margin-bottom: 18px;
    }

    .stock-empty-illustration {
        width: 112px;
        height: 112px;
    }

    .stock-empty-illustration svg {
        width: 78px;
        height: 78px;
    }

    .stock-empty-state h2 {
        font-size: 20px;
    }

    .stock-empty-state p {
        font-size: 14px;
    }
}

/* Scanner stock: video sopra la barra ricerca su mobile */
.scanner-box[hidden] {
    display: none !important;
}

.scanner-box {
    margin: 12px 0 18px;
}

.scanner-box .scanner-video {
    display: block;
    width: 100%;
    max-height: 320px;
    margin: 0;
    border-radius: 14px;
    background: #000;
    object-fit: cover;
}

.scanner-cancel {
    width: 100%;
    margin-top: 8px;
}

@media (max-width: 760px) {
    .scanner-box {
        position: fixed !important;
        left: 12px !important;
        right: 12px !important;
        bottom: calc(188px + env(safe-area-inset-bottom)) !important;
        z-index: 1001 !important;
        margin: 0 !important;
        padding: 10px !important;
        background: #fff !important;
        border: 1px solid var(--line) !important;
        border-radius: 18px !important;
        box-shadow: 0 -14px 35px rgba(16, 24, 40, .22) !important;
    }

    .scanner-box .scanner-video {
        width: 100% !important;
        height: min(42vh, 320px) !important;
        max-height: none !important;
        border-radius: 14px !important;
    }

    .scanner-cancel {
        height: 46px !important;
        margin-top: 8px !important;
    }

    body.scanner-open .stock-mobile-search {
        z-index: 1000 !important;
    }
}
/* Stock detail: tre azioni sempre in una riga, icona + testo */
.stock-action-panel {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.stock-action-btn {
    min-height: 72px;
    padding: 12px 8px;
    flex-direction: column;
    gap: 6px;
    text-align: center;
    border-radius: 15px;
}

.stock-action-icon {
    display: block;
    font-size: 26px;
    line-height: 1;
    font-weight: 900;
}

.stock-action-text {
    display: block;
    font-size: 13px;
    line-height: 1.1;
    font-weight: 800;
}

/* Scanner dentro popup Scansiona indirizzo */
.stock-modal-scanner[hidden] {
    display: none !important;
}

.stock-modal-scanner {
    margin: 0 0 12px;
    padding: 10px;
    background: #f8fafc;
    border: 1px solid var(--line);
    border-radius: 14px;
}

.stock-modal-scanner .scanner-video {
    display: block;
    width: 100%;
    height: min(38vh, 300px);
    max-height: none;
    margin: 0;
    border-radius: 12px;
    background: #000;
    object-fit: cover;
}

.scanner-cancel {
    width: 100%;
    margin-top: 8px;
}

@media (max-width: 760px) {
    .stock-action-panel {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    .stock-action-btn {
        min-height: 78px !important;
        padding: 10px 6px !important;
    }

    .stock-action-icon {
        font-size: 24px !important;
    }

    .stock-action-text {
        font-size: 12px !important;
    }

    .stock-modal-panel {
        max-height: calc(100vh - 36px);
        overflow: auto;
    }

    .stock-modal-scanner .scanner-video {
        height: min(34vh, 260px);
    }
}
.stock-back-row {
    margin: 0 0 14px;
}

.stock-back-row .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

@media (max-width: 760px) {
    .stock-back-row {
        margin: 0 0 12px;
    }

    .stock-back-row .btn {
        width: 100%;
        min-height: 44px;
    }
}
/* Gestione Stock - dettaglio CONTENITORE / SSCC più leggibile */
.container-summary-zone {
    border: 1px solid var(--line) !important;
    border-left: 1px solid var(--line) !important;
}

.container-summary-zone strong {
    font-size: 20px;
}

.container-summary-zone small {
    font-size: 13px;
}

.container-products-grid {
    margin-top: 12px;
}

.container-product-zone {
    border: 1px solid var(--line) !important;
    border-left: 1px solid var(--line) !important;
    align-items: center !important;
    padding: 13px 14px !important;
}

.container-product-info {
    min-width: 0;
}

.container-product-ref {
    display: block !important;
    margin: 0 0 4px !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    color: var(--text) !important;
}

.container-product-name {
    display: block !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    font-weight: 600 !important;
    color: var(--muted) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.container-product-qty {
    flex: 0 0 auto;
    min-width: 48px;
    text-align: right;
    font-size: 24px !important;
    color: var(--text) !important;
}

@media (max-width: 760px) {
    .container-products-grid {
        grid-template-columns: 1fr !important;
    }

    .container-product-zone {
        flex-direction: row !important;
        align-items: center !important;
    }

    .container-product-ref {
        font-size: 13px !important;
    }

    .container-product-name {
        font-size: 12px !important;
    }

    .container-product-qty {
        font-size: 23px !important;
    }
}
/* Popup Scansiona indirizzo - Stock detail */
.stock-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.stock-modal-header h2 {
    margin: 0 !important;
}

.stock-modal-close {
    width: 38px;
    height: 38px;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: #fff;
    color: var(--text);
    font-size: 26px;
    line-height: 1;
    font-weight: 700;
    cursor: pointer;
}

.stock-modal-close:hover {
    background: #f8fafc;
}

.stock-modal-scanner[hidden] {
    display: none !important;
}

.stock-modal-scanner {
    margin: 0 0 12px;
    padding: 10px;
    background: #f8fafc;
    border: 1px solid var(--line);
    border-radius: 14px;
}

.stock-modal-scanner .scanner-video {
    display: block;
    width: 100%;
    height: min(38vh, 300px);
    max-height: none;
    margin: 0;
    border-radius: 12px;
    background: #000;
    object-fit: cover;
}

.stock-target-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 10px;
}

.stock-target-actions .btn {
    width: 100%;
    min-height: 46px;
}

.transfer-sales-btn {
    background: #f5f8ff;
    border-color: #adc6ff;
    color: var(--primary);
}

.transfer-sales-btn:hover {
    background: #eef4ff;
}

@media (max-width: 760px) {
    .stock-modal-panel {
        max-height: calc(100vh - 36px);
        overflow: auto;
    }

    .stock-modal-scanner .scanner-video {
        height: min(34vh, 260px);
    }
}
/* Hub Articoli - form migliorato */
.product-form-section-title {
    margin: 0 0 12px;
    font-size: 15px;
    font-weight: 900;
    color: var(--text);
}

.products-toolbar-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.category-create-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: end;
}

.category-list {
    display: grid;
    gap: 8px;
}

.category-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
}

.category-row strong {
    display: block;
}

.category-row small {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: 3px;
}

@media (max-width: 760px) {
    .products-toolbar-actions {
        justify-content: stretch;
    }

    .products-toolbar-actions .btn {
        flex: 1;
        justify-content: center;
    }

    .category-create-form {
        grid-template-columns: 1fr;
    }

    .category-row {
        align-items: stretch;
        flex-direction: column;
    }

    .category-row .btn {
        width: 100%;
    }
}
/* Movimenti - lista responsive con record espandibili */
.movements-card {
    padding: 14px;
}

.movements-list {
    display: grid;
    gap: 8px;
}

.movement-item {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
    overflow: hidden;
}

.movement-item summary {
    list-style: none;
    cursor: pointer;
    display: grid;
    grid-template-columns: 150px 120px minmax(220px, 1fr) minmax(220px, 1fr) 72px;
    gap: 12px;
    align-items: center;
    padding: 13px 14px;
}

.movement-item summary::-webkit-details-marker {
    display: none;
}

.movement-item summary::after {
    content: "⌄";
    font-weight: 900;
    color: var(--muted);
    justify-self: end;
}

.movement-item[open] summary::after {
    content: "⌃";
}

.movement-date {
    font-size: 12px;
    color: var(--muted);
    font-weight: 700;
}

.movement-type {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
    background: #eef4ff;
    color: #3538cd;
}

.movement-type-move {
    background: #eef4ff;
    color: #3538cd;
}

.movement-type-adjustment {
    background: #ecfdf3;
    color: #067647;
}

.movement-type-sale {
    background: #fef3f2;
    color: #b42318;
}

.movement-type-inventory {
    background: #fff7ed;
    color: #b54708;
}

.movement-product {
    min-width: 0;
}

.movement-product strong {
    display: block;
    font-size: 14px;
}

.movement-product small {
    display: block;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.movement-flow {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    font-size: 13px;
    font-weight: 800;
}

.movement-flow span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.movement-flow b {
    color: var(--muted);
}

.movement-qty {
    font-size: 22px;
    font-weight: 900;
    text-align: right;
}

.movement-details {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    padding: 12px 14px 14px;
    border-top: 1px solid var(--line);
    background: #f8fafc;
}

.movement-details div {
    min-width: 0;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
}

.movement-details span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 4px;
}

.movement-details strong {
    display: block;
    font-size: 13px;
    overflow-wrap: anywhere;
}

.movement-details small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    margin-top: 3px;
}

@media (max-width: 900px) {
    .movement-item summary {
        grid-template-columns: 1fr auto;
        gap: 8px 12px;
    }

    .movement-date {
        grid-column: 1 / 2;
        grid-row: 1;
    }

    .movement-type {
        grid-column: 2 / 3;
        grid-row: 1;
    }

    .movement-product {
        grid-column: 1 / -1;
        grid-row: 2;
    }

    .movement-flow {
        grid-column: 1 / 2;
        grid-row: 3;
    }

    .movement-qty {
        grid-column: 2 / 3;
        grid-row: 3;
        align-self: center;
    }

    .movement-item summary::after {
        display: none;
    }

    .movement-details {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 520px) {
    .movements-card {
        padding: 10px;
    }

    .movement-item summary {
        padding: 12px;
    }

    .movement-flow {
        font-size: 12px;
    }

    .movement-qty {
        font-size: 24px;
    }

    .movement-details {
        grid-template-columns: 1fr;
        padding: 10px 12px 12px;
    }
}
/* Inventario - lista responsive, mobile UX, stampa/export */
.inventory-print-table {
    display: none !important;
}

.inventory-card {
    display: block !important;
}

.inventory-meta {
    display: flex !important;
    align-items: baseline !important;
    gap: 6px !important;
    margin: 12px 0 14px !important;
    color: var(--muted) !important;
}

.inventory-meta strong {
    color: var(--text) !important;
    font-size: 22px !important;
}

.inventory-meta small {
    margin-left: auto !important;
    color: var(--muted) !important;
}

/* Lista inventario */
.inventory-list {
    display: grid !important;
    gap: 8px !important;
    margin-top: 14px !important;
}

.inventory-item {
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: #fff !important;
    overflow: hidden !important;
}

.inventory-item summary {
    list-style: none !important;
    cursor: pointer !important;
    display: grid !important;
    grid-template-columns: 190px minmax(0, 1fr) 72px !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 14px !important;
}

.inventory-item summary::-webkit-details-marker {
    display: none !important;
}

.inventory-item summary::after {
    content: "⌄" !important;
    color: var(--muted) !important;
    font-weight: 900 !important;
    justify-self: end !important;
}

.inventory-item[open] summary::after {
    content: "⌃" !important;
}

.inventory-ref strong {
    display: block !important;
    font-size: 14px !important;
}

.inventory-ref small {
    display: block !important;
    color: var(--muted) !important;
    font-size: 12px !important;
    margin-top: 3px !important;
}

.inventory-name {
    min-width: 0 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-total {
    font-size: 24px !important;
    font-weight: 900 !important;
    text-align: right !important;
}

.inventory-positions {
    display: grid !important;
    gap: 8px !important;
    padding: 12px 14px 14px !important;
    border-top: 1px solid var(--line) !important;
    background: #f8fafc !important;
}

.inventory-position-row {
    display: grid !important;
    grid-template-columns: 120px minmax(140px, 1fr) minmax(180px, 1.4fr) 80px !important;
    gap: 10px !important;
    align-items: center !important;
    padding: 10px !important;
    border: 1px solid var(--line) !important;
    border-radius: 12px !important;
    background: #fff !important;
}

.inventory-position-row small {
    display: block !important;
    color: var(--muted) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
    margin-bottom: 3px !important;
}

.inventory-position-row strong {
    display: block !important;
    font-size: 13px !important;
    overflow-wrap: anywhere !important;
}

.inventory-position-qty {
    text-align: right !important;
}

.inventory-position-qty strong {
    font-size: 22px !important;
}

/* Mobile inventory bottom bar */
.inventory-mobile-search {
    display: none !important;
}

.inventory-mobile-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
}

.inventory-filter-status {
    padding: 12px !important;
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: #f8fafc !important;
    margin-bottom: 12px !important;
}

.inventory-filter-status strong {
    display: block !important;
    margin-bottom: 6px !important;
}

.inventory-filter-status p {
    margin: 0 !important;
    color: var(--muted) !important;
}

.inventory-filter-status ul {
    margin: 0 !important;
    padding-left: 18px !important;
    color: var(--muted) !important;
}

.inventory-filter-status li + li {
    margin-top: 4px !important;
}

.inventory-mobile-filter-form {
    display: grid !important;
    gap: 8px !important;
}

.inventory-modal-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 10px !important;
}

.inventory-export-options {
    display: grid !important;
    gap: 8px !important;
}

.inventory-export-options .btn {
    width: 100% !important;
    min-height: 46px !important;
}

/* Mobile */
@media (max-width: 760px) {
    .inventory-desktop-filters {
        display: none !important;
    }

    .content {
        padding-bottom: 132px !important;
    }

    .inventory-mobile-search {
        display: grid !important;
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 1000 !important;
        background: #fff !important;
        border-top: 1px solid var(--line) !important;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom)) !important;
        gap: 8px !important;
        box-shadow: 0 -12px 30px rgba(16, 24, 40, .10) !important;
    }

    .inventory-mobile-search input {
        width: 100% !important;
        min-height: 46px !important;
    }

    .inventory-mobile-actions .btn {
        width: 100% !important;
        min-height: 46px !important;
    }

    .inventory-modal-panel {
        width: min(94vw, 440px) !important;
        max-height: calc(100vh - 36px) !important;
        overflow: auto !important;
    }

    .inventory-meta {
        align-items: flex-start !important;
        flex-direction: column !important;
        gap: 2px !important;
    }

    .inventory-meta small {
        margin-left: 0 !important;
    }

    .inventory-item summary {
        grid-template-columns: 1fr auto !important;
        gap: 8px 12px !important;
    }

    .inventory-ref {
        grid-column: 1 / 2 !important;
    }

    .inventory-total {
        grid-column: 2 / 3 !important;
        grid-row: 1 / 3 !important;
        align-self: center !important;
        font-size: 25px !important;
    }

    .inventory-name {
        grid-column: 1 / 2 !important;
        white-space: normal !important;
        font-size: 13px !important;
    }

    .inventory-item summary::after {
        display: none !important;
    }

    .inventory-position-row {
        grid-template-columns: 1fr !important;
    }

    .inventory-position-qty {
        text-align: left !important;
    }
}

/* Print inventario */
@media print {
    body {
        background: #fff !important;
    }

    .sidebar,
    .topbar,
    .toolbar,
    .inventory-filters,
    .inventory-list,
    .pagination,
    .notice-stack,
    .mobile-nav,
    .mobile-nav-toggle,
    .inventory-mobile-search,
    .inventory-modal,
    .inventory-meta {
        display: none !important;
    }

    .content,
    .main,
    .card,
    .inventory-card {
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        box-shadow: none !important;
        background: #fff !important;
    }

    .inventory-print-table {
        display: block !important;
    }

    .inventory-print-table h2 {
        margin: 0 0 14px !important;
        font-size: 20px !important;
    }

    .inventory-print-table table {
        width: 100% !important;
        border-collapse: collapse !important;
        font-size: 11px !important;
    }

    .inventory-print-table th,
    .inventory-print-table td {
        border: 1px solid #222 !important;
        padding: 5px 6px !important;
        text-align: left !important;
        vertical-align: top !important;
    }

    .inventory-print-table th {
        font-weight: 800 !important;
        background: #f1f1f1 !important;
    }

    .inventory-print-table td:last-child,
    .inventory-print-table th:last-child {
        text-align: right !important;
    }

}
/* Inventario - indirizzo subito visibile */
.inventory-item summary {
    grid-template-columns: 190px minmax(0, 1fr) 72px !important;
}

.inventory-main {
    min-width: 0 !important;
    display: grid !important;
    gap: 7px !important;
}

.inventory-name {
    display: block !important;
    min-width: 0 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-zone-preview {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.inventory-zone-chip {
    display: inline-grid !important;
    grid-template-columns: auto auto !important;
    align-items: center !important;
    gap: 4px 8px !important;
    padding: 7px 9px !important;
    border: 1px solid var(--line) !important;
    border-radius: 999px !important;
    background: #f8fafc !important;
    max-width: 100% !important;
}

.inventory-zone-chip strong {
    font-size: 12px !important;
    font-weight: 900 !important;
    color: var(--text) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-zone-chip small {
    grid-column: 1 / -1 !important;
    font-size: 11px !important;
    color: var(--muted) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-zone-chip b {
    font-size: 13px !important;
    font-weight: 900 !important;
    color: var(--primary) !important;
}

.inventory-position-row {
    grid-template-columns: minmax(0, 1fr) 90px !important;
}

.inventory-position-row em {
    display: block !important;
    margin-top: 4px !important;
    color: var(--muted) !important;
    font-size: 12px !important;
    font-style: normal !important;
    overflow-wrap: anywhere !important;
}

@media (max-width: 760px) {
    .inventory-item summary {
        grid-template-columns: 1fr auto !important;
        gap: 8px 12px !important;
    }

    .inventory-ref {
        grid-column: 1 / 2 !important;
    }

    .inventory-main {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
    }

    .inventory-total {
        grid-column: 2 / 3 !important;
        grid-row: 1 !important;
        align-self: center !important;
        font-size: 26px !important;
    }

    .inventory-name {
        white-space: normal !important;
        font-size: 13px !important;
        line-height: 1.35 !important;
    }

    .inventory-zone-preview {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 6px !important;
    }

    .inventory-zone-chip {
        border-radius: 12px !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        width: 100% !important;
    }

    .inventory-zone-chip strong {
        font-size: 13px !important;
    }

    .inventory-zone-chip b {
        font-size: 16px !important;
    }

    .inventory-position-row {
        grid-template-columns: 1fr auto !important;
    }

    .inventory-position-qty {
        text-align: right !important;
    }
}
/* Inventario - lista senza dropdown */
.inventory-item-static {
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: #fff !important;
    overflow: hidden !important;
}

.inventory-item-head {
    display: grid !important;
    grid-template-columns: 190px minmax(0, 1fr) 72px !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 14px !important;
}

.inventory-item-static .inventory-main {
    min-width: 0 !important;
    display: grid !important;
    gap: 7px !important;
}

.inventory-item-static .inventory-name {
    display: block !important;
    min-width: 0 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-item-static .inventory-total {
    font-size: 24px !important;
    font-weight: 900 !important;
    text-align: right !important;
}

.inventory-item-static .inventory-zone-preview {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.inventory-item-static .inventory-zone-chip {
    display: inline-grid !important;
    grid-template-columns: minmax(0, auto) auto !important;
    align-items: center !important;
    gap: 4px 8px !important;
    padding: 7px 9px !important;
    border: 1px solid var(--line) !important;
    border-radius: 999px !important;
    background: #f8fafc !important;
    max-width: 100% !important;
}

.inventory-item-static .inventory-zone-chip strong {
    font-size: 12px !important;
    font-weight: 900 !important;
    color: var(--text) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-item-static .inventory-zone-chip small {
    grid-column: 1 / -1 !important;
    font-size: 11px !important;
    color: var(--muted) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.inventory-item-static .inventory-zone-chip b {
    font-size: 13px !important;
    font-weight: 900 !important;
    color: var(--primary) !important;
}

@media (max-width: 760px) {
    .inventory-item-head {
        grid-template-columns: 1fr auto !important;
        gap: 8px 12px !important;
    }

    .inventory-item-static .inventory-ref {
        grid-column: 1 / 2 !important;
    }

    .inventory-item-static .inventory-total {
        grid-column: 2 / 3 !important;
        grid-row: 1 !important;
        align-self: center !important;
        font-size: 26px !important;
    }

    .inventory-item-static .inventory-main {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
    }

    .inventory-item-static .inventory-name {
        white-space: normal !important;
        font-size: 13px !important;
        line-height: 1.35 !important;
    }

    .inventory-item-static .inventory-zone-preview {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 6px !important;
    }

    .inventory-item-static .inventory-zone-chip {
        width: 100% !important;
        border-radius: 12px !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
    }

    .inventory-item-static .inventory-zone-chip strong {
        font-size: 13px !important;
    }

    .inventory-item-static .inventory-zone-chip b {
        font-size: 16px !important;
    }
}
/* Hub Unplaced - lista semplice, export e stampa */
.unplaced-hub-card {
    display: block !important;
}

.unplaced-filters {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto auto auto !important;
    gap: 8px !important;
    align-items: center !important;
}

.unplaced-filters input {
    min-height: 44px !important;
}

.unplaced-meta {
    display: flex !important;
    align-items: baseline !important;
    gap: 6px !important;
    margin: 12px 0 14px !important;
    color: var(--muted) !important;
}

.unplaced-meta strong {
    color: var(--text) !important;
    font-size: 22px !important;
}

.unplaced-simple-list {
    display: grid !important;
    gap: 8px !important;
}

.unplaced-simple-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 120px 72px !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 13px 14px !important;
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: #fff !important;
    color: inherit !important;
    text-decoration: none !important;
}

.unplaced-simple-row:hover {
    border-color: var(--primary) !important;
    box-shadow: 0 8px 20px rgba(16, 24, 40, .08) !important;
}

.unplaced-object {
    min-width: 0 !important;
}

.unplaced-object strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.unplaced-object small {
    display: block !important;
    margin-top: 4px !important;
    color: var(--muted) !important;
    font-size: 12px !important;
}

.unplaced-status {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 30px !important;
    padding: 5px 9px !important;
    border-radius: 999px !important;
    background: #fff7ed !important;
    color: #b54708 !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

.unplaced-qty {
    text-align: right !important;
}

.unplaced-qty small {
    display: block !important;
    color: var(--muted) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
}

.unplaced-qty strong {
    display: block !important;
    font-size: 22px !important;
    font-weight: 900 !important;
}

.unplaced-print-table {
    display: none !important;
}

@media (max-width: 760px) {
    .unplaced-filters {
        grid-template-columns: 1fr 1fr !important;
    }

    .unplaced-filters input {
        grid-column: 1 / -1 !important;
    }

    .unplaced-filters .btn {
        width: 100% !important;
        justify-content: center !important;
    }

    .unplaced-simple-row {
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 8px 12px !important;
    }

    .unplaced-object {
        grid-column: 1 / -1 !important;
    }

    .unplaced-object strong {
        white-space: normal !important;
        line-height: 1.35 !important;
    }

    .unplaced-status {
        grid-column: 1 / 2 !important;
        justify-self: start !important;
    }

    .unplaced-qty {
        grid-column: 2 / 3 !important;
        text-align: right !important;
    }
}

@media print {
    body {
        background: #fff !important;
    }

    .sidebar,
    .topbar,
    .toolbar,
    .unplaced-filters,
    .unplaced-simple-list,
    .pagination,
    .notice-stack,
    .mobile-nav,
    .mobile-nav-toggle,
    .unplaced-meta {
        display: none !important;
    }

    .content,
    .main,
    .card,
    .unplaced-hub-card {
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        box-shadow: none !important;
        background: #fff !important;
    }

    .unplaced-print-table {
        display: block !important;
    }

    .unplaced-print-table h2 {
        margin: 0 0 14px !important;
        font-size: 20px !important;
    }

    .unplaced-print-table table {
        width: 100% !important;
        border-collapse: collapse !important;
        font-size: 11px !important;
    }

    .unplaced-print-table th,
    .unplaced-print-table td {
        border: 1px solid #222 !important;
        padding: 5px 6px !important;
        text-align: left !important;
        vertical-align: top !important;
    }

    .unplaced-print-table th {
        font-weight: 800 !important;
        background: #f1f1f1 !important;
    }

    .unplaced-print-table td:last-child,
    .unplaced-print-table th:last-child {
        text-align: right !important;
    }
}
/* Hub Unplaced - mobile bottom search, filter modal, print/export modal */
.unplaced-mobile-search {
    display: none !important;
}

.unplaced-hub-card {
    display: block !important;
}

.unplaced-filters {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 210px auto auto auto auto !important;
    gap: 8px !important;
    align-items: center !important;
}

.unplaced-filters input,
.unplaced-filters select {
    min-height: 44px !important;
}

.unplaced-meta {
    display: flex !important;
    align-items: baseline !important;
    gap: 6px !important;
    margin: 12px 0 14px !important;
    color: var(--muted) !important;
}

.unplaced-meta strong {
    color: var(--text) !important;
    font-size: 22px !important;
}

.unplaced-simple-list {
    display: grid !important;
    gap: 8px !important;
}

.unplaced-simple-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 120px 72px !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 13px 14px !important;
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: #fff !important;
    color: inherit !important;
    text-decoration: none !important;
}

.unplaced-simple-row:hover {
    border-color: var(--primary) !important;
    box-shadow: 0 8px 20px rgba(16, 24, 40, .08) !important;
}

.unplaced-object {
    min-width: 0 !important;
}

.unplaced-object strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.unplaced-object small {
    display: block !important;
    margin-top: 4px !important;
    color: var(--muted) !important;
    font-size: 12px !important;
}

.unplaced-status {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 30px !important;
    padding: 5px 9px !important;
    border-radius: 999px !important;
    background: #fff7ed !important;
    color: #b54708 !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

.unplaced-qty {
    text-align: right !important;
}

.unplaced-qty small {
    display: block !important;
    color: var(--muted) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
}

.unplaced-qty strong {
    display: block !important;
    font-size: 22px !important;
    font-weight: 900 !important;
}

.unplaced-print-table {
    display: none !important;
}

.unplaced-mobile-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
}

.unplaced-mobile-filter-form {
    display: grid !important;
    gap: 8px !important;
}

.unplaced-modal-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 10px !important;
}

.unplaced-export-options {
    display: grid !important;
    gap: 8px !important;
}

.unplaced-export-options .btn {
    width: 100% !important;
    min-height: 46px !important;
}

@media (max-width: 760px) {
    .unplaced-desktop-filters {
        display: none !important;
    }

    .content {
        padding-bottom: 132px !important;
    }

    .unplaced-mobile-search {
        display: grid !important;
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 1000 !important;
        background: #fff !important;
        border-top: 1px solid var(--line) !important;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom)) !important;
        gap: 8px !important;
        box-shadow: 0 -12px 30px rgba(16, 24, 40, .10) !important;
    }

    .unplaced-mobile-search input {
        width: 100% !important;
        min-height: 46px !important;
    }

    .unplaced-mobile-actions .btn {
        width: 100% !important;
        min-height: 46px !important;
    }

    .unplaced-modal-panel {
        width: min(94vw, 440px) !important;
        max-height: calc(100vh - 36px) !important;
        overflow: auto !important;
    }

    .unplaced-simple-row {
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 8px 12px !important;
    }

    .unplaced-object {
        grid-column: 1 / -1 !important;
    }

    .unplaced-object strong {
        white-space: normal !important;
        line-height: 1.35 !important;
    }

    .unplaced-status {
        grid-column: 1 / 2 !important;
        justify-self: start !important;
    }

    .unplaced-qty {
        grid-column: 2 / 3 !important;
        text-align: right !important;
    }
}

@media print {
    .sidebar,
    .topbar,
    .toolbar,
    .unplaced-filters,
    .unplaced-simple-list,
    .pagination,
    .notice-stack,
    .mobile-nav,
    .mobile-nav-toggle,
    .unplaced-meta,
    .unplaced-mobile-search,
    .unplaced-modal {
        display: none !important;
    }

    .content,
    .main,
    .card,
    .unplaced-hub-card {
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        box-shadow: none !important;
        background: #fff !important;
    }

    .unplaced-print-table {
        display: block !important;
    }

    .unplaced-print-table h2 {
        margin: 0 0 14px !important;
        font-size: 20px !important;
    }

    .unplaced-print-table table {
        width: 100% !important;
        border-collapse: collapse !important;
        font-size: 11px !important;
    }

    .unplaced-print-table th,
    .unplaced-print-table td {
        border: 1px solid #222 !important;
        padding: 5px 6px !important;
        text-align: left !important;
        vertical-align: top !important;
    }

    .unplaced-print-table th {
        font-weight: 800 !important;
        background: #f1f1f1 !important;
    }

    .unplaced-print-table td:last-child,
    .unplaced-print-table th:last-child {
        text-align: right !important;
    }
}
