@import"https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;1,300;1,400&family=Source+Sans+Pro:wght@400;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#333;background-color:#f5f5f5}.app{min-height:100vh;padding:2rem}.app-nav{display:flex;gap:1rem;margin-bottom:2rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.app-nav button{background:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.95rem;transition:background .3s}.app-nav button:hover{background:#2980b9}.app-nav button.active{background:#1a6da3;box-shadow:inset 0 2px 4px #0003}.tree-visualization{max-width:1400px;margin:0 auto}.tree-header{position:sticky;top:0;background:#f5f5f5;z-index:200;padding:.5rem 1rem;margin:-2rem -2rem 1rem;border-bottom:1px solid #ddd;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.tree-header h1{color:#2c3e50;margin:0;font-size:1.4rem}.tree-subtitle{color:#666;font-size:.85rem}.breadth-legend{margin-left:auto;position:relative}.legend-toggle{background:#fff;border:1px solid #ccc;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;color:#333;white-space:nowrap}.legend-toggle:hover{background:#f0f0f0}.legend-expanded{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ccc;border-radius:4px;padding:.75rem;margin-top:4px;box-shadow:0 4px 12px #00000026;z-index:300;min-width:320px}.legend-item{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.85rem;color:#333}.legend-color{width:16px;height:16px;border-radius:3px;flex-shrink:0}.tree-description{text-align:center;color:#666;margin-bottom:2rem}.tree-container{position:relative;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;transition:all .5s ease-out}.tree-container svg{display:block;margin:0 auto;transition:all .5s ease-out}.tree-node:hover rect{filter:brightness(1.1)}.tree-node.level-0 rect{filter:drop-shadow(0 4px 6px rgba(0,0,0,.2))}.tree-node.level-1 rect{filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.tree-node.level-2 rect{filter:drop-shadow(0 1px 3px rgba(0,0,0,.1))}.landing-page{max-width:1000px;margin:0 auto;text-align:center;padding:3rem 1rem}.landing-page h1{font-size:3.5rem;color:#2c3e50;margin-bottom:1rem}.tagline{font-size:1.3rem;color:#555;margin-bottom:3rem;max-width:700px;margin-left:auto;margin-right:auto}.landing-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.primary-button{background:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1.1rem;transition:background .3s}.primary-button:hover{background:#2980b9}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin:3rem 0}.feature{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.feature h3{font-size:1.3rem;margin-bottom:.5rem;color:#2c3e50}.feature p{color:#666;font-size:.95rem}.start-button{background:#3498db;color:#fff;border:none;padding:1rem 3rem;font-size:1.2rem;border-radius:8px;cursor:pointer;margin-top:2rem;transition:background .3s}.start-button:hover{background:#2980b9}.anchor-list{max-width:800px;margin:0 auto}.anchor-list h2{font-size:2.5rem;color:#2c3e50;margin-bottom:.5rem}.anchor-list>p{color:#666;margin-bottom:2rem}.anchors{display:flex;flex-direction:column;gap:1rem}.anchor-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.anchor-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.anchor-status{font-size:1.5rem;color:#3498db;min-width:30px}.anchor-card h3{flex:1;font-size:1.1rem;color:#2c3e50;text-align:left}.start-anchor-button{background:#3498db;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.95rem;transition:background .3s}.start-anchor-button:hover{background:#2980b9}.narrative-reading{max-width:800px;margin:0 auto;background:#fff;padding:3rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.narrative-header h1{font-size:2rem;color:#2c3e50;margin-bottom:.5rem}.prerequisites{color:#666;font-style:italic;margin-bottom:2rem}.narrative-text{line-height:1.8;font-size:1.1rem;margin-bottom:3rem}.narrative-text p{margin-bottom:1.5rem}.key-concepts{background:#f8f9fa;padding:2rem;border-radius:8px;margin-bottom:2rem}.key-concepts h2{font-size:1.5rem;color:#2c3e50;margin-bottom:.5rem}.concepts-note{color:#666;font-size:.9rem;font-style:italic;margin-bottom:1rem}.key-concepts ol{padding-left:1.5rem}.key-concepts li{margin-bottom:.75rem;color:#555}.quiz-button{background:#27ae60;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;width:100%;transition:background .3s}.quiz-button:hover{background:#229954}.why-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:500;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.why-panel-overlay.visible{opacity:1;visibility:visible}.why-panel{position:fixed;top:0;right:0;width:480px;height:100vh;background:#fff;box-shadow:-4px 0 20px #00000026;z-index:600;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.why-panel.open{transform:translate(0)}.why-panel-minimize{position:absolute;left:-40px;top:50%;transform:translateY(-50%);width:40px;height:100px;background:#3498db;border:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;transition:filter .2s}.why-panel-minimize:hover{filter:brightness(1.1)}.why-panel-minimize .minimize-icon{font-size:16px}.why-panel-minimize .minimize-text{writing-mode:vertical-rl;text-orientation:mixed;font-size:11px;font-weight:600;letter-spacing:.5px}.why-panel-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.why-panel-header{padding:24px;border-bottom:3px solid #3498db;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;background:#fafafa}.why-panel-title{flex:1}.why-label{font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px}.why-panel-title h2{margin:0;font-size:1.4rem;color:#2c3e50;line-height:1.3}.why-breadth-badge{padding:6px 12px;border-radius:4px;color:#fff;font-size:12px;font-weight:600;white-space:nowrap}.why-panel-explanation{padding:16px 24px;font-size:13px;color:#555;line-height:1.5;background:#fff;border-bottom:1px solid #eee}.why-formula{margin-top:10px;padding:8px 12px;background:#f0f4f8;border-radius:4px;font-family:monospace;font-size:12px;color:#666}.why-panel-candidates{flex:1;padding:16px 24px;display:flex;flex-direction:column;gap:2px}.why-candidates-header{display:flex;align-items:center;padding:10px 12px;font-size:11px;font-weight:700;color:#888;text-transform:uppercase;border-bottom:2px solid #ddd;background:#f8f8f8;border-radius:4px 4px 0 0}.why-candidate-wrapper{border-bottom:1px solid #eee}.why-candidate-wrapper:last-child{border-bottom:none}.why-candidate-row{display:flex;align-items:center;padding:10px 12px;background:#fafafa;border-left:4px solid transparent;transition:background .15s ease;cursor:pointer}.why-candidate-wrapper:nth-child(odd) .why-candidate-row{background:#f5f5f5}.why-candidate-row:hover{background:#eef4f9}.why-candidate-row.selected{background:#3498db1a}.why-candidate-row.selected .why-col-title{font-weight:600}.why-candidate-row.expanded{background:#e8f0f8}.why-expand-icon{margin-left:8px;font-size:10px;color:#888}.why-candidate-details{padding:12px 16px 12px 44px;background:#f8fafc;border-left:4px solid #3498db;font-size:12px;line-height:1.5}.why-justification{margin-bottom:8px;color:#444}.why-justification:last-child{margin-bottom:0}.why-justification strong{color:#2c3e50}.why-justification.why-no-data{color:#888;font-style:italic}.why-col-rank{width:28px;font-size:12px;color:#888;font-weight:600}.why-col-title{flex:1;font-size:13px;color:#2c3e50;padding-right:12px}.why-col-score{width:50px;text-align:center;font-size:12px;color:#666}.why-total{font-weight:700;color:#2c3e50}.why-panel-footer{padding:16px 24px;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;background:#fafafa}.why-footer-note{color:#888;font-weight:400}.why-schemes-intro{padding:12px 16px;background:#f8f8f8;border-bottom:1px solid #eee;font-size:14px;color:#2c3e50}.why-scheme-wrapper{border-bottom:1px solid #eee}.why-scheme-wrapper:last-child{border-bottom:none}.why-scheme-row{padding:12px 16px;background:#fafafa;border-left:4px solid transparent;cursor:pointer;transition:background .15s ease}.why-scheme-wrapper:nth-child(odd) .why-scheme-row{background:#f5f5f5}.why-scheme-row:hover{background:#eef4f9}.why-scheme-row.selected{background:#27ae601a}.why-scheme-row.expanded{background:#e8f5e9}.why-scheme-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.why-scheme-rank{font-size:14px;font-weight:600;color:#666;min-width:24px}.why-scheme-name{flex:1;font-size:14px;font-weight:600;color:#2c3e50;display:flex;align-items:center;gap:8px}.why-selected-badge{background:#27ae60;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase}.why-scheme-score{font-size:14px;font-weight:700;color:#2c3e50;min-width:40px;text-align:right}.why-scheme-anchors{display:flex;flex-wrap:wrap;gap:6px;padding-left:32px}.why-scheme-anchor{background:#e8e8e8;color:#555;font-size:11px;padding:3px 8px;border-radius:3px}.why-scheme-row.selected .why-scheme-anchor{background:#27ae6033;color:#1e7e34}.why-scheme-details{padding:12px 16px 12px 48px;background:#f8fafc;border-left:4px solid #27ae60;font-size:12px;line-height:1.5}.why-rating{margin-bottom:8px;color:#444}.why-rating:last-child{margin-bottom:0}.why-rating strong{color:#2c3e50}.narrative-page{min-height:100vh;background:#fdfcfa;padding-bottom:80px}.narrative-breadcrumbs{max-width:800px;margin:0 auto;padding:20px 24px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;color:#666}.breadcrumb-link{color:#2563eb;text-decoration:none;transition:color .15s ease}.breadcrumb-link:hover{color:#1d4ed8;text-decoration:underline}.breadcrumb-separator{margin:0 8px;color:#999}.breadcrumb-current{color:#333;font-weight:600}.narrative-header{max-width:700px;margin:0 auto;padding:40px 24px 32px;text-align:center;border-bottom:1px solid #e5e5e5}.narrative-title{font-family:Merriweather,Georgia,serif;font-size:2.5rem;font-weight:700;color:#1a1a1a;line-height:1.2;margin:0 0 16px;letter-spacing:-.02em}.narrative-meta{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;color:#666;display:flex;flex-direction:column;align-items:center;gap:8px}.read-time{color:#888;font-weight:500}.prerequisites{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}.prereq-label{color:#888}.prereq-link{color:#2563eb;text-decoration:none;font-weight:500}.prereq-link:hover{text-decoration:underline}.narrative-content{max-width:680px;margin:0 auto;padding:48px 24px}.narrative-text{font-family:Merriweather,Georgia,serif;font-size:1.125rem;line-height:1.8;color:#2d2d2d;letter-spacing:.01em}.narrative-text p{margin:0 0 1.75em;text-align:left}.narrative-text p:first-child:first-letter{font-size:3.5em;float:left;line-height:.8;padding-right:12px;padding-top:6px;font-weight:700;color:#1a1a1a}.narrative-text strong{font-weight:700;color:#1a1a1a}.narrative-text em{font-style:italic}.narrative-text blockquote{margin:2em 0;padding:1.5em 2em;background:#f8f7f5;border-left:4px solid #c4a35a;font-style:italic;color:#444}.narrative-text blockquote cite{display:block;margin-top:1em;font-style:normal;font-size:.9em;color:#666}.footnote-ref{color:#2563eb;text-decoration:none;font-size:.8em;font-weight:700;font-family:Source Sans Pro,-apple-system,sans-serif;padding:0 1px;transition:color .15s}.footnote-ref:hover{color:#2a5a8c}.footnotes-list{max-width:680px;margin:0 auto;padding:24px 24px 0;border-top:1px solid #e5e5e5;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:.85rem;color:#666;line-height:1.6}.footnotes-list li{margin-bottom:6px;padding-left:4px}.footnotes-list a{color:#555;text-decoration:none;border-bottom:1px dotted #aaa;transition:color .15s,border-color .15s}.footnotes-list a:hover{color:#2a5a8c;border-bottom-color:#2a5a8c}.sub-anchor-link{font-weight:700;text-decoration:none;padding:2px 7px;border-radius:4px;border:1px solid;transition:background .15s,border-color .15s}.sub-anchor-link-analytical{color:#2a5a8c;background:#e8f0fa;border-color:#c4d7ed}.sub-anchor-link-analytical:hover{background:#d6e5f5;border-color:#a8c4de}.sub-anchor-link-temporal{color:#2d6a4f;background:#e4f5ec;border-color:#b7dfc8}.sub-anchor-link-temporal:hover{background:#d0eddb;border-color:#96cead}.fact-check-badge{display:inline-block;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:12px;font-weight:700;color:#27ae60;background:#e8f8e8;padding:4px 12px;border-radius:12px;margin-bottom:16px}.fact-check-section{max-width:680px;margin:0 auto 32px;text-align:center}.fact-check-button{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:600;color:#2c3e50;background:#fff;border:1px solid #2c3e50;border-radius:6px;padding:10px 24px;cursor:pointer;transition:all .15s}.fact-check-button:hover:not(:disabled){background:#2c3e50;color:#fff}.fact-check-button:disabled{opacity:.7;cursor:default;border-color:#888;color:#888}.fact-check-error{color:#dc3545;font-size:14px;margin-top:8px}.sources-section{max-width:680px;margin:0 auto 48px;border:1px solid #e5e2d9;border-radius:8px;overflow:hidden}.sources-heading{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;font-weight:700;color:#2c3e50;padding:16px 24px;cursor:pointer;background:#f8f7f5;-webkit-user-select:none;user-select:none}.sources-heading:hover{background:#f0efe9}.sources-list{margin:0;padding:16px 24px 16px 40px;list-style-type:decimal}.source-item{margin-bottom:12px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;line-height:1.5}.source-link{color:#2c3e50;font-weight:600;text-decoration:none}.source-link:hover{text-decoration:underline}.source-claim{display:block;color:#666;font-size:13px;margin-top:2px}.key-concepts-box{max-width:680px;margin:0 auto 48px;padding:32px;background:linear-gradient(135deg,#f8f7f5,#f0efe9);border-radius:8px;border:1px solid #e5e2d9}.concepts-heading{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #c4a35a}.concepts-list{font-family:Merriweather,Georgia,serif;font-size:1rem;line-height:1.7;color:#333;margin:0;padding-left:24px}.concept-item{margin-bottom:16px;padding-left:8px}.concept-item:last-child{margin-bottom:0}.concept-item::marker{color:#c4a35a;font-weight:700}.concepts-note{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:.9rem;color:#666;margin:24px 0 0;padding-top:16px;border-top:1px solid #e5e2d9;font-style:italic}.quiz-section{max-width:680px;margin:0 auto;padding:0 24px;text-align:center}.quiz-button{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.125rem;font-weight:600;padding:16px 48px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #2563eb40}.quiz-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.quiz-button:active{transform:translateY(0)}.narrative-loading{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:40px 24px}.loading-content{text-align:center;max-width:500px}.loading-title{font-family:Merriweather,Georgia,serif;font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 16px}.loading-scope{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.1rem;line-height:1.6;color:#555;margin:0 0 40px}.loading-progress{display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:24px}.loading-spinner{width:48px;height:48px;border:3px solid #e5e5e5;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-stage{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.125rem;font-weight:600;color:#2563eb;margin:0}.loading-note{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:.9rem;color:#888;margin:0}.narrative-error{min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center}.narrative-error h1{font-family:Merriweather,Georgia,serif;font-size:1.75rem;color:#1a1a1a;margin:0 0 12px}.narrative-error p{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1rem;color:#666;margin:0 0 24px}.back-button{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1rem;font-weight:600;padding:12px 24px;background:#f0f0f0;color:#333;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.back-button:hover{background:#e5e5e5}.breadth-indicator{display:inline-block;padding:4px 12px;background:#2563eb;color:#fff;font-size:12px;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.breadth-tabs{display:flex;gap:8px;justify-content:center;margin-top:24px;padding-top:24px;border-top:1px solid #e5e5e5}.breadth-tab{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:600;padding:10px 20px;background:#f5f5f5;color:#555;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease}.breadth-tab:hover{background:#ebebeb;color:#333}.breadth-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.loading-breadth{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:600;color:#2563eb;margin:0 0 24px;padding:6px 16px;background:#2563eb1a;border-radius:4px;display:inline-block}.loading-dots{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.loading-dot{width:12px;height:12px;border-radius:50%;background:#e0e0e0;transition:all .3s ease}.loading-dot.active{background:#2563eb}.loading-dot.current{background:#2563eb;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.retry-button{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1rem;font-weight:600;padding:12px 24px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.retry-button:hover{background:#1d4ed8}.child-anchors-box{max-width:680px;margin:0 auto 48px;padding:32px;background:#fff;border-radius:8px;border:1px solid #e5e5e5}.child-anchors-heading{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.125rem;font-weight:700;color:#1a1a1a;margin:0 0 20px}.child-anchors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.child-anchor-link{display:block;padding:18px 16px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e8dcc8;text-decoration:none;border-radius:8px;font-family:Merriweather,Georgia,serif;font-size:14px;font-weight:600;text-align:center;transition:all .2s ease;border:1px solid rgba(232,220,200,.15);letter-spacing:.02em;line-height:1.4}.child-anchor-link:hover{background:linear-gradient(135deg,#2c1810,#1a1a2e);color:#f5e6d0;border-color:#e8dcc84d;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}@media(max-width:768px){.narrative-title{font-size:1.875rem}.narrative-header{padding:32px 20px 24px}.narrative-content{padding:32px 20px}.narrative-text{font-size:1.0625rem;line-height:1.75}.narrative-text p:first-child:first-letter{font-size:2.75em;padding-right:8px}.key-concepts-box{margin:0 20px 40px;padding:24px}.quiz-section{padding:0 20px}.quiz-button{width:100%;padding:18px 24px}.narrative-breadcrumbs{padding:16px 20px;font-size:13px}.loading-title{font-size:1.5rem}.loading-scope{font-size:1rem}.breadth-tabs{flex-direction:column;gap:8px}.breadth-tab{width:100%}.child-anchors-box{margin:0 20px 40px;padding:24px}.child-anchors-grid{grid-template-columns:1fr}.error-actions{flex-direction:column;width:100%;padding:0 20px}.retry-button,.error-actions .back-button{width:100%}}.breadth-tab.disabled{opacity:.4;cursor:not-allowed;background:#f0f0f0;color:#999;border-color:#e0e0e0}.breadth-tab.disabled:hover{background:#f0f0f0;color:#999}.tree-error-banner{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#dc3545;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;z-index:10000;cursor:pointer;box-shadow:0 4px 12px #dc35454d;max-width:90vw;text-align:center;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.app{padding:1rem}.app-nav{flex-wrap:wrap;gap:.5rem;padding:.75rem;margin-bottom:1rem}.app-nav button{font-size:.85rem;padding:.4rem .75rem}.tree-visualization{max-width:100%}.tree-container{overflow-x:auto}}@media(max-width:480px){.narrative-title{font-size:1.5rem}.narrative-text{font-size:1rem}.narrative-text p:first-child:first-letter{font-size:2.25em}.concepts-list{font-size:.9375rem}}.nav-auth{margin-left:auto;display:flex;align-items:center}.sign-in-button{background:transparent;color:#3498db;border:1px solid #3498db;padding:.4rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.sign-in-button:hover{background:#3498db;color:#fff}.flashcard-save-section{max-width:680px;margin:0 auto 48px;padding:32px;background:#fff;border-radius:8px;border:1px solid #e5e5e5}.flashcard-save-heading{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.125rem;font-weight:700;color:#1a1a1a;margin:0 0 20px}.flashcard-save-actions{margin-bottom:20px}.save-all-button{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:600;padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.save-all-button:hover:not(:disabled){background:#1d4ed8}.save-all-button:disabled{opacity:.5;cursor:not-allowed}.flashcard-save-list{display:flex;flex-direction:column;gap:12px}.flashcard-save-item{display:flex;gap:16px;align-items:flex-start;padding:16px;background:#f8f8f8;border-radius:6px;border:1px solid #e5e5e5}.flashcard-save-content{flex:1}.flashcard-save-question{font-size:14px;color:#333;margin:0 0 8px;line-height:1.5}.flashcard-save-answer{font-size:13px;color:#666;margin:0;line-height:1.5}.flashcard-save-button{font-size:13px;font-weight:600;padding:6px 16px;background:#2563eb;color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}.flashcard-save-button:hover:not(:disabled){background:#1d4ed8}.flashcard-save-button.saved{background:#27ae60;cursor:default}.flashcard-save-button:disabled{opacity:.7}.flashcard-sign-in-prompt{text-align:center;padding:24px;color:#666}.sign-in-prompt-button{margin-top:12px;font-size:14px;font-weight:600;padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer}.sign-in-prompt-button:hover{background:#1d4ed8}.flashcards-page{max-width:900px;margin:0 auto;padding:0 24px}.flashcards-header{text-align:center;margin-bottom:40px}.flashcards-header h1{font-family:Merriweather,Georgia,serif;font-size:2rem;color:#1a1a1a;margin:0 0 8px}.flashcards-count{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;color:#888;margin:0}.flashcards-loading{text-align:center;padding:80px 24px;color:#666;font-size:1.1rem}.flashcards-empty{text-align:center;padding:80px 24px}.flashcards-empty h2{font-family:Merriweather,Georgia,serif;font-size:1.5rem;color:#1a1a1a;margin:0 0 12px}.flashcards-empty p{color:#666;font-size:1rem}.flashcards-groups{display:flex;flex-direction:column;gap:40px}.flashcard-group-title{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:1.125rem;font-weight:700;color:#2c3e50;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e5e5e5}.flashcard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.flashcard{perspective:1000px;cursor:pointer;min-height:200px}.flashcard-inner{position:relative;width:100%;height:100%;min-height:200px;transition:transform .5s;transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;top:0;left:0;width:100%;height:100%;backface-visibility:hidden;border-radius:8px;padding:24px;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box}.flashcard-front{background:#fff;border:1px solid #e5e5e5;box-shadow:0 2px 8px #00000014}.flashcard-back{background:#f0f4f8;border:1px solid #d0d8e0;transform:rotateY(180deg)}.flashcard-question{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;font-weight:600;color:#1a1a1a;line-height:1.5;margin:0;text-align:center}.flashcard-hint{font-size:12px;color:#999;margin-top:16px;text-align:center}.flashcard-answer{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;color:#333;line-height:1.6;margin:0;text-align:center}.flashcard-delete{margin-top:16px;align-self:center;font-size:12px;padding:4px 12px;background:transparent;color:#dc3545;border:1px solid #dc3545;border-radius:4px;cursor:pointer;transition:all .15s}.flashcard-delete:hover:not(:disabled){background:#dc3545;color:#fff}.flashcard-delete:disabled{opacity:.5}.flashcards-tabs{display:flex;justify-content:center;gap:0;margin-top:16px;border-bottom:2px solid #e5e5e5}.flashcards-tab{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;font-weight:600;color:#888;background:none;border:none;padding:8px 24px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.flashcards-tab:hover{color:#333}.flashcards-tab.active{color:#2c3e50;border-bottom-color:#2c3e50}.study-session{max-width:600px;margin:0 auto;padding:24px 0}.study-progress{margin-bottom:24px}.study-progress-bar{height:4px;background:#e5e5e5;border-radius:2px;overflow:hidden}.study-progress-fill{height:100%;background:#2c3e50;transition:width .3s ease}.study-progress-text{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:13px;color:#888;display:block;text-align:center;margin-top:8px}.study-card-context{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.study-narrative-link{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;color:#2c3e50;text-decoration:none;font-weight:600}.study-narrative-link:hover{text-decoration:underline}.study-breadth-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase}.breadth-A{background:#e8f4fd;color:#1a73e8}.breadth-B{background:#fef3e2;color:#e67e22}.study-card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;padding:40px 32px;box-shadow:0 2px 12px #0000000f;text-align:center}.study-question{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:18px;font-weight:600;color:#1a1a1a;line-height:1.6;margin:0}.study-show-answer{margin-top:32px;padding:12px 40px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:16px;font-weight:600;background:#2c3e50;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.study-show-answer:hover{background:#34495e}.study-card-divider{height:1px;background:#e5e5e5;margin:24px 0}.study-answer{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:16px;color:#333;line-height:1.6;margin:0}.study-rating-buttons{display:flex;justify-content:center;gap:8px;margin-top:32px}.study-rating-btn{flex:1;max-width:100px;padding:12px 8px;border:2px solid;border-radius:8px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s}.study-rating-btn:disabled{opacity:.6;cursor:default}.rating-label{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:700}.rating-interval{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:12px;opacity:.7}.rating-again{color:#dc3545;border-color:#dc3545}.rating-hard{color:#e67e22;border-color:#e67e22}.rating-good{color:#27ae60;border-color:#27ae60}.rating-easy{color:#2980b9;border-color:#2980b9}.study-rating-btn.rating-again:hover:not(:disabled){background:#dc3545;color:#fff}.study-rating-btn.rating-again:hover:not(:disabled) .rating-interval{color:#fff}.study-rating-btn.rating-hard:hover:not(:disabled){background:#e67e22;color:#fff}.study-rating-btn.rating-hard:hover:not(:disabled) .rating-interval{color:#fff}.study-rating-btn.rating-good:hover:not(:disabled){background:#27ae60;color:#fff}.study-rating-btn.rating-good:hover:not(:disabled) .rating-interval{color:#fff}.study-rating-btn.rating-easy:hover:not(:disabled){background:#2980b9;color:#fff}.study-rating-btn.rating-easy:hover:not(:disabled) .rating-interval{color:#fff}.study-empty,.study-complete{text-align:center;padding:60px 24px}.study-empty h2,.study-complete h2{font-family:Merriweather,Georgia,serif;font-size:1.5rem;color:#1a1a1a;margin:0 0 12px}.study-empty p,.study-complete p{color:#666;font-size:1rem;margin:0 0 20px}.study-stats-summary{display:flex;justify-content:center;gap:24px;margin-bottom:20px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;color:#888}.study-complete-stats{margin:24px 0}.study-complete-total{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0 0 12px}.study-complete-breakdown{display:flex;justify-content:center;gap:16px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;font-weight:600}.study-next-due{color:#888;font-size:14px;margin:16px 0}.study-complete-actions{display:flex;justify-content:center;gap:16px;margin-top:24px}.study-again-button{padding:10px 24px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;font-weight:600;background:#2c3e50;color:#fff;border:none;border-radius:6px;cursor:pointer}.study-again-button:hover{background:#34495e}.study-browse-link{padding:10px 24px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:15px;font-weight:600;background:none;color:#2c3e50;border:1px solid #2c3e50;border-radius:6px;cursor:pointer}.study-browse-link:hover{background:#f0f4f8}.srs-badge{position:absolute;top:8px;right:8px;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.srs-new{background:#e8f4fd;color:#1a73e8}.srs-due{background:#fde8e8;color:#dc3545}.srs-scheduled{background:#e8f8e8;color:#27ae60}.flashcard-group-header{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:8px;border-bottom:2px solid #e5e5e5;margin-bottom:16px}.flashcard-group-header .flashcard-group-title{margin:0;padding:0;border:none}.flashcard-narrative-link{font-family:Source Sans Pro,-apple-system,sans-serif;font-size:13px;color:#2c3e50;text-decoration:none;font-weight:600}.flashcard-narrative-link:hover{text-decoration:underline}.flashcard-table{width:100%;border-collapse:collapse;font-family:Source Sans Pro,-apple-system,sans-serif;font-size:14px;margin-bottom:8px}.flashcard-table thead th{text-align:left;padding:10px 12px;font-weight:600;color:#666;border-bottom:2px solid #e5e5e5;font-size:13px;text-transform:uppercase;letter-spacing:.03em}.flashcard-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .15s}.flashcard-table tbody tr:hover{background:#fafafa}.flashcard-table td{padding:10px 12px;vertical-align:top}.flashcard-table-question{font-weight:500;color:#333;max-width:320px}.flashcard-table-answer{color:#555;max-width:320px}@media(max-width:768px){.flashcard-save-item{flex-direction:column}.flashcard-save-button{align-self:flex-start}.flashcard-table{font-size:13px}.flashcard-table-question,.flashcard-table-answer{max-width:200px}.flashcards-page{padding:0 16px}.study-rating-buttons{gap:4px}.study-rating-btn{padding:10px 4px}.study-card{padding:24px 16px}}
