/* ─── Auth card (login / signup / verify) ─────────────────────── */
.auth-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:40px 36px;
  box-shadow:0 1px 3px rgba(0,0,0,0.04);
  width:100%;
}
.auth-logo{
  font-family:var(--font-serif);font-size:26px;font-weight:600;
  color:var(--black);text-align:center;letter-spacing:-0.4px;margin-bottom:6px;
}
.auth-sub{
  text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:32px;letter-spacing:0.2px;
}
.auth-title{
  font-family:var(--font-serif);font-size:20px;font-weight:500;color:var(--black);
  margin-bottom:6px;letter-spacing:-0.2px;
}

/* ─── Form fields ──────────────────────────────────────────────── */
.field{margin-bottom:18px}
.field-label{
  display:block;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;
  color:var(--text-muted);margin-bottom:8px;
}
.field-input{
  width:100%;
  padding:12px 14px;
  font-family:var(--font-sans);font-size:14px;color:var(--text);
  background:var(--bg-card);
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  outline:none;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.field-input:hover{border-color:var(--border-strong)}
.field-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(154,123,79,0.12)}
.field-input::placeholder{color:var(--text-muted)}
.field-error{
  display:none;
  font-size:12px;color:var(--red);margin-top:6px;letter-spacing:0.1px;
}
.field-error.visible{display:block}
.field-hint{font-size:11px;color:var(--text-muted);margin-top:6px;letter-spacing:0.1px}

/* ─── Buttons ──────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;cursor:pointer;font-family:var(--font-sans);
  font-size:13px;font-weight:600;letter-spacing:0.3px;
  padding:12px 22px;border-radius:var(--radius-sm);
  transition:all .25s var(--ease);
}
.btn-primary{background:var(--black);color:#fff}
.btn-primary:hover{background:#2c2820;transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.12)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn-block{width:100%;padding:13px}
.btn-secondary{
  background:transparent;color:var(--text-secondary);
  border:1px solid var(--border);
}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}

/* ─── Inline link / muted text ─────────────────────────────────── */
.link{
  color:var(--gold);text-decoration:none;font-weight:600;
  border-bottom:1px solid transparent;transition:border-color .2s var(--ease);
}
.link:hover{border-bottom-color:var(--gold)}
.muted-link-row{
  text-align:center;margin-top:24px;font-size:13px;color:var(--text-muted);
}

/* ─── Banner (top-of-form errors / success) ────────────────────── */
.banner{
  display:none;
  padding:12px 16px;border-radius:var(--radius-sm);
  font-size:13px;line-height:1.5;margin-bottom:18px;
  border:1px solid transparent;
}
.banner.visible{display:block}
.banner.error{background:var(--red-bg);border-color:#cf222e30;color:var(--red)}
.banner.success{background:var(--green-bg);border-color:#1a7f3730;color:var(--green)}
.banner.warn{background:var(--amber-bg);border-color:#7a5e0030;color:var(--amber)}
.banner .banner-action{margin-left:8px;text-decoration:underline;cursor:pointer;font-weight:600}

/* ─── Loading inline state ─────────────────────────────────────── */
.btn-loading{position:relative;color:transparent !important}
.btn-loading::after{
  content:'';position:absolute;left:50%;top:50%;
  width:16px;height:16px;margin:-8px 0 0 -8px;
  border:2px solid rgba(255,255,255,0.35);border-top-color:#fff;
  border-radius:50%;animation:btn-spin .7s linear infinite;
}
@keyframes btn-spin{to{transform:rotate(360deg)}}

/* ─── Verify status (verify.html) ──────────────────────────────── */
.verify-state{text-align:center;padding:8px 0}
.verify-state .icon{
  width:64px;height:64px;border-radius:50%;
  margin:0 auto 18px;
  display:inline-flex;align-items:center;justify-content:center;
}
.verify-state.loading .icon{background:var(--gold-bg)}
.verify-state.success .icon{background:var(--green-bg)}
.verify-state.error .icon{background:var(--red-bg)}
.verify-state .title{
  font-family:var(--font-serif);font-size:22px;font-weight:500;color:var(--black);
  margin-bottom:8px;
}
.verify-state .body{font-size:14px;color:var(--text-secondary);line-height:1.65;margin-bottom:24px}

/* ─── Inline spinner (small) ───────────────────────────────────── */
.spinner-ring{
  width:32px;height:32px;border:2.5px solid var(--border);
  border-top-color:var(--gold);border-radius:50%;
  animation:btn-spin .9s cubic-bezier(0.4,0,0.2,1) infinite;
  display:inline-block;
}

/* ─── History page ─────────────────────────────────────────────── */
.history-header{
  display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.history-title{
  font-family:var(--font-serif);font-size:28px;font-weight:500;color:var(--black);letter-spacing:-0.4px;
}
.history-meta{font-size:12px;color:var(--text-muted);letter-spacing:0.2px}
.history-empty{
  background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius);
  padding:48px 24px;text-align:center;color:var(--text-muted);
}
.history-empty p{font-size:14px;line-height:1.6;margin-bottom:16px}

.h-item{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:10px;overflow:hidden;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.h-item:hover{border-color:var(--border-strong);box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.h-item.open{border-color:var(--gold)}
.h-summary{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;cursor:pointer;
}
.h-date{font-size:11px;color:var(--text-muted);min-width:88px;letter-spacing:0.2px}
.h-snippet{flex:1;font-size:14px;color:var(--text);line-height:1.5;font-weight:500}
.h-conf{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase}
.h-conf.high{background:var(--green-bg);color:var(--green)}
.h-conf.medium{background:var(--amber-bg);color:var(--amber)}
.h-conf.low{background:var(--red-bg);color:var(--red)}
.h-rating{font-size:13px;color:var(--text-muted)}
.h-rating.up{color:var(--green)}
.h-rating.down{color:var(--red)}
.h-chevron{
  width:18px;height:18px;color:var(--text-muted);
  transition:transform .25s var(--ease);
}
.h-item.open .h-chevron{transform:rotate(180deg);color:var(--gold)}

.h-body{
  display:none;padding:0 20px 20px;border-top:1px solid var(--border);
  animation:slide-down .25s var(--ease);
}
.h-item.open .h-body{display:block}
@keyframes slide-down{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.h-body .label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.8px;color:var(--gold);
  margin:18px 0 8px;font-weight:600;
}
.h-body p, .h-body li{font-size:13px;color:var(--text-secondary);line-height:1.7}
.h-body ol{padding-left:20px}
.h-body li{margin-bottom:6px}
.h-body li::marker{color:var(--gold)}
.h-query{
  font-size:14px;color:var(--text);line-height:1.65;
  background:var(--bg-card-alt);border-radius:var(--radius-sm);
  padding:12px 14px;border:1px solid var(--border);
}

/* ─── Pagination ───────────────────────────────────────────────── */
.pager{
  display:flex;align-items:center;justify-content:center;gap:16px;
  margin-top:32px;
}
.pager .pager-info{font-size:12px;color:var(--text-muted);letter-spacing:0.3px}
.pager button{
  background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px 16px;font-size:12px;color:var(--text-secondary);
  cursor:pointer;font-family:var(--font-sans);transition:all .2s var(--ease);
}
.pager button:hover:not(:disabled){border-color:var(--gold);color:var(--gold)}
.pager button:disabled{opacity:.4;cursor:not-allowed}

/* ─── Account page ─────────────────────────────────────────────── */
.account-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px;margin-bottom:14px;
}
.account-card h3{
  font-family:var(--font-serif);font-size:18px;font-weight:500;color:var(--black);
  margin-bottom:16px;letter-spacing:-0.2px;
}
.account-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.account-row:last-child{border-bottom:none}
.account-row .k{font-size:12px;color:var(--text-muted);letter-spacing:0.3px;text-transform:uppercase;font-weight:600}
.account-row .v{font-size:14px;color:var(--text)}
