/* =========================================================================
   NORTHPEAK STUDIO — admin dashboard
   Builds on the design tokens in style.css
   ========================================================================= */

body.admin { background: var(--paper-2); }

/* ----- login ----- */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 1.4rem; }
.login-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: clamp(1.8rem, 4vw, 2.8rem); width: min(100%, 400px); box-shadow: var(--shadow);
  text-align: center;
}
.login-card .brand { justify-content: center; margin-bottom: 1.6rem; }
.login-card h1 { font-size: var(--step-2); margin-bottom: .4rem; }
.login-card p { font-size: var(--step--1); color: var(--muted); margin-bottom: 1.6rem; }
.login-card .field { text-align: left; }
.login-err { color: #c0392b; font-size: var(--step--1); min-height: 1.2em; margin-top: .8rem; }
.login-hint { font-size: var(--step--1); color: var(--muted); margin-top: 1.4rem; }

/* ----- top bar ----- */
.admin-bar {
  background: var(--dark); color: var(--on-dark); position: sticky; top: 0; z-index: 30;
}
.admin-bar .inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.admin-bar .brand { color: var(--on-dark); font-size: 1.2rem; }
.admin-bar .right { display: flex; align-items: center; gap: 1rem; }
.admin-bar .tag { font-size: var(--step--1); color: var(--on-dark-mut); border: 1px solid #ffffff22; padding: .3em .8em; border-radius: 100px; }

.admin-main { padding-block: 2rem 4rem; }
.admin-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.6rem; }
.admin-head h1 { font-size: var(--step-3); }
.admin-head p { color: var(--muted); font-size: var(--step--1); }

/* ----- stat cards ----- */
.stat-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 2rem; }
.stat-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 1.4rem 1.5rem; }
.stat-card .v { font-family: var(--serif); font-size: var(--step-3); line-height: 1; }
.stat-card .k { font-size: var(--step--1); color: var(--muted); margin-top: .5rem; display: flex; align-items: center; gap: .5rem; }
.stat-card .k .ic { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* ----- panel ----- */
.panel { background: #fff; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.panel-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.3rem; border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.panel-head h2 { font-size: var(--step-1); }
.toolbar { display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; }
.toolbar .input, .toolbar .select { padding: .55em .9em; font-size: var(--step--1); width: auto; }
.toolbar .search { min-width: 200px; }

.btn-sm { padding: .55em 1em; font-size: var(--step--1); border-radius: 100px; border: 1px solid var(--line); background: #fff; cursor: pointer; font-weight: 600; transition: all .2s; display: inline-flex; align-items: center; gap: .4rem; }
.btn-sm:hover { border-color: var(--ink); }
.btn-sm.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-sm.primary:hover { background: var(--accent-2); }
.btn-sm.danger:hover { border-color: #c0392b; color: #c0392b; }

/* ----- table ----- */
.table-wrap { overflow-x: auto; }
table.leads { width: 100%; border-collapse: collapse; font-size: var(--step--1); }
table.leads th { text-align: left; padding: .85rem 1.3rem; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; font-size: .72rem; border-bottom: 1px solid var(--line); white-space: nowrap; }
table.leads td { padding: .9rem 1.3rem; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
table.leads tr { cursor: pointer; transition: background .15s; }
table.leads tbody tr:hover { background: var(--paper); }
table.leads .nm { font-weight: 600; color: var(--ink); }
table.leads .sub { color: var(--muted); font-size: .8rem; }
table.leads td.nowrap { white-space: nowrap; }

.empty { padding: 3rem 1.3rem; text-align: center; color: var(--muted); }

/* status pill + select */
.status { display: inline-flex; align-items: center; gap: .4rem; padding: .3em .7em; border-radius: 100px; font-size: .75rem; font-weight: 600; border: 1px solid transparent; }
.status::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.status.New { color: #2563eb; background: #2563eb14; }
.status.Contacted { color: #b45309; background: #b4530914; }
.status.Proposal { color: #7c3aed; background: #7c3aed14; }
.status.Won { color: #15803d; background: #15803d14; }
.status.Lost { color: #9ca3af; background: #9ca3af1f; }

.status-select { border: 1px solid var(--line); border-radius: 100px; padding: .35em 1.8em .35em .8em; font-size: .75rem; font-weight: 600; cursor: pointer; background-color: #fff; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237B746A' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .6em center; }

/* tabs */
.tabs { display: flex; gap: .4rem; }
.tab { background: none; border: 0; padding: .5em 1em; font-size: var(--step--1); font-weight: 600; color: var(--muted); cursor: pointer; border-radius: 100px; }
.tab.active { background: var(--ink); color: var(--paper); }

/* ----- detail drawer ----- */
.drawer-bg { position: fixed; inset: 0; background: rgba(24,22,18,.45); backdrop-filter: blur(3px); z-index: 60; opacity: 0; pointer-events: none; transition: opacity .3s; }
.drawer-bg.open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; height: 100%; width: min(100%, 460px);
  background: var(--paper); z-index: 61; box-shadow: var(--shadow-lg);
  transform: translateX(100%); transition: transform .4s var(--ease);
  display: flex; flex-direction: column;
}
.drawer.open { transform: none; }
.drawer-head { padding: 1.5rem; border-bottom: 1px solid var(--line); display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.drawer-head h2 { font-size: var(--step-2); }
.drawer-head .meta { font-size: var(--step--1); color: var(--muted); margin-top: .3rem; }
.drawer-body { padding: 1.5rem; overflow-y: auto; flex: 1; }
.drawer-body .row { display: flex; gap: 1rem; padding: .7rem 0; border-bottom: 1px solid var(--line-soft); font-size: var(--step--1); }
.drawer-body .row .lbl { color: var(--muted); width: 110px; flex: none; }
.drawer-body .row .val { color: var(--ink); font-weight: 500; word-break: break-word; }
.drawer-body .row .val a { color: var(--accent); border-bottom: 1px solid var(--line); }
.drawer-msg { background: #fff; border: 1px solid var(--line); border-radius: var(--r-sm); padding: 1rem; margin-top: 1rem; white-space: pre-wrap; line-height: 1.5; font-size: var(--step--1); }
.drawer-foot { padding: 1.2rem 1.5rem; border-top: 1px solid var(--line); display: flex; gap: .6rem; flex-wrap: wrap; }
.drawer label.section { display: block; font-size: var(--step--1); font-weight: 600; margin: 1.4rem 0 .5rem; }
.drawer .save-row { display: flex; align-items: center; gap: .8rem; margin-top: .8rem; }
.saved-note { font-size: var(--step--1); color: var(--accent); opacity: 0; transition: opacity .3s; }
.saved-note.show { opacity: 1; }
.close-x { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--line); background: #fff; cursor: pointer; flex: none; }
.close-x:hover { border-color: var(--ink); }

@media (max-width: 820px) {
  .stat-cards { grid-template-columns: repeat(2, 1fr); }
  table.leads .hide-sm { display: none; }
}
