:root{
  --bg:#0e1117;--surface:#161b22;--border:#30363d;
  --text:#e6edf3;--muted:#8b949e;
  --high:#ff4757;--high-bg:rgba(255,71,87,.13);--high-border:rgba(255,71,87,.4);
  --medium:#f39c12;--medium-bg:rgba(243,156,18,.13);--medium-border:rgba(243,156,18,.4);
  --low:#2ecc71;--low-bg:rgba(46,204,113,.10);--low-border:rgba(46,204,113,.3);
  --ok:#57ab5a;--accent:#58a6ff;--code-bg:#0d1117;--r:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;font-size:15px;line-height:1.65}

/* ── Header ── */
.hdr{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 28px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100}
.logo{font-size:19px;font-weight:700;letter-spacing:-.3px;white-space:nowrap}
.logo span{color:var(--accent)}
.cfg-path{font-size:11px;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-family:monospace;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.btn-cfg{background:rgba(88,166,255,.12);border:1px solid rgba(88,166,255,.35);color:var(--accent);border-radius:8px;padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:inherit}
.btn-cfg:hover{background:rgba(88,166,255,.22)}

/* ── Stats ── */
.stats{display:flex;gap:10px;padding:16px 28px;border-bottom:1px solid var(--border);background:var(--surface)}
.sc{flex:1;border-radius:var(--r);padding:14px 18px;border:1px solid;cursor:pointer;transition:opacity .15s}
.sc:hover{opacity:.8}
.sc.total{border-color:rgba(88,166,255,.3);background:rgba(88,166,255,.08)}
.sc.high  {border-color:var(--high-border);background:var(--high-bg)}
.sc.medium{border-color:var(--medium-border);background:var(--medium-bg)}
.sc.low   {border-color:var(--low-border);background:var(--low-bg)}
.sc.ok    {border-color:rgba(87,171,90,.3);background:rgba(87,171,90,.08)}
.sn{font-size:28px;font-weight:700;line-height:1}
.sn.total{color:var(--accent)}.sn.high{color:var(--high)}.sn.medium{color:var(--medium)}.sn.low{color:var(--low)}.sn.ok{color:var(--ok)}
.sl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}

/* ── Filters ── */
.filters{display:flex;gap:8px;padding:14px 28px;align-items:center;flex-wrap:wrap}
.fb{border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:20px;padding:6px 16px;font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}
.fb:hover{border-color:var(--accent);color:var(--accent)}
.fb.active{background:var(--accent);border-color:var(--accent);color:#0e1117;font-weight:600}
.fb.active.high  {background:var(--high);  border-color:var(--high);  color:#fff}
.fb.active.medium{background:var(--medium);border-color:var(--medium);color:#fff}
.fb.active.low   {background:var(--low);   border-color:var(--low);   color:#0e1117}
.search{margin-left:auto;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 14px;color:var(--text);font-size:14px;font-family:inherit;outline:none;width:240px;transition:border-color .15s}
.search:focus{border-color:var(--accent)}

/* ── Issue cards ── */
.main{padding:6px 28px 40px}
.sec-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:20px 0 10px;display:flex;align-items:center;gap:8px}
.sec-title::after{content:'';flex:1;height:1px;background:var(--border)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;overflow:hidden;transition:border-color .15s}
.card:hover{border-color:var(--muted)}
.card.high  {border-left:3px solid var(--high)}
.card.medium{border-left:3px solid var(--medium)}
.card.low   {border-left:3px solid var(--low)}
.card.jump-flash{animation:flash .6s ease}
@keyframes flash{0%,100%{background:var(--surface)}50%{background:rgba(88,166,255,.15)}}

.ch{display:flex;align-items:flex-start;gap:12px;padding:13px 16px;cursor:pointer;user-select:none}
.ch:hover{background:rgba(255,255,255,.02)}
.badge{border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 9px;white-space:nowrap;flex-shrink:0;margin-top:2px}
.badge.high  {background:var(--high-bg);  color:var(--high);  border:1px solid var(--high-border)}
.badge.medium{background:var(--medium-bg);color:var(--medium);border:1px solid var(--medium-border)}
.badge.low   {background:var(--low-bg);   color:var(--low);   border:1px solid var(--low-border)}
.cm{flex:1;min-width:0}
.ct{font-size:14px;font-weight:600;font-family:monospace;margin-bottom:3px;display:flex;align-items:center;gap:8px}
.cv{font-size:13px;color:var(--muted);word-break:break-all}
.tog{color:var(--muted);font-size:18px;flex-shrink:0;transition:transform .2s}
.card.expanded .tog{transform:rotate(180deg)}
.go-cfg{font-size:11px;color:var(--accent);background:rgba(88,166,255,.1);border:1px solid rgba(88,166,255,.25);border-radius:4px;padding:2px 8px;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}
.go-cfg:hover{background:rgba(88,166,255,.2)}

.cb{display:none;border-top:1px solid var(--border)}
.card.expanded .cb{display:block}
.ir{display:flex;border-bottom:1px solid var(--border)}
.il{width:130px;flex-shrink:0;padding:10px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);background:var(--code-bg);border-right:1px solid var(--border)}
.iv{padding:10px 16px;font-size:14px;line-height:1.55;flex:1}
.sol{color:#79c0ff}

/* snippet */
.snip-wrap{border-top:1px solid var(--border)}
.snip-hdr{padding:7px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);background:var(--code-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.snip-file{font-family:monospace;color:var(--accent);font-size:11px;font-weight:400}
pre.cb-code{background:var(--code-bg);margin:0;padding:12px 16px;overflow-x:auto;font-family:'SFMono-Regular',Consolas,monospace;font-size:13.5px;line-height:1.7}
.cl{display:block}
.cl.hl{background:rgba(255,71,87,.13);border-left:2px solid var(--high);margin-left:-16px;padding-left:14px;margin-right:-16px;padding-right:16px}
.cl.hl.medium{background:rgba(243,156,18,.11);border-left-color:var(--medium)}
.cl.hl.low{background:rgba(46,204,113,.09);border-left-color:var(--low)}
.kw{color:#ff7b72}.dir{color:#79c0ff}.str{color:#a8d08d}.cmt{color:#8b949e;font-style:italic}.var{color:#f2cc60}

/* ── Passed ── */
.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:6px;margin-top:8px}
.pi{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--ok);border-radius:8px;padding:9px 14px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}
.pi::before{content:'✓';color:var(--ok);font-weight:700}

.no-res{text-align:center;padding:40px;color:var(--muted);display:none}

/* ══════════════════════════════════════════
   МОДАЛКА — ПОЛНЫЙ КОНФИГ
══════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:none;align-items:stretch;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:900px;display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 48px)}
.modal-hdr{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.modal-title{font-size:14px;font-weight:600;flex:1}
.modal-file{font-family:monospace;font-size:11px;color:var(--accent)}
.modal-close{background:rgba(255,255,255,.08);border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 12px;cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s}
.modal-close:hover{background:rgba(255,71,87,.15);border-color:var(--high-border);color:var(--high)}
.modal-legend{display:flex;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--code-bg);flex-shrink:0;flex-wrap:wrap}
.leg-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.leg-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.leg-dot.high{background:var(--high)}.leg-dot.medium{background:var(--medium)}.leg-dot.low{background:var(--low)}
.modal-body{overflow-y:auto;flex:1}

/* Таблица конфига */
.cfg-table{width:100%;border-collapse:collapse;font-family:'SFMono-Regular',Consolas,monospace;font-size:13.5px;line-height:1.75}
.cfg-table tr{cursor:default}
.cfg-table tr:hover .ln{color:var(--text)}

.ln{width:52px;min-width:52px;text-align:right;padding:0 12px 0 8px;color:#444c56;user-select:none;border-right:1px solid var(--border);background:var(--code-bg);vertical-align:top;font-size:12px}
.lc{padding:0 16px;white-space:pre;background:var(--code-bg);vertical-align:top}

/* строки с проблемами */
.cfg-table tr.issue-line td.lc{position:relative}
.cfg-table tr.issue-high   td.lc{background:rgba(255,71,87,.10)!important}
.cfg-table tr.issue-medium td.lc{background:rgba(243,156,18,.09)!important}
.cfg-table tr.issue-low    td.lc{background:rgba(46,204,113,.07)!important}
.cfg-table tr.issue-high   td.ln{color:var(--high);border-right-color:var(--high-border)}
.cfg-table tr.issue-medium td.ln{color:var(--medium);border-right-color:var(--medium-border)}
.cfg-table tr.issue-low    td.ln{color:var(--low);border-right-color:var(--low-border)}
.cfg-table tr.issue-high   td.lc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--high)}
.cfg-table tr.issue-medium td.lc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--medium)}
.cfg-table tr.issue-low    td.lc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--low)}

/* помечена как "в фокусе" при наведении из карточки */
.cfg-table tr.focused td.lc{outline:1px solid var(--accent);outline-offset:-1px}
.cfg-table tr.focused td.ln{color:var(--accent)}

/* tooltip — боковая панель с пояснением */
.tip{
  position:fixed;z-index:400;left:0;top:0;
  background:#161b22;border:1px solid var(--border);border-radius:10px;
  padding:0;font-family:-apple-system,sans-serif;font-size:12.5px;
  width:360px;pointer-events:none;opacity:0;transition:opacity .18s;
  white-space:normal;line-height:1.5;box-shadow:0 12px 40px rgba(0,0,0,.7);
  overflow:hidden;
}
.tip.show{opacity:1}
.tip-hdr{padding:10px 14px 8px;border-bottom:1px solid var(--border)}
.tip-type{font-weight:700;font-family:monospace;font-size:13px;margin-bottom:3px}
.tip-type.high{color:var(--high)}.tip-type.medium{color:var(--medium)}.tip-type.low{color:var(--low)}
.tip-val{color:var(--muted);font-size:11px;word-break:break-all}
.tip-body{padding:10px 14px}
.tip-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:4px}
.tip-sol{color:#79c0ff;font-size:12px;margin-bottom:10px;line-height:1.5}
.tip-code{background:var(--code-bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-family:'SFMono-Regular',Consolas,monospace;font-size:11px;white-space:pre;overflow-x:auto;color:#a8d08d;line-height:1.6}

/* ══════════════════════════════════════════
   РЕДАКТОР КОНФИГА
══════════════════════════════════════════ */
.editor-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:500;display:none;align-items:center;justify-content:center;padding:24px}
.editor-overlay.open{display:flex}
.editor-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:860px;display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 48px)}
.editor-hdr{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.editor-title{font-size:15px;font-weight:600;flex:1}
.editor-close{background:rgba(255,255,255,.08);border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 12px;cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s}
.editor-close:hover{background:rgba(255,71,87,.15);border-color:var(--high-border);color:var(--high)}
.editor-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px;flex:1;overflow:auto}
.editor-hint{font-size:13px;color:var(--muted)}
.editor-hint b{color:var(--text)}
#cfg-textarea{width:100%;height:340px;background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:14px;color:var(--text);font-family:'SFMono-Regular',Consolas,monospace;font-size:13px;line-height:1.65;resize:vertical;outline:none;tab-size:4;transition:border-color .15s}
#cfg-textarea:focus{border-color:var(--accent)}
.editor-footer{display:flex;gap:10px;justify-content:flex-end;padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0}
.btn-check{background:var(--accent);border:none;color:#0e1117;border-radius:8px;padding:9px 22px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}
.btn-check:hover{opacity:.85}
.btn-check:disabled{opacity:.5;cursor:not-allowed}
.editor-err{color:var(--high);font-size:13px;display:none}

/* ══════════════════════════════════════════
   КНОПКА «ИСПРАВИТЬ КОНФИГ»
══════════════════════════════════════════ */
.btn-generate{background:rgba(155,89,182,.15);border-color:rgba(155,89,182,.45);color:#bb86fc}
.btn-generate:hover{background:rgba(155,89,182,.28)}

/* ══════════════════════════════════════════
   МОДАЛКА — ИСПРАВЛЕННЫЙ КОНФИГ
══════════════════════════════════════════ */
.gen-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:500;display:none;align-items:center;justify-content:center;padding:24px}
.gen-overlay.open{display:flex}
.gen-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:920px;display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 48px)}
.gen-hdr{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.gen-title{font-size:15px;font-weight:600;flex:1}
.gen-actions{display:flex;gap:8px;align-items:center}
.gen-hint{padding:10px 20px;font-size:12px;color:var(--muted);background:var(--code-bg);border-bottom:1px solid var(--border);flex-shrink:0}
.gen-body{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.gen-code{background:var(--code-bg);margin:0;padding:16px 20px;font-family:'SFMono-Regular',Consolas,monospace;font-size:13px;line-height:1.7;white-space:pre;overflow-x:auto;color:var(--text);min-height:200px}
.gen-footer{display:flex;align-items:center;gap:12px;padding:10px 20px;border-top:1px solid var(--border);flex-shrink:0}
.gen-stats{font-size:12px;color:var(--muted);flex:1}
.gen-copy{background:rgba(155,89,182,.15);border:1px solid rgba(155,89,182,.4);color:#bb86fc;border-radius:8px;padding:7px 16px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.gen-copy:hover{background:rgba(155,89,182,.3)}
.gen-copy.copied{background:rgba(46,204,113,.2);border-color:rgba(46,204,113,.4);color:var(--ok)}

/* scrollbar */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ══════════════════════════════════════════
   MOBILE — TABLET (< 768px)
══════════════════════════════════════════ */
@media(max-width:768px){
  body{font-size:14px;-webkit-text-size-adjust:100%}

  /* ── Header: compact row ── */
  .hdr{padding:12px 16px;gap:10px;flex-wrap:nowrap}
  .logo{font-size:18px}
  .cfg-path{display:none}
  .btn-cfg{padding:8px 12px;font-size:11px;border-radius:10px}

  /* ── Stats: horizontal scroll strip ── */
  .stats{
    display:flex;flex-wrap:nowrap;gap:8px;
    padding:12px 16px;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
  }
  .stats::-webkit-scrollbar{display:none}
  .sc{
    flex:0 0 auto;min-width:120px;
    border-radius:12px;padding:14px 16px;
    scroll-snap-align:start;
    -webkit-tap-highlight-color:transparent;
  }
  .sc:active{transform:scale(.96);transition:transform .1s}
  .sn{font-size:24px}
  .sl{font-size:10px;letter-spacing:.3px}

  /* ── Filters: horizontal scroll pills ── */
  .filters{
    display:flex;flex-wrap:nowrap;gap:8px;
    padding:10px 16px;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    align-items:center;
  }
  .filters::-webkit-scrollbar{display:none}
  .fb{
    flex:0 0 auto;
    padding:8px 16px;font-size:13px;
    border-radius:20px;
    -webkit-tap-highlight-color:transparent;
  }
  .fb:active{transform:scale(.95)}
  .search{
    width:100%;margin-left:0;order:10;flex:0 0 100%;
    padding:10px 16px;font-size:15px;border-radius:12px;
  }

  /* ── Cards: touch-friendly ── */
  .main{padding:8px 12px 80px}
  .card{border-radius:12px;margin-bottom:10px}
  .ch{padding:14px 14px;gap:10px;min-height:56px;-webkit-tap-highlight-color:transparent}
  .ch:active{background:rgba(255,255,255,.04)}
  .cm{min-width:0}
  .ct{font-size:13px;font-weight:600;flex-wrap:wrap;gap:6px;line-height:1.4}
  .cv{font-size:12px;line-height:1.5;margin-top:4px}
  .badge{font-size:10px;padding:4px 8px;border-radius:6px}
  .tog{font-size:20px;padding:4px;margin-top:-2px}
  .go-cfg{padding:4px 10px;font-size:11px;border-radius:6px}

  /* card body */
  .ir{flex-direction:column}
  .il{width:100%;padding:8px 14px;border-right:none;border-bottom:1px solid var(--border);font-size:11px}
  .iv{padding:10px 14px;font-size:13px;line-height:1.6}
  pre.cb-code{font-size:11.5px;padding:10px 12px;line-height:1.65;-webkit-overflow-scrolling:touch}

  /* ── Passed checks ── */
  .pg{grid-template-columns:1fr;gap:8px}
  .pi{padding:12px 14px;font-size:13px;border-radius:10px}

  .no-res{padding:30px;font-size:14px}

  /* ── Modal: fullscreen slide-up ── */
  .modal-overlay{padding:0;align-items:flex-end}
  .modal-overlay.open{display:flex;animation:fadeIn .2s ease}
  .modal{
    border-radius:16px 16px 0 0;
    max-height:100vh;max-width:100%;border:none;
    animation:slideUp .3s cubic-bezier(.32,.72,0,1);
  }
  .modal-hdr{
    padding:6px 16px;gap:6px;flex-wrap:nowrap;
    min-height:44px;
  }
  .modal-title{font-size:14px}
  .modal-file{display:none}
  .modal-close{padding:6px 12px;font-size:12px;border-radius:8px}
  .modal-legend{padding:6px 16px;gap:8px}
  .leg-item{font-size:9px;gap:4px}
  .leg-dot{width:8px;height:8px}

  /* ── Config table: mobile-optimized ── */
  .modal-body{
    overflow:auto;-webkit-overflow-scrolling:touch;
    position:relative;
  }
  .cfg-table{font-size:11.5px;line-height:1.6;table-layout:fixed;width:auto;min-width:100%}
  .ln{
    width:36px;min-width:36px;max-width:36px;
    padding:0 6px 0 4px;font-size:10px;
    position:sticky;left:0;z-index:2;
  }
  .lc{
    padding:0 10px;
    white-space:pre;
    overflow:visible;
  }

  /* issue lines are tappable on mobile */
  .cfg-table tr.issue-line{
    -webkit-tap-highlight-color:transparent;
    cursor:pointer;
  }
  .cfg-table tr.issue-line:active td.lc{
    filter:brightness(1.3);
  }
  /* pulse indicator on issue lines */
  .cfg-table tr.issue-line td.ln::after{
    content:'';display:inline-block;
    width:5px;height:5px;border-radius:50%;
    margin-left:2px;vertical-align:middle;
  }
  .cfg-table tr.issue-high td.ln::after{background:var(--high)}
  .cfg-table tr.issue-medium td.ln::after{background:var(--medium)}
  .cfg-table tr.issue-low td.ln::after{background:var(--low)}

  .tip{display:none!important}

  /* ── Issue nav FAB ── */
  .issue-nav{
    display:flex !important;
    position:fixed;bottom:20px;right:16px;z-index:250;
    flex-direction:column;gap:8px;
  }
  .issue-nav-btn{
    width:44px;height:44px;border-radius:50%;
    background:var(--surface);border:1px solid var(--border);
    color:var(--accent);font-size:18px;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 16px rgba(0,0,0,.5);
    -webkit-tap-highlight-color:transparent;
    cursor:pointer;
  }
  .issue-nav-btn:active{background:var(--accent);color:var(--bg)}
  .issue-nav-counter{
    font-size:9px;color:var(--muted);text-align:center;
    background:var(--surface);border:1px solid var(--border);
    border-radius:10px;padding:2px 6px;
    box-shadow:0 4px 16px rgba(0,0,0,.5);
    white-space:nowrap;
  }

  /* ── Editor: fullscreen ── */
  .editor-overlay{padding:0;align-items:flex-end}
  .editor-overlay.open{display:flex;animation:fadeIn .2s ease}
  .editor-modal{
    border-radius:16px 16px 0 0;
    max-height:95vh;max-width:100%;
    animation:slideUp .3s cubic-bezier(.32,.72,0,1);
  }
  .editor-hdr{padding:14px 16px}
  .editor-title{font-size:15px}
  .editor-close{padding:8px 14px;border-radius:8px}
  .editor-body{padding:14px 16px}
  .editor-hint{font-size:13px}
  #cfg-textarea{height:45vh;font-size:13px;padding:12px;border-radius:10px;resize:none}
  .editor-footer{padding:12px 16px;gap:10px}
  .btn-check{padding:12px 24px;font-size:15px;border-radius:12px;flex:1}
  .editor-footer .editor-close{flex:0 0 auto}

  /* ── Generate modal: fullscreen ── */
  .gen-overlay{padding:0;align-items:flex-end}
  .gen-overlay.open{display:flex;animation:fadeIn .2s ease}
  .gen-modal{
    border-radius:16px 16px 0 0;
    max-height:95vh;max-width:100%;
    animation:slideUp .3s cubic-bezier(.32,.72,0,1);
  }
  .gen-hdr{padding:12px 16px;gap:8px;flex-wrap:wrap}
  .gen-title{font-size:14px}
  .gen-hint{padding:8px 16px;font-size:11px}
  .gen-code{font-size:12px;padding:12px 14px;line-height:1.6}
  .gen-footer{padding:10px 16px;flex-wrap:wrap;gap:8px}
  .gen-copy{padding:10px 18px;font-size:13px;border-radius:10px;flex:1;text-align:center}
}

/* ══════════════════════════════════════════
   MOBILE — PHONE (< 480px)
══════════════════════════════════════════ */
@media(max-width:480px){
  /* ── Header: stacked logo + buttons row ── */
  .hdr{
    flex-wrap:wrap;padding:10px 14px;gap:8px;
  }
  .logo{font-size:20px;flex:1}
  .hdr-btns{display:contents}
  .btn-cfg{flex:0 0 auto;padding:10px 12px;font-size:11px}

  /* ── Stats: 2x2 grid + ok full-width ── */
  .stats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;padding:10px 14px;
    overflow-x:visible;
  }
  .sc{min-width:0;padding:12px 14px;text-align:center}
  .sc.ok{grid-column:1/-1}
  .sn{font-size:26px}
  .sl{font-size:9px;letter-spacing:.4px}

  /* ── Filters: full-width pills ── */
  .filters{padding:8px 14px;gap:6px;flex-wrap:wrap;overflow-x:visible}
  .fb{flex:1 1 auto;text-align:center;padding:9px 10px;font-size:12px}
  .search{padding:12px 14px;font-size:15px;border-radius:12px;margin-top:4px}

  /* ── Cards ── */
  .main{padding:6px 10px 80px}
  .card{border-radius:12px;margin-bottom:10px}
  .ch{padding:12px 12px;gap:8px}
  .ct{font-size:12.5px}
  .cv{font-size:11.5px}
  .badge{font-size:9px;padding:3px 7px}

  /* ── Modal fullscreen ── */
  .modal{border-radius:0;max-height:100vh}
  .modal-overlay{padding:0}
  .modal-hdr{padding:8px 12px;min-height:40px;gap:4px}
  .modal-title{font-size:13px}
  .modal-close{padding:6px 10px;font-size:11px}
  .modal-legend{gap:6px;padding:4px 12px}
  .leg-item{font-size:8px}
  .cfg-table{font-size:10.5px;line-height:1.55}
  .ln{width:30px;min-width:30px;max-width:30px;padding:0 4px 0 3px;font-size:9px}
  .lc{padding:0 6px}
  .cfg-table tr.issue-line td.ln::after{width:4px;height:4px;margin-left:1px}
  .issue-nav{bottom:16px;right:12px;gap:6px}
  .issue-nav-btn{width:40px;height:40px;font-size:16px}

  /* ── Editor fullscreen ── */
  .editor-modal{border-radius:0;max-height:100vh}
  .editor-overlay{padding:0}
  #cfg-textarea{height:50vh}
  .btn-check{padding:14px 20px;font-size:15px}

  /* ── Generate fullscreen ── */
  .gen-modal{border-radius:0;max-height:100vh}
  .gen-overlay{padding:0}
  .gen-code{font-size:11px;padding:10px 12px}
}

/* ── Issue nav: hidden on desktop ── */
.issue-nav{display:none}

/* ── Animations ── */
@keyframes slideUp{
  from{transform:translateY(40px);opacity:.5}
  to{transform:translateY(0);opacity:1}
}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}

/* ── Bottom sheet for issue details on mobile ── */
.bottom-sheet-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);
  z-index:600;display:none;align-items:flex-end;justify-content:center;
}
.bottom-sheet-overlay.open{display:flex;animation:fadeIn .15s ease}
.bottom-sheet{
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px 20px 0 0;width:100%;max-width:100%;
  max-height:75vh;display:flex;flex-direction:column;overflow:hidden;
  animation:slideUp .3s cubic-bezier(.32,.72,0,1);
}
.bottom-sheet-handle{
  width:36px;height:4px;background:var(--border);border-radius:2px;
  margin:10px auto 6px;flex-shrink:0;
}
.bottom-sheet-body{
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:4px 18px 24px;
}
.bottom-sheet .tip-hdr{padding:8px 0 6px;border-bottom:1px solid var(--border)}
.bottom-sheet .tip-type{font-size:14px;margin-bottom:4px}
.bottom-sheet .tip-val{font-size:12px}
.bottom-sheet .tip-body{padding:10px 0}
.bottom-sheet .tip-label{font-size:10px;margin-bottom:4px}
.bottom-sheet .tip-sol{font-size:13px;margin-bottom:12px}
.bottom-sheet .tip-code{font-size:12px;padding:10px 12px;border-radius:8px}

/* ── Safe area for notched phones ── */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .main{padding-bottom:calc(80px + env(safe-area-inset-bottom))}
  .editor-footer{padding-bottom:calc(12px + env(safe-area-inset-bottom))}
  .bottom-sheet-body{padding-bottom:calc(24px + env(safe-area-inset-bottom))}
  .issue-nav{bottom:calc(20px + env(safe-area-inset-bottom))}
}
