/* =====================================
   Headings / Alerts
===================================== */
h1 { margin-top: 50px; }
h2{ margin:0 0 30px;}

.register-err {
  background: #ffe9e9;
  color: #a00;
  padding: 10px 12px;
  border-radius: 8px;
  margin-bottom: 12px;
}

/* =====================================
   Form Base
===================================== */
.register-form label {
  display: block;
  margin: 10px 0 6px;
}

.form-row input,
.register-form input {
  width: 100%;
  padding: 10px;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-sizing: border-box;
}

/* 체크박스 확대 */
input[type="checkbox"] {
  width: 50px;
  transform: scale(1.5);
  margin: 0 5px 0 0;
}

.register-form input:invalid { border-color:#e74c3c; }
.register-form .err-msg { display:block; font-size:.85em; color:#e74c3c; margin-top:4px; min-height:1em; }
.register-form input.error { border:1px solid #e74c3c; background:#fff6f6; }
.register-form input.valid { border:1px solid #2ecc71; background:#f8fff9; }
.register-form button[disabled],
.register-form button[aria-disabled="true"] { opacity:.2; cursor:not-allowed; }
.pw-field {
  position: relative;
}
.pw-field .pw-toggle {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border: 0; background: transparent;
  cursor: pointer;
}
.pw-field .pw-toggle i { font-size: 18px; line-height: 1; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}



/* ✅ 제출 버튼만 스타일 적용 (공통 button 규칙 삭제) */
.register-form button[type="submit"] {
  margin-top: 14px;
  padding: 12px 14px;
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: #111;
  color: #fff;
  font-weight: 600;
  cursor:pointer;
}

/* 배치 */
.register-row { display: flex; gap: 8px; }
.register-row > div { flex: 1; }

.register-extra a {
  color: #2962ff;
  text-decoration: none;
}

/* =====================================
   Password Field / Toggle
===================================== */
.pw-field{
  position: relative;   /* ← 추가 */
}

/* 인풋은 가변폭, 토글은 고정 버튼 느낌 */
.pw-field input[type="password"],
.pw-field input[type="text"]{
  width: 100%;
  box-sizing: border-box;
  padding-right: 44px;  /* ← 아이콘 폭+여백만큼 확보 (24px + 8~12px) */
}
/* 토글 버튼 세로 기준선/라인하이트 고정 */
.pw-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:40px;           /* 인풋 높이에 맞추세요 */
  padding:0 10px;
  line-height:1;         /* 글꼴 라인 박스 영향 제거 */
  border:1px solid #ddd; /* 테두리 두께 변동 X */
  background:#fff;
  cursor:pointer;
}

/* 힌트는 필드 아래에 나타남 (위 JS와 페어) */
.field-hint{
  margin-top:6px;
  font-size:12px;
  color:#666;
  min-height:1em;        /* 내용이 없어도 약간의 공간 유지(옵션) */
}
.pw-field + .field-hint,
input + .field-hint { margin-top: 6px; }

/* ✅ 이 블록만 사용 */
.register-form .pw-toggle {
  all: unset;
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  line-height: 1;
  z-index: 1;
}

.register-form .pw-toggle:focus-visible {
  outline: 2px solid #2962ff;
  outline-offset: 2px;
}
.register-form .pw-toggle svg {
  width: 20px;
  height: 20px;
  display: block;
  fill: #555;
  pointer-events: none;
}
.register-form .pw-toggle:hover svg { fill: #000; }

/* 아이콘 토글 */
.pw-toggle .icon-eye-off { display: none !important; }
.pw-toggle.is-on .icon-eye { display: none !important; }
.pw-toggle.is-on .icon-eye-off { display: inline !important; }

/* 크기 규칙은 위쪽에 있어도 됨 */
.pw-toggle svg { width:20px; height:20px; display:block; }
.my-info {background:#fff; max-width:600px; margin:2rem auto; border:1px solid #ccc; padding:1.5rem; border-radius:8px; }
.my-info h2 { margin-bottom: 1rem;  border-bottom: 1px solid #ccc; padding-bottom: 10px; }
.my-info dt { font-weight:normal; margin-top:0.5rem; }
.my-info dd { margin:0 0 1rem 0; font-weight:bold; font-size:1.2em;}
p a{text-decoration:none;border:1px solid #ccc; border-radius:10px;padding:3px 10px;font-size:12px;}
.log-list{display:flex;gap:10px;}

/*member_edit.php 스타일코드*/
.container-sm{max-width:720px;margin:24px auto;padding:0 16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row{display:flex;flex-direction:column;gap:6px}
.br{margin:20px 0;}
.form-actions{margin-top:12px;display:flex;gap:8px}
.btn{display:inline-block;border:1px solid #ddd;border-radius:10px;padding:8px 14px;text-decoration:none;cursor:pointer;}
.btn-primary{background:#111;color:#fff;border-color:#111}
.muted{color:#777;font-size:12px}
.readonly-input {
  background-color: #f9f9f9 !important;
  color: #666 !important;
  border-color: #ddd !important;
  pointer-events: none !important;
}

@media (max-width:640px){.form-grid{grid-template-columns:1fr}}
  /* ========== Theme Tokens (profile/edit와 동일) ========== */
  :root{
    --bg:#f7f8fa;
    --panel:#ffffff;
    --ink:#0f172a;
    --muted:#6b7280;
    --border:#e5e7eb;
    --ring:#93c5fd;
    --primary:#1267a5;
    --primary-ink:#ffffff;
    --error-bg:#fee2e2;
    --error-ink:#991b1b;
    --error-border:#fecaca;
    --ok-bg:#d1fae5;
    --ok-ink:#065f46;
    --ok-border:#a7f3d0;
    --radius:14px;
    --shadow:0 10px 25px rgba(15,23,42,.06);
    --shadow-sm:0 6px 16px rgba(15,23,42,.05);
  }

  body{ background:var(--bg); }
  .profile-edit{ max-width:840px; margin:32px auto; padding:0 16px; color:var(--ink); }
  .profile-edit h1{ font-size:28px; line-height:1.2; margin:0 0 6px; letter-spacing:-.01em; }
  .profile-sub{ margin:0 0 18px; color:var(--muted); font-size:14px; }

  .card{ background:var(--panel); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
  .card-head{ padding:20px 22px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:12px; }
  .card-body{ padding:22px; }
  .card-foot{ padding:16px 22px; border-top:1px solid var(--border); background:linear-gradient(#fff,#fafafa); }

  .alert{ border-radius:12px; padding:12px 14px; margin:12px 0 16px; display:flex; gap:10px; align-items:flex-start; border:1px solid transparent; }
  .alert-error{ background:var(--error-bg); color:var(--error-ink); border-color:var(--error-border); }
  .alert-success{ background:var(--ok-bg); color:var(--ok-ink); border-color:var(--ok-border); }
  .alert .alert-icon{ width:18px; height:18px; flex:0 0 18px; border-radius:50%; background:currentColor;
    mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="white" viewBox="0 0 24 24"><path d="M12 9v4m0 4h.01M12 2a10 10 0 100 20 10 10 0 000-20z" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') center/contain no-repeat; }
  .alert-success .alert-icon{
    mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="white" viewBox="0 0 24 24"><path d="M9 12l2 2 4-4" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/><circle cx="12" cy="12" r="9" stroke="white" stroke-width="0"/></svg>');
  }

  .pw-form{ display:grid; gap:16px; grid-template-columns:1fr; }
  @media (min-width:780px){ .pw-form{ grid-template-columns:1fr 1fr; } .field--full{ grid-column:1 / -1; } }

  .field{ display:flex; flex-direction:column; gap:8px; }
  .field-label{ display:flex; align-items:center; justify-content:space-between; color:#374151; font-size:14px; font-weight:600; }
  .help{ color:var(--muted); font-size:12px; margin-top:2px; }

  .input{
    width:100%; height:44px; padding:10px 12px; border:1px solid var(--border); border-radius:12px; background:#fff; color:var(--ink); outline:none;
    transition:border-color .15s ease, box-shadow .15s ease, transform .04s ease;
  }
  .input:hover{ border-color:#d1d5db; }
  .input:focus{ border-color:var(--primary); box-shadow:0 0 0 4px color-mix(in srgb, var(--ring) 45%, transparent); }

  .actions{ display:flex; gap:10px; flex-wrap:wrap; }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px; height:42px; padding:0 16px; border-radius:12px; cursor:pointer; text-decoration:none;
    border:1px solid transparent; transition:transform .04s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease; font-weight:600;
  }
  .btn:active{ transform:translateY(1px); }
  .btn-primary{ background:var(--primary); color:var(--primary-ink); border-color:var(--primary); box-shadow:var(--shadow-sm); }
  .btn-primary:hover{ filter:saturate(1.05) brightness(1.02); }
  .btn-outline{ background:#fff; color:#374151; border-color:#d1d5db; }
  .btn-outline:hover{ border-color:#cbd5e1; }
  .btn-link{ background:transparent; border-color:transparent; color:var(--primary); padding:0 2px; height:auto; }

  .muted{ color:var(--muted); }

  /* --- Client-side validation extras --- */
  .input.is-invalid{
    border-color:#fca5a5 !important;
    box-shadow:0 0 0 4px color-mix(in srgb, #fecaca 45%, transparent) !important;
  }
  .error-text{
    color:#b91c1c;               /* red-700 */
    font-size:12px;
    margin-top:6px;
  }
  .shake { animation: shake .28s linear 1; }
  @keyframes shake {
    0%,100%{ transform:translateX(0) }
    20%{ transform:translateX(-4px) }
    40%{ transform:translateX(4px) }
    60%{ transform:translateX(-3px) }
    80%{ transform:translateX(2px) }
  }
  
    /* ========== Theme Tokens ========== */
  :root{
    --bg:#f7f8fa;
    --panel:#ffffff;
    --ink:#0f172a;               /* slate-900 */
    --muted:#6b7280;             /* gray-500 */
    --border:#e5e7eb;            /* gray-200 */
    --ring:#93c5fd;              /* blue-300 */
    --primary:#1267a5;           /* 브랜드 메인 */
    --primary-ink:#ffffff;
    --error-bg:#fee2e2;
    --error-ink:#991b1b;
    --error-border:#fecaca;
    --ok-bg:#d1fae5;
    --ok-ink:#065f46;
    --ok-border:#a7f3d0;
    --radius:14px;
    --radius-sm:10px;
    --shadow:0 10px 25px rgba(15,23,42,.06);
    --shadow-sm:0 6px 16px rgba(15,23,42,.05);
  }

  /* ========== Page Shell ========== */
  body{ background:var(--bg); }
  .profile-edit{
    max-width:840px; margin:32px auto; padding:0 16px; color:var(--ink);
  }
  .profile-edit h1{
    font-size:28px; line-height:1.2; margin:0 0 14px; letter-spacing:-.01em;
  }
  .profile-sub{
    margin:-6px 0 18px; color:var(--muted); font-size:14px;
  }

  /* ========== Card ========== */
  .card{
    background:var(--panel);
    border:1px solid var(--border);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    overflow:hidden;
  }
  .card-head{
    padding:20px 22px;
    border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
    gap:12px;
  }
  .card-body{ padding:22px; }
  .card-foot{
    padding:16px 22px; border-top:1px solid var(--border);
    background:linear-gradient(#fff, #fafafa);
  }

  /* ========== Alerts ========== */
  .alert{ border-radius:12px; padding:12px 14px; margin:12px 0 16px; display:flex; gap:10px; align-items:flex-start; border:1px solid transparent; }
  .alert-error{ background:var(--error-bg); color:var(--error-ink); border-color:var(--error-border); }
  .alert-success{ background:var(--ok-bg); color:var(--ok-ink); border-color:var(--ok-border); }
  .alert .alert-icon{
    width:18px; height:18px; flex:0 0 18px; border-radius:50%;
    background:currentColor; mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill=\"white\" viewBox=\"0 0 24 24\"><path d=\"M12 9v4m0 4h.01M12 2a10 10 0 100 20 10 10 0 000-20z\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>') center/contain no-repeat;
  }
  .alert-success .alert-icon{
    mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill=\"white\" viewBox=\"0 0 24 24\"><path d=\"M9 12l2 2 4-4\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><circle cx=\"12\" cy=\"12\" r=\"9\" stroke=\"white\" stroke-width=\"0\"/></svg>');
  }

  /* ========== Form Grid ========== */
  .form{
    display:grid; gap:16px;
    grid-template-columns:1fr;
  }
  @media (min-width: 780px){
    .form{ grid-template-columns:1fr; }
    .form .field--full{ grid-column:1 / -1; }
  }

  /* ========== Fields ========== */
  .field{ display:flex; flex-direction:column; gap:8px; }
  .field-label{
    display:flex; align-items:center; justify-content:space-between;
    color:#374151; font-size:14px; font-weight:600; letter-spacing:.001em;
  }
  .help{ color:var(--muted); font-size:12px; margin-top:2px; }

  /* unified input */
  .input, .text-input, .readonly-input, .input[readonly]{
    width:100%; height:44px; padding:10px 12px;
    border:1px solid var(--border); border-radius:12px;
    background:#fff; color:var(--ink); outline:none;
    transition:border-color .15s ease, box-shadow .15s ease, transform .04s ease;
  }
  .input:hover, .text-input:hover{ border-color:#d1d5db; }
  .input:focus, .text-input:focus, .input:focus-visible, .text-input:focus-visible{
    border-color:var(--primary);
    box-shadow:0 0 0 4px color-mix(in srgb, var(--ring) 45%, transparent);
  }

  /* read-only (보이는 입력) */
  .readonly-input{
    background:#f9fafb; color:#111827; border-style:dashed;
    pointer-events:none; user-select:text; height:auto; padding:12px 10px;
  }

  /* invalid quick styles (브라우저 기본 검증 연동) */
  .input:invalid, .text-input:invalid{
    border-color:#fda4af;
    box-shadow:0 0 0 4px color-mix(in srgb, #fecdd3 45%, transparent);
  }

  /* ========== Buttons ========== */
  .actions{ display:flex; gap:10px; flex-wrap:wrap; }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    height:42px; padding:0 8px; border-radius:12px; cursor:pointer; text-decoration:none;
    border:1px solid transparent; transition:transform .04s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
    font-weight:600;
  }
  .btn:active{ transform:translateY(1px); }
  .btn-primary{ background:var(--primary); color:var(--primary-ink); border-color:var(--primary); box-shadow:var(--shadow-sm); }
  .btn-primary:hover{ filter:saturate(1.05) brightness(1.02); }
  .btn-outline{ background:#fff; color:#374151; border-color:#d1d5db; }
  .btn-outline:hover{ border-color:#cbd5e1; }
  .btn-ghost{ background:#fff; color:#374151; border-color:#e5e7eb; }
  .btn-ghost:hover{ border-color:#cbd5e1; }
  .btn[disabled]{ opacity:.6; cursor:not-allowed; }

  /* ========== Utility ========== */
  .muted{ color:var(--muted); }
  .sr-only{
    position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
  }
  .register-complete {
    max-width: 480px;
    margin: 40px auto;
    padding: 40px;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    text-align: center;
}

.register-complete h1 {
    font-size: 26px;
    margin-bottom: 20px;
    color: #333;
}

.register-complete p {
    font-size: 15px;
    color: #666;
    margin-bottom: 30px;
}

.register-complete .btn {
    padding: 12px 20px;
    font-size: 16px;
}