/* TrustVerify — Portal CSS | bgv.aisecops.in
   Blue theme | Professional | Mobile-first */

:root {
  --blue-900: #042C53;
  --blue-800: #0C447C;
  --blue-700: #185FA5;
  --blue-600: #2373BF;
  --blue-500: #378ADD;
  --blue-200: #85B7EB;
  --blue-100: #B5D4F4;
  --blue-50:  #E6F1FB;
  --teal-700: #0F6E56;
  --teal-500: #1D9E75;
  --teal-50:  #E1F5EE;
  --amber-700:#854F0B;
  --amber-500:#BA7517;
  --amber-50: #FAEEDA;
  --green-700:#3B6D11;
  --green-500:#639922;
  --green-50: #EAF3DE;
  --red-700:  #A32D2D;
  --red-50:   #FCEBEB;
  --gray-800: #444441;
  --gray-600: #5F5E5A;
  --gray-200: #B4B2A9;
  --gray-100: #D3D1C7;
  --gray-50:  #F1EFE8;

  --text-primary:   #1a1a18;
  --text-secondary: #5F5E5A;
  --text-muted:     #888780;
  --border:         #e2e0d8;
  --border-strong:  #c8c6be;
  --surface:        #ffffff;
  --surface-2:      #f8f7f4;
  --surface-3:      #f0ede6;

  --radius:    10px;
  --radius-sm: 6px;
  --radius-lg: 14px;
  --shadow:    0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
  --nav-h: 58px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:15px;scroll-behavior:smooth;}
body{font-family:-apple-system,'Segoe UI',Roboto,sans-serif;color:var(--text-primary);background:var(--surface-2);line-height:1.6;}
a{color:var(--blue-700);text-decoration:none;}
a:hover{color:var(--blue-800);}
img{max-width:100%;}
input,select,textarea,button{font-family:inherit;font-size:14px;}

/* ── Top Nav ────────────────────────────────────────────────────── */
.top-nav{position:sticky;top:0;z-index:100;background:var(--blue-900);height:var(--nav-h);box-shadow:0 2px 8px rgba(4,44,83,0.4);}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:20px;height:100%;padding:0 20px;}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.nav-logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:9px;flex-shrink:0;}
.brand-mark{width:34px;height:34px;border-radius:8px;background:var(--blue-500);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:white;flex-shrink:0;}
.brand-name{font-size:16px;font-weight:800;color:white;line-height:1;letter-spacing:-0.3px;}
.brand-sub{font-size:10px;color:var(--blue-100);letter-spacing:0.5px;line-height:1;margin-top:2px;opacity:0.8;}

.nav-links{display:flex;align-items:center;gap:4px;flex:1;}
.nav-links a{color:rgba(255,255,255,0.7);font-size:13.5px;font-weight:500;padding:6px 12px;border-radius:7px;transition:all .15s;}
.nav-links a:hover{color:white;background:rgba(255,255,255,0.1);}
.nav-links a.active{color:white;background:rgba(255,255,255,0.15);}

.nav-user{margin-left:auto;display:flex;align-items:center;gap:10px;position:relative;}
.user-name{font-size:13px;color:rgba(255,255,255,0.7);}
.user-badge{width:32px;height:32px;border-radius:50%;background:var(--blue-500);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:white;cursor:pointer;border:2px solid rgba(255,255,255,0.2);}
.user-badge:hover{background:var(--blue-600);}
.user-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);background:white;border:0.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:180px;padding:6px 0;}
.user-menu a{display:block;padding:8px 16px;font-size:13px;color:var(--text-primary);}
.user-menu a:hover{background:var(--surface-2);}
.nav-user:hover .user-menu,.nav-user:focus-within .user-menu{display:block;}

.nav-hamburger{display:none;background:none;border:none;color:white;font-size:20px;cursor:pointer;padding:4px 8px;margin-left:auto;}
@media(max-width:768px){
  .nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--blue-900);flex-direction:column;padding:8px;z-index:99;}
  .nav-links.open{display:flex;}
  .nav-hamburger{display:block;}
  .user-name{display:none;}
}

/* ── Page layout ────────────────────────────────────────────────── */
.page-wrap{max-width:1280px;margin:0 auto;padding:24px 20px;}
.page-header{margin-bottom:24px;}
.page-title{font-size:22px;font-weight:700;color:var(--blue-900);}
.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:3px;}

/* ── Cards ──────────────────────────────────────────────────────── */
.card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;}
.card-title{font-size:15px;font-weight:600;color:var(--blue-900);margin-bottom:16px;display:flex;align-items:center;gap:8px;}

/* ── Stat cards ─────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px;}
.stat-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;}
.stat-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:0.4px;}
.stat-value{font-size:26px;font-weight:700;color:var(--blue-900);margin-top:4px;line-height:1.1;}
.stat-change{font-size:11px;color:var(--teal-700);margin-top:4px;}
.stat-card.blue .stat-value{color:var(--blue-700);}
.stat-card.green .stat-value{color:var(--teal-700);}
.stat-card.amber .stat-value{color:var(--amber-700);}
.stat-card.red .stat-value{color:var(--red-700);}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;}
.btn-primary{background:var(--blue-700);color:white;}
.btn-primary:hover{background:var(--blue-800);}
.btn-primary:active{transform:scale(0.98);}
.btn-secondary{background:var(--surface);color:var(--blue-700);border:1px solid var(--blue-200);}
.btn-secondary:hover{background:var(--blue-50);}
.btn-danger{background:var(--red-700);color:white;}
.btn-danger:hover{background:#891e1e;}
.btn-success{background:var(--teal-500);color:white;}
.btn-success:hover{background:var(--teal-700);}
.btn-sm{padding:5px 12px;font-size:12px;}
.btn:disabled{opacity:0.55;cursor:not-allowed;}
.btn-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}

/* ── Forms ──────────────────────────────────────────────────────── */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:5px;}
.form-control{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text-primary);background:var(--surface);transition:border-color .15s,box-shadow .15s;}
.form-control:hover{border-color:var(--border-strong);}
.form-control:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(55,138,221,0.12);}
.form-control::placeholder{color:var(--gray-200);}
select.form-control{cursor:pointer;}
textarea.form-control{min-height:90px;resize:vertical;}
.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}

/* ── Tables ─────────────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius);border:0.5px solid var(--border);}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px;}
.tbl th{background:var(--surface-3);padding:10px 14px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.3px;border-bottom:0.5px solid var(--border);}
.tbl td{padding:11px 14px;border-bottom:0.5px solid var(--border);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr:hover td{background:var(--surface-2);}
.tbl.compact td,.tbl.compact th{padding:7px 10px;font-size:12px;}

/* ── Badges ─────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;}
.badge-blue{background:var(--blue-50);color:var(--blue-800);}
.badge-green{background:var(--teal-50);color:var(--teal-700);}
.badge-amber{background:var(--amber-50);color:var(--amber-700);}
.badge-red{background:var(--red-50);color:var(--red-700);}
.badge-gray{background:var(--gray-50);color:var(--gray-800);}

/* ── Status badges (case lifecycle) ────────────────────────────── */
.status-draft{background:#f1efe8;color:#5f5e5a;}
.status-pending_payment,.status-pending{background:var(--amber-50);color:var(--amber-700);}
.status-receipt_uploaded{background:#EEF5FF;color:#1855A3;}
.status-payment_confirmed{background:var(--blue-50);color:var(--blue-700);}
.status-assigned{background:#f0edfb;color:#534AB7;}
.status-in_progress{background:var(--blue-50);color:var(--blue-700);}
.status-under_review{background:var(--amber-50);color:var(--amber-700);}
.status-completed{background:var(--teal-50);color:var(--teal-700);}
.status-cancelled{background:var(--red-50);color:var(--red-700);}
.status-initiated,.status-not_started{background:var(--gray-50);color:var(--gray-600);}

/* ── Progress bar ───────────────────────────────────────────────── */
.progress-bar{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;background:var(--blue-500);border-radius:3px;transition:width .4s ease;}
.progress-fill.green{background:var(--teal-500);}
.progress-fill.amber{background:var(--amber-500);}

/* ── Alerts ─────────────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:8px;font-size:13.5px;margin-bottom:16px;display:flex;gap:10px;align-items:flex-start;}
.alert-info{background:var(--blue-50);border:0.5px solid var(--blue-200);color:var(--blue-800);}
.alert-success{background:var(--teal-50);border:0.5px solid var(--teal-500);color:var(--teal-700);}
.alert-warning{background:var(--amber-50);border:0.5px solid var(--amber-500);color:var(--amber-700);}
.alert-danger{background:var(--red-50);border:0.5px solid var(--red-700);color:var(--red-700);}

/* ── Flash toasts ───────────────────────────────────────────────── */
.flash{padding:12px 16px;border-radius:10px;font-size:13.5px;font-weight:500;margin-bottom:8px;animation:slideIn .25s ease;box-shadow:0 4px 16px rgba(0,0,0,0.12);user-select:text;-webkit-user-select:text;cursor:text;}
.flash-success{background:#0F6E56;color:#fff;}
.flash-error{background:#A32D2D;color:#fff;}
.flash-warning{background:#854F0B;color:#fff;}
.flash-info{background:var(--blue-700);color:#fff;}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* ── Modals ─────────────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(4,44,83,0.65);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;}
.modal-box{background:var(--surface);border-radius:var(--radius-lg);padding:28px 28px 24px;max-width:560px;width:100%;position:relative;box-shadow:0 20px 60px rgba(4,44,83,0.3);margin:auto;}
.modal-title{font-size:17px;font-weight:700;color:var(--blue-900);margin-bottom:16px;}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer;line-height:1;padding:4px;}
.modal-close:hover{color:var(--text-primary);}

/* ── Check item selector ────────────────────────────────────────── */
.check-item{border:1.5px solid var(--border);border-radius:10px;padding:13px 14px;cursor:pointer;transition:all .15s;position:relative;}
.check-item:hover{border-color:var(--blue-300,#85B7EB);background:var(--blue-50);}
.check-item.selected{border-color:var(--blue-700);background:var(--blue-50);}
.check-item .check-name{font-size:13.5px;font-weight:600;color:var(--text-primary);}
.check-item .check-price{font-size:13px;color:var(--blue-700);font-weight:700;margin-top:3px;}
.check-item .check-sla{font-size:11px;color:var(--text-muted);margin-top:2px;}
.check-item .check-tick{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;background:var(--blue-700);display:flex;align-items:center;justify-content:center;color:white;font-size:11px;opacity:0;transition:opacity .15s;}
.check-item.selected .check-tick{opacity:1;}
.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;align-items:start;}
.category-header{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;padding:10px 0 6px;border-top:0.5px solid var(--border);margin-top:6px;}
.category-header:first-child{border-top:none;margin-top:0;}

/* ── Cart summary ───────────────────────────────────────────────── */
.cart-box{background:var(--surface-2);border:0.5px solid var(--border);border-radius:var(--radius);padding:16px;}
.cart-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;}
.cart-row.total{font-weight:700;font-size:14px;border-top:0.5px solid var(--border);margin-top:6px;padding-top:8px;}
.cart-gst{color:var(--text-muted);}

/* ── QR / Payment box ───────────────────────────────────────────── */
.qr-box{text-align:center;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);}
.qr-amount{font-size:28px;font-weight:800;color:var(--blue-900);margin-bottom:4px;}
.qr-label{font-size:13px;color:var(--text-muted);margin-bottom:16px;}
.qr-img{width:200px;height:200px;border:1px solid var(--border);border-radius:8px;background:#fff;display:inline-block;padding:8px;}
.qr-timer{font-size:13px;color:var(--amber-700);font-weight:600;margin-top:12px;}
.qr-upi{font-size:12px;color:var(--text-muted);margin-top:6px;font-family:monospace;}

/* ── Timeline (case tracking) ───────────────────────────────────── */
.timeline{position:relative;padding-left:28px;}
.timeline::before{content:'';position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--border);}
.tl-item{position:relative;margin-bottom:20px;}
.tl-dot{position:absolute;left:-23px;top:2px;width:14px;height:14px;border-radius:50%;background:var(--gray-100);border:2px solid var(--border);}
.tl-dot.done{background:var(--teal-500);border-color:var(--teal-500);}
.tl-dot.active{background:var(--blue-500);border-color:var(--blue-500);}
.tl-dot.pending{background:white;border-color:var(--gray-200);}
.tl-content{font-size:13.5px;}
.tl-title{font-weight:600;color:var(--text-primary);}
.tl-meta{font-size:12px;color:var(--text-muted);margin-top:2px;}

/* ── Pagination ─────────────────────────────────────────────────── */
.pagination{display:flex;gap:4px;align-items:center;justify-content:center;margin-top:20px;}
.page-btn{padding:6px 12px;border:0.5px solid var(--border);border-radius:6px;font-size:13px;color:var(--text-secondary);background:var(--surface);cursor:pointer;}
.page-btn:hover{background:var(--blue-50);border-color:var(--blue-200);}
.page-btn.active{background:var(--blue-700);color:white;border-color:var(--blue-700);}
.page-btn:disabled{opacity:0.4;cursor:not-allowed;}

/* ── Empty state ────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);}
.empty-state .empty-icon{font-size:48px;margin-bottom:16px;}
.empty-state h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;}
.empty-state p{font-size:13.5px;}

/* ── Section tabs ───────────────────────────────────────────────── */
.tab-bar{display:flex;gap:2px;border-bottom:1.5px solid var(--border);margin-bottom:20px;}
.tab-btn{padding:8px 16px;font-size:13.5px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;background:none;border-top:none;border-left:none;border-right:none;transition:all .15s;}
.tab-btn:hover{color:var(--text-primary);}
.tab-btn.active{color:var(--blue-700);border-bottom-color:var(--blue-700);font-weight:600;}

/* ── Print / report ─────────────────────────────────────────────── */
@media print{
  .top-nav,.nav-hamburger,.btn,.pagination,#flash-area{display:none!important;}
  .page-wrap{padding:0;max-width:100%;}
  .card{border:0.5px solid #ccc;box-shadow:none;}
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr 1fr;}
  .check-grid{grid-template-columns:1fr 1fr;}
  .page-wrap{padding:16px;}
  .card{padding:16px;}
}
