.heide-snippet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1999;background:#0f172a66;animation:heide-snippet-fade-in .15s ease-out}@keyframes heide-snippet-fade-in{0%{opacity:0}to{opacity:1}}.heide-snippet-modal{position:fixed;z-index:2000;top:50%;left:50%;transform:translate(-50%,-50%);width:min(1400px,95vw);height:85vh;max-height:900px;background:var(--uml-surface, #fff);border:1px solid var(--uml-border, #e4e6ea);border-radius:12px;box-shadow:0 24px 60px #0f172a40;display:flex;flex-direction:column;font-family:var(--uml-font, -apple-system, BlinkMacSystemFont, "Inter", sans-serif);color:var(--uml-text, #1f2933);overflow:hidden}.heide-snippet-modal__header{flex-shrink:0;padding:14px 18px 0;border-bottom:1px solid var(--uml-border-soft, #eef0f3)}.heide-snippet-modal__title-row{display:flex;align-items:center;gap:16px;padding-bottom:14px}.heide-snippet-modal__title{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--uml-text, #1f2933);flex-shrink:0}.heide-snippet-modal__close{background:transparent;border:none;cursor:pointer;padding:6px;color:var(--uml-text-muted, #5a6573);border-radius:4px;transition:background .12s}.heide-snippet-modal__close:hover{background:var(--uml-accent-hover, rgba(45, 62, 80, .08));color:var(--uml-text, #1f2933)}.heide-snippet-search{flex:1;position:relative;display:flex;align-items:center}.heide-snippet-search__icon{position:absolute;left:12px;color:var(--uml-text-faint, #98a2b0);pointer-events:none}.heide-snippet-search__input{flex:1;height:36px;padding:0 60px 0 36px;font-family:inherit;font-size:13px;color:var(--uml-text, #1f2933);background:var(--uml-surface-alt, #fafbfc);border:1px solid var(--uml-border, #e4e6ea);border-radius:8px;outline:none;transition:border-color .12s,background .12s}.heide-snippet-search__input:focus{border-color:var(--uml-accent, #2d3e50);background:var(--uml-surface, #fff)}.heide-snippet-search__hint{position:absolute;right:10px;padding:2px 6px;font-size:10.5px;font-family:var(--uml-mono, ui-monospace, monospace);color:var(--uml-text-faint, #98a2b0);background:var(--uml-surface, #fff);border:1px solid var(--uml-border, #e4e6ea);border-radius:4px}.heide-snippet-active-filters{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:14px}.heide-snippet-modal__body{flex:1;display:grid;grid-template-columns:200px 380px 1fr;overflow:hidden}.heide-snippet-sidebar{padding:14px 12px;border-right:1px solid var(--uml-border-soft, #eef0f3);background:var(--uml-surface-alt, #fafbfc);overflow-y:auto;display:flex;flex-direction:column;gap:4px}.heide-snippet-sidebar__group{margin-top:14px}.heide-snippet-sidebar__group-label{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--uml-text-faint, #98a2b0);padding:6px 10px}.heide-snippet-sidebar__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;font-family:inherit;font-size:13px;color:var(--uml-text-muted, #5a6573);cursor:pointer;text-align:left;transition:background .12s,color .12s}.heide-snippet-sidebar__item:hover{background:var(--uml-accent-hover, rgba(45, 62, 80, .08));color:var(--uml-text, #1f2933)}.heide-snippet-sidebar__item--active{background:#e6edf5;color:var(--uml-accent, #2d3e50);font-weight:600}.heide-snippet-sidebar__count{font-size:11.5px;font-variant-numeric:tabular-nums;color:var(--uml-text-faint, #98a2b0)}.heide-snippet-sidebar__item--active .heide-snippet-sidebar__count{color:var(--uml-accent, #2d3e50)}.heide-snippet-sidebar__shortcuts{margin-top:auto;padding-top:16px;border-top:1px solid var(--uml-border-soft, #eef0f3)}.heide-snippet-sidebar__shortcuts-label{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--uml-text-faint, #98a2b0);padding:6px 10px;margin-bottom:4px}.heide-snippet-sidebar__shortcuts-list{margin:0;display:grid;grid-template-columns:auto 1fr;gap:5px 8px;padding:0 10px;align-items:center;font-size:11.5px;color:var(--uml-text-muted, #5a6573)}.heide-snippet-sidebar__shortcuts-list dt{display:inline-flex;align-items:center;gap:2px;white-space:nowrap;margin:0}.heide-snippet-sidebar__shortcuts-list dd{margin:0;line-height:1.3}.heide-snippet-sidebar__shortcuts-list kbd{padding:1px 5px;background:var(--uml-surface, #fff);border:1px solid var(--uml-border, #e4e6ea);border-radius:3px;font-family:var(--uml-mono, ui-monospace, monospace);font-size:10.5px;color:var(--uml-text-muted, #5a6573)}.heide-snippet-list{border-right:1px solid var(--uml-border-soft, #eef0f3);display:flex;flex-direction:column;overflow:hidden}.heide-snippet-list__header{flex-shrink:0;padding:14px 16px 8px;display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--uml-text-muted, #5a6573)}.heide-snippet-list__breadcrumb{font-weight:500}.heide-snippet-list__sort{color:var(--uml-text-faint, #98a2b0);cursor:pointer}.heide-snippet-list__items{flex:1;overflow-y:auto;padding:0 12px 12px;display:flex;flex-direction:column;gap:6px}.heide-snippet-list__banner{margin:0 12px 10px;padding:9px 12px;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;font-size:12px;line-height:1.45;color:#78350f}.heide-snippet-list__banner strong{font-weight:600}.heide-snippet-list__empty{padding:32px 16px;text-align:center;color:var(--uml-text-faint, #98a2b0);font-size:12.5px;font-style:italic}.heide-snippet-card{display:flex;gap:12px;width:100%;padding:10px 12px;background:var(--uml-surface, #fff);border:1px solid var(--uml-border-soft, #eef0f3);border-radius:8px;cursor:pointer;text-align:left;font-family:inherit;transition:border-color .12s,background .12s}.heide-snippet-card:hover{border-color:var(--uml-border, #e4e6ea);background:var(--uml-surface-alt, #fafbfc)}.heide-snippet-card--selected{border-color:var(--uml-accent, #2d3e50);background:#f0f4f8}.heide-snippet-card__icon{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--uml-surface-alt, #fafbfc);border:1px solid var(--uml-border-soft, #eef0f3);border-radius:6px;color:var(--uml-text-muted, #5a6573)}.heide-snippet-card__text{flex:1;min-width:0}.heide-snippet-card__name{font-size:13px;font-weight:600;color:var(--uml-text, #1f2933);line-height:1.3}.heide-snippet-card__desc{font-size:11.5px;color:var(--uml-text-muted, #5a6573);margin-top:2px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.heide-snippet-detail{display:flex;flex-direction:column;overflow:hidden}.heide-snippet-detail--empty{align-items:center;justify-content:center;color:var(--uml-text-faint, #98a2b0);font-style:italic}.heide-snippet-detail__body{flex:1;overflow-y:auto;padding:18px 22px}.heide-snippet-detail__header{margin-bottom:18px}.heide-snippet-detail__name{font-size:18px;font-weight:600;color:var(--uml-text, #1f2933);margin:0 0 8px;line-height:1.3}.heide-snippet-detail__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.heide-snippet-detail__desc{font-size:13px;color:var(--uml-text-muted, #5a6573);margin:0;line-height:1.5}.heide-snippet-detail__intro{margin:10px 0 0;padding:8px 12px;font-size:13px;line-height:1.55;color:var(--uml-text, #1f2933);background:var(--uml-surface-alt, #fafbfc);border-left:3px solid var(--uml-accent, #2d3e50);border-radius:0 6px 6px 0}.heide-snippet-tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;background:var(--uml-surface, #fff);border:1px solid var(--uml-border, #e4e6ea);border-radius:12px;font-family:inherit;font-size:10.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--uml-text-muted, #5a6573);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.heide-snippet-tag-chip:hover{background:var(--uml-accent-hover, rgba(45, 62, 80, .08));color:var(--uml-text, #1f2933)}.heide-snippet-tag-chip--active{background:#6366f1;color:#fff;border-color:#6366f1}.heide-snippet-tag-chip__remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;margin-left:2px;font-size:14px;font-weight:400;opacity:.8}.heide-snippet-tag-chip__remove:hover{opacity:1}.heide-snippet-detail__code-preview{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}.heide-snippet-detail__col{min-width:0}.heide-snippet-detail__col-label{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--uml-text-faint, #98a2b0);margin-bottom:6px}.heide-snippet-detail__code{margin:0;padding:12px 14px;background:var(--uml-surface-alt, #fafbfc);border:1px solid var(--uml-border-soft, #eef0f3);border-radius:8px;font-family:var(--uml-mono, ui-monospace, "SF Mono", monospace);font-size:11.5px;line-height:1.5;color:var(--uml-text, #1f2933);white-space:pre;overflow-x:auto;max-height:220px}.heide-snippet-detail__code code{font-family:inherit;background:none}.heide-snippet-detail__preview{display:flex;align-items:center;justify-content:center;padding:12px;background:var(--uml-surface-alt, #fafbfc);border:1px solid var(--uml-border-soft, #eef0f3);border-radius:8px;min-height:160px}.heide-snippet-preview{max-width:100%;max-height:200px;object-fit:contain}.heide-snippet-preview--zoomable{cursor:zoom-in;transition:filter .12s,transform .12s}.heide-snippet-preview--zoomable:hover{filter:brightness(1.04) drop-shadow(0 2px 6px rgba(45,62,80,.18))}.heide-snippet-preview--loading,.heide-snippet-preview--error{font-size:11px;color:var(--uml-text-faint, #98a2b0);font-style:italic}.heide-snippet-detail__do-dont{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}.heide-snippet-detail__do .heide-snippet-detail__col-label{color:#16a34a}.heide-snippet-detail__dont .heide-snippet-detail__col-label{color:#dc2626}.heide-snippet-detail__list{margin:0;padding:0;list-style:none}.heide-snippet-detail__list-item{display:flex;align-items:flex-start;gap:8px;padding:4px 0;font-size:12.5px;color:var(--uml-text, #1f2933);line-height:1.5}.heide-snippet-detail__list-item--do .heide-snippet-detail__list-icon{color:#16a34a}.heide-snippet-detail__list-item--dont .heide-snippet-detail__list-icon{color:#dc2626}.heide-snippet-detail__list-icon{flex-shrink:0;margin-top:3px}.heide-snippet-detail__mistake{margin-bottom:18px}.heide-snippet-detail__mistake-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.heide-snippet-detail__mistake-col{border:1px solid var(--uml-border-soft, #eef0f3);border-radius:8px;padding:10px 12px;background:var(--uml-surface-alt, #fafbfc)}.heide-snippet-detail__mistake-col--right{border-color:#bbf7d0;background:#f0fdf4}.heide-snippet-detail__mistake-col--wrong{border-color:#fecaca;background:#fef2f2}.heide-snippet-detail__mistake-label{font-size:11.5px;font-weight:600;margin-bottom:6px}.heide-snippet-detail__mistake-col--right .heide-snippet-detail__mistake-label{color:#16a34a}.heide-snippet-detail__mistake-col--wrong .heide-snippet-detail__mistake-label{color:#dc2626}.heide-snippet-detail__mistake-code{margin:0 0 8px;padding:8px 10px;font-family:var(--uml-mono, ui-monospace, monospace);font-size:11px;background:#fff;border-radius:4px;white-space:pre;overflow-x:auto}.heide-snippet-detail__mistake-preview{min-height:100px;display:flex;align-items:center;justify-content:center}.heide-snippet-detail__mistake-preview .heide-snippet-preview{max-height:120px}.heide-snippet-detail__mistake--warn-only .heide-snippet-detail__mistake-col{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"label label" "code  preview";gap:8px 14px;align-items:start}.heide-snippet-detail__mistake--warn-only .heide-snippet-detail__mistake-label{grid-area:label;margin-bottom:0}.heide-snippet-detail__mistake--warn-only .heide-snippet-detail__mistake-code{grid-area:code;margin:0;align-self:start}.heide-snippet-detail__mistake--warn-only .heide-snippet-detail__mistake-preview{grid-area:preview;min-height:0}.heide-snippet-detail__col-label--warn{color:#dc2626}.heide-impressum-link{background:none;border:none;font:inherit;color:inherit;cursor:pointer;padding:0;margin:0;white-space:nowrap;text-decoration:none;letter-spacing:inherit}.heide-impressum-link:hover{color:#1f2933;text-decoration:underline;text-underline-offset:3px}.heide-impressum-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f17208c;display:flex;align-items:center;justify-content:center;z-index:10000}.heide-impressum-box{position:relative;background:#fff;border-radius:10px;padding:28px 32px;max-width:640px;width:calc(100% - 40px);max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;font-family:var(--uml-sans, system-ui, sans-serif);font-size:14px;line-height:1.55;color:#1f2933}.heide-impressum-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:28px;line-height:1;color:#98a2b0;cursor:pointer;padding:4px 8px}.heide-impressum-close:hover{color:#1f2933}.heide-impressum-title{font-size:22px;font-weight:700;margin:0 0 20px}.heide-impressum-section h2{font-size:15px;font-weight:600;margin:0 0 8px}.heide-impressum-section p{margin:0 0 8px}.heide-impressum-section ul{margin:6px 0 0;padding-left:20px}.heide-impressum-section li{margin-bottom:4px}.heide-impressum-section a{color:#2563eb;text-decoration:underline}.heide-impressum-section a:hover{color:#1d4ed8}.heide-impressum-box hr{border:none;border-top:1px solid #e5e7eb;margin:18px 0}.heide-snippet-detail__footer{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:12px 22px;border-top:1px solid var(--uml-border-soft, #eef0f3);background:var(--uml-surface, #fff)}.heide-snippet-detail__footer-spacer{flex:1}.heide-snippet-detail__action{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--uml-surface, #fff);border:1px solid var(--uml-border, #e4e6ea);border-radius:6px;font-family:inherit;font-size:12.5px;font-weight:500;color:var(--uml-text, #1f2933);cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,color .12s}.heide-snippet-detail__action:hover{background:var(--uml-accent-hover, rgba(45, 62, 80, .08));border-color:var(--uml-accent, #2d3e50)}.heide-snippet-detail__action--primary{background:#2d3e50;border-color:#2d3e50;color:#fff}.heide-snippet-detail__action--primary:hover{background:#1c2935;border-color:#1c2935;color:#fff}.heide-snippet-detail__action--ok{background:#16a34a!important;border-color:#16a34a!important;color:#fff!important}.heide-snippet-detail__action kbd{padding:1px 5px;margin-left:4px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:3px;font-family:var(--uml-mono, ui-monospace, monospace);font-size:10.5px;opacity:.85}.heide-snippet-detail__action:not(.heide-snippet-detail__action--primary) kbd{background:var(--uml-surface-alt, #fafbfc);border-color:var(--uml-border, #e4e6ea);color:var(--uml-text-muted, #5a6573)}.heide-snippet-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2100;background:#0f172ab8;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px 32px;animation:heide-snippet-fade-in .12s ease-out;cursor:zoom-out}.heide-snippet-lightbox__close{position:absolute;top:14px;right:14px;background:#ffffffeb;border:1px solid rgba(255,255,255,.4);border-radius:8px;padding:6px;color:#1f2933;cursor:pointer;display:inline-flex;align-items:center;transition:background .12s}.heide-snippet-lightbox__close:hover{background:#fff}.heide-snippet-lightbox__label{color:#e5e7eb;font-size:13px;font-weight:500;margin-bottom:12px;text-align:center;max-width:min(900px,90vw);padding:4px 10px;background:#0f172a73;border-radius:6px}.heide-snippet-lightbox__stage{cursor:default;background:#fff;border-radius:10px;padding:24px;width:min(1200px,92vw);height:min(900px,75vh);overflow:auto;box-shadow:0 24px 60px #0006;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.heide-snippet-lightbox__img{display:block;width:100%;height:100%;object-fit:contain}.heide-snippet-lightbox__loading{font-size:13px;color:var(--uml-text-faint, #98a2b0);font-style:italic;padding:80px 120px}.heide-snippet-lightbox__hint{margin-top:14px;font-size:11.5px;color:#ffffffb3}.heide-snippet-lightbox__hint kbd{padding:1px 6px;background:#ffffff2e;border:1px solid rgba(255,255,255,.35);border-radius:3px;font-family:var(--uml-mono, ui-monospace, monospace);font-size:10.5px;color:#fff}
