/* TiếngTrung Pro v2 — Frontend CSS */
:root{--ttp-blue:#2563eb;--ttp-green:#16a34a;--ttp-yellow:#d97706;--ttp-red:#dc2626;--ttp-gray:#6b7280;--ttp-border:#e5e7eb;--ttp-light:#f9fafb;--ttp-radius:8px}
.ttp-page-container{max-width:900px;margin:0 auto;padding:20px}
.ttp-wrap{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.ttp-hidden{display:none!important}
/* chips */
.ttp-chip{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;line-height:1.6}
.ttp-chip-success{background:#dcfce7;color:var(--ttp-green)}.ttp-chip-warning{background:#fef3c7;color:var(--ttp-yellow)}.ttp-chip-danger{background:#fee2e2;color:var(--ttp-red)}.ttp-chip-info{background:#dbeafe;color:var(--ttp-blue)}.ttp-chip-secondary{background:var(--ttp-light);color:var(--ttp-gray)}
/* buttons */
.ttp-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;font-size:13px;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);background:none;cursor:pointer;color:#555;transition:all .15s}
.ttp-btn:hover{background:var(--ttp-light)}.ttp-btn-primary{background:var(--ttp-blue);color:#fff;border-color:var(--ttp-blue)}.ttp-btn-primary:hover{opacity:.88}.ttp-btn-sm{padding:4px 9px;font-size:12px}.ttp-btn-full,.ttp-btn-wide{width:100%;justify-content:center;padding:10px}
/* TTS */
.ttp-tts-btn{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--ttp-border);background:none;cursor:pointer;color:#555;flex-shrink:0;font-size:12px;transition:all .15s}
.ttp-tts-btn:hover{background:var(--ttp-light)}.ttp-tts-btn.playing{border-color:var(--ttp-blue);color:var(--ttp-blue);background:#dbeafe}.ttp-tts-btn.done{border-color:var(--ttp-green);color:var(--ttp-green)}.ttp-tts-btn.error{border-color:var(--ttp-red);color:var(--ttp-red)}
.ttp-tts-sm{width:26px;height:26px;font-size:10px}.ttp-tts-lg{width:auto;border-radius:var(--ttp-radius);padding:5px 12px}
/* pack header */
.ttp-pack-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--ttp-border)}
.ttp-pack-title{font-size:22px;font-weight:600;margin:0 0 8px}
.ttp-chips-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.ttp-view-bar{display:flex;background:#f3f4f6;border-radius:var(--ttp-radius);padding:3px;gap:2px}
.ttp-view-btn{padding:5px 12px;border:none;background:none;cursor:pointer;border-radius:6px;font-size:13px;color:#666;transition:all .15s}
.ttp-view-btn.is-active,.ttp-view-btn:hover{background:#fff;color:#111;box-shadow:0 1px 3px rgba(0,0,0,.1)}
/* toolbar */
.ttp-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.ttp-filter-row{display:flex;gap:5px;flex-wrap:wrap}
.ttp-filter-btn{padding:4px 12px;border:1px solid var(--ttp-border);border-radius:20px;background:none;cursor:pointer;font-size:12px;font-weight:500;color:#666;transition:all .15s}
.ttp-filter-btn.is-active{background:#fff;border-color:#333;color:#111}
.ttp-toggle-row{display:flex;gap:12px;margin-left:auto}
.ttp-toggle-lbl{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:#555}
.ttp-toggle-lbl input{display:none}
.ttp-tog-track{width:28px;height:16px;border-radius:8px;background:#ccc;position:relative;transition:background .2s;flex-shrink:0}
.ttp-toggle-lbl input:checked+.ttp-tog-track{background:var(--ttp-blue)}
.ttp-tog-track::after{content:'';position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .2s}
.ttp-toggle-lbl input:checked+.ttp-tog-track::after{transform:translateX(12px)}
/* word list */
.ttp-pane-list{}
.ttp-word-row{display:flex;align-items:flex-start;gap:12px;padding:16px 0;border-bottom:1px solid var(--ttp-border)}
.ttp-word-row:last-child{border-bottom:none}
.ttp-word-due{border-left:3px solid var(--ttp-red);padding-left:12px;margin-left:-12px}
.ttp-word-new{border-left:3px solid var(--ttp-blue);padding-left:12px;margin-left:-12px}
.ttp-word-body{flex:1;min-width:0}
.ttp-word-top{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.ttp-hanzi{font-size:34px;font-weight:500;font-family:"Noto Sans SC","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;line-height:1}
.ttp-pinyin{font-size:15px;color:#555}
.ttp-word-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:7px}
.ttp-meaning{font-size:15px;font-weight:500;color:#111;margin-bottom:2px}
.ttp-link{font-size:12px;color:var(--ttp-blue);text-decoration:none}
.ttp-link:hover{text-decoration:underline}
.ttp-example{display:flex;gap:8px;align-items:flex-start;margin-top:9px;padding:10px 12px;background:var(--ttp-light);border-left:2px solid var(--ttp-blue)}
.ttp-ex-zh{font-size:14px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;margin-bottom:2px}
.ttp-ex-py{font-size:12px;color:#555;margin-bottom:2px}
.ttp-ex-vi{font-size:13px;color:#666}
.ttp-usage{font-size:12px;color:#888;font-style:italic;margin-top:5px}
.ttp-srs-mini{display:flex;gap:12px;margin-top:8px;font-size:11px;color:#9ca3af}
.ttp-due-now{background:#fee2e2;color:var(--ttp-red);padding:1px 6px;border-radius:20px;font-weight:600}
/* grid */
.ttp-pane-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.ttp-grid-card{padding:14px 10px;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);text-align:center;cursor:pointer;transition:all .15s}
.ttp-grid-card:hover{border-color:#9ca3af;background:var(--ttp-light)}
.ttp-gc-hanzi{font-size:28px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;margin-bottom:4px}
.ttp-gc-py,.ttp-gc-vi{font-size:11px;color:#555;margin-bottom:4px}
/* progress */
.ttp-prog-track{height:5px;background:#f0f0f0;border-radius:3px;overflow:hidden}
.ttp-prog-fill{height:100%;background:var(--ttp-blue);border-radius:3px;transition:width .4s ease}
/* flashcard */
.ttp-pane-flash,.ttp-srs-page{max-width:540px;margin:0 auto}
.ttp-flash-topbar,.ttp-srs-topbar{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ttp-dq-wrap{display:flex;gap:4px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}
.ttp-dq{width:9px;height:9px;border-radius:50%;border:1px solid #ccc;flex-shrink:0;transition:all .2s}
.ttp-dq.cur{background:var(--ttp-blue);border-color:var(--ttp-blue);transform:scale(1.4)}.ttp-dq.ok{background:var(--ttp-green);border-color:var(--ttp-green)}.ttp-dq.err{background:var(--ttp-red);border-color:var(--ttp-red)}.ttp-dq.done{background:#e5e7eb;border-color:#e5e7eb}
.ttp-flash-card{border:1px solid var(--ttp-border);border-radius:12px;min-height:220px;padding:28px 24px;display:flex;align-items:center;justify-content:center;cursor:pointer;text-align:center;transition:box-shadow .2s;position:relative;background:#fff;margin-bottom:12px}
.ttp-flash-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.ttp-fc-big-hanzi,.ttp-fc-hanzi-big{font-size:64px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1;margin-bottom:10px}
.ttp-fc-hint{font-size:13px;color:#9ca3af;margin-top:10px}
.ttp-hint-btn{position:absolute;bottom:10px;right:12px;font-size:11px;padding:3px 9px;background:none;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer}
.ttp-fc-back-body{display:flex;gap:12px;align-items:flex-start;text-align:left;width:100%}
.ttp-fc-example-show{padding:9px 12px;background:var(--ttp-light);border-left:2px solid var(--ttp-blue);margin-top:10px;width:100%;text-align:left;font-size:13px;color:#555;box-sizing:border-box}
.ttp-fc-level-badge{position:absolute;top:10px;right:12px}
.ttp-ease-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.ttp-ease-btn{padding:10px 6px;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);background:none;cursor:pointer;text-align:center;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:13px;font-weight:500}
.ttp-ease-btn small{font-size:10px;font-weight:normal}
.ttp-ease-btn:hover{transform:translateY(-1px)}.ttp-ease-btn:active{transform:scale(.97)}
.ttp-ease-again{border-color:#fca5a5;background:#fef2f2;color:var(--ttp-red)}.ttp-ease-hard{border-color:#fcd34d;background:#fffbeb;color:var(--ttp-yellow)}.ttp-ease-good{border-color:#6ee7b7;background:#f0fdf4;color:var(--ttp-green)}.ttp-ease-easy{border-color:#93c5fd;background:#eff6ff;color:var(--ttp-blue)}
.ttp-kb-hint{text-align:center;font-size:11px;color:#9ca3af;margin-top:6px}
kbd{padding:1px 5px;border:1px solid #e5e7eb;border-radius:3px;font-size:10px}
/* SRS */
.ttp-srs-scr{}
.ttp-user-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ttp-level-badge{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#16a34a);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex-shrink:0}
.ttp-xp-wrap{flex:1}
.ttp-xp-track{height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}
.ttp-xp-fill{height:100%;background:linear-gradient(90deg,var(--ttp-blue),var(--ttp-green));transition:width .5s}
.ttp-streak-badge{background:#fef3c7;color:#92400e;padding:5px 12px;border-radius:20px;font-weight:600;font-size:13px;flex-shrink:0}
.ttp-srs-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.ttp-stat-card{background:var(--ttp-light);border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);padding:14px;text-align:center}
.ttp-stat-card span{display:block;font-size:24px;font-weight:600;color:#1d2327;margin-bottom:3px}
.ttp-stat-card{font-size:12px;color:#646970}
.ttp-stat-danger{background:#fef2f2;border-color:#fca5a5}.ttp-stat-danger span{color:var(--ttp-red)}
.ttp-stat-info{background:#eff6ff;border-color:#93c5fd}.ttp-stat-info span{color:var(--ttp-blue)}
.ttp-stat-success{background:#f0fdf4;border-color:#86efac}.ttp-stat-success span{color:var(--ttp-green)}
.ttp-streak-card{display:flex;align-items:center;gap:12px;background:#fef3c7;border:1px solid #fcd34d;border-radius:var(--ttp-radius);padding:14px;margin-bottom:14px}
.ttp-streak-card strong{display:block;font-size:14px;color:#92400e}
.ttp-streak-card small{color:#b45309;font-size:12px}
.ttp-streak-toast{position:fixed;bottom:24px;right:24px;background:#fef3c7;border:1px solid #fcd34d;border-radius:var(--ttp-radius);padding:10px 16px;font-weight:600;color:#92400e;z-index:999;display:flex;align-items:center;gap:8px}
/* Writing */
.ttp-writing-layout{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ttp-writing-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.ttp-sec-lbl{font-size:11px;font-weight:600;color:#888;letter-spacing:.05em;margin-bottom:8px}
.ttp-char-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px}
.ttp-cg-cell{aspect-ratio:1;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;position:relative;user-select:none}
.ttp-cg-cell:hover{border-color:#9ca3af}.ttp-cg-cell.is-active{border-color:var(--ttp-blue);background:#dbeafe;border-width:2px}.ttp-cg-cell.mastered{border-color:var(--ttp-green);background:#dcfce7}.ttp-cg-cell.practiced{border-color:var(--ttp-yellow);background:#fef3c7}
.ttp-cg-char{font-size:22px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1}
.ttp-cg-stars{font-size:8px;color:#9ca3af;margin-top:2px}
.ttp-cg-dot{position:absolute;top:3px;right:3px;width:5px;height:5px;border-radius:50%}
.ttp-mode-bar{display:flex;gap:3px;background:#f3f4f6;border-radius:var(--ttp-radius);padding:3px;margin-bottom:10px;flex-wrap:wrap}
.ttp-mode-btn{flex:1;padding:5px 8px;font-size:11px;font-weight:500;border:none;background:none;cursor:pointer;border-radius:6px;color:#666;text-align:center;white-space:nowrap;transition:all .15s}
.ttp-mode-btn.is-active{background:#fff;color:#111;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.ttp-canvas-wrap{position:relative;background:#f8f8f8;border:1px solid var(--ttp-border);border-radius:12px;aspect-ratio:1;overflow:hidden;margin-bottom:10px}
.ttp-grid-svg{position:absolute;inset:0;width:100%;height:100%;opacity:.6}
#ttp-hw-canvas{position:absolute;inset:0}
.ttp-hw-mode-badge{position:absolute;top:8px;left:8px}
.ttp-hw-stroke-n{position:absolute;bottom:8px;right:10px;font-size:11px;color:#9ca3af}
.ttp-hw-info-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}
.ttp-hw-big-char{font-size:44px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1;flex-shrink:0}
.ttp-hw-controls{display:flex;gap:6px;margin-bottom:6px}
.ttp-hw-xp-row{display:flex;justify-content:space-between;padding:7px 10px;background:var(--ttp-light);border-radius:6px;font-size:12px;color:#555;margin-top:8px}
.ttp-combo-bar{display:flex;align-items:center;gap:6px;margin-top:8px;flex-wrap:wrap}
.ttp-writing-prog{margin-top:10px}
.ttp-xp-float{position:fixed;bottom:80px;right:24px;background:var(--ttp-green);color:#fff;padding:6px 14px;border-radius:20px;font-weight:600;font-size:14px;z-index:999;pointer-events:none}
/* Dialogue */
.ttp-dialogue{}
.ttp-dial-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--ttp-border)}
.ttp-turn{display:flex;gap:10px;padding:14px 0;border-bottom:1px solid #f0f0f0}
.ttp-turn:last-child{border-bottom:none}
.ttp-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;margin-top:2px}
.ttp-av-a{background:#dcfce7;color:var(--ttp-green)}.ttp-av-b{background:#dbeafe;color:var(--ttp-blue)}
.ttp-turn-body{flex:1;min-width:0}
.ttp-turn-speaker{font-size:11px;font-weight:600;color:#9ca3af;margin-bottom:5px}
.ttp-turn-zh{font-size:15px;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1.7;margin-bottom:4px}
.ttp-dial-py{font-size:12px;color:#555;margin-bottom:3px}
.ttp-dial-vi{font-size:13px;color:#888;margin-bottom:6px}
.ttp-autolink{color:var(--ttp-blue);border-bottom:1.5px dashed;text-decoration:none;cursor:pointer}
.ttp-autolink:hover{opacity:.75}
.ttp-autolink-tooltip{position:fixed;background:#fff;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);padding:12px 14px;box-shadow:0 4px 20px rgba(0,0,0,.12);min-width:180px;z-index:9999}
.ttp-tip-hanzi{font-size:28px;font-weight:600;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1;margin-bottom:4px}
.ttp-tip-py{font-size:13px;color:#555;margin-bottom:3px}
.ttp-tip-vi{font-size:13px;font-weight:500;margin-bottom:8px}
.ttp-tip-actions{display:flex;align-items:center;gap:8px}
.ttp-cloze-section{background:var(--ttp-light);border-radius:var(--ttp-radius);padding:16px;margin-top:14px}
.ttp-cloze-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.ttp-cloze-diff{display:flex;gap:4px}
.ttp-diff-btn{padding:3px 10px;border:1px solid var(--ttp-border);border-radius:20px;background:none;cursor:pointer;font-size:12px;color:#666}
.ttp-diff-btn.is-active{background:var(--ttp-blue);color:#fff;border-color:var(--ttp-blue)}
.ttp-cloze-item{background:#fff;border-radius:6px;padding:12px;margin-bottom:8px}
.ttp-cloze-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ttp-cloze-sentence{display:flex;align-items:center;gap:5px;flex-wrap:wrap;font-size:14px;font-family:"Noto Sans SC","PingFang SC",sans-serif}
.ttp-cloze-in{border:none;border-bottom:2px solid #ccc;background:transparent;font-size:14px;text-align:center;padding:2px 4px;outline:none;border-radius:0;transition:border-color .2s}
.ttp-cloze-in:focus{border-color:var(--ttp-blue)}.ttp-cloze-in.ok{border-color:var(--ttp-green);color:var(--ttp-green)}.ttp-cloze-in.err{border-color:var(--ttp-red);color:var(--ttp-red)}.ttp-cloze-in.revealed{border-color:var(--ttp-green);color:var(--ttp-green);opacity:.7}
.ttp-cloze-fb{font-size:12px;margin-top:5px}
.ttp-cloze-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}
.ttp-cloze-score{margin-left:auto;font-size:13px;color:#555}
/* Analysis */
.ttp-analysis-page{max-width:720px;margin:0 auto}
.ttp-an-search-wrap{position:relative;margin-bottom:12px}
.ttp-an-input{width:100%;box-sizing:border-box;padding:14px 48px 14px 52px;font-size:18px;border:2px solid var(--ttp-border);border-radius:12px;outline:none;transition:border-color .2s}
.ttp-an-input:focus{border-color:var(--ttp-blue)}
.ttp-an-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px;pointer-events:none}
#ttp-an-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;color:#9ca3af}
.ttp-suggest-drop{position:absolute;top:calc(100% + 5px);left:0;right:0;background:#fff;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);z-index:100;overflow:hidden;display:none}
.ttp-quick-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.ttp-quick-btn{padding:5px 14px;border:1px solid var(--ttp-border);border-radius:20px;background:none;cursor:pointer;font-size:14px;font-family:"Noto Sans SC","PingFang SC",sans-serif;transition:all .15s}
.ttp-quick-btn:hover{border-color:#9ca3af;background:var(--ttp-light)}
.ttp-an-stats{display:flex;gap:10px;margin-bottom:14px}
.ttp-an-stat{background:var(--ttp-light);border-radius:var(--ttp-radius);padding:12px 16px;text-align:center}
.ttp-an-stat span{display:block;font-size:22px;font-weight:600;color:#1d2327;margin-bottom:3px}
.ttp-an-hint{font-size:13px;color:#9ca3af}
.ttp-an-src-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.ttp-an-src-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;background:#dcfce7;color:var(--ttp-green)}
.ttp-an-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:14px}
.ttp-an-big-hanzi{font-size:72px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;line-height:1;flex-shrink:0}
.ttp-an-py{font-size:20px;margin-bottom:6px}
.ttp-an-meaning{font-size:18px;font-weight:500;margin-bottom:8px}
.ttp-an-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}
.ttp-an-det{background:var(--ttp-light);border-radius:6px;padding:10px 12px}
.ttp-an-det-lbl{font-size:11px;font-weight:600;color:#9ca3af;margin-bottom:3px}
.ttp-an-chars{display:flex;gap:8px;flex-wrap:wrap}
.ttp-an-char-item{padding:10px 14px;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);text-align:center;min-width:70px}
.ttp-an-char-ch{font-size:28px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;display:block;margin-bottom:4px}
.ttp-an-char-py,.ttp-an-char-vi{font-size:11px;color:#555;display:block;margin-bottom:2px}
.ttp-an-example{display:flex;gap:8px;align-items:flex-start;padding:10px;border:1px solid #f0f0f0;border-radius:6px;margin-bottom:8px}
.ttp-an-related{display:flex;gap:8px;flex-wrap:wrap}
.ttp-an-rel-pill{padding:8px 14px;border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);cursor:pointer;transition:all .15s}
.ttp-an-rel-pill:hover{border-color:#9ca3af;background:var(--ttp-light)}
.ttp-an-rel-ch{font-size:18px;font-weight:500;font-family:"Noto Sans SC","PingFang SC",sans-serif;margin-bottom:2px}
.ttp-an-rel-vi{font-size:11px;color:#9ca3af}
.ttp-an-section{margin-bottom:14px}
.ttp-section-ttl{font-size:13px;font-weight:600;color:#555;margin-bottom:10px;margin-top:12px}
.ttp-skeleton{padding:10px}
.ttp-sk-big,.ttp-sk-med,.ttp-sk-sm{background:#f0f0f0;border-radius:4px;margin-bottom:8px}
.ttp-sk-big{height:60px;width:40%}.ttp-sk-med{height:16px;width:60%}.ttp-sk-sm{height:14px;width:80%}
@keyframes skshimmer{0%{opacity:.4}50%{opacity:.9}100%{opacity:.4}}
.ttp-skeleton>*{animation:skshimmer 1.4s ease-in-out infinite}
/* Pinyin */
.ttp-pinyin-page{}
.ttp-py-tabs{display:flex;border-bottom:1px solid var(--ttp-border);margin-bottom:16px}
.ttp-py-tab{padding:8px 18px;border:none;background:none;border-bottom:2.5px solid transparent;cursor:pointer;font-size:13px;font-weight:500;color:#666;transition:all .15s}
.ttp-py-tab.is-active{color:#1d2327;border-bottom-color:#1d2327}
.ttp-py-sec-lbl{font-size:10px;font-weight:600;color:#9ca3af;letter-spacing:.06em;margin:10px 0 6px}
.ttp-syl-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:4px}
.ttp-syl-cell{border:1px solid var(--ttp-border);border-radius:var(--ttp-radius);background:var(--ttp-light);padding:7px 4px;text-align:center;cursor:pointer;transition:all .15s}
.ttp-syl-cell:hover,.ttp-syl-cell.is-active{border-color:var(--ttp-blue);background:#dbeafe}
.ttp-syl-main{display:block;font-size:13px;font-weight:600;margin-bottom:2px}
.ttp-syl-sub{display:block;font-size:9px;color:#9ca3af}
.ttp-init-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.ttp-init-cell{border:1px solid var(--ttp-border);border-radius:10px;background:var(--ttp-light);padding:10px 8px;text-align:center;cursor:pointer;transition:all .15s}
.ttp-init-cell:hover,.ttp-init-cell.is-active{border-color:var(--ttp-blue);background:#dbeafe}
.ttp-init-main{display:block;font-size:18px;font-weight:600;margin-bottom:3px}
.ttp-init-py{display:block;font-size:10px;color:#555;margin-bottom:3px}
.ttp-init-eg{display:block;font-size:10px;color:#9ca3af;font-family:"Noto Sans SC","PingFang SC",sans-serif}
.ttp-tone-card{padding:14px;border:1px solid var(--ttp-border);border-radius:10px;margin-bottom:10px}
.ttp-tone-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ttp-tone-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.ttp-tone-name{font-size:13px;font-weight:600}
.ttp-tone-mark{font-size:18px;font-weight:500;margin-bottom:6px}
.ttp-tone-desc{font-size:12px;color:#555;line-height:1.5;margin-bottom:8px}
.ttp-tone-words{display:flex;gap:8px;flex-wrap:wrap}
.ttp-tone-word{padding:5px 10px;border:1px solid var(--ttp-border);border-radius:6px;display:flex;flex-direction:column;gap:2px;transition:all .15s}
.ttp-tone-word:hover{background:var(--ttp-light)}
.ttp-tone-zh{font-family:"Noto Sans SC","PingFang SC",sans-serif;font-size:16px;font-weight:500}
/* XP float */
@keyframes fadeup{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(-24px)}}
/* Responsive */
@media(max-width:640px){
  .ttp-writing-layout{grid-template-columns:1fr}
  .ttp-an-header{flex-direction:column}.ttp-an-big-hanzi{font-size:48px}
  .ttp-an-detail-grid{grid-template-columns:1fr}
  .ttp-char-grid{grid-template-columns:repeat(5,1fr)}
  .ttp-ease-grid{grid-template-columns:repeat(2,1fr)}
  .ttp-pack-header{flex-direction:column}
  .ttp-srs-stat-grid{grid-template-columns:repeat(3,1fr)}
}
