html,body,#root{height:100%;margin:0}html{font-size:125%}body{overflow-x:hidden;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#111}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:1rem 2rem;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:baseline}.app-body{flex:1;display:flex;align-items:stretch}.app-main{flex:1 1 auto;padding:2rem;overflow-y:auto;min-width:0}.app-chat{flex:0 0 360px;width:360px;padding:2rem 2rem 2rem 0;position:sticky;top:72px;align-self:flex-start}.app-body.chat-expanded .app-main{display:none}.app-body.chat-expanded .app-chat{position:static;top:auto;flex:1 1 auto;width:100%;max-width:960px;padding:2rem;margin:0 auto}.page-body{max-width:720px;margin:0 auto;text-align:left}.page-body h2{text-align:center}.reading-section{margin-top:1.75rem}.reading-section:first-of-type{margin-top:1rem}.reading-section-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.9rem}.reading-section-line{flex:1;height:1px;background:#e5e5e5}.reading-section-title{font-size:.95rem;font-weight:600;color:#444;white-space:nowrap}.page-tiles{margin-top:2rem}.page-tiles h3{margin-bottom:1rem}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;align-items:stretch}.reading-section .tile-grid,.page-tiles.about-tiles .tile-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tile{display:flex;flex-direction:column;justify-content:flex-start;height:100%;padding:.9rem 1rem;border-radius:10px;border:1px solid #e5e5e5;background:#fafafa;text-decoration:none;color:inherit;transition:box-shadow .15s ease,transform .15s ease,background-color .15s ease}.tile h4{margin:0 0 .35rem;font-size:.95rem}.tile p{margin:0;font-size:.85rem;color:#444}.tile:hover{background:#fff;box-shadow:0 6px 18px #0000000f;transform:translateY(-1px)}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-header-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem}.chat-title{font-size:1rem;font-weight:600;margin:0}.chat-expand-btn{font-size:.75rem;padding:.2rem .7rem;border-radius:999px;border:1px solid #ddd;background:#fafafa;color:#222;cursor:pointer}.chat-expand-btn:hover{background:#fff}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;background:#fafafa;border:1px solid #e0e0e0;border-radius:8px}.chat-message{max-width:90%;padding:.55rem .75rem;border-radius:10px;margin-bottom:.5rem;line-height:1.4;font-size:.9rem;text-align:left}.chat-message-user{margin-left:auto;background:#e3efff}.chat-message-assistant{margin-right:auto;background:#f5f2ff;border:1px solid #e2e2e2}.chat-empty{font-size:.9rem;color:#555}.chat-error{margin-top:.4rem;color:#b00020;font-size:.8rem}.chat-form{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #ddd;display:flex;flex-direction:column;gap:.5rem}.chat-form textarea{resize:vertical;min-height:3rem;max-height:8rem;padding:.5rem;font-size:.9rem}.chat-form button{align-self:flex-end;padding:.35rem .9rem;font-size:.85rem;border-radius:999px;border:1px solid #ddd;background:#fafafa;cursor:pointer}.chat-form button:hover:not(.thinking){background:#fff}.thinking-wrap{display:inline-flex;align-items:center;gap:6px}.spinner{width:14px;height:14px;border:2px solid #ffffff55;border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}button.thinking{opacity:.75;cursor:wait}.app-footer{padding:1.5rem 1rem;text-align:center;font-size:.85rem;color:#666;border-top:1px solid #e5e5e5;background:#fafafa}.app-footer a{color:#444;text-decoration:none}.app-footer a:hover{text-decoration:underline}@media(max-width:1200px){.app-body{flex-direction:column}.app-main{padding:1rem;padding-bottom:45vh;overflow-y:auto}.app-chat{position:fixed!important;inset:auto 0 0;width:100%;height:45vh;padding:.75rem 1.25rem 1rem;background:#fff;box-shadow:0 -2px 14px #0000002e;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.chat-panel{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.chat-messages{flex:1 1 0;overflow-y:auto;min-height:0}.chat-form{flex:0 0 auto;margin-top:.5rem}.tile-grid{grid-template-columns:1fr}.app-footer{margin-bottom:45vh}.app-body.chat-expanded .app-main{display:none}.app-body.chat-expanded .app-chat{position:static!important;top:auto;bottom:auto;height:auto;width:100%;padding:1rem;box-shadow:none}.app-body.chat-expanded~.app-footer{margin-bottom:0}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#111;background-color:#fafafa}a{color:inherit}.app-root{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;justify-content:space-between;align-items:baseline;padding:1rem 1.5rem;border-bottom:1px solid #ddd;background:#fff}.app-header h1{margin:0;font-size:1.4rem}.app-header p{margin:.15rem 0 0;font-size:.85rem;color:#666}.app-nav a{text-decoration:none;font-size:.9rem}.app-body{flex:1;display:grid;grid-template-columns:minmax(0,2.5fr) minmax(260px,1fr);gap:1rem;padding:1rem 1.5rem}.app-main{min-width:0}.app-chat{border-left:1px solid #eee;padding-left:1rem}.page{display:flex;flex-direction:column;gap:1.5rem}.page-body p{line-height:1.6}.page-tiles h3{margin-bottom:.75rem}.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.tile{border:1px solid #ddd;border-radius:6px;padding:.75rem;text-decoration:none;background:#fff;transition:box-shadow .15s ease,transform .15s ease}.tile h4{margin:0 0 .25rem;font-size:.95rem}.tile p{margin:0;font-size:.85rem;color:#555}.tile:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.chat-panel{display:flex;flex-direction:column;height:calc(100vh - 96px)}.chat-title{margin:0 0 .5rem;font-size:1rem}.chat-messages{flex:1;border:1px solid #ddd;border-radius:4px;padding:.75rem;margin-bottom:.75rem;overflow-y:auto;font-size:.9rem;background:#fff}.chat-empty{color:#777;font-style:italic}.chat-message{margin-bottom:.5rem}.chat-message-user{text-align:right}.chat-form{display:flex;flex-direction:column;gap:.5rem}.chat-form textarea{resize:vertical;min-height:60px;max-height:140px;padding:.5rem;font:inherit}.chat-form button{align-self:flex-end;padding:.35rem .9rem;border-radius:4px;border:1px solid #444;background:#444;color:#fff;font-size:.85rem;cursor:pointer}.chat-form button:hover{filter:brightness(1.05)}@media(max-width:900px){.app-body{grid-template-columns:1fr}.app-chat{border-left:none;border-top:1px solid #eee;padding-left:0;padding-top:1rem}.chat-panel{height:auto}}
