/* ============================================================
   QR Library — UI CSS Library  v1.0
   Powered by DuckDeals.sa
   Load Figtree + JetBrains Mono + Material Symbols, then this file.
   All classes are namespaced with .ql-
   ============================================================ */

/* ---------- 1. Design tokens ---------- */
:root{
  /* Brand */
  --ql-navy:#041a2e;       /* deepest sections   */
  --ql-night:#07263f;      /* dark sections      */
  --ql-blue:#0b74c4;       /* primary            */
  --ql-deep:#0959a8;       /* primary gradient   */
  --ql-cyan:#1fb8d4;       /* accent             */
  /* Neutrals */
  --ql-ink:#08263f;        /* primary text       */
  --ql-slate:#5a7488;      /* muted text         */
  --ql-faint:#92a8ba;      /* placeholder/hint   */
  --ql-foam:#e4f1fb;       /* tonal fill         */
  --ql-mist:#f4f9fd;       /* page / field bg    */
  --ql-line:#e1edf6;       /* borders            */
  --ql-line-2:#d4e3ef;     /* input borders      */
  --ql-white:#ffffff;
  /* System */
  --ql-success:#0b8a5f; --ql-success-bg:#eafaf2; --ql-success-line:#bfe9d4;
  --ql-danger:#c0392b;  --ql-danger-bg:#fdecec;  --ql-danger-line:#f3c8c8;
  --ql-warn:#b9770a;    --ql-warn-bg:#fdf4e3;    --ql-warn-line:#f0dcb0;
  --ql-info:#0959a8;    --ql-info-bg:#e4f1fb;    --ql-info-line:#c5e0f4;
  /* Gradients */
  --ql-grad:linear-gradient(140deg,#0b74c4,#0959a8);
  --ql-grad-brand:linear-gradient(140deg,#0b74c4,#1fb8d4);
  --ql-grad-dark:linear-gradient(155deg,#07263f,#0b74c4);
  /* Radii */
  --ql-r-sm:8px; --ql-r:11px; --ql-r-md:14px; --ql-r-lg:18px; --ql-r-pill:999px;
  /* Type */
  --ql-font:'Figtree',system-ui,-apple-system,sans-serif;
  --ql-mono:'JetBrains Mono',ui-monospace,monospace;
  /* Elevation */
  --ql-shadow-sm:0 1px 3px rgba(8,55,95,.10);
  --ql-shadow:0 10px 22px -8px rgba(11,116,196,.45);
  --ql-shadow-card:0 24px 50px -34px rgba(8,55,95,.30);
  --ql-shadow-pop:0 16px 40px -16px rgba(8,55,95,.35);
  /* Spacing scale */
  --ql-1:4px; --ql-2:8px; --ql-3:12px; --ql-4:16px; --ql-5:24px; --ql-6:32px; --ql-7:48px;
  /* Motion */
  --ql-ease:.2s cubic-bezier(.4,0,.2,1);
}

/* ---------- 2. Base ---------- */
.ql{font-family:var(--ql-font);color:var(--ql-ink);line-height:1.5;-webkit-font-smoothing:antialiased;}
.ql *,.ql *::before,.ql *::after{box-sizing:border-box;}
.ql-mono{font-family:var(--ql-mono);}
.ql-h1{font-size:clamp(34px,5vw,54px);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin:0;}
.ql-h2{font-size:clamp(26px,3vw,40px);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0;}
.ql-h3{font-size:18.5px;font-weight:700;margin:0;}
.ql-eyebrow{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ql-blue);}
.ql-body{font-size:16px;color:var(--ql-slate);line-height:1.65;}
.ql-muted{color:var(--ql-slate);}

/* ---------- 3. Buttons ---------- */
.ql-btn{
  font-family:var(--ql-font);font-size:15px;font-weight:700;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:var(--ql-r);border:1px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform var(--ql-ease),box-shadow var(--ql-ease),background var(--ql-ease);
  white-space:nowrap;user-select:none;
}
.ql-btn:active{transform:translateY(1px);}
.ql-btn:disabled,.ql-btn.is-disabled{opacity:.5;cursor:not-allowed;transform:none;}
.ql-btn--primary{color:#fff;background:var(--ql-grad);box-shadow:var(--ql-shadow);}
.ql-btn--primary:hover{box-shadow:0 14px 28px -8px rgba(11,116,196,.6);}
.ql-btn--secondary{color:var(--ql-ink);background:#fff;border-color:var(--ql-line-2);}
.ql-btn--secondary:hover{border-color:var(--ql-blue);}
.ql-btn--tonal{color:var(--ql-deep);background:var(--ql-foam);border-color:var(--ql-info-line);}
.ql-btn--ghost{color:var(--ql-deep);background:transparent;}
.ql-btn--ghost:hover{background:var(--ql-foam);}
.ql-btn--danger{color:#fff;background:var(--ql-danger);}
.ql-btn--sm{font-size:13px;padding:9px 15px;border-radius:var(--ql-r-sm);}
.ql-btn--lg{font-size:16px;padding:16px 28px;}
.ql-btn--block{display:flex;width:100%;}
.ql-btn--icon{padding:11px;border-radius:var(--ql-r-sm);}
.ql-btn .material-symbols-outlined{font-size:1.25em;}
.ql-btn-group{display:inline-flex;gap:8px;flex-wrap:wrap;}
.ql-btn--loading{position:relative;color:transparent !important;pointer-events:none;}
.ql-btn--loading::after{content:"";position:absolute;width:16px;height:16px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:ql-spin .7s linear infinite;}

/* ---------- 4. Forms ---------- */
.ql-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.ql-label{font-size:12.5px;font-weight:600;color:#33495c;}
.ql-label .ql-opt{color:var(--ql-faint);font-weight:500;}
.ql-input,.ql-textarea,.ql-select{
  width:100%;font-family:var(--ql-font);font-size:14.5px;color:var(--ql-ink);
  background:var(--ql-mist);border:1px solid var(--ql-line-2);border-radius:var(--ql-r);
  padding:12px 14px;transition:border-color var(--ql-ease),background var(--ql-ease),box-shadow var(--ql-ease);
}
.ql-input::placeholder,.ql-textarea::placeholder{color:var(--ql-faint);}
.ql-input:focus,.ql-textarea:focus,.ql-select:focus{
  outline:none;border-color:var(--ql-blue);background:#fff;box-shadow:0 0 0 3px rgba(11,116,196,.12);
}
.ql-input:disabled{opacity:.6;cursor:not-allowed;}
.ql-input.is-error,.ql-textarea.is-error,.ql-select.is-error{border-color:var(--ql-danger);background:var(--ql-danger-bg);}
.ql-input.is-valid{border-color:var(--ql-success);}
.ql-textarea{resize:vertical;min-height:96px;}
.ql-help{font-size:12px;color:var(--ql-faint);}
.ql-help.is-error{color:var(--ql-danger);}
.ql-mono-input{font-family:var(--ql-mono);font-size:14px;}

/* Input with leading icon / prefix */
.ql-input-group{display:flex;align-items:stretch;}
.ql-input-group .ql-prefix{
  display:flex;align-items:center;padding:0 12px;font-family:var(--ql-mono);font-size:14px;color:var(--ql-slate);
  background:#eef4f9;border:1px solid var(--ql-line-2);border-right:none;border-radius:var(--ql-r) 0 0 var(--ql-r);
}
.ql-input-group .ql-input{border-radius:0 var(--ql-r) var(--ql-r) 0;}
.ql-input-icon{position:relative;}
.ql-input-icon .material-symbols-outlined{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--ql-faint);font-size:20px;pointer-events:none;}
.ql-input-icon .ql-input{padding-left:42px;}

/* Select / dropdown */
.ql-select{
  appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:40px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%235a7488' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
}

/* Checkbox / radio (native, brand-tinted) */
.ql-check,.ql-radio{display:inline-flex;align-items:center;gap:9px;font-size:14px;color:#33495c;cursor:pointer;}
.ql-check input,.ql-radio input{width:17px;height:17px;accent-color:var(--ql-blue);cursor:pointer;}

/* Toggle switch */
.ql-switch{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0;}
.ql-switch input{opacity:0;width:0;height:0;}
.ql-switch .ql-track{position:absolute;inset:0;background:#cdd9e3;border-radius:var(--ql-r-pill);transition:background var(--ql-ease);}
.ql-switch .ql-track::before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform var(--ql-ease);}
.ql-switch input:checked + .ql-track{background:var(--ql-blue);}
.ql-switch input:checked + .ql-track::before{transform:translateX(20px);}

/* Range slider */
.ql-range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:var(--ql-r-pill);background:var(--ql-line);outline:none;}
.ql-range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--ql-blue);border:3px solid #fff;box-shadow:0 1px 4px rgba(8,55,95,.4);cursor:pointer;}
.ql-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--ql-blue);border:3px solid #fff;box-shadow:0 1px 4px rgba(8,55,95,.4);cursor:pointer;}

/* File upload */
.ql-file{display:flex;align-items:center;gap:12px;padding:18px;border:1.5px dashed var(--ql-line-2);border-radius:var(--ql-r-md);background:var(--ql-mist);color:var(--ql-slate);font-size:14px;cursor:pointer;transition:border-color var(--ql-ease);}
.ql-file:hover{border-color:var(--ql-blue);}

/* Date / time pickers use .ql-input directly:
   <input class="ql-input" type="date">  <input class="ql-input" type="time"> */

/* ---------- 5. Tables ---------- */
.ql-table-wrap{border:1px solid var(--ql-line);border-radius:var(--ql-r-md);overflow:hidden;}
.ql-table{width:100%;border-collapse:collapse;font-size:14px;}
.ql-table thead th{
  text-align:left;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ql-faint);background:var(--ql-mist);padding:13px 16px;border-bottom:1px solid var(--ql-line);
}
.ql-table tbody td{padding:14px 16px;border-bottom:1px solid var(--ql-line);color:#33495c;}
.ql-table tbody tr:last-child td{border-bottom:none;}
.ql-table tbody tr{transition:background var(--ql-ease);}
.ql-table--hover tbody tr:hover{background:var(--ql-mist);}
.ql-table--zebra tbody tr:nth-child(even){background:#fafcfe;}
.ql-table td .ql-mono{font-size:13px;color:var(--ql-slate);}
.ql-table--sticky thead th{position:sticky;top:0;z-index:1;}

/* ---------- 6. Pagination ---------- */
.ql-pagination{display:inline-flex;align-items:center;gap:6px;}
.ql-page{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;font-size:14px;font-weight:600;color:#33495c;background:#fff;border:1px solid var(--ql-line);border-radius:var(--ql-r-sm);cursor:pointer;text-decoration:none;transition:all var(--ql-ease);}
.ql-page:hover{border-color:var(--ql-blue);color:var(--ql-blue);}
.ql-page.is-active{background:var(--ql-grad);color:#fff;border-color:transparent;}
.ql-page.is-disabled{opacity:.4;pointer-events:none;}

/* ---------- 7. Tabs ---------- */
.ql-tabs{display:inline-flex;gap:4px;background:var(--ql-mist);border:1px solid var(--ql-line);border-radius:var(--ql-r);padding:4px;}
.ql-tab{font-size:14px;font-weight:600;color:var(--ql-slate);background:transparent;border:none;border-radius:var(--ql-r-sm);padding:9px 16px;cursor:pointer;transition:all var(--ql-ease);}
.ql-tab.is-active{background:var(--ql-grad);color:#fff;box-shadow:var(--ql-shadow-sm);}

/* ---------- 8. Accordion ---------- */
.ql-accordion{display:flex;flex-direction:column;gap:10px;}
.ql-acc-item{border:1px solid var(--ql-line);border-radius:var(--ql-r-md);overflow:hidden;transition:border-color var(--ql-ease);}
.ql-acc-item.is-open{border-color:var(--ql-blue);}
.ql-acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;font-size:15.5px;font-weight:700;color:var(--ql-ink);background:none;border:none;cursor:pointer;text-align:left;}
.ql-acc-body{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.ql-acc-item.is-open .ql-acc-body{max-height:320px;}
.ql-acc-body p{margin:0;padding:0 18px 18px;font-size:14px;color:var(--ql-slate);line-height:1.65;}

/* ---------- 9. Badges / chips / status ---------- */
.ql-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;padding:4px 10px;border-radius:var(--ql-r-pill);}
.ql-badge--info{color:var(--ql-info);background:var(--ql-info-bg);}
.ql-badge--success{color:var(--ql-success);background:var(--ql-success-bg);}
.ql-badge--danger{color:var(--ql-danger);background:var(--ql-danger-bg);}
.ql-badge--warn{color:var(--ql-warn);background:var(--ql-warn-bg);}
.ql-badge--neutral{color:var(--ql-slate);background:var(--ql-mist);}
.ql-dot{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block;}
.ql-chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:#33495c;background:#fff;border:1px solid var(--ql-line);border-radius:var(--ql-r-pill);padding:6px 12px;}
.ql-chip .ql-x{cursor:pointer;color:var(--ql-faint);font-size:16px;}

/* ---------- 10. Alerts / toast ---------- */
.ql-alert{display:flex;gap:13px;align-items:flex-start;padding:16px 18px;border-radius:var(--ql-r-md);border:1px solid;font-size:14px;line-height:1.55;}
.ql-alert .material-symbols-outlined{font-size:22px;flex-shrink:0;}
.ql-alert--info{background:var(--ql-info-bg);border-color:var(--ql-info-line);color:#0a3f73;}
.ql-alert--success{background:var(--ql-success-bg);border-color:var(--ql-success-line);color:#0a5c40;}
.ql-alert--danger{background:var(--ql-danger-bg);border-color:var(--ql-danger-line);color:#8e2a20;}
.ql-alert--warn{background:var(--ql-warn-bg);border-color:var(--ql-warn-line);color:#7d5208;}
.ql-alert-title{font-weight:700;color:var(--ql-ink);margin-bottom:2px;}
.ql-toast{display:inline-flex;align-items:center;gap:11px;padding:13px 18px;background:var(--ql-night);color:#fff;border-radius:var(--ql-r-md);box-shadow:var(--ql-shadow-pop);font-size:14px;font-weight:500;}
.ql-toast .material-symbols-outlined{color:var(--ql-cyan);font-size:20px;}

/* ---------- 11. Progress / spinner / skeleton ---------- */
.ql-progress{height:8px;background:var(--ql-line);border-radius:var(--ql-r-pill);overflow:hidden;}
.ql-progress-bar{height:100%;background:var(--ql-grad-brand);border-radius:var(--ql-r-pill);transition:width .4s ease;}
.ql-spinner{width:28px;height:28px;border:3px solid var(--ql-line);border-top-color:var(--ql-blue);border-radius:50%;animation:ql-spin .7s linear infinite;}
.ql-skeleton{background:linear-gradient(90deg,#eef4f9 25%,#e1edf6 37%,#eef4f9 63%);background-size:400% 100%;animation:ql-shimmer 1.4s ease infinite;border-radius:var(--ql-r-sm);}

/* ---------- 12. Tooltip ---------- */
.ql-tooltip{position:relative;display:inline-flex;}
.ql-tooltip .ql-tip{
  position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--ql-night);color:#fff;font-size:12.5px;font-weight:500;white-space:nowrap;
  padding:7px 11px;border-radius:var(--ql-r-sm);box-shadow:var(--ql-shadow-pop);
  opacity:0;pointer-events:none;transition:opacity var(--ql-ease);
}
.ql-tooltip .ql-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ql-night);}
.ql-tooltip:hover .ql-tip{opacity:1;}

/* ---------- 13. Modal ---------- */
.ql-overlay{position:fixed;inset:0;background:rgba(7,38,63,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;}
.ql-modal{background:#fff;border-radius:var(--ql-r-lg);box-shadow:var(--ql-shadow-pop);max-width:460px;width:100%;padding:28px;}
.ql-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.ql-modal-title{font-size:19px;font-weight:800;color:var(--ql-ink);}
.ql-modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;}

/* ---------- 14. Cards ---------- */
.ql-card{background:#fff;border:1px solid var(--ql-line);border-radius:var(--ql-r-lg);padding:24px;}
.ql-card--tinted{background:var(--ql-mist);}
.ql-card--dark{background:var(--ql-night);color:#fff;border-color:transparent;}
.ql-card--elevated{box-shadow:var(--ql-shadow-card);}

/* ---------- 15. Avatar / breadcrumb ---------- */
.ql-avatar{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#fff;background:var(--ql-grad-brand);overflow:hidden;}
.ql-avatar img{width:100%;height:100%;object-fit:cover;}
.ql-avatar-group{display:inline-flex;}
.ql-avatar-group .ql-avatar{border:2px solid #fff;margin-left:-10px;}
.ql-avatar-group .ql-avatar:first-child{margin-left:0;}
.ql-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ql-slate);}
.ql-breadcrumb a{color:var(--ql-slate);text-decoration:none;}
.ql-breadcrumb a:hover{color:var(--ql-blue);}
.ql-breadcrumb .ql-sep{color:var(--ql-line-2);}
.ql-breadcrumb .is-current{color:var(--ql-ink);font-weight:700;}

/* ---------- 16. Stat / counter ---------- */
.ql-stat{border:1px solid var(--ql-line);border-radius:var(--ql-r-md);padding:18px;background:#fff;}
.ql-stat-label{font-size:11.5px;font-weight:600;color:var(--ql-faint);margin-bottom:6px;}
.ql-stat-value{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ql-ink);}
.ql-stat-delta{font-size:12px;font-weight:600;margin-top:4px;}
.ql-stat-delta.is-up{color:var(--ql-success);}
.ql-stat-delta.is-down{color:var(--ql-danger);}
.ql-counter{display:inline-flex;gap:8px;}
.ql-counter .ql-unit{background:var(--ql-night);color:#fff;border-radius:var(--ql-r);padding:12px 6px;min-width:60px;text-align:center;}
.ql-counter .ql-num{font-family:var(--ql-mono);font-size:26px;font-weight:700;line-height:1;}
.ql-counter .ql-lab{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ql-cyan);margin-top:5px;}

/* ---------- 17. Keyframes ---------- */
@keyframes ql-spin{to{transform:rotate(360deg);}}
@keyframes ql-shimmer{0%{background-position:100% 0;}100%{background-position:-100% 0;}}
@keyframes ql-blip{0%,100%{opacity:.4;}50%{opacity:1;}}
