*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f12;--surf: #1a1a1f;--surf2: #232329;--surf3: #2c2c34;--brd: #2a2a32;--gold: #f0b429;--gold2: #ffd166;--golddim: rgba(240,180,41,.1);--txt: #ffffff;--sub: #9898a6;--dim: #55555f;--ok: #00c896;--ok-bg: rgba(0,200,150,.1);--ok-bd: rgba(0,200,150,.25);--err: #ff4d6a;--err-bg: rgba(255,77,106,.1);--err-bd: rgba(255,77,106,.25);--nav-h: 72px;--top-h: 56px;--r: 16px;--board-light: #f0d9b5;--board-dark: #b58863}html,body,#root{height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--txt);overflow:hidden}.app-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;max-width:430px;margin:0 auto;box-shadow:0 0 0 1px var(--brd);overflow:hidden}.top-bar{height:var(--top-h);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;background:var(--bg);border-bottom:1px solid var(--brd)}.top-logo{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:var(--txt)}.top-logo span{color:var(--gold)}.btn-back{position:absolute;left:16px;background:var(--surf2);border:none;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt);font-size:.9rem;transition:background .15s}.btn-back:hover{background:var(--surf3)}.bottom-nav{height:var(--nav-h);flex-shrink:0;background:var(--surf);border-top:1px solid var(--brd);display:flex;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:8px 20px;border-radius:12px;border:none;background:none;color:var(--dim);font-family:inherit;transition:background .15s}.nav-item.active{color:var(--gold)}.nav-item:hover{background:var(--surf2)}.nav-icon{font-size:1.3rem;line-height:1}.nav-label{font-size:.65rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.screen{flex:1;overflow-y:auto;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.screen::-webkit-scrollbar{display:none}.cover{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:28px;text-align:center;background:radial-gradient(ellipse 100% 40% at 50% 0%,rgba(240,180,41,.08),transparent 60%),var(--bg)}.cover-board-wrap{width:200px;height:200px;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #0009,0 0 0 1px #ffffff0f;flex-shrink:0}.cover-content{display:flex;flex-direction:column;align-items:center;gap:8px}.cover-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}.cover-headline{font-size:2rem;font-weight:800;line-height:1.1;letter-spacing:-.04em}.cover-sub{font-size:.88rem;color:var(--sub);line-height:1.6;max-width:280px}.btn-primary{width:100%;padding:16px;border-radius:14px;background:var(--gold);color:#0f0f12;border:none;cursor:pointer;font-size:1rem;font-weight:700;font-family:inherit;letter-spacing:-.01em;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--gold2);transform:scale(1.01)}.btn-primary:active{transform:scale(.99)}.cover-stats{display:flex;gap:24px;justify-content:center}.stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-val{font-size:1.2rem;font-weight:700}.stat-lbl{font-size:.68rem;color:var(--sub);font-weight:500}.cover-cta{padding:0 24px 16px;width:100%}.index-screen{flex:1;padding:0 16px 16px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.index-screen::-webkit-scrollbar{display:none}.idx-label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--sub);padding:16px 4px 8px}.chapter-card{background:var(--surf);border:1px solid var(--brd);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .15s}.chapter-card:hover{background:var(--surf2);border-color:var(--surf3)}.chapter-card:active{transform:scale(.99)}.ch-num{width:40px;height:40px;border-radius:12px;flex-shrink:0;background:var(--golddim);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--gold)}.ch-info{flex:1;min-width:0}.ch-name{font-weight:600;font-size:.95rem;margin-bottom:2px}.ch-meta{font-size:.75rem;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-arrow{color:var(--dim);font-size:.9rem;flex-shrink:0}.exercise-screen{flex:1;display:flex;flex-direction:column;overflow:hidden}.ex-topbar{flex-shrink:0;padding:12px 16px 0;display:flex;flex-direction:column;gap:8px;background:var(--bg)}.ex-meta{display:flex;align-items:center;justify-content:space-between}.ex-chapter{font-size:.78rem;font-weight:600;color:var(--sub)}.ex-counter{font-size:.78rem;color:var(--dim);font-weight:500}.pbar{height:3px;background:var(--brd);border-radius:2px;overflow:hidden}.pbar-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .35s ease}.ex-content{flex:1;overflow-y:auto;padding:12px 16px 16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.ex-content::-webkit-scrollbar{display:none}.ex-quote{background:var(--golddim);border-left:3px solid var(--gold);border-radius:0 10px 10px 0;padding:10px 14px;font-style:italic;font-size:.83rem;color:#e8c76a;line-height:1.6}.ex-qbox{background:var(--surf);border:1px solid var(--brd);border-radius:12px;padding:12px 14px}.ex-qlabel{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}.ex-qtext{font-size:.86rem;line-height:1.68;color:var(--txt)}.board-wrap{display:flex;justify-content:center}.ex-footer{padding:12px 16px;border-top:1px solid var(--brd);background:var(--surf);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.btn-nav{flex:1;background:none;border:1px solid var(--brd);color:var(--sub);padding:10px 16px;border-radius:10px;cursor:pointer;font-size:.83rem;font-family:inherit;font-weight:600;transition:all .15s}.btn-nav:hover:not(:disabled){border-color:var(--gold);color:var(--gold)}.btn-nav:disabled{opacity:.25;cursor:not-allowed}.btn-reset{background:none;border:none;color:var(--dim);font-size:1rem;cursor:pointer;font-family:inherit;padding:10px 12px;transition:color .15s;flex-shrink:0}.btn-reset:hover{color:var(--sub)}.fb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fb-sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:var(--surf);border-radius:24px 24px 0 0;padding:20px 24px;z-index:201;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));animation:slideUp .35s cubic-bezier(.22,1,.36,1)}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.fb-handle{width:36px;height:4px;background:var(--brd);border-radius:2px;margin:0 auto 20px}.fb-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:12px}.fb-icon.ok{background:var(--ok-bg);color:var(--ok)}.fb-icon.err{background:var(--err-bg);color:var(--err)}.fb-title{font-size:1.1rem;font-weight:700;margin-bottom:6px}.fb-title.ok{color:var(--ok)}.fb-title.err{color:var(--err)}.fb-text{font-size:.88rem;color:var(--sub);line-height:1.65;margin-bottom:20px}.btn-fb{width:100%;padding:15px;border-radius:14px;border:none;cursor:pointer;font-size:.95rem;font-weight:700;font-family:inherit;transition:all .15s}.btn-fb.ok{background:var(--ok);color:#0f0f12}.btn-fb.ok:hover{background:#00daa6}.btn-fb.err{background:var(--surf2);border:1px solid var(--brd);color:var(--txt)}.btn-fb.err:hover{border-color:var(--sub)}
