:root{--bg: oklch(10% .018 260);--bg2: oklch(13% .022 255);--bg3: oklch(16% .02 258);--paper: oklch(96.5% .01 80);--ink: oklch(18% .025 255);--ink2: oklch(38% .02 250);--ink3: oklch(55% .015 250);--border: oklch(20% .02 260);--border2: oklch(26% .025 260);--amber: oklch(72% .165 55);--amber-dim: oklch(55% .12 55);--amber-bg: oklch(18% .04 55);--amber-border:oklch(30% .08 55);--rule: oklch(82% .025 75);--text-main: oklch(88% .012 80);--text-dim: oklch(60% .012 260);--text-faint: oklch(40% .01 260)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:EB Garamond,Georgia,serif;background:var(--bg);color:var(--text-main);font-size:16px;-webkit-font-smoothing:antialiased}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:48px;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.top-bar-title{display:flex;align-items:center;gap:10px;font-family:Cinzel,serif;font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--amber)}.book-icon{font-size:16px}.chr-overview-strip{height:108px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:8px 24px 10px;flex-shrink:0;overflow:hidden}.main-layout{display:flex;flex:1;overflow:hidden}.chapter-list{width:200px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;padding:16px 0}.chapter-list::-webkit-scrollbar{width:4px}.chapter-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.chapter-list-header{padding:0 16px 12px;font-family:DM Mono,monospace;font-size:9px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint)}.chapter-group{margin-bottom:6px}.chapter-group-label{padding:6px 16px 4px;font-family:DM Mono,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}.chapter-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 16px;background:none;border:none;cursor:pointer;text-align:left;font-family:DM Mono,monospace;font-size:12px;color:var(--text-dim);transition:background .1s,color .1s}.chapter-item:hover{background:var(--bg3);color:var(--text-main)}.chapter-item.active{background:var(--amber-bg);color:var(--amber)}.chapter-name{font-weight:500}.chapter-gene-count{font-size:10px;opacity:.6}.reader-area{flex:1;overflow-y:auto;padding:0 0 100px;display:flex;justify-content:center}.reader-area::-webkit-scrollbar{width:5px}.reader-area::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.book-reader{width:100%;max-width:720px;padding:40px 48px 0}.chapter-heading{margin-bottom:20px}.chapter-label{font-family:DM Mono,monospace;font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--text-faint)}.chapter-title{font-family:Cinzel,serif;font-size:21px;font-weight:500;color:var(--text-main);margin-top:4px}.ideogram-wrapper{margin-bottom:28px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:14px 20px 8px}.ideogram-wrapper svg{width:100%;height:auto;display:block}.gene-article{background:var(--paper);color:var(--ink);border-radius:0;padding:48px 56px 56px;margin-bottom:24px;position:relative;box-shadow:0 0 80px #02000066,0 0 0 1px #cac3ba;box-shadow:0 0 80px oklch(5% .05 55/.4),0 0 0 1px #cac3ba}.gene-article:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;opacity:.5}.gene-header{margin-bottom:28px}.gene-title-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:10px}.gene-name{font-family:Cinzel,serif;font-size:34px;font-weight:600;color:var(--ink);letter-spacing:.02em;line-height:1.1}.gene-type-badge{padding:3px 10px;border-radius:2px;font-family:DM Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.08em;white-space:nowrap;background:#e1d6c6;color:var(--amber-dim);border:1px solid oklch(78% .04 75)}.gene-type-badge.type-protein_coding{background:#e1d6c6;color:#964d09}.gene-type-badge.type-lncRNA{background:#c9dcdd;color:#006266;color:oklch(45% .12 200)}.gene-type-badge.type-pseudogene,.gene-type-badge.type-processed_pseudogene,.gene-type-badge.type-unprocessed_pseudogene,.gene-type-badge.type-transcribed_unprocessed_pseudogene{background:#d5d7e2;color:#4b4d8b}.gene-type-badge.type-miRNA{background:#e2d5cb;color:#925000;color:oklch(50% .14 60)}.gene-type-badge.type-snRNA,.gene-type-badge.type-snoRNA{background:#e5d3d1;color:#a43b38}.gene-meta{font-family:DM Mono,monospace;font-size:11px;color:var(--ink3);display:flex;flex-wrap:wrap;gap:4px;align-items:center}.meta-sep{color:var(--ink3);opacity:.4}.story-text{font-family:EB Garamond,Georgia,serif;font-size:17.5px;line-height:1.85;color:var(--ink);text-align:justify;text-wrap:pretty;-webkit-hyphens:auto;hyphens:auto}.story-text p{margin-bottom:1.4em}.story-text p:last-child{margin-bottom:0}.story-text p:first-child:first-letter{font-family:Cinzel,serif;font-size:4.2em;font-weight:600;float:left;line-height:.82;margin:.06em .12em 0 0;color:var(--amber-dim)}.cursor-blink{display:inline-block;animation:blink .8s step-start infinite;color:var(--amber);font-style:normal}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.story-generating{display:flex;align-items:center;gap:10px;color:var(--ink2);font-size:15px}.generating-label{font-style:italic}.story-empty{color:var(--ink3);font-style:italic}.gene-footer{margin-top:28px;padding-top:16px;border-top:1px solid var(--rule);display:flex;gap:20px;font-family:DM Mono,monospace;font-size:11px;color:var(--ink3)}.ensembl-id{font-family:DM Mono,monospace}.bookmark-btn{position:absolute;top:20px;right:20px;cursor:pointer;opacity:.3;transition:opacity .15s,transform .15s;background:none;border:none;padding:4px;color:var(--amber-dim)}.bookmark-btn:hover{opacity:.75;transform:scale(1.1)}.bookmark-btn.bookmarked{opacity:1}.book-nav{display:flex;justify-content:space-between;gap:0;margin-bottom:60px}.nav-btn{flex:1;padding:12px 20px;background:var(--bg2);border:1px solid var(--border);font-family:DM Mono,monospace;font-size:12px;font-weight:500;color:var(--text-dim);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.nav-btn:hover:not(:disabled){background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-prev{text-align:left;border-radius:6px 0 0 6px}.nav-next{text-align:right;border-radius:0 6px 6px 0;border-left:none}.nav-gene-name{font-weight:600;color:var(--amber)}.search-wrapper{position:relative;width:260px}.search-input{width:100%;padding:6px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:5px;font-family:DM Mono,monospace;font-size:12px;color:var(--text-main);outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--amber-dim);background:var(--bg3)}.search-input::placeholder{color:var(--text-faint)}.search-spinner{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:12px;height:12px;border:2px solid var(--border2);border-top-color:var(--amber);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg2);border:1px solid var(--border2);border-radius:6px;box-shadow:0 8px 32px #000003d9;list-style:none;z-index:100;max-height:320px;overflow-y:auto}.search-alpha-bar{display:flex;flex-wrap:wrap;gap:2px;padding:8px 10px;border-bottom:1px solid var(--border);background:var(--bg3)}.search-alpha-btn{font-family:DM Mono,monospace;font-size:10px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;cursor:pointer;color:var(--text-dim);border:1px solid transparent;transition:all .1s;background:none}.search-alpha-btn:hover:not(.empty){background:var(--bg2);border-color:var(--border2);color:var(--text-main)}.search-alpha-btn.active{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}.search-alpha-btn.empty{opacity:.2;cursor:default;pointer-events:none}.search-result{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.search-result:last-child{border-bottom:none}.search-result:hover{background:var(--bg3)}.search-result-name{font-family:DM Mono,monospace;font-size:13px;font-weight:500;color:var(--text-main)}.search-result-meta{display:flex;gap:6px;align-items:center}.search-result-chrom{font-family:DM Mono,monospace;font-size:10px;color:var(--text-faint)}.search-result-type{font-family:DM Mono,monospace;font-size:9px;padding:1px 6px;background:var(--amber-bg);color:var(--amber-dim);border-radius:2px}.loading-screen,.error-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dim);font-family:DM Mono,monospace}.loading-text{font-size:14px;color:var(--text-faint);font-style:italic;font-family:EB Garamond,serif}.error-screen h2{color:#d74745;font-size:18px;font-family:Cinzel,serif}.error-screen p{font-size:14px;color:var(--text-dim)}.error-screen code{background:var(--bg2);padding:2px 6px;border-radius:4px;font-size:13px}.reader-loading{display:flex;align-items:center;gap:10px;padding:40px 0;color:var(--text-faint);font-size:14px;font-family:DM Mono,monospace}.loading-pulse{width:10px;height:10px;background:var(--amber);border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}.reader-error{padding:40px;text-align:center;color:var(--text-dim)}.reader-error button{margin-top:12px;padding:8px 20px;background:var(--amber-dim);color:var(--bg);border:none;border-radius:4px;cursor:pointer;font-size:13px;font-family:DM Mono,monospace}.welcome{padding:60px 40px;text-align:center;color:var(--text-dim)}.welcome h1{font-family:Cinzel,serif;font-size:28px;color:var(--text-main);margin-bottom:12px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}@media(max-width:768px){.chapter-list{display:none}.book-reader{padding:24px 20px 0}.gene-article{padding:32px 24px 40px}.gene-name{font-size:26px}.story-text{font-size:16px}.chr-overview-strip{overflow-x:auto;justify-content:flex-start;padding:8px 16px 10px}}@media(max-width:480px){.gene-article{padding:24px 16px 32px}.gene-name{font-size:22px}}.book-wrap{position:relative;padding-right:18px;margin-bottom:24px}.book-wrap:after{content:"";position:absolute;top:6px;bottom:6px;right:0;width:18px;border-radius:0 3px 3px 0;background:repeating-linear-gradient(to bottom,#e6e0d8,#e6e0d8 1.5px,#d4d0cb 1.5px,#d4d0cb 3px);box-shadow:3px 0 10px #0000024d,inset -2px 0 6px #0000021f;pointer-events:none}.book-wrap .gene-article{margin-bottom:0;box-shadow:4px 3px #e2ddd6,8px 6px #d4d0cb,12px 9px #c7c3bf,0 16px 60px #02000073,0 2px 12px #00000440;box-shadow:4px 3px #e2ddd6,8px 6px #d4d0cb,12px 9px #c7c3bf,0 16px 60px oklch(5% .05 55 / .45),0 2px 12px #00000440}.book-wrap .gene-article>*{position:relative;z-index:2}.book-wrap .gene-article:after{content:"";position:absolute;top:0;left:0;width:48px;height:100%;background:linear-gradient(to right,oklch(5% .02 260 / .13) 0%,oklch(5% .02 260 / .06) 40%,transparent 100%);pointer-events:none;z-index:1;border-radius:0}@media(max-width:768px){.book-wrap{padding-right:10px}.book-wrap:after{width:10px}.book-wrap .gene-article{box-shadow:2px 2px #e2ddd6,4px 4px #d4d0cb,0 8px 30px #02000059;box-shadow:2px 2px #e2ddd6,4px 4px #d4d0cb,0 8px 30px oklch(5% .05 55 / .35)}}
