/*
 * IMDTEC — Auth UI (shared)
 * Used by:
 *  - /signin/
 *  - /signup/
 *  - /signin/forgot-password/
 *
 * ✅ Single source of truth for the auth design.
 * Change values in :root to adjust the whole auth UI quickly.
 */

:root{
  --imd-auth-bg:#ffffff;
  --imd-auth-text:#0f172a;
  --imd-auth-muted:#6b7280;
  --imd-auth-border:#e5e7eb;
  --imd-auth-focus:rgba(17,24,39,.14);

  --imd-auth-btn:#111827;
  --imd-auth-btn-hover:#0b1220;

  --imd-auth-radius:14px;
  --imd-auth-max:460px;
  --imd-auth-hero-radius:180px;
}

/* Base */
body.imdtec-auth-page{
  margin:0;
  background:var(--imd-auth-bg);
  color:var(--imd-auth-text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif;
}

.imd-auth{
  min-height:100dvh;
  display:flex;
  align-items:stretch;
}

.imd-auth__left{
  flex:0 0 46%;
  min-width:460px;
  padding:clamp(26px, 4vw, 56px);
  display:flex;
  align-items:center;
}

.imd-auth__inner{
  width:100%;
  max-width:var(--imd-auth-max);
}

/* Header (logo + optional back link) */
.imd-auth__header{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  margin:0 0 22px;
}

.imd-auth__header .imd-auth__logo{
  margin:0;
}

.imd-auth__header .imd-auth__back{
  margin:0;
}

.imd-auth__back{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 18px;
  color:var(--imd-auth-text);
  text-decoration:none;
  font-weight:700;
  opacity:.78;
}

.imd-auth__back:hover{
  opacity:1;
  text-decoration:underline;
}

.imd-auth__back svg{
  width:18px;
  height:18px;
  display:block;
}

.imd-auth__logo{
  display:inline-flex;
  margin-bottom:22px;
  text-decoration:none;
}

.imd-auth__logo img{
  width:150px;
  height:auto;
  display:block;
}

.imd-auth__title{
  margin:0 0 8px;
  font-size:28px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:-0.02em;
}

.imd-auth__subtitle{
  margin:0 0 22px;
  color:var(--imd-auth-muted);
  font-size:14.5px;
  line-height:1.55;
}

.imd-auth__notice{
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  padding:12px 14px;
  border-radius:var(--imd-auth-radius);
  margin:0 0 14px;
  font-size:14px;
}

.imd-auth__notice--error{
  background:#fef2f2;
  border-color:#fecaca;
  color:#991b1b;
}

.imd-auth__notice--success{
  background:#ecfdf5;
  border-color:#a7f3d0;
  color:#065f46;
}

/* Divider "OU" */
.imd-auth__divider{
  display:flex;
  align-items:center;
  gap:12px;
  margin:22px 0 14px;
  color:var(--imd-auth-muted);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.imd-auth__divider:before,
.imd-auth__divider:after{
  content:"";
  flex:1;
  height:1px;
  background:var(--imd-auth-border);
}

.imd-auth__divider span{ padding:0 2px; }

/* Social */
.imd-auth__social{ display:flex; flex-direction:column; gap:12px; }

.imd-auth__social-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  border:1px solid var(--imd-auth-border);
  border-radius:var(--imd-auth-radius);
  padding:13px 16px;
  background:#fff;
  color:var(--imd-auth-text);
  font-weight:700;
  text-decoration:none;
  transition:background .15s ease, border-color .15s ease, transform .02s ease;
}

.imd-auth__social-btn:hover{
  background:#f9fafb;
  border-color:rgba(17,24,39,.18);
}

.imd-auth__social-btn:active{ transform:translateY(1px); }

.imd-auth__icon{ width:18px; height:18px; display:inline-flex; }

/* Right hero */
.imd-auth__right{
  flex:1;
  padding:clamp(18px, 2vw, 28px);
  display:flex;
  align-items:stretch;
  justify-content:flex-end;
  background:#fff;
}

.imd-auth__media{
  width:min(900px, 100%);
  height:100%;
  border-radius:var(--imd-auth-hero-radius) 0 0 var(--imd-auth-hero-radius);
  overflow:hidden;
  position:relative;
}

.imd-auth__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Forms (shared) */
.imd-auth-form{ margin-top:6px; }

.imd-auth-grid{ display:grid; gap:12px; }
.imd-auth-grid--2{ grid-template-columns:1fr 1fr; }

.imd-auth-field{ margin:0 0 14px; }

.imd-auth-label{
  display:block;
  margin:0 0 6px;
  font-size:12px;
  color:var(--imd-auth-muted);
  font-weight:700;
}

.imd-auth-control{
  width:100%;
  border:1px solid var(--imd-auth-border);
  border-radius:var(--imd-auth-radius);
  padding:14px 14px;
  font-size:15px;
  background:#fff;
  outline:none;
  box-sizing:border-box;
}

.imd-auth-control:focus{
  border-color:rgba(17,24,39,.35);
  box-shadow:0 0 0 4px var(--imd-auth-focus);
}

.imd-auth-control::placeholder{ color:rgba(15,23,42,.55); }

.imd-auth-btn{
  width:100%;
  background:var(--imd-auth-btn);
  color:#fff;
  border:none;
  border-radius:var(--imd-auth-radius);
  padding:14px 16px;
  font-weight:800;
  font-size:14px;
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.imd-auth-btn:hover{ background:var(--imd-auth-btn-hover); }

.imd-auth__links{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:14px;
  font-size:14px;
  color:var(--imd-auth-muted);
}

.imd-auth__links a{
  color:var(--imd-auth-text);
  font-weight:700;
  text-decoration:none;
}

.imd-auth__links a:hover{ text-decoration:underline; }

.imd-auth__section-title{
  margin:18px 0 10px;
  font-size:20px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:-0.01em;
}

.imd-auth__section-note{
  margin:0 0 14px;
  color:var(--imd-auth-muted);
  font-size:13px;
  line-height:1.55;
}

/* WP login form tweaks (signin) */
.imd-auth .login form{
  border:none !important;
  padding:0 !important;
  box-shadow:none !important;
  margin:0;
}

.imd-auth .login p{ margin:0 0 14px; }

/* Hide username/password labels visually (PECB-style). */
.imd-auth .login .login-username label,
.imd-auth .login .login-password label{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.imd-auth .login .input{
  width:100%;
  border:1px solid var(--imd-auth-border);
  border-radius:var(--imd-auth-radius);
  padding:14px 14px;
  font-size:15px;
  background:#fff;
  outline:none;
  box-sizing:border-box;
}

.imd-auth .login .input:focus{
  border-color:rgba(17,24,39,.35);
  box-shadow:0 0 0 4px var(--imd-auth-focus);
}

.imd-auth__aux{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:2px 0 18px;
}

.imd-auth__aux .login-remember{ margin:0; }

.imd-auth__aux .login-remember label{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
  font-size:14px;
  color:var(--imd-auth-text);
  font-weight:500;
}

.imd-auth__aux input[type="checkbox"]{ width:18px; height:18px; border-radius:4px; }

.imd-auth__forgot{
  font-size:14px;
  color:var(--imd-auth-text);
  text-decoration:none;
  opacity:.75;
}

.imd-auth__forgot:hover{ opacity:1; text-decoration:underline; }

.imd-auth .login .login-submit{ margin:0; }

#wp-submit{
  width:100%;
  background:var(--imd-auth-btn);
  color:#fff;
  border:none;
  border-radius:var(--imd-auth-radius);
  padding:14px 16px;
  font-weight:800;
  font-size:14px;
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.08em;
}

#wp-submit:hover{ background:var(--imd-auth-btn-hover); }

.imd-auth__signup{
  margin:16px 0 0;
  font-size:14px;
  color:var(--imd-auth-muted);
}

.imd-auth__signup a{
  color:var(--imd-auth-text);
  font-weight:700;
  text-decoration:none;
}

.imd-auth__signup a:hover{ text-decoration:underline; }

/* Responsive */
@media (max-width: 1020px){
  .imd-auth__left{ flex:1; min-width:0; }
  .imd-auth__right{ display:none; }
  .imd-auth__inner{ max-width:520px; }
}

@media (max-width: 560px){
  .imd-auth-grid--2{ grid-template-columns:1fr; }
}

/* RTL adjustments */
[dir="rtl"] .imd-auth{ flex-direction:row-reverse; }
[dir="rtl"] .imd-auth__media{ border-radius:0 var(--imd-auth-hero-radius) var(--imd-auth-hero-radius) 0; }
[dir="rtl"] .imd-auth__aux{ flex-direction:row-reverse; }
[dir="rtl"] .imd-auth__links{ flex-direction:row-reverse; }
[dir="rtl"] .imd-auth__back{ flex-direction:row-reverse; }
