:root{--bg: #fff8e7;--panel: #ffffff;--ink: #2c2a4a;--shadow: 0 4px 0 rgba(0, 0, 0, .08);--accent: #ffd166;--tap: 80px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}html,body,#root{margin:0;height:100%;width:100%;background:var(--bg);font-family:Comic Sans MS,Chalkboard SE,system-ui,sans-serif;color:var(--ink);overscroll-behavior:none;touch-action:manipulation}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer;color:inherit}.app{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.big-btn{min-width:var(--tap);min-height:var(--tap);padding:8px 14px;border-radius:22px;background:var(--panel);box-shadow:var(--shadow);display:inline-flex;align-items:center;justify-content:center;gap:6px;font-weight:700;font-size:22px;transition:transform .08s ease}.big-btn:active{transform:translateY(2px);box-shadow:0 1px #00000014}.big-btn:disabled{opacity:.35;pointer-events:none}.big-btn .emoji{font-size:30px;line-height:1}.big-btn .label{font-size:16px}.start{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:24px;padding:24px}.start h1{font-size:56px;margin:0;color:var(--ink);text-shadow:0 3px 0 rgba(0,0,0,.1)}.start-tiles{display:flex;gap:32px;flex-wrap:wrap;justify-content:center}.start-tile{width:240px;height:240px;background:var(--panel);border-radius:32px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:28px;font-weight:700;gap:12px;transition:transform .1s ease}.start-tile:active{transform:scale(.96)}.start-tile .big{font-size:96px;line-height:1}.profile-picker{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:32px;padding:24px}.profile-picker h1{font-size:48px;margin:0;color:var(--ink);text-shadow:0 3px 0 rgba(0,0,0,.1)}.profile-tiles{display:flex;gap:32px;flex-wrap:wrap;justify-content:center}.profile-tile{width:220px;background:var(--panel);border-radius:32px;box-shadow:var(--shadow);padding:28px 16px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;transition:transform .1s ease;border:4px solid transparent}.profile-tile:active{transform:scale(.96)}.profile-tile.supervisor{border-color:var(--accent);background:linear-gradient(180deg,#fff8e7,#fff)}.profile-tile .big{font-size:96px;line-height:1}.profile-tile .profile-name{font-size:28px;font-weight:700}.profile-tile .profile-meta{display:flex;gap:10px;font-size:18px;color:#6b6a85}.profile-tile .profile-meta.locked{background:var(--accent);color:#5a4900;font-weight:700;padding:4px 10px;border-radius:999px;font-size:14px}.profile-tile .streak{font-weight:700;color:#d97706}.profile-tile-wrap{position:relative;display:inline-block}.profile-delete{position:absolute;top:-6px;right:-6px;width:28px;height:28px;border-radius:50%;background:#fff;color:#c0392b;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000002e;z-index:1}.profile-delete:active{transform:scale(.92)}.profile-add{background:#ffffff8c;border:2px dashed #c8c2a8}.profile-add .big{color:#6b6580}.create-profile-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1412288c;display:flex;align-items:center;justify-content:center;z-index:70;padding:16px}.create-profile{background:var(--panel);border-radius:22px;box-shadow:0 12px 32px #00000040;width:min(420px,100%);padding:22px;max-height:90vh;overflow-y:auto}.create-profile-title{font-weight:700;font-size:22px;margin-bottom:14px;text-align:center}.create-profile-label{display:block;font-weight:700;font-size:14px;margin:8px 0 6px}.create-profile-input{width:100%;padding:12px 14px;border-radius:14px;border:2px solid #e6dec0;background:#fffdf3;font:inherit;font-size:18px}.create-profile-input:focus{outline:3px solid var(--ink);outline-offset:1px}.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:4px}.avatar-tile{aspect-ratio:1 / 1;font-size:28px;border-radius:12px;background:#f3eedb;display:flex;align-items:center;justify-content:center}.avatar-tile.active{background:var(--accent);outline:3px solid var(--ink)}.create-profile-error{margin-top:10px;background:#ffe0e0;color:#8a1f1f;padding:8px 12px;border-radius:10px;font-size:14px}.create-profile-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.create-profile-btn{padding:10px 18px;border-radius:14px;font-weight:700;font-size:16px}.create-profile-btn.cancel{background:#f3eedb;color:var(--ink)}.create-profile-btn.primary{background:var(--accent);color:#5a4900}.create-profile-btn.primary:disabled{opacity:.55}.profile-footer{margin-top:20px;display:flex;justify-content:center;align-items:center;gap:8px;font-size:14px;color:#6c6a7e}.policy-link{font:inherit;color:#2c2a4a;text-decoration:underline;font-weight:600;padding:4px 6px}.policy-link:active{opacity:.6}.policy-sep{opacity:.5}.dashboard-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1412288c;display:flex;align-items:center;justify-content:center;z-index:75;padding:16px}.dashboard{background:var(--panel);border-radius:22px;box-shadow:0 12px 32px #00000040;width:min(540px,100%);max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.dashboard-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:2px solid #f3eedb}.dashboard-title{margin:0;font-size:18px}.dashboard-close{width:36px;height:36px;border-radius:50%;font-size:18px}.dashboard-close:active{background:#f3eedb}.dashboard-section{padding:16px 18px;border-bottom:1px solid #f3eedb;overflow-y:auto}.dashboard-section.danger{background:#fff4f4;border-radius:0 0 22px 22px;border-bottom:none}.dashboard-section-title{margin:0 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:#6c6a7e}.dashboard-section.danger .dashboard-section-title{color:#8a1f1f}.dashboard-row{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0;font-size:15px}.dashboard-row-label{color:#6c6a7e}.dashboard-row-value{font-weight:700;word-break:break-all}.dashboard-help{font-size:13px;color:#6c6a7e;margin:0 0 10px;line-height:1.5}.dashboard-help-strong{color:var(--ink);font-weight:600}.dashboard-form{display:flex;flex-direction:column;gap:8px}.dashboard-input{width:100%;padding:10px 12px;border-radius:12px;border:2px solid #e6dec0;background:#fffdf3;font:inherit;font-size:15px}.dashboard-input:focus{outline:3px solid var(--ink);outline-offset:1px}.dashboard-error{background:#ffe0e0;color:#8a1f1f;padding:8px 12px;border-radius:10px;font-size:13px;margin:6px 0}.dashboard-success{background:#d8f5d8;color:#1f5a1f;padding:8px 12px;border-radius:10px;font-size:13px;margin:6px 0}.dashboard-btn{padding:10px 18px;border-radius:14px;font-weight:700;font-size:15px;margin-top:6px}.dashboard-btn.primary{background:var(--accent);color:#5a4900;box-shadow:var(--shadow)}.dashboard-btn.danger{background:#c0392b;color:#fff}.dashboard-btn:disabled{opacity:.55}.verify-banner{margin:12px auto;max-width:min(720px,92%);background:#fff3cf;color:#6b4f0a;border-radius:14px;padding:10px 14px;font-size:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.verify-banner.success{background:#d8f5d8;color:#1f5a1f}.verify-resend{background:var(--accent);color:#5a4900;font-weight:700;padding:6px 14px;border-radius:10px;font-size:14px}.verify-resend:disabled{opacity:.55}.migration-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1412288c;display:flex;align-items:center;justify-content:center;z-index:80;padding:16px}.migration-card{background:var(--panel);border-radius:22px;box-shadow:0 12px 32px #00000040;padding:28px;text-align:center;width:min(440px,100%);max-height:90vh;overflow-y:auto}.migration-emoji{font-size:56px;line-height:1;margin-bottom:10px}.migration-title{margin:0 0 8px;font-size:22px}.migration-body{margin:0 0 14px;color:#4a4860;line-height:1.5}.migration-progress{margin:8px 0;color:#6c6a7e;font-size:14px}.migration-warn{margin:8px 0;background:#ffe0e0;color:#8a1f1f;padding:8px 12px;border-radius:12px;font-size:14px}.migration-actions{display:flex;gap:10px;justify-content:center;margin-top:14px}.migration-skip,.migration-submit{padding:12px 22px;border-radius:16px;font-weight:700;font-size:16px}.migration-skip{background:#f3eedb;color:var(--ink)}.migration-submit{background:var(--accent);color:#5a4900;box-shadow:var(--shadow)}.migration-submit:disabled,.migration-skip:disabled{opacity:.55}.auth-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg)}.auth-card{background:var(--panel);border-radius:22px;box-shadow:var(--shadow);padding:24px;width:min(420px,100%);max-height:95vh;overflow-y:auto}.auth-title{margin:0 0 4px;font-size:28px;text-align:center}.auth-sub{margin:0 0 18px;color:#6c6a7e;text-align:center;font-size:14px}.auth-label{display:block;font-weight:700;font-size:14px;margin:10px 0 6px}.auth-input{width:100%;padding:12px 14px;border-radius:14px;border:2px solid #e6dec0;background:#fffdf3;font:inherit;font-size:16px}.auth-input:focus{outline:3px solid var(--ink);outline-offset:1px}.auth-check{display:flex;align-items:flex-start;gap:10px;margin-top:14px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.auth-check input{margin-top:2px;width:20px;height:20px;flex-shrink:0}.auth-error{margin-top:12px;background:#ffe0e0;color:#8a1f1f;padding:10px 12px;border-radius:12px;font-size:14px}.auth-submit{width:100%;margin-top:18px;background:var(--accent);color:#5a4900;font-weight:700;font-size:18px;padding:14px 20px;border-radius:16px;box-shadow:var(--shadow)}.auth-submit:active{transform:translateY(2px);box-shadow:0 1px #00000014}.auth-submit:disabled{opacity:.55}.auth-switch{margin-top:16px;text-align:center;font-size:14px;color:#6c6a7e}.auth-link{font:inherit;color:#2c2a4a;font-weight:700;text-decoration:underline}.auth-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#6c6a7e;font-size:18px}.lazy-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:32px;color:#6c6a7e}.install-prompt{position:fixed;top:max(env(safe-area-inset-top,0px),12px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:var(--panel);color:var(--ink);padding:10px 14px;border-radius:18px;box-shadow:0 8px 24px #0000002e;font-size:14px;z-index:90;max-width:calc(100% - 32px)}.install-prompt.ios{font-size:13px;line-height:1.35}.install-emoji{font-size:22px;line-height:1;flex-shrink:0}.install-msg{flex:1;min-width:0}.install-btn{background:var(--accent);color:#5a4900;font-weight:700;padding:6px 14px;border-radius:12px;flex-shrink:0}.install-btn:active{transform:translateY(1px)}.install-dismiss{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:#6c6a7e;flex-shrink:0}.install-dismiss:active{background:#f3eedb}.update-prompt{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:var(--panel);color:var(--ink);padding:10px 14px;border-radius:18px;box-shadow:0 8px 24px #0000002e;font-size:14px;z-index:90;max-width:calc(100% - 32px)}.update-msg{font-weight:600}.update-btn{background:var(--accent);color:#5a4900;font-weight:700;padding:6px 14px;border-radius:12px}.update-btn:active{transform:translateY(1px)}.update-dismiss{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:#6c6a7e}.update-dismiss:active{background:#f3eedb}.error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.error-card{background:var(--panel);border-radius:24px;box-shadow:var(--shadow);padding:32px 28px;max-width:440px;text-align:center}.error-emoji{font-size:72px;line-height:1;margin-bottom:12px}.error-title{margin:0 0 8px;font-size:22px}.error-sub{margin:0 0 20px;color:#6c6a7e}.error-btn{background:var(--accent);color:#5a4900;font-weight:700;font-size:18px;padding:12px 24px;border-radius:16px;box-shadow:var(--shadow)}.error-btn:active{transform:translateY(2px);box-shadow:0 1px #00000014}.policy-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1412288c;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.policy-modal{background:var(--panel);border-radius:18px;box-shadow:0 12px 32px #00000040;width:min(640px,100%);max-height:min(90vh,720px);display:flex;flex-direction:column;overflow:hidden}.policy-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:2px solid #f3eedb}.policy-title{font-weight:700;font-size:18px}.policy-close{font-size:22px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.policy-close:active{background:#f3eedb}.policy-tabs{display:flex;gap:6px;padding:10px 18px 0;flex-wrap:wrap}.policy-tab{padding:6px 14px;border-radius:14px;background:#f3eedb;font-weight:700;font-size:14px}.policy-tab.active{background:var(--accent);color:#5a4900}.policy-meta{padding:6px 18px 0;font-size:12px;color:#6c6a7e}.policy-body{margin:0;padding:14px 18px 18px;overflow-y:auto;flex:1;font-family:inherit;font-size:14px;line-height:1.5;white-space:pre-wrap;user-select:text;-webkit-user-select:text}.profile-chip{position:absolute;top:20px;left:20px;display:inline-flex;align-items:center;gap:10px;background:var(--panel);border-radius:999px;padding:6px 14px 6px 6px;box-shadow:var(--shadow);font-weight:700;font-size:18px}.profile-chip:active{transform:scale(.96)}.profile-chip-avatar{font-size:32px;line-height:1}.profile-chip-switch{font-size:18px;color:#888}.start{position:relative}.supervisor-gate-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:60;padding:24px}.supervisor-gate{background:var(--panel);border-radius:28px;padding:24px;width:100%;max-width:360px;box-shadow:0 12px 32px #00000040;display:flex;flex-direction:column;gap:12px}.gate-head{display:flex;flex-direction:column;align-items:center;gap:6px}.gate-avatar{font-size:64px}.gate-name{font-size:24px;font-weight:700}.gate-sub{font-size:14px;color:#6b6a85;text-align:center}.gate-input{width:100%;background:#f3f2f8;border:2px solid transparent;border-radius:14px;padding:12px 14px;font-size:18px;outline:none;font-family:inherit}.gate-input:focus{border-color:var(--accent)}.gate-error{color:#c0392b;font-size:14px;text-align:center}.gate-actions{display:flex;gap:10px;margin-top:4px}.gate-btn{flex:1;padding:12px;border-radius:14px;font-weight:700;font-size:18px}.gate-btn.cancel{background:#e9e8ef;color:#4a4860}.gate-btn.primary{background:var(--accent);color:#5a4900}.gate-btn:disabled{opacity:.6}.trophy-shelf{width:100%;max-width:720px;background:#fff;border-radius:18px;padding:10px 14px;box-shadow:var(--shadow)}.trophy-shelf-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.trophy-shelf-label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b6a85}.trophy-shelf-count{font-weight:700;font-size:14px;color:#5a4900}.trophy-shelf-row{display:flex;flex-wrap:wrap;gap:6px}.trophy-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;border:2px solid transparent}.trophy-pill.earned{background:linear-gradient(135deg,#fff3cf,#ffd166);color:#5a4900;border-color:#f0b330}.trophy-pill.locked{background:#f3f2f8;color:#aaa}.trophy-emoji{font-size:16px}.todays-lesson-card{background:linear-gradient(135deg,#fff3cf,#ffd166);border-radius:24px;padding:16px 20px;display:flex;align-items:center;gap:16px;width:100%;max-width:720px;box-shadow:0 6px #00000014;flex-wrap:wrap}.todays-lesson-card.done{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.todays-lesson-card.finished{background:linear-gradient(135deg,#f3e5f5,#ce93d8)}.todays-lesson-head{display:flex;align-items:center;gap:16px;flex:1;min-width:240px}.todays-lesson-emoji{font-size:56px;line-height:1}.todays-lesson-body{flex:1}.todays-lesson-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#5a4900}.todays-lesson-title{font-size:22px;font-weight:700;color:var(--ink)}.todays-lesson-blurb{font-size:14px;color:#4a4860}.todays-lesson-cta{background:var(--ink);color:#fff;padding:12px 20px;border-radius:16px;font-weight:700;font-size:16px;box-shadow:var(--shadow)}.todays-lesson-cta.secondary{background:#fff;color:var(--ink)}.todays-lesson-cta:active{transform:scale(.96)}.lesson-runner{display:flex;flex-direction:column;height:100%;padding:16px;gap:12px}.lesson-runner-header{display:flex;align-items:center;gap:12px}.lesson-runner-title{flex:1;text-align:center;font-size:22px;font-weight:700}.lesson-runner-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:20px}.lesson-runner-body.summary{background:linear-gradient(180deg,#fff8e7,#ffd166);border-radius:24px;margin:16px}.lesson-intro-emoji,.lesson-step-emoji,.lesson-summary-emoji{font-size:80px;line-height:1}.lesson-intro-text{font-size:18px;max-width:480px}.lesson-intro-line{font-size:16px;color:#6b6a85;margin-bottom:12px}.lesson-intro-steps{list-style:none;margin:0;display:flex;flex-direction:column;gap:8px;text-align:left;background:#fff8e7;border-radius:14px;padding:12px 16px}.lesson-intro-steps li{font-weight:600}.lesson-step-text{font-size:22px;font-weight:700}.lesson-prompt{background:#fff8e7;border-radius:18px;padding:16px 20px;font-size:18px;max-width:560px;font-weight:600;box-shadow:var(--shadow)}.lesson-runner-cta{background:var(--accent);color:#5a4900;padding:16px 32px;border-radius:22px;font-weight:700;font-size:22px;box-shadow:var(--shadow)}.lesson-runner-cta:active{transform:scale(.96)}.lesson-runner-cta:disabled{opacity:.5}.lesson-reflection-q{font-size:22px;font-weight:700;max-width:480px}.lesson-reflection-options{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.lesson-reflection-opt{background:var(--panel);border:3px solid #ece9f5;border-radius:18px;padding:14px 22px;font-size:18px;font-weight:700;box-shadow:var(--shadow)}.lesson-reflection-opt.selected{border-color:var(--accent);background:#fff3cf}.lesson-summary-title{font-size:32px;font-weight:700;color:#5a4900}.lesson-summary-blurb{font-size:18px;color:#5a4900;max-width:420px}.lesson-floating-done{position:fixed;top:14px;right:14px;background:var(--ink);color:#fff;font-weight:700;font-size:16px;padding:10px 16px;border-radius:999px;box-shadow:0 6px 16px #00000040;z-index:40}.lesson-floating-done:active{transform:scale(.96)}.skill-tree{display:flex;flex-direction:column;height:100%;padding:16px;gap:12px;overflow:hidden}.skill-tree-header{display:flex;align-items:center;gap:12px}.skill-tree-header h1{flex:1;text-align:center;font-size:32px;margin:0}.skill-tree-banner{background:linear-gradient(135deg,#fff3cf,#ffd166);border-radius:18px;padding:10px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);font-size:16px;color:#5a4900}.skill-tree-banner-avatar{font-size:28px}.skill-tree-scroll{flex:1;overflow-x:auto;overflow-y:hidden;padding:60px 24px}.skill-tree-path{display:flex;gap:36px;align-items:flex-start;position:relative;min-width:max-content}.skill-tree-path:before{content:"";position:absolute;left:60px;right:60px;top:50%;height:8px;background:repeating-linear-gradient(90deg,rgba(150,140,200,.4) 0,rgba(150,140,200,.4) 12px,transparent 12px,transparent 22px);border-radius:999px;transform:translateY(-4px);z-index:0}.rung-node{width:160px;background:var(--panel);border-radius:28px;padding:14px 12px 12px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1;transition:transform .1s ease;border:4px solid transparent}.rung-node:active{transform:scale(.96)}.rung-node:nth-child(odd){transform:translateY(-50px)}.rung-node:nth-child(odd):active{transform:translateY(-50px) scale(.96)}.rung-node:nth-child(2n){transform:translateY(50px)}.rung-node:nth-child(2n):active{transform:translateY(50px) scale(.96)}.rung-node.locked{filter:grayscale(.7);opacity:.65}.rung-node.recommended{border-color:var(--accent);box-shadow:0 0 0 3px #ffd1664d,var(--shadow)}.rung-node.rung-mastered{background:linear-gradient(180deg,#fff3cf,#ffe5a0)}.rung-node.rung-practicing{background:linear-gradient(180deg,#f3f8ff,#e3edff)}.rung-order{position:absolute;top:-14px;left:-10px;width:30px;height:30px;background:var(--ink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.rung-emoji{font-size:48px;line-height:1}.rung-title{font-size:16px;font-weight:700;text-align:center;line-height:1.1;min-height:36px;display:flex;align-items:center}.rung-status{display:flex;align-items:center;gap:4px;font-size:12px;color:#6b6a85;font-weight:700}.rung-progress{width:100%;height:6px;background:#f3f2f8;border-radius:999px;overflow:hidden}.rung-progress-fill{height:100%;background:linear-gradient(90deg,#ffd166,#ff9f43);transition:width .3s ease}.rung-lock{position:absolute;top:8px;right:8px;font-size:18px}.rung-pin{position:absolute;bottom:-22px;background:var(--accent);color:#5a4900;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;box-shadow:var(--shadow)}.rung-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:60;padding:0 16px 16px}.rung-sheet{background:var(--panel);border-radius:28px 28px 16px 16px;padding:20px;width:100%;max-width:620px;max-height:80vh;overflow-y:auto;box-shadow:0 -8px 24px #0000002e;display:flex;flex-direction:column;gap:14px;position:relative}.rung-sheet-close{position:absolute;top:8px;right:14px;font-size:28px;font-weight:700;color:#888}.rung-sheet-head{display:flex;align-items:center;gap:14px}.rung-sheet-emoji{font-size:56px;line-height:1}.rung-sheet-title{font-size:24px;font-weight:700}.rung-sheet-blurb{font-size:16px;color:#4a4860}.rung-sheet-mastery{background:#f7f6fb;border-radius:14px;padding:10px 14px}.rung-sheet-mastery-line{display:flex;justify-content:space-between;font-weight:700;margin-bottom:6px}.rung-sheet-attempts{color:#6b6a85;font-weight:400}.rung-sheet-bar{height:8px;background:#fff;border-radius:999px;overflow:hidden}.rung-sheet-bar-fill{height:100%;background:linear-gradient(90deg,#ffd166,#ff9f43)}.rung-sheet-locked{background:#fff3cf;border-radius:12px;padding:10px 12px;color:#5a4900;font-weight:700;font-size:14px}.rung-sheet-section{display:flex;flex-direction:column;gap:8px}.rung-sheet-section-title{font-size:16px;font-weight:700;color:var(--ink)}.rung-sheet-chips{display:flex;flex-wrap:wrap;gap:8px}.rung-sheet-chip{background:var(--panel);border:2px solid #ece9f5;border-radius:999px;padding:8px 14px;display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14px;box-shadow:var(--shadow)}.rung-sheet-chip.drill{background:#fff3cf;border-color:#ffd166}.rung-sheet-chip.tutorial{background:#e3edff;border-color:#95b5ff}.rung-sheet-chip-emoji{font-size:18px}.rung-sheet-coming-soon{text-align:center;color:#6b6a85;padding:14px;font-size:14px;background:#f7f6fb;border-radius:12px}.start-tile.primary{background:linear-gradient(180deg,#fff3cf,#ffe5a0);box-shadow:0 0 0 3px #ffd16666,var(--shadow)}.drill-gallery{display:flex;flex-direction:column;height:100%;padding:16px;gap:12px;overflow:hidden}.drill-gallery-header{display:flex;align-items:center;gap:12px}.drill-gallery-header h1{flex:1;text-align:center;font-size:32px;margin:0}.drill-gallery-sub{text-align:center;margin:0;color:#6b6a85;font-size:16px}.drill-gallery-tiles{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:8px;overflow-y:auto}.drill-tile{background:var(--panel);border-radius:24px;box-shadow:var(--shadow);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;transition:transform .1s ease}.drill-tile:active{transform:scale(.97)}.drill-tile-emoji{font-size:56px;line-height:1}.drill-tile-title{font-size:22px;font-weight:700}.drill-tile-blurb{font-size:14px;color:#6b6a85}.drill-tile-score{margin-top:4px;font-size:12px;font-weight:700;background:#fff3cf;color:#5a4900;padding:4px 10px;border-radius:999px}.drill-cancel{background:var(--panel);border-radius:999px;padding:8px 14px;box-shadow:var(--shadow);font-weight:700;font-size:16px}.drill-screen{display:flex;flex-direction:column;height:100%;padding:12px;gap:10px;overflow:hidden}.drill-header{display:flex;align-items:center;gap:12px}.drill-title{flex:1;text-align:center;font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px}.drill-emoji{font-size:28px}.drill-step{background:var(--panel);border-radius:999px;padding:6px 14px;box-shadow:var(--shadow);font-weight:700}.drill-timer{background:#ffe5e0;color:#b54b00}.drill-blurb{text-align:center;font-size:18px;color:#4a4860}.drill-prompt-emoji{font-size:22px}.drill-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:#fff;border-radius:20px;box-shadow:var(--shadow);overflow:hidden}.drill-canvas-guide,.drill-canvas{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;touch-action:none}.drill-canvas{cursor:crosshair}.drill-canvas-host{flex:1;display:flex;position:relative}.drill-canvas-host>.drill-canvas-wrap{flex:1}.drill-recording-overlay{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#ffffffeb;border-radius:18px;padding:8px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;z-index:5}.drill-recording-emoji{font-size:28px;line-height:1;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.drill-recording-text{font-weight:700;font-size:14px}.drill-recording-hint{font-size:12px;color:#6b6a85}.drill-footer{min-height:80px;display:flex;align-items:center;justify-content:center;gap:12px}.drill-primary,.drill-secondary{padding:14px 24px;border-radius:18px;font-weight:700;font-size:18px;box-shadow:var(--shadow)}.drill-primary{background:var(--accent);color:#5a4900}.drill-secondary{background:var(--panel);color:var(--ink)}.drill-result{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--panel);border-radius:20px;padding:12px 20px;box-shadow:var(--shadow);width:100%;max-width:480px}.drill-result-emoji{font-size:40px;line-height:1}.drill-result-text{font-size:20px;font-weight:700}.drill-result-bar{width:100%;height:12px;background:#f3f2f8;border-radius:999px;overflow:hidden}.drill-result-bar-fill{height:100%;background:linear-gradient(90deg,#ffd166,#ff9f43);transition:width .3s ease}.drill-result-actions{display:flex;gap:12px}.drill-self-rate{display:flex;flex-direction:column;align-items:center;gap:10px}.drill-self-rate-q{font-size:18px;font-weight:700}.drill-self-rate-row{display:flex;gap:12px}.drill-self-rate-btn{background:var(--panel);border-radius:18px;padding:12px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:4px;font-weight:700;font-size:14px;min-width:96px}.drill-self-rate-emoji{font-size:36px;line-height:1}.gallery{display:flex;flex-direction:column;height:100%;padding:16px}.gallery-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.gallery-export{margin-left:auto;background:var(--panel);color:var(--ink);font-weight:700;padding:10px 16px;border-radius:18px;box-shadow:var(--shadow);font-size:16px}.gallery-export:active{transform:translateY(1px)}.gallery-export:disabled{opacity:.55}.category-bar{display:flex;gap:8px;overflow-x:auto;padding:4px 4px 12px;margin-bottom:8px;flex-shrink:0}.category-bar::-webkit-scrollbar{display:none}.cat-btn{flex-shrink:0;min-height:64px;padding:6px 16px;border-radius:18px;background:var(--panel);box-shadow:var(--shadow);display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:16px;transition:transform .08s ease}.cat-btn .emoji{font-size:26px}.cat-btn.active{background:var(--accent);transform:scale(1.04)}.diff-bar{display:flex;gap:8px;padding:0 4px 12px;flex-shrink:0}.diff-chip{min-height:44px;padding:6px 14px;border-radius:22px;background:#f1ecdc;font-weight:700;font-size:16px;display:inline-flex;align-items:center;gap:6px}.diff-chip.active{background:var(--accent)}.empty{padding:32px;text-align:center;color:#666;font-size:18px}.hint{background:#fff3cf;border-radius:14px;padding:10px 14px;margin:0 4px 10px;font-size:14px;color:#6b4f0a;flex-shrink:0}.hint-error{background:#ffe0e0;color:#8a1f1f}.saved-tile{position:relative}.saved-tile-img{width:100%}.saved-delete{position:absolute;top:4px;right:4px;width:44px;height:44px;border-radius:50%;background:#ff6b6bf2;color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.saved-print{position:absolute;top:4px;right:52px;width:44px;height:44px;border-radius:50%;background:#fffffff2;color:#2c2a4a;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.saved-print:disabled{opacity:.4}.search-tile-wrap{position:relative}.search-print{position:absolute;top:6px;right:6px;width:40px;height:40px;border-radius:50%;background:#ffffffeb;color:#2c2a4a;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #00000040}.search-print:active{transform:scale(.95)}.search-credit{position:absolute;bottom:6px;left:6px;max-width:calc(100% - 12px);padding:2px 8px;border-radius:10px;background:#ffffffd9;color:#2c2a4a;font-size:11px;font-weight:600;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 3px #0000002e;-webkit-user-select:none;user-select:none}.search-credit:active{transform:translateY(1px)}.search-attribution{flex-shrink:0;text-align:center;font-size:13px;padding:8px 4px 4px;color:#6c6a7e}.search-attribution a{color:#2c2a4a;font-weight:700}.tile-fallback{width:100%;height:140px;display:flex;align-items:center;justify-content:center;font-size:64px}.tutorial-view{display:flex;flex-direction:column;height:100%;padding:16px;overflow:hidden}.tutorial-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;overflow-y:auto;padding:4px;align-content:start}.tutorial-panel{background:var(--panel);border-radius:18px;box-shadow:var(--shadow);padding:10px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.tutorial-panel-num{position:absolute;top:8px;left:12px;width:32px;height:32px;background:var(--accent);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}.tutorial-panel-svg{width:100%;aspect-ratio:1 / 1}.tutorial-panel-svg svg{width:100%;height:100%;display:block}.tutorial-panel-label{text-align:center;font-weight:700;font-size:14px;padding:0 4px;min-height:36px}.tutorial-actions{display:flex;justify-content:center;padding:12px 0 4px;flex-shrink:0}.search-screen{display:flex;flex-direction:column;height:100%;padding:16px;overflow:hidden}.search-bar{display:flex;gap:10px;padding:4px 4px 12px;flex-shrink:0}.search-bar input{flex:1;font-family:inherit;font-size:22px;padding:14px 18px;border:3px solid var(--accent);border-radius:22px;background:var(--panel);outline:none}.search-bar input:focus{border-color:var(--ink)}.search-go{min-width:64px;min-height:64px;padding:0 18px;border-radius:22px;background:var(--accent);font-size:28px;font-weight:700;box-shadow:var(--shadow)}.search-go:disabled{opacity:.4}.search-suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:0 4px 12px;align-items:center;flex-shrink:0}.search-suggestions-label{font-weight:700;margin-right:4px}.suggest-pill{padding:6px 14px;border-radius:22px;background:var(--panel);box-shadow:var(--shadow);font-size:15px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.suggest-pill:active{transform:scale(.96)}.suggest-pill.active{background:var(--accent);outline:3px solid var(--ink)}.search-styles{display:flex;flex-wrap:wrap;gap:8px;padding:0 4px 12px;align-items:center;flex-shrink:0}.search-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;overflow-y:auto;padding:4px;flex:1;align-content:start}.search-tile{background:var(--panel);border-radius:14px;box-shadow:var(--shadow);padding:6px;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:transform .08s ease}.search-tile:active{transform:scale(.95)}.search-tile img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;overflow-y:auto;padding:4px;flex:1}.gallery-tile{background:var(--panel);border-radius:24px;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .08s ease}.gallery-tile:active{transform:scale(.95)}.gallery-tile img{width:100%;height:140px;object-fit:contain;pointer-events:none}.gallery-tile span{font-size:18px;font-weight:700}.editor{display:flex;flex-direction:row;height:100%;width:100%}.toolbar{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--panel);box-shadow:2px 0 8px #0000000f;flex-shrink:0;z-index:2;width:96px;overflow-y:auto}.toolbar .spacer{flex:1}.toolbar .big-btn{min-width:78px;width:78px;min-height:70px;padding:6px 4px;flex-direction:column;gap:2px}.toolbar .big-btn .emoji{font-size:26px}.toolbar .big-btn .label{font-size:12px}.surface-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:12px;overflow:hidden;background:linear-gradient(180deg,var(--bg) 0%,#ffeac2 100%);touch-action:none;position:relative;min-width:0}.surface{position:relative;width:min(96vh,96%);height:min(96vh,96%);max-width:96vh;aspect-ratio:1 / 1;background:#fff;border-radius:18px;box-shadow:0 6px 24px #0000001f;overflow:hidden;transform-origin:center center;will-change:transform}.toast{position:fixed;top:24px;left:50%;transform:translate(-50%);padding:14px 24px;border-radius:22px;font-weight:700;font-size:18px;box-shadow:0 6px 20px #0003;z-index:20;pointer-events:none;animation:toast-in .18s ease-out}.toast-success{background:#a3d977;color:#1a3a0c}.toast-error{background:#ff6b6b;color:#fff}.toast-info{background:var(--panel);color:var(--ink)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.step-strip{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:8px 10px;border-radius:22px;background:#ffffffeb;box-shadow:0 4px 14px #00000024;z-index:4;max-width:92%;overflow-x:auto}.step-strip::-webkit-scrollbar{display:none}.step-pill{position:relative;flex-shrink:0;width:56px;height:56px;border-radius:14px;background:#f7f1e0;padding:4px;display:block;transition:transform .08s ease,background .12s ease}.step-pill.active{background:var(--accent);transform:scale(1.06);outline:3px solid var(--ink)}.step-pill-num{position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--ink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;z-index:1}.step-thumb{width:100%;height:100%;pointer-events:none}.step-thumb svg{width:100%;height:100%;display:block}.step-pill-done,.step-pill-color{background:#d6f5cc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0}.step-pill-done.active{background:#4caf50;outline-color:#1f5c1f}.step-pill-done.active .step-pill-icon,.step-pill-done.active .step-pill-done-label{color:#fff}.step-pill-color{background:#ffd166}.step-pill-color:active{transform:scale(.94)}.step-pill-color .step-pill-icon{color:#b8860b}.step-pill-color .step-pill-done-label{color:#6b4f0a}.step-pill-icon{font-size:26px;font-weight:800;line-height:1;color:#1f5c1f}.step-pill-done-label{font-size:10px;font-weight:800;color:#1f5c1f;margin-top:2px}.zoom-reset{position:absolute;bottom:12px;right:12px;min-height:56px;padding:8px 16px;border-radius:22px;background:var(--panel);box-shadow:var(--shadow);font-weight:700;font-size:18px;z-index:3}.ref-toggle{position:absolute;bottom:12px;left:12px;min-height:56px;padding:8px 16px;border-radius:22px;background:var(--panel);box-shadow:var(--shadow);font-weight:700;font-size:16px;z-index:3}.surface .layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.surface .svg-layer{pointer-events:none}.surface .reference-image-layer{pointer-events:none;opacity:.28;z-index:0;width:100%;height:100%;object-fit:contain;background:#fff;filter:brightness(1.08) saturate(.75)}.surface .guide-layer{pointer-events:none;opacity:.22;z-index:0}.surface .guide-layer.stepped{opacity:1}.surface .guide-layer svg{width:100%;height:100%;display:block}.surface .svg-layer.tool-interactive{pointer-events:auto}.surface .svg-layer .fillable{cursor:pointer;transition:opacity .12s ease}.surface .svg-layer.tool-interactive .fillable:active{opacity:.7}.surface .svg-layer .fillable.lock-active{stroke:#ffd166!important;stroke-width:8!important;stroke-dasharray:12 8;paint-order:stroke fill}.surface .canvas-layer{touch-action:none}.surface .canvas-layer.disabled,.surface .sticker-layer{pointer-events:none}.surface .sticker-layer.tool-stickers{pointer-events:auto;cursor:crosshair}.surface .sticker-layer image{pointer-events:none}.tab-tray{background:var(--panel);box-shadow:-2px 0 8px #0000000f;flex-shrink:0;width:280px;display:flex;flex-direction:column;z-index:2}.tabs{display:flex;gap:6px;padding:8px 8px 0;flex-shrink:0}.tab{flex:1;padding:8px 2px 10px;border-radius:16px 16px 0 0;background:#f1ecdc;font-weight:700;font-size:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:background .12s ease;min-height:60px}.tab .emoji{font-size:22px}.tab.active{background:var(--accent)}.tray{display:flex;flex-wrap:wrap;align-content:flex-start;justify-content:center;gap:8px;padding:10px;overflow-y:auto;overflow-x:hidden;flex:1}.tray::-webkit-scrollbar{display:none}.brush-tray-multi{display:flex;flex-direction:column;flex:1;overflow:hidden}.brush-tray-multi .tray-row{padding:8px;min-height:0}.brush-tray-multi .tray-tools{flex:0 0 auto;max-height:50%;overflow-y:auto}.brush-tray-multi .tray-colors{border-top:1px solid #f1ecdc;flex:1 1 auto;overflow-y:auto}.tray-sep{flex-basis:100%;height:1px;background:#f1ecdc;margin:4px 0}.swatch{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:3px solid #ffffff;box-shadow:0 2px 4px #0000002e;transition:transform .1s ease}.swatch.selected{transform:scale(1.18);border-color:var(--ink);border-width:4px}.lock-btn{flex-shrink:0;width:80px;height:80px;border-radius:18px;background:#f7f1e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-weight:700;font-size:13px;transition:transform .08s ease}.lock-btn .emoji{font-size:30px}.lock-btn.on{background:var(--accent)}.size-btn{flex-shrink:0;width:80px;height:80px;border-radius:18px;background:#f7f1e0;display:flex;align-items:center;justify-content:center;transition:transform .08s ease}.size-btn.selected{background:var(--accent);transform:scale(1.06)}.size-dot{display:inline-block;border-radius:50%;background:#2c2a4a}.brush-btn,.sticker-btn{flex-shrink:0;width:80px;height:80px;border-radius:18px;background:#f7f1e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:13px;font-weight:700;transition:transform .08s ease}.brush-btn .emoji{font-size:32px}.brush-btn.selected,.sticker-btn.selected{background:var(--accent);transform:scale(1.06)}.sticker-btn img{width:56px;height:56px;pointer-events:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10}.modal{background:var(--panel);border-radius:28px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:18px;box-shadow:0 8px 30px #00000040;max-width:340px;text-align:center}.modal h2{margin:0;font-size:26px}.modal-buttons{display:flex;gap:18px}.modal-btn{width:100px;height:100px;border-radius:50%;font-size:48px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}.picker-modal{background:var(--panel);border-radius:28px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 30px #00000040;max-width:90vw}.picker-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.picker-header h2{margin:0;font-size:22px}.picker-close{width:56px;height:56px;border-radius:50%;background:#ff6b6b;color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center}.picker-grid{display:grid;grid-template-columns:repeat(6,56px);gap:8px;max-height:60vh;overflow-y:auto}.picker-tile{width:56px;height:56px;border-radius:14px;border:3px solid #ffffff;box-shadow:0 2px 4px #0000002e}.picker-tile:active{transform:scale(.92)}.swatch-add{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:3px dashed #aaa;background:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;color:#888}.modal-btn.confirm-yes{background:#a3d977;color:#fff}.modal-btn.confirm-no{background:#ff6b6b;color:#fff}
