*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-noto),Noto Sans KR,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-0{bottom:0}.bottom-4{bottom:1rem}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-10{z-index:10}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1{height:.25rem}.h-10{height:2.5rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.max-h-48{max-height:12rem}.min-h-svh{min-height:100svh}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-20{width:5rem}.w-5{width:1.25rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-\[480px\]{max-width:480px}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.translate-x-\[22px\]{--tw-translate-x:22px}.translate-x-\[22px\],.translate-x-\[2px\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-\[2px\]{--tw-translate-x:2px}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-x-1{-moz-column-gap:.25rem;column-gap:.25rem}.gap-y-2{row-gap:.5rem}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-t-3xl{border-top-left-radius:1.5rem;border-top-right-radius:1.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.bg-black\/40{background-color:rgb(0 0 0/.4)}.bg-black\/50{background-color:rgb(0 0 0/.5)}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-primary-500{--tw-bg-opacity:1;background-color:rgb(0 102 255/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-0\.5{padding-bottom:.125rem}.pb-10{padding-bottom:2.5rem}.pb-16{padding-bottom:4rem}.pb-2{padding-bottom:.5rem}.pb-28{padding-bottom:7rem}.pb-3{padding-bottom:.75rem}.pb-32{padding-bottom:8rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pb-8{padding-bottom:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[17px\]{font-size:17px}.text-\[18px\]{font-size:18px}.text-\[20px\]{font-size:20px}.text-\[22px\]{font-size:22px}.text-\[24px\]{font-size:24px}.font-black{font-weight:900}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.shadow-md{--tw-shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&display=swap");:root{--font-noto:"Noto Sans KR",sans-serif;--accent:#0066FF;--accent-soft:#E8F1FF;--jjpp-accent:#0066FF;--jjpp-accent-soft:#E8F1FF;--jjpp-warm:#FF7A18;--blue-50:#EFF6FF;--blue-500:#3B82F6;--blue-700:#1D4ED8;--green-500:#22C55E;--yellow-50:#FEFCE8;--red-50:#FEF2F2;--red-500:#EF4444;--green-700:#15803d;--violet-100:#EDE9FE;--active-bg:#E8F0FF;--active-bd:#0066FF;--hsk1-bg:#E6F9EE;--hsk1-fg:#007A29;--hsk2-bg:#E0F4F8;--hsk2-fg:#006B7D;--hsk3-bg:#E8F1FF;--hsk3-fg:#004FC4;--hsk4-bg:#EFE9FE;--hsk4-fg:#5435CF;--hsk5-bg:#FFEDD8;--hsk5-fg:#B5560A;--hsk6-bg:#FFE5E5;--hsk6-fg:#C81F1F;--neutral-50:#F8F9FA;--neutral-100:#F2F3F5;--neutral-200:#E5E7EB;--neutral-800:#1F2937;--fg-primary:#111827;--fg-secondary:#374151;--fg-tertiary:#6B7280;--border-default:#E5E7EB}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-noto);background-color:#F2F3F5;max-width:480px;margin:0 auto;min-height:100svh;overflow-x:hidden}.safe-top{padding-top:env(safe-area-inset-top)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}.pt-safe{padding-top:calc(env(safe-area-inset-top) + 12px)}::-webkit-scrollbar{display:none}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.font-chinese{font-family:Noto Sans SC,sans-serif}.chip-hsk1{background:var(--hsk1-bg);color:var(--hsk1-fg)}.chip-hsk2{background:var(--hsk2-bg);color:var(--hsk2-fg)}.chip-hsk3{background:var(--hsk3-bg);color:var(--hsk3-fg)}.chip-hsk4{background:var(--hsk4-bg);color:var(--hsk4-fg)}.chip-hsk5{background:var(--hsk5-bg);color:var(--hsk5-fg)}.chip-hsk6{background:var(--hsk6-bg);color:var(--hsk6-fg)}.zh-token{display:inline-block;cursor:pointer;border-radius:3px;padding:1px 0;transition:background .12s}.zh-token:active{background:var(--accent-soft)}.zh-token.kw{text-decoration:underline;text-decoration-style:dotted;text-decoration-thickness:1.5px;text-decoration-color:var(--accent);text-underline-offset:4px}.token-wrap{display:inline-flex;flex-direction:column;align-items:center;margin:0 1px;vertical-align:baseline}.token-pinyin{display:block;font-size:10.5px;line-height:1.4;color:var(--fg-tertiary);letter-spacing:.02em;font-weight:500;font-style:italic;margin-bottom:1px}.sentence-block{display:flex;gap:8px;padding:12px 14px;border-radius:12px;background:#fff;border:1px solid var(--border-default);border-left:3px solid transparent;transition:background .2s,border-color .2s,box-shadow .2s}.sentence-block.active{background:var(--active-bg);border-left-color:var(--active-bd)}.sentence-zh{flex:1;line-height:2}.sentence-zh.size-sm{font-size:16px;line-height:1.9}.sentence-zh.size-md{font-size:18px;line-height:2}.sentence-zh.size-lg{font-size:21px;line-height:2.1}.sentence-zh.word-mode.size-sm{line-height:2.7}.sentence-zh.word-mode.size-md{line-height:2.8}.sentence-zh.word-mode.size-lg{line-height:2.9}.sentence-ko{font-size:13px;line-height:1.55}.sentence-ko,.sentence-pinyin-line{color:var(--fg-tertiary);margin-top:4px}.sentence-pinyin-line{font-size:12px;letter-spacing:.02em;font-weight:500;font-style:italic;line-height:1.5}.app-header{align-items:center;gap:8px;padding:calc(env(safe-area-inset-top) + 12px) 16px 12px;top:0;z-index:40}.app-header,.app-tabs{display:flex;background:#fff;border-bottom:1px solid var(--border-default);position:sticky}.app-tabs{top:calc(env(safe-area-inset-top) + 57px);z-index:39}.app-tab{flex:1;text-align:center;padding:10px 4px;font-size:13px;font-weight:600;color:var(--fg-tertiary);cursor:pointer;border-bottom:2px solid transparent;transition:color .12s,border-color .12s}.app-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.scroll-area{overflow-y:auto;-webkit-overflow-scrolling:touch}.card{background:#fff;border:1px solid var(--border-default);border-radius:14px;box-shadow:0 1px 3px rgba(23,23,23,.04)}.card-flat{background:var(--neutral-50)}.btn,.card-flat{border-radius:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 16px;border:0;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;letter-spacing:-.01em;transition:opacity .12s,transform .08s;white-space:nowrap;text-decoration:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.lg{height:50px;font-size:15px;border-radius:12px}.btn-pri{background:var(--accent);color:#fff}.btn-pri:hover:not(:disabled){opacity:.88}.btn-sec{background:var(--neutral-100);color:var(--fg-primary);border:1px solid var(--border-default)}.btn-sec:hover:not(:disabled){background:var(--neutral-200)}.btn-ghost{background:transparent;color:var(--fg-secondary)}.btn-ghost:hover:not(:disabled){background:var(--neutral-100)}.muted,.tiny{color:var(--fg-tertiary)}.tiny{letter-spacing:.01em}.muted.tiny,.tiny{font-size:11px}.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--neutral-200);margin:0 auto 16px}.icon-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:var(--fg-tertiary);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}.icon-btn:hover{background:var(--neutral-100);color:var(--fg-primary)}.icon-btn.active{background:var(--accent-soft);color:var(--accent)}.thumb-warm{background:linear-gradient(135deg,#FFB37A,#FF6B9D 60%,#9747FF)}.thumb-cool{background:linear-gradient(135deg,#0066FF,#6541F2 60%,#FF6B9D)}.thumb-green{background:linear-gradient(135deg,#00BF40,#0098B2)}.thumb-warm2{background:linear-gradient(135deg,#FF7A18,#FF4242 60%,#9747FF)}.thumb-default{background:linear-gradient(135deg,#0066FF,#6541F2)}.sheet-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4);z-index:50;animation:fadeIn .2s ease-out}.sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:24px 24px 0 0;padding:8px 20px 28px;z-index:51;animation:slideUp .25s cubic-bezier(.32,.72,0,1);max-height:80%;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.touch-manipulation{touch-action:manipulation}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:50px;border-radius:12px;border:0;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:-.01em;transition:transform .12s,box-shadow .12s;white-space:nowrap}.oauth-btn:active{transform:translateY(1px)}.oauth-google{background:#fff;color:#171719;border:1px solid #dadce0}.oauth-apple{background:#000;color:#fff}.oauth-icon{width:20px;height:20px;justify-content:center}.guest-chip,.oauth-icon{display:inline-flex;align-items:center}.guest-chip{gap:4px;padding:3px 8px;background:var(--neutral-100);color:var(--fg-tertiary);border-radius:999px;font-size:10px;font-weight:600}.guest-banner{margin:0 16px 12px;padding:12px 14px;border-radius:12px;background:linear-gradient(135deg,var(--accent-soft),var(--violet-100));gap:10px}.guest-banner,.list-row{display:flex;align-items:center}.list-row{gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-default);cursor:pointer}.list-row:active{background:var(--neutral-50)}.list-row .label{flex:1;font-size:14px;font-weight:500;color:var(--fg-primary)}.list-row .label.danger{color:var(--red-500)}.list-row .meta{font-size:12px;color:var(--fg-tertiary)}.daily-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--neutral-100);color:var(--fg-secondary);border-radius:999px;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}.daily-pill.warn{background:var(--yellow-50);color:#B87514}.daily-pill.full{background:var(--red-50);color:#C81F1F}.lang-toggle{display:inline-flex;background:var(--neutral-100);border-radius:10px;padding:3px;gap:0}.lang-toggle button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;color:var(--fg-tertiary);cursor:pointer;letter-spacing:-.01em;transition:all .12s}.lang-toggle button.active{box-shadow:0 1px 3px rgba(23,23,23,.08)}.ai-input,.lang-toggle button.active{background:#fff;color:var(--fg-primary)}.ai-input{width:100%;border:1.5px solid var(--border-default);border-radius:14px;padding:14px;font-size:14px;line-height:1.55;font-family:inherit;resize:none;outline:none;transition:border-color .12s,box-shadow .12s;letter-spacing:-.005em}.ai-input:focus{border-color:var(--jjpp-accent);box-shadow:0 0 0 3px var(--jjpp-accent-soft)}.char-counter{font-size:11px;font-variant-numeric:tabular-nums;color:var(--fg-tertiary);font-weight:600}.char-counter.warn{color:#B87514}.char-counter.over{color:#C81F1F}.preview-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:var(--blue-50);color:var(--blue-700);border-radius:999px;font-size:11px;font-weight:600;animation:popIn .3s cubic-bezier(.34,1.4,.64,1)}@keyframes popIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.gen-step{display:flex;align-items:center;gap:10px;padding:10px 0;font-size:13px;color:var(--fg-secondary)}.gen-step .dot{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--neutral-100);color:var(--fg-tertiary);font-size:10px;font-weight:800}.gen-step.done .dot{background:var(--green-500);color:#fff}.gen-step.active .dot{background:var(--jjpp-accent);color:#fff;animation:pulseRing 1.4s ease-in-out infinite}@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(0,102,255,.4)}70%{box-shadow:0 0 0 8px rgba(0,102,255,0)}to{box-shadow:0 0 0 0 rgba(0,102,255,0)}}.gen-step.active .label{color:var(--fg-primary);font-weight:600}.gen-step.done .label{color:var(--fg-tertiary)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;flex-shrink:0}.status-pending{background:#FFF6E5;color:#B87514}.status-approved{background:#E5F8EC;color:#0E8537}.status-rejected{background:#FFE5E5;color:#C81F1F}.status-manual{background:#F0EBFF;color:#5A35D1}.status-private{background:var(--neutral-100);color:var(--fg-tertiary)}.mod-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border-default)}.mod-row:last-child{border-bottom:0}.mod-row .mark{width:22px;height:22px;border-radius:6px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}.mod-row.pass .mark{background:#E5F8EC;color:#0E8537}.mod-row.fail .mark{background:#FFE5E5;color:#C81F1F}.mod-row.checking .mark{background:var(--blue-50);color:var(--blue-500)}.mod-row.pending .mark{background:var(--neutral-100);color:var(--fg-tertiary)}.mod-row .name{flex:1;font-size:13px;font-weight:600;color:var(--fg-primary);letter-spacing:-.005em}.mod-row.fail .name{color:#C81F1F}.mod-row .note{font-size:11px;color:var(--fg-tertiary)}.studio-card{background:#fff;border:1px solid var(--border-default);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:8px}.studio-card .title-row{display:flex;align-items:center;gap:8px}.studio-card .title{font-size:14px;font-weight:700;letter-spacing:-.01em;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.studio-card .meta{font-size:11px;color:var(--fg-tertiary);display:flex;gap:8px;align-items:center}.studio-card .preview-zh{font-size:13px;color:var(--fg-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.studio-card .actions{display:flex;align-items:center;gap:8px;margin-top:4px}.switch{position:relative;width:36px;height:22px;flex-shrink:0;background:var(--neutral-200);border-radius:999px;cursor:pointer;transition:background .18s}.switch.on{background:var(--green-500)}.switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(23,23,23,.2);transition:transform .18s}.switch.on:after{transform:translateX(14px)}.switch.disabled{opacity:.4;cursor:not-allowed}.flag-text{background:linear-gradient(180deg,transparent 60%,#FFD8D8 0);padding:0 2px;font-weight:600}.cmp-tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;letter-spacing:-.005em}.cmp-tbl td,.cmp-tbl th{padding:9px 8px;text-align:left;border-bottom:1px solid var(--border-default);vertical-align:top}.cmp-tbl th{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-tertiary);font-weight:700;background:var(--neutral-50)}.cmp-tbl td.no{color:var(--red-500);font-weight:700}.cmp-tbl td.yes{color:#0E8537;font-weight:700}.gen-card{background:var(--neutral-50);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:6px}.gen-card .zh{font-size:18px;font-weight:700;letter-spacing:-.01em}.gen-card .py{font-size:11px;color:var(--fg-tertiary);font-style:italic}.gen-card .ko{font-size:12px;color:var(--fg-secondary)}.stream-cursor{display:inline-block;width:8px;height:1em;background:var(--jjpp-accent);vertical-align:text-bottom;margin-left:2px;animation:blink 1s steps(2,start) infinite}@keyframes blink{to{visibility:hidden}}@keyframes spin{to{transform:rotate(1turn)}}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-primary-500:focus-visible{--tw-ring-opacity:1;--tw-ring-color:rgb(0 102 255/var(--tw-ring-opacity,1))}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95}.active\:scale-95:active,.active\:scale-\[0\.98\]:active{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.active\:scale-\[0\.98\]:active{--tw-scale-x:0.98;--tw-scale-y:0.98}.active\:opacity-90:active{opacity:.9}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.disabled\:opacity-70:disabled{opacity:.7}