:root{--ios-blue: hsl(197 71% 73%);--ios-blue-light: hsl(197 71% 92%);--aero-blue: hsl(197 71% 73%);--aero-blue-strong: hsl(192 70% 45%);--aero-blue-soft: hsl(194 78% 94%);--aero-bg: #f3fbff;--glass-card: rgba(255, 255, 255, .82);--glass-card-strong: rgba(255, 255, 255, .94);--pronunciation-green: #0f766e;--ios-red: #FF3B30;--ios-green: #34C759;--ios-orange: #FF9500;--ios-bg: #F3F8FC;--ios-card: #FFFFFF;--ios-separator: #C6C6C8;--ios-separator-light: #E5E5EA;--ios-primary: #000000;--ios-secondary: #3C3C43;--ios-tertiary: #8E8E93;--ios-quaternary: #AEAEB2;--ios-nav-blur: rgba(255, 255, 255, .85);--ios-corner-lg: 20px;--ios-corner-md: 16px;--ios-corner-sm: 12px;--ios-shadow: 0 10px 28px rgba(66, 119, 153, .1);--soft-border: rgba(119, 181, 213, .2);color:var(--ios-primary);font-family:-apple-system,SF Pro Display,SF Pro Text,Helvetica Neue,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#dbf4fff2,#f6fbfff5 42%,#f6f8fc)}button,input{font:inherit}button{border:0;cursor:pointer}button:active{opacity:.7}button:focus-visible,input:focus-visible{outline:2px solid var(--ios-blue);outline-offset:2px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--ios-quaternary);border-radius:4px}.app-shell{width:min(1180px,100%);margin:0 auto;padding:0 18px max(36px,env(safe-area-inset-bottom));min-height:100vh;background:linear-gradient(180deg,#e7f8ffbd,#fafcfff5 34%,#f6f8fcfa);box-shadow:0 24px 80px #25597e1f}.page-top,.speech-bar,.reader-toolbar,.section-heading{display:flex;align-items:center;justify-content:space-between;gap:14px}.app-header{display:flex;align-items:center;justify-content:space-between;padding:max(8px,env(safe-area-inset-top)) 20px 10px;background:#f8fdffc2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid var(--soft-border);position:sticky;top:0;z-index:10}.app-shell:not(.route-home) .app-header{display:none}.route-home .app-header{position:relative;align-items:center;min-height:228px;padding:max(30px,calc(env(safe-area-inset-top) + 20px)) 24px 30px;overflow:hidden;background:linear-gradient(90deg,#fffffffc,#ffffffe0,#ffffff47 48%,#fff0),linear-gradient(180deg,#ffffff5c,#e5f8ff1a 48%,#b0e4f400),url(/images/hong-kong-skyline-banner.png);background-position:left center,left center,right 46%;background-repeat:no-repeat;background-size:100% 100%,100% 100%,auto 112%;border-bottom:0}.route-home .app-header:before{content:"";position:absolute;left:0;right:0;bottom:0;height:64px;pointer-events:none;background:linear-gradient(180deg,#fff0,#abe1f32e 68%,#5ebede29)}.route-home .app-header:after{content:none}.app-header>*{position:relative;z-index:1}.app-header h1{color:#10205a;font-size:34px;font-weight:800;letter-spacing:-.41px;margin:0;line-height:1.1}.app-header>div:first-child{min-width:0}.app-header>div:last-child{flex-shrink:0}.eyebrow{display:block;margin:0;color:#263769;font-size:13px;font-weight:600;letter-spacing:-.08px}h1,h2,h3,p{margin-top:0}h1{font-size:28px;font-weight:700;letter-spacing:.36px;line-height:1.15;margin-bottom:0}h2{margin-bottom:6px;font-size:20px;font-weight:650;letter-spacing:.38px}h3{font-size:17px;font-weight:600;letter-spacing:-.41px;margin-bottom:6px}.speech-chip{font-family:-apple-system,SF Pro Text,Helvetica Neue,sans-serif;display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:6px 14px;border-radius:20px;background:var(--ios-card);box-shadow:var(--ios-shadow);color:var(--ios-secondary);font-size:15px;font-weight:500;white-space:nowrap}.speech-chip.playing{background:var(--ios-blue-light);color:var(--aero-blue-strong)}.speech-chip.paused{background:#fff3e0;color:var(--ios-orange)}.home-panel{display:grid;align-content:start;min-height:min(600px,calc(100vh - 160px));margin-top:0;padding:20px 20px 24px;position:relative;z-index:2}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.module-tile{--tile-accent: var(--ios-blue);display:flex;flex-direction:column;align-items:flex-start;gap:12px;min-height:144px;padding:18px 16px 16px;background:linear-gradient(145deg,#fffffffa,#ffffffbd);color:var(--ios-primary);cursor:pointer;border:1px solid rgba(255,255,255,.88);border-radius:14px;box-shadow:0 16px 34px #46789821;text-align:left;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease;width:100%}.module-tile:nth-child(1){--tile-accent: #2f8cff}.module-tile:nth-child(2){--tile-accent: #37d681}.module-tile:nth-child(3){--tile-accent: #ffb02e}.module-tile:nth-child(4){--tile-accent: #9b78ff}.module-tile:nth-child(5){--tile-accent: #27c7d7}.module-tile:nth-child(6){--tile-accent: #ff7c55}.module-tile:nth-child(7){--tile-accent: #4aa2ff}.module-tile:nth-child(8){--tile-accent: #ff7aa8}.module-tile:nth-child(9){--tile-accent: #9a74ff}.module-tile:nth-child(10){--tile-accent: #20c8c7}.module-tile:hover{border-color:color-mix(in srgb,var(--tile-accent),white 35%);box-shadow:0 20px 42px color-mix(in srgb,var(--tile-accent),transparent 78%)}.module-tile:active{transform:translateY(1px)}.module-tile svg:first-child{width:42px;height:42px;padding:8px;border-radius:13px;color:var(--tile-accent);background:linear-gradient(145deg,color-mix(in srgb,var(--tile-accent),white 72%),#ffffffbd);box-shadow:inset 0 1px 1px #ffffffeb,0 8px 16px color-mix(in srgb,var(--tile-accent),transparent 76%)}.module-copy{display:flex;flex-direction:column;gap:7px;min-width:0;margin-top:auto}.module-copy strong{font-size:19px;font-weight:800;letter-spacing:0;line-height:1.15}.module-copy small{color:#66727c;font-size:13px;font-weight:600;letter-spacing:0;line-height:1.3}.page-top{display:flex;align-items:center;gap:12px;margin-bottom:0;padding:max(16px,env(safe-area-inset-top)) 20px 12px;background:#f7fcffd1;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid var(--soft-border);position:sticky;top:0;z-index:10}.page-title-chip{display:inline-flex;align-items:center;justify-content:flex-start;width:fit-content;max-width:min(240px,42vw);margin-left:auto;margin-right:16px;padding:7px 15px 8px;border:1px solid rgba(255,255,255,.88);border-radius:999px;background:linear-gradient(180deg,#fffffff5,#effaffc7);box-shadow:0 10px 24px #4678981f,inset 0 1px 1px #ffffffe6;color:#264457}.page-top h2{font-size:17px;font-weight:700;letter-spacing:0;margin:0;text-align:left;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.back-button{display:inline-flex;align-items:center;gap:2px;justify-self:start;min-height:36px;padding:0 4px;background:transparent;color:var(--aero-blue-strong);font-size:17px;font-weight:500;letter-spacing:-.41px;flex-shrink:0}.back-button svg{width:20px;height:20px;stroke-width:2.5}.speech-bar{margin-bottom:0;padding:10px 20px 8px;background:#f7fcffd1;border-bottom:.5px solid var(--soft-border)}.speech-controls-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px}.speed-selector{display:inline-flex;padding:2px;background:#d7e5efbd;border-radius:999px;box-shadow:inset 0 1px 2px #527a961f}.speed-selector button{display:inline-flex;align-items:center;justify-content:center;min-height:28px;min-width:40px;padding:0 6px;border-radius:999px;background:transparent;color:var(--ios-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .1s ease}.speed-selector button.selected{background:linear-gradient(180deg,#40bfd4,#20aabd);color:#fff;box-shadow:0 8px 18px #1fa9be40,inset 0 1px 1px #ffffff59}.edit-bar{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:8px 20px;background:#f7fcffd1;border-bottom:.5px solid var(--soft-border)}.edit-bar span{margin-right:auto;color:var(--ios-secondary);font-size:13px;font-weight:700}.segmented-control{display:inline-flex;padding:2px;background:#d7e5efbd;border-radius:999px;box-shadow:inset 0 1px 2px #527a961f}.segmented-control button{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:30px;padding:0 12px;border-radius:999px;background:transparent;color:var(--ios-secondary);font-size:13px;font-weight:500;letter-spacing:-.08px;cursor:pointer;transition:all .1s ease}.segmented-control button.selected{background:linear-gradient(180deg,#40bfd4,#20aabd);color:#fff;box-shadow:0 8px 18px #1fa9be40,inset 0 1px 1px #ffffff59}.workspace{min-width:0;background:transparent;overflow:visible}.two-column{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr)}.lesson-list-sidebar{display:none}.lesson-drawer{display:none;padding:10px 20px;background:#f7fcffd1;position:relative}.lesson-drawer-trigger{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:44px;padding:0 16px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.92);border-radius:12px;color:var(--ios-primary);text-align:left;cursor:pointer;box-shadow:0 8px 22px #4678981a}.lesson-drawer-trigger span{display:flex;flex-direction:column;gap:1px;min-width:0}.lesson-drawer-trigger small{color:var(--ios-tertiary);font-size:12px;font-weight:500;letter-spacing:-.08px}.lesson-drawer-trigger strong{overflow:hidden;font-size:17px;font-weight:500;letter-spacing:-.41px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.lesson-drawer-trigger svg{flex:0 0 auto;color:var(--aero-blue-strong);transition:transform .16s ease}.lesson-drawer.open .lesson-drawer-trigger svg{transform:rotate(180deg)}.lesson-drawer-panel{margin-top:8px;padding:4px;background:transparent;border:0;border-radius:var(--ios-corner-sm);box-shadow:none;max-height:60vh;overflow:auto}.lesson-drawer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.lesson-drawer-item{display:grid;grid-template-columns:30px minmax(0,1fr);align-items:center;gap:8px;min-height:52px;padding:8px 12px;background:#ffffffb8;color:var(--ios-primary);text-align:left;border:.5px solid rgba(255,255,255,.88);border-radius:var(--ios-corner-sm);width:100%;cursor:pointer;transition:background .12s ease,border-color .12s ease}.lesson-drawer-item.selected{border-color:var(--aero-blue-strong);background:linear-gradient(145deg,#cdf6fde0,#e1faffc7);box-shadow:inset 0 0 0 .5px var(--aero-blue-strong)}.lesson-drawer-item:disabled{opacity:.45}.lesson-drawer-item .lesson-number{flex-shrink:0}.lesson-drawer-item strong{overflow:hidden;font-size:14px;font-weight:500;letter-spacing:-.08px;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.lesson-drawer-item em{grid-column:2;color:var(--ios-tertiary);font-size:12px;font-style:normal;font-weight:400;letter-spacing:-.08px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-list{max-height:calc(100vh - 160px);overflow:auto;padding:12px 16px;border-right:.5px solid var(--ios-separator-light)}.lesson-group+.lesson-group{margin-top:0}.lesson-group h2{padding:12px 16px 4px;margin:0;color:var(--ios-tertiary);font-size:13px;font-weight:500;letter-spacing:-.08px;text-transform:uppercase}.lesson-row{display:flex;align-items:center;gap:10px;width:100%;min-height:44px;padding:8px 12px;background:transparent;color:var(--ios-primary);text-align:left;border:none;border-radius:var(--ios-corner-sm);cursor:pointer;transition:background .1s ease}.lesson-row.selected{background:var(--ios-blue-light)}.lesson-row:disabled{cursor:not-allowed;opacity:.45}.lesson-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:9px;background:#e7f0f7e6;color:#789;font-size:13px;font-weight:700;letter-spacing:-.08px;flex-shrink:0}.lesson-row em{color:var(--ios-tertiary);font-size:13px;font-style:normal;font-weight:400;letter-spacing:-.08px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-count{flex-shrink:0;min-width:24px;padding:2px 8px;border-radius:999px;background:var(--ios-separator-light);color:var(--ios-tertiary);font-size:13px;font-weight:500;letter-spacing:-.08px;text-align:center}.lesson-row.selected .lesson-count{background:var(--aero-blue-strong);color:#fff}.reader{min-width:0;min-height:600px;padding:24px 28px}.reader-toolbar{margin-bottom:14px;padding:18px 18px 16px;border:1px solid rgba(255,255,255,.88);border-radius:18px;background:linear-gradient(90deg,#fffffffc,#ffffffeb 39%,#ffffff52 62%,#fff0),linear-gradient(180deg,#ffffff47,#cdf2fc0a),url(/images/hong-kong-skyline-banner.png);background-position:left center,left center,right 46%;background-repeat:no-repeat;background-size:100% 100%,100% 100%,auto 112%;box-shadow:var(--ios-shadow);align-items:flex-start;overflow:hidden;position:relative}.reader-toolbar:after{content:none;position:absolute;right:-18px;bottom:-20px;width:148px;height:78px;background:linear-gradient(180deg,#fff0,#41b2cd29),linear-gradient(90deg,transparent 0 10%,rgba(81,166,198,.16) 10% 15%,transparent 15% 22%,rgba(81,166,198,.14) 22% 27%,transparent 27% 36%,rgba(81,166,198,.18) 36% 42%,transparent 42%);clip-path:polygon(0 62%,10% 58%,17% 22%,24% 60%,34% 30%,42% 61%,54% 24%,62% 62%,76% 38%,86% 63%,100% 54%,100% 100%,0 100%);pointer-events:none}.reader-title{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px}.reader-title small{color:#66727c;font-size:14px;font-weight:600}.reader-title h3{margin:0;font-size:17px;font-weight:600;letter-spacing:-.41px}.status-badge{display:inline-flex;align-items:center;width:fit-content;margin-top:6px;padding:2px 10px;border-radius:999px;background:#ff95001f;color:var(--ios-orange);font-size:12px;font-weight:500;letter-spacing:-.08px;line-height:1.3}.section-heading{padding:16px 20px 10px;background:transparent;font-size:13px;font-weight:500;color:var(--ios-tertiary);letter-spacing:-.08px;text-transform:uppercase;border-bottom:none;align-items:center}.section-heading h3{margin:0;font-size:13px;font-weight:500;text-transform:uppercase;color:var(--ios-tertiary)}.toolbar-actions{display:flex;flex-wrap:wrap;gap:6px}.card-actions,.review-controls{display:flex;flex-wrap:wrap;gap:8px}.primary-button,.secondary-button,.danger-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;border-radius:var(--ios-corner-sm);cursor:pointer;font-weight:500;font-size:15px;letter-spacing:-.41px;font-family:-apple-system,SF Pro Text,Helvetica Neue,sans-serif;transition:opacity .1s ease}.primary-button{padding:0 14px;background:linear-gradient(180deg,#43b9d3,#1f9fb8);color:#fff;font-weight:700;box-shadow:0 10px 18px #1f9fb838,inset 0 1px 1px #ffffff59}.primary-button:disabled{opacity:.4;cursor:not-allowed}.secondary-button{padding:0 14px;background:#eff8fdeb;color:var(--aero-blue-strong)}.danger-button{padding:0 14px;background:var(--ios-red);color:#fff}.icon-button{width:34px;background:#eff8fdeb;color:var(--aero-blue-strong)}.note-html{min-width:0;width:100%;max-width:100%;overflow-x:auto;color:var(--ios-primary);font-size:16px;line-height:1.7;font-family:-apple-system,SF Pro Text,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;word-break:normal}.lesson-reader{max-width:720px;margin:0 auto}.note-html h1{margin-top:1.4rem;margin-bottom:.6rem;font-size:22px;font-weight:700;letter-spacing:.36px;line-height:1.25}.note-html h1:first-child{margin-top:0}.note-html p{margin-bottom:.85rem;max-width:100%;overflow-wrap:break-word;word-break:normal}.note-html p:last-child{margin-bottom:0}.note-html table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;border-radius:14px;border:1px solid var(--soft-border);background:#ffffffc2}.note-html td,.note-html th{padding:12px;border:0;border-right:1px solid var(--soft-border);border-bottom:1px solid var(--soft-border);text-align:center;vertical-align:middle;word-break:normal;overflow-wrap:break-word;font-size:15px;position:relative}.note-html tr>:last-child{border-right:0}.note-html tr:last-child>*{border-bottom:0}.note-html th{background:#d7f4fbd1;color:var(--aero-blue-strong);font-weight:700}.note-html .table-pronounced-term{display:inline-flex;flex-direction:column;align-items:center;min-width:0;max-width:100%}.note-html .table-pronounced-term .jyutping-above,.note-html .table-pronounced-term .jyutping-below{white-space:normal}.note-html .explanation-subsection{margin-top:14px;padding:14px;border:1px solid var(--soft-border);border-radius:14px;background:#f8fdffb8}.note-html .explanation-subsection h3{margin:0 0 8px;color:var(--aero-blue-strong);font-size:17px;font-weight:700}.note-html .dialogue-explainer{display:grid;gap:14px;max-width:100%}.note-html .annotated-dialogue-line{display:flex;gap:10px;max-width:none;margin:0 0 10px;padding:12px;background:#f1f9fdeb;border:1px solid rgba(255,255,255,.8);border-radius:var(--ios-corner-sm);position:relative;box-shadow:0 8px 18px #46789814}.note-html .annotated-dialogue-line:last-child{margin-bottom:0}.note-html .dialogue-speaker{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;background:var(--ios-blue-light);color:var(--aero-blue-strong);font-size:13px;font-weight:700;flex-shrink:0}.note-html .dialogue-utterance{display:flex;flex-wrap:wrap;min-width:0;align-items:flex-end;gap:6px}.annotated-dialogue-line .dialogue-speak-btn{position:absolute;top:50%;right:12px;transform:translateY(-50%);z-index:2;border-radius:6px}.dialogue-list{display:grid;gap:12px;padding-top:8px}.dialogue-line{display:flex;align-items:flex-start;gap:10px;padding:14px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:16px;box-shadow:var(--ios-shadow);position:relative}.dialogue-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:#e6f2faf0;color:var(--aero-blue-strong);font-size:13px;font-weight:700;flex-shrink:0;font-variant-numeric:tabular-nums}.dialogue-body{flex:1;min-width:0}.pronunciation-line{display:flex;flex-wrap:wrap;gap:5px 6px;align-items:baseline;line-height:1.5}.pronunciation-line+.pronunciation-line{margin-top:4px}.source-pronunciation{color:var(--pronunciation-green);font-size:14px;font-weight:500}.jyutping-line{color:var(--pronunciation-green);font-size:14px;font-weight:600}.pronunciation-label{display:inline-flex;align-items:center;min-height:20px;padding:0 7px;border-radius:4px;background:var(--ios-bg);font-size:12px;font-weight:500;letter-spacing:-.08px;white-space:nowrap}.source-pronunciation .pronunciation-label{color:var(--pronunciation-green)}.pronunciation-incomplete{color:var(--ios-orange)}.pronunciation-incomplete .pronunciation-label{background:#fff3e0;color:var(--ios-orange)}.pronunciation-token{white-space:nowrap}.line-speak-button,.line-edit-button,.inline-edit-button,.chip-edit-button{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;background:#eff8fdf0;color:var(--aero-blue-strong);cursor:pointer;flex-shrink:0;border:1px solid rgba(255,255,255,.88)}.line-speak-button:hover,.line-edit-button:hover,.inline-edit-button:hover,.chip-edit-button:hover{background:var(--ios-blue-light)}.note-html .annotated-dialogue-line.dialogue-line-with-speak{position:relative}.local-edit-badge{display:inline-flex;align-items:center;width:fit-content;min-height:22px;padding:0 8px;border-radius:999px;background:#34c7591f;color:#248a3d;font-size:12px;font-weight:700;line-height:1.2}.cantonese-text{margin:8px 0 0;font-size:20px;font-weight:600;line-height:1.5;letter-spacing:.36px}.translation-panel{margin-top:16px;padding:16px;background:#eff8fdeb;border:1px solid rgba(255,255,255,.84);border-radius:var(--ios-corner-sm)}.translation-panel h3{margin-bottom:10px;font-size:15px;font-weight:600;color:var(--ios-secondary)}.translation-panel ol{display:grid;gap:8px;margin:0;padding-left:1.4rem}.translation-panel li{font-size:15px;line-height:1.5;color:var(--ios-secondary)}.short-reading-card{display:flex;flex-direction:column;gap:14px;max-width:720px;margin:12px auto 0;padding:20px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:18px;box-shadow:var(--ios-shadow);position:relative}.short-reading-card .inline-edit-button{position:absolute;top:16px;right:16px}.reading-meta{display:flex;flex-wrap:wrap;gap:8px}.reading-meta span{display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:999px;background:var(--ios-blue-light);color:var(--aero-blue-strong);font-size:13px;font-weight:600;letter-spacing:-.08px}.reading-meta span+span{background:var(--ios-bg);color:var(--ios-tertiary)}.short-reading-text{margin:0;font-size:18px;font-weight:500;line-height:1.75;letter-spacing:.38px}.tokenized-jyutping{display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px 6px;margin:0;font-size:17px;line-height:1.4}.jyutping-pair{display:inline-flex;flex-direction:column;align-items:center;justify-content:flex-end;min-width:0;max-width:100%;vertical-align:bottom}.jyutping-above{color:var(--pronunciation-green);font-size:.75em;font-weight:500;line-height:1.15;white-space:nowrap}.jyutping-below{font-weight:600;line-height:1.35;white-space:nowrap}.jyutping-punct{display:inline-flex;align-items:flex-end;min-height:2.45em;font-weight:600;color:var(--ios-secondary)}.understanding-list{display:grid;gap:14px;width:100%;margin:12px 0 0}.understanding-item{padding:18px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:18px;box-shadow:var(--ios-shadow)}.understanding-title{display:flex;align-items:center;gap:8px;margin-bottom:10px}.understanding-title span{color:var(--aero-blue-strong);font-weight:700;font-size:14px;flex-shrink:0;white-space:nowrap}.understanding-title h3{flex:1;min-width:0;margin:0;font-size:17px;font-weight:600;letter-spacing:-.41px;line-height:1.35}.understanding-title .local-edit-badge{flex-shrink:0}.explanation-edit-button{flex-shrink:0;position:static;width:28px;height:28px;border-radius:8px}.understanding-item .note-html p{margin:0;padding:12px 0;border-top:.5px solid var(--soft-border);font-size:15px;line-height:1.65}.understanding-item .note-html p:first-child{border-top:0}.understanding-item .note-html .ku-example{display:flex;flex-wrap:wrap;align-items:flex-start;column-gap:10px;row-gap:6px}.ku-example-number{flex:0 0 auto;color:var(--aero-blue-strong);font-weight:700;font-size:14px;line-height:1.35;padding-top:1.08em}.ku-example-main{display:flex;flex-wrap:wrap;flex:1 1 0;min-width:0;align-items:flex-end;gap:6px}.ku-example-translation{flex:0 0 100%;margin-left:42px;color:var(--ios-tertiary);font-weight:400;font-size:14px;line-height:1.6}.sentence-list{display:grid;gap:12px}.sentence-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:14px 84px 14px 14px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:16px;box-shadow:var(--ios-shadow)}.sentence-main{display:flex;align-items:flex-start;gap:10px}.sentence-token-grid{flex:1;min-width:0;font-size:16px;display:flex;flex-wrap:wrap;align-items:flex-end;gap:6px}.sentence-translation{margin:0 0 0 42px;color:var(--ios-tertiary);font-size:14px;line-height:1.55}.sentence-card .line-speak-button{position:absolute;top:14px;right:12px}.sentence-card .line-edit-button{position:absolute;top:14px;right:48px}.empty-state{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--ios-tertiary);font-size:15px}.setting-control{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:var(--ios-corner-sm);color:var(--ios-secondary);font-size:15px;font-weight:500;box-shadow:var(--ios-shadow)}.setting-control input{width:56px;min-height:28px;border:.5px solid var(--ios-separator-light);border-radius:6px;padding:0 6px;background:var(--ios-card);font-size:15px;text-align:center}.review-summary{display:flex;flex-wrap:wrap;gap:8px;padding:12px 20px}.review-summary span,.counter{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eff8fdeb;color:var(--ios-secondary);font-size:13px;font-weight:600;letter-spacing:-.08px;border:1px solid rgba(255,255,255,.84)}.flash-card{display:flex;flex-direction:column;gap:10px;width:min(600px,calc(100% - 32px));margin:12px auto;padding:28px 24px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:22px;box-shadow:0 18px 42px #46789821}.flash-card h3{margin:0;font-size:clamp(2rem,10vw,3.5rem);font-weight:700;letter-spacing:.36px;line-height:1.05}.pronunciation{color:var(--pronunciation-green);font-weight:500;font-size:17px}.flash-card small{color:var(--ios-tertiary);font-size:13px;font-weight:500}blockquote{margin:0;padding:14px;border-left:3px solid var(--aero-blue);background:#edf9fec7;border-radius:0 var(--ios-corner-sm) var(--ios-corner-sm) 0}blockquote span{display:block;margin-top:6px;color:var(--ios-tertiary);font-size:14px}.review-controls{align-items:center;justify-content:center;padding:0 20px 20px;gap:10px}.vocabulary-browser{display:flex;flex-direction:column;gap:14px;padding:16px 20px}.vocabulary-lesson-list{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow:auto;padding:0}.vocabulary-chip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));align-content:start;gap:10px}.vocabulary-chip{display:flex;flex-direction:column;gap:5px;padding:14px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:16px;box-shadow:var(--ios-shadow);position:relative}.vocabulary-chip-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.vocabulary-chip small{color:var(--ios-tertiary);font-size:12px;font-weight:500;letter-spacing:-.08px}.vocabulary-chip strong{font-size:18px;font-weight:600;line-height:1.25}.vocabulary-chip span{color:var(--pronunciation-green);font-size:14px;font-weight:500;line-height:1.35}.vocabulary-chip p{margin:0;color:var(--ios-tertiary);font-size:14px;line-height:1.4}.chip-speak-button{display:flex;flex:0 0 auto;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--ios-bg);color:var(--ios-blue);cursor:pointer;border:none}.chip-speak-button:hover{background:var(--ios-blue-light)}.chip-edit-button{position:absolute;right:10px;bottom:10px;width:28px;height:28px;border-radius:8px}.vocabulary-example{margin-top:6px;padding:10px 12px;border-left:3px solid var(--aero-blue);background:#eff8fdeb;border-radius:0 var(--ios-corner-sm) var(--ios-corner-sm) 0;font-size:14px;line-height:1.4}.edit-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:flex-end;justify-content:center;padding:18px;background:#0e21303d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.edit-sheet{width:min(680px,100%);max-height:min(720px,calc(100vh - 36px));overflow:auto;padding:18px;border-radius:18px;border:1px solid rgba(255,255,255,.9);background:#fffffff5;box-shadow:0 24px 70px #2b597638}.edit-sheet-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.edit-sheet-header h3{margin:0;font-size:20px}.edit-fields{display:grid;gap:12px}.edit-field{display:grid;gap:6px;color:var(--ios-secondary);font-size:13px;font-weight:700}.edit-field input,.edit-field textarea{width:100%;border:1px solid var(--ios-separator-light);border-radius:10px;padding:10px 12px;background:#fff;color:var(--ios-primary);font:inherit;line-height:1.45;resize:vertical}.edit-field textarea{min-height:74px}.edit-field .html-source-editor{min-height:320px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.55;white-space:pre;overflow:auto}.edit-sheet-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-top:16px}.structured-editor{display:grid;gap:10px}.structured-block{display:grid;gap:8px;padding:12px;border:1px solid var(--soft-border);border-radius:12px;background:#f8fdffb8}.structured-block-title{margin:0;color:var(--aero-blue-strong);font-size:13px;font-weight:700}.structured-pair-block{grid-template-columns:repeat(2,minmax(0,1fr))}.structured-pair-block .structured-block-title{grid-column:1 / -1}.structured-table-wrap{max-width:100%;overflow:auto;border:1px solid var(--soft-border);border-radius:10px;background:#ffffffb8}.structured-table-editor{width:100%;border-collapse:collapse;table-layout:fixed}.structured-table-editor td{min-width:140px;padding:6px;border-right:1px solid var(--soft-border);border-bottom:1px solid var(--soft-border);vertical-align:top}.structured-table-editor tr:last-child td{border-bottom:0}.structured-table-editor td:last-child{border-right:0}.structured-table-editor textarea{width:100%;min-height:50px;border:1px solid var(--ios-separator-light);border-radius:8px;padding:8px;background:#fff;color:var(--ios-primary);font:inherit;line-height:1.45;resize:vertical}.source-fallback-editor{padding:10px 12px;border:1px dashed var(--soft-border);border-radius:12px;background:#ffffff8a}.source-fallback-editor summary{cursor:pointer;color:var(--ios-tertiary);font-size:13px;font-weight:700}.source-fallback-editor .edit-field{margin-top:10px}.compact-empty{min-height:80px}.note-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:16px 20px}.note-item{min-height:160px;padding:18px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:18px;box-shadow:var(--ios-shadow)}.note-item small{color:var(--ios-tertiary);font-weight:500;font-size:13px}.note-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.culture-list{display:grid;gap:10px;padding:16px 20px}.culture-item{background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:16px;box-shadow:var(--ios-shadow);overflow:hidden}.culture-item summary{display:flex;align-items:center;gap:10px;min-height:48px;padding:10px 14px;cursor:pointer;list-style:none}.culture-item summary::-webkit-details-marker{display:none}.culture-item summary:after{content:"";flex-shrink:0;width:20px;height:20px;margin-left:auto;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C6C6C8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-size:contain;transition:transform .16s ease}.culture-item[open] summary:after{transform:rotate(180deg)}.culture-item summary strong{font-size:16px;font-weight:500}.culture-item summary small{color:var(--ios-tertiary);font-weight:500;font-size:13px}.culture-body{display:flex;flex-direction:column;gap:14px;padding:0 14px 16px}.culture-reading{max-width:780px;margin:12px auto 0;padding:20px;background:var(--glass-card-strong);border:1px solid rgba(255,255,255,.84);border-radius:18px;box-shadow:var(--ios-shadow)}.culture-note-html{display:flex;flex-direction:column;gap:14px;min-width:0;overflow-x:clip}.culture-note-html>p,.culture-note-html .explanation-subsection>p{max-width:none;min-width:0;margin:0;padding:14px 16px;background:#eff8fdeb;border-radius:var(--ios-corner-sm);overflow-wrap:anywhere;font-size:15px;line-height:1.6}.culture-note-html>p:first-child,.culture-note-html .explanation-subsection>p:first-of-type{background:var(--ios-blue-light);font-weight:500}.culture-note-html .explanation-subsection{display:grid;gap:10px;min-width:0;margin-top:2px;padding:16px;background:#eff8fdeb;border-radius:var(--ios-corner-sm)}.culture-note-html .explanation-subsection h3{margin:0;color:var(--ios-secondary);font-size:16px;font-weight:600;line-height:1.35}.culture-note-html table{display:table;width:100%;max-width:100%;table-layout:fixed;overflow:visible;border-radius:14px;border-collapse:separate;border-spacing:0;background:#fffc;box-shadow:var(--ios-shadow);border:1px solid var(--soft-border)}.culture-note-html th{background:#d7f4fbd1;color:var(--aero-blue-strong);font-size:13px;font-weight:700;letter-spacing:-.08px}.culture-note-html td,.culture-note-html th{border:0;border-right:1px solid var(--soft-border);border-bottom:1px solid var(--soft-border);padding:11px 12px;text-align:center;vertical-align:middle;line-height:1.55;white-space:normal;word-break:normal;overflow-wrap:anywhere;font-size:15px;position:relative}.culture-note-html tr>:last-child{border-right:0}.culture-note-html tr:last-child>*{border-bottom:0}.culture-note-html tbody tr:nth-child(2n){background:#eff8fd94}.culture-note-html td:first-child{font-weight:600}.culture-note-html .table-pronounced-term{min-width:0;max-width:100%;white-space:normal}.culture-note-html .table-pronounced-term .jyutping-above,.culture-note-html .table-pronounced-term .jyutping-below{max-width:100%;white-space:normal;overflow-wrap:anywhere;text-align:center}.resizable-table{table-layout:fixed;width:100%}.table-resize-cell{position:relative}.table-resize-handle{position:absolute;top:0;right:-5px;z-index:4;width:10px;height:100%;cursor:col-resize;touch-action:none}.table-resize-handle:after{content:"";position:absolute;top:10px;bottom:10px;left:4px;width:2px;border-radius:999px;background:transparent;transition:background .12s ease,box-shadow .12s ease}.table-resize-handle:hover:after,.table-resize-handle:active:after,.table-resizing .table-resize-handle:after{background:var(--aero-blue-strong);box-shadow:0 0 0 2px #1f9fb824}.table-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}@media (max-width: 820px){.route-home .app-header{background-size:100% 100%,100% 100%,auto 118%}.module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-tile{min-height:150px}.lesson-list{display:none}.two-column{grid-template-columns:1fr}.workspace{border:0;background:transparent;box-shadow:none;overflow:visible}.lesson-list-sidebar{display:none}.lesson-drawer{position:sticky;top:max(8px,env(safe-area-inset-top));z-index:6;display:block;padding:0;background:transparent}.reader{min-height:520px;padding:14px 0 0}.reader-toolbar{margin-bottom:10px;padding:14px;background-size:100% 100%,100% 100%,auto 118%}.note-list{grid-template-columns:1fr}.culture-body{padding-left:18px}.culture-reading{max-width:none;margin-top:12px}.vocabulary-browser{padding-inline:0}.vocabulary-lesson-list{display:none}.vocabulary-chip-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.ku-example-translation{margin-left:40px}.sentence-card{padding-right:84px}.sentence-translation{margin-left:40px}}@media (max-width: 560px){.app-shell{padding:max(10px,env(safe-area-inset-top)) 10px 26px}.app-header{padding:max(6px,env(safe-area-inset-top)) 16px 8px;margin-bottom:8px}.app-header h1{font-size:28px;line-height:.96}.route-home .app-header{min-height:120px;padding:max(10px,env(safe-area-inset-top)) 16px 10px;background-size:100% 100%,100% 100%,auto 120%;background-position:left center,left center,right 46%}.route-home .app-header:before{height:48px}.home-panel{padding:12px 0}.page-top{gap:8px;padding:8px 0;margin-bottom:8px}.page-title-chip{max-width:42vw;margin-right:16px;padding:6px 12px}.page-top h2{font-size:17px}.speech-bar{padding:8px;margin-bottom:10px}.reader-toolbar{flex-direction:column;align-items:stretch;background-size:100% 100%,100% 100%,auto 120%}.section-heading{flex-direction:column;align-items:stretch;padding:14px 0}.review-summary{padding:0}.module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-tile{min-height:118px;padding:16px}.module-copy strong{font-size:1.25rem}.note-list,.culture-list,.vocabulary-browser{padding:12px 0}.vocabulary-chip-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:8px}.flash-card{width:100%;margin:14px 0;padding:20px 16px}.review-controls{padding:0 0 18px}.understanding-list{margin-top:8px}.short-reading-card{margin:8px auto 0;padding:16px}.note-html{font-size:15px;line-height:1.6}.dialogue-line{padding:10px}.understanding-item{padding:14px}.short-reading-text{font-size:16px}.sentence-card{padding:12px 78px 12px 12px}.sentence-card .line-speak-button{top:12px;right:10px}.sentence-card .line-edit-button{top:12px;right:44px}.sentence-token-grid{font-size:15px}.cantonese-text{font-size:18px}.sentence-translation,.ku-example-translation{margin-left:0}}.note-html table{font-size:14px}.note-html td,.note-html th{padding:8px}.note-html .explanation-subsection{overflow-x:auto}
