/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-600:oklch(44.6% .03 256.802);--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-1\.5{top:calc(var(--spacing) * -1.5)}.top-4{top:calc(var(--spacing) * 4)}.-right-1\.5{right:calc(var(--spacing) * -1.5)}.right-0{right:calc(var(--spacing) * 0)}.right-4{right:calc(var(--spacing) * 4)}.left-0{left:calc(var(--spacing) * 0)}.z-40{z-index:40}.z-50{z-index:50}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-\[44px\]{height:44px}.h-\[100px\]{height:100px}.h-screen{height:100vh}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-screen{min-height:100vh}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-\[44px\]{width:44px}.w-\[60px\]{width:60px}.w-\[100px\]{width:100px}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[64px\]{min-width:64px}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.grow{flex-grow:1}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize-y{resize:vertical}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-\[2px\]{gap:2px}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[var\(--primary\)\]{border-color:var(--primary)}.border-gray-200{border-color:var(--color-gray-200)}.bg-\[var\(--danger\)\]{background-color:var(--danger)}.bg-\[var\(--primary\)\]{background-color:var(--primary)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-white{background-color:var(--color-white)}.object-cover{object-fit:cover}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-20{padding-block:calc(var(--spacing) * 20)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.pb-24{padding-bottom:calc(var(--spacing) * 24)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.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-\[21px\]{font-size:21px}.text-\[22px\]{font-size:22px}.text-\[24px\]{font-size:24px}.text-\[26px\]{font-size:26px}.text-\[28px\]{font-size:28px}.text-\[32px\]{font-size:32px}.text-\[48px\]{font-size:48px}.text-\[56px\]{font-size:56px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.whitespace-nowrap{white-space:nowrap}.text-\[var\(--border\)\]{color:var(--border)}.text-\[var\(--danger\)\]{color:var(--danger)}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--primary\)\]{color:var(--primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-gray-600{color:var(--color-gray-600)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.no-underline{text-decoration-line:none}.accent-\[var\(--primary\)\]{accent-color:var(--primary)}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.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,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}@media (hover:hover){.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}.focus\:border-\[var\(--primary\)\]:focus{border-color:var(--primary)}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}}:root{--primary:#3b8686;--primary-hover:#2d6b6b;--primary-light:#e8f4f4;--accent:#c4956a;--accent-light:#fdf5ee;--danger:#c4574b;--success:#4a8c6f;--warning:#b8923e;--muted:#8b8d98;--bg:#faf8f5;--card:#fff;--border:#e8e5e0;--text:#2c2c2e;--text-secondary:#6b6b6e;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 12px #0000000f;--radius:16px;--radius-sm:12px}*{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;min-height:100%;font-family:-apple-system,SF Pro Display,PingFang HK,Microsoft YaHei,system-ui,sans-serif;font-size:17px;line-height:1.6}button,a,[role=button],select,input,textarea{min-height:44px;font-size:16px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s}.card:hover,.card:focus-within{border-color:var(--primary);box-shadow:var(--shadow-md)}.card-primary{background:linear-gradient(135deg, var(--primary) 0%, #4a9e9e 100%);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);border:none;transition:box-shadow .2s,transform .15s}.card-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3b86864d}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;padding:12px 24px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{background:var(--card);color:var(--text);border:2px solid var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-danger{color:var(--danger);background:#fff5f4;border:2px solid #f0d0cc}.btn-danger:hover{background:#f0d0cc}.btn-lg{border-radius:var(--radius);padding:18px 32px;font-size:18px}.btn-record{background:var(--primary);color:#fff;border-radius:var(--radius);width:100%;padding:20px 32px;font-size:18px;font-weight:700}.btn-record:hover{background:var(--primary-hover)}.btn-record-active{background:var(--danger)}.input{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card);width:100%;color:var(--text);outline:none;padding:14px 16px;font-size:16px;transition:border-color .15s}.input:focus{border-color:var(--primary)}.emoji-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.avatar{background:var(--primary-light);width:52px;height:52px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.bottom-nav{background:var(--card);border-top:1px solid var(--border);z-index:50;height:60px;padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.page{max-width:480px;margin:0 auto;padding:20px 20px 76px}.bubble{white-space:pre-wrap;border-radius:18px;max-width:85%;padding:14px 18px;font-size:16px;line-height:1.7}.bubble-ai{background:var(--card);border:1px solid var(--border);border-bottom-left-radius:4px}.bubble-user{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.progress-bar{background:var(--border);height:3px}.progress-fill{background:var(--primary);height:100%;transition:width .3s}.badge{letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-easy{color:#1a7a3e;background:#d6f1df}.badge-medium{color:#956b00;background:#fff3cd}.badge-hard{color:#c62a30;background:#ffd6d9}.badge-chat{background:var(--primary-light);color:var(--primary)}.badge-quiz{color:var(--success);background:#d6f1df}.section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:10px;font-size:12px;font-weight:700}.stat-card{background:var(--primary-light);border-radius:var(--radius-sm);text-align:center;padding:14px}.stat-value{color:var(--primary);font-size:26px;font-weight:800}.stat-label{color:var(--text-secondary);margin-top:2px;font-size:12px}.feedback-correct{color:#1a7a3e;border-radius:var(--radius);background:#d6f1df;border:1px solid #b4dfc4;padding:16px}.feedback-encourage{background:var(--primary-light);color:var(--primary);border-radius:var(--radius);border:1px solid #c2dede;padding:16px}.transcription-preview{background:var(--accent-light);border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid #e8ddd2;padding:12px 16px;font-style:italic}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.6}}.recording{animation:1.2s ease-in-out infinite rec-pulse}@keyframes speak-wave{0%,to{opacity:.5}50%{opacity:1}}.speaking-indicator{animation:1.5s ease-in-out infinite speak-wave;display:inline-block}.session-context-bar{color:var(--accent);background:var(--accent-light);border-bottom:1px solid #e8ddd2;padding:8px 20px;font-size:13px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.feedback-enter{animation:.3s ease-out fadeSlideIn}.pace-selected{box-shadow:0 0 0 2px var(--primary)}.avatar-img{object-fit:cover;border-radius:50%;flex-shrink:0;width:52px;height:52px}.avatar-fallback{position:absolute}.photo-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;background:var(--card);cursor:pointer;padding:24px 16px;transition:border-color .2s,background .2s}.photo-upload-zone:hover{border-color:var(--primary);background:var(--primary-light)}.photo-thumbnail{border-radius:var(--radius-sm);object-fit:cover;border:2px solid var(--border);width:72px;height:72px}.photo-display{border-radius:var(--radius);object-fit:contain;max-width:80vw;max-height:50vh;box-shadow:var(--shadow-md)}.choice-btn{background:var(--card);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;min-height:60px;padding:16px 20px;font-size:17px;font-weight:600;transition:all .15s}.choice-btn:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.toggle-switch{background:var(--border);cursor:pointer;border:none;border-radius:16px;align-items:center;width:52px;height:32px;min-height:32px;padding:2px;transition:background .2s;display:flex}.toggle-on{background:var(--primary)}.toggle-knob{background:#fff;border-radius:50%;width:28px;height:28px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle-on .toggle-knob{transform:translate(20px)}.audio-mode-bg{background:linear-gradient(160deg,#faf8f5 0%,#e8f4f4 50%,#fdf5ee 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.audio-record-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;width:120px;height:120px;min-height:120px;font-size:40px;transition:all .2s;box-shadow:0 8px 32px #3b86864d}.audio-record-btn:hover{box-shadow:0 12px 40px #3b868666}.audio-record-btn.btn-record-active{background:var(--danger);box-shadow:0 8px 32px #c4574b4d}@keyframes audio-pulse{0%,to{box-shadow:0 0 #3b868666}50%{box-shadow:0 0 0 20px #3b868600}}.audio-listening{animation:2s ease-in-out infinite audio-pulse}@keyframes audio-rings{0%{opacity:.5;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}.audio-ring{border:2px solid var(--primary);pointer-events:none;border-radius:50%;width:120px;height:120px;animation:2s ease-out infinite audio-rings;position:absolute}.audio-ring:nth-child(2){animation-delay:.6s}.audio-ring:nth-child(3){animation-delay:1.2s}.album-photo-container{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.album-nav-btn{background:var(--card);border:1px solid var(--border);cursor:pointer;width:48px;height:48px;min-height:48px;box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.album-nav-btn:hover{background:var(--primary-light);border-color:var(--primary)}.badge-album{color:var(--accent);background:#fdf5ee}.badge-audio{color:var(--primary);background:#e8f4f4}.stock-picker-overlay{z-index:60;background:var(--bg);flex-direction:column;display:flex;position:fixed;inset:0}.stock-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.stock-thumb{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;border:2px solid #0000;width:100%;transition:border-color .2s,transform .15s}.stock-thumb:hover{border-color:var(--primary);transform:scale(1.03)}.stock-category-tab{background:var(--card);border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:20px;align-items:center;gap:4px;min-height:36px;padding:8px 14px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.stock-category-tab:hover{border-color:var(--primary);color:var(--primary)}.stock-category-tab.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.companion-wrapper{flex-direction:column;align-items:center;display:inline-flex;position:relative}.companion-face{will-change:transform;transition:transform .3s}.companion-small{width:40px;height:40px}.companion-medium{width:64px;height:64px}.companion-large{width:120px;height:120px}@keyframes companion-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.companion-breathe{animation:3s ease-in-out infinite companion-breathe}@keyframes companion-mouth-speak{0%,to{d:path("M 42 64 Q 50 68 58 64")}50%{d:path("M 42 64 Q 50 74 58 64")}}.companion-mouth-speak{animation:.6s ease-in-out infinite companion-mouth-speak}.companion-bubble{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--primary);white-space:nowrap;box-shadow:var(--shadow-sm);z-index:1;padding:6px 12px;font-size:12px;font-weight:600;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)translateY(100%)}.exp-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#e0e0e4;border-radius:var(--radius-sm);background:#1e1e23eb;max-height:50vh;padding:12px;font-size:11px;line-height:1.4;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.exp-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.exp-badge{color:#7cc;background:#3b86864d;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600}.exp-grid{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px;display:grid}.exp-metric{text-align:center;background:#ffffff0d;border-radius:8px;padding:6px 4px}.exp-metric-value{color:#e0e0e4;font-size:16px;font-weight:800}.exp-metric-label{color:#888;text-transform:uppercase;letter-spacing:.4px;margin-top:2px;font-size:9px}.exp-tag{color:#aaa;background:#ffffff14;border-radius:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.exp-tag-ok{color:#6dc;background:#4a8c6f40}.exp-tag-warn{color:#eb6;background:#b8923e40}.exp-tag-danger{color:#f88;background:#c4574b40}.exp-recent{margin-top:4px}.exp-response{border-bottom:1px solid #ffffff0d;align-items:center;gap:6px;padding:3px 0;font-size:11px;display:flex}.exp-response-indicator{border-radius:50%;flex-shrink:0;width:6px;height:6px}.bg-green{background:#4a8c6f}.bg-amber{background:#b8923e}.bg-gray{background:#666}.text-green{color:#6dc}.text-amber{color:#eb6}.text-red{color:#f88}.exp-toggle-btn{z-index:70;color:#aaa;cursor:pointer;background:#1e1e23d9;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;min-height:32px;font-size:14px;transition:all .15s;display:flex;position:fixed;top:8px;left:8px}.exp-toggle-btn:hover{color:#ddd;background:#1e1e23f2}.exp-panel-wrapper{z-index:70;width:280px;max-width:calc(100vw - 16px);position:fixed;top:44px;left:8px}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
