:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}}.worksheet-page-root{min-height:100vh;padding:24px 16px;background:linear-gradient(180deg,#fff,#f1f5f9);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.site-header{width:100%;max-width:920px;box-sizing:border-box}.page-header{margin-bottom:10px;padding:12px 14px;border-radius:14px;background:#ffffffe0;box-shadow:0 8px 20px #0f172a24}.site-header-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.08em;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe}.site-header-title{margin:8px 0 2px;font-size:20px;line-height:1.2;color:#0f172a}.site-header-desc{margin:0;color:#64748b;font-size:13px}.home-root{min-height:100vh;padding:28px 14px;background:radial-gradient(circle at 0% 0%,#e0e7ff 0,transparent 35%),radial-gradient(circle at 100% 10%,#fce7f3 0,transparent 30%),linear-gradient(160deg,#f8fafc,#e2e8f0);display:flex;justify-content:center;box-sizing:border-box}.home-card{max-width:980px;width:100%;padding:22px;border-radius:24px;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 20px 50px #0f172a26,inset 0 0 0 1px #ffffffa6;color:#0f172a}.home-header{margin-bottom:16px;padding:10px 8px}.home-title{margin:10px 0 6px;font-size:clamp(28px,4vw,38px);font-weight:900;letter-spacing:.01em;color:#0f172a}.home-subtitle{margin:0;font-size:15px;color:#475569}.home-meta-row{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}.home-meta-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:600;border:1px solid #c7d2fe}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.home-item{text-decoration:none;padding:12px;border-radius:14px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;display:flex;flex-direction:column;gap:6px;min-height:140px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.home-item-top{display:flex;align-items:center;justify-content:space-between}.home-item-icon{font-size:18px}.home-item-tag{font-size:12px;font-weight:600;color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;padding:2px 8px}.home-item.worksheet{border-color:#a7f3d0}.home-item.name-practice{border-color:#fde68a}.home-item.xhs-cover{border-color:#fbcfe8}.home-item.nine-grid{border-color:#bae6fd}.preview-image-container{padding:16px 12px 24px;display:flex;justify-content:center;align-items:flex-start}.preview-image{max-width:100%;max-height:80vh;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a;background:#fff}.preview-empty{width:100%;padding:60px 20px;text-align:center;color:#666;font-size:16px}.home-item:hover{transform:translateY(-3px);box-shadow:0 16px 30px #0f172a1f}.home-item-title{font-size:20px;font-weight:800;line-height:1.25}.home-item-desc{font-size:14px;color:#475569;line-height:1.55;flex:1}.home-item-cta{font-size:13px;font-weight:700;color:#2563eb}.subpage-root{padding-top:74px!important}.subpage-nav{position:fixed;top:0;left:0;right:0;z-index:50;width:100%;min-height:56px;background:#fffffff5;box-shadow:0 8px 22px #0f172a1a;margin:0}.subpage-nav-inner{width:100%;max-width:920px;margin:0 auto;min-height:56px;padding:6px 10px;box-sizing:border-box;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}.subpage-nav-back{justify-self:start;height:32px;padding:0 10px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:500;color:#344054;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.subpage-nav-title{margin:0;font-size:16px;font-weight:700;text-align:center;color:#0f172a}.subpage-nav-action{justify-self:end;height:32px;padding:0 12px;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,#1677ff,#0f5bd9);cursor:pointer}.subpage-nav-action:disabled{opacity:.58;cursor:not-allowed}.subpage-nav-action-placeholder{justify-self:end;width:66px;height:1px}.subpage-nav-desc{width:100%;max-width:920px;margin:0 0 10px;font-size:13px;color:#64748b}.page-toast{width:100%;max-width:920px;margin:0 0 10px;padding:8px 12px;border-radius:10px;background:#16a34a24;border:1px solid rgba(22,163,74,.35);color:#166534;font-size:13px;font-weight:600;box-sizing:border-box}@media(max-width:600px){.subpage-root{padding-top:70px!important}.subpage-nav-inner{grid-template-columns:auto 1fr auto;padding:6px 8px}.subpage-nav-title{font-size:15px}.subpage-nav-action{padding:0 10px}.page-header{padding:10px 12px;border-radius:12px}.site-header-title{font-size:17px}.site-header-desc{font-size:12px}.home-card{padding:16px;border-radius:18px}.home-title{font-size:28px}.home-item{min-height:170px}}.ws-link{font-size:14px;color:#1d4ed8}.worksheet-a4{width:794px;height:1123px;background:#fff;box-shadow:0 18px 40px #0f172a66,0 0 0 1px #94a3b899;border-radius:8px;padding:32px 40px;box-sizing:border-box;color:#0f172a;aspect-ratio:210 / 297;container-type:inline-size}.worksheet-config-panel{width:100%;max-width:920px;margin-bottom:16px;padding:10px 14px;border-radius:999px;background:#ffffffe6;box-shadow:0 10px 25px #0f172a40,0 0 0 1px #94a3b866;display:flex;justify-content:space-between;align-items:center;gap:16px;box-sizing:border-box}.worksheet-header{border-bottom:1px solid #e5e7eb;padding-bottom:10px;margin-bottom:12px}.worksheet-title{margin:0 0 12px;font-size:22px;text-align:center;letter-spacing:.1em}.worksheet-meta-row{display:flex;justify-content:space-between;gap:24px;font-size:14px}.worksheet-field{display:flex;align-items:center;gap:6px;flex:1}.worksheet-input-line{border-bottom:1.5px solid #94a3b8;flex:1;height:20px}.worksheet-input-line.short{max-width:96px}.worksheet-input-line.medium{max-width:140px}.worksheet-config-row{margin-top:10px;padding-top:8px;border-top:1px dashed #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:16px}.worksheet-config-group{display:flex;flex-wrap:wrap;gap:12px}.worksheet-config-label{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:#475569}.worksheet-config-input{width:72px;padding:2px 6px;border-radius:6px;border:1px solid #cbd5e1;font-size:13px;font-family:inherit}.worksheet-generate-btn{border-radius:999px;border:none;padding:4px 12px;font-size:13px;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#60a5fa,#2563eb);color:#f9fafb;box-shadow:0 8px 18px #2563eb66,0 0 0 1px #bfdbfee6}@media(max-width:600px){.worksheet-config-panel{flex-direction:column;align-items:stretch;border-radius:18px}.worksheet-config-group{width:100%}.worksheet-generate-btn{align-self:flex-end}}.worksheet-body{padding-top:8px}.worksheet-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:48px;row-gap:28px;font-size:22px}.worksheet-problem{display:flex;align-items:center;gap:2px}.ws-num{min-width:24px;text-align:center}.ws-op,.ws-eq{min-width:22px;text-align:center}.ws-answer-line{width:38px;height:38px;border:1.5px solid #94a3b8;border-radius:4px}@media(max-width:900px){.worksheet-a4{width:100%;height:auto;aspect-ratio:210 / 297;padding:24px 20px;transform-origin:top center}.worksheet-grid{grid-template-columns:repeat(2,minmax(0,1fr));column-gap:24px;row-gap:18px;font-size:18px}.ws-answer-line{width:32px;height:32px}}.name-practice-page-root{min-height:100vh;padding:24px 16px;background:radial-gradient(circle at top,#e5e7eb 0,#cbd5f5 40%,#94a3b8);display:flex;flex-direction:column;align-items:center;box-sizing:border-box;width:100%;max-width:100%;overflow-x:hidden}.name-practice-config-panel{width:100%;max-width:920px;margin-bottom:16px;padding:10px 14px;border-radius:999px;background:#ffffffe6;box-shadow:0 10px 25px #0f172a40,0 0 0 1px #94a3b866;display:flex;justify-content:space-between;align-items:center;gap:16px;box-sizing:border-box;overflow-x:auto}.name-practice-config-group{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.name-practice-input{width:120px;padding:4px 8px;border-radius:6px;border:1px solid #cbd5e1;font-size:14px;font-family:inherit}.name-practice-display-name{text-align:center;font-size:16px;color:#475569;margin-top:8px}.name-highlight{font-size:18px;font-weight:700;color:#1e40af}.name-practice-body{padding-top:16px;flex:1;display:flex;flex-direction:column;justify-content:flex-start;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.name-practice-empty{text-align:center;color:#94a3b8;padding:40px 20px;font-size:15px}.name-practice-grid{display:grid;grid-template-columns:repeat(var(--cols, 4),1fr);gap:8px;width:100%;max-width:100%;padding:8px 0;box-sizing:border-box}.tianzige-cell{position:relative;width:100%;aspect-ratio:1;border:1.5px solid #94a3b8;box-sizing:border-box;display:flex;align-items:center;justify-content:center;background:#fff;container-type:size}.tianzige-grid{position:absolute;inset:0;pointer-events:none}.tianzige-horizontal{position:absolute;left:0;right:0;top:50%;height:1px;background-image:url("data:image/svg+xml,%3Csvg width='6' height='1' xmlns='http://www.w3.org/2000/svg'%3E%3Cline x1='0' y1='0.5' x2='3' y2='0.5' stroke='%23e2e8f0' stroke-width='1'/%3E%3C/svg%3E");background-repeat:repeat-x;transform:translateY(-50%)}.tianzige-vertical{position:absolute;top:0;bottom:0;left:50%;width:1px;background-image:url("data:image/svg+xml,%3Csvg width='1' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cline x1='0.5' y1='0' x2='0.5' y2='3' stroke='%23e2e8f0' stroke-width='1'/%3E%3C/svg%3E");background-repeat:repeat-y;transform:translate(-50%)}.tianzige-char{position:relative;z-index:1;font-size:80cqw;font-weight:500;color:#cbd5e1;font-family:KaiTi,楷体,STKaiti,STKaiTi,serif;line-height:1;-webkit-user-select:none;user-select:none}@media(max-width:900px){.worksheet-a4{width:100%;max-width:100%;height:auto;aspect-ratio:210 / 297;padding:calc(32px*min(1,100vw / 794px)) calc(40px*min(1,100vw / 794px));transform-origin:top center;box-sizing:border-box;overflow-x:hidden}.name-practice-grid{gap:calc(8px*min(1,100vw / 794px));max-width:100%;box-sizing:border-box}.tianzige-char{font-size:80cqw}.name-practice-display-name{font-size:calc(16px*min(1,100vw / 794px))}.name-highlight{font-size:calc(18px*min(1,100vw / 794px))}.worksheet-header{padding-bottom:calc(10px*min(1,100vw / 794px));margin-bottom:calc(12px*min(1,100vw / 794px))}.worksheet-title{font-size:calc(22px*min(1,100vw / 794px));margin-bottom:calc(12px*min(1,100vw / 794px))}}@media(max-width:600px){.name-practice-page-root{padding:12px 8px}.name-practice-config-panel{flex-direction:column;align-items:stretch;border-radius:18px;padding:12px 16px;margin-bottom:12px}.name-practice-config-group{width:100%;flex-direction:column;align-items:stretch;gap:10px}.name-practice-config-group .worksheet-config-label{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:14px}.name-practice-input{width:100%;max-width:200px;padding:6px 10px;font-size:15px}.worksheet-config-input{width:100%;max-width:100px;padding:6px 10px;font-size:15px}.worksheet-a4{padding:calc(24px*min(1,100vw / 794px)) calc(20px*min(1,100vw / 794px))}.name-practice-grid{gap:calc(4px*min(1,100vw / 794px));padding:calc(4px*min(1,100vw / 794px)) 0;max-width:100%;box-sizing:border-box}.tianzige-cell{border-width:calc(1px*min(1,100vw / 794px));border-color:#94a3b8;min-height:calc(60px*min(1,100vw / 794px))}.tianzige-char{font-size:80cqw}.name-practice-empty{padding:30px 16px;font-size:14px}.worksheet-header{padding-bottom:8px;margin-bottom:10px}.worksheet-title{font-size:18px;margin-bottom:8px}.name-practice-display-name{font-size:13px;margin-top:6px}.name-highlight{font-size:15px}}.xhs-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#fce7f3 0,#dbeafe 42%,#bfdbfe);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.xhs-config-panel{width:100%;max-width:920px;margin-bottom:16px;padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e}.xhs-mobile-tip{font-size:12px;color:#64748b;margin-bottom:8px}.xhs-config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.xhs-input{margin-top:4px;width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;box-sizing:border-box}.xhs-actions-row{margin-top:10px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.xhs-clear-btn{border-radius:999px;border:1px solid #fda4af;background:#fff1f2;color:#be123c;padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer}.xhs-ideas{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.xhs-idea-chip{border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#334155;padding:5px 12px;font-size:12px;cursor:pointer}.xhs-idea-chip:hover{background:#e2e8f0}.xhs-preview-wrap{width:100%;max-width:920px;display:flex;justify-content:center}.xhs-card{width:min(100%,432px);aspect-ratio:3 / 4;border-radius:20px;position:relative;overflow:hidden;box-shadow:0 24px 50px #0f172a59;color:#fff;padding:22px;box-sizing:border-box}.xhs-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 20%,rgba(255,255,255,.25),transparent 38%);pointer-events:none}.xhs-tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;background:#ffffff38;border:1px solid rgba(255,255,255,.45);padding:5px 10px;border-radius:999px}.xhs-center{position:absolute;left:22px;right:22px;top:44%;transform:translateY(-50%)}.xhs-title{font-size:clamp(28px,6.2vw,54px);line-height:1.1;font-weight:900;margin-bottom:10px;text-shadow:0 6px 18px rgba(15,23,42,.35)}.xhs-subtitle{font-size:clamp(14px,2.5vw,22px);opacity:.95;font-weight:600;text-shadow:0 4px 12px rgba(15,23,42,.28)}.xhs-footer{position:absolute;left:22px;bottom:20px;display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700}.xhs-dot{width:10px;height:10px;border-radius:50%}@media(max-width:768px){.xhs-root{padding:12px 8px}.xhs-config-panel{padding:12px;border-radius:14px}.xhs-config-grid{grid-template-columns:1fr}.xhs-actions-row{position:sticky;top:0;z-index:2;background:#fffffff2;padding:6px 0}.xhs-ideas{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.xhs-idea-chip{white-space:nowrap;flex:0 0 auto}.xhs-card{width:min(100%,420px);border-radius:16px}}.nine-grid-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#e0e7ff 0,#dbeafe 42%,#bfdbfe);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.nine-grid-panel{width:100%;max-width:920px;display:grid;grid-template-columns:minmax(260px,340px) 1fr;gap:14px}.nine-grid-controls{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:10px}.nine-grid-preview-card{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;align-items:center;gap:10px}.nine-grid-preview{position:relative;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:14px;box-shadow:inset 0 0 0 1px #94a3b880;background:#f8fafc}.nine-grid-cell{position:absolute;overflow:hidden;border-radius:8px}.nine-grid-image{position:absolute;max-width:none;pointer-events:none}.nine-grid-empty{width:100%;min-height:320px;border:1px dashed #94a3b8;border-radius:12px;display:grid;place-items:center;color:#64748b;font-size:14px}.nine-grid-tip{font-size:12px;color:#64748b}.nine-grid-color-input{height:38px;padding:4px}@media(max-width:860px){.nine-grid-panel{grid-template-columns:1fr}}.preview-page-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#dbeafe 0,#eff6ff 42%,#f8fafc);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.preview-page-panel{width:100%;max-width:920px}.preview-tip{margin:0 0 12px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#ffffffeb;font-size:14px;font-weight:600;color:#334155}.preview-image-card{margin:0 0 14px;padding:10px;border-radius:14px;border:1px solid #e2e8f0;background:#fff}.preview-image-card.single{padding:0;overflow:hidden}.preview-image-title{margin:0 0 8px;font-size:14px;color:#64748b}.preview-image{display:block;width:100%;height:auto}.preview-empty{padding:28px 18px;border-radius:14px;border:1px dashed #94a3b8;color:#64748b;text-align:center;background:#ffffffd9}.handwriting-page-root{min-height:100vh;padding:24px 16px;background:radial-gradient(circle at top,#fef3c7 0,#fde68a 40%,#fcd34d);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.handwriting-config-panel{width:100%;max-width:920px;margin-bottom:16px;padding:12px 16px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:12px}.handwriting-config-group{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.handwriting-config-label{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#475569}.handwriting-select{padding:6px 10px;border-radius:8px;border:1px solid #cbd5e1;font-size:14px;font-family:inherit;background:#fff;min-width:120px}.handwriting-range{width:100px;cursor:pointer}.handwriting-range-value{min-width:48px;font-size:13px;color:#64748b;font-weight:500}.handwriting-colors{display:flex;gap:6px}.handwriting-color-btn{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.handwriting-color-btn:hover{transform:scale(1.1)}.handwriting-color-btn.active{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.handwriting-textarea{width:100%;max-width:920px;margin-bottom:16px;padding:12px 14px;border-radius:12px;border:1px solid #cbd5e1;font-size:15px;font-family:inherit;resize:vertical;min-height:100px;box-sizing:border-box;background:#fffffff2}.handwriting-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.handwriting-preview{width:100%;max-width:920px;min-height:200px;padding:40px 32px;border-radius:12px;background:var(--bg-color);box-shadow:0 4px 12px #00000014;font-family:var(--font-family);font-size:var(--font-size);line-height:var(--line-height);color:#1e293b;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.handwriting-line{margin-bottom:calc(var(--line-height) * 1em - 1em);white-space:pre-wrap;word-break:break-word;text-align:center}.handwriting-placeholder{color:#94a3b8;text-align:center;padding:40px;font-family:system-ui,sans-serif;font-size:14px}.home-item.handwriting{border-color:#fde68a}@media(max-width:600px){.handwriting-page-root{padding:16px 12px}.handwriting-config-panel{padding:12px;border-radius:14px}.handwriting-config-group{flex-direction:column;align-items:stretch;gap:12px}.handwriting-config-label{width:100%;justify-content:space-between}.handwriting-select{width:100%;max-width:200px}.handwriting-range{flex:1}.handwriting-textarea{padding:10px 12px;font-size:14px}.handwriting-preview{padding:20px 16px}}.bg-remover-page-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#e0f2fe 0,#bae6fd 42%,#7dd3fc);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.bg-remover-upload-area{width:100%;max-width:920px;margin-top:16px}.bg-remover-upload-card{padding:60px 20px;border-radius:20px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;align-items:center;gap:12px}.bg-remover-upload-icon{font-size:48px}.bg-remover-upload-text{font-size:18px;font-weight:700;color:#0f172a}.bg-remover-upload-hint{font-size:14px;color:#64748b}.bg-remover-upload-btn{margin-top:8px;padding:10px 24px;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.bg-remover-upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 18px #2563eb66}.bg-remover-content{width:100%;max-width:920px;display:flex;flex-direction:column;gap:20px}.bg-remover-preview-section{display:flex;flex-direction:column;gap:8px}.bg-remover-preview-label{font-size:14px;font-weight:600;color:#334155}.bg-remover-preview-card{padding:12px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;justify-content:center;align-items:center;min-height:200px}.bg-remover-preview-image{max-width:100%;max-height:400px;width:auto;height:auto;border-radius:8px}.bg-remover-canvas{max-width:100%;max-height:400px;border-radius:8px}.bg-remover-reupload-btn{align-self:center;padding:8px 16px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;color:#475569;font-size:14px;font-weight:500;cursor:pointer}.bg-remover-action-section{display:flex;justify-content:center}.bg-remover-process-btn{padding:12px 32px;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 8px 18px #2563eb66;transition:transform .15s ease}.bg-remover-process-btn:hover{transform:translateY(-2px)}.bg-remover-color-picker{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:10px}.bg-remover-color-label{font-size:14px;font-weight:600;color:#334155}.bg-remover-color-options{display:flex;gap:10px;flex-wrap:wrap}.bg-remover-color-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;border:2px solid #e2e8f0;background:#fff;color:#475569;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.bg-remover-color-btn.active{border-color:#3b82f6;background:#eff6ff;color:#1e40af}.bg-remover-color-swatch{width:20px;height:20px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.bg-remover-color-swatch.white{background:#fff}.bg-remover-color-swatch.blue{background:#3b82f6}.bg-remover-color-swatch.red{background:#ef4444}.bg-remover-loading{padding:40px;display:flex;flex-direction:column;align-items:center;gap:12px}.bg-remover-loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.bg-remover-loading-text{font-size:15px;font-weight:600;color:#0f172a}.bg-remover-loading-hint{font-size:13px;color:#64748b;text-align:center}.bg-remover-progress{width:100%;max-width:920px;margin-bottom:12px;padding:10px 14px;border-radius:12px;background:#3b82f624;border:1px solid rgba(59,130,246,.35);color:#1e40af;font-size:14px;font-weight:600;box-sizing:border-box}.bg-remover-progress-text{text-align:center}.home-item.bg-remover{border-color:#bae6fd}.bg-remover-preview-info{margin:0 0 14px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#ffffffeb;font-size:14px;font-weight:600;color:#334155;text-align:center}.bg-remover-color-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:600}.bg-remover-color-badge.white{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.bg-remover-color-badge.blue{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.bg-remover-color-badge.red{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}@media(max-width:600px){.bg-remover-page-root{padding:12px 8px}.bg-remover-upload-card{padding:40px 16px;border-radius:16px}.bg-remover-preview-card{padding:8px;border-radius:12px;min-height:150px}.bg-remover-color-options{flex-direction:column}.bg-remover-color-btn{width:100%;justify-content:center}}.qrcode-page-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#e0e7ff 0,#dbeafe 42%,#bfdbfe);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.qrcode-config-panel{width:100%;max-width:920px;margin-bottom:16px;padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:14px}.qrcode-input-group{display:flex;flex-direction:column;gap:6px}.qrcode-label{font-size:14px;font-weight:600;color:#334155}.qrcode-textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;box-sizing:border-box;background:#fff}.qrcode-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.qrcode-colors{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.qrcode-color-group{display:flex;flex-direction:column;gap:6px}.qrcode-color-row{display:flex;align-items:center;gap:10px}.qrcode-color-input{width:44px;height:38px;padding:2px;border-radius:8px;border:1px solid #cbd5e1;cursor:pointer;background:#fff}.qrcode-color-text{flex:1;padding:8px 10px;border-radius:8px;border:1px solid #cbd5e1;font-size:14px;font-family:monospace;background:#fff}.qrcode-color-text:focus{outline:none;border-color:#3b82f6}.qrcode-size-group{display:flex;flex-direction:column;gap:8px}.qrcode-size-slider{width:100%;cursor:pointer;accent-color:#3b82f6}.qrcode-size-range{display:flex;justify-content:space-between;font-size:12px;color:#64748b}.qrcode-preview-section{width:100%;max-width:920px;display:flex;justify-content:center}.qrcode-preview-card{padding:20px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;justify-content:center;align-items:center;min-width:200px;min-height:200px}.qrcode-preview-image{border-radius:8px;box-shadow:0 4px 12px #0000001a}.qrcode-empty{padding:60px 40px;border-radius:16px;border:1px dashed #94a3b8;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;gap:12px}.qrcode-empty-icon{font-size:48px;opacity:.6}.qrcode-empty-text{font-size:15px;color:#64748b}.qrcode-loading{font-size:14px;color:#64748b;display:flex;align-items:center;gap:8px}.qrcode-loading:after{content:"";width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.qrcode-preview-info{margin:14px 0;padding:12px 14px;border-radius:12px;border:1px solid #e2e8f0;background:#ffffffeb;font-size:14px;color:#334155;line-height:1.6}.home-item.qrcode{border-color:#c4b5fd}@media(max-width:600px){.qrcode-page-root{padding:12px 8px}.qrcode-config-panel{padding:12px;border-radius:14px;gap:12px}.qrcode-colors{grid-template-columns:1fr}.qrcode-preview-card{padding:16px;border-radius:14px}.qrcode-empty{padding:40px 20px}.qrcode-empty-icon{font-size:36px}.qrcode-empty-text{font-size:13px}}.textimage-root{min-height:100vh;padding:20px 14px;background:linear-gradient(180deg,#f8fafc,#e2e8f0);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.textimage-preview-wrap{width:100%;max-width:920px;margin-bottom:16px;display:flex;justify-content:center}.textimage-card{width:100%;max-width:600px;min-height:300px;border-radius:16px;box-shadow:0 10px 30px #00000026;display:flex;flex-direction:column;align-items:center;justify-content:center;box-sizing:border-box}.textimage-card-content{text-align:center;width:100%}.textimage-title{margin:0 0 16px;font-size:32px;font-weight:700;line-height:1.3}.textimage-content{margin:0;font-size:18px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.textimage-config-panel{width:100%;max-width:920px;display:flex;flex-direction:column;gap:16px}.textimage-config-section{padding:14px;border-radius:14px;background:#ffffffeb;box-shadow:0 4px 12px #0f172a14}.textimage-config-title{margin:0 0 12px;font-size:15px;font-weight:700;color:#0f172a}.textimage-config-label{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-size:14px;font-weight:600;color:#334155}.textimage-config-label:last-child{margin-bottom:0}.textimage-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;background:#fff;box-sizing:border-box}.textimage-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.textimage-textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;background:#fff;box-sizing:border-box}.textimage-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.textimage-bg-grid{display:flex;flex-wrap:wrap;gap:8px}.textimage-bg-chip{padding:8px 14px;border-radius:999px;border:2px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.textimage-bg-chip:hover{transform:translateY(-2px);box-shadow:0 4px 10px #00000026}.textimage-bg-chip.active{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640}.textimage-font-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.textimage-font-chip{padding:10px 14px;border-radius:10px;border:2px solid #e2e8f0;background:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease}.textimage-font-chip:hover{border-color:#cbd5e1;background:#f8fafc}.textimage-font-chip.active{border-color:#3b82f6;background:#eff6ff;color:#1e40af}.textimage-range{width:100%;cursor:pointer;accent-color:#3b82f6}.home-item.text-image{border-color:#c4b5fd}@media(max-width:600px){.textimage-root{padding:12px 8px}.textimage-card{min-height:200px}.textimage-title{font-size:24px}.textimage-content{font-size:15px}.textimage-config-section{padding:12px;border-radius:12px}.textimage-bg-grid{flex-direction:column}.textimage-bg-chip{width:100%;justify-content:center}.textimage-font-grid{grid-template-columns:repeat(2,1fr)}}.image-border-page-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#e0f2fe 0,#bae6fd 42%,#7dd3fc);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.image-border-upload-area{width:100%;max-width:920px;margin-top:16px}.image-border-upload-card{padding:60px 20px;border-radius:20px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;align-items:center;gap:12px}.image-border-upload-icon{font-size:48px}.image-border-upload-text{font-size:18px;font-weight:700;color:#0f172a}.image-border-upload-hint{font-size:14px;color:#64748b}.image-border-upload-btn{margin-top:8px;padding:10px 24px;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.image-border-upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 18px #2563eb66}.image-border-content{width:100%;max-width:920px;display:flex;flex-direction:column;gap:20px}.image-border-preview-section{display:flex;flex-direction:column;gap:8px}.image-border-preview-card{padding:12px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;justify-content:center;align-items:center;min-height:200px}.image-border-preview-image{max-width:100%;max-height:60vh;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a}.image-border-preview-loading{padding:40px;color:#64748b;font-size:14px}.image-border-reupload-btn{align-self:center;padding:8px 16px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;color:#475569;font-size:14px;font-weight:500;cursor:pointer}.image-border-config-section{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:16px}.image-border-config-group{display:flex;flex-direction:column;gap:8px}.image-border-config-label{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#334155}.image-border-config-value{font-size:13px;font-weight:500;color:#64748b}.image-border-range{width:100%;cursor:pointer;accent-color:#3b82f6}.image-border-color-grid{display:flex;flex-wrap:wrap;gap:8px}.image-border-color-btn{width:36px;height:36px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.image-border-color-btn:hover{transform:scale(1.1)}.image-border-color-btn.active{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.image-border-color-custom{position:relative;width:36px;height:36px}.image-border-color-input{width:100%;height:100%;border:none;border-radius:8px;cursor:pointer;padding:0;background:transparent}.image-border-color-preview{position:absolute;inset:0;border-radius:8px;border:2px solid #3b82f6;pointer-events:none}.image-border-ratio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.image-border-ratio-btn{padding:10px 12px;border-radius:8px;border:2px solid #e2e8f0;background:#fff;color:#475569;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease}.image-border-ratio-btn:hover{border-color:#cbd5e1;background:#f8fafc}.image-border-ratio-btn.active{border-color:#3b82f6;background:#eff6ff;color:#1e40af}.image-border-preview-info{margin:0 0 14px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#ffffffeb;font-size:14px;font-weight:600;color:#334155}.image-border-preview-row{display:flex;align-items:center;gap:8px;padding:4px 0}.image-border-preview-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.home-item.image-border{border-color:#bae6fd}@media(max-width:600px){.image-border-page-root{padding:12px 8px}.image-border-upload-card{padding:40px 16px;border-radius:16px}.image-border-preview-card{padding:8px;border-radius:12px;min-height:150px}.image-border-config-section{padding:12px;border-radius:14px;gap:14px}.image-border-ratio-grid{grid-template-columns:repeat(4,1fr);gap:6px}.image-border-ratio-btn{padding:8px 10px;font-size:13px}.image-border-color-grid{gap:6px}.image-border-color-btn{width:32px;height:32px}}.tictactoe-page-root{padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:16px}.tictactoe-mode-select{display:flex;gap:12px;margin-bottom:8px}.tictactoe-mode-btn{padding:8px 20px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;transition:all .16s ease}.tictactoe-mode-btn.active{border-color:#1677ff;background:#1677ff;color:#fff}.tictactoe-status{font-size:18px;font-weight:700;color:#0f172a;padding:12px 24px;border-radius:12px;background:#f1f5f9}.tictactoe-status.game-over{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.tictactoe-board{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:16px;background:#f8fafc;box-shadow:0 4px 16px #00000014}.tictactoe-row{display:flex;gap:8px}.tictactoe-square{width:72px;height:72px;border:none;border-radius:12px;background:#fff;font-size:32px;font-weight:800;cursor:pointer;transition:all .12s ease;box-shadow:0 2px 8px #0000000f}.tictactoe-square:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.tictactoe-square.X{color:#1677ff;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.tictactoe-square.O{color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.tictactoe-square:disabled{cursor:not-allowed;opacity:.9}.tictactoe-reset-btn{margin-top:8px;padding:12px 32px;border:none;border-radius:12px;background:linear-gradient(135deg,#1677ff,#0f5bd9);color:#fff;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #1677ff4d}.tictactoe-reset-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #1677ff66}.tictactoe-rules{margin-top:16px;padding:16px;border-radius:12px;background:#f8fafc;max-width:300px}.tictactoe-rules p{margin:0 0 8px;font-size:14px;font-weight:600;color:#0f172a}.tictactoe-rules ul{margin:0;padding-left:20px;font-size:13px;color:#64748b;line-height:1.8}@media(max-width:480px){.tictactoe-square{width:60px;height:60px;font-size:26px}}.home-footer{margin-top:24px;padding-top:16px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;align-items:center;gap:4px}.home-version{font-size:12px;font-weight:600;color:#94a3b8}.home-build-time{font-size:11px;color:#cbd5e1}.home-category{margin-bottom:24px}.home-category-title{margin:0 0 12px;font-size:16px;font-weight:700;color:#0f172a;padding-left:4px}.home-category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:480px){.home-category-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.home-category-grid{grid-template-columns:repeat(4,1fr)}}.game2048-page-root{padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:16px}.game2048-score-row{display:flex;gap:16px;width:100%;max-width:340px}.game2048-score{flex:1;background:#bbada0;border-radius:8px;padding:8px 16px;display:flex;flex-direction:column;align-items:center}.game2048-score-label{font-size:11px;font-weight:600;color:#eee4da;text-transform:uppercase}.game2048-score-value{font-size:20px;font-weight:700;color:#fff}.game2048-board{background:#bbada0;border-radius:12px;padding:12px;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.game2048-grid{display:flex;flex-direction:column;gap:10px}.game2048-row{display:flex;gap:10px}.game2048-cell{width:64px;height:64px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;background:#eee4da59;color:#776e65;transition:all .1s ease}.game2048-cell.tile-2{background:#eee4da}.game2048-cell.tile-4{background:#ede0c8}.game2048-cell.tile-8{background:#f2b179;color:#f9f6f2}.game2048-cell.tile-16{background:#f59563;color:#f9f6f2}.game2048-cell.tile-32{background:#f67c5f;color:#f9f6f2}.game2048-cell.tile-64{background:#f65e3b;color:#f9f6f2}.game2048-cell.tile-128{background:#edcf72;color:#f9f6f2;font-size:20px}.game2048-cell.tile-256{background:#edcc61;color:#f9f6f2;font-size:20px}.game2048-cell.tile-512{background:#edc850;color:#f9f6f2;font-size:20px}.game2048-cell.tile-1024{background:#edc53f;color:#f9f6f2;font-size:16px}.game2048-cell.tile-2048{background:#edc22e;color:#f9f6f2;font-size:16px}.game2048-cell.tile-super{background:#3c3a32;color:#f9f6f2;font-size:16px}.game2048-hint{font-size:13px;color:#8f7a66;margin:0}.game2048-reset-btn{padding:12px 32px;border:none;border-radius:8px;background:#8f7a66;color:#fff;font-size:15px;font-weight:600;cursor:pointer}.game2048-overlay{position:fixed;inset:0;background:#eee4dacc;display:flex;align-items:center;justify-content:center;z-index:100}.game2048-overlay-content{background:#fff;border-radius:12px;padding:24px 32px;text-align:center;box-shadow:0 8px 32px #0003}.game2048-overlay-content h2{margin:0 0 12px;font-size:24px;color:#776e65}.game2048-overlay-content p{margin:0 0 16px;font-size:16px;color:#8f7a66}@media(max-width:400px){.game2048-cell{width:56px;height:56px;font-size:20px}}.whackamole-page-root{padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:20px}.whackamole-header{display:flex;gap:24px}.whackamole-score,.whackamole-time,.whackamole-best{display:flex;flex-direction:column;align-items:center;background:#4a5568;padding:12px 20px;border-radius:12px}.whackamole-label{font-size:12px;color:#a0aec0;text-transform:uppercase}.whackamole-value{font-size:24px;font-weight:700;color:#fff}.whackamole-value.time-warning{color:#fc8181;animation:time-pulse .5s ease-in-out infinite}@keyframes time-pulse{0%,to{opacity:1}50%{opacity:.5}}.whackamole-board{display:grid;grid-template-columns:repeat(3,90px);grid-template-rows:repeat(3,90px);gap:12px;background:#744210;padding:16px;border-radius:16px;box-shadow:inset 0 4px 12px #0000004d}.whackamole-hole{position:relative;background:#5c3d2e;border-radius:50%;border:none;cursor:pointer;overflow:hidden;box-shadow:inset 0 4px 8px #0006;transition:transform .1s}.whackamole-hole:active{transform:scale(.95)}.whackamole-mole{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:48px;transition:transform .15s ease-out;transform:translateY(100%)}.whackamole-hole.has-mole .whackamole-mole{transform:translateY(0)}.whackamole-start-btn{padding:16px 48px;font-size:18px;font-weight:700;color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 12px #48bb7866;transition:transform .2s,box-shadow .2s}.whackamole-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #48bb7880}.whackamole-result{text-align:center;background:#fff;padding:24px 32px;border-radius:16px;box-shadow:0 8px 32px #0003}.whackamole-result h2{margin:0 0 12px;font-size:24px;color:#2d3748}.whackamole-result p{margin:0 0 20px;font-size:18px;color:#718096}.whackamole-hint{font-size:14px;color:#a0aec0;margin:0}@media(max-width:400px){.whackamole-board{grid-template-columns:repeat(3,72px);grid-template-rows:repeat(3,72px)}.whackamole-mole{font-size:36px}}.notfound-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.notfound-content{text-align:center;color:#fff}.notfound-emoji{font-size:80px;font-weight:800;margin-bottom:16px;text-shadow:0 4px 20px rgba(0,0,0,.2)}.notfound-content h1{margin:0 0 12px;font-size:28px}.notfound-content p{margin:0 0 24px;font-size:16px;opacity:.8}.notfound-btn{display:inline-block;padding:14px 36px;background:#fff;color:#667eea;font-size:16px;font-weight:600;border-radius:12px;text-decoration:none;box-shadow:0 4px 16px #0003;transition:transform .2s,box-shadow .2s}.notfound-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.mathquiz-page-root{padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:20px}.mathquiz-card{background:#fff;border-radius:16px;padding:20px;width:100%;max-width:340px;box-shadow:0 2px 12px #00000014}.mathquiz-card h2{margin:0 0 16px;font-size:16px;font-weight:600;color:#374151}.mathquiz-grade-row,.mathquiz-count-row{display:flex;gap:12px;flex-wrap:wrap}.mathquiz-grade-btn,.mathquiz-count-btn{flex:1;min-width:80px;padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s}.mathquiz-grade-btn.active,.mathquiz-count-btn.active{border-color:#1677ff;background:#1677ff;color:#fff}.mathquiz-start-btn{width:100%;max-width:340px;padding:16px;border:none;border-radius:16px;background:linear-gradient(135deg,#1677ff,#0f5bd9);color:#fff;font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #1677ff4d}.mathquiz-progress{display:flex;justify-content:space-between;width:100%;max-width:340px;font-size:14px;color:#6b7280}.mathquiz-question-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:20px;padding:32px 48px;box-shadow:0 4px 16px #0000001a}.mathquiz-question{display:flex;align-items:center;gap:12px;font-size:36px;font-weight:700}.mathquiz-num{color:#1677ff}.mathquiz-op{color:#64748b}.mathquiz-input{width:100px;height:56px;text-align:center;font-size:32px;font-weight:700;border:none;border-radius:12px;background:#fff;color:#1f2937;outline:none;box-shadow:0 2px 8px #0000001a}.mathquiz-input:focus{box-shadow:0 0 0 3px #1677ff4d}.mathquiz-submit-btn{width:100%;max-width:340px;padding:14px;border:none;border-radius:14px;background:#22c55e;color:#fff;font-size:16px;font-weight:600;cursor:pointer}.mathquiz-hint{font-size:13px;color:#9ca3af;margin:0}.mathquiz-result-card{background:#fff;border-radius:20px;padding:28px;width:100%;max-width:340px;text-align:center;box-shadow:0 4px 20px #0000001f}.mathquiz-result-card h2{margin:0 0 24px;font-size:22px;color:#1f2937}.mathquiz-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.mathquiz-stat{display:flex;flex-direction:column;align-items:center;padding:16px;background:#f8fafc;border-radius:12px}.mathquiz-stat-value{font-size:28px;font-weight:700;color:#1677ff}.mathquiz-stat-label{font-size:13px;color:#6b7280;margin-top:4px}.mathquiz-badge{font-size:24px;margin-bottom:20px}.mathquiz-change-btn{padding:12px 24px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer}@media(max-width:400px){.mathquiz-question-card{padding:24px 32px}.mathquiz-question{font-size:28px;gap:8px}.mathquiz-input{width:80px;height:48px;font-size:24px}}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;color-scheme:light;background:#fff;color:#1e293b}body{margin:0;min-height:100vh;background:transparent}.game-root{max-width:960px;margin:0 auto;background:#fff;border-radius:24px;padding:24px 24px 28px;box-shadow:0 4px 20px #00000014,0 0 0 1px #0000000d;position:relative;overflow:hidden}.game-nav{display:flex;justify-content:flex-start;margin-bottom:4px}.game-title{margin:0 0 12px;text-align:center;font-size:26px;font-weight:700;letter-spacing:.04em;background:linear-gradient(120deg,#e5e7eb,#facc15,#38bdf8);-webkit-background-clip:text;color:transparent}.game-timer{display:flex;justify-content:center;align-items:baseline;gap:6px;margin-bottom:18px;font-size:15px;color:#64748b}.timer{font-size:20px;font-weight:700;padding:4px 12px;border-radius:999px;background:radial-gradient(circle at top,#22c55e,#15803d);color:#ecfdf3;min-width:72px;text-align:center;box-shadow:0 0 0 1px #22c55e40}.timer.finished{background:radial-gradient(circle at top,#ef4444,#b91c1c);box-shadow:0 0 0 1px #f8717166}.game-top-panel{border-radius:18px;padding:18px 18px 16px;background:#f8fafc;box-shadow:inset 0 0 0 1px #00000014}.section{margin-bottom:14px}.section:last-child{margin-bottom:0}.section-title{font-size:14px;font-weight:600;color:#475569;margin-bottom:6px}.number-row{display:flex;flex-wrap:wrap;gap:8px}.number-chip{min-width:40px;height:32px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;box-shadow:0 2px 8px #0000001a}.number-chip.result{background:radial-gradient(circle at top,#fde68a,#f97316);color:#111827}.number-chip.small{min-width:30px;height:26px;font-size:13px}.number-chip.selected{background:radial-gradient(circle at top,#38bdf8,#1d4ed8);color:#0b1120}.number-chip.unselected{background:#e2e8f0;color:#64748b}.hint-text{margin-top:4px;font-size:12px;color:#64748b}.result-info{margin-top:4px;padding-top:8px;border-top:1px dashed #e2e8f0}.result-subtext{margin-top:4px;font-size:13px;color:#64748b;opacity:.92}.result-ok{animation:resultGlowSoft .9s ease-out}.result-good{animation:resultGlowMedium .9s ease-out}.result-great{animation:resultGlowStrong 1s ease-out}.hit-count-highlight{animation:hitPulse .9s ease-out}.result-text{font-size:15px;color:#334155}.hit-count{font-size:20px;font-weight:800;color:#fbbf24;text-shadow:0 0 12px rgba(251,191,36,.7);padding:0 4px}.game-bottom-panel{margin-top:18px;padding:16px 18px 18px;border-radius:18px;background:#f8fafc;box-shadow:0 4px 12px #0000000d,0 0 0 1px #0000000d}.card-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-top:10px}@media(max-width:640px){.card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.card-button{border-radius:16px;border:none;padding:10px 0;background:#fff;color:#334155;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #00000014,0 0 0 1px #0000000f;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.card-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #0000001a,0 0 0 1px #00000014}.card-selected{background:radial-gradient(circle at top,#22c55e,#15803d);box-shadow:0 18px 40px #16a34af5,0 0 0 1px #dcfce7cc;color:#ecfdf3}.card-disabled{opacity:.5;cursor:not-allowed}.game-actions{display:flex;justify-content:center;margin-top:18px}.restart-button{border-radius:999px;border:none;padding:8px 20px;font-size:14px;font-weight:600;letter-spacing:.03em;cursor:pointer;background:linear-gradient(135deg,#f1f5f9,#e0f2fe);color:#334155;box-shadow:0 4px 12px #00000014,0 0 0 1px #0000000f;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.restart-button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0000001a,0 0 0 1px #00000014;filter:brightness(1.02)}.confetti-overlay{pointer-events:none;position:absolute;inset:0;overflow:hidden;z-index:10}.confetti-piece{position:absolute;top:-12px;width:7px;height:14px;border-radius:999px;opacity:.95;transform-origin:center;animation-name:confettiFall,confettiSwing;animation-timing-function:linear,ease-in-out;animation-iteration-count:1,infinite}@keyframes confettiFall{0%{transform:translate3d(0,-10px,0) rotate(0);opacity:0}10%{opacity:1}to{transform:translate3d(0,320px,0) rotate(360deg);opacity:0}}@keyframes confettiSwing{0%{transform:translate(0)}50%{transform:translate(16px)}to{transform:translate(-16px)}}@keyframes hitPulse{0%{transform:scale(1);text-shadow:0 0 8px rgba(251,191,36,.5)}40%{transform:scale(1.25);text-shadow:0 0 18px rgba(251,191,36,.8)}to{transform:scale(1);text-shadow:0 0 10px rgba(251,191,36,.6)}}@keyframes resultGlowSoft{0%{box-shadow:inset 0 0 0 1px #4ade8000}to{box-shadow:inset 0 0 0 1px #4ade8099}}@keyframes resultGlowMedium{0%{box-shadow:inset 0 0 0 1px #4ade8000,0 0 #34d39900}to{box-shadow:inset 0 0 0 1px #4ade80cc,0 0 40px #2dd4bf99}}@keyframes resultGlowStrong{0%{box-shadow:inset 0 0 0 1px #facc1500,0 0 #facc1500}to{box-shadow:inset 0 0 0 1px #facc15f2,0 0 55px #facc15e6}}.ribbon-layer{pointer-events:none;position:absolute;inset:0;overflow:hidden;z-index:12}.ribbon-piece{position:absolute;bottom:10px;width:6px;height:46px;border-radius:999px;opacity:0;transform-origin:bottom center;animation-name:ribbonShoot,ribbonTwist;animation-delay:var(--ribbon-delay, 0s);animation-duration:var(--ribbon-duration, 1s),.6s;animation-timing-function:cubic-bezier(.2,.8,.1,1),ease-in-out;animation-iteration-count:1,infinite}.ribbon-piece.from-left{left:4%}.ribbon-piece.from-right{right:4%}.ribbon-cannon{position:absolute;bottom:0;width:28px;height:28px;border-radius:14px;background:radial-gradient(circle at top,#f97316,#b91c1c);box-shadow:0 0 0 1px #f8fafce6,0 0 18px #f87171e6;opacity:.9}.cannon-left{left:1.8%;transform:rotate(36deg)}.cannon-right{right:1.8%;transform:rotate(-36deg)}@keyframes ribbonShoot{0%{opacity:0;transform:translateZ(0) rotate(0) scaleY(.4)}15%{opacity:1}to{opacity:0;transform:translate3d(calc(cos(var(--ribbon-angle, 70deg))*260px),calc(sin(var(--ribbon-angle, 70deg))*260px*-1),0) rotate(380deg) scaleY(1.05)}}@keyframes ribbonTwist{0%{transform:rotateX(0)}50%{transform:rotateX(60deg)}to{transform:rotateX(-60deg)}}.gif-tool-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#fce7f3 0,#e0e7ff 42%,#ddd6fe);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.gif-mode-tabs{display:flex;gap:8px;margin-bottom:16px;width:100%;max-width:920px}.gif-mode-tab{flex:1;padding:10px 16px;border:none;border-radius:10px;background:#ffffffe6;color:#475569;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #00000014}.gif-mode-tab:hover{background:#fff}.gif-mode-tab.active{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;box-shadow:0 4px 12px #6366f166}.gif-split-panel,.gif-combine-panel{width:100%;max-width:920px;display:flex;flex-direction:column;gap:16px}.gif-config-card{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;gap:12px}.gif-preview-card{padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e;display:flex;flex-direction:column;align-items:center;gap:12px}.gif-preview-container{width:100%;max-width:400px;display:flex;justify-content:center;align-items:center;min-height:200px;border-radius:12px;overflow:hidden}.gif-preview-image{max-width:100%;max-height:400px;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a}.gif-preview-loading{color:#64748b;font-size:14px;padding:40px}.gif-frame-nav{display:flex;align-items:center;gap:16px}.gif-frame-btn{padding:8px 16px;border:none;border-radius:8px;background:#f1f5f9;color:#475569;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.gif-frame-btn:hover:not(:disabled){background:#e2e8f0}.gif-frame-btn:disabled{opacity:.5;cursor:not-allowed}.gif-frame-counter{font-size:14px;font-weight:600;color:#475569}.gif-frames-list{display:flex;flex-direction:column;gap:8px}.gif-frame-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;background:#ffffffe6;box-shadow:0 2px 8px #0000000f}.gif-frame-order{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.gif-frame-thumb{width:48px;height:48px;object-fit:cover;border-radius:8px;border:1px solid #e2e8f0}.gif-frame-controls{flex:1;display:flex;align-items:center;gap:6px}.gif-frame-delay-input{width:70px!important;padding:6px 8px!important;font-size:13px!important;text-align:center}.gif-frame-delay-unit{font-size:12px;color:#64748b}.gif-frame-actions{display:flex;gap:6px}.gif-frame-move-btn{width:28px;height:28px;border:none;border-radius:6px;background:#f1f5f9;color:#475569;font-size:14px;cursor:pointer;transition:all .2s ease}.gif-frame-move-btn:hover:not(:disabled){background:#e2e8f0}.gif-frame-move-btn:disabled{opacity:.4;cursor:not-allowed}.gif-frame-remove-btn{width:28px;height:28px;border:none;border-radius:6px;background:#fee2e2;color:#dc2626;font-size:16px;cursor:pointer;transition:all .2s ease}.gif-frame-remove-btn:hover{background:#fecaca}.gif-delay-config{margin-top:8px}.home-item.gif-tool{border-color:#ddd6fe}.gif-frame-preview-item{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.gif-frame-preview-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.gif-frame-preview-label{font-size:12px;font-weight:600;color:#64748b;margin-bottom:8px}@media(max-width:600px){.gif-mode-tabs{gap:6px}.gif-mode-tab{padding:8px 12px;font-size:13px}.gif-frame-item{flex-wrap:wrap;gap:8px}.gif-frame-controls{width:100%;order:3}.gif-frame-actions{margin-left:auto}}.countdown-page-root{min-height:100vh;padding:20px 14px;background:radial-gradient(circle at top,#e0f2fe 0,#bae6fd 42%,#7dd3fc);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.countdown-preview-wrap{width:100%;max-width:920px;display:flex;justify-content:center;margin-bottom:16px}.countdown-card{width:min(100%,480px);aspect-ratio:4 / 3;border-radius:24px;position:relative;overflow:hidden;box-shadow:0 24px 50px #0f172a59;color:#fff;padding:32px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.countdown-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.15),transparent 50%);pointer-events:none}.countdown-title{font-size:clamp(22px,4vw,32px);font-weight:700;text-align:center;text-shadow:0 4px 12px rgba(15,23,42,.25);position:relative;z-index:1}.countdown-timer{display:flex;align-items:center;justify-content:center;gap:8px;position:relative;z-index:1}.countdown-unit{display:flex;flex-direction:column;align-items:center}.countdown-number{font-size:clamp(36px,7vw,64px);font-weight:800;line-height:1;text-shadow:0 6px 18px rgba(15,23,42,.35);font-variant-numeric:tabular-nums}.countdown-label{font-size:clamp(14px,2.5vw,18px);font-weight:600;margin-top:8px}.countdown-separator{font-size:clamp(28px,5vw,48px);font-weight:700;transform:translateY(-8px);opacity:.9}.countdown-target{font-size:clamp(14px,2.5vw,18px);font-weight:600;text-align:center;position:relative;z-index:1}.countdown-placeholder{font-size:20px;font-weight:600;opacity:.8}.countdown-expired{font-size:clamp(32px,6vw,48px);font-weight:800;text-align:center;text-shadow:0 4px 12px rgba(15,23,42,.3)}.countdown-config-panel{width:100%;max-width:920px;padding:14px;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 25px #0f172a2e}.countdown-config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.countdown-input{margin-top:4px;width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;box-sizing:border-box}.countdown-input[type=datetime-local]{color-scheme:light}.home-item.countdown{border-color:#fcd34d}@media(max-width:600px){.countdown-page-root{padding:12px 8px}.countdown-card{width:min(100%,420px);aspect-ratio:4 / 3;border-radius:18px;padding:24px}.countdown-config-panel{padding:12px;border-radius:14px}.countdown-config-grid{grid-template-columns:1fr}}
