/* bridge/bridge.css — Bridge-specific styles */
@keyframes pulse-rec { 0%,100%{opacity:1} 50%{opacity:.3} }

:root {
  --bg:  #0a0f1e; --bg2: #111827; --bg3: #1a2235; --bg4: #0e1528;
  --border:  rgba(255,255,255,.08); --border2: rgba(255,255,255,.16);
  --text:    rgba(255,255,255,.92); --text2:   rgba(255,255,255,.6);
  --text3:   rgba(255,255,255,.35);
  --p:    #00aeef;
  --teal: #0d9488;
}

html.light-mode {
  --bg:#f5f5f7; --bg2:#ffffff; --bg3:#efefef; --bg4:#e5e5ea;
  --border:rgba(0,0,0,.09); --border2:rgba(0,0,0,.16);
  --text:#1a1a2e; --text2:#4b5563; --text3:#9ca3af;
}
html.light-mode body         { background:var(--bg); color:var(--text); }
html.light-mode .tbar        { background:rgba(255,255,255,.92); border-bottom-color:rgba(0,0,0,.1); box-shadow:0 1px 6px rgba(0,0,0,.07); }
html.light-mode .tbar-badge  { background:rgba(0,174,239,.12); color:#0369a1; }
html.light-mode .tbar-sep    { background:rgba(0,0,0,.12); }
html.light-mode .bg-grid     { background-image:linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px); }
html.light-mode .orb         { opacity:.06; }
html.light-mode .card        { background:#ffffff; border-color:rgba(0,0,0,.09); }
html.light-mode .fi          { background:#f5f5f7; border-color:rgba(0,0,0,.14); color:var(--text); }
html.light-mode .fi:focus    { border-color:var(--p); }
html.light-mode .fs          { background:#f5f5f7; border-color:rgba(0,0,0,.14); color:var(--text); }
html.light-mode .flbl        { color:var(--text3); }
html.light-mode .bubble.theirs { background:#f0f0f5; border-color:rgba(0,0,0,.09); }
html.light-mode .bubble.mine   { background:rgba(0,174,239,.1); border-color:rgba(0,174,239,.2); }
html.light-mode .msg-meta    { color:var(--text3); }
html.light-mode .user-pill   { background:rgba(0,0,0,.05); border-color:rgba(0,0,0,.1); }
html.light-mode #tbar-name   { color:var(--text) !important; }
html.light-mode .sb          { background:#f0f0f5; border-right-color:rgba(0,0,0,.09); }
html.light-mode .sb-item     { color:var(--text2); }
html.light-mode .sb-item:hover         { background:rgba(0,0,0,.05); color:var(--text); }
html.light-mode .sb-item.active        { background:rgba(0,174,239,.1); color:#0369a1; }
html.light-mode .sb-item .mi          { color:var(--text3); }
html.light-mode .sb-item.active .mi   { color:#0369a1; }
html.light-mode .sb-foot      { border-top-color:rgba(0,0,0,.08); }
html.light-mode .sb-col-toggle:hover { background:rgba(0,0,0,.06) !important; }
html.light-mode #theme-btn   { background:rgba(0,0,0,.06) !important; border-color:rgba(0,0,0,.12) !important; color:#4b5563 !important; }
html.light-mode #no-access   { background:#0a0f1e !important; }
html.light-mode #no-access * { color:inherit !important; }

/* ── inline colour overrides for light mode ── */
html.light-mode [style*="color:#fff"]:not(.btn):not([class*="badge"]):not([class*="avatar"]):not(button) { color:var(--text) !important; }
html.light-mode [style*="color:rgba(255,255,255,.9"] { color:var(--text)  !important; }
html.light-mode [style*="color:rgba(255,255,255,.8"] { color:var(--text)  !important; }
html.light-mode [style*="color:rgba(255,255,255,.6"] { color:var(--text2) !important; }
html.light-mode [style*="color:rgba(255,255,255,.5"] { color:var(--text3) !important; }
html.light-mode [style*="color:rgba(255,255,255,.4"] { color:var(--text3) !important; }
html.light-mode [style*="color:rgba(255,255,255,.3"] { color:var(--text3) !important; }
html.light-mode [style*="background:#111827"],
html.light-mode [style*="background:#1a2235"],
html.light-mode [style*="background:#0a0f1e"],
html.light-mode [style*="background:#0e1528"]         { background:var(--bg2) !important; }
html.light-mode [style*="background:rgba(255,255,255,.06)"] { background:rgba(0,0,0,.04) !important; }
html.light-mode [style*="background:rgba(255,255,255,.08)"] { background:rgba(0,0,0,.06) !important; }
html.light-mode [style*="background:rgba(255,255,255,.04)"] { background:rgba(0,0,0,.03) !important; }

body  { font-family:'DM Sans',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; overflow-x:hidden; }

/* material icons */
.mi     { font-family:'Material Symbols Outlined'; font-style:normal; font-weight:300; font-size:20px;
          font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24; user-select:none; line-height:1; display:inline-block; }
.mi.xs  { font-size:15px; }
.mi.sm  { font-size:18px; }
.mi.lg  { font-size:28px; }

/* backgrounds */
.bg-grid  { position:fixed; inset:0; background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px); background-size:60px 60px; pointer-events:none; z-index:0; }
.orb      { position:absolute; border-radius:50%; filter:blur(90px); opacity:.08; animation:drift 22s ease-in-out infinite; }
.orb1     { width:700px; height:700px; background:#00aeef; top:-250px; left:-250px; }
.orb2     { width:600px; height:600px; background:#0d9488; bottom:-250px; right:-250px; animation-delay:-8s; }
.orb3     { width:400px; height:400px; background:#7c3aed; top:40%; right:5%; animation-delay:-14s; }
@keyframes drift  { 0%,100%{transform:translate(0,0)} 33%{transform:translate(40px,-30px)} 66%{transform:translate(-30px,40px)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }

/* app layout */
.app  { position:relative; z-index:1; display:grid; grid-template-columns:auto 1fr; grid-template-rows:58px 1fr; flex:1; min-height:0; }
/* Mobile sidebar collapse */
.sb-toggle{display:none;background:none;border:none;color:var(--text2);cursor:pointer;padding:4px}
.sb-backdrop{display:none}
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sb{position:fixed;left:-240px;top:58px;bottom:0;width:230px;z-index:200;transition:left .25s ease;background:var(--bg2)}
  .sb.open{left:0;box-shadow:8px 0 30px rgba(0,0,0,.5)}
  .sb-backdrop{position:fixed;inset:0;top:58px;background:rgba(0,0,0,.5);z-index:199}
  .sb-toggle{display:flex}
  .sb-col-toggle{display:none !important}
  .page{padding:20px 16px}
  .page-title{font-size:18px}
  .msg-list{max-height:calc(100vh - 260px)!important}
  .bubble{max-width:88%}
}
/* Preview mode — visual distinction when admin is "viewing as client" */
body.preview-mode .sb-hdr:first-child::after{content:' (Client View)';color:#fbbf24;font-weight:400;text-transform:none;letter-spacing:0}
body.preview-mode .tbar{border-bottom:2px solid rgba(251,191,36,.4);background:linear-gradient(90deg,rgba(10,15,30,.85),rgba(120,53,15,.15))}
body.preview-mode .sb{border-right-color:rgba(251,191,36,.2)}
body.preview-mode .sb-item.active{background:rgba(251,191,36,.12);color:#fbbf24}
body.preview-mode .sb-item.active .mi{color:#fbbf24}

.tbar { grid-column:1/-1; display:flex; align-items:center; gap:12px; padding:0 22px; border-bottom:1px solid var(--border); background:rgba(10,15,30,.85); backdrop-filter:blur(14px); position:sticky; top:0; z-index:100; }
.tbar-sep   { width:1px; height:20px; background:var(--border2); margin:0 6px; }
.tbar-badge { font-size:10px; font-weight:700; background:rgba(0,174,239,.18); color:var(--p); border-radius:6px; padding:2px 8px; }
.tbar-right { margin-left:auto; display:flex; align-items:center; gap:8px; }
.user-pill  { display:flex; align-items:center; gap:8px; padding:5px 12px 5px 5px; background:rgba(255,255,255,.06); border:1px solid var(--border2); border-radius:20px; cursor:pointer; transition:background .15s; }
.user-pill:hover { background:rgba(255,255,255,.1); }
.avatar     { width:30px; height:30px; border-radius:50%; background:linear-gradient(135deg,#00aeef,#0d9488); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:#fff; flex-shrink:0; }

/* sidebar */
.sb      { background:rgba(8,12,26,.7); border-right:1px solid var(--border); padding:16px 0; display:flex; flex-direction:column; transition:width .25s; overflow:visible; width:230px; }
/* collapsed sidebar (desktop) */
.sb.col  { width:52px; overflow:hidden; }
.sb.col .sb-hdr    { display:none; }
.sb.col .sb-item   { justify-content:center; padding:8px 0; font-size:0; color:transparent; gap:0; margin:1px 0; width:100%; text-align:center; }
.sb.col .sb-item .mi  { font-size:22px; margin:0 auto; color:var(--text3); }
.sb.col .sb-item { position:relative; }
.sb.col .sb-item::after { content:attr(title); position:absolute; left:calc(100% + 8px); top:50%; transform:translateY(-50%); background:#1e293b; border:1px solid rgba(255,255,255,.15); color:#e2e8f0; font-size:11px; font-weight:600; padding:4px 10px; border-radius:6px; white-space:nowrap; pointer-events:none; opacity:0; transition:opacity .15s; z-index:200; box-shadow:0 4px 12px rgba(0,0,0,.3); }
.sb.col .sb-item:hover::after { opacity:1; }
.sb.col .sb-item.active .mi { color:var(--p); }
.sb.col .sb-item svg   { margin:0 auto; }
.sb.col .sb-item span:not(.mi):not(.sb-badge) { display:none; width:0; height:0; overflow:hidden; }
.sb.col .sb-badge  { display:none; }
.sb.col .sb-foot   { display:none; }
.sb.col .admin-only > .sb-hdr { display:none !important; }
.sb.col .admin-only > div:not(.sb-item):not(button) { display:none !important; }
.sb.col .sb-col-toggle .mi::after { content:'chevron_right'; }
.sb-col-toggle:hover { background:rgba(255,255,255,.06) !important; border-radius:8px; }
.app.sb-collapsed .app-switcher { left:64px; }
.sb-hdr  { padding:10px 16px 4px; font-size:9px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.12em; }
.sb-item { display:flex; align-items:center; gap:9px; padding:9px 14px; border-radius:9px; margin:1px 8px; cursor:pointer; font-size:13px; font-weight:500; color:var(--text2); transition:all .15s; border:none; background:none; font-family:'DM Sans',sans-serif; text-align:left; width:calc(100% - 16px); }
.sb-item:hover       { background:rgba(255,255,255,.05); color:var(--text); }
.sb-item.active      { background:rgba(0,174,239,.12); color:var(--p); font-weight:600; }
.sb-item.active .mi  { color:var(--p); }
.sb-item .mi         { font-size:17px; flex-shrink:0; color:var(--text3); }
.sb-badge { margin-left:auto; background:#f87171; color:#fff; font-size:9px; font-weight:700; min-width:16px; height:16px; border-radius:8px; display:flex; align-items:center; justify-content:center; padding:0 4px; }
.sb-foot  { margin-top:auto; padding:12px 8px; }

/* main area */
.main        { overflow-y:auto; }
.page        { display:none; padding:30px 34px; animation:fadeUp .3s ease; }
.page.active { display:block; }
.page-hdr    { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:26px; gap:12px; flex-wrap:wrap; }
.page-title  { font-size:22px; font-weight:800; letter-spacing:-.02em; }
.page-sub    { font-size:13px; color:var(--text3); margin-top:4px; }

/* buttons */
.btn { display:inline-flex; align-items:center; gap:5px; padding:7px 14px; border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; transition:all .15s; border:none; font-family:'DM Sans',sans-serif; }
.btn.bp  { background:var(--p);   color:#fff; }    .btn.bp:hover  { opacity:.85; }
.btn.bt  { background:var(--teal);color:#fff; }    .btn.bt:hover  { opacity:.85; }
.btn.bs  { background:rgba(255,255,255,.07); color:var(--text2); border:1px solid var(--border2); } .btn.bs:hover { background:rgba(255,255,255,.12); }
.btn.bd  { background:rgba(248,113,113,.12); color:#f87171; border:1px solid rgba(248,113,113,.25); }
.btn.bsm { padding:5px 10px; font-size:11px; }

/* cards & components */
.card     { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:20px 22px; margin-bottom:16px; }
.card-ttl { font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; display:flex; align-items:center; gap:7px; }
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:20px; }
.kpi      { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:18px 20px; }
.kpi-val  { font-size:26px; font-weight:800; color:var(--p); line-height:1; letter-spacing:-.02em; }
.kpi-lbl  { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.07em; margin-top:5px; }
.badge        { display:inline-flex; align-items:center; font-size:10px; font-weight:700; padding:3px 9px; border-radius:6px; text-transform:uppercase; letter-spacing:.04em; }
.b-green { background:rgba(74,222,128,.14);  color:#4ade80;  border:1px solid rgba(74,222,128,.22); }
.b-red   { background:rgba(248,113,113,.14); color:#f87171;  border:1px solid rgba(248,113,113,.22); }
.b-blue  { background:rgba(0,174,239,.12);   color:#67e8f9;  border:1px solid rgba(0,174,239,.2); }
.b-grey  { background:rgba(255,255,255,.06); color:var(--text3); border:1px solid var(--border); }
.b-teal  { background:rgba(13,148,136,.15);  color:#2dd4bf;  border:1px solid rgba(13,148,136,.25); }
.prog      { height:5px; background:rgba(255,255,255,.07); border-radius:3px; overflow:hidden; margin-top:5px; }
.prog-fill { height:100%; border-radius:3px; transition:width .5s; }

/* table */
table { width:100%; border-collapse:collapse; }
th    { text-align:left; padding:7px 10px; font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.07em; border-bottom:1px solid var(--border2); }
td    { padding:11px 10px; font-size:13px; border-bottom:1px solid var(--border); vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:rgba(255,255,255,.025); }

/* form */
.fi    { background:rgba(255,255,255,.06); border:1.5px solid var(--border); border-radius:9px; padding:10px 13px; color:var(--text); font-size:13px; font-family:'DM Sans',sans-serif; width:100%; outline:none; transition:border-color .15s; }
.fi:focus { border-color:var(--p); }
.fs    { background:rgba(255,255,255,.06); border:1.5px solid var(--border); border-radius:9px; padding:9px 12px; color:var(--text); font-size:13px; font-family:'DM Sans',sans-serif; width:100%; outline:none; }
.fg    { margin-bottom:14px; }
.flbl  { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.08em; display:block; margin-bottom:6px; }
.g2    { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* messages */
.msg-list  { display:flex; flex-direction:column; gap:10px; max-height:420px; overflow-y:auto; padding-right:4px; margin-bottom:12px; }
.bubble    { max-width:74%; padding:10px 14px; border-radius:12px; font-size:13px; line-height:1.5; }
.bubble.mine   { align-self:flex-end;  background:rgba(0,174,239,.18); border:1px solid rgba(0,174,239,.25); }
.bubble.theirs { align-self:flex-start; background:var(--bg3); border:1px solid var(--border); }
.msg-meta  { font-size:10px; color:var(--text3); margin-top:3px; }

/* loading overlay */
.bridge-loading{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.bridge-loading .spin{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--p);border-radius:50%;animation:spin .7s linear infinite}
.bridge-loading span{font-size:12px;color:var(--text2);font-weight:600}
@keyframes spin{to{transform:rotate(360deg)}}

/* toast */
.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(60px); background:#1e293b; border:1px solid var(--border2); border-radius:10px; padding:10px 20px; font-size:13px; font-weight:600; color:var(--text); z-index:9000; transition:transform .3s,opacity .3s; opacity:0; pointer-events:none; }
.toast.show { transform:translateX(-50%) translateY(0); opacity:1; }

/* preview bar */
.preview-bar { background:rgba(251,191,36,.12); border-bottom:1px solid rgba(251,191,36,.3); padding:8px 22px; display:flex; align-items:center; gap:10px; font-size:12px; color:#fbbf24; position:relative; z-index:101; }

/* app switcher */
.app-switcher       { position:fixed; bottom:20px; left:16px; z-index:2000; display:flex; flex-direction:column; gap:8px; align-items:flex-start; }
.app-switcher-toggle { width:42px; height:42px; border-radius:12px; background:#1f2937; border:1.5px solid rgba(255,255,255,.15); cursor:pointer; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); transition:all .2s; box-shadow:0 4px 16px rgba(0,0,0,.35); }
.app-switcher-toggle:hover { background:#374151; color:#fff; border-color:rgba(255,255,255,.3); }
.app-switcher-menu  { background:#0c1220; border:1.5px solid rgba(255,255,255,.12); border-radius:14px; padding:8px; display:none; flex-direction:column; gap:2px; box-shadow:0 8px 40px rgba(0,0,0,.55); min-width:188px; }
.app-switcher-menu.open { display:flex; }
.app-sw-icon { width:26px; height:26px; border-radius:7px; display:flex; align-items:center; justify-content:center; flex-shrink:0; overflow:hidden; }
.app-sw-item { display:flex; align-items:center; gap:10px; padding:7px 9px; border-radius:9px; cursor:pointer; text-decoration:none; transition:background .15s; color:rgba(255,255,255,.6); font-size:12px; font-weight:500; border:none; background:none; font-family:inherit; width:100%; text-align:left; }
.app-sw-item:hover   { background:rgba(255,255,255,.07); color:#fff; }
.app-sw-item.current { background:rgba(255,255,255,.08); color:#fff; font-weight:600; }
.app-sw-sep { height:1px; background:rgba(255,255,255,.07); margin:2px 0; }
html.light-mode .app-switcher-toggle { background:#fff; border-color:rgba(0,0,0,.15); color:#4b5563; }
html.light-mode .app-switcher-menu   { background:#fff; border-color:rgba(0,0,0,.12); }
html.light-mode .app-sw-item         { color:#4b5563; }
html.light-mode .app-sw-item:hover   { background:rgba(0,0,0,.05); color:#111; }
html.light-mode .app-sw-item.current { background:rgba(0,0,0,.06); color:#111; }
html.light-mode .app-sw-sep          { background:rgba(0,0,0,.07); }

/* ── WhatsApp panel styles ── */
.wa-rte-btn { width:26px;height:26px;border:none;border-radius:4px;background:transparent;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;padding:0 }
.wa-rte-btn:hover { background:rgba(255,255,255,.08);color:var(--text) }
.wa-rte-btn:active { background:rgba(99,102,241,.2);color:#818cf8 }
.wa-panel-tab [contenteditable]:empty:before { content:attr(data-placeholder);color:var(--text3);pointer-events:none;font-style:italic }
.wa-panel-tab [contenteditable] b,.wa-panel-tab [contenteditable] strong { font-weight:700;color:var(--text) }
.wa-panel-tab [contenteditable] i,.wa-panel-tab [contenteditable] em { font-style:italic }
.wa-panel-tab [contenteditable] ul,.wa-panel-tab [contenteditable] ol { margin:4px 0;padding-left:18px }
.wa-panel-tab [contenteditable] a { color:var(--p);text-decoration:underline }
#wa-card-panel { scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent }
#wa-card-panel select { color-scheme:dark }
html.light-mode #wa-card-panel select { color-scheme:light }
html.light-mode .wa-rte-btn:hover { background:rgba(0,0,0,.06);color:var(--text) }
html.light-mode .wa-rte-btn:active { background:rgba(99,102,241,.12) }
