/* ============================================================
   PRESTIGE BIMMER — Admin styles
   ============================================================ */

/* ---------------- Login ---------------- */
.admin-login { min-height: 100vh; display: grid; place-items: center; padding: 100px 20px 60px; position: relative; }
.admin-login-card { width: 100%; max-width: 440px; padding: 44px 40px 36px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.admin-login-brand { margin-bottom: 30px; }
.admin-login-lock { width: 60px; height: 60px; border-radius: 16px; display: grid; place-items: center; background: var(--blue-soft); color: var(--blue-bright); border: 1px solid rgba(31,109,255,0.25); margin-bottom: 22px; }
.admin-login-card h1 { margin-bottom: 8px; }
.admin-login-card > p { color: var(--text-dim); margin-bottom: 28px; }
.admin-login-form { width: 100%; display: flex; flex-direction: column; gap: 16px; text-align: left; }
.admin-login-form .btn { margin-top: 8px; }
.admin-login-err { color: var(--red); font-size: 12px; display: inline-flex; align-items: center; gap: 6px; }
.admin-login-hint { margin-top: 26px; padding: 14px 18px; border: 1px dashed var(--line-2); border-radius: 12px; width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.admin-login-hint span { font-size: 10px; letter-spacing: 0.18em; color: var(--text-faint); }
.admin-login-hint code { font-family: var(--font-mono); font-size: 13px; color: var(--blue-bright); }
.shake { animation: shake .5s var(--ease-in-out); }
@keyframes shake { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-9px)} 40%,80%{transform:translateX(9px)} }

/* ---------------- Admin shell ---------------- */
.admin { min-height: 100vh; }
.admin-bar { position: sticky; top: 0; z-index: 50; background: rgba(6,8,12,0.82); backdrop-filter: blur(18px); border-bottom: 1px solid var(--line); }
.admin-bar-inner { display: flex; align-items: center; gap: 20px; height: 76px; }
.admin-bar-brand { display: flex; align-items: center; gap: 10px; }
.editor-back { color: var(--text-dim); font-weight: 600; font-size: 14px; transition: color .3s, gap .3s; gap: 8px; }
.editor-back:hover { color: var(--text); }
.admin-bar-tag { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); padding: 7px 13px; border: 1px solid var(--line); border-radius: 100px; }
.admin-bar-actions { margin-left: auto; display: flex; gap: 12px; }
.admin-bar-actions .btn { padding: 11px 18px; font-size: 13.5px; }

.admin-content { padding-block: 44px 90px; }
.admin-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 36px; }
.admin-head p { margin-top: 8px; }

/* ---------------- Stat cards ---------------- */
.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr) 1.4fr; gap: 16px; margin-bottom: 40px; }
.admin-stat { padding: 22px 22px 20px; display: flex; flex-direction: column; gap: 4px; position: relative; overflow: hidden; transition: border-color .4s, transform .4s; }
.admin-stat:hover { border-color: var(--line-2); transform: translateY(-3px); }
.admin-stat-ic { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 10px; background: var(--blue-soft); color: var(--blue-bright); margin-bottom: 12px; }
.admin-stat-v { font-family: var(--font-display); font-weight: 800; font-size: 30px; line-height: 1; }
.admin-stat-l { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); margin-top: 6px; }
.admin-stat-wide .admin-stat-v { font-size: 26px; }
.tone-green .admin-stat-ic { background: rgba(56,211,159,0.12); color: var(--green); }
.tone-amber .admin-stat-ic { background: rgba(245,177,76,0.12); color: var(--amber); }
.tone-red .admin-stat-ic { background: rgba(255,94,107,0.12); color: var(--red); }

/* ---------------- Toolbar ---------------- */
.admin-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 20px; }
.admin-reset { display: inline-flex; align-items: center; gap: 7px; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); transition: color .3s; }
.admin-reset:hover { color: var(--red); }

/* ---------------- Table ---------------- */
.admin-table { overflow: hidden; }
.admin-trow { display: grid; grid-template-columns: 2.4fr 1fr 1fr 1.1fr 0.8fr 0.9fr; align-items: center; gap: 16px; padding: 16px 24px; border-bottom: 1px solid var(--line); transition: background .3s; }
.admin-trow:last-child { border-bottom: none; }
.admin-trow:not(.admin-thead):hover { background: var(--surface-2); }
.admin-thead { font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); background: var(--bg-2); padding-block: 14px; }
.admin-tveh { display: flex; align-items: center; gap: 14px; }
.admin-tthumb { width: 64px; height: 44px; border-radius: 8px; flex-shrink: 0; }
.admin-tthumb.ph::after { font-size: 0; padding: 0; border: none; background: none; content: ""; }
.admin-tveh > div { display: flex; flex-direction: column; min-width: 0; }
.admin-tveh strong { font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-tveh span { font-size: 11.5px; margin-top: 2px; }
.admin-tprice { font-family: var(--font-display); font-weight: 700; font-size: 15px; }
.admin-tactions { display: flex; gap: 8px; justify-content: flex-end; }
.admin-iconbtn { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 10px; border: 1px solid var(--line); color: var(--text-dim); transition: all .3s var(--ease-out); }
.admin-iconbtn:hover { color: var(--blue-bright); border-color: var(--blue); background: var(--blue-soft); transform: translateY(-2px); }
.admin-iconbtn.danger:hover { color: var(--red); border-color: var(--red); background: rgba(255,94,107,0.1); }
.admin-empty { padding: 50px; text-align: center; color: var(--text-faint); }
.text-faint { color: var(--text-faint); }

/* ---------------- Editor ---------------- */
.editor-content { padding-block: 40px 90px; }
.editor-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 34px; }
.editor-head .kicker { display: inline-flex; margin-bottom: 14px; }
.editor-head-actions { display: flex; gap: 12px; }
.editor-grid { display: grid; grid-template-columns: 1fr 380px; gap: 24px; align-items: start; }
.editor-main { display: flex; flex-direction: column; gap: 20px; }
.editor-side { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 96px; }
.editor-section { padding: 26px 26px 28px; }
.editor-section-title { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--blue-bright); margin-bottom: 22px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.editor-section-body { display: flex; flex-direction: column; gap: 18px; }
.editor-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.editor-row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

.editor-toggle { display: flex; align-items: center; gap: 12px; cursor: pointer; font-weight: 500; font-size: 14.5px; }
.editor-toggle input { position: absolute; opacity: 0; }
.editor-toggle-track { width: 46px; height: 26px; border-radius: 100px; background: var(--surface-3); border: 1px solid var(--line-2); position: relative; transition: background .3s; flex-shrink: 0; }
.editor-toggle-thumb { position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 50%; background: var(--text-dim); transition: transform .3s var(--spring), background .3s; }
.editor-toggle input:checked + .editor-toggle-track { background: var(--blue); border-color: var(--blue); }
.editor-toggle input:checked + .editor-toggle-track .editor-toggle-thumb { transform: translateX(20px); background: #fff; }

.editor-preview { pointer-events: none; }
.editor-preview .vcard { transform: none !important; }

@media (max-width: 1000px) {
  .editor-grid { grid-template-columns: 1fr; }
  .editor-side { position: static; }
  .admin-stats { grid-template-columns: repeat(2, 1fr); }
  .admin-stat-wide { grid-column: span 2; }
  .admin-trow { grid-template-columns: 2fr 1fr 1fr; }
  .admin-trow > :nth-child(4), .admin-trow > :nth-child(5) { display: none; }
}
@media (max-width: 620px) {
  .editor-row-2, .editor-row-3 { grid-template-columns: 1fr; }
  .admin-stats { grid-template-columns: 1fr; }
  .admin-stat-wide { grid-column: auto; }
  .admin-trow { grid-template-columns: 1.6fr 1fr auto; gap: 10px; padding-inline: 16px; }
  .admin-trow > :nth-child(3) { display: none; }
  .admin-bar-view { display: none; }
}
