/* VS Conference Management - Modern Journal UI (lightweight)
 * Applies on pages that contain VSCM shortcodes.
 */

:root{
  --vscm-bg:#f7f8fb;
  --vscm-card:#ffffff;
  --vscm-border:#e6e8ef;
  --vscm-text:#111827;
  --vscm-muted:#6b7280;
  --vscm-primary:#1d4ed8;
  --vscm-primary-hover:#1e40af;
  --vscm-danger:#b91c1c;
  --vscm-success:#0f766e;
  --vscm-warn:#b45309;
  --vscm-shadow:0 10px 25px rgba(17,24,39,.08);
  --vscm-radius:18px;
}

/* Container */
.vscm-box{
  background:var(--vscm-card);
  border:1px solid var(--vscm-border);
  border-radius:var(--vscm-radius);
  padding:22px;
  box-shadow:var(--vscm-shadow);
}

.vscm-box h1,.vscm-box h2,.vscm-box h3{
  color:var(--vscm-text);
  margin:0 0 12px 0;
  font-weight:700;
}

.vscm-small{
  color:var(--vscm-muted);
  font-size:13px;
}

/* Messages */
.vscm-msg{margin:12px 0; padding:12px 14px; border-radius:14px; border:1px solid var(--vscm-border);}
.vscm-msg-success{background:#ecfdf5; border-color:#a7f3d0; color:#065f46;}
.vscm-msg-error{background:#fef2f2; border-color:#fecaca; color:#991b1b;}
.vscm-msg-warn{background:#fffbeb; border-color:#fde68a; color:#92400e;}

/* Buttons */
.vscm-button, button.vscm-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 16px;
  border-radius:14px;
  border:1px solid transparent;
  background:var(--vscm-primary);
  color:#fff;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:transform .02s ease, background .15s ease, box-shadow .15s ease;
  box-shadow:0 8px 18px rgba(29,78,216,.16);
}
.vscm-button:hover{background:var(--vscm-primary-hover);}
.vscm-button:active{transform:translateY(1px);}
.vscm-button-danger{background:var(--vscm-danger); box-shadow:0 8px 18px rgba(185,28,28,.16);}

/* Inputs */
.vscm-box input[type="text"],
.vscm-box input[type="email"],
.vscm-box input[type="password"],
.vscm-box input[type="url"],
.vscm-box input[type="number"],
.vscm-box select,
.vscm-box textarea{
  width:100%;
  box-sizing:border-box;
  border:1px solid var(--vscm-border);
  border-radius:14px;
  padding:12px 12px;
  font-size:14px;
  background:#fff;
  color:var(--vscm-text);
  outline:none;
}
.vscm-box textarea{min-height:100px;}
.vscm-box input:focus,
.vscm-box select:focus,
.vscm-box textarea:focus{
  border-color:rgba(29,78,216,.6);
  box-shadow:0 0 0 4px rgba(29,78,216,.12);
}

.vscm-field{margin-bottom:14px;}
.vscm-label{display:block;font-size:13px;font-weight:600;color:var(--vscm-muted);margin-bottom:6px;}
.vscm-input, .vscm-select, .vscm-textarea{
  width:100%;
  background:#fff;
  border:1px solid var(--vscm-border);
  border-radius:12px;
  padding:12px 12px;
  font-size:15px;
  line-height:1.2;
  color:var(--vscm-text);
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
  box-sizing:border-box;
}
.vscm-textarea{min-height:110px;resize:vertical;}
.vscm-input:focus, .vscm-select:focus, .vscm-textarea:focus{
  border-color:rgba(29,78,216,.6);
  box-shadow:0 0 0 4px rgba(29,78,216,.12);
}
.vscm-check{font-size:14px;color:var(--vscm-muted);
  user-select:none;}

.vscm-login-form{margin-top:18px;}
.vscm-login-actions{margin-top:8px;}
.vscm-login-title{font-weight:800;}

/* Inline row */
.vscm-inline{display:flex; gap:12px; flex-wrap:wrap;}
.vscm-inline > *{flex:1 1 auto;}

/* Login */
.vscm-login-wrap{max-width:520px; margin:32px auto;}
.vscm-login-banner{border-radius:var(--vscm-radius); overflow:hidden; margin-bottom:16px; border:1px solid var(--vscm-border);}
.vscm-login-banner img{width:100%; display:block;}
.vscm-login-logo{display:flex; justify-content:center; margin:6px 0 14px 0;}
.vscm-login-logo img{max-height:72px; width:auto;}

.vscm-login-title{text-align:center; margin:0 0 14px 0; font-size:28px; letter-spacing:-.01em;}

.vscm-login-actions{display:flex; justify-content:space-between; align-items:center; gap:10px; margin-top:10px;}
.vscm-login-actions .vscm-remember{display:flex; align-items:center; gap:8px; color:var(--vscm-muted); font-size:13px;}
.vscm-login-actions .vscm-remember input{width:auto;}

/* Make wp_login_form look decent if ever used */
.vscm-box #loginform p{margin:0 0 12px 0;}
.vscm-box #loginform label{display:block; font-weight:600; margin-bottom:8px; font-size:13px;}
.vscm-box #loginform input[type="text"],
.vscm-box #loginform input[type="password"]{width:100%;}
.vscm-box #loginform input[type="submit"]{margin-top:6px;}

/* Responsive tweaks */
@media (max-width: 520px){
  .vscm-box{padding:18px; border-radius:16px;}
  .vscm-login-title{font-size:24px;}
  .vscm-login-actions{flex-direction:column; align-items:stretch;}
  .vscm-login-actions .vscm-button{width:100%;}
}
