/* ── Flag icons ── */
.flag-icon{height:13px;width:auto;border-radius:2px;display:block;flex-shrink:0;}
/* In the source pill the span wrapping the flag must be a flex container so the img sits centred */
#source-pill-icon{display:flex;align-items:center;}
/* Wrapper that keeps flag + badge together at the same vertical centre */
.card-head-src{display:flex;align-items:center;gap:4px;}
/* Doc-bar flag: slightly smaller, no extra right margin (gap from flex parent handles spacing) */
.doc-bar-flag{height:11px}

/* ── Source picker dropdown options ── */
.source-option{
  display:flex;align-items:center;gap:6px;
  padding:7px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-xs);
  cursor:pointer;color:var(--text2);transition:background .12s,color .12s;
}
.source-option:hover{background:var(--bg3);color:var(--text);}
.source-option.active{background:var(--accent-bg);color:var(--accent);font-weight:600;}

/* ── All-Jurisdictions tab bar ── */
.all-jur-tabbar{display:flex;gap:4px;padding:0 0 12px;border-bottom:1px solid var(--border);margin-bottom:14px;flex-shrink:0;}
.all-jur-tab{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:border-color .14s,background .14s,color .14s;}
.all-jur-tab:hover{border-color:var(--accent);color:var(--accent);}
.all-jur-tab.active{background:var(--accent-bg);border-color:var(--accent-bg2);color:var(--accent);font-weight:600;}
.all-jur-tab-count{color:var(--text3);font-weight:400;}
.all-jur-tab.active .all-jur-tab-count{color:var(--accent);opacity:.75;}
.all-jur-panel{display:none;}
.all-jur-panel.active{display:block;}

/* ── Bundesrecht result cards ── */
.br-badge{background:rgba(0,80,200,.08);color:#1d4ed8;border:1px solid rgba(0,80,200,.15);}
[data-theme="dark"] .br-badge{background:rgba(60,130,255,.12);color:#7ab3ff;border-color:rgba(60,130,255,.2);}
.br-law-card{cursor:pointer;}

/* ── Bundesrecht TOC extras ── */
.br-toc-ext-link{font-size:10px;color:var(--text3);text-decoration:none;margin-left:auto;padding:0 2px;}
.br-toc-ext-link:hover{color:var(--accent);}
.br-toc-item.active{color:var(--accent);font-weight:600;background:var(--accent-bg);}
.br-toc-section{padding:10px 14px 2px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);border-top:1px solid var(--border);margin-top:4px;}
.br-toc-section:first-of-type{border-top:none;margin-top:0;}

/* ── Bundesrecht section dividers (Bücher, Kapitel, Titel …) in full text ── */
.br-section-divider{padding:20px 0 6px;margin-top:8px;}
.br-section-divider:first-child{padding-top:4px;}
.br-section-heading{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);border-bottom:1px solid var(--border);padding-bottom:6px;font-family:'Inter',-apple-system,sans-serif;}

/* ── Fulltext section depth variants ─────────────────────────────────────────
   br-sec-d0 = top level (Buch/Teil)    — most prominent
   br-sec-d1 = 2nd level (Abschnitt)   — moderately prominent
   br-sec-d2 = 3rd level (Titel)       — base style (matches existing default)
   br-sec-d3 = 4th level (Untertitel)  — least prominent                    ── */
.br-section-divider.br-sec-d0{padding-top:40px;}
.br-section-divider.br-sec-d0 .br-section-heading{font-size:14px;color:var(--text);letter-spacing:0;border-bottom:2px solid var(--border2);}
.br-section-divider.br-sec-d1{padding-top:30px;}
.br-section-divider.br-sec-d1 .br-section-heading{font-size:12px;color:var(--text2);letter-spacing:.04em;border-bottom-color:var(--border2);}
.br-section-divider.br-sec-d2{padding-top:22px;}
/* d2 uses base .br-section-heading style (11px, text3, border) */
.br-section-divider.br-sec-d3{padding-top:14px;}
.br-section-divider.br-sec-d3 .br-section-heading{font-size:10px;}

/* ── Bundesrecht TOC depth styling ─────────────────────────────────────────
   toc-chapter-toggle is the base class (from viewer.css: bold, uppercase, bg:--bg).
   .br-toc-dN overrides per hierarchy depth so higher levels look more prominent. ── */
.toc-chapter-toggle.br-toc-d0{font-weight:700;text-transform:uppercase;} /* depth 0 = Buch/Teil: same as viewer.css defaults */
.toc-chapter-toggle.br-toc-d1{text-transform:none;letter-spacing:0;font-size:12px;font-weight:600;color:var(--text);background:var(--surface);border-top-color:transparent;margin-top:0;}
.toc-chapter-toggle.br-toc-d2{text-transform:none;letter-spacing:0;font-size:11.5px;font-weight:500;color:var(--text2);background:var(--surface);border-top-color:transparent;margin-top:0;}
.toc-chapter-toggle.br-toc-d3{text-transform:none;letter-spacing:0;font-size:11px;font-weight:400;color:var(--text3);background:var(--surface);border-top-color:transparent;margin-top:0;}
/* Open state accent colour still applies at all depths (from viewer.css) */

/* ── Bundesrecht norm body ── */
.br-norm-label{font-size:13px;font-weight:600;color:var(--text2);font-family:'Inter',-apple-system,sans-serif;}
/* Paragraph body text in serif — matches EU law reading style */
.br-norm-body{font-size:15px;line-height:1.9;color:var(--text);font-family:Georgia,'Times New Roman',serif;}
/* Structural / heading elements stay in sans-serif */
.br-norm-article .lex-article-heading{font-family:'Inter',-apple-system,sans-serif;}
.br-norm-body .jnheader,.br-norm-body .jnheader *{font-family:'Inter',-apple-system,sans-serif;font-size:13px;font-weight:700;color:var(--text);}
.br-norm-body h1,.br-norm-body h2,.br-norm-body h3{font-size:13px;font-weight:700;margin:12px 0 4px;font-family:'Inter',-apple-system,sans-serif;}
.br-norm-body .jnhtml{padding:0;}
/* dl used for numbered / lettered lists (1. text, a) text …):
   grid puts each dt label and its dd text on the same row. */
.br-norm-body dl{display:grid;grid-template-columns:max-content 1fr;column-gap:.6em;row-gap:.15em;margin:6px 0;}
.br-norm-body dt{font-weight:600;font-family:'Inter',-apple-system,sans-serif;font-size:13px;margin:0;padding:.1em 0;white-space:nowrap;}
.br-norm-body dd{margin:0;padding:.1em 0;}
.br-norm-body table{border-collapse:collapse;width:100%;margin:8px 0;font-family:'Inter',-apple-system,sans-serif;font-size:13px;}
.br-norm-body td,.br-norm-body th{padding:4px 8px;border:1px solid var(--border);vertical-align:top;}

/* ── Bayern Landesrecht content classes ──────────────────────────────────
   gesetze-bayern.de uses .absatz.paratext for each paragraph, dl/dt/dd
   for numbered lists, sup.satznr for sentence-number superscripts, and
   div.clearer as float-clearers.  The .paraheading (Art.-Nr. + title) is
   stripped by the backend; the few cases it slips through should be hidden.
   ───────────────────────────────────────────────────────────────────── */
.br-norm-body .absatz.paratext{display:block;margin:0 0 .4em;}
.br-norm-body .absatz.paranr,.br-norm-body .absatz.paratitel{display:none;}/* stripped by backend; hide if present */
.br-norm-body .paraheading{display:none;}/* belt-and-braces hide of duplicate heading */
.br-norm-body .absatz.standangabe{font-size:12px;color:var(--text3);font-style:italic;margin-bottom:.6em;font-family:'Inter',-apple-system,sans-serif;}
.br-norm-body sup.satznr{font-size:9px;color:var(--text3);font-family:'Inter',sans-serif;font-weight:600;vertical-align:super;line-height:0;margin-right:.1em;}
.br-norm-body div.clearer{clear:both;height:0;overflow:hidden;display:none;}
/* Nested dl inside dd (Bavaria sometimes nests lists) */
.br-norm-body dd dl{margin-top:.2em;}


/* ── Bundesrecht lazy-load skeleton ── */
.br-norm-content[data-loading]{min-height:64px;}
.br-norm-skeleton{display:flex;flex-direction:column;gap:8px;padding:4px 0 8px;}
.br-norm-skeleton div{height:12px;border-radius:4px;background:var(--border);animation:br-shimmer 1.4s ease-in-out infinite;}
.br-norm-skeleton div:nth-child(1){width:92%;}
.br-norm-skeleton div:nth-child(2){width:78%;}
.br-norm-skeleton div:nth-child(3){width:55%;}
@keyframes br-shimmer{0%,100%{opacity:.5}50%{opacity:1}}
.br-norm-err{font-size:12px;color:var(--text3);}

/* ── Search area / bar ── */
.search-area{padding:16px 20px 0;display:flex;flex-direction:column;gap:10px;flex-shrink:0;}
.search-bar{display:flex;align-items:center;}
.search-unit{
  display:flex;align-items:center;flex:1;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:24px;
  box-shadow:0 1px 6px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.03);
  padding:5px 5px 5px 18px;
  gap:4px;
  transition:border-color .15s,box-shadow .15s;
}
[data-theme="dark"] .search-unit{box-shadow:0 1px 6px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.04);}
.search-unit:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);}
.search-unit .search-wrap{flex:1;display:flex;align-items:center;position:relative;}
.search-input{width:100%;border:none;background:transparent;outline:none;padding:6px 6px 7px;font-size:14px;color:var(--text);resize:none;overflow:hidden;line-height:1.45;min-height:30px;max-height:140px;font-family:inherit;}
.search-input::placeholder{color:transparent;}
.search-typewriter{position:absolute;left:6px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--text3);pointer-events:none;white-space:nowrap;overflow:hidden;max-width:calc(100% - 12px);}
.search-typewriter::after{content:'|';animation:tw-cursor .75s step-end infinite;margin-left:1px;}
@keyframes tw-cursor{0%,100%{opacity:.6;}50%{opacity:0;}}
.search-unit-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--text3);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;}
.search-unit-btn:hover{background:var(--bg3);color:var(--text2);}
.search-unit-divider{width:1px;height:20px;background:var(--border2);flex-shrink:0;margin:0 2px;}
.search-unit-submit{flex-shrink:0;height:34px;padding:0 18px;background:var(--accent);border:none;border-radius:20px;color:#fff;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap;}
.search-unit-submit:hover{opacity:.88;}
.search-unit-submit:disabled{opacity:.4;cursor:default;}
.search-unit-clear{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:none;background:transparent;color:var(--text3);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:color .12s;}
.search-unit-clear:hover{color:var(--text2);}
.search-unit-clear.hidden{display:none;}

.search-wrap{flex:1;position:relative;display:flex;align-items:center;}

/* ── Search context bar (clarification chips / coverage signal) ── */
.search-context-bar{padding:4px 2px 0;display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-height:26px;}
.search-context-bar.hidden{display:none;}
.clarif-hint{font-size:12px;color:var(--text3);white-space:nowrap;}
.clarif-chip{padding:3px 11px;border-radius:20px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-family:inherit;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap;}
.clarif-chip:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent);}
.coverage-signal{font-size:12px;color:var(--text3);letter-spacing:.01em;}


/* ── Skeleton cards ── */
.card-skeleton{pointer-events:none;user-select:none;}
.sk{border-radius:4px;background:linear-gradient(90deg,var(--bg3) 0%,var(--border2) 50%,var(--bg3) 100%);background-size:200% 100%;animation:sk-shimmer 1.4s ease-in-out infinite;}
@keyframes sk-shimmer{to{background-position:-200% 0}}
.sk-badge{width:56px;height:16px;border-radius:20px;}
.sk-date{width:52px;height:11px;margin-left:auto;}
.sk-title-lg{width:82%;height:13px;margin-bottom:6px;}
.sk-title-sm{width:58%;height:13px;margin-bottom:8px;}
.sk-footer{width:90px;height:11px;}

/* ── Hero label cycling animation — fade only, no movement ── */
#hero-lbl-slot{transition:opacity .35s ease;}
#hero-lbl-slot.lbl-exit{opacity:0;pointer-events:none;}
#hero-lbl-slot.lbl-enter{opacity:1;}

/* ── Autocomplete dropdown ── */
.autocomplete-dd{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;}
.autocomplete-dd.hidden{display:none;}
.autocomplete-item{padding:9px 14px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text);}
.autocomplete-item:hover,.autocomplete-item.ac-active{background:var(--accent-bg);color:var(--accent);}
.autocomplete-icon{font-size:11px;color:var(--text3);flex-shrink:0;}
.autocomplete-match{font-weight:600;}

/* ── Shared button styles ── */
.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 18px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s;white-space:nowrap;flex-shrink:0;}
.btn-primary:hover{opacity:.88;}
.btn-primary:disabled{opacity:.45;cursor:default;}
.btn-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border2);color:var(--text2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow-sm);transition:all .15s;position:relative;}
.btn-icon:hover{background:var(--bg3);}
.btn-sm{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-bg2);border-radius:var(--radius-xs);padding:5px 12px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s;display:inline-block;}
.btn-sm:hover{background:var(--accent-bg2);}


/* ── Search bar inner buttons (history, recent) ── */
.search-bar-btn{height:auto;padding:0 14px;border:1px solid var(--border2);border-left:none;background:var(--surface);color:var(--text2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;box-shadow:var(--shadow-sm);}
.search-bar-btn:hover{background:var(--bg3);color:var(--text);}
.search-bar-btn.history-btn{border-radius:0;}
.search-bar-btn.recent-btn-inner{border-radius:0;}
.btn-recent{height:auto;padding:0 14px;border-radius:0;background:var(--surface);border:1px solid var(--border2);border-left:none;color:var(--text2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow-sm);transition:all .2s;}
.btn-recent:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bg2);}
.btn-recent.spinning,#recent-btn.spinning{animation:spin .7s linear infinite;}
.recent-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0 6px;border-bottom:1px solid var(--border);margin-bottom:6px;}
.recent-header-left{display:flex;align-items:baseline;gap:8px;}

/* ── Update toast ── */
.update-toast{position:fixed;top:62px;right:16px;z-index:400;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:14px 16px;display:flex;align-items:center;gap:12px;max-width:320px;animation:toast-in .25s ease;}
.update-toast.hidden{display:none;}
@keyframes toast-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.update-toast-icon{font-size:20px;flex-shrink:0;}
.update-toast-body{flex:1;min-width:0;}
.update-toast-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;}
.update-toast-sub{font-size:11px;color:var(--text2);}
.update-toast-actions{display:flex;gap:6px;margin-top:10px;}
.btn-restart{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-xs);padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s;}
.btn-restart:hover{opacity:.85;}
.btn-dismiss{background:transparent;color:var(--text3);border:1px solid var(--border);border-radius:var(--radius-xs);padding:5px 10px;font-size:12px;cursor:pointer;transition:all .15s;}
.btn-dismiss:hover{background:var(--bg3);color:var(--text2);}
