/* ===== Ibn Qaid V3.1 - Production Stylesheet ===== */
:root {
  --brand-purple: #802a5d;
  --brand-orange: #f39c12;
  --brand-dark: #4a1a35;
  --brand-light: #f8f0f5;
  --text-dark: #1a1a1a;
  --bg-main: #f1f5f9;
  --section-bg: #fdfdfd;
  --border-color: #e2e8f0;
  --danger: #dc2626;
  --success: #16a34a;
  --info: #1d4ed8;
  --ink-blue: #1a237e;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 16px 48px rgba(128,42,93,0.12);
}

/* === Reset & Base === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Cairo','Segoe UI',Tahoma,sans-serif;background:var(--bg-main);direction:rtl;overscroll-behavior-y:none;color:var(--text-dark);line-height:1.6}
input,select,button,textarea{font-family:inherit;font-size:15px}
input:focus,select:focus,textarea:focus{border-color:var(--brand-purple)!important;box-shadow:0 0 0 3px rgba(128,42,93,0.1);outline:none}
button{transition:all 0.2s;cursor:pointer;border:none}
button:hover:not(:disabled){opacity:0.92;transform:translateY(-1px)}
button:disabled{opacity:0.5;cursor:not-allowed;transform:none}
img{max-width:100%;height:auto}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}

/* === Animations === */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shake{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}
@keyframes bounceIn{0%{opacity:0;transform:scale(0.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(0.9)}100%{transform:scale(1)}}
@keyframes progressFill{from{width:0}to{width:var(--progress)}}
.fade-in{animation:fadeIn 0.35s ease}
.slide-up{animation:slideUp 0.4s cubic-bezier(0.16,1,0.3,1)}
.shake{animation:shake 0.5s ease-in-out}
.bounce-in{animation:bounceIn 0.6s ease}

/* === UI Components === */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700}
.badge-green{background:#dcfce7;color:var(--success)}
.badge-yellow{background:#fef9c3;color:#a16207}
.badge-red{background:#fef2f2;color:var(--danger)}
.badge-blue{background:#dbeafe;color:var(--info)}
.badge-purple{background:var(--brand-light);color:var(--brand-purple)}

.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);padding:12px 24px;border-radius:var(--radius-md);font-size:13px;font-weight:700;z-index:9999;box-shadow:0 8px 24px rgba(0,0,0,0.15);display:flex;align-items:center;gap:8px;animation:slideUp 0.3s ease,fadeIn 0.3s ease}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:5000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-content{background:white;width:100%;max-width:600px;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,0.2)}

.card{background:white;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}
.card-header{padding:20px 24px 16px;border-bottom:1px solid #f1f5f9}
.card-body{padding:20px 24px;min-height:360px}
.card-footer{padding:12px 24px 20px;display:flex;gap:10px}

/* === Stats Dashboard === */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:white;border-radius:var(--radius-lg);padding:16px;text-align:center;border:1px solid var(--border-color);transition:transform 0.2s,box-shadow 0.2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-icon{font-size:28px;margin-bottom:6px}
.stat-number{font-size:28px;font-weight:900;line-height:1}
.stat-label{font-size:11px;font-weight:700;color:#64748b;margin-top:4px}

/* === Filter Bar === */
.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.filter-bar input,.filter-bar select{padding:8px 12px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;background:#f8fafc;min-width:120px}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--brand-purple)}

/* === Progress Steps === */
.progress-steps{display:flex;gap:4px;margin-bottom:8px}
.progress-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.progress-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;transition:all 0.3s;border:2px solid var(--border-color);background:white;color:#94a3b8}
.progress-dot.active{border-color:var(--brand-purple);background:var(--brand-purple);color:white}
.progress-dot.completed{border-color:var(--success);background:var(--success);color:white}
.progress-label{font-size:8px;font-weight:700;color:#94a3b8;text-align:center;max-width:60px;line-height:1.2}
.progress-label.active{color:var(--brand-purple)}
.progress-label.completed{color:var(--success)}
.progress-bar-track{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden;margin-top:4px}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--brand-purple),var(--brand-orange));border-radius:2px;transition:width 0.5s ease}

/* === Settings Panels === */
.settings-section{background:#f8fafc;border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;border:1px solid var(--border-color)}
.settings-title{font-size:14px;font-weight:800;color:var(--brand-purple);margin-bottom:12px;display:flex;align-items:center;gap:8px}

/* === Tab Navigation === */
.tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.tab{display:flex;align-items:center;gap:6px;padding:10px 18px;background:white;color:#64748b;border-radius:var(--radius-md);font-size:13px;font-weight:700;box-shadow:var(--shadow-sm);position:relative}
.tab.active{background:var(--brand-purple);color:white;box-shadow:0 4px 12px rgba(128,42,93,0.2)}
.tab-badge{background:rgba(255,255,255,0.3);padding:1px 7px;border-radius:10px;font-size:10px;font-weight:800}
.tab:not(.active) .tab-badge{background:var(--danger);color:white}

/* ===== PRINT & PDF STYLES ===== */
@media print{
  body{background:none!important;padding:0!important;margin:0!important}
  .no-print{display:none!important}
  .page-a4{box-shadow:none!important;border:none!important;margin:0!important;width:210mm!important;height:297mm!important;page-break-after:always;break-after:page}
  .page-a4::before{content:'';position:absolute;top:0;left:0;right:0;height:15px;background:var(--brand-orange)!important;-webkit-print-color-adjust:exact}
  .page-a4::after{content:'';position:absolute;bottom:0;left:0;right:0;height:15px;background:var(--brand-purple)!important;-webkit-print-color-adjust:exact}
}
@page{size:A4 portrait;margin:0}

.page-a4{background:white;width:210mm;height:296mm;max-height:296mm;position:relative;overflow:hidden;display:flex;flex-direction:column;border-top:15px solid var(--brand-orange);border-bottom:15px solid var(--brand-purple);font-family:'Cairo',sans-serif;direction:rtl;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;margin-bottom:20px;box-shadow:0 10px 30px rgba(0,0,0,0.2);page-break-inside:avoid;break-inside:avoid}
.watermark-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;opacity:0.03;z-index:0;pointer-events:none;display:flex;justify-content:center;align-items:center}
.watermark-img{width:100%;height:auto;filter:grayscale(100%)}
.content-wrapper{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;padding:10mm 15mm;gap:15px;justify-content:space-between}
.designer-mark{position:absolute;bottom:3px;right:10px;font-size:8px;color:#ccc;font-style:italic;z-index:1000;opacity:0.7}

/* PDF handwritten style for client data */
.pdf-handwritten{font-family:'Aref Ruqaa','Cairo',serif;color:var(--ink-blue);font-weight:700}

/* PDF Page Elements */
.page-header{display:flex;justify-content:space-between;align-items:center;border-bottom:3px solid var(--brand-purple);padding-bottom:10px;margin-bottom:10px}
.header-title{font-size:20px;font-weight:900;color:var(--brand-purple)}
.section-label{font-size:14px;font-weight:800;color:var(--brand-purple);margin-bottom:10px;border-bottom:1px dashed #ccc;padding-bottom:5px;display:flex;align-items:center;gap:8px}
.section-label i{color:var(--brand-orange);font-size:16px}
.cover-header{text-align:center;margin-top:10mm}
.logo-container{width:180px;height:180px;margin:0 auto 10px auto}
.logo-img{width:100%;height:100%;object-fit:contain}
.company-title{font-size:34px;font-weight:900;color:var(--brand-purple);margin:0;line-height:1.2}
.company-subtitle{font-size:16px;font-weight:700;color:var(--brand-orange);letter-spacing:1px;margin-top:5px}
.file-label-box{text-align:center;width:100%;margin:8mm 0}
.file-label{background:linear-gradient(to right,var(--brand-purple),#a03c78);color:white;padding:12px 70px;border-radius:50px;font-size:30px;font-weight:800;display:inline-block}
.cover-fields{width:100%;display:flex;flex-direction:column;gap:20px;margin-bottom:auto}
.field-row{display:flex;flex-direction:column;gap:8px}
.field-label{font-size:20px;font-weight:800;color:var(--brand-purple);display:flex;align-items:center;gap:12px}
.field-label i{color:var(--brand-orange);font-size:22px}
.input-display{border:2px solid #ddd;background:rgba(250,250,250,0.8);height:55px;border-radius:12px;display:flex;align-items:center;padding:0 20px;font-size:20px;font-weight:700;color:#333}
.account-input{border-color:var(--brand-orange);background:rgba(255,251,242,0.9);font-family:monospace;letter-spacing:3px;font-size:26px;color:var(--brand-purple)}
.cover-footer{text-align:center;border-top:3px solid var(--brand-orange);padding-top:15px;margin-top:auto;padding-bottom:5mm}
.contact-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-bottom:12px}
.contact-pill{background:#f0f0f0;padding:6px 18px;border-radius:30px;font-size:13px;font-weight:700;color:var(--text-dark);display:flex;align-items:center;gap:8px;border:1px solid #ddd}
.contact-pill i{color:var(--brand-purple)}
.address-bar{background:var(--brand-purple);color:white;padding:8px;border-radius:8px;font-size:12px;font-weight:700;display:inline-block;width:100%}

/* Terms page */
.title-box{text-align:center;margin-bottom:20px;border-bottom:3px solid var(--brand-purple);padding-bottom:10px}
.main-title{background:rgba(128,42,93,0.1);color:var(--brand-purple);padding:10px 40px;border-radius:10px;font-size:24px;font-weight:900;display:inline-block;border:2px solid var(--brand-purple)}
.terms-list{font-size:15px;line-height:1.7;color:var(--text-dark);text-align:justify;list-style:none;padding:0}
.terms-list li{margin-bottom:8px;padding-right:20px;position:relative}
.terms-list li::before{content:'▪';color:var(--brand-orange);font-size:20px;position:absolute;right:0;top:-2px}
.terms-list strong{color:var(--brand-purple)}
.declaration-section{margin-top:auto;background:#fffcf5;border:2px solid var(--brand-orange);border-radius:10px;padding:20px}
.declaration-text{font-size:16px;font-weight:800;text-align:center;color:var(--brand-purple);margin-bottom:30px;border-bottom:1px dashed #ccc;padding-bottom:10px}
.signature-row{display:flex;justify-content:space-between;align-items:flex-end;padding:0 20px}
.sig-block{display:flex;flex-direction:column;gap:10px;width:40%}
.sig-label{font-size:14px;font-weight:700;color:#555}
.sig-input{border-bottom:2px dotted #333;height:30px;display:flex;align-items:flex-end;padding-bottom:2px;font-weight:700;font-size:14px}

/* Data page */
.header-meta{display:flex;gap:15px}
.meta-field{border:1px solid var(--brand-orange);padding:5px 15px;border-radius:6px;font-size:12px;font-weight:700;color:var(--text-dark);background:#fffbf2}
.section-container{background:var(--section-bg);border:1px solid #eee;border-radius:8px;padding:12px}
.fields-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:10px}
.field-group{display:flex;flex-direction:column}
.label{font-size:11px;font-weight:700;color:#444;margin-bottom:4px}
.input{border:1px solid #ccc;height:35px;background:white;border-radius:4px;font-size:13px;padding:0 8px;display:flex;align-items:center}
.checkbox-row{display:flex;flex-wrap:wrap;gap:10px;padding:2px 0}
.checkbox-item{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#333}
.box{width:16px;height:16px;border:2px solid var(--brand-purple);border-radius:3px;background:white;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:var(--brand-purple)}

/* Signature cards */
.signatures-container-p3{border:2px solid var(--brand-purple);border-radius:10px;padding:15px;background:#fff}
.sig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.page-3-sig-card{border:1px dashed #999;height:180px;position:relative;border-radius:6px;background:#fdfdfd;display:flex;flex-direction:column;justify-content:center;align-items:center;padding-top:20px}
.sig-card-header{position:absolute;top:0;right:0;left:0;background:var(--brand-orange);color:white;font-size:11px;padding:6px 0;text-align:center;font-weight:700;border-radius:5px 5px 0 0}
.footer-small{border-top:1px solid #ddd;padding-top:5px;display:flex;justify-content:space-between;font-size:9px;color:#777;margin-top:10px}

/* Auth table */
.auth-table-container{border:1px solid #ccc;border-radius:8px;overflow:hidden;background:#fff}
.auth-table{width:100%;border-collapse:collapse;font-size:11px}
.auth-table th{background:var(--brand-purple);color:white;padding:10px;border:1px solid #fff;text-align:center;font-weight:700}
.auth-table td{border:1px solid #ddd;padding:10px;vertical-align:top}
.permission-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:10px}
.perm-item{display:flex;align-items:center;gap:6px}
.legal-note{font-size:11px;color:#d3161d;font-weight:700;margin-top:10px;text-align:center;background:#fff0f0;padding:8px;border-radius:6px;border:1px dashed #d3161d}
.approval-section{background:var(--section-bg);border:1px solid #ddd;border-radius:8px;padding:20px}
.approval-text{font-size:12px;margin-bottom:15px;text-align:justify;line-height:1.6;color:#333}
.approval-grid{display:flex;justify-content:space-between;align-items:flex-end;margin-top:15px;gap:20px}
.field-line{display:flex;flex-direction:column;gap:8px;flex:1}
.line{border-bottom:1px solid #999;height:30px;display:flex;align-items:flex-end;padding-bottom:2px;font-weight:700;font-size:12px}
.lbl{font-size:11px;font-weight:700;color:#555}
.employee-auth{background:#eee;padding:15px;border-radius:8px;display:flex;justify-content:space-between;align-items:flex-end;border:1px solid #ccc}
.admin-decision{border:2px solid var(--brand-orange);border-radius:10px;padding:20px;background:#fffcf5;margin-top:auto}
.admin-title{text-align:center;font-size:16px;font-weight:900;color:var(--brand-purple);margin-bottom:20px;text-decoration:underline}
.admin-grid{display:flex;justify-content:space-between;align-items:flex-end;padding:0 30px}
.stamp-box{width:120px;height:120px;border:2px dashed var(--brand-orange);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:12px;font-weight:700;background:white;text-align:center}

/* PDF Page 3 layout helpers */
.compact-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.page-3-wrapper{gap:10px;padding:8mm 12mm!important}

/* ID photos page (Page 5) */
.photos-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px}
.photo-frame{border:2px solid #ddd;border-radius:12px;padding:10px;text-align:center;background:#fafafa}
.photo-frame img{width:100%;max-height:300px;object-fit:contain;border-radius:8px}
.photo-frame-label{font-size:14px;font-weight:800;color:var(--brand-purple);margin-top:10px}

/* Admin notes */
.admin-notes-box{background:#fffbeb;border:1px solid #fef3c7;border-radius:8px;padding:12px;margin-top:10px}
.admin-notes-box textarea{width:100%;border:1px solid #e2e8f0;border-radius:8px;padding:8px;font-size:13px;resize:vertical;min-height:60px;background:white}

/* === Responsive === */
@media (max-width: 768px) {
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .filter-bar{flex-direction:column}
  .filter-bar input,.filter-bar select{width:100%}
  .fields-grid{grid-template-columns:repeat(6,1fr)}
  .sig-grid{grid-template-columns:1fr 1fr}
  .admin-grid{flex-direction:column;gap:20px;align-items:center}
  .approval-grid{flex-direction:column}
  .tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .tab{white-space:nowrap;flex-shrink:0}
  .progress-steps{overflow-x:auto}
  .photos-page-grid{grid-template-columns:1fr}
}

/* PDF output specific - no gaps between pages */
#pdf-output .page-a4{margin-bottom:0!important;box-shadow:none!important}
#pdf-output{background:white!important}

