/* ─────────────────────────────────────────────────────────────────
   Auto Repair Skill Bot — UI v2
   Design language: Restaurant bot — flat black, amber accent,
   Figtree display font, chat-as-hero, clean sidebar card
──────────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700&display=swap');

:root {
  --bg:          #0a0a0a;
  --surface:     #111111;
  --surface-2:   #181818;
  --border:      #222222;
  --border-2:    #2e2e2e;
  --text:        #f0f0f0;
  --text-2:      #888888;
  --text-3:      #555555;
  --accent:      #e8a020;
  --accent-dim:  rgba(232,160,32,.10);
  --accent-glow: rgba(232,160,32,.22);
  --danger:      #e05050;
  --success:     #3ecf8e;
  --radius:      12px;
  --radius-sm:   8px;
  --font:        'Figtree', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0}
html,body,body.arsb-shell,#page,#primary,#content,.site,.site-content,.site-main,main.site-main{background:var(--bg)!important;color:var(--text)!important}
body{font-family:var(--font)!important;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;margin:0;min-height:100vh}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
pre{white-space:pre-wrap;font-family:var(--font)}
a{color:var(--accent);text-decoration:none}

/* SAD utility */
.ff-hidden{display:none !important}

/* ── Shell ── */
.arsb-app-shell{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;min-height:100vh}

/* ── Top bar ── */
.arsb-topbar{display:flex;align-items:center;padding:13px 28px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}
.arsb-topbar__back{display:flex;align-items:center;gap:6px;color:var(--text-2);font-size:13px;font-weight:500;text-decoration:none;transition:color .15s}
.arsb-topbar__back:hover{color:var(--text)}
.arsb-topbar__sep{width:1px;height:14px;background:var(--border-2);margin:0 14px;flex-shrink:0}
.arsb-topbar__crumb{font-size:13px;color:var(--text-2);font-weight:500}
.arsb-topbar__tenant{font-size:13px;color:var(--text-3);margin-left:14px}
.arsb-topbar__spacer{flex:1}
.arsb-topbar__session{font-size:11px;color:var(--text-3);font-family:ui-monospace,monospace}

/* ── Brand ── */
.arsb-brand{padding:28px 28px 0}
.arsb-brand__eyebrow{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px}
.arsb-brand h1{font-size:30px;font-weight:700;line-height:1.1;margin-bottom:8px}
.arsb-brand p{font-size:14px;color:var(--text-2);max-width:520px}
/* hide meta pills from old topbar - rendered as topbar now */
.arsb-topbar__meta{display:flex;gap:8px;align-items:center}
.arsb-meta-pill{font-size:12px;color:var(--text-3);padding:0}
.arsb-meta-pill+.arsb-meta-pill::before{content:'·';margin-right:8px;color:var(--border-2)}

/* ── Tabs ── */
.arsb-tabs{display:flex;padding:0 28px;border-bottom:1px solid var(--border);margin-top:20px;overflow-x:auto;scrollbar-width:none;gap:0}
.arsb-tabs::-webkit-scrollbar{display:none}
.arsb-tab{padding:13px 18px;background:transparent;border:none;color:var(--text-2);font-size:14px;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s,border-color .15s}
.arsb-tab:hover{color:var(--text)}
.arsb-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}

/* ── Layout ── */
.arsb-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;flex:1;align-items:start;padding:28px}
.arsb-main,.arsb-sidebar{display:grid;gap:14px}

/* ── Panels ── */
.arsb-panel{display:none}
.arsb-panel.is-active{display:block}

/* ── Console ── */
.arsb-console-grid{display:grid;gap:16px}

/* Chat area */
.arsb-chatlog-wrap,.arsb-console-chat{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;min-height:300px;max-height:420px;overflow-y:auto;
  display:flex;flex-direction:column;gap:10px;
  scrollbar-width:thin;scrollbar-color:var(--border-2) transparent
}
.arsb-chatlog{display:flex;flex-direction:column;gap:10px;flex:1}
.arsb-bubble{max-width:82%;padding:12px 16px;border-radius:10px;font-size:14px;line-height:1.55}
.arsb-bubble--assistant{background:var(--surface-2);border:1px solid var(--border);color:var(--text);align-self:flex-start}
.arsb-bubble--user{background:var(--accent-dim);border:1px solid rgba(232,160,32,.18);color:var(--text);align-self:flex-end}

/* Input row */
.arsb-input-row{display:flex;gap:10px;align-items:stretch}
.arsb-chatbar{
  flex:1;display:flex;align-items:center;
  background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius);
  padding:0 14px;transition:border-color .15s
}
.arsb-chatbar:focus-within{border-color:var(--accent)}
.arsb-chatbar input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:14px;padding:15px 0}
.arsb-chatbar input::placeholder{color:var(--text-3)}
#arsb-chat-send{
  width:50px;height:50px;border-radius:10px;
  background:var(--accent);border:none;color:#000;font-size:18px;
  display:grid;place-items:center;flex-shrink:0;
  transition:opacity .15s,transform .1s
}
#arsb-chat-send:hover{opacity:.85;transform:scale(1.04)}

/* Mic */
.arsb-mic-row{display:flex;align-items:center;gap:10px}
#arsb-voice-toggle{
  width:50px;height:50px;border-radius:50%;
  border:1px solid var(--border-2);background:var(--surface);
  color:var(--text-2);font-size:20px;display:grid;place-items:center;
  transition:border-color .15s,color .15s,box-shadow .2s
}
#arsb-voice-toggle:hover{border-color:var(--accent);color:var(--accent)}
body.arsb-voice-live #arsb-voice-toggle{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
#arsb-voice-stop{background:transparent;border:none;color:var(--text-3);font-size:13px;padding:0 4px;transition:color .15s}
#arsb-voice-stop:hover{color:var(--text)}
#arsb-camera-toggle{width:50px;height:50px;border-radius:50%;border:1px solid var(--border-2);background:var(--surface);color:var(--text-2);font-size:20px;display:grid;place-items:center;transition:border-color .15s}

/* Try saying */
.arsb-try-saying-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.arsb-try-saying-head{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;cursor:pointer;user-select:none;font-size:13px;color:var(--text-2);transition:color .15s}
.arsb-try-saying-head:hover{color:var(--text)}
.arsb-try-saying,.arsb-try-saying-body{display:flex;gap:8px;flex-wrap:wrap;padding:0 18px 14px}
.arsb-chip{padding:6px 13px;border-radius:999px;border:1px solid var(--border-2);background:var(--surface-2);color:var(--text-2);font-size:13px;transition:border-color .15s,color .15s}
.arsb-chip:hover{border-color:var(--accent);color:var(--text)}

/* VAD / session note */
.arsb-vad-bar{padding:4px 0 0}
#ffConsoleSessNote{font-size:11px;color:var(--text-3);padding:2px 0}

/* Quick action cards */
.arsb-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.arsb-card-grid--compact{grid-template-columns:repeat(2,minmax(0,1fr))}
.arsb-card{display:flex;gap:12px;align-items:flex-start;width:100%;text-align:left;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);transition:border-color .15s,background .15s}
.arsb-card:hover{border-color:var(--border-2);background:var(--surface-2)}
.arsb-card.is-selected{border-color:var(--accent);background:var(--accent-dim)}
.arsb-card.is-highlighted{border-color:var(--text);animation:arsbPulse .9s ease}
.arsb-card__visual{width:42px;height:42px;border-radius:9px;background:var(--surface-2);display:grid;place-items:center;font-size:18px;flex-shrink:0}
.arsb-card__icon{font-size:18px;width:34px;height:34px;border-radius:8px;background:var(--surface-2);display:grid;place-items:center;flex-shrink:0}
.arsb-card__body{display:grid;gap:3px}
.arsb-card__body strong{font-size:13px;font-weight:600}
.arsb-card__body span{color:var(--text-2);font-size:12px;line-height:1.4}

/* ── Sidebar ── */
.arsb-progress-card,.arsb-summary-card,.arsb-escalation-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.arsb-progress-card__head,.arsb-summary-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px}
.arsb-progress-card h3,.arsb-summary-card h3,.arsb-escalation-card h3{font-size:14px;font-weight:600}
.arsb-progress-card__head div{font-size:12px;color:var(--text-3)}
.arsb-progress-bar{height:3px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin:4px 0 8px}
.arsb-progress-bar span{display:block;height:100%;width:0;background:var(--accent);transition:width .4s ease}
#arsb-progress-text{font-size:12px;color:var(--text-3)}
.arsb-step-tracker{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:5px}
.arsb-step-tracker li{display:flex;gap:9px;align-items:center;color:var(--text-3);font-size:12px;padding:8px 11px;border-radius:var(--radius-sm);background:var(--surface-2)}
.arsb-step-tracker li span{width:20px;height:20px;border-radius:50%;background:var(--border);display:grid;place-items:center;font-size:10px;flex-shrink:0}
.arsb-step-tracker li.is-current{color:var(--text);background:var(--accent-dim)}
.arsb-step-tracker li.is-current span{background:var(--accent);color:#000}
.arsb-step-tracker li.is-complete span{background:var(--surface-2);color:var(--success)}
.arsb-summary-lines{display:grid;gap:6px;margin:10px 0;font-size:13px;color:var(--text-2)}
.arsb-summary-detail{font-size:13px;color:var(--text-2)}
.arsb-summary-meta{font-size:12px;color:var(--text-3);margin-top:8px}
.arsb-escalation-card p{font-size:13px;color:var(--text-2);margin-top:6px}
.arsb-escalation-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}

/* ── Buttons ── */
/* ── Platform canonical button system (ff-btn) ── */
.ff-btn{background:var(--accent);color:#0f0f11;border:1px solid transparent;border-radius:10px;padding:11px 18px;cursor:pointer;font-family:var(--sans)!important;font-size:.9rem;font-weight:700;transition:all .15s;box-shadow:0 2px 6px rgba(212,168,67,.2);display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}
.ff-btn:hover{filter:brightness(1.08);box-shadow:0 3px 10px rgba(212,168,67,.3)}
.ff-btn-ghost{background:var(--surface-1);color:var(--text-1);border-color:var(--border-2);box-shadow:var(--shadow-sm)}
.ff-btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:rgba(212,168,67,.08);box-shadow:none}
.ff-btn-danger{background:rgba(224,80,80,.12);border-color:rgba(224,80,80,.35);color:#fc8080;box-shadow:none}
.ff-btn-danger:hover{background:rgba(224,80,80,.22)}
.ff-btn-sm{padding:7px 13px;font-size:.82rem}
.ff-btn-link{background:transparent;border:none;color:var(--accent);padding:0;font-size:13px;cursor:pointer;font-weight:500}
.ff-btn-link:hover{text-decoration:underline}
.arsb-voice-controls{display:flex;gap:8px;align-items:center}
#arsb-voice-status{font-size:12px;color:var(--text-3);padding:5px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border)}

/* ── Inner panels ── */
.arsb-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px}
.arsb-panel-head h2{font-size:20px;font-weight:700;margin-bottom:4px}
.arsb-panel-head p{font-size:13px;color:var(--text-2)}
.arsb-inline-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.arsb-inline-head h3{font-size:15px;font-weight:600}

.arsb-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}
.arsb-field{display:grid;gap:5px}
.arsb-field span{font-size:12px;color:var(--text-2);font-weight:500}
.arsb-field input,.arsb-field select,.arsb-field textarea{width:100%;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text);padding:10px 12px;border-radius:var(--radius-sm);outline:none;font-size:14px;transition:border-color .15s}
.arsb-field input:focus,.arsb-field select:focus,.arsb-field textarea:focus{border-color:var(--accent)}
.arsb-field--full{grid-column:1/-1}
.arsb-form-section{display:grid;gap:12px;margin-bottom:16px}
.arsb-question-list{margin:0;padding-left:18px;color:var(--text-2);display:grid;gap:6px;font-size:13px}
.arsb-help-text{font-size:12px;color:var(--text-3);margin-top:4px}

.arsb-info-card,.arsb-list-card,.arsb-side-card,.arsb-upload-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.arsb-side-card h3,.arsb-info-card h3{font-size:13px;font-weight:600;margin-bottom:8px}
.arsb-side-card p,.arsb-info-card p{font-size:13px;color:var(--text-2)}
.arsb-side-card pre{font-size:12px;color:var(--text-2)}
.arsb-info-card--alert{border-color:rgba(224,80,80,.3);background:rgba(224,80,80,.05)}
.arsb-console-side{display:grid;gap:12px}

.arsb-list-card{display:grid;gap:9px;margin-bottom:10px}
.arsb-list-card__head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.arsb-list-card__copy{display:grid;gap:5px;font-size:13px;color:var(--text-2)}
.arsb-status-pill{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-2);font-size:11px;font-weight:500;text-transform:capitalize;color:var(--text-2)}

.arsb-alert{padding:12px 15px;border-radius:var(--radius-sm);border:1px solid rgba(224,80,80,.3);background:rgba(224,80,80,.05);display:grid;gap:5px;margin-bottom:14px;font-size:13px;color:#fc8080}
.arsb-upload-box{display:grid;gap:12px}
.arsb-upload-actions{display:flex;gap:10px;flex-wrap:wrap}
.arsb-media-group{padding:9px 12px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);margin-top:8px}
.arsb-media-group h4{margin:0 0 8px;font-size:13px}
.arsb-media-pill{display:inline-flex;padding:3px 9px;border-radius:999px;background:var(--surface);margin:3px 4px 0 0;color:var(--text-2);font-size:12px;border:1px solid var(--border-2)}
.arsb-issue-list{display:grid;gap:10px}
.arsb-settings-grid,.arsb-contact-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.arsb-support-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.arsb-empty,.arsb-empty-inline{font-size:13px;color:var(--text-3)}
.arsb-nav-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

@keyframes arsbPulse{0%{transform:scale(1)}40%{transform:scale(1.015)}100%{transform:scale(1)}}

@media(max-width:1100px){.arsb-layout{grid-template-columns:1fr;padding:20px}.arsb-sidebar{order:-1}.arsb-card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.arsb-layout{padding:14px}.arsb-brand{padding:16px 14px 0}.arsb-tabs{padding:0 14px}.arsb-topbar{padding:11px 14px}.arsb-brand h1{font-size:22px}.arsb-card-grid,.arsb-card-grid--compact,.arsb-form-grid,.arsb-settings-grid,.arsb-contact-cards,.arsb-support-layout{grid-template-columns:1fr}}

/* ── C-48: Wake Word State Indicator ─────────────────────────────── */
.ww-state-indicator { display:flex; align-items:center; gap:5px;
  font-size:.75rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.04em; opacity:.75; transition:opacity .3s; margin-top:6px; }
.ww-dot { width:8px; height:8px; border-radius:50%;
  background:#9ca3af; flex-shrink:0; }
.ww-state-indicator.ww-sleeping .ww-dot { background:#f59e0b;
  animation:ww-pulse 2s ease-in-out infinite; }
.ww-state-indicator.ww-sleeping .ww-label::after { content:'Sleeping'; }
.ww-state-indicator.ww-listening .ww-dot { background:#22c55e;
  animation:ww-pulse .8s ease-in-out infinite; }
.ww-state-indicator.ww-listening .ww-label::after { content:'Listening'; }
.ww-state-indicator.ww-dormant .ww-dot { background:#9ca3af; }
.ww-state-indicator.ww-dormant { opacity:.35; }
.ww-state-indicator.ww-dormant .ww-label::after { content:'Off'; }
@keyframes ww-pulse { 0%,100%{opacity:1} 50%{opacity:.25} }
/* ── End C-48 ──────────────────────────────────────────────────────── */

/* ── Media toolbar (ff-media-bar) ── */
.ff-media-bar{display:flex;align-items:center;gap:6px;margin-top:10px;flex-wrap:wrap}
.ff-icon-btn{width:38px;height:38px;padding:0;border-radius:10px;border:1px solid var(--border-2);background:var(--surface-1);color:var(--text-1);display:grid;place-items:center;cursor:pointer;transition:all .15s;flex-shrink:0}
.ff-media-btn{width:38px;height:38px}
.ff-icon-btn:hover,.ff-media-btn:hover{color:var(--accent);border-color:var(--accent);background:rgba(212,168,67,.08)}
.ff-icon-btn.is-active-voice{color:var(--accent);border-color:var(--accent);background:rgba(212,168,67,.12)}
.ff-icon-btn.is-active-stop{color:var(--err,#fc8080);border-color:rgba(192,57,43,.3);background:rgba(192,57,43,.07)}
.ff-icon-btn.is-muted{color:var(--warn,#f59e0b);border-color:rgba(184,110,0,.3);background:rgba(184,110,0,.07)}
.ff-media-divider{width:1px;height:24px;background:var(--border-2);margin:0 2px;flex-shrink:0}

/* ── VAD dot-bar ── */
.ff-vad-bar{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--surface-2);border:1px solid var(--accent);border-radius:10px;width:fit-content}
.ff-vad-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.3;flex-shrink:0}
.ff-vad-bar.is-speaking .ff-vad-dot:nth-child(1){animation:ff-vad .8s ease-in-out infinite 0s}
.ff-vad-bar.is-speaking .ff-vad-dot:nth-child(2){animation:ff-vad .8s ease-in-out infinite .1s}
.ff-vad-bar.is-speaking .ff-vad-dot:nth-child(3){animation:ff-vad .8s ease-in-out infinite .2s}
.ff-vad-bar.is-speaking .ff-vad-dot:nth-child(4){animation:ff-vad .8s ease-in-out infinite .1s}
.ff-vad-bar.is-speaking .ff-vad-dot:nth-child(5){animation:ff-vad .8s ease-in-out infinite 0s}
.ff-vad-label{font-size:.75rem;color:var(--text-2);margin-left:4px}
@keyframes ff-vad{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.8)}}
