@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;600;700&family=Noto+Sans+SC:wght@300;400;500;600&display=swap";@layer components;@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-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;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #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 utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.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}.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))}}:root{--primary:#b08bad;--primary-hover:#9a7899;--primary-light:#f7f0f5;--secondary:#d4b8d0;--secondary-light:#ede5ef;--accent:#e8a5b0;--accent-light:#fdf0f2;--warning:#d4a574;--bg:#faf8f9;--surface:#fff;--text-primary:#4a3f4b;--text-secondary:#8a7a8f;--border:#ede5ed;--shadow:0 2px 12px #a078a014;--shadow-lg:0 8px 32px #a078a01f}*{box-sizing:border-box}html,body,#root{height:100%}body{background-color:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;margin:0;font-family:Noto Sans SC,-apple-system,sans-serif}.film-texture{position:relative}.film-texture:before{content:"";pointer-events:none;border-radius:inherit;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}.film-card{border:3px solid var(--primary);box-shadow:5px 5px 0px var(--primary);background:#fff;border-radius:4px;position:relative;overflow:hidden}.film-card:before{content:"";background:repeating-linear-gradient(90deg, var(--primary) 0px, var(--primary) 8px, transparent 8px, transparent 16px);opacity:.08;height:28px;position:absolute;top:0;left:0;right:0}.film-card:after{content:"";background:repeating-linear-gradient(90deg, var(--primary) 0px, var(--primary) 8px, transparent 8px, transparent 16px);opacity:.08;height:28px;position:absolute;bottom:0;left:0;right:0}.checkin-dot{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:inline-flex;position:relative;box-shadow:0 2px 6px #e07a5f66}.checkin-dot:after{content:"";border:2px dashed var(--primary);opacity:.5;border-radius:50%;position:absolute;inset:-2px}@keyframes heartBeat{0%{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(1)}75%{transform:scale(1.2)}to{transform:scale(1)}}.heart-animate{animation:.4s heartBeat}.bottom-nav{border-top:1px solid var(--border);z-index:100;background:#fff;justify-content:space-around;align-items:center;height:64px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000f}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:.4s forwards fadeInUp}.masonry{columns:2;column-gap:12px}.masonry-item{break-inside:avoid;margin-bottom:12px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;letter-spacing:.02em;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px 32px;font-family:Noto Sans SC,sans-serif;font-size:16px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #e07a5f66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{color:var(--primary);border:2px solid var(--primary);cursor:pointer;background:0 0;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-family:Noto Sans SC,sans-serif;font-size:15px;font-weight:500;transition:all .2s;display:inline-flex}.btn-secondary:hover{background:var(--primary-light)}.title-font{font-family:Noto Serif SC,serif}.input-field{border:2px solid var(--border);width:100%;color:var(--text-primary);background:#fff;border-radius:12px;outline:none;padding:14px 16px;font-family:Noto Sans SC,sans-serif;font-size:15px;transition:border-color .2s}.input-field:focus{border-color:var(--primary)}.input-field::placeholder{color:var(--text-secondary)}.toggle-switch{cursor:pointer;width:52px;height:28px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-track{background:var(--border);border-radius:28px;transition:background .2s;position:absolute;inset:0}.toggle-thumb{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.toggle-switch input:checked~.toggle-track{background:var(--primary)}.toggle-switch input:checked~.toggle-thumb{transform:translate(24px)}.tab-bar{background:var(--primary-light);border-radius:12px;gap:4px;padding:4px;display:flex}.tab-item{text-align:center;cursor:pointer;color:var(--text-secondary);border-radius:9px;flex:1;padding:8px;font-size:14px;font-weight:500;transition:all .2s}.tab-item.active{color:var(--text-primary);background:#fff;box-shadow:0 1px 4px #0000001a}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toast{animation:.3s slideInDown}.member-badge{background:linear-gradient(135deg, var(--secondary) 0%, var(--accent) 100%);color:#fff;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.site-wrapper{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.site-header{z-index:100;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#fdfcf8eb;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:32px;max-width:1100px;height:64px;margin:0 auto;padding:0 24px;display:flex}.site-logo{color:var(--text-primary);letter-spacing:-.01em;flex-shrink:0;align-items:center;gap:10px;font-family:Noto Serif SC,serif;font-size:17px;font-weight:600;text-decoration:none;display:flex}.site-logo svg{color:var(--primary)}.site-nav{flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.nav-link{color:var(--text-secondary);letter-spacing:.01em;border-radius:8px;padding:6px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.nav-link:hover{color:var(--text-primary);background:#0000000a}.nav-link.active{color:var(--primary);background:var(--primary-light);font-weight:600}.btn-login{background:var(--primary);color:#fff;letter-spacing:.01em;border-radius:24px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-login:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 14px #e07a5f59}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 14px #e07a5f59}.site-main{flex:1;padding:48px 0 80px}.content-container{max-width:860px;margin:0 auto;padding:0 24px}.magazine-heading{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-family:Noto Serif SC,serif;font-size:42px;font-weight:700;line-height:1.15}.magazine-subtitle{color:var(--text-secondary);margin:0;font-family:Noto Sans SC,sans-serif;font-size:16px;font-weight:400;line-height:1.6}.magazine-divider{background:var(--primary);border-radius:2px;width:48px;height:3px;margin:24px 0}.magazine-card{background:var(--surface);box-shadow:var(--shadow);border:1px solid #0000000a;border-radius:16px;padding:32px}@media (width<=768px){.header-inner{height:56px;padding:0 16px}.site-logo span{display:none}.site-nav{gap:2px}.nav-link{padding:5px 10px;font-size:13px}.content-container{padding:0 16px}.site-main{padding:32px 0 60px}.magazine-heading{font-size:32px}.magazine-card{border-radius:12px;padding:24px 20px}}@media (width<=480px){.site-nav{justify-content:flex-end}.nav-link{padding:5px 8px}}.page-container{background-color:var(--bg);min-height:auto;padding-bottom:0}.home-page{padding-top:32px}.hero-section{text-align:center;padding:40px 0 48px;position:relative}.hero-date{background:var(--primary-light);border-radius:20px;align-items:center;gap:8px;margin-bottom:20px;padding:6px 16px;display:inline-flex}.date-label{color:var(--primary);font-size:13px;font-weight:600}.date-num{color:var(--primary);font-family:Noto Serif SC,serif;font-size:15px;font-weight:600}.hero-title{color:var(--text-primary);letter-spacing:-.03em;margin:0 0 16px;font-family:Noto Serif SC,serif;font-size:52px;font-weight:700;line-height:1.1}.hero-desc{color:var(--text-secondary);margin:0 0 20px;font-size:17px;font-weight:400;line-height:1.7}.hero-meta{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:inline-flex}.hero-meta svg{color:var(--text-secondary);opacity:.7}.task-section{margin-bottom:48px}.task-loading{flex-direction:column;gap:16px;display:flex}.skeleton{background:linear-gradient(90deg, var(--primary-light) 25%, #eee5ec 50%, var(--primary-light) 75%);background-size:200% 100%;border-radius:12px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-title{width:60%;height:28px}.skeleton-body{width:80%;height:16px}.skeleton-btn{width:160px;height:48px;margin-top:8px}.task-card{background:var(--surface);box-shadow:var(--shadow-lg);border:1px solid #0000000a;border-radius:20px;padding:32px;transition:box-shadow .3s}.task-card:hover{box-shadow:0 12px 40px #0000001a}.task-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.task-emoji-badge{background:var(--primary-light);border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.task-meta-right{align-items:center;gap:8px;display:flex}.task-count{color:var(--text-secondary);background:var(--primary-light);border-radius:20px;padding:4px 12px;font-size:13px}.task-title{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 10px;font-family:Noto Serif SC,serif;font-size:26px;font-weight:700;line-height:1.3}.task-desc{color:var(--text-secondary);margin:0 0 24px;font-size:15px;line-height:1.7}.task-card-footer{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.task-cta{padding:12px 28px;font-size:15px}.task-tip{color:var(--text-secondary);font-size:13px}.task-empty{text-align:center;padding:48px 24px}.empty-illustration{margin-bottom:20px}.empty-title{color:var(--text-primary);margin:0 0 8px;font-family:Noto Serif SC,serif;font-size:20px;font-weight:600}.empty-desc{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.7}.history-section{margin-top:8px;padding:24px}.section-title{color:var(--text-primary);margin:0 0 16px;padding-left:4px;font-family:Noto Serif SC,serif;font-size:16px;font-weight:600}.history-list{flex-direction:column;gap:12px;display:flex}.history-item{background:var(--surface);box-shadow:var(--shadow);cursor:pointer;border-radius:12px;align-items:center;gap:16px;padding:14px 16px;transition:all .2s;display:flex}.history-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.history-item-today{background:linear-gradient(135deg,#b08bad14 0%,#dbb7dc14 100%);border:1px solid #b08bad33}.history-date{flex-direction:column;align-items:center;min-width:48px;display:flex}.history-weekday{color:var(--text-secondary);font-size:11px}.history-date-num{color:var(--text-primary);font-size:14px;font-weight:600}.history-content{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.history-emoji{flex-shrink:0;font-size:20px}.history-info{align-items:center;gap:8px;min-width:0;display:flex}.history-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.history-today-badge{color:var(--primary);background:#b08bad26;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:600}.history-meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.history-count{color:var(--text-secondary);font-size:12px}.history-meta svg{color:var(--text-secondary)}.home-footer{text-align:center;margin-top:16px;padding:32px 0}.footer-decoration{background:var(--border);border-radius:2px;width:32px;height:3px;margin:0 auto 16px}.footer-text{color:var(--text-secondary);opacity:.6;margin:0;font-size:13px;font-style:italic}@media (width<=768px){.hero-title{font-size:38px}.hero-desc{font-size:15px}.task-card{border-radius:16px;padding:24px 20px}.task-title{font-size:22px}.task-card-footer{flex-direction:column;align-items:flex-start;gap:12px}.task-cta{justify-content:center;width:100%}}.square-page .page-hero{border-bottom:1px solid var(--border);margin-bottom:36px;padding:48px 0 36px}.square-date-tabs{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}.square-date-tab{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;min-width:56px;padding:10px 16px;transition:all .2s;display:flex}.square-date-tab:hover{border-color:var(--primary);background:var(--primary-light)}.square-date-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.square-date-tab .day-label{opacity:.7;margin-bottom:4px;font-size:11px;font-weight:500;line-height:1}.square-date-tab .day-num{font-family:Noto Serif SC,serif;font-size:18px;font-weight:700;line-height:1}.square-date-tab .weekday{opacity:.6;margin-top:3px;font-size:10px}.square-task-banner{background:var(--primary-light);border-left:4px solid var(--primary);border-radius:14px;align-items:center;gap:12px;margin-bottom:28px;padding:16px 20px;display:flex}.square-task-banner .banner-emoji{flex-shrink:0;font-size:28px}.square-task-banner .banner-text{color:var(--primary);font-size:15px;font-weight:600;line-height:1.4}.square-masonry{columns:3;column-gap:20px}.square-masonry-item{break-inside:avoid;background:var(--surface);box-shadow:var(--shadow);cursor:pointer;border:1px solid #0000000a;border-radius:16px;margin-bottom:20px;transition:box-shadow .25s,transform .25s;overflow:hidden}.square-masonry-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.square-masonry-item img{border-radius:0;width:100%;display:block}.square-card-body{padding:14px 16px}.square-card-user{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.square-card-info{align-items:center;gap:8px;display:flex}.square-avatar{border:2px solid var(--border);object-fit:cover;border-radius:50%;width:28px;height:28px}.square-avatar-placeholder{background:var(--primary-light);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:flex}.square-nickname{color:var(--text-primary);font-size:13px;font-weight:600}.square-content{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.square-empty{text-align:center;padding:80px 0}.square-empty-icon{opacity:.7;margin-bottom:16px;font-size:64px}.square-empty-title{color:var(--text-primary);margin:0 0 8px;font-family:Noto Serif SC,serif;font-size:20px;font-weight:600}.square-empty-desc{color:var(--text-secondary);margin:0;font-size:14px}.like-btn{cursor:pointer;color:var(--text-secondary);background:var(--primary-light);border:none;border-radius:20px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.like-btn.liked{background:var(--primary);color:#fff}.like-btn:hover{transform:scale(1.05)}@media (width<=768px){.square-masonry{columns:2;column-gap:12px}.square-masonry-item{margin-bottom:12px}.square-page .page-hero{padding:32px 0 24px}}@media (width<=480px){.square-masonry{columns:1}}.calendar-page,.history-page{padding-top:8px}.page-section{margin-bottom:40px}.section-heading{align-items:center;gap:12px;margin-bottom:20px;display:flex}.section-heading .sh-title{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-family:Noto Serif SC,serif;font-size:22px;font-weight:700}.section-heading .sh-line{background:var(--border);border-radius:1px;flex:1;height:1px}.calendar-grid{background:var(--surface);box-shadow:var(--shadow);border:1px solid #0000000a;border-radius:16px;padding:20px}.calendar-weekdays{grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;margin-bottom:4px;display:grid}.calendar-weekday{text-align:center;color:var(--text-secondary);opacity:.6;justify-content:center;align-items:center;min-height:36px;padding:8px 0;font-size:12px;font-weight:600;display:flex}.calendar-cells{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-cell{border:1.5px solid var(--border);height:48px;color:var(--text-secondary);box-sizing:border-box;border-radius:10px;justify-content:center;align-items:center;font-size:14px;font-weight:500;transition:all .15s;display:flex}.calendar-cell.empty{cursor:default;background:0 0;border-color:#0000}.calendar-cell.has-task{border-color:var(--primary-light);background:var(--primary-light);cursor:pointer;color:var(--primary)}.calendar-cell.has-task:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.calendar-cell.checked{border-color:var(--primary);background:var(--primary);color:#fff;font-weight:700}.calendar-cell.today{border:2.5px solid var(--primary);color:var(--primary);font-weight:700}.calendar-cell.today.checked{background:var(--primary);color:#fff;border:none}.calendar-cell.selected:not(.today):not(.checked){border-color:var(--primary)!important;background:var(--primary-light)!important;color:var(--primary)!important}.calendar-cell.selected.today{box-shadow:0 0 0 3px #b08bad33}.calendar-cell .checkin-dot{background:var(--accent);border-radius:50%;width:7px;height:7px;position:absolute;bottom:4px;right:4px}.calendar-cell .checkin-dot:after{display:none}.calendar-nav{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.calendar-nav-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.calendar-nav-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.calendar-month-label{color:var(--text-primary);letter-spacing:-.01em;font-family:Noto Serif SC,serif;font-size:18px;font-weight:700}.history-card{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:20px;padding:20px 0;transition:all .15s;display:flex}.history-card:hover{opacity:.8}.history-card:last-child{border-bottom:none}.history-date-block{text-align:center;background:var(--primary-light);border-radius:12px;flex-shrink:0;width:52px;padding:12px 8px}.history-date-block.checked{background:var(--primary)}.history-date-num{color:var(--text-primary);font-family:Noto Serif SC,serif;font-size:24px;font-weight:700;line-height:1}.history-date-block.checked .history-date-num{color:#fff}.history-date-month{color:var(--text-secondary);margin-top:3px;font-size:11px}.history-date-block.checked .history-date-month{color:#fffc}.history-card-content{flex:1;min-width:0}.history-task-title{color:var(--text-primary);letter-spacing:-.01em;align-items:center;gap:6px;margin:0 0 4px;font-family:Noto Serif SC,serif;font-size:16px;font-weight:600;display:flex}.history-task-meta{color:var(--text-secondary);margin:0;font-size:12px}.history-task-status{flex-shrink:0;align-self:center}.history-status-badge{border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.history-status-badge.checked{background:var(--accent-light);color:var(--accent)}.history-status-badge.unchecked{background:var(--primary-light);color:var(--primary)}.profile-page{padding-top:8px}.profile-hero{border-bottom:1px solid var(--border);align-items:center;gap:24px;margin-bottom:32px;padding:32px 0 28px;display:flex}.profile-avatar-large{background:var(--primary);color:#fff;border:3px solid var(--surface);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:700;display:flex;box-shadow:0 4px 16px #e07a5f4d}.profile-info{flex:1;min-width:0}.profile-nickname{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px;font-family:Noto Serif SC,serif;font-size:24px;font-weight:700}.profile-phone{color:var(--text-secondary);margin:0 0 8px;font-size:13px}.profile-stats{gap:24px;display:flex}.profile-stat{flex-direction:column;gap:2px;display:flex}.profile-stat-num{color:var(--text-primary);font-family:Noto Serif SC,serif;font-size:18px;font-weight:700;line-height:1}.profile-stat-label{color:var(--text-secondary);opacity:.7;font-size:11px}.pricing-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;display:grid}.pricing-card{background:var(--surface);text-align:center;border:2px solid var(--border);cursor:pointer;border-radius:16px;padding:24px 20px;transition:all .2s}.pricing-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}.pricing-card.featured{border-color:var(--primary);background:var(--primary-light);position:relative}.pricing-card.featured:before{content:"推荐";background:var(--primary);color:#fff;letter-spacing:.05em;border-radius:20px;padding:3px 12px;font-size:11px;font-weight:700;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.pricing-name{color:var(--text-secondary);margin:0 0 12px;font-size:14px;font-weight:600}.pricing-price{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px;font-family:Noto Serif SC,serif;font-size:32px;font-weight:700}.pricing-price .price-unit{color:var(--text-secondary);font-size:14px;font-weight:400}.pricing-desc{color:var(--text-secondary);margin:8px 0 0;font-size:12px;line-height:1.5}@media (width<=768px){.pricing-grid{grid-template-columns:1fr}.profile-hero{gap:16px;padding:24px 0 20px}.profile-avatar-large{width:60px;height:60px;font-size:22px}.profile-nickname{font-size:20px}.profile-stats{gap:16px}}@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-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}
