/*!
 * DOMN Auth screens — modern split-screen (login / register / forgot / reset / trainee).
 */
.domn-auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:26px 16px;background:radial-gradient(1100px 560px at 82% -8%, #EEF2F5 0%, #F6F8FA 55%, #F2F4F7 100%);font-family:var(--domn-font,'Cairo','Tajawal',sans-serif)}
.domn-auth-shell{width:100%;max-width:480px;display:grid;grid-template-columns:1fr;background:var(--domn-surface,#fff);border-radius:24px;overflow:hidden;box-shadow:0 30px 80px rgba(38,46,54,.20);border:1px solid var(--domn-border,#e3e7eb)}
.domn-auth-shell.is-wide{max-width:600px;grid-template-columns:1fr}

/* Brand side */
.domn-auth-brand{position:relative;overflow:hidden;color:#fff;background:linear-gradient(150deg,#2A323A 0%,#36404A 46%,#A11F27 132%);padding:42px 34px;display:flex;flex-direction:column;gap:24px}
.domn-auth-brand::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.07) 1px, transparent 0);background-size:22px 22px;opacity:.55}
.domn-auth-brand__glow{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle, rgba(197,44,53,.55), transparent 70%);inset-inline-end:-130px;top:-100px}
.domn-auth-brand>*{position:relative;z-index:1}
.domn-auth-brand__logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:24px;color:#fff;text-decoration:none;letter-spacing:.5px}
.domn-auth-brand__logo img{max-height:44px;width:auto;filter:brightness(0) invert(1)}
.domn-auth-brand__head{font-size:23px;font-weight:800;line-height:1.55;margin:6px 0 0}
.domn-auth-brand__sub{margin:.4rem 0 0;color:rgba(255,255,255,.82);font-size:13.5px;line-height:1.9}
.domn-auth-points{list-style:none;margin:auto 0 0;padding:0;display:grid;gap:13px}
.domn-auth-points li{display:flex;align-items:flex-start;gap:12px}
.domn-auth-points .ic{flex:0 0 auto;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18)}
.domn-auth-points .ic svg{width:20px;height:20px;stroke:#fff;fill:none}
.domn-auth-points b{display:block;font-weight:700;font-size:13.5px}
.domn-auth-points span{color:rgba(255,255,255,.72);font-size:12px;line-height:1.6}
.domn-auth-brand__foot{font-size:12px;color:rgba(255,255,255,.6);margin-top:4px}

/* Form side */
.domn-auth-main{display:flex;align-items:center;justify-content:center;padding:42px 36px;max-height:100vh;overflow:auto}
.domn-auth-card{width:100%;background:transparent;box-shadow:none;border-radius:0;padding:0;max-width:none}
.domn-auth-logo{display:none}
.domn-auth-title{font-size:26px;font-weight:800;color:var(--domn-ink,#36404A);text-align:start;margin:0 0 6px;display:flex;align-items:center;gap:8px}
.domn-auth-subtitle{text-align:start;color:var(--domn-text-muted,#7a828b);margin-bottom:22px;font-size:14px;line-height:1.7}

/* form controls refinement (scoped) */
.domn-auth-card .domn-input,.domn-auth-card .domn-select,.domn-auth-card .domn-textarea{border-radius:12px;border:1.5px solid var(--domn-border-strong,#cbd5e1);padding:.7rem .9rem;background:#fff;transition:border-color .15s,box-shadow .15s}
.domn-auth-card .domn-input:focus,.domn-auth-card .domn-select:focus,.domn-auth-card .domn-textarea:focus{outline:none;border-color:var(--domn-primary);box-shadow:0 0 0 3px var(--domn-primary-soft)}
.domn-auth-card .domn-label{font-size:13px;font-weight:700;color:#3b444d;margin-bottom:6px;display:block}
.domn-auth-card .domn-field{margin-bottom:14px}
.domn-auth-card .domn-row{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.domn-auth-card .domn-col{min-width:0}
@media(max-width:520px){.domn-auth-card .domn-row{grid-template-columns:1fr}}
.domn-auth-card .domn-btn-lg{padding:.85rem 1.2rem;font-size:15px;border-radius:12px}
.domn-btn-block{width:100%}
.domn-auth-card .domn-btn{transition:background .15s,transform .08s,box-shadow .15s}
.domn-auth-card .domn-btn:hover{transform:translateY(-1px)}
.domn-auth-card .domn-btn:not(.domn-btn-secondary):not(.domn-btn-ghost):hover{box-shadow:0 8px 22px rgba(197,44,53,.30)}

/* remember + inline forgot */
.domn-auth-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:2px 0 4px;font-size:13px}
.domn-auth-meta label{display:flex;align-items:center;gap:.5rem;color:#4b5560;cursor:pointer}
.domn-auth-meta input{width:16px;height:16px;accent-color:var(--domn-primary)}
.domn-auth-meta a{font-weight:600;color:var(--domn-primary)}

/* divider + option cards (login) */
.domn-auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0 16px;color:var(--domn-text-soft,#94a3b8);font-size:12px}
.domn-auth-divider::before,.domn-auth-divider::after{content:"";flex:1;height:1px;background:var(--domn-border,#e3e7eb)}
.domn-auth-options{display:grid;gap:10px}
.domn-auth-opt{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1.5px solid var(--domn-border,#e3e7eb);border-radius:14px;text-decoration:none;color:var(--domn-ink,#36404A);background:#fff;transition:border-color .15s,box-shadow .15s,transform .1s}
.domn-auth-opt:hover{border-color:var(--domn-primary);box-shadow:0 8px 20px rgba(38,46,54,.08);transform:translateY(-1px)}
.domn-auth-opt .ic{flex:0 0 auto;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--domn-primary-soft);color:var(--domn-primary)}
.domn-auth-opt .ic svg{width:21px;height:21px}
.domn-auth-opt .tx b{display:block;font-size:14px;font-weight:800}
.domn-auth-opt .tx span{font-size:12px;color:var(--domn-text-muted,#7a828b)}
.domn-auth-opt .go{margin-inline-start:auto;color:var(--domn-text-soft,#94a3b8);display:grid;place-items:center}
.domn-auth-opt .go svg{width:18px;height:18px}
.domn-auth-footer{text-align:center;margin-top:20px;font-size:14px;color:var(--domn-text-muted,#7a828b)}
.domn-auth-footer a{font-weight:700;color:var(--domn-primary)}

/* form sections (register/trainee grouping) */
.domn-formsec{border:1px solid var(--domn-border,#e3e7eb);border-radius:16px;padding:18px 16px 4px;margin-bottom:16px;background:#fff}
.domn-formsec__head{display:flex;align-items:center;gap:10px;margin:-2px 0 14px}
.domn-formsec__n{flex:0 0 auto;width:28px;height:28px;border-radius:9px;display:grid;place-items:center;background:var(--domn-primary);color:#fff;font-weight:800;font-size:13px}
.domn-formsec__t{font-size:15px;font-weight:800;color:var(--domn-ink,#36404A);line-height:1.3}
.domn-formsec__t small{display:block;font-weight:500;font-size:12px;color:var(--domn-text-muted,#7a828b)}

/* course cards (trainee) */
.domn-courses{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.domn-courses{grid-template-columns:1fr}}
.domn-course{position:relative;display:block;cursor:pointer}
.domn-course input{position:absolute;opacity:0;pointer-events:none}
.domn-course__box{border:1.5px solid var(--domn-border,#e3e7eb);border-radius:14px;padding:14px;height:100%;transition:border-color .15s,box-shadow .15s,background .15s}
.domn-course:hover .domn-course__box{border-color:var(--domn-primary)}
.domn-course input:checked+.domn-course__box{border-color:var(--domn-primary);box-shadow:0 0 0 3px var(--domn-primary-soft);background:var(--domn-primary-soft)}
.domn-course__cat{display:inline-block;font-size:11px;font-weight:700;color:var(--domn-primary);background:#fff;border:1px solid var(--domn-primary-soft);padding:2px 9px;border-radius:999px;margin-bottom:8px}
.domn-course__title{font-size:13.5px;font-weight:800;color:var(--domn-ink,#36404A);line-height:1.5;margin-bottom:9px}
.domn-course__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:11.5px;color:var(--domn-text-muted,#7a828b)}
.domn-course__meta span{display:inline-flex;align-items:center;gap:4px}
.domn-course__meta svg{width:13px;height:13px;opacity:.8}

/* file inputs */
.domn-file{display:flex;align-items:center;gap:10px;border:1.5px dashed var(--domn-border-strong,#cbd5e1);border-radius:12px;padding:11px 12px;font-size:13px;color:var(--domn-text-muted,#7a828b);background:#fff;cursor:pointer;transition:border-color .15s}
.domn-file:hover{border-color:var(--domn-primary)}
.domn-file>svg{flex:0 0 auto;width:18px;height:18px;color:var(--domn-primary)}
.domn-file input[type=file]{display:none}
.domn-file .fn{font-weight:600;color:var(--domn-ink,#36404A)}

/* password */
.domn-pw{position:relative}
.domn-pw .domn-input{padding-inline-end:44px!important}
.domn-pw-toggle{position:absolute;inset-inline-end:6px;top:50%;transform:translateY(-50%);width:32px;height:32px;display:grid;place-items:center;background:transparent;border:0;border-radius:8px;color:#9aa3ab;cursor:pointer;padding:0}
.domn-pw-toggle:hover{color:var(--domn-primary);background:var(--domn-primary-soft)}
.domn-pw-toggle svg{width:19px;height:19px;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,#7a828b);min-width:66px;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}
.domn-interests{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.3rem}
@media(max-width:520px){.domn-interests{grid-template-columns:1fr}}
.domn-chk{display:flex;align-items:center;gap:.5rem;font-size:13px;color:#374151;cursor:pointer;border:1px solid var(--domn-border,#e3e7eb);border-radius:10px;padding:9px 11px;transition:border-color .15s}
.domn-chk:hover{border-color:var(--domn-primary)}
.domn-chk input{width:16px;height:16px;accent-color:var(--domn-primary)}
.domn-forgot-ic{width:56px;height:56px;border-radius:16px;background:var(--domn-primary-soft);color:var(--domn-primary);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.domn-welcome-badge{display:inline-flex;align-items:center;gap:6px;background:var(--domn-primary-soft);color:var(--domn-primary);font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px;margin-bottom:10px}

/* responsive: collapse brand to a top band */
@media(max-width:880px){
  .domn-auth-shell,.domn-auth-shell.is-wide{grid-template-columns:1fr;max-width:620px}
  .domn-auth-brand{padding:22px 22px;flex-direction:row;align-items:center;gap:14px;flex-wrap:wrap}
  .domn-auth-brand__head,.domn-auth-brand__sub,.domn-auth-points,.domn-auth-brand__foot{display:none}
  .domn-auth-brand__logo{font-size:20px}
  .domn-auth-main{padding:26px 20px}
  .domn-auth-title{text-align:center;justify-content:center}
  .domn-auth-subtitle{text-align:center}
}
@media(max-width:560px){
  .domn-auth-page{padding:0;align-items:stretch}
  .domn-auth-shell{border-radius:0;border:0;box-shadow:none;min-height:100vh;align-content:start}
}
/* back-to-previous button (chromeless forms) */
.domn-auth-back{position:fixed;top:16px;inset-inline-start:20px;z-index:40;display:inline-flex;align-items:center;gap:6px;background:#fff;color:var(--domn-ink,#36404A);border:1px solid var(--domn-border,#e3e7eb);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:700;text-decoration:none;box-shadow:0 6px 18px rgba(38,46,54,.15)}
.domn-auth-back:hover{color:var(--domn-primary);box-shadow:0 8px 22px rgba(38,46,54,.22);transform:translateY(-1px)}
.domn-auth-back svg{width:16px;height:16px;flex:0 0 auto}
@media(max-width:560px){.domn-auth-back{top:12px;inset-inline-start:12px;padding:7px 12px;font-size:12px}}
/* wizard */
.domn-wzbar{margin:2px 0 22px}
.domn-wzsteps{display:flex;justify-content:space-between;list-style:none;margin:0 0 12px;padding:0;gap:6px}
.domn-wzstep{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;color:#9aa3ac;font-size:.78rem;font-weight:700;text-align:center}
.domn-wzstep__n{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:#eef1f4;color:#6b7178;font-weight:800;border:2px solid #e3e7eb;transition:.25s}
.domn-wzstep.is-active{color:var(--domn-primary,#C52C35)}
.domn-wzstep.is-active .domn-wzstep__n{background:var(--domn-primary,#C52C35);color:#fff;border-color:var(--domn-primary,#C52C35);box-shadow:0 6px 16px rgba(197,44,53,.28)}
.domn-wzstep.is-done{color:var(--domn-ink,#2A323A)}
.domn-wzstep.is-done .domn-wzstep__n{background:var(--domn-ink,#2A323A);color:#fff;border-color:var(--domn-ink,#2A323A)}
.domn-wzprogress{height:6px;border-radius:99px;background:#eef1f4;overflow:hidden}
.domn-wzprogress__bar{display:block;height:100%;width:25%;background:linear-gradient(90deg,var(--domn-primary,#C52C35),#cf3b43);border-radius:99px;transition:width .35s cubic-bezier(.4,0,.2,1)}
form[data-wizard] .domn-wstep{display:none}
form[data-wizard] .domn-wstep.is-current{display:block;animation:domnWzIn .3s ease}
@keyframes domnWzIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.domn-wznav{display:flex;gap:12px;margin-top:14px}
.domn-wznav .domn-btn{flex:1;justify-content:center}
.domn-wznav .domn-btn[hidden]{display:none!important}
.domn-btn-ghost{background:transparent;border:1.5px solid #d7dce1;color:#41494f;box-shadow:none}
.domn-btn-ghost:hover{border-color:var(--domn-primary,#C52C35);color:var(--domn-primary,#C52C35);background:rgba(197,44,53,.04)}
/* wizard forms fit the viewport (no page scroll) */
form[data-wizard] .domn-formsec{border:0;padding:0;margin:0;background:transparent}
form[data-wizard] .domn-formsec .domn-formsec__head{margin-top:0}
@media(max-width:480px){.domn-wzstep__l{display:none}.domn-wzstep__n{width:28px;height:28px}}
/* auth v2 — job select + inline validation + step counter + no x-scroll */
/* no horizontal scroll, mobile-first safety */
html,body.domn-portal-page,body.domn-chromeless-body{overflow-x:hidden;max-width:100%}
.domn-auth-page,.domn-auth-shell,.domn-auth-main,.domn-auth-card{max-width:100%;min-width:0}
.domn-auth-card form,.domn-auth-card .domn-row,.domn-auth-card .domn-col,.domn-auth-card .domn-formsec,.domn-auth-card section{min-width:0;max-width:100%}
.domn-auth-card .domn-input,.domn-auth-card .domn-select,.domn-auth-card .domn-textarea{max-width:100%}
.domn-auth-card img,.domn-auth-card svg{max-width:100%}

/* step counter */
.domn-wzcount{font-size:12.5px;font-weight:700;color:var(--domn-primary,#C52C35);margin-bottom:10px;letter-spacing:.2px}

/* inline validation */
.domn-field.is-invalid .domn-input,.domn-field.is-invalid .domn-select,.domn-field.is-invalid .domn-textarea{border-color:#dc2626!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important}
.domn-field.is-valid .domn-input,.domn-field.is-valid .domn-select{border-color:#16a34a!important}
.domn-fielderr{display:block;color:#b91c1c;font-size:12px;font-weight:600;margin-top:5px;animation:domnErrIn .2s ease}
.domn-fielderr:empty{display:none}
@keyframes domnErrIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:none}}

/* searchable job select */
.domn-jobselect{position:relative}
.domn-jobselect__control{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:.72rem .9rem;border:1.5px solid var(--domn-border-strong,#cbd5e1);border-radius:12px;background:#fff;cursor:pointer;font:inherit;color:var(--domn-ink,#36404A);text-align:start;transition:border-color .15s,box-shadow .15s}
.domn-jobselect__control:hover{border-color:var(--domn-primary,#C52C35)}
.domn-jobselect__control[aria-expanded="true"]{border-color:var(--domn-primary,#C52C35);box-shadow:0 0 0 3px var(--domn-primary-soft,#FBEAEB)}
.domn-jobselect.is-invalid .domn-jobselect__control{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.12)}
.domn-jobselect__label{font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.domn-jobselect__label.is-placeholder{color:var(--domn-text-soft,#94a3b8);font-weight:500}
.domn-jobselect__control svg{width:18px;height:18px;flex:0 0 auto;color:var(--domn-text-muted,#7a828b)}
.domn-jobselect__panel{position:absolute;z-index:60;top:calc(100% + 6px);inset-inline:0;background:#fff;border:1px solid var(--domn-border,#e3e7eb);border-radius:14px;box-shadow:0 18px 44px rgba(38,46,54,.18);overflow:hidden;animation:domnErrIn .15s ease}
.domn-jobselect__search{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--domn-border,#e3e7eb)}
.domn-jobselect__search svg{width:17px;height:17px;color:var(--domn-text-soft,#94a3b8);flex:0 0 auto}
.domn-jobselect__search input{flex:1;border:0;outline:none;font:inherit;font-size:14px;background:transparent;color:var(--domn-ink,#36404A)}
.domn-jobselect__list{list-style:none;margin:0;padding:6px;max-height:240px;overflow-y:auto}
.domn-jobselect__opt{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .12s}
.domn-jobselect__opt:hover{background:var(--domn-primary-soft,#FBEAEB)}
.domn-jobselect__opt-t{font-weight:700;font-size:13.5px;color:var(--domn-ink,#36404A)}
.domn-jobselect__opt-m{font-size:11.5px;color:var(--domn-text-muted,#7a828b)}
.domn-jobselect__empty{padding:18px;text-align:center;color:var(--domn-text-muted,#7a828b);font-size:13px}

/* auto-filled job summary */
.domn-jobsummary{margin-top:12px;border:1px solid var(--domn-border,#e3e7eb);border-radius:14px;padding:6px 14px;background:var(--domn-bg,#f8fafc)}
.domn-jobsummary__row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px dashed var(--domn-border,#e3e7eb);font-size:13px}
.domn-jobsummary__row:last-child{border-bottom:0}
.domn-jobsummary__row>span{color:var(--domn-text-muted,#7a828b);font-weight:600}
.domn-jobsummary__row>b{color:var(--domn-ink,#36404A);font-weight:800;text-align:end}
.domn-jobsummary__hint{font-size:11.5px;color:var(--domn-text-muted,#7a828b);margin-top:8px;display:flex;align-items:center;gap:6px}
/* chosen-program confirmation banner (trainee, preselected) */
.domn-chosen{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1.5px solid var(--domn-primary-soft,#FBEAEB);background:linear-gradient(180deg,#fff, var(--domn-primary-soft,#FBEAEB));border-radius:16px;margin-bottom:18px}
.domn-chosen__ic{flex:0 0 auto;width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--domn-primary,#C52C35);color:#fff}
.domn-chosen__ic svg{width:24px;height:24px;stroke:#fff;fill:none}
.domn-chosen__body{flex:1;min-width:0}
.domn-chosen__label{display:block;font-size:11.5px;font-weight:700;color:var(--domn-primary,#C52C35);letter-spacing:.3px}
.domn-chosen__title{display:block;font-size:15px;font-weight:800;color:var(--domn-ink,#36404A);margin:2px 0 3px;line-height:1.4}
.domn-chosen__meta{font-size:12px;color:var(--domn-text-muted,#7a828b)}
.domn-chosen__change{flex:0 0 auto;font-size:12.5px;font-weight:700;color:var(--domn-primary,#C52C35);text-decoration:none;border:1px solid var(--domn-primary,#C52C35);padding:7px 14px;border-radius:999px;transition:.15s}
.domn-chosen__change:hover{background:var(--domn-primary,#C52C35);color:#fff}
@media(max-width:520px){.domn-chosen{flex-wrap:wrap}.domn-chosen__change{width:100%;text-align:center}}