:root{font-family:Inter,Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#ffecee;background-color:#2b0913;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#5c0e1d,#2b0913 55%,#1a040b)}#root{min-height:100vh}button{font-family:inherit}.app{min-height:100vh;display:flex;flex-direction:column;gap:24px;padding:32px clamp(16px,4vw,48px) 48px;color:#fbe9ec}.hero{display:flex;justify-content:space-between;align-items:center;gap:24px}.hero h1{margin:0;font-size:clamp(2rem,3vw,3rem);letter-spacing:.02em}.eyebrow{font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:#f1b0b6}.subtitle{max-width:560px;margin-top:12px;color:#f5c7cc}.canvas-shell{flex:1;min-height:60vh;border-radius:28px;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 80px #1e000c73;background:radial-gradient(circle at top,rgba(255,255,255,.08),transparent 60%)}.bloodstream-canvas{width:100%;height:100%;display:block;cursor:pointer}.modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0f040873;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.modal-card{width:min(480px,90vw);border-radius:24px;padding:24px;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);box-shadow:0 20px 50px #00000040;color:#fff6f7}.modal-header{display:flex;justify-content:space-between;align-items:start;gap:16px}.modal-header h2{margin:8px 0 0}.modal-eyebrow{margin:0;font-size:.75rem;letter-spacing:.25em;text-transform:uppercase;color:#f5c1c8}.modal-body{margin-top:16px;color:#fde3e7}.modal-meta{margin-top:16px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px 20px;border-radius:16px;background:#ffffff1f}.modal-meta span{font-size:.85rem;color:#f5c1c8;text-transform:uppercase;letter-spacing:.05em;opacity:.9}.modal-meta strong{font-size:1.1rem;line-height:1.3}.modal-close{background:#fff3;border:none;color:#fff;border-radius:50%;width:36px;height:36px;cursor:pointer}.modal-card.modal-card-fullscreen{width:min(1000px,94vw);height:min(800px,90vh);display:flex;flex-direction:column}.modal-content-wrapper{flex:1;position:relative;overflow:hidden;margin-top:24px}.modal-summary{display:flex;flex-direction:column;height:100%}.modal-deep-dive{height:100%}.hero-cell{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;padding:24px 0;transition:transform .3s ease}.hero-cell:hover{transform:scale(1.02)}.hero-icon{width:140px;height:140px;filter:drop-shadow(0 0 30px rgba(255,100,100,.4));animation:float 6s ease-in-out infinite}.hero-hint{margin-top:16px;font-size:.9rem;color:#f5c1c8;opacity:.7;text-transform:uppercase;letter-spacing:.1em}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.dive-button{width:100%;margin-top:24px;padding:16px;border-radius:12px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.dive-button:hover{background:#ffffff40;transform:translateY(-2px)}.header-content{display:flex;flex-direction:column;gap:8px}.back-button{background:none;border:none;color:#f5c1c8;padding:0;margin-bottom:4px;cursor:pointer;font-size:.9rem;text-align:left}.back-button:hover{text-decoration:underline}.cell-internals-container{display:grid;grid-template-columns:1.2fr .8fr;gap:32px;height:100%}.internals-visual{height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(255,255,255,.05),transparent 70%);border-radius:20px}.internals-svg{width:100%;height:100%;max-height:500px}.internals-info{display:flex;flex-direction:column;justify-content:center;padding-right:16px}.internals-info h3{font-size:1.5rem;margin:0 0 12px;color:#fff}.hint{color:#f5c7cc;font-style:italic;margin-bottom:24px}.organelle-detail{padding:20px;background:#0003;border-radius:16px;border:1px solid rgba(255,255,255,.1)}.organelle-detail strong{display:block;font-size:1.2rem;margin-bottom:8px;color:#ffdce0}.organelle-detail p{margin:0;line-height:1.5;color:#f5c7cc}@media(max-width:768px){.cell-internals-container{grid-template-columns:1fr;grid-template-rows:1fr 1fr;gap:16px}}
