/* Login page + admin panel (sidebar, tables, forms). nav-auth-link/.nav-auth-form/.form-grid/.input-field/.btn-outline/.form-alert live in styles.css (loaded globally on every page) — admin views don't need to load contact.css. */

.login-wrap{max-width:420px}
.login-form{display:flex;flex-direction:column;gap:18px}
.login-submit{width:100%}

.admin-empty{color:var(--muted);padding:28px 20px;text-align:center;border:1px dashed var(--border);border-radius:var(--r-card);font-size:.9rem}
.admin-subhead{margin:40px 0 18px;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:10px}
.admin-subhead::before{content:"";width:4px;height:1.1em;background:var(--cyan);border-radius:2px;flex-shrink:0}
.admin-add-btn{display:inline-block;margin-bottom:24px}

.admin-form{max-width:760px;margin-bottom:10px}
.admin-form .btn{margin-top:10px}
.admin-form-wide{max-width:920px}

.upload-progress-wrap{display:flex;align-items:center;gap:10px;margin-top:14px}
.upload-progress-bar{flex:1;height:8px;border-radius:4px;background:var(--border);overflow:hidden}
.upload-progress-fill{height:100%;width:0%;background:var(--cyan);border-radius:4px;transition:width .15s linear}
.upload-progress-label{color:var(--muted);font-size:.85rem;min-width:3.5em;text-align:left}

.admin-repeat-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.admin-repeat-row{display:flex;gap:8px;align-items:center}
.admin-repeat-row input{flex:1;min-width:0}
.admin-repeat-row .admin-row-remove{flex-shrink:0}
.admin-repeat-row-3 input:last-of-type{flex:0 0 140px}

.admin-color-field .admin-color-row{display:flex;align-items:center;gap:10px}
.admin-color-field input[type="color"]{width:44px;height:38px;padding:2px;cursor:pointer}
.admin-color-hex{font-size:.82rem;color:var(--muted);direction:ltr}

.admin-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-card)}
.admin-table{width:100%;border-collapse:collapse;font-size:.92rem}
.admin-table th,.admin-table td{padding:12px 14px;text-align:right;border-bottom:1px solid var(--border);white-space:nowrap}
.admin-table .admin-table-cell-wrap{white-space:normal}
.admin-table th{color:var(--muted);font-weight:600;background:var(--card2)}
.admin-table tr:last-child td{border-bottom:none}
.admin-row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.admin-row-actions form{display:inline}
.admin-grant-form{display:flex;flex-direction:column;gap:8px}
.admin-table .admin-checkbox-list{max-width:280px;max-height:90px;overflow-y:auto;gap:6px 10px;padding:2px}

.btn-sm{padding:7px 16px;font-size:.85rem}

.admin-checkbox-list{display:flex;flex-wrap:wrap;gap:10px 16px;margin-bottom:10px}
.admin-checkbox{display:flex;align-items:center;gap:6px;font-size:.88rem;color:var(--text)}

.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:.78rem;font-weight:600;white-space:nowrap}
.status-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.status-badge.status-new{background:rgba(0,229,255,.12);color:var(--cyan)}
.status-badge.status-contacted{background:rgba(123,97,255,.12);color:var(--purple)}
.status-badge.status-quoted{background:rgba(255,107,53,.12);color:var(--orange)}
.status-badge.status-closed{background:color-mix(in srgb, var(--muted) 18%, transparent);color:var(--muted)}

/* Product/order/payment status variants — same visual language as leads's status-badge above */
.status-badge.status-draft,.status-badge.status-pending,.status-badge.status-pending_payment,.status-badge.status-verifying{background:color-mix(in srgb, var(--orange) 16%, transparent);color:var(--orange)}
.status-badge.status-published,.status-badge.status-paid,.status-badge.status-confirmed{background:rgba(0,229,255,.12);color:var(--cyan)}
.status-badge.status-archived,.status-badge.status-cancelled{background:color-mix(in srgb, var(--muted) 18%, transparent);color:var(--muted)}
.status-badge.status-failed,.status-badge.status-rejected{background:rgba(255,71,87,.14);color:#ff6b6b}

.admin-shell{display:flex;flex-direction:column;gap:20px;max-width:var(--maxw);margin:0 auto;padding:calc(var(--nav-h) + 30px) 24px 60px;min-height:100vh}
.admin-topbar{width:100%;background:linear-gradient(160deg, var(--card), color-mix(in srgb, var(--card) 80%, var(--cyan) 6%));border:1px solid var(--border);border-radius:var(--r-card);padding:14px 18px;box-shadow:0 18px 40px -22px rgba(0,0,0,.45)}
.admin-topbar-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.admin-brand{font-weight:700;font-size:1.05rem}
.admin-brand b{color:var(--cyan)}
.admin-topbar-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;flex-shrink:0;border:0;background:transparent;cursor:pointer;padding:8px}
.admin-topbar-toggle span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px;transition:transform .2s,opacity .2s}
.admin-topbar.open .admin-topbar-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.admin-topbar.open .admin-topbar-toggle span:nth-child(2){opacity:0}
.admin-topbar.open .admin-topbar-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.admin-topbar-panel{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.admin-topbar-nav{position:static;height:auto;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.admin-topbar-nav a{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--r-btn);color:var(--muted);font-size:.92rem;border-bottom:2px solid transparent;transition:color .2s,background .2s,border-color .2s}
.admin-nav-ic{width:18px;height:18px;flex-shrink:0;color:var(--muted);transition:color .2s}
.admin-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--orange);color:#fff;font-size:.72rem;font-weight:700;line-height:1;flex-shrink:0}
.admin-topbar-nav a:hover{color:var(--text);background:var(--card2)}
.admin-topbar-nav a:hover .admin-nav-ic{color:var(--cyan)}
.admin-topbar-nav a.active{color:var(--cyan);background:var(--card2);border-bottom-color:var(--cyan)}
.admin-topbar-nav a.active .admin-nav-ic{color:var(--cyan)}
.admin-logout{display:flex;align-items:center;gap:10px;flex-shrink:0}
.admin-user{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--muted)}
.admin-user-dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);flex-shrink:0}

.admin-content{flex:1;min-width:0}
.admin-page h1{margin-bottom:24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}

.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}
.admin-stat-card{display:flex;flex-direction:column;gap:6px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-card);padding:20px;text-align:center;transition:border-color .2s,transform .2s,box-shadow .2s}
.admin-stat-card:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:0 10px 24px -8px rgba(0,229,255,.25)}
.admin-stat-num{font-size:1.8rem;font-weight:700;color:var(--cyan)}

@media (max-width:760px){
  .admin-shell{padding-top:calc(var(--nav-h) + 16px);padding-inline:16px}
  .admin-topbar-toggle{display:flex}
  .admin-topbar-panel{display:none}
  .admin-topbar.open .admin-topbar-panel{display:flex;flex-direction:column;align-items:stretch;flex-wrap:nowrap;margin-top:14px}
  .admin-topbar-nav{flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:3px}
  .admin-logout{flex-direction:row;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}
  .admin-logout .btn{width:auto}

  /* Tables become a stack of bordered cards — each <td> shows its column
     label (via data-label) instead of relying on a <thead> row, so nothing
     needs horizontal scrolling on narrow screens. */
  .admin-table-wrap{overflow-x:visible;border:none}
  .admin-table{font-size:.88rem}
  .admin-table thead{display:none}
  .admin-table,.admin-table tbody,.admin-table tr{display:block;width:100%}
  .admin-table tr{margin-bottom:12px;border:1px solid var(--border);border-radius:var(--r-card);padding:4px 14px;background:var(--card)}
  .admin-table tr:last-child{margin-bottom:0}

  .admin-table:not(.admin-table-kv) td{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);white-space:normal}
  .admin-table:not(.admin-table-kv) td:last-child{border-bottom:none}
  .admin-table:not(.admin-table-kv) td::before{content:attr(data-label);color:var(--muted);font-weight:600;font-size:.78rem;flex-shrink:0}
  .admin-table:not(.admin-table-kv) td.admin-table-cell-wrap{flex-direction:column;align-items:stretch;gap:8px}
  .admin-table:not(.admin-table-kv) td.admin-row-actions{justify-content:flex-start}
  .admin-table:not(.admin-table-kv) td.admin-row-actions::before{content:none}

  /* Key/value detail tables (e.g. a single lead's full record) already read
     fine as plain stacked rows — skip the data-label/flex treatment above. */
  .admin-table.admin-table-kv th,.admin-table.admin-table-kv td{display:block;width:100%;padding:6px 0;border-bottom:none;white-space:normal}
  .admin-table.admin-table-kv th{padding-top:10px;background:none;font-size:.78rem}
  .admin-table.admin-table-kv tr{padding:4px 14px 10px}

  .admin-table .admin-checkbox-list{max-width:none}

  .admin-repeat-row{flex-wrap:wrap}
  .admin-repeat-row input{flex:1 1 100%}
  .admin-repeat-row-3 input:last-of-type{flex:1 1 100%}
  .admin-repeat-row .admin-row-remove{flex:0 0 auto;margin-inline-start:auto}
}
