body,html{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol}#app{display:flex;height:100vh}.sidebar{width:250px;background-color:#f6f9fc;border-right:1px solid #e8e8e8;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:20px;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;gap:12px;position:sticky;top:0;background-color:#f6f9fc;z-index:1}.sidebar-header h1{font-size:1.2rem;margin:0;color:#333}.sidebar-title{color:inherit;text-decoration:none}.sidebar-title:hover{text-decoration:underline}.sidebar-github{margin-left:auto;display:inline-flex;align-items:center}.sidebar-github img{width:18px;height:18px;display:block}#pattern-nav{display:flex;flex-direction:column;padding:10px 0}.pattern-btn{background:none;border:none;text-align:left;padding:8px 20px;cursor:pointer;font-size:14px;color:#444;transition:background-color .2s}.pattern-btn:hover{background-color:#eef2f6}.pattern-btn.active{color:#1ea7fd;font-weight:700}.pattern-details{display:flex;flex-direction:column}.pattern-summary{padding:8px 20px;font-size:14px;color:#444;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.pattern-summary:hover{background-color:#eef2f6}.pattern-details-content{display:flex;flex-direction:column;padding-left:16px}.pattern-group{display:flex;flex-direction:column;padding:8px 0 4px}.pattern-group-title{padding:6px 20px 4px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#7b8794}.pattern-group-content{display:flex;flex-direction:column;padding-left:10px}.content{flex:1;background-color:#fff;display:grid;grid-template-rows:minmax(260px,1fr) 8px minmax(200px,1fr);min-height:0;min-width:0;overflow:hidden}.content.readme-only{display:block;background-color:#fbfbfd}.content.readme-only .viewer-pane,.content.readme-only .content-splitter{display:none}.content.readme-only .readme-content{height:100%;overflow:auto}#pattern-viewer{width:100%;height:100%;border:none;display:block}.viewer-pane{min-height:0;min-width:0;overflow:hidden}.content-splitter{background-color:#e8e8e8;cursor:row-resize;position:relative;touch-action:none}.content-splitter:after{content:"";position:absolute;left:50%;top:50%;width:64px;height:2px;transform:translate(-50%,-50%);background-color:#cfd8e3;border-radius:999px}.readme-pane{display:flex;flex-direction:column;min-height:0;min-width:0;background-color:#fbfbfd}.readme-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #e8e8e8;background-color:#fff;font-size:13px;color:#425466}.readme-theme{display:inline-flex;align-items:center;gap:8px}.readme-theme label{font-weight:600}.readme-theme select{padding:6px 10px;border-radius:6px;border:1px solid #d0d7e2;background-color:#fff;font-size:13px}.readme-link{margin-left:auto;color:#1a73e8;text-decoration:none;font-weight:600}.readme-link:hover{text-decoration:underline}.readme-content{flex:1 1 auto;min-height:0;padding:16px 18px 24px;overflow:auto;font-size:14px;line-height:1.6;color:#2b2f36}.readme-content h1,.readme-content h2,.readme-content h3{margin-top:0;color:#1f2937}.readme-content h2{margin-top:24px;font-size:1.2rem}.readme-content p{margin:0 0 12px}.readme-content ul,.readme-content ol{padding-left:20px;margin:0 0 12px}.readme-content blockquote{margin:0 0 12px;padding:12px 14px;background-color:#f3f5f8;border-left:3px solid #cbd5e1;color:#475569}.readme-content code{font-family:ui-monospace,SFMono-Regular,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;background-color:#eef2f6;padding:2px 4px;border-radius:4px;font-size:.9em}.readme-content pre{background-color:#111827;color:#f9fafb;padding:12px;border-radius:6px;overflow:auto;margin:0 0 12px}.readme-content pre code{background:none;padding:0;color:inherit}.readme-empty{display:flex;align-items:center;justify-content:center;text-align:center}.readme-empty p{margin:0;font-size:13px;color:#9aa3b2}
