@import "https://fonts.loli.net/css2?family=Noto+Serif+SC:wght@400;600;700&family=ZCOOL+XiaoWei&display=swap";
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--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-outline-style:solid;--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;--tw-ease: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;--spacing:.25rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--radius-sm:.25rem;--radius-lg:.5rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--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{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.italic{font-style:italic}.underline{text-decoration-line:underline}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{--canvas:#fdf8f0;--canvas-warm:#fef5e7;--canvas-deep:#faecd3;--sun-core:#f6a623;--sun-light:#fcd34d;--sun-glow:#fef3c7;--sun-pale:#fffbeb;--peach:#fda085;--peach-light:#fde2ca;--blush:#f8b4b4;--blush-light:#fde8e8;--sage:#86c7a3;--sage-light:#d4edda;--sage-pale:#ecf7f0;--lavender:#a78bfa;--lavender-lt:#ede9fe;--sky:#7dd3fc;--sky-light:#e0f2fe;--text-primary:#3d2e1f;--text-secondary:#7a6b5d;--text-ghost:#b8a99a;--emo-calm:#86c7a3;--emo-warm:#fcd34d;--emo-ember:#f87171;--glass-bg:#ffffff8c;--glass-border:#ffffffb3;--glass-shadow:#f6a62314;--glass-glow:#f6a6231f;--card-bg:#fff;--card-border:#0000000a;--r-sm:14px;--r-md:22px;--r-lg:28px;--r-xl:36px;--r-full:9999px;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.2s;--duration-med:.45s;--duration-slow:.8s;--font-display:"Noto Serif SC", "Songti SC", Georgia, serif;--font-art:"ZCOOL XiaoWei", "Noto Serif SC", serif;--font-body:"Noto Sans SC", -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.75rem;--text-5xl:3.5rem;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--sp-20:5rem;--sp-24:6rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);color:var(--text-primary);background:var(--canvas);min-height:100vh;line-height:1.7;position:relative;overflow-x:hidden}::selection{color:var(--text-primary);background:#f6a62333}.sunshine{z-index:0;pointer-events:none;background:linear-gradient(170deg, var(--sun-pale) 0%, var(--canvas) 35%, var(--canvas-warm) 65%, var(--peach-light) 100%);position:fixed;inset:0;overflow:hidden}.sunshine:before{content:"";background:radial-gradient(circle,#fcd34d2e 0%,#fda08514 40%,#0000 70%);border-radius:50%;width:80vw;max-width:900px;height:80vw;max-height:900px;animation:12s ease-in-out infinite sunPulse;position:absolute;top:-30%;right:-20%}.sunshine:after{content:"";background:radial-gradient(circle,#a78bfa14 0%,#86c7a30f 40%,#0000 70%);border-radius:50%;width:60vw;max-width:700px;height:60vw;max-height:700px;animation:15s ease-in-out 3s infinite sunPulse;position:absolute;bottom:-20%;left:-15%}@keyframes sunPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.orb{filter:blur(60px);border-radius:50%;animation:linear infinite orbFloat,ease-in-out infinite orbBreath;position:absolute}.orb--1{background:radial-gradient(circle,#fcd34d33,#0000 70%);width:300px;height:300px;animation-duration:22s,8s;top:8%;right:15%}.orb--2{background:radial-gradient(circle,#fda08526,#0000 70%);width:250px;height:250px;animation-duration:18s,10s;animation-delay:-5s,-3s;bottom:25%;left:8%}.orb--3{background:radial-gradient(circle,#86c7a31f,#0000 70%);width:200px;height:200px;animation-duration:25s,12s;animation-delay:-10s,-5s;top:50%;right:5%}.orb--4{background:radial-gradient(circle,#a78bfa14,#0000 70%);width:280px;height:280px;animation-duration:20s,9s;animation-delay:-8s,-2s;top:15%;left:20%}@keyframes orbFloat{0%{transform:translate(0)}25%{transform:translate(30px,-20px)}50%{transform:translate(-15px,25px)}75%{transform:translate(20px,10px)}to{transform:translate(0)}}@keyframes orbBreath{0%,to{opacity:.5}50%{opacity:1}}.grain{z-index:0;pointer-events:none;opacity:.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");position:fixed;inset:0}.app{z-index:1;min-height:100vh;position:relative}.page{width:100%;max-width:640px;padding:var(--sp-10) var(--sp-6);gap:var(--sp-10);flex-direction:column;margin:0 auto;display:flex}.glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);-webkit-backdrop-filter:blur(20px)saturate(1.3);padding:var(--sp-8);transition:all var(--duration-med) ease;position:relative;overflow:hidden;box-shadow:0 2px 20px #00000008,inset 0 1px #fffc}.glass:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#fff9 0%,#ffffff1a 50%,#ffffff4d 100%);position:absolute;inset:0}.glass:hover{border-color:#f6a62326;box-shadow:0 4px 30px #f6a62314,inset 0 1px #ffffffe6}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--r-lg);padding:var(--sp-8);transition:all var(--duration-med) ease;position:relative;overflow:hidden;box-shadow:0 2px 16px #0000000a}.card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000000f}.heading-display{font-family:var(--font-display);font-weight:700;font-size:var(--text-4xl);background:linear-gradient(135deg, var(--text-primary) 20%, var(--sun-core) 80%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;line-height:1.3}.heading-section{font-family:var(--font-display);font-weight:600;font-size:var(--text-2xl);color:var(--text-primary)}.text-body{font-size:var(--text-base);color:var(--text-secondary);line-height:1.8}.text-caption{font-size:var(--text-xs);color:var(--text-ghost);letter-spacing:.06em;text-transform:uppercase;font-weight:500}.btn{justify-content:center;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-8);border-radius:var(--r-full);font-family:var(--font-body);font-size:var(--text-base);cursor:pointer;transition:all var(--duration-med) var(--ease-out-expo);white-space:nowrap;border:none;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn-sun{background:linear-gradient(135deg, var(--sun-core), var(--peach));color:#fff;box-shadow:0 4px 20px #f6a62340,inset 0 1px #ffffff40}.btn-sun:hover{transform:translateY(-2px);box-shadow:0 8px 35px #f6a62359,inset 0 1px #ffffff4d}.btn-sage{background:linear-gradient(135deg, var(--sage), #6bbd8a);color:#fff;box-shadow:0 4px 20px #86c7a340}.btn-sage:hover{transform:translateY(-2px);box-shadow:0 8px 35px #86c7a359}.btn-peach{background:linear-gradient(135deg, var(--peach), var(--blush));color:#fff;box-shadow:0 4px 20px #fda08533}.btn-peach:hover{transform:translateY(-2px);box-shadow:0 8px 35px #fda0854d}.btn-ghost{color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff80;border:1px solid #0000000f}.btn-ghost:hover{color:var(--text-primary);background:#ffffffb3}.btn-sm{padding:var(--sp-2) var(--sp-5);font-size:var(--text-sm)}.btn-lg{padding:var(--sp-5) var(--sp-10);font-size:var(--text-lg)}.slider-wrap{padding:var(--sp-4) 0}.slider-track{border-radius:var(--r-full);background:linear-gradient(90deg, var(--sage) 0%, var(--sun-light) 40%, var(--sun-core) 60%, var(--peach) 80%, var(--emo-ember) 100%);width:100%;height:10px;position:relative;box-shadow:inset 0 1px 3px #0000000f}.slider-track input[type=range]{appearance:none;cursor:pointer;z-index:2;background:0 0;width:100%;height:44px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.slider-track input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;border:3px solid var(--sun-core);width:32px;height:32px;transition:all var(--duration-fast) ease;background:#fff;border-radius:50%;box-shadow:0 2px 12px #f6a62340,0 0 0 6px #f6a62314}.slider-track input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 4px 20px #f6a62359,0 0 0 8px #f6a6231f}.slider-track input[type=range]::-moz-range-thumb{border:3px solid var(--sun-core);background:#fff;border-radius:50%;width:32px;height:32px;box-shadow:0 2px 12px #f6a62340}.slider-value{font-family:var(--font-display);font-size:var(--text-5xl);text-align:center;margin-bottom:var(--sp-1);transition:color var(--duration-med) ease;font-weight:700;line-height:1}.slider-label{text-align:center;font-size:var(--text-sm);color:var(--text-ghost);letter-spacing:.06em}.tag-grid{gap:var(--sp-3);flex-wrap:wrap;justify-content:center;display:flex}.tag{padding:var(--sp-2) var(--sp-5);border-radius:var(--r-full);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-med) var(--ease-out-expo);-webkit-user-select:none;user-select:none;background:#fff9;border:1px solid #0000000d}.tag:hover{color:var(--text-primary);background:#ffffffd9;border-color:#f6a62333}.tag.active{background:linear-gradient(135deg, var(--sun-glow), var(--peach-light));border-color:var(--sun-core);color:var(--text-primary);box-shadow:0 2px 12px #f6a6231f}.input-area{border-radius:var(--r-md);width:100%;padding:var(--sp-5) var(--sp-6);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);resize:vertical;min-height:120px;transition:all var(--duration-med) ease;background:#ffffff80;border:1.5px solid #0000000f;outline:none;line-height:1.8}.input-area::placeholder{color:var(--text-ghost)}.input-area:focus{border-color:var(--sun-core);background:#ffffffb3;box-shadow:0 0 0 4px #f6a62314,0 2px 12px #f6a6230f}.input-line{border-radius:var(--r-full);width:100%;padding:var(--sp-4) var(--sp-6);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:all var(--duration-med) ease;background:#ffffff80;border:1.5px solid #0000000f;outline:none}.input-line:focus{border-color:var(--sun-core);box-shadow:0 0 0 4px #f6a62314}.page--chat{justify-content:flex-start;gap:var(--sp-3);min-height:100vh;padding-top:var(--sp-4)}.chat-header{align-items:center;gap:var(--sp-3);padding-bottom:var(--sp-3);border-bottom:1px solid #0000000a;display:flex}.chat-avatar{background:linear-gradient(135deg, var(--sun-glow), var(--peach-light));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;display:flex}.chat-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.chat-status{font-size:var(--text-xs);color:var(--sage)}.chat-messages{gap:var(--sp-4);padding:var(--sp-2) 0 var(--sp-4);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.chat-input-bar{-webkit-backdrop-filter:blur(12px);padding:var(--sp-4);border-radius:var(--r-xl);gap:var(--sp-3);background:#fdf8f0eb;border:1px solid #0000000a;align-items:center;display:flex;position:sticky;bottom:0;box-shadow:0 -2px 20px #0000000a}.chat-input-bar .input-line{flex:1}.loading-dots{padding:var(--sp-4) var(--sp-6);gap:5px;display:inline-flex}.loading-dots span{background:var(--sun-core);opacity:.3;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite dotPulse}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.chat-bubble{max-width:85%;padding:var(--sp-5) var(--sp-8);font-size:var(--text-base);animation:bubbleIn var(--duration-slow) var(--ease-out-expo) both;border-radius:24px;line-height:1.7}.chat-bubble--ai{color:var(--text-primary);background:#ffffffbf;border:1px solid #0000000a;border-bottom-left-radius:8px;align-self:flex-start;box-shadow:0 2px 16px #0000000a}.chat-bubble--user{background:linear-gradient(135deg, var(--sun-glow), var(--peach-light));color:var(--text-primary);border:1px solid #f6a62326;border-bottom-right-radius:8px;align-self:flex-end;box-shadow:0 2px 16px #f6a62314}@keyframes bubbleIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.typewriter-cursor{background:var(--sun-core);vertical-align:text-bottom;width:2px;height:1.1em;margin-left:2px;animation:1s ease-in-out infinite cursorBlink;display:inline-block}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.literary-card{border-radius:var(--r-lg);padding:var(--sp-10) var(--sp-8);background:linear-gradient(145deg,#fffc,#fef3c766,#fde2ca4d);border:1px solid #f6a6231a;position:relative;overflow:hidden;box-shadow:0 4px 30px #f6a6230f}.literary-card:before{content:"";pointer-events:none;background:conic-gradient(#0000,#fcd34d0f,#0000,#fda0850a,#0000);border-radius:50%;width:200%;height:200%;animation:25s linear infinite literaryGlow;position:absolute;top:-50%;left:-50%}@keyframes literaryGlow{to{transform:rotate(360deg)}}.literary-quote{font-family:var(--font-art);font-size:var(--text-5xl);color:var(--sun-core);opacity:.2;top:var(--sp-6);left:var(--sp-6);line-height:1;position:absolute}.literary-text{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);z-index:1;white-space:pre-wrap;line-height:2.2;position:relative}.literary-text .char{opacity:0;animation:.5s ease-out forwards charSunrise;display:inline}@keyframes charSunrise{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.progress-bar{align-items:center;gap:var(--sp-2);padding:var(--sp-4) 0;display:flex}.progress-dot{width:10px;height:10px;transition:all var(--duration-med) var(--ease-out-expo);background:#00000014;border-radius:50%}.progress-dot.active{background:var(--sun-core);transform:scale(1.4);box-shadow:0 0 12px #f6a62366}.progress-dot.done{background:var(--sage);box-shadow:0 0 8px #86c7a366}.progress-line{background:#0000000f;border-radius:1px;flex:1;height:2px;overflow:hidden}.progress-line.done:after{content:"";background:linear-gradient(90deg, var(--sage), var(--sun-light));width:100%;height:100%;animation:lineGrow var(--duration-slow) var(--ease-out-expo) forwards;transform-origin:0;display:block}@keyframes lineGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.hero{text-align:center;padding:var(--sp-12) var(--sp-6) var(--sp-8);align-items:center;gap:var(--sp-8);flex-direction:column;max-width:600px;margin:0 auto;display:flex}.hero-badge{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);animation:fadeDown .8s var(--ease-out-expo) both;background:#f6a62314;border:1px solid #f6a62326;justify-content:center;align-items:center;display:inline-flex}.hero-logo{object-fit:contain;vertical-align:middle;width:auto;height:96px}@keyframes fadeDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-family:var(--font-display);color:var(--text-primary);animation:fadeUp .8s .1s var(--ease-out-expo) both;font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;line-height:1.25}.hero-title em{background:linear-gradient(135deg, var(--sun-core), var(--peach));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:400px;animation:fadeUp .8s .2s var(--ease-out-expo) both;line-height:1.9}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.module-grid{gap:var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}.module-card{text-align:center;padding:var(--sp-6) var(--sp-4);color:inherit;cursor:pointer;transition:all var(--duration-med) var(--ease-out-expo);flex-direction:column;align-items:center;text-decoration:none;display:flex}.module-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px #f6a6231f}.module-icon{margin-bottom:var(--sp-3);font-size:2.2rem;display:block}.module-title{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--sp-1);font-weight:600}.module-desc{font-size:var(--text-xs);color:var(--text-ghost);line-height:1.6}.stagger>*{animation:stagIn var(--duration-slow) var(--ease-out-expo) both}.stagger>:first-child{animation-delay:50ms}.stagger>:nth-child(2){animation-delay:.1s}.stagger>:nth-child(3){animation-delay:.15s}.stagger>:nth-child(4){animation-delay:.2s}.stagger>:nth-child(5){animation-delay:.25s}.stagger>:nth-child(6){animation-delay:.3s}.stagger>:nth-child(7){animation-delay:.35s}@keyframes stagIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:pageSlideUp var(--duration-slow) var(--ease-out-expo) both}@keyframes pageSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.nav-bar{justify-content:center;align-items:center;gap:var(--sp-3);padding-bottom:var(--sp-4);display:flex}.section{gap:var(--sp-10);flex-direction:column;width:100%;display:flex}.dashboard-stat-grid{gap:var(--sp-3);grid-template-columns:repeat(3,1fr);display:grid}.dashboard-stat-card{text-align:center;padding:var(--sp-5) var(--sp-4)}.dashboard-stat-number{font-family:var(--font-display);font-size:var(--text-3xl);background:linear-gradient(135deg, var(--sun-core), var(--peach));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700;line-height:1.2}.dashboard-stat-label{font-size:var(--text-sm);color:var(--text-ghost);margin-top:var(--sp-1)}.dashboard-record{align-items:flex-start;gap:var(--sp-4);padding:var(--sp-5);display:flex}.dashboard-record-emoji{background:#f6a62314;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.6rem;display:flex}.dashboard-record-info{flex:1;min-width:0}.dashboard-record-title{font-weight:600;font-size:var(--text-base);color:var(--text-primary);margin-bottom:2px}.dashboard-record-meta{font-size:var(--text-xs);color:var(--text-ghost);margin-bottom:var(--sp-2)}.dashboard-record-badge{align-items:center;gap:var(--sp-1);border-radius:var(--r-full);color:#4a9e6f;font-size:var(--text-xs);background:#86c7a31f;padding:2px 10px;font-weight:600;display:inline-flex}.dashboard-record-text{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--sp-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}.chart-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--r-md);padding:var(--sp-6);box-shadow:0 2px 16px #00000008}.chart-container canvas{max-height:280px}.modal-overlay{z-index:2000;padding:var(--sp-6);-webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity var(--duration-med) ease;background:#3e2e1f4d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal-box{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--r-xl);padding:var(--sp-8);width:100%;max-width:420px;transition:transform var(--duration-med) var(--ease-out-expo);transform:translateY(20px)scale(.97);box-shadow:0 20px 60px #0000001f}.modal-overlay.open .modal-box{transform:translateY(0)scale(1)}.modal-close{top:var(--sp-4);right:var(--sp-4);cursor:pointer;width:32px;height:32px;font-size:var(--text-lg);color:var(--text-ghost);transition:all var(--duration-fast) ease;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.modal-close:hover{color:var(--text-primary);background:#0000001a}.author-avatar{object-fit:cover;width:80px;height:80px;margin:0 auto var(--sp-5);border:3px solid var(--accent);border-radius:50%;display:block;box-shadow:0 4px 20px #0000001f}.author-links{gap:var(--sp-2);flex-direction:column;display:flex}.author-link-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-lg);font-size:var(--text-sm);color:var(--text-secondary);transition:background var(--duration-fast) ease;background:#00000008;text-decoration:none;display:flex}a.author-link-item:hover{background:#0000000f}.author-link-icon{flex-shrink:0;font-size:1.1rem}.assess-progress-bar{border-radius:var(--r-full);width:100%;height:6px;margin-bottom:var(--sp-6);background:#0000000f;overflow:hidden}.assess-progress-fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--sage), var(--sun-core));height:100%;transition:width .5s var(--ease-out-expo)}.assess-question{font-family:var(--font-display);font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--sp-6);font-weight:600;line-height:1.5}.assess-options{gap:var(--sp-3);flex-direction:column;display:flex}.assess-option{padding:var(--sp-4) var(--sp-6);border-radius:var(--r-md);cursor:pointer;transition:all var(--duration-fast) ease;font-size:var(--text-base);color:var(--text-secondary);text-align:left;background:#ffffff80;border:1.5px solid #0000000d}.assess-option:hover{background:#fffc;border-color:#f6a62333}.assess-option.selected{background:linear-gradient(135deg, var(--sun-glow), var(--peach-light));border-color:var(--sun-core);color:var(--text-primary);font-weight:600}.assess-score-ring{width:140px;height:140px;margin:0 auto var(--sp-6);border:4px solid var(--sun-core);background:#fff9;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;display:flex}.assess-score-num{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--sun-core);font-weight:700;line-height:1}.assess-score-label{font-size:var(--text-xs);color:var(--text-ghost);margin-top:var(--sp-1)}.assess-level{padding:var(--sp-1) var(--sp-4);border-radius:var(--r-full);font-size:var(--text-sm);margin-bottom:var(--sp-4);font-weight:600;display:inline-block}.assess-level--mild{color:#4a9e6f;background:#86c7a326}.assess-level--moderate{color:var(--sun-core);background:#f6a6231f}.assess-level--severe{color:#e05555;background:#f871711f}.breathe-circle{width:200px;height:200px;margin:0 auto var(--sp-8);font-family:var(--font-display);font-size:var(--text-2xl);color:var(--text-primary);background:radial-gradient(circle,#fffc,#86c7a326);border:3px solid #86c7a34d;border-radius:50%;justify-content:center;align-items:center;font-weight:600;transition:transform 4s ease-in-out,border-color 2s;display:flex}.breathe-circle.inhale{border-color:var(--sage);background:radial-gradient(circle,#ffffffe6,#86c7a340);transform:scale(1.3)}.breathe-circle.hold{border-color:var(--sun-light);background:radial-gradient(circle,#ffffffe6,#fcd34d26);transform:scale(1.3)}.breathe-circle.exhale{border-color:var(--lavender);background:radial-gradient(circle,#fffc,#a78bfa1f);transform:scale(1)}.breathe-phase{font-size:var(--text-sm);color:var(--text-ghost);text-align:center;margin-bottom:var(--sp-2);min-height:1.5em}.breathe-counter{font-family:var(--font-display);font-size:var(--text-5xl);text-align:center;color:var(--sun-core);margin-bottom:var(--sp-4);font-weight:700}.breathe-cycles{text-align:center;font-size:var(--text-sm);color:var(--text-ghost)}.gratitude-input-group{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);display:flex}.gratitude-num{width:28px;height:28px;color:var(--sun-core);font-size:var(--text-sm);background:#f6a6231a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.gratitude-input{border-radius:var(--r-full);padding:var(--sp-3) var(--sp-5);font-family:var(--font-body);font-size:var(--text-base);color:var(--text-primary);transition:all var(--duration-fast) ease;background:#ffffff80;border:1.5px solid #0000000f;outline:none;flex:1}.gratitude-input:focus{border-color:var(--sun-core);box-shadow:0 0 0 4px #f6a62314}.gratitude-history-item{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid #0000000a}.gratitude-history-item:last-child{border-bottom:none}.gratitude-date{font-size:var(--text-xs);color:var(--text-ghost);margin-bottom:var(--sp-2)}.gratitude-list{padding:0;list-style:none}.gratitude-list li{font-size:var(--text-sm);color:var(--text-secondary);padding:var(--sp-1) 0}.gratitude-list li:before{content:"🌿 "}.tool-indicator{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-size:var(--text-xs);color:var(--sage);animation:fadeUp .4s var(--ease-out-expo) both;background:#86c7a31a;border:1px solid #86c7a333;display:inline-flex}.tool-indicator .spinner{border-width:2px;width:14px;height:14px}.text-center{text-align:center}.spinner{border:2.5px solid #0000000f;border-top-color:var(--sun-core);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast{bottom:var(--sp-8);padding:var(--sp-3) var(--sp-6);border-radius:var(--r-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;font-size:var(--text-sm);z-index:1000;opacity:0;transition:all var(--duration-med) var(--ease-out-expo);pointer-events:none;background:#3e2e1fe0;position:fixed;left:50%;transform:translate(-50%)translateY(16px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.disclaimer{text-align:center;font-size:var(--text-xs);color:var(--text-ghost);padding:var(--sp-8) var(--sp-4);max-width:460px;margin:0 auto;line-height:1.9}.calendar-grid{width:100%}.calendar-weekdays{margin-bottom:var(--sp-1);grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-weekday{text-align:center;font-size:var(--text-xs);color:var(--text-ghost);padding:var(--sp-1) 0;font-weight:600}.calendar-week{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);flex-direction:column;justify-content:center;align-items:center;min-height:44px;transition:transform .15s;display:flex;position:relative}.calendar-day:hover{transform:scale(1.1)}.calendar-day--empty{cursor:default}.calendar-day--empty:hover{transform:none}.calendar-day--today{outline:2px solid var(--sun-core);outline-offset:-2px;border-radius:var(--radius-sm)}.calendar-day-num{z-index:1;font-weight:500}.calendar-day-dot{background:var(--text-primary);border-radius:50%;width:4px;height:4px;margin-top:2px}.calendar-day--has-record .calendar-day-num{color:var(--text-primary);font-weight:700}.bottom-nav{z-index:100;padding:var(--sp-2) 0 calc(var(--sp-2) + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fdf8f0f2;border-top:1px solid #0000000f;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{padding:var(--sp-1) 0;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;align-items:center;gap:2px;text-decoration:none;transition:color .2s;display:flex}.bottom-nav-icon{font-size:1.3rem;line-height:1}.bottom-nav-label{font-size:var(--text-xs);line-height:1}@media (max-width:375px){:root{--text-4xl:1.75rem;--text-5xl:2.2rem}.page{padding:var(--sp-5) var(--sp-3) calc(var(--sp-5) + 76px + env(safe-area-inset-bottom,0px))}.glass{padding:var(--sp-5)}.module-grid{gap:var(--sp-2);grid-template-columns:repeat(2,1fr)}.module-card{padding:var(--sp-4) var(--sp-3)}.hero{padding:var(--sp-6) var(--sp-3) var(--sp-5);gap:var(--sp-5)}.hero-title{font-size:1.8rem}.disclaimer{padding-bottom:calc(var(--sp-8) + 76px + env(safe-area-inset-bottom,0px))}}@media (max-width:640px){:root{--text-4xl:2rem;--text-5xl:2.5rem}.page{padding:var(--sp-6) var(--sp-4) calc(var(--sp-6) + 76px + env(safe-area-inset-bottom,0px))}.glass{padding:var(--sp-6)}.module-grid{grid-template-columns:repeat(2,1fr)}.dashboard-stat-grid{grid-template-columns:repeat(3,1fr)}.dashboard-stat-card{padding:var(--sp-3) var(--sp-2)}.dashboard-stat-number{font-size:var(--text-2xl)}.dashboard-record{padding:var(--sp-3);gap:var(--sp-3)}.dashboard-record-emoji{width:36px;height:36px;font-size:1.3rem}.chart-container{padding:var(--sp-4)}.hero{padding:var(--sp-8) var(--sp-4) var(--sp-6);gap:var(--sp-6)}.disclaimer{padding-bottom:calc(var(--sp-8) + 76px + env(safe-area-inset-bottom,0px))}.bottom-nav{display:flex}.chat-input-bar{padding-bottom:calc(var(--sp-3) + 76px + env(safe-area-inset-bottom,0px))}}@media (min-width:641px) and (max-width:768px){.module-grid{grid-template-columns:repeat(3,1fr)}.page{max-width:700px}}@media (min-width:769px) and (max-width:1024px){.module-grid{grid-template-columns:repeat(3,1fr)}.page{max-width:800px}}@media (min-width:1025px){.module-grid{grid-template-columns:repeat(4,1fr)}.page{max-width:960px}}@media (pointer:coarse){button,a.btn,.tag,.assess-option,.module-card,.calendar-day,.bottom-nav-item{min-width:44px;min-height:44px}input[type=range]{height:44px}}@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-border-style{syntax:"*";inherits:false;initial-value:solid}@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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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}@property --tw-ease{syntax:"*";inherits:false}
