/* Portal Vendor — design system (light default + dark toggle) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root,[data-theme="light"]{
    --vp-bg:#eef1f6;
    --vp-surface:#ffffff;
    --vp-surface-2:#f8fafc;
    --vp-surface-hover:#f1f5f9;
    --vp-border:#e2e8f0;
    --vp-border-soft:#f1f5f9;
    --vp-text:#1e293b;
    --vp-text-secondary:#475569;
    --vp-text-muted:#94a3b8;
    --vp-accent:#0d9488;
    --vp-accent-hover:#0f766e;
    --vp-accent-soft:#ecfdf5;
    --vp-accent-rfq:#2563eb;
    --vp-accent-rfq-soft:#eff6ff;
    --vp-shadow:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
    --vp-shadow-md:0 4px 16px rgba(15,23,42,.08);
    --vp-header-bg:rgba(255,255,255,.92);
    --vp-input-bg:#fff;
    --vp-success-bg:#f0fdf4;--vp-success-text:#166534;--vp-success-border:#bbf7d0;
    --vp-warn-bg:#fffbeb;--vp-warn-text:#92400e;--vp-warn-border:#fde68a;
    --vp-error-bg:#fef2f2;--vp-error-text:#991b1b;--vp-error-border:#fecaca;
    --vp-info-bg:#eff6ff;--vp-info-text:#1e40af;--vp-info-border:#bfdbfe;
    --vp-link:#0d9488;
    --vp-radius:8px;
    --vp-radius-lg:12px;
    --vp-font:13px;
    --vp-font-sm:12px;
    --vp-font-xs:11px;
    --vp-font-lg:14px;
    --vp-font-xl:16px;
}

[data-theme="dark"]{
    --vp-bg:#0c1017;
    --vp-surface:#151c28;
    --vp-surface-2:#1a2332;
    --vp-surface-hover:#1f2a3d;
    --vp-border:#2a3548;
    --vp-border-soft:#1f2a3d;
    --vp-text:#e2e8f0;
    --vp-text-secondary:#94a3b8;
    --vp-text-muted:#64748b;
    --vp-accent:#2dd4bf;
    --vp-accent-hover:#5eead4;
    --vp-accent-soft:#134e4a33;
    --vp-accent-rfq:#60a5fa;
    --vp-accent-rfq-soft:#1e3a5f33;
    --vp-shadow:0 1px 3px rgba(0,0,0,.3);
    --vp-shadow-md:0 4px 20px rgba(0,0,0,.35);
    --vp-header-bg:rgba(21,28,40,.94);
    --vp-input-bg:#1a2332;
    --vp-success-bg:#14532d33;--vp-success-text:#86efac;--vp-success-border:#166534;
    --vp-warn-bg:#78350f33;--vp-warn-text:#fcd34d;--vp-warn-border:#92400e;
    --vp-error-bg:#7f1d1d33;--vp-error-text:#fca5a5;--vp-error-border:#991b1b;
    --vp-info-bg:#1e3a8a33;--vp-info-text:#93c5fd;--vp-info-border:#1d4ed8;
    --vp-link:#2dd4bf;
}

html{font-size:var(--vp-font);height:100%}
body{
    font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
    background:var(--vp-bg);
    color:var(--vp-text);
    min-height:100vh;
    display:flex;
    flex-direction:column;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
}
a{color:var(--vp-link);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Header ── */
.vp-header{
    background:var(--vp-header-bg);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--vp-border);
    position:sticky;top:0;z-index:200;width:100%;
}
.vp-header-inner{
    width:100%;padding:10px 24px;
    display:flex;align-items:center;justify-content:space-between;
    flex-wrap:wrap;gap:10px;
}
.vp-brand h1{font-size:var(--vp-font-lg);font-weight:700;color:var(--vp-text);line-height:1.3}
.vp-brand p{font-size:var(--vp-font-sm);color:var(--vp-text-muted);margin-top:1px}
.vp-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.vp-nav{display:flex;flex-wrap:wrap;align-items:center;gap:4px}
.vp-nav-link{
    padding:6px 12px;border-radius:6px;
    font-size:var(--vp-font-sm);font-weight:600;
    text-decoration:none;color:var(--vp-text-secondary);
    transition:background .15s,color .15s;
}
.vp-nav-link:hover{background:var(--vp-surface-hover);color:var(--vp-text);text-decoration:none}
.vp-nav-link.active{background:var(--vp-accent);color:#fff}
.vp-nav-link.active:hover{background:var(--vp-accent-hover);color:#fff}
body.vp-rfq .vp-nav-link.active{background:var(--vp-accent-rfq)}
body.vp-rfq .vp-nav-link.active:hover{opacity:.9}
.vp-nav-link.vp-out{color:var(--vp-text-muted)}
.vp-theme-btn,.theme-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:32px;height:32px;border-radius:6px;
    border:1px solid var(--vp-border);background:var(--vp-surface-2);
    color:var(--vp-text-secondary);cursor:pointer;transition:.15s;
}
.vp-theme-btn:hover,.theme-toggle:hover{background:var(--vp-surface-hover);color:var(--vp-text)}

/* ── Main ── */
.vp-main{flex:1;width:100%;padding:20px 24px 32px}
.vp-main-inner{width:100%;max-width:1440px;margin:0 auto}

/* ── Page header ── */
.vp-page-head{margin-bottom:16px}
.vp-page-head h2{font-size:var(--vp-font-xl);font-weight:700;color:var(--vp-text);margin-bottom:2px}
.vp-page-head p{font-size:var(--vp-font-sm);color:var(--vp-text-muted)}
.vp-back{
    display:inline-flex;align-items:center;gap:4px;
    font-size:var(--vp-font-sm);color:var(--vp-text-muted);
    text-decoration:none;margin-bottom:12px;font-weight:500;
}
.vp-back:hover{color:var(--vp-accent);text-decoration:none}
.vp-back svg{flex-shrink:0}

/* ── Cards ── */
.card{
    background:var(--vp-surface);
    border-radius:var(--vp-radius-lg);
    padding:16px 18px;
    margin-bottom:14px;
    border:1px solid var(--vp-border);
    box-shadow:var(--vp-shadow);
}
.card h2{
    font-size:var(--vp-font-lg);
    margin-bottom:12px;
    color:var(--vp-text);
    border-bottom:1px solid var(--vp-border-soft);
    padding-bottom:8px;
    font-weight:700;
}
.card-head{
    display:flex;justify-content:space-between;align-items:flex-start;
    flex-wrap:wrap;gap:10px;margin-bottom:12px;
}
.card-head h2,.card-head .card-title{
    border:none;padding:0;margin:0;
    font-size:var(--vp-font-xl);font-weight:700;color:var(--vp-text);
}
.card-sub{font-size:var(--vp-font-sm);color:var(--vp-text-muted);margin-top:2px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.grid .lbl{font-size:var(--vp-font-xs);color:var(--vp-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.grid .val{font-weight:600;font-size:var(--vp-font);margin-top:3px;color:var(--vp-text)}
.note-box{
    font-size:var(--vp-font-sm);margin-top:10px;padding:8px 10px;
    background:var(--vp-surface-2);border-radius:var(--vp-radius);
    border:1px solid var(--vp-border-soft);color:var(--vp-text-secondary);
}

/* ── Badges & alerts ── */
.badge{
    display:inline-block;padding:3px 9px;border-radius:99px;
    font-size:var(--vp-font-xs);font-weight:700;
    background:var(--vp-accent-rfq-soft);color:var(--vp-accent-rfq);white-space:nowrap;
}
.badge-warn{background:var(--vp-warn-bg);color:var(--vp-warn-text)}
.badge-ok{background:var(--vp-success-bg);color:var(--vp-success-text)}
.badge-danger{background:var(--vp-error-bg);color:var(--vp-error-text)}
.badge-muted{background:var(--vp-surface-2);color:var(--vp-text-muted);border:1px solid var(--vp-border)}
.status-pill{display:inline-block;padding:3px 9px;border-radius:99px;font-size:var(--vp-font-xs);font-weight:700}

.alert{
    padding:10px 14px;border-radius:var(--vp-radius);
    margin-bottom:14px;font-size:var(--vp-font-sm);
    display:flex;align-items:flex-start;gap:10px;
    border:1px solid transparent;
}
.alert-body{flex:1}
.alert-close{
    background:none;border:none;color:inherit;opacity:.6;
    cursor:pointer;font-size:14px;line-height:1;padding:0 2px;
}
.alert-close:hover{opacity:1}
.alert-err,.alert-error{background:var(--vp-error-bg);color:var(--vp-error-text);border-color:var(--vp-error-border)}
.alert-ok,.alert-success{background:var(--vp-success-bg);color:var(--vp-success-text);border-color:var(--vp-success-border)}
.alert-info{background:var(--vp-info-bg);color:var(--vp-info-text);border-color:var(--vp-info-border)}
.alert-warn{background:var(--vp-warn-bg);color:var(--vp-warn-text);border-color:var(--vp-warn-border)}
.alert-action{justify-content:space-between;align-items:center;flex-wrap:wrap}

/* ── Tables ── */
.table-wrap{overflow-x:auto;margin:0 -2px}
table{width:100%;border-collapse:collapse;font-size:var(--vp-font)}
th,td{padding:8px 10px;border-bottom:1px solid var(--vp-border-soft);text-align:left;vertical-align:top}
th{
    background:var(--vp-surface-2);font-size:var(--vp-font-xs);
    color:var(--vp-text-muted);font-weight:700;
    text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;
}
tr:hover td{background:var(--vp-surface-hover)}
.text-right{text-align:right}

/* ── Buttons & forms ── */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    padding:7px 14px;border-radius:6px;border:none;
    font-weight:600;font-size:var(--vp-font-sm);
    cursor:pointer;text-decoration:none;font-family:inherit;
    transition:opacity .15s,transform .1s,background .15s;
    white-space:nowrap;
}
.btn:hover{opacity:.92;text-decoration:none}
.btn:active{transform:scale(.98)}
.btn-sm{padding:5px 10px;font-size:var(--vp-font-xs)}
.btn-primary{background:var(--vp-accent);color:#fff}
.btn-success{background:var(--vp-accent);color:#fff}
.btn-outline{background:var(--vp-surface);border:1px solid var(--vp-border);color:var(--vp-text-secondary)}
.btn-danger{background:#dc2626;color:#fff}
.btn-warn{background:#d97706;color:#fff}
body.vp-rfq .btn-primary{background:var(--vp-accent-rfq)}
.form-group{margin-bottom:12px}
.form-label{display:block;font-size:var(--vp-font-xs);font-weight:600;color:var(--vp-text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}
.form-control{
    width:100%;padding:8px 11px;
    border:1px solid var(--vp-border);border-radius:6px;
    font-size:var(--vp-font-sm);font-family:inherit;
    background:var(--vp-input-bg);color:var(--vp-text);
}
.form-control:focus{outline:none;border-color:var(--vp-accent);box-shadow:0 0 0 2px var(--vp-accent-soft)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
input[type=number],input[type=text],input[type=date],textarea,select{
    width:100%;padding:7px 10px;
    border:1px solid var(--vp-border);border-radius:6px;
    font-size:var(--vp-font-sm);font-family:inherit;
    background:var(--vp-input-bg);color:var(--vp-text);
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--vp-accent);box-shadow:0 0 0 2px var(--vp-accent-soft)}

/* ── List ── */
.vp-list{display:grid;gap:8px}
.vp-list-item{
    display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;
    padding:12px 14px;border:1px solid var(--vp-border);border-radius:var(--vp-radius);
    text-decoration:none;color:inherit;background:var(--vp-surface);
    transition:box-shadow .15s,border-color .15s,transform .1s;
}
.vp-list-item:hover{
    box-shadow:var(--vp-shadow-md);border-color:var(--vp-accent);
    transform:translateY(-1px);text-decoration:none;
}
.vp-list-item strong{font-size:var(--vp-font);font-weight:700;color:var(--vp-text)}
.vp-list-item .meta{font-size:var(--vp-font-sm);color:var(--vp-text-muted);margin-top:3px}
.vp-list-item .vp-list-arrow{color:var(--vp-text-muted);font-size:var(--vp-font-xs)}

/* ── Empty state ── */
.vp-empty{text-align:center;padding:36px 20px;color:var(--vp-text-muted)}
.vp-empty-icon{
    width:44px;height:44px;margin:0 auto 12px;
    border-radius:50%;background:var(--vp-surface-2);
    border:1px dashed var(--vp-border);
    display:flex;align-items:center;justify-content:center;
    font-size:18px;opacity:.7;
}
.vp-empty p{font-size:var(--vp-font-sm);font-weight:600;color:var(--vp-text-secondary);margin-bottom:4px}
.vp-empty span{font-size:var(--vp-font-xs)}

/* ── PO ── */
.po-lifecycle{display:flex;flex-wrap:wrap;gap:0;margin:10px 0;overflow-x:auto;padding-bottom:4px}
.po-lc-step{flex:1;min-width:72px;text-align:center;position:relative;padding:0 4px 8px}
.po-lc-step:not(:last-child)::after{
    content:'';position:absolute;top:11px;right:-50%;width:100%;height:2px;
    background:var(--vp-border);z-index:0;
}
.po-lc-step.done:not(:last-child)::after,.po-lc-step.current:not(:last-child)::after{background:var(--vp-accent)}
.po-lc-dot{
    width:22px;height:22px;border-radius:50%;
    background:var(--vp-surface-2);color:var(--vp-text-muted);
    display:inline-flex;align-items:center;justify-content:center;
    font-size:9px;font-weight:700;margin:0 auto 4px;
    position:relative;z-index:1;border:2px solid var(--vp-surface);
}
.po-lc-step.done .po-lc-dot{background:var(--vp-accent);color:#fff}
.po-lc-step.current .po-lc-dot{background:var(--vp-accent-rfq);color:#fff;box-shadow:0 0 0 2px var(--vp-accent-rfq-soft)}
.po-lc-label{font-size:9px;font-weight:600;color:var(--vp-text-muted);line-height:1.25}
.po-lc-date{font-size:8px;color:var(--vp-text-muted);margin-top:2px;line-height:1.2}
.po-lc-detail{font-size:8px;color:var(--vp-text-secondary);margin-top:3px;line-height:1.3;max-width:88px;margin-left:auto;margin-right:auto}

/* Vendor PO process flow */
.vp-process-mini{margin-top:8px;padding-top:8px;border-top:1px dashed var(--vp-border)}
.vp-process-mini-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px}
.vp-process-mini-label{font-size:var(--vp-font-xs);font-weight:600;color:var(--vp-text-secondary);line-height:1.3}
.vp-process-mini-label.vp-process-terminal{color:#b91c1c}
.vp-process-mini-pct{font-size:var(--vp-font-xs);font-weight:700;color:var(--vp-accent);white-space:nowrap}
.vp-process-mini-bar{height:4px;background:var(--vp-border);border-radius:2px;overflow:hidden;margin-bottom:6px}
.vp-process-mini-fill{height:100%;background:var(--vp-accent);border-radius:2px;transition:width .2s}
.vp-process-mini-dots{display:flex;gap:4px;flex-wrap:wrap}
.vp-pdot{width:7px;height:7px;border-radius:50%;background:var(--vp-border);flex-shrink:0}
.vp-pdot.done{background:var(--vp-accent)}
.vp-pdot.current{background:var(--vp-accent-rfq);box-shadow:0 0 0 2px var(--vp-accent-rfq-soft)}
.vp-process-now{
    padding:12px 14px;margin-bottom:14px;border-radius:var(--vp-radius);
    background:var(--vp-accent-rfq-soft);border:1px solid var(--vp-accent-rfq);
}
.vp-process-now-label{font-size:var(--vp-font-sm);color:var(--vp-text)}
.vp-process-now-hint{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin-top:4px;line-height:1.4}
.vp-process-overall{height:6px;background:var(--vp-surface);border-radius:3px;overflow:hidden;margin-top:10px;border:1px solid var(--vp-border)}
.vp-process-overall-fill{height:100%;background:var(--vp-accent);border-radius:3px}
.vp-process-overall-text{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin-top:6px}
.vp-process-steps .po-lc-step{min-width:84px}
.vp-process-footnote{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin:12px 0 0;line-height:1.45}
.vp-process-terminal-box{
    padding:14px;border-radius:var(--vp-radius);
    background:#fef2f2;border:1px solid #fecaca;color:#991b1b;font-size:var(--vp-font-sm);
}
.vp-process-terminal-box p{margin:6px 0 0;font-size:var(--vp-font-xs);color:#b91c1c}

/* Vertical process timeline with dates */
.vp-process-timeline{display:flex;flex-direction:column;gap:0;margin-top:4px}
.vp-process-item{display:flex;gap:12px;position:relative;padding-bottom:18px}
.vp-process-item:last-child{padding-bottom:0}
.vp-process-item:not(:last-child)::before{
    content:'';position:absolute;left:13px;top:28px;bottom:0;width:2px;background:var(--vp-border);
}
.vp-process-item.done:not(:last-child)::before,.vp-process-item.current:not(:last-child)::before{background:var(--vp-accent)}
.vp-process-marker{
    flex-shrink:0;width:28px;height:28px;border-radius:50%;
    background:var(--vp-surface-2);color:var(--vp-text-muted);
    display:flex;align-items:center;justify-content:center;
    font-size:11px;font-weight:700;border:2px solid var(--vp-surface);z-index:1;
}
.vp-process-item.done .vp-process-marker{background:var(--vp-accent);color:#fff}
.vp-process-item.current .vp-process-marker{background:var(--vp-accent-rfq);color:#fff;box-shadow:0 0 0 3px var(--vp-accent-rfq-soft)}
.vp-process-body{
    flex:1;min-width:0;padding:8px 12px;border-radius:var(--vp-radius);
    background:var(--vp-surface-2);border:1px solid var(--vp-border);
}
.vp-process-item.current .vp-process-body{background:var(--vp-accent-rfq-soft);border-color:var(--vp-accent-rfq)}
.vp-process-item.done .vp-process-body{border-color:color-mix(in srgb,var(--vp-accent) 35%,var(--vp-border))}
.vp-process-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px 16px}
.vp-process-title{font-size:var(--vp-font-sm);font-weight:700;color:var(--vp-text);line-height:1.3}
.vp-process-dates{text-align:right;min-width:120px}
.vp-process-date-main{font-size:var(--vp-font-xs);font-weight:600;color:var(--vp-text-secondary);white-space:nowrap}
.vp-process-date-sub{font-size:10px;color:var(--vp-text-muted);margin-top:2px;line-height:1.3}
.vp-process-date-muted{color:var(--vp-text-muted);font-weight:500;font-style:italic}
.vp-process-detail{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin-top:6px;line-height:1.4}
@media (max-width:520px){
    .vp-process-row{flex-direction:column}
    .vp-process-dates{text-align:left}
    .vp-process-date-main{white-space:normal}
}
.shipment-card{
    border:1px solid var(--vp-border);border-radius:var(--vp-radius);
    padding:12px;margin-bottom:10px;background:var(--vp-surface-2);
}
.shipment-card h3{font-size:var(--vp-font-sm);margin-bottom:6px;color:var(--vp-text);font-weight:700}
.progress-bar{height:6px;background:var(--vp-border);border-radius:3px;overflow:hidden;margin-top:4px}
.progress-fill{height:100%;background:var(--vp-accent);border-radius:3px}
.action-box{
    background:var(--vp-warn-bg);border:1px solid var(--vp-warn-border);
    border-radius:var(--vp-radius);padding:14px;margin-top:10px;
}
.step-banner{
    padding:12px 14px;border-radius:var(--vp-radius);
    font-size:var(--vp-font-sm);margin-bottom:14px;
    display:flex;gap:10px;align-items:flex-start;
    border:1px solid transparent;
}
.step-banner.approved{background:var(--vp-info-bg);border-color:var(--vp-info-border);color:var(--vp-info-text)}
.step-banner.action{background:var(--vp-success-bg);border-color:var(--vp-success-border);color:var(--vp-success-text)}
.step-banner.wait{background:var(--vp-surface-2);border-color:var(--vp-border);color:var(--vp-text-muted)}
.step-num{
    flex-shrink:0;width:26px;height:26px;border-radius:50%;
    background:var(--vp-surface);display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:var(--vp-font-xs);
}
.qty-hint{font-size:var(--vp-font-xs);color:var(--vp-text-muted)}

/* ── RFQ tabs ── */
.vendor-nav{
    display:flex;gap:4px;background:var(--vp-surface);
    border-radius:var(--vp-radius);padding:4px;
    margin-bottom:14px;border:1px solid var(--vp-border);flex-wrap:wrap;
}
.vendor-nav a{
    padding:7px 14px;border-radius:5px;
    text-decoration:none;font-weight:600;
    font-size:var(--vp-font-sm);color:var(--vp-text-muted);
    transition:background .15s,color .15s;
}
.vendor-nav a:hover{background:var(--vp-surface-hover);color:var(--vp-text);text-decoration:none}
.vendor-nav a.active{background:var(--vp-accent-rfq);color:#fff}
.vendor-nav a .nav-badge{
    display:inline-block;min-width:16px;height:16px;line-height:16px;
    padding:0 5px;border-radius:99px;background:#ef4444;color:#fff;
    font-size:9px;font-weight:800;margin-left:4px;vertical-align:middle;
}
.vendor-nav a.active .nav-badge{background:#fff;color:#ef4444}
.tab-panel{display:none}.tab-panel.active{display:block}
.nego-box{
    background:var(--vp-warn-bg);border:1px solid var(--vp-warn-border);
    border-radius:var(--vp-radius-lg);padding:16px;margin-bottom:14px;
}
.nego-box h2{color:var(--vp-warn-text);border-color:var(--vp-warn-border)}
.nego-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.price-down{color:var(--vp-accent);font-weight:700}
.price-up{color:#ef4444;font-weight:700}

/* ── Login ── */
.vp-login-page{min-height:100vh;display:flex;flex-direction:column}
.vp-login-page .vp-header-inner{justify-content:space-between}
.vp-login-wrap{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:24px;
}
.vp-login-wrap--with-demo{padding-bottom:32px}
.vp-login-row{
    display:flex;flex-direction:column;align-items:center;width:100%;gap:0;
}
.vp-login-row--with-demo{
    flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:flex-start;
    gap:20px;max-width:920px;
}
.vp-login-box{
    background:var(--vp-surface);border-radius:var(--vp-radius-lg);
    padding:28px 32px;border:1px solid var(--vp-border);
    box-shadow:var(--vp-shadow-md);width:100%;max-width:400px;
}
.vp-login-box h1{font-size:var(--vp-font-xl);color:var(--vp-text);text-align:center;margin-bottom:4px;font-weight:700}
.vp-login-box .sub{color:var(--vp-text-muted);font-size:var(--vp-font-sm);text-align:center;margin-bottom:20px}
.vp-login-box .btn{width:100%;padding:9px;margin-top:6px}
.vp-login-box .hint{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin-top:14px;text-align:center;line-height:1.6}
.vp-login-box code{font-size:var(--vp-font-xs);background:var(--vp-surface-2);padding:2px 5px;border-radius:4px;word-break:break-all;color:var(--vp-text-secondary)}
.vp-steps{
    display:flex;gap:6px;margin-bottom:18px;justify-content:center;
}
.vp-step{
    flex:1;text-align:center;padding:8px 6px;
    background:var(--vp-surface-2);border-radius:6px;
    border:1px solid var(--vp-border-soft);
}
.vp-step-num{
    display:block;font-size:var(--vp-font-xs);font-weight:700;
    color:var(--vp-accent);margin-bottom:2px;
}
.vp-step span{font-size:var(--vp-font-xs);color:var(--vp-text-muted);line-height:1.3}

/* Demo panel login (hanya saat APP_DEMO_LOGIN_HINT aktif) */
.vp-demo-panel{
    flex:1 1 300px;max-width:400px;max-height:min(72vh,560px);overflow:auto;
    background:var(--vp-surface);border:1px solid var(--vp-border);border-radius:var(--vp-radius-lg);
    padding:18px 20px;box-shadow:var(--vp-shadow-md);
}
.vp-demo-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.vp-demo-head strong{font-size:var(--vp-font-sm);color:var(--vp-text)}
.vp-demo-badge{
    font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
    padding:3px 8px;border-radius:999px;background:var(--vp-warn-bg);color:var(--vp-warn-text);
}
.vp-demo-intro{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin:0 0 12px;line-height:1.45}
.vp-demo-group{margin-bottom:12px}
.vp-demo-group h3{
    font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
    color:var(--vp-text-muted);margin:0 0 6px;
}
.vp-demo-group ul{list-style:none;margin:0;padding:0;display:grid;gap:4px}
.vp-demo-token{
    width:100%;text-align:left;display:flex;flex-direction:column;gap:2px;
    padding:8px 10px;border:1px solid var(--vp-border);border-radius:8px;
    background:var(--vp-surface-2);cursor:pointer;font:inherit;color:inherit;
    transition:border-color .15s,background .15s;
}
.vp-demo-token:hover{border-color:var(--vp-accent);background:var(--vp-surface)}
.vp-demo-token-label{font-size:var(--vp-font-sm);font-weight:600;color:var(--vp-text)}
.vp-demo-token-meta{font-size:10px;color:var(--vp-text-muted);line-height:1.35}

/* ── Dashboard ── */
.vp-dashboard{max-width:1440px;margin:0 auto}
.vp-company-identity{
    display:flex;align-items:center;gap:16px;flex-wrap:wrap;
    padding:18px 20px;margin-bottom:18px;
    border-radius:var(--vp-radius-lg);
    border:1px solid var(--vp-border);
    background:linear-gradient(135deg,var(--vp-surface) 0%,var(--vp-surface-2) 100%);
    box-shadow:var(--vp-shadow-sm);
}
.vp-company-login{margin-bottom:18px;justify-content:center;text-align:center;flex-direction:column;padding:20px 16px}
.vp-company-login .vp-company-text{align-items:center}
.vp-company-mark{
    flex-shrink:0;width:52px;height:52px;border-radius:14px;
    background:var(--vp-accent);color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-size:1.35rem;font-weight:800;letter-spacing:.02em;
    box-shadow:0 4px 14px color-mix(in srgb,var(--vp-accent) 35%,transparent);
}
.vp-company-text{flex:1;min-width:200px}
.vp-company-name{
    font-size:var(--vp-font-xl);font-weight:800;color:var(--vp-text);
    line-height:1.2;letter-spacing:.04em;text-transform:uppercase;
}
.vp-company-tagline{font-size:var(--vp-font-xs);color:var(--vp-text-muted);margin-top:4px}
.vp-company-vendor{
    flex-shrink:0;text-align:right;padding:10px 14px;border-radius:var(--vp-radius);
    background:var(--vp-accent-soft);border:1px solid color-mix(in srgb,var(--vp-accent) 25%,var(--vp-border));
    min-width:160px;
}
.vp-company-vendor-lbl{display:block;font-size:10px;color:var(--vp-text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.vp-company-vendor strong{display:block;font-size:var(--vp-font-sm);color:var(--vp-accent);font-weight:700;line-height:1.3}
.vp-dashboard-hero{margin-bottom:20px}
.vp-dashboard-hero h2{font-size:var(--vp-font-xl);color:var(--vp-text);margin-bottom:2px;font-weight:700}
.vp-dashboard-hero p{color:var(--vp-text-muted);font-size:var(--vp-font-sm)}
.vp-vendor-chip{
    display:inline-block;background:var(--vp-accent-soft);color:var(--vp-accent);
    padding:4px 12px;border-radius:99px;font-weight:600;
    font-size:var(--vp-font-xs);margin-bottom:10px;
    border:1px solid transparent;
}
[data-theme="dark"] .vp-vendor-chip{border-color:var(--vp-accent)}
.vp-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.vp-dash-card{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 18px;border-radius:var(--vp-radius-lg);
    border:1px solid var(--vp-border);text-decoration:none;color:inherit;
    background:var(--vp-surface);transition:box-shadow .2s,transform .15s,border-color .15s;
    min-height:90px;
}
.vp-dash-card:hover{box-shadow:var(--vp-shadow-md);transform:translateY(-2px);text-decoration:none;border-color:var(--vp-accent)}
.vp-dash-card strong{display:block;color:var(--vp-text);font-size:var(--vp-font-sm);font-weight:700;margin-bottom:2px}
.vp-dash-card span{font-size:var(--vp-font-xs);color:var(--vp-text-muted)}
.vp-dash-card .count{
    background:var(--vp-accent-rfq-soft);color:var(--vp-accent-rfq);
    font-size:var(--vp-font-xs);font-weight:700;
    padding:4px 10px;border-radius:99px;flex-shrink:0;margin-left:12px;
}
.vp-dash-card.card-rfq{border-left:3px solid var(--vp-accent-rfq)}
.vp-dash-card.card-po{border-left:3px solid var(--vp-accent)}
.vp-dash-card.card-po .count{background:var(--vp-accent-soft);color:var(--vp-accent)}
.vp-dash-card.card-inv{border-left:3px solid #7c3aed}
.vp-dash-card.card-inv .vp-dash-icon{background:#f5f3ff;color:#7c3aed}
.vp-dash-card.card-inv .count{background:#f5f3ff;color:#7c3aed}
.vp-dash-icon{
    width:36px;height:36px;border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    font-size:var(--vp-font-lg);margin-right:12px;flex-shrink:0;
}
.vp-dash-card.card-rfq .vp-dash-icon{background:var(--vp-accent-rfq-soft);color:var(--vp-accent-rfq)}
.vp-dash-card.card-po .vp-dash-icon{background:var(--vp-accent-soft);color:var(--vp-accent)}
.vp-dash-body{flex:1;min-width:0}

.vp-footer{
    text-align:center;color:var(--vp-text-muted);
    font-size:var(--vp-font-xs);padding:14px 24px;
    border-top:1px solid var(--vp-border);
    background:var(--vp-surface);margin-top:auto;
}

@media(min-width:1100px){
    .vp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
    .vp-detail-grid .card{margin-bottom:0}
    .vp-detail-full{grid-column:1/-1}
}
@media(max-width:768px){
    .vp-header-inner{padding:10px 14px}
    .vp-main{padding:14px}
    .vp-login-box{padding:22px 18px}
    .vp-login-row--with-demo{flex-direction:column;align-items:stretch}
    .vp-demo-panel{max-width:none;max-height:none}
    .form-grid{grid-template-columns:1fr}
    .vp-nav-link{padding:6px 10px}
    .vp-company-identity{flex-direction:column;align-items:flex-start}
    .vp-company-vendor{text-align:left;width:100%}
}
