/*!
 * DOMN Design System — design tokens, reset, RTL Arabic foundation.
 * Loaded on every frontend request. Mobile-first.
 */

:root {
  /* Brand */
  --domn-primary:        #C52C35;
  --domn-primary-hover:  #A11F27;
  --domn-primary-soft:   #FBEAEB;
  --domn-primary-fore:   #ffffff;
  --domn-ink:            #36404A;
  --domn-steel:          #2A323A;

  --domn-success:        #16a34a;
  --domn-success-soft:   #dcfce7;
  --domn-warning:        #d97706;
  --domn-warning-soft:   #fef3c7;
  --domn-danger:         #dc2626;
  --domn-danger-soft:    #fee2e2;
  --domn-info:           #0891b2;
  --domn-info-soft:      #cffafe;

  /* Neutrals */
  --domn-bg:             #f8fafc;
  --domn-surface:        #ffffff;
  --domn-surface-alt:    #f1f5f9;
  --domn-border:         #e2e8f0;
  --domn-border-strong:  #cbd5e1;
  --domn-text:           #0f172a;
  --domn-text-muted:     #64748b;
  --domn-text-soft:      #94a3b8;

  /* Status pills (maintenance + quote workflow states) */
  --domn-status-new:        #2563eb;
  --domn-status-reviewing:  #d97706;
  --domn-status-progress:   #0891b2;
  --domn-status-completed:  #16a34a;
  --domn-status-cancelled:  #64748b;
  --domn-status-rejected:   #dc2626;

  /* Typography */
  --domn-font:           'Cairo', 'Tajawal', 'Segoe UI', 'Helvetica Neue', sans-serif;
  --domn-fs-xs:          0.75rem;   /* 12 */
  --domn-fs-sm:          0.875rem;  /* 14 */
  --domn-fs-base:        1rem;      /* 16 */
  --domn-fs-lg:          1.125rem;  /* 18 */
  --domn-fs-xl:          1.25rem;   /* 20 */
  --domn-fs-2xl:         1.5rem;    /* 24 */
  --domn-fs-3xl:         1.875rem;  /* 30 */
  --domn-lh-tight:       1.25;
  --domn-lh-snug:        1.4;
  --domn-lh-normal:      1.6;

  /* Spacing scale */
  --domn-space-1:        0.25rem;
  --domn-space-2:        0.5rem;
  --domn-space-3:        0.75rem;
  --domn-space-4:        1rem;
  --domn-space-5:        1.25rem;
  --domn-space-6:        1.5rem;
  --domn-space-8:        2rem;
  --domn-space-10:       2.5rem;
  --domn-space-12:       3rem;

  /* Layout */
  --domn-radius-sm:      0.375rem;
  --domn-radius:         0.5rem;
  --domn-radius-lg:      0.75rem;
  --domn-radius-xl:      1rem;
  --domn-radius-pill:    9999px;

  --domn-shadow-sm:      0 1px 2px rgba(15, 23, 42, 0.06);
  --domn-shadow:         0 4px 12px rgba(15, 23, 42, 0.08);
  --domn-shadow-lg:      0 12px 32px rgba(15, 23, 42, 0.12);

  --domn-container:      1200px;
  --domn-z-modal:        1100;
  --domn-z-toast:        1200;

  --domn-transition:     150ms ease-out;
}

@media (prefers-color-scheme: dark) {
  /* Reserved: dark mode tokens will land in Phase 12. */
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }

/* Overflow safety net: keep all portal content inside its boxes (no horizontal break-out). */
.domn-app, .domn-portal, .domn-portal-main, .domn-portal-content, .domn-card, .domn-col, .domn-row { min-width: 0; max-width: 100%; }
.domn-portal-content, .domn-portal-main { overflow-x: hidden; }
.domn-app p, .domn-app dd, .domn-app dt, .domn-app td, .domn-app th, .domn-app li, .domn-app span, .domn-app strong, .domn-app a, .domn-app h1, .domn-app h2, .domn-app h3, .domn-app h4 { overflow-wrap: anywhere; word-break: break-word; }
.domn-app code, .domn-app .domn-ltr { white-space: normal; overflow-wrap: anywhere; max-width: 100%; }
.domn-app img { max-width: 100%; height: auto; }
/* Neutralise theme dt/dd styling that can break grid detail lists. */
.domn-app dl { margin: 0; }
.domn-app dt, .domn-app dd { margin: 0; padding: 0; float: none; width: auto; }
/* Robust key/value list (replaces fragile CSS-grid <dl> in detail cards). */
.domn-kv { display: flex; flex-direction: column; gap: .55rem; font-size: var(--domn-fs-sm, 13px); }
.domn-kv-row { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; }
.domn-kv-k { color: var(--domn-text-muted); flex: 0 0 auto; white-space: nowrap; }
.domn-kv-v { flex: 1 1 auto; min-width: 0; text-align: left; overflow-wrap: anywhere; word-break: break-word; font-weight: 600; }
/* Password field with reliable show/hide toggle (reusable across auth + portal). */
.domn-pw { position: relative; display: block; }
.domn-pw input { width: 100%; padding-inline-end: 46px !important; direction: ltr; text-align: left; letter-spacing: .04em; }
.domn-pw-toggle { position: absolute; inset-inline-end: 8px; top: 50%; transform: translateY(-50%); width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; background: transparent; border: 0; border-radius: 8px; color: #9ca3af; cursor: pointer; padding: 0; transition: color .15s, background .15s; }
.domn-pw-toggle:hover { color: var(--domn-primary); background: rgba(177,7,8,.06); }
.domn-pw-toggle svg { width: 20px; height: 20px; pointer-events: none; }
.domn-pw-strength { display: flex; align-items: center; gap: 8px; margin-top: 7px; }
.domn-pw-bar { flex: 1; height: 6px; border-radius: 999px; background: #e5e7eb; overflow: hidden; }
.domn-pw-bar i { display: block; height: 100%; width: 0; border-radius: 999px; background: #dc2626; transition: width .25s, background .25s; }
.domn-pw-strength-label { font-size: 11.5px; color: var(--domn-text-muted,#6b7280); min-width: 78px; text-align: start; font-weight: 600; }
.domn-pw-strength.s1 .domn-pw-bar i { width: 33%; background: #dc2626; }
.domn-pw-strength.s2 .domn-pw-bar i { width: 66%; background: #f59e0b; }
.domn-pw-strength.s3 .domn-pw-bar i { width: 100%; background: #16a34a; }
.domn-pw-match { display: flex; align-items: center; gap: 6px; margin-top: 7px; font-size: 12.5px; font-weight: 600; padding: 6px 10px; border-radius: 8px; }
.domn-pw-match.ok { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.domn-pw-match.bad { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
/* "View as" manager banner. */
.domn-viewas-bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; background: #fffbeb; border: 1px solid #fde68a; color: #92400e; padding: .6rem 1rem; border-radius: 10px; margin-bottom: 1rem; font-size: 13px; font-weight: 700; }
.domn-viewas-bar a.domn-viewas-exit { color: #b10708; text-decoration: underline; white-space: nowrap; }
body.domn-portal-page {
  margin: 0;
  font-family: var(--domn-font);
  font-size: var(--domn-fs-base);
  line-height: var(--domn-lh-normal);
  color: var(--domn-text);
  background: var(--domn-bg);
  direction: rtl;
  text-align: right;
}

.domn-app a { color: var(--domn-primary); text-decoration: none; }
.domn-app a:hover { text-decoration: underline; }

.domn-app h1, .domn-app h2, .domn-app h3, .domn-app h4 {
  margin: 0 0 var(--domn-space-3);
  line-height: var(--domn-lh-snug);
  font-weight: 700;
  color: var(--domn-text);
}
.domn-app h1 { font-size: var(--domn-fs-3xl); }
.domn-app h2 { font-size: var(--domn-fs-2xl); }
.domn-app h3 { font-size: var(--domn-fs-xl); }
.domn-app h4 { font-size: var(--domn-fs-lg); }

.domn-app p { margin: 0 0 var(--domn-space-4); }
.domn-muted { color: var(--domn-text-muted); }
.domn-soft  { color: var(--domn-text-soft); }

/* Layout primitives */
.domn-container {
  max-width: var(--domn-container);
  margin: 0 auto;
  padding: 0 var(--domn-space-4);
}
.domn-stack > * + * { margin-top: var(--domn-space-4); }
.domn-stack-sm > * + * { margin-top: var(--domn-space-2); }
.domn-stack-lg > * + * { margin-top: var(--domn-space-6); }

.domn-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--domn-space-4);
}
.domn-row > .domn-col { flex: 1 1 0; min-width: 0; }

.domn-grid {
  display: grid;
  gap: var(--domn-space-4);
}
.domn-grid-2 { grid-template-columns: 1fr; }
.domn-grid-3 { grid-template-columns: 1fr; }
.domn-grid-4 { grid-template-columns: 1fr; }

@media (min-width: 640px) {
  .domn-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .domn-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .domn-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
  .domn-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .domn-grid-4 { grid-template-columns: repeat(4, 1fr); }
}

.domn-hidden { display: none !important; }
.domn-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Focus ring for accessibility (WCAG 2.4.7) */
.domn-app :focus-visible {
  outline: 2px solid var(--domn-primary);
  outline-offset: 2px;
  border-radius: var(--domn-radius-sm);
}


/* ==================== Icons (Lucide SVG inline) ==================== */
.domn-icon {
  display: inline-block;
  vertical-align: -0.15em;
  flex-shrink: 0;
  pointer-events: none;
}
.domn-icon-lg { width: 24px; height: 24px; }
.domn-icon-xl { width: 32px; height: 32px; }
.domn-icon-2xl { width: 48px; height: 48px; }

.domn-icon-spin { animation: domn-spin 1s linear infinite; }
@keyframes domn-spin { from { transform: rotate(0); } to { transform: rotate(360deg); } }

/* Star rating icon row helper */
.domn-stars { display: inline-flex; gap: 0.15rem; color: var(--domn-warning); direction: ltr; }
.domn-stars .domn-icon { width: 18px; height: 18px; }

/* Icon inside chip/button gets a smaller default size */
.domn-btn .domn-icon { width: 16px; height: 16px; }
.domn-badge .domn-icon { width: 14px; height: 14px; }
.domn-status .domn-icon { width: 14px; height: 14px; }
/* Job-application radios + checkbox grid */
.domn-radio-row{display:flex;gap:var(--domn-space-2);flex-wrap:wrap}
.domn-radio{flex:1 1 0;min-width:120px;display:flex;align-items:center;gap:var(--domn-space-2);padding:10px 14px;border:1px solid var(--domn-border);border-radius:var(--domn-radius);background:var(--domn-surface);cursor:pointer;font-size:var(--domn-fs-sm);transition:var(--domn-transition)}
.domn-radio:hover{border-color:var(--domn-primary)}
.domn-radio:has(input:checked){border-color:var(--domn-primary);background:var(--domn-primary-soft);color:var(--domn-primary-fore);font-weight:600}
.domn-radio input{accent-color:var(--domn-primary);width:16px;height:16px;margin:0}
.domn-check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--domn-space-2)}
.domn-check{display:flex;align-items:center;gap:var(--domn-space-2);padding:10px 14px;border:1px solid var(--domn-border);border-radius:var(--domn-radius);background:var(--domn-surface);cursor:pointer;font-size:var(--domn-fs-sm);transition:var(--domn-transition)}
.domn-check:hover{border-color:var(--domn-primary)}
.domn-check:has(input:checked){border-color:var(--domn-primary);background:var(--domn-primary-soft);color:var(--domn-primary-fore);font-weight:600}
.domn-check input{accent-color:var(--domn-primary);width:16px;height:16px;margin:0}
@media(max-width:560px){.domn-check-grid{grid-template-columns:1fr}}
