/* ============================================================
   PARKSAATHI — pages.css
   Single file for ALL dashboard & page-specific styles.
   Load after style.css in dash-header.php
   ============================================================ */

/* ============================================================
   SIDEBAR — redesigned to match index.php brand theme
   ============================================================ */
.dash-sidebar {
    width: var(--sidebar-w);
    background: linear-gradient(180deg, #0a0f1e 0%, #0d1629 55%, #110829 100%);
    position: fixed; top: 0; left: 0; bottom: 0;
    display: flex; flex-direction: column;
    z-index: 100; overflow-y: auto;
    transition: transform var(--transition);
    border-right: 1px solid rgba(67,97,238,0.14);
    box-shadow: 4px 0 24px rgba(0,0,0,0.25);
}

.dash-sidebar-logo {
    display: flex; align-items: center; gap: 11px;
    padding: 22px 20px 20px; text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    margin-bottom: 6px; position: relative; overflow: hidden;
}
.dash-sidebar-logo::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(67,97,238,0.1) 0%, transparent 60%);
    pointer-events: none;
}
.dash-logo-img { height: 36px; width: auto; filter: brightness(0) invert(1); opacity: 0.9; position: relative; z-index: 1; }

/* Section labels */
.dash-nav { flex: 1; padding: 6px 12px; }
.dash-nav-label {
    font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.8px;
    color: rgba(255,255,255,0.2); padding: 0 10px; margin: 18px 0 5px;
    display: flex; align-items: center; gap: 8px;
}
.dash-nav-label:first-child { margin-top: 4px; }
.dash-nav-label::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.05); }

/* Nav items */
.dash-nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px; border-radius: 10px;
    color: rgba(255,255,255,0.42); font-size: 0.875rem; font-weight: 500;
    transition: all var(--transition); margin-bottom: 1px; text-decoration: none;
    position: relative;
}
.dash-nav-item:hover {
    background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.88);
    transform: translateX(2px);
}
.dash-nav-item.active {
    background: linear-gradient(135deg, rgba(67,97,238,0.88), rgba(114,9,183,0.72));
    color: white; box-shadow: 0 4px 16px rgba(67,97,238,0.3), inset 0 1px 0 rgba(255,255,255,0.1);
}
.dash-nav-item.active::before {
    content: ''; position: absolute; left: 0; top: 22%; bottom: 22%;
    width: 3px; background: white; border-radius: 0 3px 3px 0; opacity: 0.5;
}
.dash-nav-item .nav-icon {
    font-size: 1rem; width: 20px; text-align: center; flex-shrink: 0;
    transition: transform var(--transition);
}
.dash-nav-item:hover .nav-icon   { transform: scale(1.18); }
.dash-nav-item.active .nav-icon  { transform: scale(1.1); }

/* User block at bottom */
.dash-user {
    padding: 12px 16px 16px; border-top: 1px solid rgba(255,255,255,0.06);
    margin-top: auto; background: rgba(0,0,0,0.18);
}
.dash-user-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.dash-user-avatar {
    width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif; font-size: 0.95rem; font-weight: 700; color: white;
    box-shadow: 0 3px 10px rgba(67,97,238,0.4);
}
.dash-user-name  { font-size: 0.82rem; font-weight: 700; color: white; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-user-email,
.dash-user-phone { font-size: 0.7rem; color: rgba(255,255,255,0.28); margin-top: 1px; }
.dash-logout {
    display: flex; align-items: center; gap: 7px;
    padding: 8px 12px; background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06); border-radius: 8px;
    color: rgba(255,255,255,0.28); font-size: 0.76rem; font-weight: 600;
    transition: all var(--transition); text-decoration: none;
}
.dash-logout:hover { color: #fc8181; background: rgba(252,129,129,0.08); border-color: rgba(252,129,129,0.15); }

/* Mobile toggle */
.dash-mobile-toggle {
    display: none; position: fixed; top: 14px; left: 14px; z-index: 200;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    color: white; border: none; width: 42px; height: 42px; border-radius: 11px;
    font-size: 1.15rem; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(67,97,238,0.4);
}
.dash-sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 99; backdrop-filter: blur(3px); }
.dash-sidebar-overlay.open { display: block; }

/* ============================================================
   LOGIN PAGE
   ============================================================ */
.login-tabs {
    display: flex; background: #f1f3fb; border-radius: 14px;
    padding: 5px; margin-bottom: 26px; gap: 4px;
}
.login-tab {
    flex: 1; padding: 10px 0; border: none; background: transparent;
    border-radius: 10px; font-size: 0.88rem; font-weight: 700; color: #6b7280;
    cursor: pointer; transition: all 0.22s; display: flex; align-items: center;
    justify-content: center; gap: 7px; font-family: inherit;
}
.login-tab.active { background: white; color: var(--primary); box-shadow: 0 2px 12px rgba(67,97,238,0.13); }
.login-tab:hover:not(.active) { color: var(--primary); background: rgba(67,97,238,0.06); }

.otp-panel { display: none; }
.otp-panel.visible { display: block; }
.pwd-panel { display: block; }
.pwd-panel.hidden  { display: none; }

.otp-digits { display: flex; gap: 10px; justify-content: center; margin: 20px 0 6px; }
.otp-digit {
    width: 48px; height: 58px; border: 2px solid #e5e7eb; border-radius: 12px;
    font-size: 1.5rem; font-weight: 800; text-align: center; color: var(--dark);
    background: white; outline: none; transition: border-color 0.2s, box-shadow 0.2s;
    caret-color: var(--primary);
}
.otp-digit:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(67,97,238,0.12); }
.otp-digit.filled { border-color: var(--primary); }
@keyframes shake {
    0%,100%{transform:translateX(0)} 20%{transform:translateX(-6px)} 60%{transform:translateX(6px)}
}

.otp-step2 { display: none; }
.otp-step2.visible { display: block; }

.phone-display-chip {
    display: inline-flex; align-items: center; gap: 8px;
    background: #f1f3fb; border-radius: 50px; padding: 8px 16px;
    font-size: 0.92rem; font-weight: 700; color: var(--dark); margin-bottom: 4px;
}
.phone-display-chip .change-link { font-size: 0.76rem; color: var(--primary); cursor: pointer; font-weight: 600; margin-left: 4px; }
.phone-display-chip .change-link:hover { text-decoration: underline; }
.otp-sent-msg { font-size: 0.82rem; color: #6b7280; margin-bottom: 4px; text-align: center; }

.resend-row { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 6px; font-size: 0.82rem; color: #9ca3af; }
.resend-btn { background: none; border: none; color: var(--primary); font-weight: 700; cursor: pointer; font-size: 0.82rem; padding: 0; font-family: inherit; }
.resend-btn:disabled { color: #9ca3af; cursor: default; }

.dev-otp-badge { display: none; margin: 12px 0 0; padding: 10px 14px; background: #fef9c3; border: 1.5px solid #fde68a; border-radius: 10px; font-size: 0.82rem; color: #78350f; text-align: center; }
.dev-otp-badge strong { font-size: 1.3rem; letter-spacing: 4px; color: #92400e; }

.btn-form-submit .spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(255,255,255,0.4); border-top-color: white; border-radius: 50%; animation: spin 0.7s linear infinite; vertical-align: middle; margin-right: 6px; }
@keyframes spin { to { transform: rotate(360deg); } }

.or-divider { display: flex; align-items: center; gap: 12px; color: #d1d5db; font-size: 0.8rem; margin: 18px 0; }
.or-divider::before,.or-divider::after { content:''; flex:1; height:1px; background:#e5e7eb; }

/* ============================================================
   SHOP PAGE
   ============================================================ */
.shop-hero {
    background: linear-gradient(135deg, #0d1b6e, #3a0878); border-radius: 20px;
    padding: 32px 36px; text-align: center; margin-bottom: 32px;
    position: relative; overflow: hidden; box-shadow: 0 10px 40px rgba(13,27,110,0.25);
}
.shop-hero::before { content:''; position:absolute; top:-60px;left:-40px; width:240px;height:240px; background:radial-gradient(circle,rgba(67,97,238,0.4) 0%,transparent 65%); border-radius:50%; pointer-events:none; }
.shop-hero::after  { content:''; position:absolute; bottom:-50px;right:-30px; width:180px;height:180px; background:radial-gradient(circle,rgba(114,9,183,0.38) 0%,transparent 65%); border-radius:50%; pointer-events:none; }
.shop-hero-badge { display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.18); color:rgba(255,255,255,0.9); padding:6px 16px; border-radius:50px; font-size:0.78rem; font-weight:600; letter-spacing:0.4px; margin-bottom:14px; position:relative;z-index:1; }
.badge-dot-live { width:6px;height:6px;border-radius:50%;background:#06d6a0;box-shadow:0 0 6px #06d6a0;animation:liveBlink 2s infinite; }
@keyframes liveBlink { 0%,100%{opacity:1}50%{opacity:.3} }
.shop-hero h2 { font-family:'Rajdhani',sans-serif; font-size:clamp(1.8rem,4vw,2.4rem); font-weight:700; color:white; margin-bottom:8px; position:relative;z-index:1; }
.shop-hero p  { font-size:0.9rem; color:rgba(255,255,255,0.7); max-width:460px; margin:0 auto; position:relative;z-index:1; line-height:1.65; }
.product-img { width:100%; height:160px; background:linear-gradient(135deg,rgba(67,97,238,0.06),rgba(114,9,183,0.06)); border-radius:12px; overflow:hidden; margin-bottom:16px; display:flex; align-items:center; justify-content:center; }
.product-img img { max-height:130px; width:auto; object-fit:contain; transition:transform 0.3s; }
.product-card:hover .product-img img { transform:scale(1.05); }
.product-info { text-align:center; }

/* ============================================================
   ACTIVATE TAG PAGE
   ============================================================ */
.activate-wrap { max-width: 560px; margin: 0 auto; }
.activate-card {
    background: #f8f9ff; border: 1.5px solid rgba(67,97,238,0.1); border-radius: 20px;
    padding: 32px; box-shadow: 0 4px 20px rgba(67,97,238,0.08);
    position: relative; overflow: hidden;
}
.activate-card::before { content:''; position:absolute; top:0;left:0;right:0; height:4px; background:linear-gradient(135deg,#4361ee,#7209b7); }
.activate-hero {
    background: linear-gradient(135deg,#0d1b6e,#3a0878); border-radius: 16px;
    padding: 22px 20px; text-align: center; margin-bottom: 24px;
    position: relative; overflow: hidden;
}
.activate-hero::before { content:''; position:absolute; top:-30px;left:-20px; width:120px;height:120px; background:radial-gradient(circle,rgba(67,97,238,0.4) 0%,transparent 70%); border-radius:50%; }
.activate-hero-icon  { font-size:2.2rem; margin-bottom:8px; position:relative;z-index:1; }
.activate-hero-title { font-family:'Rajdhani',sans-serif; font-size:1.5rem; font-weight:700; color:white; margin-bottom:5px; position:relative;z-index:1; }
.activate-hero-sub   { font-size:0.82rem; color:rgba(255,255,255,0.7); position:relative;z-index:1; line-height:1.6; }
.activate-success {
    background: linear-gradient(135deg,#0d1b6e,#3a0878); color:white;
    border-radius: 16px; padding: 24px; text-align: center; margin-top: 20px;
    position: relative; overflow: hidden;
}
.activate-success::before { content:''; position:absolute; top:-30px;left:-30px; width:120px;height:120px; background:radial-gradient(circle,rgba(6,214,160,0.3) 0%,transparent 70%); border-radius:50%; }
.activate-success-icon  { font-size:2.5rem; margin-bottom:10px; position:relative;z-index:1; }
.activate-success-title { font-family:'Rajdhani',sans-serif; font-size:1.4rem; font-weight:700; margin-bottom:6px; position:relative;z-index:1; }
.activate-success-sub   { font-size:0.85rem; opacity:0.82; position:relative;z-index:1; }

/* ============================================================
   SCAN LOGS PAGE
   ============================================================ */
.scan-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px; }
.scan-stat-card {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:14px;
    padding:18px 16px; text-align:center; position:relative; overflow:hidden;
    transition:all 0.25s; box-shadow:0 2px 8px rgba(67,97,238,0.05);
}
.scan-stat-card::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:linear-gradient(135deg,#4361ee,#7209b7); transform:scaleX(0); transform-origin:left; transition:transform 0.25s; }
.scan-stat-card:hover { background:white; box-shadow:0 6px 20px rgba(67,97,238,0.1); transform:translateY(-3px); }
.scan-stat-card:hover::before { transform:scaleX(1); }
.scan-stat-icon  { font-size:1.4rem; margin-bottom:6px; }
.scan-stat-num   { font-family:'Rajdhani',sans-serif; font-size:1.9rem; font-weight:800; line-height:1; background:linear-gradient(135deg,#4361ee,#7209b7); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.scan-stat-label { font-size:0.74rem; color:#6c757d; margin-top:4px; font-weight:600; letter-spacing:0.3px; }

.filter-bar {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:14px;
    padding:14px 18px; display:flex; gap:12px; align-items:center;
    flex-wrap:wrap; margin-bottom:20px; box-shadow:0 2px 8px rgba(67,97,238,0.04);
}
.filter-bar label { font-size:0.78rem; font-weight:700; color:#1b263b; margin-right:4px; text-transform:uppercase; letter-spacing:0.4px; }
.filter-bar select, .filter-bar input[type=date] { padding:8px 12px; border:1.5px solid rgba(67,97,238,0.14); border-radius:50px; font-size:0.84rem; color:#1b263b; background:white; outline:none; transition:all 0.2s; font-family:inherit; }
.filter-bar select:focus, .filter-bar input[type=date]:focus { border-color:#4361ee; box-shadow:0 0 0 3px rgba(67,97,238,0.1); }
.filter-bar .btn-filter { background:linear-gradient(135deg,#4361ee,#7209b7); color:white; border:none; padding:9px 20px; border-radius:50px; font-size:0.84rem; font-weight:700; cursor:pointer; transition:all 0.2s; box-shadow:0 4px 14px rgba(67,97,238,0.28); font-family:inherit; }
.filter-bar .btn-filter:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(67,97,238,0.38); }
.filter-bar .btn-clear { background:white; border:1.5px solid rgba(67,97,238,0.14); color:#1b263b; padding:8px 16px; border-radius:50px; font-size:0.84rem; font-weight:600; cursor:pointer; text-decoration:none; transition:all 0.2s; }
.filter-bar .btn-clear:hover { border-color:#4361ee; color:#4361ee; }

.logs-table-wrap { background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:16px; overflow:hidden; box-shadow:0 2px 8px rgba(67,97,238,0.05); }
.logs-table { width:100%; border-collapse:collapse; }
.logs-table th { background:white; padding:11px 16px; text-align:left; font-size:0.74rem; font-weight:700; color:#6c757d; letter-spacing:0.5px; text-transform:uppercase; border-bottom:1.5px solid rgba(67,97,238,0.08); }
.logs-table td { padding:13px 16px; font-size:0.86rem; color:#1b263b; border-bottom:1.5px solid rgba(67,97,238,0.06); }
.logs-table tr:last-child td { border-bottom:none; }
.logs-table tr:hover td { background:white; }
.scan-tag-badge { display:inline-flex;align-items:center;gap:5px; background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:50px; padding:3px 10px; font-size:0.76rem; font-weight:700; color:#0d1117; }
.scan-time { white-space:nowrap; }
.scan-ip   { font-family:monospace; font-size:0.78rem; color:#9ca3af; }
.pagination { display:flex; gap:6px; align-items:center; justify-content:center; margin-top:20px; }
.pg-btn { width:34px;height:34px; border:1.5px solid rgba(67,97,238,0.14); border-radius:50px; background:white; color:#1b263b; font-size:0.85rem; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; text-decoration:none; transition:all 0.2s; }
.pg-btn:hover  { border-color:#4361ee; color:#4361ee; }
.pg-btn.active { background:linear-gradient(135deg,#4361ee,#7209b7); color:white; border-color:transparent; box-shadow:0 4px 12px rgba(67,97,238,0.3); }
.pg-btn.disabled { opacity:0.35; cursor:not-allowed; pointer-events:none; }

/* ============================================================
   EMERGENCY CONTACTS PAGE
   ============================================================ */
.ec-summary-banner {
    display:flex; align-items:center; gap:20px;
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:16px;
    padding:18px 22px; margin-bottom:28px; box-shadow:0 2px 8px rgba(67,97,238,0.05);
    flex-wrap:wrap;
}
.ec-summary-item { text-align:center; }
.ec-summary-num  { font-family:'Rajdhani',sans-serif; font-size:1.8rem; font-weight:800; background:linear-gradient(135deg,#4361ee,#7209b7); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.ec-summary-label { font-size:0.72rem; color:var(--gray); font-weight:600; text-transform:uppercase; letter-spacing:0.4px; margin-top:3px; }

.ec-tag-section { margin-bottom:28px; }
.ec-tag-header { display:flex; align-items:center; gap:12px; margin-bottom:16px; padding-bottom:12px; border-bottom:1.5px solid rgba(67,97,238,0.08); }
.ec-tag-num    { font-family:'Rajdhani',sans-serif; font-size:1.1rem; font-weight:800; color:#0d1117; }
.ec-tag-sub    { font-size:0.78rem; color:#6c757d; margin-top:2px; }

.ec-contacts-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:12px; margin-bottom:14px; }

.ec-card {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:14px;
    padding:16px; display:flex; gap:12px; align-items:flex-start;
    transition:all 0.2s; position:relative; overflow:hidden;
}
.ec-card::before { content:''; position:absolute; top:0;left:0;right:0; height:2px; background:linear-gradient(135deg,#4361ee,#7209b7); transform:scaleX(0); transform-origin:left; transition:transform 0.25s; }
.ec-card:hover { background:white; box-shadow:0 6px 20px rgba(67,97,238,0.1); border-color:rgba(67,97,238,0.2); }
.ec-card:hover::before { transform:scaleX(1); }
.ec-avatar { width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:800;color:white;flex-shrink:0; }
.ec-info   { flex:1;min-width:0; }
.ec-name   { font-weight:700;font-size:0.9rem;color:#0d1117;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.ec-phone  { font-size:0.82rem;color:#6c757d;margin-bottom:4px; }
.ec-rel-badge { display:inline-block;font-size:0.7rem;font-weight:700;background:rgba(67,97,238,0.08);color:#4361ee;padding:2px 9px;border-radius:50px; }
.ec-card-actions { display:flex;gap:6px;margin-top:10px;flex-wrap:wrap; }
.ec-action-btn { font-size:0.74rem;font-weight:700;padding:5px 12px;border-radius:50px;border:1.5px solid rgba(67,97,238,0.14);background:white;cursor:pointer;transition:all 0.2s;color:#1b263b;text-decoration:none;display:inline-flex;align-items:center;gap:5px; }
.ec-action-btn:hover       { border-color:#4361ee; color:#4361ee; }
.ec-action-btn.danger:hover{ border-color:#ef4444; color:#ef4444; }
.ec-action-btn.call        { background:rgba(6,214,160,0.08); border-color:rgba(6,214,160,0.25); color:#0d9488; }

.add-ec-panel { background:#f8f9ff; border:1.5px dashed rgba(67,97,238,0.2); border-radius:14px; padding:16px; transition:all 0.2s; }
.add-ec-panel:hover { border-color:rgba(67,97,238,0.4); background:white; }
.add-ec-toggle { display:flex;align-items:center;gap:8px;cursor:pointer;font-size:0.86rem;font-weight:700;color:#4361ee; }
.add-ec-form { display:none;margin-top:14px;padding-top:14px;border-top:1.5px solid rgba(67,97,238,0.08); }
.add-ec-form.open { display:block; }
.ec-form-grid { display:grid;grid-template-columns:1fr 1fr;gap:12px; }

/* EC / Doc shared modal base */
.edit-overlay, .upload-overlay {
    display:none; position:fixed; inset:0;
    background:rgba(13,17,23,0.6); z-index:9000;
    align-items:center; justify-content:center;
    padding:20px; backdrop-filter:blur(4px);
}
.edit-overlay.open, .upload-overlay.open { display:flex; }
.edit-modal, .upload-modal { background:white; border-radius:20px; width:100%; max-width:480px; overflow:hidden; animation:modalUp 0.3s ease; }
@keyframes modalUp { from{transform:translateY(30px);opacity:0} to{transform:translateY(0);opacity:1} }
.edit-modal-header, .upload-modal-header { background:linear-gradient(135deg,#0d1b6e,#3a0878); padding:20px 24px; color:white; display:flex; align-items:center; justify-content:space-between; }
.edit-modal-title, .upload-modal-title   { font-family:'Rajdhani',sans-serif; font-size:1.2rem; font-weight:700; }
.edit-modal-close, .upload-close { background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.2); color:white; width:30px;height:30px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; }
.edit-modal-close:hover, .upload-close:hover { background:rgba(255,255,255,0.3); }
.edit-modal-body, .upload-modal-body { padding:22px 24px; }

/* ============================================================
   DOCUMENTS PAGE
   ============================================================ */
.doc-tag-section { margin-bottom:32px; }
.doc-tag-header { display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1.5px solid rgba(67,97,238,0.08); }
.doc-tag-num   { font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:800;color:#0d1117; }
.doc-tag-plate { font-size:0.76rem;color:#6c757d;margin-top:2px; }

.doc-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px; }

.doc-card {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:14px;
    padding:18px; position:relative; overflow:hidden; transition:all 0.25s;
    display:flex; flex-direction:column; gap:4px;
    box-shadow:0 2px 8px rgba(67,97,238,0.04);
}
.doc-card::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:linear-gradient(135deg,#4361ee,#7209b7); transform:scaleX(0); transform-origin:left; transition:transform 0.3s; }
.doc-card:hover { background:white; box-shadow:0 6px 20px rgba(67,97,238,0.1); border-color:rgba(67,97,238,0.22); }
.doc-card:hover::before { transform:scaleX(1); }
.doc-card.has-doc { border-color:rgba(67,97,238,0.14); }

.doc-card-icon   { font-size:2rem; margin-bottom:8px; }
.doc-card-type   { font-family:'Rajdhani',sans-serif; font-size:1rem; font-weight:700; color:#0d1117; }
.doc-card-desc   { font-size:0.76rem; color:#6c757d; margin-bottom:8px; }
.doc-status-badge { display:inline-flex;align-items:center;gap:4px;font-size:0.7rem;font-weight:700;padding:3px 10px;border-radius:50px;margin-bottom:10px; }
.doc-status-badge.has-doc { background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0; }
.doc-status-badge.no-doc  { background:#fffbeb;color:#b45309;border:1px solid #fcd34d; }
.doc-uploaded-info { font-size:0.74rem;color:#6c757d;margin-bottom:8px;line-height:1.5; }

.doc-actions { display:flex;gap:7px;flex-wrap:wrap;margin-top:auto; }
.doc-btn { font-size:0.74rem;font-weight:700;padding:5px 12px;border-radius:50px;border:1.5px solid rgba(67,97,238,0.14);background:white;cursor:pointer;transition:all 0.2s;color:#1b263b;text-decoration:none;display:inline-flex;align-items:center;gap:5px; }
.doc-btn:hover        { border-color:#4361ee;color:#4361ee; }
.doc-btn.primary      { background:linear-gradient(135deg,#4361ee,#7209b7);color:white;border-color:transparent; }
.doc-btn.primary:hover{ opacity:0.88; }
.doc-btn.danger:hover { border-color:#ef4444;color:#ef4444; }

.upload-drop-zone { border:2px dashed rgba(67,97,238,0.25);border-radius:14px;padding:30px 20px;text-align:center;background:#f8f9ff;transition:all 0.2s;cursor:pointer;margin-bottom:16px; }
.upload-drop-zone:hover, .upload-drop-zone.dragover { border-color:#4361ee;background:rgba(67,97,238,0.02); }
.upload-drop-icon { font-size:2rem;margin-bottom:8px;opacity:0.55; }
.upload-drop-text { font-size:0.88rem;font-weight:700;color:#0d1117;margin-bottom:4px; }
.upload-drop-hint { font-size:0.76rem;color:#6c757d; }
.upload-file-preview { display:none;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:10px;padding:10px 14px;margin-bottom:16px;font-size:0.84rem;color:#15803d;font-weight:600; }
.upload-file-preview.show { display:flex;align-items:center;gap:8px; }
.btn-upload-submit { width:100%;background:linear-gradient(135deg,#4361ee,#7209b7);color:white;border:none;padding:13px;border-radius:50px;font-size:0.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all 0.25s;box-shadow:0 4px 16px rgba(67,97,238,0.3); }
.btn-upload-submit:hover { transform:translateY(-2px);box-shadow:0 8px 24px rgba(67,97,238,0.4); }

/* ============================================================
   PROFILE PAGE
   ============================================================ */
.profile-wrap { display:grid; grid-template-columns:260px 1fr; gap:24px; align-items:start; }

.profile-sidebar {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1);
    border-radius:20px; overflow:hidden; position:sticky; top:20px;
    box-shadow:0 2px 12px rgba(67,97,238,0.07);
}
.profile-avatar-block {
    background:linear-gradient(135deg,#0d1b6e,#3a0878);
    padding:28px 20px; text-align:center; position:relative; overflow:hidden;
}
.profile-avatar-block::before { content:''; position:absolute; top:-30px;left:-20px; width:120px;height:120px; background:radial-gradient(circle,rgba(67,97,238,0.45) 0%,transparent 70%); border-radius:50%; }
.profile-avatar-block::after  { content:''; position:absolute; bottom:-20px;right:-15px; width:90px;height:90px; background:radial-gradient(circle,rgba(114,9,183,0.4) 0%,transparent 70%); border-radius:50%; }
.profile-avatar {
    width:72px;height:72px;border-radius:50%;margin:0 auto 12px;
    background:rgba(255,255,255,0.15);border:3px solid rgba(255,255,255,0.3);
    display:flex;align-items:center;justify-content:center;
    font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:800;color:white;
    position:relative;z-index:1; box-shadow:0 6px 20px rgba(0,0,0,0.3);
}
.profile-avatar-name  { font-family:'Rajdhani',sans-serif;font-size:1.2rem;font-weight:700;color:white;position:relative;z-index:1; }
.profile-avatar-phone { font-size:0.78rem;color:rgba(255,255,255,0.6);margin-top:3px;position:relative;z-index:1; }
.profile-member-since { font-size:0.7rem;color:rgba(255,255,255,0.4);margin-top:5px;position:relative;z-index:1; }

.profile-stats { display:flex; gap:0; border-top:1px solid rgba(255,255,255,0.08); }
.profile-stat  { flex:1;padding:14px 10px;text-align:center;background:linear-gradient(135deg,#0d1b6e,#3a0878); border-right:1px solid rgba(255,255,255,0.08); }
.profile-stat:last-child { border-right:none; }
.profile-stat-num   { font-family:'Rajdhani',sans-serif;font-size:1.5rem;font-weight:800;color:white;line-height:1; }
.profile-stat-label { font-size:0.64rem;color:rgba(255,255,255,0.4);font-weight:600;text-transform:uppercase;letter-spacing:0.4px;margin-top:3px; }

.profile-tab-nav { padding:12px;display:flex;flex-direction:column;gap:2px; }
.profile-tab-btn {
    display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
    font-size:0.86rem;font-weight:600;color:var(--gray);transition:all var(--transition);text-decoration:none;
}
.profile-tab-btn:hover  { background:rgba(67,97,238,0.07);color:var(--primary); }
.profile-tab-btn.active { background:linear-gradient(135deg,#4361ee,#7209b7);color:white;box-shadow:0 4px 14px rgba(67,97,238,0.28); }
.tab-icon { font-size:1rem; }

.profile-card {
    background:#f8f9ff; border:1.5px solid rgba(67,97,238,0.1); border-radius:18px;
    overflow:hidden; margin-bottom:20px; box-shadow:0 2px 10px rgba(67,97,238,0.06);
    position:relative;
}
.profile-card::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:linear-gradient(135deg,#4361ee,#7209b7); }
.profile-card-header { padding:20px 22px 0; }
.profile-card-title  { font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700;color:#0d1117;display:flex;align-items:center;gap:9px;margin-bottom:16px; }
.profile-card-body   { padding:0 22px 22px; }

.addr-card { background:white;border:1.5px solid rgba(67,97,238,0.1);border-radius:12px;padding:14px 16px;margin-bottom:10px;transition:all 0.2s; }
.addr-card:hover { border-color:rgba(67,97,238,0.25);box-shadow:0 3px 12px rgba(67,97,238,0.08); }
.addr-card.default-addr { border-color:rgba(67,97,238,0.35);background:rgba(67,97,238,0.02); }
.addr-default-chip { display:inline-flex;align-items:center;gap:4px;font-size:0.7rem;font-weight:700;padding:2px 9px;border-radius:50px;background:rgba(67,97,238,0.08);color:#4361ee;margin-bottom:5px; }
.addr-text { font-size:0.84rem;color:#1b263b;line-height:1.65; }
.addr-btns { margin-top:10px;display:flex;gap:7px;flex-wrap:wrap; }
.addr-btn  { font-size:0.74rem;font-weight:700;padding:4px 12px;border-radius:50px;border:1.5px solid rgba(67,97,238,0.14);background:white;cursor:pointer;text-decoration:none;transition:all 0.2s;color:#1b263b; }
.addr-btn:hover        { border-color:#4361ee;color:#4361ee; }
.addr-btn.danger:hover { border-color:#ef4444;color:#ef4444; }

.cascade-row { display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px; }
.pw-wrap { position:relative; }
.pw-toggle { position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;opacity:0.45;transition:opacity var(--transition);padding:0; }
.pw-toggle:hover { opacity:1; }

/* ============================================================
   TAG SETTINGS PAGE
   ============================================================ */
.settings-back {
    display:inline-flex;align-items:center;gap:7px;margin-bottom:22px;
    font-size:0.84rem;font-weight:600;color:#6c757d;text-decoration:none;
    padding:7px 16px 7px 11px;background:white;
    border:1.5px solid rgba(67,97,238,0.12);border-radius:50px;
    box-shadow:0 2px 8px rgba(67,97,238,0.06);transition:all 0.2s;
}
.settings-back:hover { color:#4361ee;border-color:rgba(67,97,238,0.35);transform:translateX(-2px); }

.settings-hero {
    background:linear-gradient(135deg,#0d1b6e,#3a0878); border-radius:20px;
    padding:26px 30px; display:flex; align-items:center; gap:16px; flex-wrap:wrap;
    margin-bottom:26px; position:relative; overflow:hidden;
    box-shadow:0 8px 32px rgba(13,27,110,0.22);
}
.settings-hero::before { content:''; position:absolute; top:-50px;left:-40px; width:200px;height:200px; background:radial-gradient(circle,rgba(67,97,238,0.4) 0%,transparent 65%); border-radius:50%; pointer-events:none; animation:sOrb 9s ease-in-out infinite; }
.settings-hero::after  { content:''; position:absolute; bottom:-40px;right:-30px; width:160px;height:160px; background:radial-gradient(circle,rgba(114,9,183,0.38) 0%,transparent 65%); border-radius:50%; pointer-events:none; animation:sOrb 11s ease-in-out infinite reverse; }
@keyframes sOrb { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(15px,-10px) scale(1.08)} }
.settings-hero-icon  { width:52px;height:52px;border-radius:15px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;position:relative;z-index:1; }
.settings-hero-body  { flex:1;position:relative;z-index:1; }
.settings-hero-num   { font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;color:white;line-height:1; }
.settings-hero-plate { display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:white;font-size:0.8rem;font-weight:700;padding:3px 12px;border-radius:50px;margin-top:7px;font-family:'Courier New',monospace;letter-spacing:0.8px; }

.settings-grid { display:grid;grid-template-columns:1.2fr 0.8fr;gap:20px;align-items:start; }

.settings-card {
    background:#f8f9ff;border:1.5px solid rgba(67,97,238,0.1);border-radius:16px;
    padding:22px;margin-bottom:18px;position:relative;overflow:hidden;transition:all 0.25s;
    box-shadow:0 2px 8px rgba(67,97,238,0.05);
}
.settings-card:last-child { margin-bottom:0; }
.settings-card::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#4361ee,#7209b7);transform:scaleX(0);transform-origin:left;transition:transform 0.25s; }
.settings-card:hover { background:white;box-shadow:0 6px 24px rgba(67,97,238,0.1);border-color:rgba(67,97,238,0.18); }
.settings-card:hover::before { transform:scaleX(1); }
.settings-card-title { font-family:'Rajdhani',sans-serif;font-size:1.05rem;font-weight:700;color:#0d1117;margin-bottom:16px;display:flex;align-items:center;gap:8px; }
.settings-card-icon  { width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0; }

.toggle-row { display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1.5px solid rgba(67,97,238,0.06); }
.toggle-row:last-child { border-bottom:none;padding-bottom:0; }
.toggle-label { font-size:0.87rem;font-weight:600;color:#1b263b; }
.toggle-sub   { font-size:0.74rem;color:#6c757d;margin-top:2px; }
.toggle-switch { position:relative;width:44px;height:24px;flex-shrink:0; }
.toggle-switch input { opacity:0;width:0;height:0; }
.toggle-slider { position:absolute;inset:0;background:#e2e8f0;border-radius:50px;cursor:pointer;transition:0.3s;border:1.5px solid rgba(0,0,0,0.05); }
.toggle-slider::before { content:'';position:absolute;height:16px;width:16px;left:3px;bottom:2px;background:white;border-radius:50%;transition:0.3s;box-shadow:0 1px 4px rgba(0,0,0,0.15); }
input:checked + .toggle-slider { background:linear-gradient(135deg,#4361ee,#7209b7);border-color:transparent; }
input:checked + .toggle-slider::before { transform:translateX(20px); }

/* ============================================================
   ORDERS PAGE
   ============================================================ */
.order-success-banner { background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;padding:16px 20px;display:flex;align-items:center;gap:14px;margin-bottom:24px; }
.order-success-banner .s-icon  { font-size:1.8rem; }
.order-success-banner .s-title { font-weight:800;color:#15803d;font-family:'Rajdhani',sans-serif;font-size:1.05rem; }
.order-success-banner .s-desc  { font-size:0.84rem;color:#16a34a;margin-top:2px; }

.orders-list { display:flex;flex-direction:column;gap:12px; }
.order-card {
    background:#f8f9ff;border:1.5px solid rgba(67,97,238,0.1);border-radius:16px;
    overflow:hidden;transition:all 0.25s;cursor:pointer;position:relative;
    box-shadow:0 2px 8px rgba(67,97,238,0.05);
}
.order-card::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#4361ee,#7209b7);transform:scaleX(0);transform-origin:left;transition:transform 0.25s; }
.order-card:hover { background:white;box-shadow:0 8px 30px rgba(67,97,238,0.12);border-color:rgba(67,97,238,0.2);transform:translateY(-2px); }
.order-card:hover::before { transform:scaleX(1); }
.order-card-header { display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1.5px solid rgba(67,97,238,0.07); }
.order-card-num    { font-family:'Rajdhani',sans-serif;font-size:1rem;font-weight:800;color:#0d1117; }
.order-card-date   { font-size:0.76rem;color:#6b7280;margin-top:2px; }
.order-card-header-right { margin-left:auto;display:flex;align-items:center;gap:10px; }
.status-pill { display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:50px;font-size:0.75rem;font-weight:700; }
.order-card-body    { display:flex;align-items:center;gap:20px;padding:14px 20px; }
.order-card-product { font-weight:700;font-size:0.9rem;color:#1b263b;flex:1; }
.order-card-product small { display:block;font-weight:400;font-size:0.76rem;color:#6b7280;margin-top:2px; }
.order-card-total  { font-family:'Rajdhani',sans-serif;font-size:1.2rem;font-weight:800;color:#0d1117;white-space:nowrap; }
.order-card-arrow  { color:#9ca3af; }
.orders-empty { background:#f8f9ff;border:1.5px solid rgba(67,97,238,0.1);border-radius:20px;padding:60px 40px;text-align:center; }

.detail-overlay { display:none;position:fixed;inset:0;background:rgba(13,17,23,0.55);z-index:9000;align-items:flex-start;justify-content:center;padding:24px 16px;overflow-y:auto;backdrop-filter:blur(4px); }
.detail-overlay.open { display:flex; }
.detail-modal { background:white;border-radius:20px;width:100%;max-width:680px;margin:auto;overflow:hidden;animation:slideUp 0.3s ease; }
@keyframes slideUp { from{transform:translateY(40px);opacity:0} to{transform:translateY(0);opacity:1} }
.detail-header { background:linear-gradient(135deg,#0d1b6e,#3a0878);padding:22px 28px;color:white;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;position:relative;overflow:hidden; }
.detail-header::before { content:'';position:absolute;top:-40px;left:-30px;width:160px;height:160px;background:radial-gradient(circle,rgba(67,97,238,0.4) 0%,transparent 70%);border-radius:50%;pointer-events:none; }
.detail-order-num  { font-family:'Rajdhani',sans-serif;font-size:1.4rem;font-weight:800;position:relative;z-index:1; }
.detail-order-date { font-size:0.82rem;opacity:0.75;margin-top:3px;position:relative;z-index:1; }
.detail-close { background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.2);color:white;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0;position:relative;z-index:1; }
.detail-close:hover { background:rgba(255,255,255,0.3); }
.detail-body { padding:0; }
.detail-section { padding:20px 26px;border-bottom:1.5px solid rgba(67,97,238,0.07); }
.detail-section:last-child { border-bottom:none; }
.detail-section-title { font-family:'Rajdhani',sans-serif;font-size:0.82rem;font-weight:700;color:#9ca3af;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:14px; }
.detail-item-row { display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1.5px solid rgba(67,97,238,0.07); }
.detail-item-row:last-child { border-bottom:none;padding-bottom:0; }
.detail-item-icon { width:44px;height:44px;background:#f8f9ff;border-radius:10px;border:1.5px solid rgba(67,97,238,0.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem; }
.detail-item-name  { font-weight:700;font-size:0.9rem;color:#0d1117; }
.detail-item-qty   { font-size:0.78rem;color:#6b7280;margin-top:2px; }
.detail-item-price { margin-left:auto;font-weight:800;color:#0d1117;font-family:'Rajdhani',sans-serif;font-size:1rem; }
.detail-price-row { display:flex;justify-content:space-between;font-size:0.88rem;color:#6b7280;margin-bottom:8px; }
.detail-price-row.total { font-size:1rem;font-weight:800;color:#0d1117;padding-top:10px;margin-top:4px;border-top:2px solid rgba(67,97,238,0.1);margin-bottom:0; }
.detail-price-row.total .pv { background:linear-gradient(135deg,#4361ee,#7209b7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-family:'Rajdhani',sans-serif;font-size:1.25rem; }
.detail-address { background:#f8f9ff;border-radius:12px;padding:14px 16px;font-size:0.86rem;color:#1b263b;line-height:1.7;border:1.5px solid rgba(67,97,238,0.08); }
.detail-address strong { display:block;font-weight:700;color:#0d1117;margin-bottom:2px; }
.pay-method-badge { display:inline-flex;align-items:center;gap:7px;background:#f8f9ff;border:1.5px solid rgba(67,97,238,0.1);border-radius:50px;padding:8px 16px;font-size:0.86rem;font-weight:600;color:#1b263b; }
.timeline-wrap { display:flex;align-items:flex-start;justify-content:space-between;position:relative;padding:8px 0 4px; }
.timeline-wrap::before { content:'';position:absolute;top:20px;left:20px;right:20px;height:3px;background:rgba(67,97,238,0.12);z-index:0; }
.timeline-progress { position:absolute;top:20px;left:20px;height:3px;background:linear-gradient(135deg,#4361ee,#7209b7);z-index:1;transition:width 0.5s; }
.timeline-step { display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;position:relative;z-index:2; }
.timeline-dot { width:40px;height:40px;border-radius:50%;border:3px solid rgba(67,97,238,0.2);background:white;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all 0.3s; }
.timeline-dot.done   { background:linear-gradient(135deg,#4361ee,#7209b7);border-color:transparent; }
.timeline-dot.active { border-color:#4361ee;box-shadow:0 0 0 4px rgba(67,97,238,0.15); }
.timeline-label { font-size:0.7rem;font-weight:700;color:#9ca3af;text-align:center;line-height:1.3;max-width:60px; }
.timeline-label.done   { color:#4361ee; }
.timeline-label.active { color:#0d1117; }

/* ============================================================
   CHECKOUT PAGE
   ============================================================ */
.checkout-wrap { display:grid;grid-template-columns:1fr 380px;gap:28px;align-items:start; }
.order-summary { background:white;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:24px; }
.order-summary-header { background:var(--gradient);padding:20px 24px;color:white; }
.order-summary-header h3 { font-family:'Rajdhani',sans-serif;font-size:1.05rem;font-weight:700;margin:0;letter-spacing:0.5px; }
.order-summary-body { padding:22px 24px; }
.product-preview { display:flex;gap:14px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:18px; }
.product-preview-img { width:68px;height:68px;background:var(--light);border-radius:var(--radius-md);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.product-preview-img img { width:52px;height:52px;object-fit:contain; }
.product-preview-name { font-family:'Rajdhani',sans-serif;font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:3px; }
.product-preview-desc { font-size:0.8rem;color:#6b7280;line-height:1.5; }
.qty-row { display:flex;justify-content:space-between;align-items:center;margin-bottom:14px; }
.qty-label { font-size:0.85rem;font-weight:600;color:var(--dark-2); }
.qty-stepper { display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;overflow:hidden; }
.qty-btn { background:var(--light);border:none;width:34px;height:34px;font-size:1.1rem;font-weight:700;color:var(--primary);cursor:pointer;transition:background var(--transition); }
.qty-btn:hover { background:rgba(67,97,238,0.08); }
.qty-display { width:42px;text-align:center;font-weight:700;font-size:0.95rem;color:var(--dark);border:none;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);background:white;height:34px;outline:none;-moz-appearance:textfield; }
.qty-display::-webkit-outer-spin-button,.qty-display::-webkit-inner-spin-button { -webkit-appearance:none; }
.price-line { display:flex;justify-content:space-between;font-size:0.86rem;color:#6b7280;margin-bottom:9px; }
.price-line.discount { color:#16a34a; }
.price-line.total-line { font-size:1.05rem;font-weight:800;color:var(--dark);padding-top:12px;margin-top:4px;border-top:2px solid var(--border);margin-bottom:0; }
.price-line.total-line .price-val { background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-family:'Rajdhani',sans-serif;font-size:1.35rem; }
.trust-badges { display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--border); }
.trust-badge { display:flex;align-items:center;gap:5px;font-size:0.74rem;color:#6b7280;font-weight:600; }
.checkout-form-card { background:white;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden; }
.checkout-form-section { padding:22px 26px;border-bottom:1px solid var(--border); }
.checkout-form-section:last-child { border-bottom:none; }
.checkout-section-title { font-family:'Rajdhani',sans-serif;font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:16px;display:flex;align-items:center;gap:8px; }
.checkout-section-title .step-num { width:24px;height:24px;background:var(--gradient);color:white;border-radius:50%;font-size:0.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.saved-addr-list { display:flex;flex-direction:column;gap:10px;margin-bottom:16px; }
.saved-addr-item { display:flex;align-items:flex-start;gap:10px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;transition:all var(--transition); }
.saved-addr-item:hover  { border-color:var(--primary);background:rgba(67,97,238,0.02); }
.saved-addr-item.selected { border-color:var(--primary);background:rgba(67,97,238,0.04); }
.saved-addr-item input[type=radio] { margin-top:3px;accent-color:var(--primary); }
.saved-addr-name   { font-weight:700;font-size:0.88rem;color:var(--dark); }
.saved-addr-detail { font-size:0.8rem;color:#6b7280;margin-top:2px;line-height:1.4; }
.saved-addr-default { font-size:0.72rem;background:rgba(67,97,238,0.1);color:var(--primary);font-weight:700;padding:2px 8px;border-radius:20px;margin-left:6px; }
.new-addr-toggle { font-size:0.85rem;color:var(--primary);font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;margin-bottom:14px; }
.new-addr-toggle:hover { text-decoration:underline; }
.payment-tabs { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
.payment-tab { border:1.5px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:10px;position:relative; }
.payment-tab:hover  { border-color:var(--primary);background:rgba(67,97,238,0.02); }
.payment-tab.active { border-color:var(--primary);background:rgba(67,97,238,0.05); }
.payment-tab input[type=radio] { display:none; }
.payment-tab-icon  { font-size:1.4rem; }
.payment-tab-label { font-weight:700;font-size:0.88rem;color:var(--dark); }
.payment-tab-desc  { font-size:0.76rem;color:#6b7280;margin-top:1px; }
.payment-tab-check { width:18px;height:18px;border-radius:50%;border:2px solid var(--border);margin-left:auto;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0; }
.payment-tab.active .payment-tab-check { background:var(--gradient);border-color:transparent; }
.payment-tab.active .payment-tab-check::after { content:'✓';font-size:0.7rem;color:white;font-weight:800; }
.razorpay-note { margin-top:12px;font-size:0.8rem;color:#6b7280;display:flex;align-items:center;gap:6px;padding:10px 12px;background:var(--light);border-radius:var(--radius-sm); }
.btn-place-order { width:100%;background:var(--gradient);color:white;border:none;padding:15px;border-radius:var(--radius-md);font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:800;letter-spacing:0.5px;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 18px rgba(67,97,238,0.3);display:flex;align-items:center;justify-content:center;gap:8px; }
.btn-place-order:hover { transform:translateY(-2px);box-shadow:0 10px 30px rgba(67,97,238,0.4); }
.btn-place-order:disabled { opacity:0.65;cursor:not-allowed;transform:none; }
.success-overlay { display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:9999;align-items:center;justify-content:center; }
.success-overlay.show { display:flex; }
.success-box { background:white;border-radius:var(--radius-xl);padding:40px;text-align:center;max-width:420px;width:90%;animation:popIn 0.4s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes popIn { from{transform:scale(0.7);opacity:0} to{transform:scale(1);opacity:1} }
.success-icon  { font-size:3.5rem;margin-bottom:16px; }
.success-title { font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:800;color:var(--dark);margin-bottom:8px; }
.success-order { font-size:0.88rem;color:#6b7280;margin-bottom:24px; }
.success-order strong { color:var(--primary); }

/* ============================================================
   TAG DETAIL PAGE
   ============================================================ */
/* Local aliases using global vars */
.pg-back { display:inline-flex;align-items:center;gap:8px;font-size:0.84rem;font-weight:600;color:var(--gray);text-decoration:none;margin-bottom:26px;padding:7px 16px 7px 11px;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);transition:all .2s; }
.pg-back:hover { color:var(--primary);border-color:rgba(67,97,238,0.3);transform:translateX(-3px); }
.pg-flash { display:flex;align-items:center;gap:10px;padding:13px 18px;border-radius:12px;margin-bottom:22px;font-size:0.88rem;font-weight:600; }
.pg-flash.ok  { background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a; }
.pg-flash.err { background:#fef2f2;border:1px solid #fecaca;color:#dc2626; }

.pg-hero {
    background:var(--gradient-hero);border-radius:24px;padding:32px 36px;
    margin-bottom:32px;position:relative;overflow:hidden;
    box-shadow:0 12px 48px rgba(13,27,110,0.28);display:flex;align-items:center;gap:22px;flex-wrap:wrap;
}
.pg-hero::before { content:'';position:absolute;border-radius:50%;width:320px;height:320px;background:radial-gradient(circle,rgba(67,97,238,0.4) 0%,transparent 65%);top:-120px;left:-80px;pointer-events:none;animation:heroOrb 9s ease-in-out infinite; }
.pg-hero::after  { content:'';position:absolute;border-radius:50%;width:240px;height:240px;background:radial-gradient(circle,rgba(114,9,183,0.38) 0%,transparent 65%);bottom:-80px;right:-60px;pointer-events:none;animation:heroOrb 11s ease-in-out infinite reverse; }
@keyframes heroOrb { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-20px) scale(1.08)} 66%{transform:translate(-18px,28px) scale(0.93)} }
.pg-hero-grid { position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,0.028) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.028) 1px,transparent 1px);background-size:48px 48px; }
.pg-tag-icon { width:64px;height:64px;border-radius:18px;flex-shrink:0;background:rgba(255,255,255,0.12);border:1.5px solid rgba(255,255,255,0.18);display:flex;align-items:center;justify-content:center;font-size:1.9rem;position:relative;z-index:1;backdrop-filter:blur(8px); }
.pg-hero-body { flex:1;min-width:0;position:relative;z-index:1; }
.pg-tag-number { font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;color:#fff;line-height:1;letter-spacing:0.3px; }
.pg-vehicle-row { display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap; }
.pg-plate-chip { display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:#fff;font-size:0.83rem;font-weight:700;padding:4px 14px;border-radius:var(--radius-pill);font-family:'Courier New',monospace;letter-spacing:1px; }
.pg-vehicle-model { font-size:0.87rem;color:rgba(255,255,255,0.62); }
.pg-status-row { display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap; }
.pg-status-badge { display:inline-flex;align-items:center;gap:6px;font-size:0.74rem;font-weight:700;letter-spacing:0.5px;padding:4px 12px;border-radius:var(--radius-pill);text-transform:uppercase; }
.pg-status-badge.active { background:rgba(6,214,160,0.2);color:#06d6a0;border:1px solid rgba(6,214,160,0.35); }
.pg-status-badge.paused { background:rgba(255,183,3,0.2);color:#ffb703;border:1px solid rgba(255,183,3,0.35); }
.pg-status-badge.other  { background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.15); }
.pg-status-dot { width:6px;height:6px;border-radius:50%;background:currentColor;animation:statusBlink 2s infinite; }
@keyframes statusBlink { 0%,100%{opacity:1} 50%{opacity:.25} }
.pg-hero-since { font-size:0.74rem;color:rgba(255,255,255,0.38); }
.pg-hero-btns { display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1; }
.pg-hero-btn { display:inline-flex;align-items:center;gap:8px;font-size:0.84rem;font-weight:700;padding:11px 20px;border-radius:var(--radius-pill);border:none;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all .25s; }
.pg-hero-btn.primary   { background:#fff;color:var(--primary);box-shadow:0 6px 22px rgba(0,0,0,0.2); }
.pg-hero-btn.primary:hover { transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.28); }
.pg-hero-btn.secondary { background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.88);border:1.5px solid rgba(255,255,255,0.2); }
.pg-hero-btn.secondary:hover { background:rgba(255,255,255,0.18); }

.pg-grid { display:grid;grid-template-columns:1.25fr 1fr;gap:24px;align-items:start; }

.pg-card { background:var(--light);border-radius:var(--radius-md);padding:28px;border:1.5px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:22px;position:relative;overflow:hidden;transition:all .3s; }
.pg-card:last-child { margin-bottom:0; }
.pg-card::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient);transform:scaleX(0);transform-origin:left;transition:transform .3s; }
.pg-card:hover { box-shadow:var(--shadow-lg);background:#fff;border-color:rgba(67,97,238,0.15); }
.pg-card:hover::before { transform:scaleX(1); }
.pg-card-head { display:flex;align-items:center;gap:12px;margin-bottom:22px; }
.pg-card-icon { width:48px;height:48px;border-radius:14px;flex-shrink:0;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:var(--shadow-md);transition:transform .3s; }
.pg-card:hover .pg-card-icon { transform:rotate(-6deg) scale(1.1); }
.pg-card-icon.muted { background:var(--light);border:1.5px solid var(--border);box-shadow:none; }
.pg-card-title { font-family:'Rajdhani',sans-serif;font-size:1.15rem;font-weight:700;color:var(--dark);flex:1; }
.pg-card-badge { font-size:0.72rem;font-weight:700;padding:3px 10px;border-radius:var(--radius-pill);background:rgba(67,97,238,0.08);color:var(--primary); }
.pg-card-badge.warm { background:rgba(255,183,3,0.1);color:#b45309; }

.vis-state { display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:12px;margin-bottom:16px; }
.vis-state.on  { background:#f0fdf4;border:1px solid #bbf7d0; }
.vis-state.off { background:#fffbeb;border:1px solid #fed7aa; }
.vis-emoji { font-size:1.6rem;flex-shrink:0;line-height:1; }
.vis-title { font-weight:700;font-size:0.92rem;margin-bottom:3px; }
.vis-state.on  .vis-title { color:#15803d; }
.vis-state.off .vis-title { color:#b45309; }
.vis-sub  { font-size:0.8rem;color:var(--gray);line-height:1.5; }
.vis-desc { font-size:0.84rem;color:var(--gray);line-height:1.7;margin-bottom:18px; }
.vis-toggle { width:100%;padding:12px 20px;border-radius:var(--radius-pill);font-family:'Plus Jakarta Sans',sans-serif;font-size:0.88rem;font-weight:700;cursor:pointer;border:2px solid;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s; }
.vis-toggle.pause  { background:#fffbeb;color:#b45309;border-color:#fed7aa; }
.vis-toggle.pause:hover  { background:#fef3c7; }
.vis-toggle.resume { background:#f0fdf4;color:#15803d;border-color:#bbf7d0; }
.vis-toggle.resume:hover { background:#dcfce7; }

.pg-fg { margin-bottom:15px; }
.pg-fg label { display:block;font-size:0.74rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--gray);margin-bottom:6px; }
.pg-fg input, .pg-fg select { width:100%;padding:10px 14px;border-radius:10px;background:var(--light);border:1.5px solid var(--border);font-family:'Plus Jakarta Sans',sans-serif;font-size:0.88rem;color:var(--dark-2);transition:all .2s; }
.pg-fg input:focus, .pg-fg select:focus { outline:none;background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px rgba(67,97,238,0.1); }
.pg-row2 { display:grid;grid-template-columns:1fr 1fr;gap:12px; }
.pg-submit { display:inline-flex;align-items:center;gap:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:0.87rem;font-weight:700;padding:11px 24px;border-radius:var(--radius-pill);border:none;cursor:pointer;text-decoration:none;background:var(--gradient);color:#fff;box-shadow:0 4px 16px rgba(67,97,238,0.3);transition:all .25s; }
.pg-submit:hover { transform:translateY(-2px);box-shadow:0 8px 28px rgba(67,97,238,0.42); }
.pg-submit.teal { background:linear-gradient(135deg,#14b8a6,#0d9488);box-shadow:0 4px 14px rgba(20,184,166,0.3); }
.pg-submit.teal:hover { box-shadow:0 8px 24px rgba(20,184,166,0.42); }

.ec-item { display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:12px;background:var(--light);border:1.5px solid var(--border);margin-bottom:9px;transition:all .2s; }
.ec-item:hover { background:#fff;border-color:rgba(67,97,238,0.2);box-shadow:var(--shadow-sm); }
.ec-av { width:38px;height:38px;border-radius:50%;flex-shrink:0;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:0.88rem;font-weight:800;color:#fff; }
.ec-name   { font-size:0.88rem;font-weight:700;color:var(--dark-2); }
.ec-detail { font-size:0.76rem;color:var(--gray);margin-top:2px; }
.ec-rm-btn { margin-left:auto;flex-shrink:0;background:#fff;color:#dc2626;border:1.5px solid #fecaca;border-radius:var(--radius-pill);padding:5px 13px;font-family:'Plus Jakarta Sans',sans-serif;font-size:0.74rem;font-weight:700;cursor:pointer;transition:all .2s; }
.ec-rm-btn:hover { background:#fef2f2;border-color:#f87171; }
.pg-divider { border:none;border-top:1.5px solid var(--border);margin:18px 0; }

.stats-row { display:grid;grid-template-columns:1fr 1fr;gap:14px; }
.stat-box { text-align:center;padding:20px 14px;border-radius:14px;border:1.5px solid var(--border);background:var(--light);transition:all .2s; }
.stat-box:hover { background:#fff;box-shadow:var(--shadow-md); }
.stat-number { font-family:'Rajdhani',sans-serif;font-size:2.8rem;font-weight:700;line-height:1;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px; }
.stat-label  { font-size:0.72rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--gray); }
.pg-meta-line { font-size:0.75rem;color:var(--gray);text-align:center;margin-top:14px;padding-top:14px;border-top:1.5px solid var(--border); }

.log-list { display:flex;flex-direction:column;gap:8px; }
.log-row { display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;background:var(--light);border:1.5px solid var(--border);transition:all .2s; }
.log-row:hover { background:#fff;border-color:rgba(67,97,238,0.2);box-shadow:var(--shadow-sm); }
.log-icon { width:36px;height:36px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1rem; }
.li-scan { background:rgba(67,97,238,0.1); }
.li-call { background:rgba(6,214,160,0.12); }
.li-sms  { background:rgba(255,183,3,0.12); }
.li-wa   { background:rgba(37,211,102,0.12); }
.li-def  { background:rgba(108,117,125,0.1); }
.log-text { font-size:0.86rem;font-weight:600;color:var(--dark-2); }
.log-time { font-size:0.74rem;color:var(--gray);margin-top:2px; }
.log-loc  { margin-left:auto;font-size:0.73rem;color:var(--gray);white-space:nowrap; }
.log-empty { text-align:center;padding:28px 10px;color:var(--gray);font-size:0.84rem;line-height:1.7; }
.log-empty-ico { font-size:2rem;opacity:.35;display:block;margin-bottom:8px; }

/* ============================================================
   MY TAGS PAGE — PVC card styles
   ============================================================ */
.mytags-grid { display:flex;flex-direction:column;gap:36px; }
.ps-card-outer { width:100%;max-width:760px; }
.ps-tag-card { width:760px;height:479px;max-width:100%;border-radius:30px;overflow:hidden;display:flex;box-shadow:0 20px 60px rgba(67,97,238,0.25),0 4px 16px rgba(0,0,0,0.12),inset 0 1px 0 rgba(255,255,255,0.6);font-family:'Plus Jakarta Sans',sans-serif;transition:transform 0.35s ease,box-shadow 0.35s ease;position:relative; }
.ps-tag-card:hover { transform:translateY(-6px);box-shadow:0 32px 80px rgba(67,97,238,0.30),0 8px 24px rgba(0,0,0,0.15); }
.ps-left { width:486px;height:100%;flex-shrink:0;background:#eef0f8;padding:32px 30px 26px 34px;display:flex;flex-direction:column;position:relative;overflow:hidden; }
.ps-left::after { content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 10%,rgba(67,97,238,0.06) 0%,transparent 60%);pointer-events:none; }
.ps-top-row { display:flex;align-items:center;gap:5px;margin-bottom:6px; }
.ps-logo    { width:100px;height:100px;object-fit:contain;flex-shrink:0; }
.ps-brand-block { display:flex;flex-direction:column; }
.ps-brand-name { font-family:'Rajdhani',sans-serif;font-size:48px;font-weight:800;line-height:1;background:linear-gradient(135deg,#2745e0 0%,#6d0db0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-0.5px; }
.ps-brand-sub  { font-size:9.5px;color:#5a6482;line-height:1.4;margin-top:3px;max-width:220px; }
.ps-headline   { display:flex;flex-direction:column;font-family:'Rajdhani',sans-serif;font-size:48px;font-weight:900;color:#1a237e;line-height:1.08;letter-spacing:-0.5px;flex:1;justify-content:center;margin:6px 0; }
.ps-info-lines { display:flex;flex-direction:column;gap:3px; }
.ps-info-row   { font-size:9px;color:#5a6482;line-height:1.5;display:flex;gap:5px; }
.ps-arr        { color:#4361ee;font-size:9px;flex-shrink:0;margin-top:1px; }
.ps-info-row strong { color:#1a237e; }
.ps-dashed-rule { position:absolute;left:10px;top:60px;bottom:60px;width:1px;border-left:1.5px dashed #c0c8e0; }
.ps-right { flex:1;height:100%;background:linear-gradient(150deg,#4458e8 0%,#5b30b8 45%,#7209b7 100%);display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:24px 20px 20px;position:relative;overflow:hidden; }
.ps-right::before { content:'';position:absolute;top:-60px;left:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(100,140,255,0.35) 0%,transparent 65%);pointer-events:none; }
.ps-right::after  { content:'';position:absolute;bottom:-40px;right:-20px;width:160px;height:160px;background:radial-gradient(circle,rgba(180,60,220,0.3) 0%,transparent 65%);pointer-events:none; }
.ps-tag-card.ps-paused .ps-right { background:linear-gradient(150deg,#64748b 0%,#475569 50%,#334155 100%); }
.ps-tag-card.ps-paused .ps-right::before, .ps-tag-card.ps-paused .ps-right::after { display:none; }
.ps-tag-card.ps-inactive .ps-right { background:linear-gradient(150deg,#94a3b8 0%,#64748b 50%,#475569 100%); }
.ps-tag-card.ps-inactive .ps-right::before, .ps-tag-card.ps-inactive .ps-right::after { display:none; }
.ps-qr-box { width:210px;height:210px;border-radius:16px;overflow:hidden;box-shadow:0 0 0 3px rgba(255,255,255,0.25),0 8px 30px rgba(0,0,0,0.35);position:relative;z-index:2;flex-shrink:0; }
.ps-qr { width:100%;height:100%;object-fit:cover;display:block; }
.ps-qr-dim { opacity:0.35;filter:grayscale(0.6); }
.ps-qr-locked { width:100%;height:100%;background:rgba(0,0,0,0.25);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px; }
.ps-qr-locked-icon { font-size:2.2rem; }
.ps-qr-locked-text { font-size:9px;font-weight:700;color:rgba(255,255,255,0.55);text-align:center;line-height:1.4; }
.ps-brand-vertical { position:absolute;right:7px;top:50%;transform:translateY(-50%) rotate(90deg);font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;color:rgba(255,255,255,0.4);letter-spacing:3px;white-space:nowrap;z-index:2; }
.ps-cta-block  { text-align:center;position:relative;z-index:2; }
.ps-phone-icon { width:40px;height:40px;background:rgba(255,255,255,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 6px; }
.ps-cta-label  { font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:800;color:white;letter-spacing:0.3px;margin-bottom:4px; }
.ps-cta-sub    { font-size:8.5px;color:rgba(255,255,255,0.7);line-height:1.5;text-align:center; }
.ps-status-badge { position:absolute;bottom:12px;left:14px;font-size:7.5px;font-weight:800;letter-spacing:1px;padding:3px 9px;border-radius:20px;z-index:3; }
.ps-status-badge.active   { background:rgba(74,222,128,0.18);color:#4ade80;border:1px solid rgba(74,222,128,0.3); }
.ps-status-badge.paused   { background:rgba(251,191,36,0.18);color:#fbbf24;border:1px solid rgba(251,191,36,0.3); }
.ps-status-badge.inactive { background:rgba(148,163,184,0.18);color:#cbd5e1;border:1px solid rgba(148,163,184,0.3); }
.ps-card-actions { display:flex;align-items:center;gap:8px;max-width:756px;padding:10px 2px 4px;flex-wrap:wrap; }
.ps-vehicle-chip { font-size:0.8rem;font-weight:700;color:var(--dark-2);background:var(--light);border:1px solid var(--border);border-radius:20px;padding:5px 14px; }
.ps-action-btn { font-size:0.78rem;font-weight:700;padding:6px 14px;border-radius:50px;border:1.5px solid var(--border);background:white;color:var(--dark-2);cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-flex;align-items:center;gap:4px; }
.ps-action-btn:hover { border-color:var(--primary);color:var(--primary); }
.ps-action-btn.primary { background:var(--gradient);color:white;border-color:transparent;box-shadow:0 4px 14px rgba(67,97,238,0.3); }
.ps-action-btn.primary:hover { opacity:0.9; }

/* PVC print card styles (used in print window from my-tags.php) */
.pvc-card { width:85.6mm;height:54mm;border-radius:3.18mm;overflow:hidden;display:flex;flex-direction:row;box-shadow:0 6px 24px rgba(67,97,238,0.28),0 2px 8px rgba(0,0,0,0.15);font-family:'Plus Jakarta Sans',sans-serif;position:relative; }
.pvc-left { width:57mm;height:100%;background:#eef0f8;display:flex;flex-direction:column;padding:3.2mm 3mm 2.8mm 3.5mm;position:relative;overflow:hidden;flex-shrink:0; }
.pvc-left::after { content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 10%,rgba(67,97,238,0.07) 0%,transparent 60%);pointer-events:none; }
.pvc-dashed { position:absolute;left:2.5mm;top:8mm;bottom:8mm;border-left:0.4mm dashed #b8c0dc; }
.pvc-top { display:flex;align-items:center;gap:1.2mm;margin-bottom:1mm; }
.pvc-logo { width:9mm;height:9mm;object-fit:contain;flex-shrink:0; }
.pvc-brand { display:flex;flex-direction:column; }
.pvc-brand-name { font-family:'Rajdhani',sans-serif;font-size:6.5mm;font-weight:900;line-height:1;background:linear-gradient(135deg,#2745e0 0%,#6d0db0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-0.2px; }
.pvc-brand-sub  { font-size:1.5mm;color:#5a6482;line-height:1.35;margin-top:0.5mm;max-width:32mm; }
.pvc-headline { display:flex;flex-direction:column;font-family:'Rajdhani',sans-serif;font-size:6.8mm;font-weight:900;color:#1a237e;line-height:1.05;letter-spacing:-0.3px;flex:1;justify-content:center;margin:0.5mm 0; }
.pvc-info     { display:flex;flex-direction:column;gap:0.8mm; }
.pvc-info-row { font-size:1.5mm;color:#5a6482;line-height:1.4;display:flex;align-items:flex-start;gap:1mm; }
.pvc-arr      { color:#4361ee;flex-shrink:0;margin-top:0.2mm; }
.pvc-info-row strong { color:#1a237e; }
.pvc-right { flex:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:2.8mm 2.2mm 2.4mm;position:relative;overflow:hidden; }
.pvc-right::before { content:'';position:absolute;top:-8mm;left:-5mm;width:22mm;height:22mm;background:radial-gradient(circle,rgba(100,140,255,0.35) 0%,transparent 65%);pointer-events:none; }
.pvc-right::after  { content:'';position:absolute;bottom:-5mm;right:-3mm;width:18mm;height:18mm;background:radial-gradient(circle,rgba(180,60,220,0.3) 0%,transparent 65%);pointer-events:none; }
.pvc-qr-box { width:25mm;height:25mm;border-radius:2mm;overflow:hidden;box-shadow:0 0 0 0.5mm rgba(255,255,255,0.25),0 1.5mm 5mm rgba(0,0,0,0.35);position:relative;z-index:2;flex-shrink:0;background:rgba(0,0,0,0.15);display:flex;align-items:center;justify-content:center; }
.pvc-qr-box img { width:100%;height:100%;object-fit:cover;display:block; }
.pvc-qr-locked { width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1mm;font-size:5mm; }
.pvc-qr-locked span { font-size:1.5mm;color:rgba(255,255,255,0.5);text-align:center;line-height:1.3; }
.pvc-watermark { position:absolute;right:1mm;top:50%;transform:translateY(-50%) rotate(90deg);font-family:'Rajdhani',sans-serif;font-size:1.6mm;font-weight:700;color:rgba(255,255,255,0.35);letter-spacing:1.5px;white-space:nowrap;z-index:2; }
.pvc-cta  { text-align:center;position:relative;z-index:2; }
.pvc-phone { width:5.5mm;height:5.5mm;background:rgba(255,255,255,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1mm; }
.pvc-phone svg { width:3.5mm;height:3.5mm; }
.pvc-cta-label { font-family:'Rajdhani',sans-serif;font-size:2.5mm;font-weight:800;color:white;letter-spacing:0.2px;margin-bottom:0.8mm; }
.pvc-cta-sub   { font-size:1.35mm;color:rgba(255,255,255,0.7);line-height:1.45; }
.pvc-badge { position:absolute;bottom:1.8mm;left:2mm;font-size:1.2mm;font-weight:800;letter-spacing:0.8px;padding:0.5mm 1.8mm;border-radius:5mm;z-index:3; }
.pvc-badge.active   { background:rgba(74,222,128,0.18);color:#4ade80;border:0.3mm solid rgba(74,222,128,0.4); }
.pvc-badge.paused   { background:rgba(251,191,36,0.18);color:#fbbf24;border:0.3mm solid rgba(251,191,36,0.4); }
.pvc-badge.inactive { background:rgba(148,163,184,0.18);color:#cbd5e1;border:0.3mm solid rgba(148,163,184,0.4); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
    .dash-sidebar { transform:translateX(-100%); }
    .dash-sidebar.open { transform:translateX(0);box-shadow:8px 0 32px rgba(0,0,0,0.3); }
    .dash-mobile-toggle { display:flex; }
    .dash-main { margin-left:0;padding:70px 20px 32px; }
    .scan-stats { grid-template-columns:1fr 1fr; }
    .pg-grid { grid-template-columns:1fr; }
    .settings-grid { grid-template-columns:1fr; }
    .profile-wrap { grid-template-columns:1fr; }
    .profile-sidebar { position:static; }
    .checkout-wrap { grid-template-columns:1fr; }
    .order-summary { position:static;order:-1; }
    .payment-tabs { grid-template-columns:1fr; }
}
@media (max-width: 768px) {
    .ec-contacts-grid { grid-template-columns:1fr; }
    .ec-form-grid { grid-template-columns:1fr; }
    .doc-grid { grid-template-columns:1fr 1fr; }
    .cascade-row { grid-template-columns:1fr 1fr; }
    .logs-table th:nth-child(3), .logs-table td:nth-child(3) { display:none; }
    .ps-tag-card { width:100%;height:auto;aspect-ratio:85.6/54;border-radius:clamp(10px,3vw,24px); }
    .ps-left { width:64%;padding:clamp(12px,2.5vw,32px) clamp(10px,2vw,30px) clamp(10px,2vw,26px) clamp(12px,2.5vw,34px); }
    .ps-brand-name { font-size:clamp(18px,4.5vw,48px); }
    .ps-brand-sub  { font-size:clamp(6px,1.1vw,9.5px); }
    .ps-headline   { font-size:clamp(20px,5vw,48px); }
    .ps-info-row   { font-size:clamp(5.5px,1vw,9px); }
    .ps-logo       { width:clamp(36px,8vw,100px);height:clamp(36px,8vw,100px); }
    .ps-right      { padding:clamp(10px,2vw,24px) clamp(8px,1.5vw,20px); }
    .ps-qr-box     { width:clamp(80px,20vw,210px);height:clamp(80px,20vw,210px); }
    .ps-cta-label  { font-size:clamp(8px,1.7vw,15px); }
    .ps-cta-sub    { font-size:clamp(4.5px,0.9vw,8.5px); }
    .ps-phone-icon { width:clamp(20px,3.8vw,40px);height:clamp(20px,3.8vw,40px); }
    .pg-hero { padding:26px 24px; }
    .pg-hero-btns { width:100%; }
    .pg-hero-btn  { flex:1;justify-content:center; }
}
@media (max-width: 480px) {
    .dash-main      { padding:62px 14px 28px; }
    .scan-stats     { grid-template-columns:1fr 1fr;gap:10px; }
    .doc-grid       { grid-template-columns:1fr; }
    .cascade-row    { grid-template-columns:1fr; }
    .filter-bar     { flex-direction:column;align-items:stretch; }
    .filter-bar select, .filter-bar input[type=date] { width:100%; }
    .checkout-form-section { padding:16px; }
    .form-row-2     { grid-template-columns:1fr; }
    .pg-row2        { grid-template-columns:1fr; }
    .stats-row      { grid-template-columns:1fr 1fr; }
    .pg-hero        { border-radius:18px;gap:16px; }
    .pg-tag-number  { font-size:1.55rem; }
    .otp-digit      { width:40px;height:50px;font-size:1.2rem;border-radius:10px; }
    .otp-digits     { gap:7px; }
}

/* ============================================================
   UTILITY — replaces all inline style= attributes
   ============================================================ */

/* Alerts with bottom margin */
.alert { margin-bottom: 20px; }

/* Alert banners — warning (expiring tags) */
.alert-banner-warn {
    background: #fffbeb; border: 1.5px solid #fcd34d; color: #92400e;
    border-radius: 12px; padding: 13px 18px; margin-bottom: 18px;
    display: flex; align-items: center; gap: 10px;
    font-size: 0.87rem; font-weight: 600;
}
.alert-banner-warn a { color: #92400e; text-decoration: underline; font-weight: 700; margin-left: auto; }

/* Alert banners — danger (expired tags) */
.alert-banner-danger {
    background: #fef2f2; border: 1.5px solid #fecaca; color: #dc2626;
    border-radius: 12px; padding: 13px 18px; margin-bottom: 18px;
    display: flex; align-items: center; gap: 10px;
    font-size: 0.87rem; font-weight: 600;
}
.alert-banner-danger a { color: #dc2626; text-decoration: underline; font-weight: 700; margin-left: auto; }

/* Alert banners — success */
.alert-banner-success {
    background: #f0fdf4; border: 1.5px solid #bbf7d0; color: #15803d;
    border-radius: 12px; padding: 13px 18px; margin-bottom: 20px;
    display: flex; align-items: center; gap: 10px;
    font-size: 0.87rem; font-weight: 600;
}
.alert-banner-success a { color: #15803d; text-decoration: underline; font-weight: 700; margin-left: auto; }

/* Tag expired / expiring inline labels */
.tag-expired-label  { font-size: 0.72rem; color: #dc2626; font-weight: 700; margin-top: 2px; }
.tag-expiring-label { font-size: 0.72rem; color: #f59e0b; font-weight: 700; margin-top: 2px; }

/* tag-qr thumbnail inside tag-card */
.tag-qr-thumb { width: 44px; height: 44px; border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.tag-qr-thumb img { display: block; }

/* Section card spacing helpers */
.section-card + .section-card  { margin-top: 24px; }
.section-card-title { margin-bottom: 20px; }

/* Quick actions in dashboard */
.quick-actions .section-card-title { margin-bottom: 16px; }

/* Promo card (buy first tag) */
.promo-card {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    border: none; color: white; margin-top: 24px;
}
.promo-card-title {
    font-family: 'Rajdhani', sans-serif; font-size: 20px;
    font-weight: 800; margin-bottom: 12px;
}
.promo-card-desc  { font-size: 14px; opacity: 0.85; line-height: 1.6; margin-bottom: 20px; }
.promo-card-btn {
    display: inline-block; background: white; color: var(--primary);
    padding: 12px 20px; border-radius: 10px; font-weight: 700;
    font-size: 14px; text-decoration: none;
}

/* Order row right alignment */
.order-row-right { text-align: right; }

/* Empty state full card */
.empty-state-card {
    background: white; border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 60px 40px;
}
.empty-state-card .btn { display: inline-block; }

/* Scan logs result count */
.filter-result-count { margin-left: auto; font-size: 0.82rem; color: #6b7280; }

/* Table row number cell */
.td-row-num { color: #9ca3af; font-size: 0.8rem; }

/* Table muted cell */
.td-muted { color: #9ca3af; }

/* Scan time sub-line */
.scan-time-sub { font-size: 0.76rem; color: #9ca3af; }

/* EC summary divider */
.ec-summary-divider { width: 1px; height: 36px; background: var(--border); }

/* EC summary tip */
.ec-summary-tip { font-size: 0.82rem; color: #6b7280; margin-left: auto; max-width: 240px; line-height: 1.5; }

/* EC tag header car icon */
.ec-tag-car-icon { font-size: 1.4rem; }

/* EC tag header right side */
.ec-tag-header-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.ec-contacts-count   { font-size: 0.78rem; color: #6b7280; }

/* EC max contacts note */
.ec-max-note { font-size: 0.82rem; color: #9ca3af; padding: 10px 16px; background: var(--light); border-radius: var(--radius-sm); }

/* EC add form bottom actions */
.ec-form-actions { display: flex; gap: 10px; margin-top: 16px; }

/* Form required asterisk */
.req { color: #ef4444; }

/* Form group no bottom margin */
.form-group-last { margin-bottom: 0; }

/* Doc tag header icon */
.doc-car-icon { font-size: 1.4rem; }

/* Doc status dot */
.doc-status-dot { position: absolute; top: 10px; right: 10px; width: 8px; height: 8px; background: #16a34a; border-radius: 50%; }

/* Profile card header meta */
.profile-card-meta { font-size: 0.82rem; color: #6b7280; padding-top: 20px; padding-right: 22px; float: right; }

/* Profile phone disabled input */
.input-disabled { background: var(--light); cursor: not-allowed; opacity: 0.7; }
.input-hint { color: #9ca3af; font-size: 0.75rem; margin-top: 4px; display: block; }

/* Profile two-col form grid */
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* Profile form actions bar */
.form-actions { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border); }

/* Danger zone block */
.danger-zone-heading { font-family: 'Rajdhani', sans-serif; font-size: 1rem; font-weight: 700; color: var(--dark); margin-bottom: 16px; margin-top: 32px; }

/* Profile addresses header */
.profile-card-header-row { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px 0; }
.profile-card-header-count { font-size: 0.82rem; color: #6b7280; }

/* Address actions row */
.addr-actions { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 10px; }
.addr-actions form { margin: 0; }

/* Add address toggle */
.add-addr-toggle {
    display: flex; align-items: center; gap: 8px; cursor: pointer;
    font-size: 0.86rem; font-weight: 700; color: var(--primary);
    padding: 12px 16px; border: 1.5px dashed rgba(67,97,238,0.25);
    border-radius: 12px; background: #f8f9ff; margin-top: 12px;
    transition: all 0.2s;
}
.add-addr-toggle:hover { border-color: var(--primary); background: white; }

/* Add address form */
.add-addr-form { display: none; padding: 18px 0 0; }
.add-addr-form.open { display: block; }

/* Address form grid */
.addr-form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.addr-form-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.addr-form-actions { display: flex; gap: 10px; margin-top: 18px; }

/* Password toggle wrapper */
.pw-input-wrap { position: relative; }

/* Profile tags empty */
.tags-empty-block { text-align: center; padding: 40px 20px; }
.tags-empty-block .empty-icon { font-size: 3rem; margin-bottom: 12px; }
.tags-empty-block .empty-title { font-weight: 700; color: var(--dark); margin-bottom: 8px; }
.tags-empty-block .empty-desc  { color: #6b7280; font-size: 0.86rem; }

/* Tags tab hint text */
.tags-tab-hint { font-size: 0.84rem; color: #6b7280; margin-bottom: 20px; line-height: 1.5; }

/* Profile tag cards grid */
.tag-cards-grid { display: flex; flex-direction: column; gap: 36px; }

/* Orders detail JS-built items */
.detail-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.detail-pay-id  { font-size: 0.76rem; color: #6b7280; align-self: center; }
.detail-free    { color: #16a34a; font-weight: 700; }
.detail-no-item { color: #9ca3af; font-size: 0.85rem; }
.detail-no-addr { color: #9ca3af; font-size: 0.85rem; }
.detail-hist-row { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; }
.detail-hist-icon { font-size: 1rem; }
.detail-hist-status { font-size: 0.84rem; font-weight: 700; }
.detail-hist-notes  { font-size: 0.78rem; color: #6b7280; }
.detail-hist-time   { font-size: 0.76rem; color: #9ca3af; margin-top: 2px; }

/* Activate tag page */
.activate-page-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 24px; flex-wrap: wrap; gap: 14px; }

/* Shop page header */
.shop-page-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 28px; flex-wrap: wrap; gap: 14px; }

/* Tag number input style */
.input-tag-style { text-transform: uppercase; letter-spacing: 1px; font-weight: 700; }
.input-vehicle-style { text-transform: uppercase; letter-spacing: 1.2px; font-weight: 700; }
.input-hint-inline { font-size: 0.75rem; color: #6c757d; margin-top: 5px; display: block; }

/* form-group optional label */
.label-optional { font-weight: 400; text-transform: none; color: #6c757d; }

/* Orders modal JS inline styles */
.detail-loading { padding: 40px; text-align: center; color: #9ca3af; }


/* Dashboard section spacing */
.section-card--mt    { margin-top: 24px; }
.section-card-title--mb { margin-bottom: 20px; }
.empty-state--compact { padding: 30px 20px; }

/* Address card layout */
.address-grid { display: flex; flex-direction: column; gap: 0; margin-bottom: 12px; }
.address-card {
    background: white; border: 1.5px solid rgba(67,97,238,0.1);
    border-radius: 12px; padding: 14px 16px; margin-bottom: 10px;
    position: relative; transition: all 0.2s;
}
.address-card:hover { border-color: rgba(67,97,238,0.25); box-shadow: 0 3px 12px rgba(67,97,238,0.08); }
.address-card.default-addr { border-color: rgba(67,97,238,0.35); background: rgba(67,97,238,0.02); }
.addr-default-badge {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 0.7rem; font-weight: 700; padding: 2px 9px;
    border-radius: 50px; background: rgba(67,97,238,0.08); color: #4361ee;
    margin-bottom: 5px;
}
.addr-name   { font-weight: 700; font-size: 0.9rem; color: var(--dark); margin-bottom: 2px; }
.addr-phone  { font-size: 0.82rem; color: #6c757d; margin-bottom: 4px; }
.addr-detail { font-size: 0.84rem; color: #1b263b; line-height: 1.65; margin-bottom: 10px; }
.addr-btn {
    font-size: 0.74rem; font-weight: 700; padding: 4px 12px;
    border-radius: 50px; border: 1.5px solid rgba(67,97,238,0.14);
    background: white; cursor: pointer; text-decoration: none;
    transition: all 0.2s; color: #1b263b;
}
.addr-btn:hover        { border-color: #4361ee; color: #4361ee; }
.addr-btn.danger:hover { border-color: #ef4444; color: #ef4444; }
.addr-btn.primary      { background: linear-gradient(135deg,#4361ee,#7209b7); color: white; border-color: transparent; }

/* Danger-soft button (sign out) */
.btn-danger-soft {
    display: inline-flex; align-items: center;
    background: #fef2f2; color: #dc2626;
    border: 1.5px solid #fca5a5; font-size: 0.85rem;
    padding: 8px 18px; border-radius: var(--radius-pill);
    text-decoration: none; font-weight: 700; transition: all 0.2s;
}
.btn-danger-soft:hover { background: #fee2e2; border-color: #f87171; }

/* PS card action buttons row */
.ps-card-action-btns {
    display: flex; gap: 8px; margin-left: auto; flex-wrap: wrap;
}

/* Doc actions form inline */
.doc-actions form { margin: 0; display: inline; }

/* profile-card-header fix (addresses/tags tab with count) */
.profile-card-header { padding: 20px 22px 0; }
.profile-card-header-row { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px 0; }
.profile-card-header-count { font-size: 0.82rem; color: #6b7280; }

/* pw-strength-label color */
.pw-strength-label { font-size: 0.8rem; margin-top: 5px; color: #9ca3af; }

/* Danger zone area */
.danger-zone-heading {
    font-family: 'Rajdhani', sans-serif; font-size: 1rem; font-weight: 700;
    color: var(--dark); margin-bottom: 16px; margin-top: 32px;
}

/* Form actions separator */
.form-actions {
    margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border);
}


/* ============================================================
   TAG SETTINGS PAGE — complete component styles
   ============================================================ */

/* Hero tag number + plate */
.settings-hero-tag {
    font-family: 'Rajdhani', sans-serif; font-size: 1.6rem;
    font-weight: 700; color: white; line-height: 1;
    position: relative; z-index: 1;
}
.settings-hero-vehicle {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
    color: white; font-size: 0.8rem; font-weight: 600;
    padding: 3px 12px; border-radius: 50px; margin-top: 7px;
    letter-spacing: 0.5px; position: relative; z-index: 1;
}
.settings-hero-status {
    margin-left: auto; display: flex; align-items: center; gap: 6px;
    background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
    color: white; font-size: 0.82rem; font-weight: 700;
    padding: 6px 14px; border-radius: 50px;
    position: relative; z-index: 1;
}

/* Settings card description */
.settings-card-desc {
    font-size: 0.84rem; color: #6c757d; line-height: 1.65;
    margin-bottom: 18px;
}

/* ── Pause toggle row ── */
.pause-toggle-row {
    display: flex; align-items: center; justify-content: space-between;
    gap: 14px; padding: 14px 16px; border-radius: 12px;
    background: rgba(6,214,160,0.06); border: 1.5px solid rgba(6,214,160,0.2);
    transition: all 0.3s;
}
.pause-toggle-row.is-paused {
    background: rgba(255,183,3,0.07); border-color: rgba(255,183,3,0.28);
}
.pause-toggle-label {
    font-size: 0.9rem; font-weight: 700; color: #0d1117;
    display: flex; align-items: center; gap: 7px;
}
.pause-toggle-sub { font-size: 0.78rem; color: #6c757d; margin-top: 3px; }

.toggle-end { display: flex; align-items: center; gap: 10px; }

/* ── Custom toggle switch ── */
.switch {
    position: relative; display: inline-block;
    width: 46px; height: 26px; flex-shrink: 0;
}
.switch input { opacity: 0; width: 0; height: 0; }
.slider {
    position: absolute; inset: 0; cursor: pointer;
    background: #e2e8f0; border-radius: 50px;
    border: 1.5px solid rgba(0,0,0,0.05);
    transition: all 0.3s;
}
.slider::before {
    content: ''; position: absolute;
    height: 18px; width: 18px; left: 3px; bottom: 2px;
    background: white; border-radius: 50%;
    transition: all 0.3s; box-shadow: 0 1px 4px rgba(0,0,0,0.18);
}
.switch input:checked + .slider {
    background: linear-gradient(135deg, #4361ee, #7209b7);
    border-color: transparent;
}
.switch input:checked + .slider::before { transform: translateX(20px); }

/* ── Save indicator ── */
.save-indicator {
    font-size: 0.72rem; font-weight: 700; opacity: 0;
    transition: opacity 0.2s; white-space: nowrap;
    color: #9ca3af;
}
.save-indicator.visible { opacity: 1; }
.save-indicator.ok  { color: #06d6a0; }
.save-indicator.err { color: #ef476f; }

/* ── Contact option toggle rows ── */
.toggle-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 13px 0; border-bottom: 1.5px solid rgba(67,97,238,0.06);
}
.toggle-row:last-of-type { border-bottom: none; padding-bottom: 4px; }

.toggle-info { display: flex; align-items: center; gap: 12px; }

.toggle-icon {
    width: 38px; height: 38px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}
.toggle-icon.call { background: rgba(6,214,160,0.12); }
.toggle-icon.sms  { background: rgba(96,165,250,0.12); }
.toggle-icon.wa   { background: rgba(74,222,128,0.1);  }
.toggle-icon.emer { background: rgba(248,113,113,0.12);}

.toggle-name { font-size: 0.9rem; font-weight: 700; color: #0d1117; }
.toggle-desc { font-size: 0.76rem; color: #6c757d; margin-top: 2px; }

/* ── Live preview box ── */
.preview-box {
    background: white; border: 1.5px solid rgba(67,97,238,0.1);
    border-radius: 14px; padding: 18px; margin-top: 20px;
    position: relative; overflow: hidden;
}
.preview-box-title {
    font-size: 0.78rem; font-weight: 700; color: #6c757d;
    text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 14px;
}
.preview-btns {
    display: flex; gap: 10px; flex-wrap: wrap;
    transition: opacity 0.3s;
}
.preview-btn {
    display: flex; align-items: center; gap: 7px;
    padding: 8px 16px; border-radius: 50px;
    font-size: 0.82rem; font-weight: 700; transition: all 0.25s;
}
.call-p  { background: rgba(6,214,160,0.1);  color: #0d9488; border: 1.5px solid rgba(6,214,160,0.25); }
.sms-p   { background: rgba(96,165,250,0.1); color: #2563eb; border: 1.5px solid rgba(96,165,250,0.25); }
.wa-p    { background: rgba(74,222,128,0.1); color: #15803d; border: 1.5px solid rgba(74,222,128,0.25); }
.emer-p  { background: rgba(248,113,113,0.1);color: #dc2626; border: 1.5px solid rgba(248,113,113,0.25);}
.hidden-p { opacity: 0.22; text-decoration: line-through; filter: grayscale(1); }

/* Paused overlay inside preview */
.paused-overlay {
    display: none; align-items: center; justify-content: center;
    position: absolute; inset: 0; border-radius: 14px;
    background: rgba(255,249,235,0.96);
    font-size: 0.84rem; font-weight: 700; color: #b45309;
    z-index: 2; gap: 8px;
}
.paused-overlay.show { display: flex; }

/* Quick preview link row */
.settings-preview-link {
    text-align: center; padding: 8px 0 24px;
}
.settings-preview-link a {
    font-size: 0.84rem; color: var(--primary);
    text-decoration: none; font-weight: 600;
    display: inline-flex; align-items: center; gap: 6px;
    transition: all 0.2s;
}
.settings-preview-link a:hover { text-decoration: underline; }


/* Toggle icon colors — FA icons inside color containers */
.toggle-icon.call i { color: #0d9488; }
.toggle-icon.sms  i { color: #2563eb; }
.toggle-icon.wa   i { color: #15803d; font-size: 1.2rem; }
.toggle-icon.emer i { color: #dc2626; }

/* ============================================================
   LOGIN PAGE — extra helpers (no inline styles)
   ============================================================ */
.auth-form-sub     { margin-bottom: 20px; color: #6b7280; font-size: 0.9rem; }
.input-icon--text  { font-size: 0.85rem; font-weight: 700; color: #6b7280; letter-spacing: 0; }
.form-input--pl    { padding-left: 44px; }
.pwd-wrap          { position: relative; }
.pw-eye-btn {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; opacity: 0.5; font-size: 1rem;
    padding: 0;
}
.pw-eye-btn:hover { opacity: 1; }
.login-forgot-row {
    text-align: right; margin-top: -8px; margin-bottom: 16px;
}
.login-forgot-row a { font-size: 0.82rem; color: var(--primary); text-decoration: none; }
.login-forgot-row a:hover { text-decoration: underline; }
.otp-verify-btn    { margin-top: 14px; }
.otp-phone-row     { text-align: center; margin-bottom: 6px; }
.dev-otp-label     { margin-bottom: 4px; font-weight: 600; }
.dev-otp-hint      { margin-top: 4px; font-size: 0.75rem; opacity: 0.7; }
.auth-link-text--mt{ margin-top: 22px; }
.auth-back-link    { color: #6c757d; text-decoration: none; }
.auth-back-link:hover { color: var(--primary); }

/* ============================================================
   PROFILE PHOTO
   ============================================================ */
/* Replace plain letter avatar with photo-capable one */
.profile-avatar-wrap {
    position: relative; width: 80px; height: 80px;
    margin: 0 auto 12px; z-index: 1;
}
.profile-avatar-img {
    width: 80px; height: 80px; border-radius: 50%;
    object-fit: cover; border: 3px solid rgba(255,255,255,0.35);
    box-shadow: 0 6px 20px rgba(0,0,0,0.3); display: block;
}
.profile-avatar-initials {
    width: 80px; height: 80px; border-radius: 50%;
    background: rgba(255,255,255,0.15); border: 3px solid rgba(255,255,255,0.3);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif; font-size: 2rem; font-weight: 800;
    color: white; box-shadow: 0 6px 20px rgba(0,0,0,0.3);
}
/* Camera edit button overlaid on avatar */
.profile-avatar-edit {
    position: absolute; bottom: 0; right: 0;
    width: 26px; height: 26px; border-radius: 50%;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    border: 2px solid white; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.65rem; color: white; transition: all 0.2s;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}
.profile-avatar-edit:hover { transform: scale(1.15); }

/* Photo upload modal */
/* ============================================================
   PROFILE PHOTO MODAL
   ============================================================ */
@keyframes modalUp {
    from { transform: translateY(24px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

.photo-overlay {
    display: none;
    position: fixed; inset: 0; z-index: 9000;
    background: rgba(13,17,23,0.65);
    backdrop-filter: blur(5px);
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.photo-overlay.open { display: flex; }

.photo-modal {
    background: white;
    border-radius: 22px;
    width: 100%;
    max-width: 400px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(13,17,23,0.35);
    animation: modalUp 0.28s cubic-bezier(.22,.68,0,1.2);
}

/* ── Header ── */
.photo-modal-header {
    background: linear-gradient(135deg, #0d1b6e 0%, #3a0878 100%);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.photo-modal-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    color: white;
    letter-spacing: 0.3px;
    line-height: 1;
}
.photo-modal-close {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.22);
    color: white;
    font-size: 0.8rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
    padding: 0;
    font-family: inherit;
}
.photo-modal-close:hover { background: rgba(255,255,255,0.28); }

/* ── Body ── */
.photo-modal-body {
    padding: 22px 22px 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* ── Current photo preview ── */
.photo-current-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.photo-current-img {
    width: 84px; height: 84px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid rgba(67,97,238,0.18);
    box-shadow: 0 4px 16px rgba(67,97,238,0.14);
    display: block;
}
.photo-current-initials {
    width: 84px; height: 84px;
    border-radius: 50%;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.1rem;
    font-weight: 800;
    color: white;
    box-shadow: 0 4px 16px rgba(67,97,238,0.22);
}
.photo-current-label {
    font-size: 0.73rem;
    color: #9ca3af;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Divider */
.photo-modal-divider {
    height: 1px;
    background: rgba(67,97,238,0.08);
    margin: 0;
}

/* ── Drop zone ── */
.photo-drop-zone {
    border: 2px dashed rgba(67,97,238,0.25);
    border-radius: 14px;
    padding: 24px 20px 20px;
    text-align: center;
    background: #f8f9ff;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: border-color 0.2s, background 0.2s;
}
.photo-drop-zone input[type=file] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
    font-size: 0; /* prevents any text showing */
}
.photo-drop-zone:hover,
.photo-drop-zone.dragover {
    border-color: #4361ee;
    background: rgba(67,97,238,0.04);
}
.photo-drop-icon {
    font-size: 1.9rem;
    margin-bottom: 8px;
    display: block;
    opacity: 0.45;
    line-height: 1;
}
.photo-drop-text {
    font-size: 0.88rem;
    font-weight: 700;
    color: #1b263b;
    margin-bottom: 3px;
}
.photo-drop-hint {
    font-size: 0.74rem;
    color: #9ca3af;
}

/* ── Selected file preview strip ── */
.photo-file-preview {
    display: none;
    align-items: center;
    gap: 12px;
    background: #f0fdf4;
    border: 1.5px solid #bbf7d0;
    border-radius: 10px;
    padding: 10px 14px;
}
.photo-file-preview.show { display: flex; }
.photo-preview-thumb {
    width: 44px; height: 44px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(67,97,238,0.12);
    flex-shrink: 0;
}
.photo-preview-info { flex: 1; min-width: 0; }
.photo-preview-name {
    font-size: 0.82rem;
    font-weight: 700;
    color: #15803d;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.photo-preview-size { font-size: 0.72rem; color: #6b7280; margin-top: 2px; }

/* ── Error alert inside modal ── */
.photo-modal-body .alert { margin: 0; }

/* ── Upload button ── */
.btn-upload-photo {
    width: 100%;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    color: white;
    border: none;
    padding: 12px 20px;
    border-radius: 50px;
    font-size: 0.92rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.25s;
    box-shadow: 0 4px 14px rgba(67,97,238,0.28);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.btn-upload-photo:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(67,97,238,0.38);
}
.btn-upload-photo:disabled { opacity: 0.65; cursor: not-allowed; }

/* ── Remove button ── */
.photo-remove-btn {
    width: 100%;
    background: #fff;
    border: 1.5px solid rgba(239,71,111,0.25);
    color: #ef476f;
    padding: 10px 20px;
    border-radius: 50px;
    font-size: 0.84rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
}
.photo-remove-btn:hover:not(:disabled) {
    background: #fff0f4;
    border-color: #ef476f;
}
.photo-remove-btn:disabled { opacity: 0.55; cursor: not-allowed; }

/* ── addr-other-input hidden by default ── */
.addr-other-input { display: none; margin-top: 6px; }

/* ── Profile avatar wrap positioning ── */
.profile-avatar-block .profile-avatar-wrap { position: relative; }

/* ============================================================
   CHECKOUT — Online-only payment block + misc fixes
   ============================================================ */
.checkout-online-only {
    display: flex; align-items: center; gap: 14px;
    background: linear-gradient(135deg, rgba(67,97,238,0.06), rgba(114,9,183,0.04));
    border: 1.5px solid rgba(67,97,238,0.18);
    border-radius: 14px; padding: 16px 18px;
    margin-bottom: 12px;
}
.checkout-online-icon {
    font-size: 1.6rem; flex-shrink: 0;
    width: 44px; height: 44px; border-radius: 12px;
    background: linear-gradient(135deg, #4361ee, #7209b7);
    display: flex; align-items: center; justify-content: center;
}
.checkout-online-label {
    font-weight: 800; font-size: 0.95rem; color: #0d1117;
    font-family: 'Rajdhani', sans-serif;
}
.checkout-online-desc {
    font-size: 0.78rem; color: #6b7280; margin-top: 2px;
}
.checkout-online-badge {
    margin-left: auto; font-size: 1.4rem; flex-shrink: 0;
}

.checkout-terms {
    text-align: center; font-size: 0.77rem;
    color: #9ca3af; margin-top: 10px; margin-bottom: 0;
}
.checkout-terms a { color: var(--primary); }

.saved-addr-body { flex: 1; }

/* ── Checkout success overlay — tag assignment ── */
.success-tags {
    background: rgba(67,97,238,0.06);
    border: 1.5px solid rgba(67,97,238,0.15);
    border-radius: 12px; padding: 14px 16px;
    margin: 14px 0; text-align: left;
}
.success-tags-label {
    font-size: 0.82rem; font-weight: 700;
    color: #4361ee; margin-bottom: 10px;
}
.success-tags-list {
    display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 8px;
}
.success-tag-chip {
    background: white; border: 1.5px solid rgba(67,97,238,0.2);
    border-radius: 50px; padding: 4px 12px;
    font-size: 0.8rem; font-weight: 700; color: #0d1117;
    font-family: 'Courier New', monospace; letter-spacing: 0.5px;
}
.success-tags-hint {
    font-size: 0.74rem; color: #6b7280;
}
.success-actions {
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    margin-top: 6px;
}

/* ============================================================
   PRINT CARD — screen-wrap, hint, print media
   (used by printCard() popup window)
   ============================================================ */

/* Body of the popup window */
.screen-wrap {
    background: #e8ecf5;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 32px 20px 24px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
}

/* Instruction text below the card preview */
.screen-wrap .hint {
    margin-top: 20px;
    background: #fff;
    border: 1px solid rgba(67,97,238,0.15);
    border-radius: 10px;
    padding: 13px 20px;
    font-size: 13px;
    color: #4a5568;
    text-align: center;
    max-width: 420px;
    line-height: 1.75;
    box-shadow: 0 2px 12px rgba(67,97,238,0.07);
}

/* Right panel dark gradient background */
.pvc-right {
    background: linear-gradient(145deg, #1a1f5e 0%, #2e0a5a 100%);
}

/* ── Print media — exact CR80 card size, no margins ── */
@media print {
    @page {
        size: 85.6mm 54mm;
        margin: 0;
    }

    body, .screen-wrap {
        background: none !important;
        padding: 0 !important;
        display: block !important;
        min-height: unset !important;
    }

    .hint { display: none !important; }

    .pvc-card {
        width:  85.6mm !important;
        height: 54mm   !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        page-break-inside: avoid;
        break-inside: avoid;
    }

    * {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
    }
}

/* ============================================================
   DARK MODE  —  [data-theme="dark"]
   Applied to <html> element via JS.
   ============================================================ */

[data-theme="dark"] {
    --primary:       #6b8fff;
    --primary-dark:  #4361ee;
    --secondary:     #c77dff;
    --success:       #06d6a0;
    --warning:       #ffb703;
    --danger:        #ff6b8a;
    --dark:          #e8eaf6;
    --dark-2:        #c5c8e8;
    --light:         #0f1117;
    --gray:          #8b8fa8;
    --gray-light:    #1e2030;
    --white:         #1a1d2e;
    --border:        rgba(107,143,255,0.15);
    --shadow-sm:     0 2px 8px rgba(0,0,0,0.4);
    --shadow-md:     0 4px 20px rgba(0,0,0,0.5);
    --shadow-lg:     0 10px 40px rgba(0,0,0,0.6);
}

/* Body & backgrounds */
[data-theme="dark"] body                      { background: #0f1117; color: #c5c8e8; }
[data-theme="dark"] .dash-main                { background: #0f1117; }
[data-theme="dark"] .dash-sidebar             { background: #13161f; border-right-color: rgba(107,143,255,0.12); }
[data-theme="dark"] .dash-nav-item            { color: #8b8fa8; }
[data-theme="dark"] .dash-nav-item:hover,
[data-theme="dark"] .dash-nav-item.active     { background: rgba(107,143,255,0.12); color: #6b8fff; }
[data-theme="dark"] .dash-nav-label           { color: #484c6c; }
[data-theme="dark"] .dash-user                { border-top-color: rgba(107,143,255,0.1); }
[data-theme="dark"] .dash-user-name           { color: #c5c8e8; }
[data-theme="dark"] .dash-user-phone          { color: #6b6f8a; }
[data-theme="dark"] .dash-logout              { color: #8b8fa8; }

/* Cards */
[data-theme="dark"] .stat-card,
[data-theme="dark"] .section-card,
[data-theme="dark"] .dash-stat-card           { background: #13161f; border-color: rgba(107,143,255,0.12); color: #c5c8e8; }
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .section-card:hover,
[data-theme="dark"] .dash-stat-card:hover     { background: #1a1d2e; border-color: rgba(107,143,255,0.25); }
[data-theme="dark"] .stat-card-label,
[data-theme="dark"] .stat-card-sub            { color: #6b6f8a; }
[data-theme="dark"] .stat-card-num            { color: #6b8fff; -webkit-text-fill-color: unset; background: none; }
[data-theme="dark"] .section-card-title       { color: #c5c8e8; }
[data-theme="dark"] .section-card-header      { border-color: rgba(107,143,255,0.1); }

/* Tags */
[data-theme="dark"] .tag-card                 { background: #1a1d2e; border-color: rgba(107,143,255,0.1); }
[data-theme="dark"] .tag-number               { color: #e8eaf6; }
[data-theme="dark"] .tag-vehicle              { color: #8b8fa8; }

/* Orders */
[data-theme="dark"] .order-row                { border-bottom-color: rgba(107,143,255,0.08); }
[data-theme="dark"] .order-num               { color: #6b8fff; }
[data-theme="dark"] .order-item,
[data-theme="dark"] .order-amount            { color: #c5c8e8; }

/* Quick actions */
[data-theme="dark"] .qa-btn                  { background: #1a1d2e; border-color: rgba(107,143,255,0.15); color: #c5c8e8; }
[data-theme="dark"] .qa-btn:hover            { background: #22253a; border-color: rgba(107,143,255,0.3); }
[data-theme="dark"] .qa-label               { color: #8b8fa8; }

/* Buttons */
[data-theme="dark"] .btn-sm                  { background: linear-gradient(135deg,#4361ee,#7209b7); color: #fff; }
[data-theme="dark"] .btn-sm.outline          { background: transparent; border-color: rgba(107,143,255,0.4); color: #6b8fff; }
[data-theme="dark"] .btn-sm.outline:hover    { background: rgba(107,143,255,0.1); }

/* Alerts */
[data-theme="dark"] .alert-banner-warn       { background: rgba(255,183,3,0.1); border-color: rgba(255,183,3,0.25); color: #ffb703; }
[data-theme="dark"] .alert-banner-danger     { background: rgba(239,71,111,0.1); border-color: rgba(239,71,111,0.25); color: #ff6b8a; }

/* Page header */
[data-theme="dark"] .page-title              { color: #e8eaf6; }
[data-theme="dark"] .page-sub               { color: #6b6f8a; }

/* Inputs & forms */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea                 { background: #1a1d2e; border-color: rgba(107,143,255,0.2); color: #c5c8e8; }
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder   { color: #484c6c; }
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus          { border-color: #6b8fff; outline: none; }

/* Scan logs */
[data-theme="dark"] .scan-stat-card         { background: #13161f; border-color: rgba(107,143,255,0.12); }
[data-theme="dark"] .log-text              { color: #c5c8e8; }

/* Misc utility text colors */
[data-theme="dark"] .empty-title           { color: #c5c8e8; }
[data-theme="dark"] .empty-desc,
[data-theme="dark"] .order-item           { color: #6b6f8a; }

/* Onboarding banner */
[data-theme="dark"] .onboarding-banner    { background: #13161f; border-color: rgba(107,143,255,0.2); }
[data-theme="dark"] .ob-title            { color: #e8eaf6; }
[data-theme="dark"] .ob-step-label       { color: #8b8fa8; }
[data-theme="dark"] .ob-step-num         { background: #1a1d2e; border-color: rgba(107,143,255,0.2); color: #6b8fff; }
[data-theme="dark"] .ob-step.active .ob-step-num { background: linear-gradient(135deg,#4361ee,#7209b7); color:#fff; border-color:transparent; }
[data-theme="dark"] .ob-step.done .ob-step-num   { background: #06d6a0; color:#fff; border-color:transparent; }
[data-theme="dark"] .ob-step-line        { background: rgba(107,143,255,0.15); }

/* Dashboard scan chart area */
[data-theme="dark"] .scan-chart-wrap     { background: #13161f; border-color: rgba(107,143,255,0.12); }

/* Profile page */
[data-theme="dark"] .pg-card            { background: #13161f; border-color: rgba(107,143,255,0.12); }
[data-theme="dark"] .pg-card-title      { color: #e8eaf6; }
[data-theme="dark"] .pg-fg label        { color: #8b8fa8; }
[data-theme="dark"] .pg-fg input,
[data-theme="dark"] .pg-fg select       { background: #1a1d2e; border-color: rgba(107,143,255,0.2); color: #c5c8e8; }

/* Checkout */
[data-theme="dark"] .checkout-summary,
[data-theme="dark"] .checkout-form-card  { background: #13161f; border-color: rgba(107,143,255,0.12); }
[data-theme="dark"] .price-line          { color: #c5c8e8; }
[data-theme="dark"] .price-line.total-line { border-top-color: rgba(107,143,255,0.15); color:#e8eaf6; }

/* Scrollbar in dark mode */
[data-theme="dark"] ::-webkit-scrollbar-track  { background: #1a1d2e; }
[data-theme="dark"] ::-webkit-scrollbar-thumb  { background: #4361ee; }

/* Dark mode toggle button in sidebar */
.dark-toggle-wrap {
    padding: 12px 16px;
    margin: 0 12px 8px;
    background: rgba(107,143,255,0.06);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    border: 1px solid rgba(107,143,255,0.1);
    transition: all 0.2s;
}
.dark-toggle-wrap:hover { background: rgba(107,143,255,0.1); }
.dark-toggle-label { font-size: .78rem; font-weight: 600; color: var(--gray); }
.dark-toggle-switch {
    width: 36px; height: 20px;
    background: #ddd;
    border-radius: 20px;
    position: relative;
    transition: background 0.2s;
    flex-shrink: 0;
}
.dark-toggle-switch::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    background: #fff;
    border-radius: 50%;
    top: 3px; left: 3px;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
[data-theme="dark"] .dark-toggle-switch             { background: #4361ee; }
[data-theme="dark"] .dark-toggle-switch::after      { transform: translateX(16px); }
[data-theme="dark"] .dark-toggle-label              { color: #6b8fa8; }

/* ── Onboarding Banner ─────────────────────────────────────── */
.onboarding-banner {
    background: #fff;
    border: 1.5px solid rgba(67,97,238,0.15);
    border-radius: 20px;
    padding: 22px 24px;
    margin-bottom: 22px;
    position: relative;
    box-shadow: 0 4px 20px rgba(67,97,238,0.08);
}
.ob-close {
    position: absolute; top: 14px; right: 16px;
    background: none; border: none; color: #9ca3af;
    font-size: 1rem; cursor: pointer; line-height: 1; padding: 4px;
}
.ob-close:hover { color: #374151; }
.ob-title {
    font-weight: 800; font-size: 1rem; color: #1b263b; margin-bottom: 18px;
    font-family: 'Rajdhani', sans-serif;
}
.ob-steps {
    display: flex; align-items: center; gap: 0; flex-wrap: wrap; gap: 8px;
}
.ob-step {
    display: flex; align-items: center; gap: 10px;
    text-decoration: none; flex-shrink: 0;
}
.ob-step-num {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: #f3f4f6;
    border: 2px solid #e5e7eb;
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; font-weight: 700; color: #9ca3af;
    flex-shrink: 0; transition: all .2s;
}
.ob-step.active .ob-step-num {
    background: linear-gradient(135deg,#4361ee,#7209b7);
    color: #fff; border-color: transparent;
    box-shadow: 0 4px 12px rgba(67,97,238,0.3);
}
.ob-step.done .ob-step-num {
    background: #06d6a0; color: #fff; border-color: transparent;
}
.ob-step-label {
    font-size: .82rem; font-weight: 600; color: #374151; white-space: nowrap;
}
.ob-step.active .ob-step-label { color: #4361ee; }
.ob-step.done  .ob-step-label  { color: #06d6a0; }
.ob-step-line {
    flex: 1; height: 2px; background: #e5e7eb;
    min-width: 20px; max-width: 60px; border-radius: 2px;
}
.ob-progress {
    height: 4px; background: #f3f4f6; border-radius: 4px;
    margin-top: 16px; overflow: hidden;
}
.ob-progress-bar {
    height: 100%;
    background: linear-gradient(135deg,#4361ee,#7209b7);
    border-radius: 4px; transition: width .4s ease;
}

/* ── Scan chart widget ─────────────────────────────────────── */
.scan-chart-wrap {
    background: #fff;
    border: 1px solid rgba(67,97,238,0.1);
    border-radius: 16px;
    padding: 18px 20px;
    margin-bottom: 16px;
}
.scan-chart-title {
    font-family: 'Rajdhani',sans-serif;
    font-size: 1rem; font-weight: 700; color: #1b263b;
    margin-bottom: 14px;
    display: flex; align-items: center; justify-content: space-between;
}
.scan-chart-canvas { width: 100% !important; height: 120px !important; }

/* ── Email notification preference card ────────────────────── */
.notif-pref-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 0; border-bottom: 1px solid rgba(67,97,238,0.08);
}
.notif-pref-row:last-child { border-bottom: none; }
.notif-pref-label { font-size: .88rem; font-weight: 600; color: #374151; }
.notif-pref-desc  { font-size: .75rem; color: #9ca3af; margin-top: 2px; }
.toggle-switch-wrap {
    position: relative; width: 44px; height: 24px; flex-shrink: 0;
}
.toggle-switch-wrap input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute; cursor: pointer; inset: 0;
    background: #d1d5db; border-radius: 24px; transition: .2s;
}
.toggle-slider::before {
    content: ''; position: absolute;
    width: 18px; height: 18px; border-radius: 50%;
    background: #fff; bottom: 3px; left: 3px;
    transition: .2s; box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.toggle-switch-wrap input:checked + .toggle-slider         { background: #4361ee; }
.toggle-switch-wrap input:checked + .toggle-slider::before { transform: translateX(20px); }
[data-theme="dark"] .toggle-slider { background: #374151; }
