/* ============================================================================
   app-shell.css — shared topbar + collapsible sidebar for every app page.
   ----------------------------------------------------------------------------
   Link AFTER tokens.css. Pairs with app-shell.js (renders the markup + wires
   the collapse toggle). A page only needs:

       <link rel="stylesheet" href="tokens.css">
       <link rel="stylesheet" href="app-shell.css">
       ...
       <div id="cq-shell" data-active="rfi-fact-checker"></div>
       <main class="cq-main"> …page content… </main>
       <script>window.CONSENTIQ_CONTEXT = { … };</script>
       <script src="app-shell.js"></script>

   The shell is authored ONCE here; all 12 app pages inherit it, collapse state
   included (persisted in localStorage across pages).
   ========================================================================== */

/* Shared Help & feedback panel internals (tabs, FAQ, form). Container styles
   for the sidebar sub-view stay below. */
@import url('consentiq-help.css');

/* ── topbar ── */
.cq-topbar{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--teal-dim);
  display:flex;align-items:center;gap:16px;padding:0 16px;z-index:100;color:#fff}
.cq-topbar__logo{font-family:var(--font-display);font-size:21px;letter-spacing:-.3px;color:#fff;text-decoration:none;
  display:flex;align-items:center;gap:8px;flex-shrink:0}
.cq-topbar__logo.is-link{cursor:pointer;transition:opacity .12s}
.cq-topbar__logo.is-link:hover{opacity:.82}
.cq-topbar__logo .cq-logo-mark{width:27px;height:27px;color:#fff;flex-shrink:0}
.cq-topbar__logo em{font-style:italic;color:var(--teal-mid)}
.cq-topbar__divider{width:1px;height:20px;background:rgba(255,255,255,.15);flex-shrink:0}
.cq-topbar__project{font-size:13px;color:rgba(255,255,255,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cq-topbar__project strong{color:rgba(255,255,255,.9);font-weight:500}
.cq-topbar__spacer{flex:1}
.cq-topbar__actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.cq-topbar__btn{height:32px;padding:0 12px;border-radius:7px;border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);color:#fff;font-size:13px;font-weight:600;display:inline-flex;
  align-items:center;gap:6px;cursor:pointer}
.cq-topbar__btn:hover{background:rgba(255,255,255,.16)}
.cq-avatar{display:flex;align-items:center;gap:9px;cursor:pointer;position:relative}
.cq-avatar__badge{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.16);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.cq-avatar__meta{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.cq-avatar__name{font-size:12.5px;font-weight:600;color:#fff}
.cq-avatar__practice{font-size:11px;color:rgba(255,255,255,.6)}
@media(max-width:720px){.cq-avatar__meta{display:none}}
.cq-avatar__caret{font-size:10px;color:rgba(255,255,255,.55);margin-left:-2px;flex-shrink:0}

/* ── avatar dropdown menu ── */
.cq-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:224px;background:var(--surface);
  border:1px solid var(--rule);border-radius:var(--r-md);box-shadow:var(--sh-md);padding:6px;z-index:120;display:none}
.cq-menu.is-open{display:block}
.cq-menu__id{padding:9px 10px 10px}
.cq-menu__id .lbl{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-light)}
.cq-menu__id .nm{font-size:13.5px;font-weight:600;color:var(--ink);margin-top:3px}
.cq-menu__id .pr{font-size:12px;color:var(--ink-light);margin-top:1px}
.cq-menu__sep{height:1px;background:var(--rule);margin:4px 0}
.cq-menu__item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 10px;border:none;
  background:none;border-radius:var(--r-sm);font-family:var(--font-sans);font-size:13px;color:var(--ink-mid);
  cursor:pointer;text-decoration:none;box-sizing:border-box}
.cq-menu__item:hover{background:var(--teal-light);color:var(--teal)}
.cq-menu__item.is-danger{color:var(--red)}
.cq-menu__item.is-danger:hover{background:var(--red-light);color:var(--red)}
.cq-menu__ic{width:15px;text-align:center;opacity:.7;flex-shrink:0}

/* ── sidebar ── */
.cq-sidebar{position:fixed;top:var(--header-h);left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);
  border-right:1px solid var(--rule);display:flex;flex-direction:column;padding:0;z-index:90;
  transition:width .18s ease}
.cq-sidebar__toggle{position:absolute;top:12px;right:-11px;width:22px;height:22px;border-radius:50%;
  background:var(--surface);border:1px solid var(--rule);color:var(--ink-light);display:flex;align-items:center;
  justify-content:center;font-size:11px;cursor:pointer;box-shadow:var(--sh-sm);z-index:5;transition:color .12s}
.cq-sidebar__toggle:hover{color:var(--teal)}
.cq-sidebar__sec{padding:0 12px;margin-bottom:22px}
.cq-sidebar__label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-light);padding:0 8px;margin-bottom:6px}
.cq-nav{display:flex;flex-direction:column;gap:2px}
.cq-nav__item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;font-size:13px;
  color:var(--ink-mid);cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .12s,color .12s}
.cq-nav__item:hover{background:var(--teal-light);color:var(--teal)}
.cq-nav__item.is-active{background:var(--teal-light);color:var(--teal);font-weight:600}
.cq-nav__ic{width:18px;text-align:center;opacity:.6;flex-shrink:0;font-size:14px}
.cq-nav__item:hover .cq-nav__ic,.cq-nav__item.is-active .cq-nav__ic{opacity:1}
.cq-nav__label{flex:1;overflow:hidden}
.cq-nav__badge{background:var(--amber);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;
  border-radius:10px;font-family:var(--font-mono);flex-shrink:0}
.cq-nav__badge.is-new{background:var(--green);letter-spacing:.4px}
.cq-meta{margin:0 12px 18px;background:var(--bg);border-radius:6px;padding:10px 12px}
.cq-meta__row{display:flex;gap:6px;font-size:12px;line-height:1.4;margin-bottom:5px}
.cq-meta__row:last-child{margin-bottom:0}
.cq-meta__k{font-weight:600;color:var(--ink-mid);min-width:52px;flex-shrink:0}
.cq-meta__v{color:var(--ink-light)}
.cq-sidebar__bottom{margin-top:auto;padding:12px;border-top:1px solid var(--rule)}
.cq-help-btn{width:100%;margin-bottom:8px;border:none;background:none;font-family:var(--font-sans);
  font-size:13px;text-align:left;cursor:pointer}
.cq-alpha{display:flex;align-items:center;gap:7px;padding:7px 10px;background:var(--purple-light);
  border:1px solid #ddd3f8;border-radius:5px;font-size:11px;color:var(--purple);font-weight:500;white-space:nowrap}
.cq-alpha .ic{flex-shrink:0}

/* ── help & feedback sub-view (slides over the nav within the sidebar) ── */
.cq-sidebar__stage{position:absolute;inset:0;overflow:hidden}
.cq-sidebar__main,.cq-sidebar__help{position:absolute;inset:0;display:flex;flex-direction:column;
  transition:transform .24s cubic-bezier(.4,0,.2,1)}
.cq-sidebar__main{padding:14px 0}
.cq-sidebar__help{transform:translateX(100%);background:var(--surface)}
.cq-sidebar.is-help .cq-sidebar__main{transform:translateX(-100%)}
.cq-sidebar.is-help .cq-sidebar__help{transform:translateX(0)}
.cq-sidebar.is-help .cq-sidebar__toggle{display:none}
.cq-collapsed .cq-sidebar__help{display:none}

.cq-help__head{flex-shrink:0;padding:14px 12px 0}
.cq-help__back{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;cursor:pointer;
  font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--ink);padding:7px 8px;border-radius:var(--r-sm)}
.cq-help__back:hover{background:var(--teal-light);color:var(--teal)}
.cq-help__back .ic{font-size:16px;line-height:1}
/* tabs, FAQ, feedback form + status → consentiq-help.css (shared, @imported above) */

/* ── collapsed / rail state ── */
.cq-collapsed .cq-sidebar{width:var(--sidebar-rail-w)}
.cq-collapsed .cq-sidebar__label,
.cq-collapsed .cq-nav__label,
.cq-collapsed .cq-nav__badge,
.cq-collapsed .cq-meta,
.cq-collapsed .cq-alpha .txt{display:none}
.cq-collapsed .cq-nav__item{justify-content:center;padding:9px 0}
.cq-collapsed .cq-nav__ic{width:auto}
.cq-collapsed .cq-sidebar__sec{padding:0 8px}
.cq-collapsed .cq-alpha{justify-content:center;padding:8px 0}
.cq-collapsed .cq-sidebar__bottom{padding:12px 8px}

/* ── main content offset ── */
.cq-main{margin-top:var(--header-h);margin-left:var(--sidebar-w);
  padding:var(--s-6) var(--s-6) var(--s-7);
  transition:margin-left .18s ease;min-height:calc(100vh - var(--header-h))}
.cq-collapsed .cq-main{margin-left:var(--sidebar-rail-w)}

/* ── no-sidebar mode (dashboard / wizard pages) ── */
.cq-no-sidebar .cq-main{margin-left:0}
