/* public_legal_form.css — Amal Portal Legal Form v4 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1B2D4F;--navy-dark:#0F1D34;--navy-mid:#24426b;
  --teal:#0B7A6E;--teal-light:#0EA38F;--teal-bg:#E8F6F4;
  --bg:#F2F4F7;--white:#FFFFFF;--border:#D4D9E2;--border-light:#E8ECF1;
  --text:#1A2332;--text-mid:#3D4F6A;--text-muted:#6B7A96;--text-light:#9AA5BC;
  --red:#C0392B;--red-bg:#FDECEA;--amber:#B45309;--amber-bg:#FEF3C7;
  --green:#0B7A6E;--green-bg:#E8F6F4;--locked-bg:#F7F8FA;
  --input-h:42px;--radius:8px;--radius-sm:5px;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.08);
  /* Custom date picker (template_2 CDP) */
  --primary:var(--navy-mid);--primary2:var(--navy);--muted:var(--text-light);--line:var(--border);
  --infobg:#EEF2F7;--focus:rgba(36,66,107,.22);--danger:var(--red);--dangerbg:var(--red-bg);
}
html{scroll-behavior:smooth;font-size:15px;overflow-x:clip}
body{font-family:'Tajawal',sans-serif;background:var(--bg);color:var(--text);direction:rtl;min-height:100vh;overflow-x:clip}

/* TOP BAR */
.topbar{background:var(--navy-dark);height:40px;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:100}
.topbar-inner{max-width:1280px;width:100%;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.topbar-left{display:flex;align-items:center;gap:16px}
.topbar-email{color:rgba(255,255,255,.5);font-size:.72rem;font-family:'Inter',sans-serif;letter-spacing:.4px}
.topbar-sep{width:1px;height:14px;background:rgba(255,255,255,.15)}
.topbar-ref{color:rgba(255,255,255,.38);font-size:.68rem;font-family:'Inter',sans-serif;letter-spacing:.3px}
.topbar-lang{display:flex;gap:4px}
.lang-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.55);padding:2px 9px;border-radius:3px;font-size:.68rem;cursor:pointer;font-family:'Inter',sans-serif;letter-spacing:.5px;transition:.2s}
.lang-btn.active,.lang-btn:hover{border-color:rgba(255,255,255,.45);color:rgba(255,255,255,.9)}

/* PAGE HEADER */
.page-header-wrap{background:var(--white);border-bottom:1px solid var(--border)}
.page-header-accent{height:4px;background:linear-gradient(90deg,var(--navy) 0%,var(--navy-mid) 55%,var(--teal) 100%)}
.page-header-inner{max-width:1280px;margin:0 auto;padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;overflow:hidden}
.page-header-brand{display:flex;align-items:center;gap:18px;min-width:0;flex:1}
.gov-logo{border:1px solid #dde8f4;border-radius:12px;width:90px;height:90px;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#fff 60%,#f4f8ff);overflow:hidden;padding:8px;flex-shrink:0}
.gov-logo img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
.brand-divider{width:1px;height:90px;background:var(--border);align-self:center;flex-shrink:0}
.brand-title h1{font-size:1.15rem;font-weight:800;color:var(--navy);line-height:1.35;margin-bottom:4px}
.brand-title .subtitle-ar{font-size:.8rem;color:var(--text-muted);font-weight:400;margin-bottom:3px}
.brand-title .subtitle-en{font-family:'Inter',sans-serif;font-size:.68rem;color:var(--text-light);letter-spacing:.3px}
.page-header-meta{display:flex;flex-direction:column;gap:5px;align-items:flex-end;flex-shrink:0;min-width:0}
.meta-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--border);border-radius:3px;font-family:'Inter',sans-serif;font-size:.68rem;background:var(--bg)}
.meta-pill .mp-label{color:var(--text-light);font-size:.62rem}
.meta-pill .mp-val{color:var(--navy);font-weight:700;letter-spacing:.3px}
.meta-pill .mp-dot{width:5px;height:5px;border-radius:50%;background:var(--border);flex-shrink:0}
.meta-pill.status-pending .mp-dot{background:var(--amber)}.meta-pill.status-pending .mp-val{color:var(--amber)}
.meta-pill.status-active .mp-dot{background:#16A34A}.meta-pill.status-active .mp-val{color:#16A34A}
.meta-pill.status-locked .mp-dot{background:var(--red)}.meta-pill.status-locked .mp-val{color:var(--red)}

/* BREADCRUMB */
.breadcrumb-wrap{background:var(--white);border-bottom:1px solid var(--border-light)}
.breadcrumb{max-width:1280px;margin:0 auto;padding:9px 24px;display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-muted)}
.breadcrumb a{color:var(--text-light);text-decoration:none;transition:.15s}
.breadcrumb a:hover{color:var(--navy)}
.breadcrumb .bc-sep{color:var(--border);font-size:.8rem;font-family:'Inter',sans-serif}
.breadcrumb .active{color:var(--text-mid);font-weight:500}

/* PAGE SECTION WRAPPER */
.page-section-wrap{max-width:1280px;margin:0 auto;padding-left:24px;padding-right:24px}

/* INFO CARDS */
.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.info-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}
.info-cards{font-family:'Tajawal',sans-serif}
.ic-label{font-size:.68rem;color:var(--text-light);margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}
.ic-val{font-size:.88rem;font-weight:700;color:var(--navy)}
.ic-sub{font-size:.67rem;color:var(--text-muted);margin-top:2px}

/* STATUS BAR (optional) */
.status-bar{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 18px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;box-shadow:var(--shadow);overflow:hidden}
.status-item{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--text-mid);min-width:0}
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.status-dot.green{background:#16A34A}.status-dot.amber{background:#D97706}.status-dot.navy{background:var(--navy)}
.status-sep{width:1px;height:20px;background:var(--border-light)}

/* LAYOUT */
.page-body{display:flex;gap:24px;max-width:1280px;margin:0 auto;padding:24px 24px 60px;align-items:flex-start}
.main-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:20px}
.sidebar{width:260px;flex-shrink:0;position:sticky;top:80px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 56px);overflow-y:auto}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}

/* SIDEBAR CARD */
.sidebar-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);flex-shrink:0}
.sidebar-head{background:var(--navy);color:#fff;padding:14px 16px}
.sidebar-head h3{font-size:.9rem;font-weight:700}
.sidebar-head p{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:2px;font-family:'Inter',sans-serif}
.progress-wrap{padding:12px 16px;border-bottom:1px solid var(--border-light)}
.progress-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.75rem}
.progress-label{color:var(--text-muted)}
.progress-pct{color:var(--navy);font-weight:700;font-family:'Inter',sans-serif}
.progress-bar{height:5px;background:var(--border);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:var(--teal);border-radius:99px;transition:width .4s ease;width:0%}
.nav-sections{padding:8px 0}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;transition:.15s;text-decoration:none;color:inherit;border-right:3px solid transparent}
.nav-item:hover{background:var(--bg)}
.nav-item.active{background:var(--teal-bg);border-right-color:var(--teal)}
.nav-item.done{border-right-color:var(--border-light)}
.nav-num{width:28px;height:28px;border-radius:50%;background:var(--border-light);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;font-family:'Inter',sans-serif;color:var(--text-muted);flex-shrink:0;transition:.15s}
.nav-item.active .nav-num{background:var(--teal);color:#fff}
.nav-item.done .nav-num{background:var(--navy-mid);color:#fff}
.nav-label{font-size:.8rem;color:var(--text-mid);font-weight:500;line-height:1.3}
.nav-label small{display:block;font-size:.68rem;color:var(--text-light);font-weight:400;font-family:'Inter',sans-serif;margin-top:1px}
.nav-item.active .nav-label{color:var(--teal);font-weight:600}
.nav-item.done .nav-label{color:var(--navy)}

/* SAVE CARD */
.save-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;box-shadow:var(--shadow);font-size:.75rem;flex-shrink:0}
.save-card__row{display:flex;align-items:center;gap:7px;color:var(--text-mid);margin-bottom:5px}
.save-card__time{color:var(--text-light);font-family:'Inter',sans-serif;font-size:.67rem}
.save-card__enc{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light);font-size:.7rem;color:var(--text-muted)}

/* SECTION CARDS — overflow:visible حتى لا تُقصّ قوائم searchable-select المنسدلة داخل البطاقة */
.section-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:visible;scroll-margin-top:60px}
.card-header{padding:16px 22px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.card-header-left{display:flex;align-items:center;gap:12px}
.card-num{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;font-family:'Inter',sans-serif;flex-shrink:0}
.card-title h2{font-size:1rem;font-weight:700;color:var(--navy)}
.card-title p{font-size:.75rem;color:var(--text-muted);font-family:'Inter',sans-serif;margin-top:1px}
.card-badge{font-size:.7rem;padding:3px 10px;border-radius:99px;font-weight:600;border:1px solid}
.badge-locked{background:#F1F3F6;color:var(--text-muted);border-color:var(--border)}
.badge-required{background:var(--teal-bg);color:var(--teal);border-color:#A7D8D3}
.badge-optional{background:#F5F5F5;color:var(--text-muted);border-color:var(--border)}
.badge-sensitive{background:#FFF0F0;color:var(--red);border-color:#FDA4A4}
.card-body{padding:22px;overflow:visible}

/* LOCKED NOTICE */
.locked-notice{border-radius:var(--radius-sm);padding:11px 14px;margin-bottom:18px}
.locked-notice p{font-size:.78rem;line-height:1.7;margin:0}
.locked-notice.amber{background:var(--amber-bg);border:1px solid #FCD34D;border-right:3px solid #D97706}
.locked-notice.amber p{color:#92400E}
.locked-notice.red{background:var(--red-bg);border:1px solid #FDA4A4;border-right:3px solid var(--red)}
.locked-notice.red p{color:#7F1D1D}
.locked-notice.blue{background:#F0F4FF;border:1px solid #BFCFFF;border-right:3px solid #4F6FD6}
.locked-notice.blue p{color:#1E3A8A}
.locked-notice.teal{background:var(--teal-bg);border:1px solid #A7D8D3;border-right:3px solid var(--teal)}
.locked-notice.teal p{color:#064E3B}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}
.span-2{grid-column:span 2}.span-3{grid-column:span 3}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{font-size:.8rem;font-weight:600;color:var(--text-mid)}
.form-label .req{color:var(--red);margin-right:2px}
.form-label .en{font-family:'Inter',sans-serif;font-size:.7rem;font-weight:400;color:var(--text-light);margin-right:4px}
.form-label>.req+.en{font-family:inherit}
.form-input,.form-select,.form-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:'Tajawal',sans-serif;font-size:.85rem;color:var(--text);background:var(--white);transition:.2s;direction:rtl}
.form-input{height:var(--input-h);padding:0 12px}
.form-select{height:var(--input-h);padding:0 12px;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7A96' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 12px center}
.form-textarea{padding:10px 12px;resize:vertical;min-height:100px;line-height:1.65}
/* حالات الحقول: أزرق عند التركيز، أخضر صالح، أحمر خطأ */
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none}
.form-input:focus:not(.lf-field--invalid),.form-select:focus:not(.lf-field--invalid),.form-textarea:focus:not(.lf-field--invalid){
  border-color:#2563EB;box-shadow:0 0 0 3px rgba(37,99,235,.14)
}
.form-input.lf-field--valid:not(:focus),.form-select.lf-field--valid:not(:focus),.form-textarea.lf-field--valid:not(:focus){
  border-color:#16A34A;box-shadow:0 0 0 3px rgba(22,163,74,.12)
}
.form-input.lf-field--invalid,.form-select.lf-field--invalid,.form-textarea.lf-field--invalid,
.form-input.error,.form-textarea.error,.form-select.error{
  border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(192,57,43,.12)!important
}
.form-input[readonly],.form-textarea[readonly]{background:var(--locked-bg);color:var(--text-mid);cursor:default;border-color:var(--border-light)}
.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--locked-bg);color:var(--text-mid);cursor:not-allowed;border-color:var(--border-light)}
.cdp-trigger .form-input:focus:not(.lf-field--invalid){border-color:#2563EB;box-shadow:0 0 0 3px rgba(37,99,235,.14)}
.cdp-trigger .form-input.lf-field--valid:not(:focus){border-color:#16A34A;box-shadow:0 0 0 3px rgba(22,163,74,.12)}
.lf-inline-msg{display:block;min-height:1.2em;font-size:.72rem;line-height:1.45;margin-top:4px;transition:color .15s}
.lf-inline-msg--err{color:var(--red);font-weight:600}
.lf-inline-msg--ok{color:#15803D;font-weight:500}
.form-hint{font-size:.72rem;color:var(--text-light);margin-top:2px}
.form-hint-below-label{display:block;margin-top:2px;margin-bottom:8px;line-height:1.5}
.form-hint.error{color:var(--red)}
.form-hint-charcount{display:block;margin-top:4px}
.form-hint-charcount.warn strong{color:var(--amber)}
.form-hint-charcount.ok strong{color:var(--teal)}

/* LOCKED FIELD */
.locked-field{background:var(--locked-bg);border:1px dashed var(--border);border-radius:var(--radius-sm);height:var(--input-h);padding:0 11px;display:flex;align-items:center;cursor:not-allowed}
.field-val{font-size:.85rem;color:var(--text-mid);font-weight:500;flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0}
.field-val.empty{color:var(--text-light);font-style:italic;font-weight:400}

/* TABLE */
.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
.data-table{width:100%;border-collapse:collapse;font-size:.8rem}
.data-table thead tr{background:var(--navy)}
.data-table thead th{color:#fff;padding:10px 12px;text-align:right;font-weight:600;font-size:.75rem;white-space:nowrap}
.data-table tbody tr{border-bottom:1px solid var(--border-light);transition:.12s}
.data-table tbody tr:hover{background:var(--bg)}
.data-table td{padding:9px 12px;color:var(--text-mid);vertical-align:middle}
.row-num{color:var(--text-light);font-family:'Inter',sans-serif;font-weight:600;font-size:.7rem}
.gender-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.68rem;font-weight:600}
.gender-badge.m{background:#EFF6FF;color:#1D4ED8}.gender-badge.f{background:#FDF2F8;color:#9D174D}
.doc-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:.68rem;font-weight:600;background:#F1F3F6;color:var(--text-muted);font-family:'Inter',sans-serif}
.rel-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.68rem;background:var(--teal-bg);color:var(--teal);font-weight:600}

/* CHIPS */
.chips-container{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--locked-bg)}
.chips-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:12px}
.chip{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:99px;border:1.5px solid var(--border);cursor:pointer;font-size:.78rem;color:var(--text-mid);background:var(--white);transition:.2s;user-select:none}
.chip:hover{border-color:var(--teal-light);color:var(--teal)}
.chip.selected{background:var(--teal-bg);border-color:var(--teal);color:var(--teal);font-weight:600}
.chip.selected::before{content:"✓ ";font-size:.68rem}
.chip input{display:none}

/* YES / NO */
.yn-group{display:flex;gap:10px}
.yn-btn{flex:1;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px;text-align:center;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--text-muted);transition:.2s;user-select:none;max-width:160px}
.yn-btn:hover{border-color:var(--navy);color:var(--navy)}
.yn-btn.selected.yes{background:var(--teal-bg);border-color:var(--teal);color:var(--teal)}
.yn-btn.selected.no{background:#FFF0F0;border-color:#FDA4A4;color:var(--red)}
.yn-btn.selected.na{background:var(--amber-bg);border-color:#FCD34D;color:var(--amber)}
.yn-btn input{display:none}

/* UPLOAD ZONES */
.upload-section-title{font-size:.82rem;font-weight:700;color:var(--navy);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;cursor:pointer;transition:.2s;background:var(--bg)}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--teal);background:var(--teal-bg)}
.upload-zone h4{font-size:.88rem;font-weight:700;color:var(--text-mid);margin-bottom:4px}
.upload-zone p{font-size:.75rem;color:var(--text-light);line-height:1.6}
.upload-zone .choose-btn{display:inline-block;margin-top:10px;padding:6px 18px;background:var(--navy);color:#fff;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;transition:.2s}
.upload-zone:hover .choose-btn{background:var(--teal)}
.file-cards{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.file-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;align-items:center;gap:10px}
.file-icon{width:34px;height:34px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;font-family:'Inter',sans-serif;flex-shrink:0}
.file-icon.pdf{background:#FDECEA;color:var(--red)}.file-icon.img{background:#EFF6FF;color:#1D4ED8}.file-icon.vid{background:#F5F3FF;color:#6D28D9}
.file-info{flex:1;min-width:0}
.file-name{font-size:.8rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-meta{font-size:.7rem;color:var(--text-light);font-family:'Inter',sans-serif;margin-top:2px}
.file-progress{height:3px;background:var(--border-light);border-radius:99px;overflow:hidden;margin-top:5px}
.file-progress-bar{height:100%;background:var(--teal);width:0%}
.file-del{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:.9rem;padding:4px;border-radius:3px;transition:.15s}
.file-del:hover{color:var(--red);background:var(--red-bg)}

/* CHECKLIST */
.checklist-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.check-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:.15s}
.check-item:hover{border-color:var(--teal);background:var(--teal-bg)}
.check-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--teal);cursor:pointer;flex-shrink:0}
.check-item label{font-size:.78rem;color:var(--text-mid);cursor:pointer;font-weight:500}

/* WITNESSES */
.witness-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:14px}
.witness-header{background:var(--navy);padding:12px 18px;display:flex;align-items:center;justify-content:space-between}
.witness-header h3{color:#fff;font-size:.88rem;font-weight:600}
.witness-num{background:rgba(255,255,255,.15);color:#fff;font-family:'Inter',sans-serif;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:99px}
.witness-body{padding:18px}
.witness-del{background:var(--red);border:1px solid rgba(0,0,0,.12);color:#fff;padding:4px 12px;border-radius:4px;font-size:.72rem;font-weight:600;cursor:pointer;transition:.2s;font-family:'Tajawal',sans-serif;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.witness-del:hover{background:#A93226;color:#fff;border-color:rgba(0,0,0,.15)}
.witness-del:focus-visible{outline:2px solid #fff;outline-offset:2px}
.add-witness-btn{display:flex;align-items:center;gap:8px;width:100%;padding:13px 18px;background:var(--bg);border:1.5px dashed var(--border);border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:600;color:var(--navy);transition:.2s;justify-content:center;font-family:'Tajawal',sans-serif}
.add-witness-btn:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}

/* DECLARATION */
.legal-text-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 18px;font-size:.8rem;line-height:1.9;color:var(--text-mid);margin-bottom:18px}
.legal-text-box h4{font-size:.85rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.declaration-checks{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.decl-check{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);transition:.15s;cursor:pointer}
.decl-check:hover{border-color:var(--navy)}
.decl-check.checked{background:var(--green-bg);border-color:var(--teal)}
.decl-check input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--teal);cursor:pointer;flex-shrink:0}
.decl-check label{font-size:.79rem;line-height:1.7;color:var(--text-mid);cursor:pointer}

/* SIGNATURE */
.sig-canvas-wrap{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--white);position:relative}
.sig-canvas{width:100%;height:160px;cursor:crosshair;display:block;touch-action:none}
.sig-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:.8rem;color:var(--text-light)}
.sig-actions{display:flex;justify-content:flex-end;margin-top:6px}
.sig-clear{background:none;border:1px solid var(--border);padding:5px 14px;border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-muted);cursor:pointer;font-family:'Tajawal',sans-serif;transition:.2s}
.sig-clear:hover{border-color:var(--red);color:var(--red)}
.sig-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:99px;font-size:.72rem;font-weight:600;border:1px solid}
.sig-badge.pending{background:var(--amber-bg);color:var(--amber);border-color:#FCD34D}
.sig-badge.done{background:var(--green-bg);color:var(--teal);border-color:#A7D8D3}

/* ERROR BANNER + FIELD ERRORS */
.lf-error-banner{display:none;max-width:1280px;margin:0 auto;padding:12px 24px 0}
.lf-error-banner__inner{
  display:flex;align-items:flex-start;gap:14px;
  background:linear-gradient(165deg,#FADBD8 0%,#FCE4E1 45%,#FBE9E7 100%);
  border:1px solid rgba(192,57,43,.42);
  border-radius:var(--radius);
  box-shadow:0 2px 10px rgba(192,57,43,.14);
  padding:14px 16px;
  border-inline-end:4px solid var(--red);
}
.lf-error-banner__icon{
  flex-shrink:0;width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.65);color:var(--red);
  border:1px solid rgba(192,57,43,.25);
  display:flex;align-items:center;justify-content:center;
}
.lf-error-banner__content{flex:1;min-width:0}
.lf-error-banner__title{display:block;font-size:.82rem;font-weight:700;color:#7F1D1D;line-height:1.45;margin-bottom:8px}
.lf-error-banner__list{margin:0;padding:0 18px 0 0;font-size:.78rem;font-weight:500;color:#5C2B26;line-height:1.65}
.lf-error-banner__list li{margin-bottom:4px}
.lf-error-banner__list li:last-child{margin-bottom:0}

.chips-container.lf-field-error,
.form-group.lf-field-error,
.declaration-checks.lf-field-error,
.sig-canvas-wrap.lf-field-error{
  border:1px solid rgba(192,57,43,.55)!important;
  border-radius:var(--radius-sm);
  box-shadow:0 0 0 3px rgba(192,57,43,.08);
}
.chips-container.lf-field-error{padding:10px 12px}
.form-group.lf-field-error{padding:10px 12px}
.declaration-checks.lf-field-error{padding:10px 12px}

/* BOTTOM BAR */
.bottom-bar{background:var(--white);border-top:1px solid var(--border);padding:0 28px;position:sticky;bottom:0;z-index:90;box-shadow:0 -2px 8px rgba(0,0,0,.05)}
.bottom-bar-inner{max-width:1280px;margin:0 auto;padding:14px 0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.bottom-bar-right{display:flex;align-items:center;gap:10px}
.bottom-bar-left{display:flex;align-items:center;gap:10px}
.bottom-bar-status{font-size:.74rem;color:var(--text-muted);font-family:'Inter',sans-serif;text-align:center}

/* BUTTONS */
.btn{padding:9px 20px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;border:1.5px solid;font-family:'Tajawal',sans-serif;transition:.2s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-primary:hover{background:var(--navy-mid);border-color:var(--navy-mid)}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-teal:hover{background:var(--teal-light);border-color:var(--teal-light)}
.btn-outline{background:var(--white);color:var(--text-mid);border-color:var(--border)}
.btn-outline:hover{border-color:var(--navy);color:var(--navy)}
.btn-ghost{background:none;color:var(--text-muted);border-color:transparent;font-weight:500}
.btn-ghost:hover{color:var(--navy);background:var(--bg)}

/* SITE FOOTER */
.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.55);padding:28px 24px 20px}
.footer-inner{max-width:1280px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.footer-brand h4{color:#fff;font-size:.88rem;font-weight:700;margin-bottom:4px}
.footer-brand p{font-size:.7rem;color:rgba(255,255,255,.4);font-family:'Inter',sans-serif;line-height:1.65}
.footer-links{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.footer-link{color:rgba(255,255,255,.45);font-size:.72rem;text-decoration:none;padding:4px 10px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);transition:.15s;font-family:'Inter',sans-serif}
.footer-link:hover{color:#fff;border-color:rgba(255,255,255,.3)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:14px;font-size:.67rem;font-family:'Inter',sans-serif;flex-wrap:wrap;gap:8px}
.footer-bottom span{color:rgba(255,255,255,.3)}

/* TOAST */
#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:10px 22px;border-radius:var(--radius);font-size:.82rem;opacity:0;transition:.3s;z-index:999;pointer-events:none;white-space:nowrap;box-shadow:0 8px 20px rgba(0,0,0,.16)}

/* RESPONSIVE */
@media(max-width:1024px){
  .page-body{flex-direction:column}
  .sidebar{display:none!important}
  .info-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  /* لا نستخدم overflow:hidden هنا حتى لا تُقصّ القوائم المنسدلة أسفل البطاقة */
  .page-body{padding:12px 10px 60px;max-width:100%;overflow:visible}
  .main-content{min-width:0;max-width:100%}
  .form-grid,.form-grid.cols-3{grid-template-columns:1fr}
  .span-2,.span-3{grid-column:span 1}
  .checklist-grid{grid-template-columns:1fr}
  .info-cards{grid-template-columns:1fr 1fr}
  .page-section-wrap{padding-left:10px;padding-right:10px}
  .lf-error-banner{padding:10px 12px 0}
  .lf-error-banner__inner{flex-direction:column;align-items:stretch}
  .lf-error-banner__icon{align-self:flex-start}
  .section-card{max-width:100%;overflow:visible}
  .card-body{overflow:visible}
  .topbar-inner{padding:0 12px}
  .topbar-ref,.topbar-sep{display:none}
  .page-header-inner{flex-direction:column;gap:10px;padding:12px 14px 14px;overflow:hidden}
  .page-header-brand{gap:10px;min-width:0;flex:1;width:100%}
  .brand-title{min-width:0;flex:1}
  .gov-logo{width:76px;height:76px;padding:6px;border-radius:10px}
  .gov-logo img{max-width:100%;max-height:100%}
  .brand-divider{height:76px}
  .brand-title h1{font-size:.92rem;white-space:normal}
  .brand-title .subtitle-en{display:none}
  .page-header-meta{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:4px;width:100%;max-width:100%}
  .meta-pill{flex-shrink:1;min-width:0;padding:3px 8px;font-size:.62rem}
  .breadcrumb{padding:7px 14px;font-size:.7rem}
  .card-header{padding:12px 14px}
  .card-body{padding:14px}
  .card-title h2{font-size:.92rem}
  .nav-sections{display:grid;grid-template-columns:repeat(2,1fr)}
  .bottom-bar{padding:0 12px}
  .bottom-bar-inner{flex-wrap:nowrap;padding:10px 0;gap:8px;justify-content:space-between}
  .bottom-bar-status{display:none}
  .bottom-bar-right{gap:5px}
  .btn{padding:7px 11px;font-size:.76rem}
  .locked-field{min-width:0;overflow:hidden}
  .field-val{min-width:0}
  .table-wrap{max-width:calc(100vw - 40px)}
  .chips-wrap{gap:6px;padding:10px}
  .chip{font-size:.74rem;padding:5px 10px}
  .witness-body{padding:14px}
  .footer-top{flex-direction:column;gap:16px}
  .site-footer{padding:20px 14px 16px}
}
/* ═══════════════════════════════════════════
   Custom Modern Date Picker
═══════════════════════════════════════════ */
.cdp-trigger{
  position:relative;
  cursor:pointer;
  user-select:none;
}
.cdp-trigger .cdp-icon{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  color:var(--muted);
  pointer-events:none;
  transition:.2s;
}
/* RTL: icon RIGHT, text LEFT */
[dir="rtl"] .cdp-trigger .cdp-icon,
.cdp-trigger .cdp-icon{ right:14px; left:auto; }
[dir="rtl"] .cdp-trigger input.form-input{
  text-align:left !important;
  direction:ltr !important;
  padding-right:40px !important;
  padding-left:12px !important;
}
/* LTR: icon LEFT, text RIGHT */
[dir="ltr"] .cdp-trigger .cdp-icon{ left:14px; right:auto; }
[dir="ltr"] .cdp-trigger input.form-input{
  text-align:right !important;
  direction:ltr !important;
  padding-left:40px !important;
  padding-right:12px !important;
}
.cdp-trigger:hover .cdp-icon{ color:var(--primary); }

.cdp-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(0,0,0,.35);
  backdrop-filter:blur(4px);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity .25s, visibility .25s;
}
.cdp-overlay.open{
  opacity:1;
  visibility:visible;
}
.cdp-modal{
  background:#fff;
  border-radius:20px;
  width:min(380px, 92vw);
  box-shadow:0 25px 60px rgba(0,0,0,.18);
  overflow:hidden;
  transform:translateY(20px) scale(.96);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  direction:ltr;
  text-align:left;
}
[dir="rtl"] .cdp-modal{
  direction:rtl;
  text-align:right;
}
.cdp-overlay.open .cdp-modal{
  transform:translateY(0) scale(1);
}

/* Header */
.cdp-header{
  background:var(--primary);
  color:#fff;
  padding:20px 22px 16px;
  text-align:center;
}
.cdp-header-display{
  font-size:13px;
  opacity:.7;
  margin-bottom:6px;
  font-weight:500;
}
.cdp-header-date{
  font-size:22px;
  font-weight:700;
  letter-spacing:.5px;
}

/* Navigation */
.cdp-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 18px 8px;
  gap:8px;
}
.cdp-nav-btn{
  width:36px;
  height:36px;
  border:none;
  border-radius:50%;
  background:transparent;
  cursor:pointer;
  display:grid;
  place-items:center;
  color:var(--text);
  transition:.15s;
}
.cdp-nav-btn:hover{
  background:var(--infobg);
  color:var(--primary);
}
/* Flip prev/next arrows in RTL */
[dir="rtl"] .cdp-nav-btn svg{
  transform:scaleX(-1);
}
.cdp-nav-title{
  display:flex;
  align-items:center;
  gap:6px;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  padding:6px 14px;
  border-radius:10px;
  transition:.15s;
  border:none;
  background:transparent;
  color:var(--text);
}
.cdp-nav-title:hover{
  background:var(--infobg);
  color:var(--primary);
}
.cdp-nav-title svg{
  transition:transform .2s;
}
.cdp-nav-title.expanded svg{
  transform:rotate(180deg);
}

/* Weekday header */
.cdp-weekdays{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  padding:4px 14px;
  gap:2px;
}
.cdp-weekday{
  text-align:center;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  padding:6px 0;
}

/* Days grid */
.cdp-days{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  padding:2px 14px 14px;
  gap:2px;
}
.cdp-day{
  width:100%;
  aspect-ratio:1;
  border:none;
  border-radius:50%;
  background:transparent;
  cursor:pointer;
  font-size:14px;
  font-weight:600;
  color:var(--text);
  transition:.15s;
  display:grid;
  place-items:center;
  position:relative;
}
.cdp-day:hover:not(.cdp-day-empty):not(.cdp-day-selected){
  background:var(--infobg);
  color:var(--primary);
}
.cdp-day.cdp-day-today:not(.cdp-day-selected){
  color:var(--primary);
  font-weight:800;
}
.cdp-day.cdp-day-today:not(.cdp-day-selected)::after{
  content:'';
  position:absolute;
  bottom:4px;
  left:50%;
  transform:translateX(-50%);
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--primary);
}
.cdp-day.cdp-day-selected{
  background:var(--primary) !important;
  color:#fff !important;
  font-weight:700;
  box-shadow:0 4px 12px rgba(11,74,162,.3);
}
.cdp-day.cdp-day-empty{
  cursor:default;
}
.cdp-day.cdp-day-outside{
  color:#ccc;
}

/* Month/Year selector panel */
.cdp-selector{
  padding:10px 14px 14px;
  display:none;
}
.cdp-selector.visible{
  display:block;
}
.cdp-selector-label{
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  margin-bottom:8px;
  padding:0 4px;
}
.cdp-months-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:6px;
  margin-bottom:14px;
}
.cdp-month-btn{
  padding:8px 4px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  font-size:13px;
  font-weight:600;
  color:var(--text);
  transition:.15s;
  text-align:center;
}
.cdp-month-btn:hover{
  border-color:var(--primary);
  background:var(--infobg);
  color:var(--primary);
}
.cdp-month-btn.active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}

.cdp-year-row{
  display:flex;
  align-items:center;
  gap:6px;
}
.cdp-year-input{
  flex:1;
  height:40px;
  border:1px solid var(--line);
  border-radius:10px;
  text-align:center;
  font-size:16px;
  font-weight:700;
  color:var(--text);
  outline:none;
  transition:.15s;
  -moz-appearance: textfield;
}
.cdp-year-input::-webkit-inner-spin-button,
.cdp-year-input::-webkit-outer-spin-button{
  -webkit-appearance:none;
  margin:0;
}
.cdp-year-input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--focus);
}
.cdp-year-btn{
  width:40px;
  height:40px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  color:var(--text);
  transition:.15s;
  flex-shrink:0;
}
.cdp-year-btn:hover{
  border-color:var(--primary);
  background:var(--infobg);
  color:var(--primary);
}

/* Footer */
.cdp-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0 18px 16px;
  gap:8px;
}
.cdp-footer-btn{
  padding:9px 20px;
  border-radius:10px;
  border:none;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  transition:.15s;
}
.cdp-btn-clear{
  background:transparent;
  color:var(--muted);
}
.cdp-btn-clear:hover{
  background:var(--dangerbg);
  color:var(--danger);
}
.cdp-btn-today{
  background:var(--infobg);
  color:var(--primary);
}
.cdp-btn-today:hover{
  background:#dce9ff;
}
.cdp-btn-confirm{
  background:var(--primary);
  color:#fff;
  min-width:90px;
}
.cdp-btn-confirm:hover{
  background:var(--primary2);
}

/* Animations */
.cdp-days{
  animation: cdpFadeIn .2s ease;
}
@keyframes cdpFadeIn{
  from{opacity:0; transform:translateY(4px);}
  to{opacity:1; transform:translateY(0);}
}

/* CDP: readonly date fields stay white (not default locked-field gray) */
[dir="rtl"] .cdp-trigger input.form-input[readonly]:not(:disabled),
.cdp-trigger .form-input[readonly]:not(:disabled){
  background:var(--white)!important;
  color:var(--text);
  cursor:pointer;
  border-color:var(--border);
}
.cdp-trigger .form-input[readonly]:disabled{
  background:var(--locked-bg)!important;
  cursor:not-allowed;
  opacity:.9;
}

@media print{
  .topbar,.breadcrumb-wrap,.sidebar,.bottom-bar,.page-header-wrap,.status-bar,.info-cards,.site-footer,#errorBox{display:none!important}
  .main-content{width:100%}
}
