*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:Arial,Helvetica,sans-serif;background:#f4f4f4;color:#111}a{color:inherit}.vg-sidebar{position:fixed;inset:0 auto 0 0;width:280px;background:#111;color:#fff;padding:22px 18px;overflow:auto;border-right:5px solid #ff7a1a;z-index:20}.vg-brand{display:grid;grid-template-columns:52px 1fr;gap:10px;text-decoration:none;align-items:center;margin-bottom:22px}.vg-brand span{grid-row:1/3;width:52px;height:52px;background:#ff7a1a;color:#111;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:22px}.vg-brand strong{font-size:24px;line-height:1}.vg-brand small{color:#ddd;text-transform:uppercase;letter-spacing:.12em}.vg-card.mini{background:#1c1c1c;border:1px solid #2c2c2c;padding:16px;margin-bottom:18px}.vg-card.mini span,.vg-kicker{display:block;color:#ff7a1a;text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:900}.vg-card.mini strong{display:block;margin:8px 0 3px;font-size:19px}.vg-card.mini small{color:#ccc}.vg-nav{display:grid;gap:8px}.vg-nav a{padding:13px 14px;text-decoration:none;color:#eee;font-weight:800}.vg-nav a.active,.vg-nav a:hover{background:#ff7a1a;color:#111}.vg-logout{display:block;margin-top:24px;color:#fff;text-decoration:none;border:1px solid #333;padding:12px 14px}.vg-main{margin-left:285px;padding:38px 46px}.vg-top{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px}.vg-top h1{margin:6px 0 0;font-size:48px;line-height:.98;letter-spacing:-.04em}.vg-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#111;color:#fff;text-decoration:none;border:0;padding:13px 16px;font-weight:900;cursor:pointer;font-size:15px}.vg-btn.orange{background:#ff7a1a;color:#111}.vg-btn.ghost{background:#fff;color:#111;border:1px solid #ddd}.vg-btn.small{padding:9px 11px;font-size:13px}.vg-grid{display:grid;gap:18px}.vg-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.vg-grid.two{grid-template-columns:1fr 1fr}.vg-stat,.vg-panel,.vg-list-card{background:#fff;border:1px solid #e6e6e6;box-shadow:0 10px 28px rgba(0,0,0,.04)}.vg-stat{padding:22px;border-top:5px solid #111}.vg-stat.orange{border-top-color:#ff7a1a}.vg-stat.good{border-top-color:#0f8a43}.vg-stat.red{border-top-color:#b42318}.vg-stat span{display:block;color:#555;text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:900}.vg-stat strong{display:block;margin:12px 0;font-size:42px;line-height:1}.vg-stat small{color:#777}.vg-panel{padding:24px}.vg-panel-title{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}.vg-panel h2{margin:0;font-size:26px}.vg-form{display:grid;gap:14px}.vg-field label{display:block;font-weight:900;margin-bottom:7px}.vg-field input,.vg-field select,.vg-field textarea{width:100%;padding:13px 14px;border:1px solid #ddd;background:#fff;font-size:16px;outline:none}.vg-field input:focus,.vg-field select:focus,.vg-field textarea:focus{border-color:#ff7a1a;box-shadow:0 0 0 4px rgba(255,122,26,.14)}.vg-field textarea{min-height:90px;resize:vertical}.vg-muted{color:#666;line-height:1.55}.vg-alert{padding:14px 16px;margin:0 0 16px;font-weight:800}.vg-alert.success{background:#fff3e9;border:1px solid #ffd3b0;color:#8a4700}.vg-alert.error{background:#fff1f1;border:1px solid #fecaca;color:#7f1d1d}.vg-table{width:100%;border-collapse:separate;border-spacing:0 10px}.vg-table th{text-align:left;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.vg-table td{background:#fff;border-top:1px solid #eee;border-bottom:1px solid #eee;padding:14px}.vg-table td:first-child{border-left:1px solid #eee}.vg-table td:last-child{border-right:1px solid #eee}.vg-badge{display:inline-flex;padding:6px 9px;background:#fff3e9;color:#8a4700;font-weight:900;font-size:12px}.vg-actions{display:flex;gap:8px;flex-wrap:wrap}.vg-empty{padding:28px;background:#fff;border:1px dashed #ccc;text-align:center}.vg-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#000,#1b1b1b)}.vg-login-box{width:min(440px,100%);background:#fff;padding:30px;border-top:6px solid #ff7a1a}.vg-login-box h1{margin:0 0 10px;font-size:34px}.vg-mobile{display:none;position:fixed;top:12px;left:12px;z-index:30;background:#ff7a1a;color:#111;border:0;width:46px;height:46px;font-size:22px;font-weight:900}.print-sheet{background:#fff}.label-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12mm;padding:10mm}.qr-label{border:1.5px solid #111;padding:10mm;min-height:120mm;display:grid;grid-template-rows:auto 1fr auto;page-break-inside:avoid}.qr-label.orange{border-color:#ff7a1a}.qr-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;border-bottom:3px solid #111;padding-bottom:8px}.qr-head h2{margin:0;font-size:22px}.qr-head strong{color:#ff7a1a}.qr-body{text-align:center;padding:14px 0}.qr-body img{width:155px;height:155px}.qr-code{font-weight:900;font-size:15px;margin-top:8px}.qr-foot{font-size:13px;color:#333;border-top:1px solid #ddd;padding-top:8px}.print-actions{position:sticky;top:0;background:#111;color:#fff;padding:10px;display:flex;gap:8px;z-index:5}@media print{body{background:#fff}.print-actions{display:none}.label-grid{padding:0;gap:0;grid-template-columns:repeat(2,1fr)}.qr-label{margin:5mm;min-height:130mm}}@media(max-width:980px){.vg-mobile{display:block}.vg-sidebar{transform:translateX(-105%);transition:.2s}.vg-sidebar.open{transform:translateX(0)}.vg-main{margin-left:0;padding:78px 14px 24px}.vg-top{display:block}.vg-top h1{font-size:36px;margin-bottom:16px}.vg-grid.four,.vg-grid.two{grid-template-columns:1fr}.vg-panel{padding:18px}.vg-table{font-size:14px}.vg-table thead{display:none}.vg-table,.vg-table tbody,.vg-table tr,.vg-table td{display:block;width:100%}.vg-table tr{margin-bottom:12px}.vg-table td{border-left:1px solid #eee;border-right:1px solid #eee}.label-grid{grid-template-columns:1fr;padding:10px}.qr-label{min-height:auto}.qr-body img{width:180px;height:180px}}


/* V2 — upload logo/photo étiquette */
.vg-upload{
    display:flex !important;
    align-items:center;
    gap:12px;
    width:100%;
    padding:12px;
    border:1px dashed #cfcfcf;
    background:#fff;
    cursor:pointer;
}
.vg-upload input[type=file]{
    position:absolute;
    width:1px;
    height:1px;
    opacity:0;
    pointer-events:none;
}
.vg-upload-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 16px;
    background:#111;
    color:#fff;
    font-weight:900;
    white-space:nowrap;
}
.vg-upload-text{
    color:#555;
    font-weight:700;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
.vg-upload:hover{
    border-color:#ff7a1a;
    box-shadow:0 0 0 4px rgba(255,122,26,.12);
}
.qr-logo{
    max-width:80px;
    max-height:54px;
    object-fit:contain;
    display:block;
}
@media(max-width:760px){
    .vg-upload{
        align-items:stretch;
        flex-direction:column;
    }
    .vg-upload-btn{
        width:100%;
    }
    .vg-upload-text{
        white-space:normal;
    }
}
