/* ===========================================================
 * Account console chrome — shared utility classes for the
 * operator (`/profile`, `/cars`, `/cars/:id/...`) surfaces.
 * Designed against the CSS variables declared in the
 * `account` layout (mirrors admin/site_admin chrome).
 * =========================================================== */

/* === Top status strip (mirrors admin dashboard's session-strip) === */
.session-strip {
  border: 1px solid var(--line-2);
  background: linear-gradient(90deg, rgba(255,192,67,.06), transparent 35%);
  margin-bottom: 22px;
  position: relative;
}
.session-strip::before {
  content: ''; position: absolute; top: 0; bottom: 0; left: 0; width: 3px;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
}
.strip-line {
  display: flex; align-items: center; gap: 16px;
  padding: 12px 18px;
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase;
  flex-wrap: wrap;
}
.strip-label { color: var(--dim); }
.strip-value { color: var(--text); }
.strip-divider { width: 1px; height: 14px; background: var(--line-2); }
.strip-status {
  margin-left: auto; display: flex; align-items: center; gap: 10px;
  color: var(--green); letter-spacing: 0.18em;
  font-variant-numeric: tabular-nums;
}

/* === KPI gauges === */
.gauges {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-bottom: 30px;
}
.gauge {
  position: relative; padding: 22px 22px 18px;
  background: linear-gradient(180deg, var(--panel) 0%, var(--bg-elev) 100%);
  border: 1px solid var(--line-2);
  overflow: hidden;
}
.gauge::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
}
.gauge-amber::before { background: var(--accent); box-shadow: 0 0 14px rgba(255,192,67,.6); }
.gauge-green::before { background: var(--green);  box-shadow: 0 0 14px rgba(46,230,160,.6); }
.gauge-red::before   { background: var(--red);    box-shadow: 0 0 14px rgba(255,45,61,.6); }
.gauge-blue::before  { background: var(--blue);   box-shadow: 0 0 14px rgba(77,201,255,.6); }
.gauge-dim::before   { background: var(--dim); }
.gauge-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.gauge-label {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.24em; color: var(--muted); text-transform: uppercase;
}
.gauge-num {
  font-family: 'Big Shoulders Display', sans-serif; font-weight: 800;
  font-size: 64px; line-height: .9; color: var(--text);
  letter-spacing: -0.005em; font-variant-numeric: tabular-nums;
}
.gauge-amber .gauge-num { color: #fff1d0; text-shadow: 0 0 18px rgba(255,192,67,.18); }
.gauge-green .gauge-num { color: #d8fff0; }
.gauge-red   .gauge-num { color: #ffd5d9; }
.gauge-blue  .gauge-num { color: #d6efff; }
.gauge-hint {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.18em;
  color: var(--dim); text-transform: uppercase; margin-top: 12px;
}
.gauge-corner {
  position: absolute; width: 8px; height: 8px;
  border-color: var(--line-2);
}
.gauge-corner-tl { top: 5px; left: 5px;  border-top: 1px solid; border-left: 1px solid; }
.gauge-corner-tr { top: 5px; right: 5px; border-top: 1px solid; border-right: 1px solid; }
.gauge-corner-bl { bottom: 5px; left: 5px;  border-bottom: 1px solid; border-left: 1px solid; }
.gauge-corner-br { bottom: 5px; right: 5px; border-bottom: 1px solid; border-right: 1px solid; }

/* === Layout grid === */
.layout-grid {
  display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(0, 1fr); gap: 20px;
}
.layout-main, .layout-aside { display: grid; gap: 20px; align-content: start; }

/* === Panels === */
.panel {
  background: linear-gradient(180deg, var(--panel) 0%, var(--bg-elev) 100%);
  border: 1px solid var(--line-2);
  position: relative;
}
.panel-head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 14px;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.018), transparent);
}
.panel-title-row { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.panel-eyebrow {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.24em;
  color: var(--accent); text-transform: uppercase;
}
.panel-eyebrow.warn { color: var(--amber); }
.panel-eyebrow.dim  { color: var(--dim); }
.panel-eyebrow.red  { color: var(--red); }
.panel-title {
  margin: 0;
  font-family: 'Big Shoulders Display', sans-serif; font-weight: 800; font-size: 28px;
  letter-spacing: 0.04em; line-height: 1;
}
.panel-meta {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.18em;
  color: var(--muted); text-transform: uppercase; white-space: nowrap;
}
.panel-action {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em;
  color: var(--accent); text-decoration: none; text-transform: uppercase;
  border: 1px solid rgba(255,192,67,.35); padding: 6px 10px;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.panel-action:hover { background: var(--accent); color: #1a1408; }
.panel-body { padding: 20px; }
.panel-foot {
  display: flex; gap: 10px; flex-wrap: wrap;
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  background: rgba(0,0,0,.18);
}
.panel-warn { border-color: rgba(255,192,67,.28); }
.panel-warn-stripe {
  height: 4px;
  background: repeating-linear-gradient(45deg, transparent 0 6px, rgba(255,192,67,.5) 6px 12px);
}

/* === Buttons === */
.btn-primary {
  background: var(--accent); color: #1a1408 !important; border: 0;
  padding: 9px 16px; cursor: pointer; text-decoration: none;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700;
  display: inline-block;
}
.btn-primary:hover { background: #ffd166; }
.btn-ghost {
  background: transparent; color: var(--text); border: 1px solid var(--line-2);
  padding: 8px 14px; cursor: pointer; text-decoration: none;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500;
  display: inline-block;
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn-danger {
  background: transparent; color: var(--red); border: 1px solid rgba(255,45,61,.4);
  padding: 8px 14px; cursor: pointer; text-decoration: none;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500;
  display: inline-block;
}
.btn-danger:hover { background: var(--red); color: #fff; border-color: var(--red); }
.warn-action {
  background: var(--amber); color: #1a1408 !important; border: 0;
  padding: 9px 14px; cursor: pointer;
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase; font-weight: 700;
}
.warn-action:hover { background: #ffd166; }

/* === Hub list (cars/teams/etc) === */
.hub-list { list-style: none; margin: 0; padding: 0; }
.hub-row {
  display: grid; grid-template-columns: 70px 1fr auto; gap: 16px;
  align-items: center; padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  transition: background .15s;
  position: relative;
}
.hub-row::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 0;
  background: var(--accent); transition: width .15s;
}
.hub-row:hover::before { width: 2px; }
.hub-row:last-child { border-bottom: 0; }
.hub-row:hover { background: rgba(255,255,255,.018); }
.hub-row-num {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  color: var(--dim); letter-spacing: 0.16em;
}
.hub-row-name {
  font-family: 'Big Shoulders Display', sans-serif; font-weight: 700; font-size: 19px;
  letter-spacing: 0.02em; line-height: 1.1; margin-bottom: 6px;
}
.hub-row-name a { color: var(--text); text-decoration: none; }
.hub-row-name a:hover { color: var(--accent); }
.hub-row-meta {
  font-family: 'Archivo', sans-serif; font-size: 12px; color: var(--muted);
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.hub-row-meta .dot { color: var(--dim); }
.hub-row-meta .mono { font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.hub-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; padding: 3px 7px;
  letter-spacing: 0.18em; border: 1px solid var(--line-2);
  color: var(--muted); text-transform: uppercase;
}
.hub-tag.tag-amber { color: var(--accent); border-color: rgba(255,192,67,.4); }
.hub-tag.tag-green { color: var(--green);  border-color: rgba(46,230,160,.4); }
.hub-tag.tag-red   { color: var(--red);    border-color: rgba(255,45,61,.4); }
.row-link {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em;
  color: var(--muted); text-decoration: none;
  border: 1px solid var(--line-2); padding: 6px 11px;
  transition: all .15s;
}
.row-link:hover { color: var(--accent); border-color: var(--accent); }

/* === Mini list (organizations sidebar etc) === */
.mini-list { list-style: none; margin: 0; padding: 0; }
.mini-list li {
  padding: 11px 20px;
  border-bottom: 1px solid var(--line);
  font-family: 'Archivo', sans-serif; font-size: 13px;
}
.mini-list li:last-child { border-bottom: 0; }
.linky { color: var(--text); text-decoration: none; }
.linky:hover { color: var(--accent); }

/* === Identity card (avatar + dl) === */
.id-grid {
  display: grid; grid-template-columns: 140px 1fr; gap: 24px;
  align-items: start;
}
.id-avatar .avatar {
  width: 128px; height: 128px;
  border: 1px solid var(--line-2);
  background: var(--bg-elev);
}
.id-fields { margin: 0; display: grid; grid-template-columns: 130px 1fr; row-gap: 10px; column-gap: 16px; }
.id-fields dt {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.18em;
  color: var(--dim); text-transform: uppercase; align-self: center;
}
.id-fields dd {
  margin: 0; color: var(--text); font-size: 13.5px;
}
.id-fields dd.mono { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.id-fields .dim { color: var(--dim); }

.action-row {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-top: 22px; padding-top: 16px;
  border-top: 1px dashed var(--line);
}
.panel-profile-nudge {
  border-color: rgba(255,192,67,.35);
  box-shadow: 0 0 0 1px rgba(255,192,67,.05) inset;
}
.setup-list {
  list-style: none; margin: 14px 0 0; padding: 0;
  display: grid; gap: 8px;
}
.setup-list li {
  display: flex; align-items: center; gap: 8px;
  color: var(--text); font-size: 13px;
}
.setup-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--amber); box-shadow: 0 0 10px rgba(255,192,67,.4);
}
.pay-paid { color: var(--green); border-color: rgba(46,230,160,.4); }
.pay-comped { color: var(--blue); border-color: rgba(77,201,255,.4); }
.pay-unpaid { color: var(--amber); border-color: rgba(255,192,67,.4); }

/* === Telemetry feed === */
.feed { list-style: none; margin: 0; padding: 0; }
.feed-item {
  display: grid; grid-template-columns: 50px auto auto 1fr; gap: 8px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
  align-items: center;
}
.feed-item:last-child { border-bottom: 0; }
.feed-time {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--dim);
  letter-spacing: 0.06em; font-variant-numeric: tabular-nums;
}
.feed-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; padding: 3px 7px;
  letter-spacing: 0.18em; border: 1px solid; text-transform: uppercase;
  line-height: 1;
}
.feed-tag.tag-confirmed  { color: var(--green); border-color: rgba(46,230,160,.4); }
.feed-tag.tag-waitlisted { color: var(--blue);  border-color: rgba(77,201,255,.4); }
.feed-tag.tag-pending    { color: var(--amber); border-color: rgba(255,192,67,.4); }
.feed-tag.tag-withdrawn  { color: var(--dim);   border-color: var(--line-2); }
.feed-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.feed-body strong {
  font-family: 'Archivo', sans-serif; font-size: 13px; font-weight: 600; color: var(--text);
}
.feed-rel {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; color: var(--dim);
  letter-spacing: 0.1em;
}

/* === Forms === */
.form-grid { display: grid; gap: 18px; max-width: 640px; }
.form-grid label,
.form-grid .form-field {
  display: grid; gap: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  letter-spacing: 0.18em; color: var(--muted); text-transform: uppercase;
  margin: 0;
}
.form-grid input[type=text],
.form-grid input[type=email],
.form-grid input[type=password],
.form-grid input[type=file],
.form-grid select,
.form-grid textarea {
  background: #0c0f14; color: var(--text);
  border: 1px solid var(--line-2);
  padding: .65rem .8rem;
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  letter-spacing: normal; text-transform: none;
}
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus {
  outline: 1px solid var(--accent); border-color: var(--accent);
}
.form-grid trix-toolbar,
.form-grid trix-editor,
.form-grid .trix-content {
  letter-spacing: normal;
  text-transform: none;
}
.form-grid trix-editor {
  cursor: text;
  color: var(--text);
  font-family: 'Archivo', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  min-height: 150px;
}
.form-grid trix-toolbar .trix-dialogs {
  position: static;
  width: 100%;
}
.form-grid trix-toolbar .trix-dialog {
  position: static;
  inset: auto;
  max-width: none;
  margin-top: 8px;
  background: #0d1014;
  border: 1px solid var(--line-2);
  color: var(--text);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
}
.form-grid trix-toolbar .trix-dialog__link-fields {
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.form-grid trix-toolbar .trix-input--dialog {
  flex: 1 1 260px;
  min-width: 0;
  margin: 0;
  background: #0c0f14;
  border: 1px solid var(--line-2);
  color: var(--text);
  letter-spacing: normal;
  text-transform: none;
}
.form-grid trix-toolbar .trix-dialog__link-fields .trix-button-group {
  flex: 0 0 auto;
  gap: 6px;
}
.form-grid trix-toolbar .trix-button--dialog {
  width: auto;
  height: auto;
  min-width: 72px;
  text-indent: 0;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.form-grid trix-toolbar .trix-button--dialog::before {
  content: none;
}
.form-actions {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  margin-top: 22px; padding-top: 18px;
  border-top: 1px dashed var(--line);
}
.form-errors {
  border: 1px solid rgba(255,45,61,.4);
  background: rgba(255,45,61,.06);
  color: #f7c5cb;
  padding: 12px 16px; margin-bottom: 18px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
}
.form-errors strong { display: block; margin-bottom: 6px; letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
.form-errors ul { margin: 0; padding-left: 18px; }

/* === Photo gallery === */
.photo-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px;
  padding: 20px;
}
.photo-card {
  background: var(--bg-elev);
  border: 1px solid var(--line-2);
  display: flex; flex-direction: column;
}
.photo-card-img {
  aspect-ratio: 4/3; overflow: hidden; background: #000;
  display: grid; place-items: center;
}
.photo-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo-card-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.photo-card-title {
  font-family: 'Big Shoulders Display', sans-serif; font-weight: 700; font-size: 16px;
  letter-spacing: 0.02em; color: var(--text); margin: 0; line-height: 1.1;
}
.photo-card-desc {
  font-family: 'Archivo', sans-serif; font-size: 12.5px; color: var(--muted);
  margin: 0; line-height: 1.4;
}
.photo-card-foot {
  display: flex; gap: 8px; padding: 10px 14px;
  border-top: 1px solid var(--line);
  background: rgba(0,0,0,.18);
}
.photo-card-foot a, .photo-card-foot button {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px;
  letter-spacing: 0.16em; text-transform: uppercase; text-decoration: none;
  padding: 5px 9px; border: 1px solid var(--line-2); background: transparent;
  color: var(--muted); cursor: pointer;
}
.photo-card-foot a:hover { color: var(--accent); border-color: var(--accent); }
.photo-card-foot .photo-del { color: var(--red); border-color: rgba(255,45,61,.35); }
.photo-card-foot .photo-del:hover { background: var(--red); color: #fff; border-color: var(--red); }

/* === Misc === */
.muted-line { color: var(--muted); font-size: 12px; margin: 0 0 14px; }
.empty-state {
  padding: 50px 20px; text-align: center; color: var(--muted);
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em;
}
.empty-state.small { padding: 28px 20px; }
.empty-mark {
  display: block; font-family: 'Big Shoulders Display', sans-serif; font-size: 36px;
  color: var(--dim); margin-bottom: 10px;
}

@media (max-width: 1100px) {
  .gauges { grid-template-columns: repeat(2, 1fr); }
  .layout-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .id-grid { grid-template-columns: 1fr; }
  .id-fields { grid-template-columns: 1fr; row-gap: 4px; }
  .id-fields dt { margin-top: 6px; }
  .hub-row { grid-template-columns: 1fr; }
  .hub-row-num { display: none; }
  .gauges { grid-template-columns: 1fr 1fr; }
}
