:root{color-scheme:dark;font-family:Manrope,PingFang SC,Microsoft YaHei,sans-serif;--bg-0: #f3eee5;--bg-1: #f8f4ed;--ink-0: #221b17;--ink-1: rgba(34, 27, 23, .72);--line: rgba(86, 66, 46, .12);--card: rgba(255, 252, 247, .74);--shadow: 0 24px 72px rgba(49, 36, 24, .14);--radius-xl: 32px;--radius-lg: 24px;--blur: blur(24px)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--ink-0);background:radial-gradient(circle at top left,rgba(217,199,166,.4),transparent 30%),radial-gradient(circle at 85% 10%,rgba(171,198,236,.42),transparent 28%),linear-gradient(180deg,var(--bg-0) 0%,var(--bg-1) 100%);font-family:Manrope,PingFang SC,Microsoft YaHei,sans-serif}button,input,textarea{font:inherit}button{cursor:pointer}canvas{touch-action:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.eyebrow{display:inline-flex;align-items:center;gap:8px;color:#4736268f;font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase}.app-shell{position:relative;min-height:100vh;overflow:hidden}.app-shell__glow{position:fixed;width:28rem;height:28rem;border-radius:999px;filter:blur(90px);opacity:.45;pointer-events:none}.app-shell__glow--one{top:-10rem;right:-8rem;background:#719dde47}.app-shell__glow--two{bottom:-12rem;left:-8rem;background:#f0ae7038}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 18px;border-radius:999px;border:1px solid transparent;transition:transform .18s ease,background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.button:hover{transform:translateY(-1px)}.button--ghost{background:#fffdf9a3;border-color:#785f3e29;color:var(--ink-0);box-shadow:0 10px 28px #49372614}.button--accent{color:#fff;background:linear-gradient(135deg,#5f8ee9,#7db4f4);box-shadow:0 16px 32px #5680dd47}.button--compact{min-height:40px;padding:0 16px}.link-button{border:0;padding:0;background:transparent;color:#40332894;font-size:.86rem;font-weight:700}.home-page,.module-shell{position:relative;z-index:1;max-width:1240px;margin:0 auto;padding:32px 24px 48px}.home-page__header,.module-shell__topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.home-page__header h1,.module-shell__hero h1,.season-page__hero h1,.tree-module__hero h1{margin:12px 0 0;font-family:"Noto Serif SC",Songti SC,serif;font-size:clamp(2rem,4vw,3.8rem);line-height:1.05;letter-spacing:-.03em}.home-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,.8fr);gap:18px;margin-top:28px}.home-hero__copy,.home-hero__meta,.module-shell__hero,.season-card,.anniversary-feature,.anniversary-list,.anniversary-composer{border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--card);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:var(--shadow)}.home-hero__copy,.module-shell__hero{padding:32px}.home-hero__copy h2,.module-shell__hero h1,.season-card h2,.anniversary-feature h2,.anniversary-list__header h2,.anniversary-composer h2{margin:14px 0 12px;font-family:"Noto Serif SC",Songti SC,serif;font-size:clamp(1.5rem,2.2vw,2.5rem);line-height:1.18}.home-hero__copy p,.module-shell__hero p,.season-card p,.anniversary-feature p,.anniversary-composer p{margin:0;color:var(--ink-1);line-height:1.7}.home-hero__meta{padding:28px;display:flex;flex-direction:column;justify-content:flex-end;min-height:220px;background:linear-gradient(155deg,#ffffffad,#e8f4ffc7),var(--card)}.home-hero__meta span{color:#3e2f218a;font-size:.84rem;letter-spacing:.18em;text-transform:uppercase}.home-hero__meta strong{margin-top:18px;font-family:"Noto Serif SC",Songti SC,serif;font-size:clamp(1.6rem,2.6vw,2.5rem);line-height:1.2}.home-section{margin-top:36px}.home-section__header{display:flex;justify-content:space-between;gap:18px;align-items:end;margin-bottom:18px}.home-section__header h2{margin:0;font-size:1.08rem;letter-spacing:.16em;text-transform:uppercase}.home-section__header p{margin:0;max-width:660px;color:var(--ink-1);line-height:1.7}.module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.module-grid--feature{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.module-card{position:relative;overflow:hidden;min-height:224px;padding:24px;text-align:left;border:1px solid rgba(255,255,255,.45);border-radius:var(--radius-xl);color:#221b17;box-shadow:0 24px 60px #3326191f;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.module-card:hover{transform:translateY(-4px);box-shadow:0 28px 72px #33261929}.module-card__label{display:inline-flex;font-size:.78rem;font-weight:800;letter-spacing:.22em}.module-card__body{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-top:22px}.module-card h3{margin:0;font-family:"Noto Serif SC",Songti SC,serif;font-size:2rem}.module-card p{max-width:34ch;margin:12px 0 0;color:#251c14b8;line-height:1.7}.module-card__status,.module-card__cta{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;white-space:nowrap}.module-card__status{min-height:32px;padding:0 12px;background:#ffffff94;font-size:.78rem;font-weight:700;color:#2b2219b8}.module-card__cta{margin-top:28px;min-height:40px;padding:0 14px;background:#ffffff8f;font-weight:700}.module-card--spring{background:radial-gradient(circle at top right,rgba(255,203,223,.36),transparent 28%),radial-gradient(circle at bottom left,rgba(186,223,192,.42),transparent 30%),linear-gradient(160deg,#eff8e9f0,#fff2f1e6)}.module-card--summer{background:linear-gradient(160deg,#fff3d6f2,#dcedffeb)}.module-card--autumn{background:linear-gradient(160deg,#ffe9d0f5,#f7dec9eb)}.module-card--winter{background:linear-gradient(160deg,#eef5fff5,#fafcffeb)}.module-card--tree{color:#f8fcff;background:radial-gradient(circle at top right,rgba(81,156,255,.38),transparent 24%),linear-gradient(160deg,#070c1df5,#11162deb)}.module-card--tree p,.module-card--tree .module-card__status,.module-card--tree .module-card__cta{color:#f1f8ffcc}.module-card--tree .module-card__status,.module-card--tree .module-card__cta{background:#ffffff1a}.module-card--anniversaries{background:radial-gradient(circle at top right,rgba(239,164,128,.28),transparent 30%),linear-gradient(160deg,#fffbf3f5,#f8ebdeeb)}.module-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--ink-1);font-size:1rem;letter-spacing:.08em}.module-shell__hero{margin-top:22px}.module-shell__topbar-actions{display:flex;gap:12px}.season-page{min-height:100vh}.season-page__hero{margin-top:22px;padding:34px 32px;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.45);box-shadow:var(--shadow)}.season-page__hero p{max-width:44rem;margin:16px 0 0;color:#221b17b8;line-height:1.75}.season-page__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:20px}.season-card{padding:28px}.season-card__list{margin:18px 0;padding-left:20px;color:var(--ink-0);line-height:1.8}.season-page__actions{display:flex;gap:12px;margin-top:22px}.season-page--spring .season-page__hero{background:linear-gradient(150deg,#f0fae8f0,#fff4f4e0)}.season-page--summer .season-page__hero{background:linear-gradient(150deg,#fff0d4f0,#e0eeffe0)}.season-page--autumn .season-page__hero{background:linear-gradient(150deg,#ffe7d4f5,#f7e0cde0)}.season-page--winter .season-page__hero{background:linear-gradient(150deg,#edf5fff5,#fcfeffe6)}.anniversary-page{min-height:100vh}.anniversary-composer{margin-top:18px;padding:24px}.anniversary-composer__header h2{margin:0 0 8px;font-size:1.45rem}.anniversary-composer__header p{color:var(--ink-1)}.anniversary-composer__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px}.field{display:flex;flex-direction:column;gap:10px}.field span{color:#382b20ad;font-size:.92rem;font-weight:700}.field input,.field textarea{width:100%;border:1px solid rgba(109,84,56,.16);border-radius:18px;background:#ffffffd1;color:var(--ink-0);padding:14px 16px;outline:none}.field textarea{resize:vertical}.field input:focus,.field textarea:focus{border-color:#5f8ee966;box-shadow:0 0 0 4px #5f8ee91f}.field--wide{grid-column:1 / -1}.anniversary-composer__footer{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:18px;color:var(--ink-1)}.anniversary-layout{display:grid;grid-template-columns:minmax(320px,.95fr) minmax(0,1.3fr);gap:18px;margin-top:18px}.anniversary-feature{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:18px;padding:28px;min-height:290px;background:radial-gradient(circle at top right,rgba(112,163,244,.18),transparent 30%),linear-gradient(160deg,#ffffffbd,#f8f3ece6)}.anniversary-feature__note{margin-top:14px!important}.anniversary-counter{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:28px;color:#fff;padding:20px}.anniversary-counter strong{font-size:clamp(4rem,8vw,5.8rem);line-height:1;letter-spacing:-.04em}.anniversary-counter span{margin-top:10px;padding:6px 14px;border-radius:999px;background:#ffffff2e;font-weight:700}.anniversary-counter--future{background:linear-gradient(160deg,#58a0ef,#2a78dd)}.anniversary-counter--past{background:linear-gradient(160deg,#ffb148,#ff7a1f)}.anniversary-counter--today{background:linear-gradient(160deg,#ff7f8f,#ff4f67)}.anniversary-list{padding:18px}.anniversary-list__header{display:flex;align-items:end;justify-content:space-between;gap:16px;padding:10px 10px 16px}.anniversary-list__header h2{margin:0;font-size:1.3rem}.anniversary-list__header span,.anniversary-empty{color:var(--ink-1)}.anniversary-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:18px 16px;border-radius:22px;background:#ffffffb8;border:1px solid rgba(120,95,62,.1)}.anniversary-row+.anniversary-row{margin-top:12px}.anniversary-row__text h3{margin:0;font-size:1.18rem}.anniversary-row__text p,.anniversary-row__text small{display:block;margin-top:6px;color:var(--ink-1)}.anniversary-row__actions{display:flex;align-items:center;gap:14px}.anniversary-chip{min-width:138px;padding:14px 16px;border-radius:18px;color:#fff;text-align:center}.anniversary-chip strong{display:block;font-size:2rem;line-height:1}.anniversary-chip span{display:block;margin-top:6px;font-size:.95rem;letter-spacing:.08em}.anniversary-chip--future{background:linear-gradient(160deg,#5ea8f4,#2e80dc)}.anniversary-chip--past{background:linear-gradient(160deg,#ffb04f,#ff7d23)}.anniversary-chip--today{background:linear-gradient(160deg,#ff7b8f,#ff5067)}.anniversary-empty{padding:18px 12px 24px}.spring-module{position:relative;height:100vh;min-height:100vh;overflow:hidden;background:radial-gradient(circle at top left,rgba(255,212,229,.54),transparent 26%),radial-gradient(circle at 84% 18%,rgba(179,224,212,.5),transparent 30%),linear-gradient(180deg,#edf8f0,#eef6eb 54%,#f8f3ec)}.spring-module__canvas{position:absolute;top:0;right:0;bottom:0;left:0}.spring-module__canvas>div,.spring-module__canvas canvas{width:100%!important;height:100%!important;display:block}.spring-module__overlay{position:absolute;left:0;width:100%;z-index:20;pointer-events:none}.spring-module__overlay--top{top:0}.spring-module__overlay--bottom{bottom:0}.spring-module__header,.spring-module__actions,.spring-module__notice,.spring-module__selection{pointer-events:auto}.spring-module__header{display:flex;justify-content:space-between;gap:18px;padding:24px}.spring-module__header-actions{display:flex;align-items:flex-start;gap:12px}.spring-module__hero{max-width:560px;margin-left:auto;padding:26px 30px;border-radius:30px;border:1px solid rgba(255,255,255,.48);background:linear-gradient(160deg,#ffffff9e,#fff6f970);box-shadow:0 26px 68px #68524529;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.spring-module__hero .eyebrow{color:#65493f8f}.spring-module__hero h1{margin:14px 0 0;font-family:"Noto Serif SC",Songti SC,serif;font-size:clamp(2rem,5vw,4rem);line-height:1.04}.spring-module__hero p{margin:14px 0 0;color:#342a23b8;line-height:1.8}.spring-module__tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.spring-module__tag{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border-radius:999px;background:#ffffff9e;border:1px solid rgba(160,123,137,.12);color:#4a3a31bd;font-size:.84rem;font-weight:700}.spring-module__selection{display:flex;align-items:center;justify-content:center;gap:14px;width:fit-content;max-width:calc(100% - 48px);margin:0 auto 14px;padding:12px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.52);background:linear-gradient(180deg,#ffffffa8,#fff6f87a);box-shadow:0 20px 48px #71564924;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.spring-module__selection-meta{min-width:176px;text-align:center}.spring-module__selection-meta .eyebrow{justify-content:center;margin-bottom:4px}.spring-module__selection-meta strong,.spring-module__selection-meta small{display:block}.spring-module__selection-meta strong{color:#3f2f28db;font-size:.96rem;font-weight:800;line-height:1.35}.spring-module__selection-meta small{margin-top:3px;color:#3a2e268f;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase}.spring-module__selection-button{min-width:44px;padding:0;font-size:1rem}.spring-module__selection-button:disabled{opacity:.45;cursor:default;transform:none}.spring-module__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:0 24px 28px}.spring-module .button--ghost{background:#ffffff9e;border-color:#90717d1f;color:#43342ae6;box-shadow:0 14px 30px #6950421a}.spring-module .button--accent{background:linear-gradient(135deg,#ee97b8,#7ccab5);box-shadow:0 18px 34px #9c6d8c3d}.spring-module__notice{width:fit-content;max-width:calc(100% - 48px);margin:0 auto 14px;padding:10px 16px;border-radius:999px;background:#ffffffad;color:#4a3a31d6;box-shadow:0 14px 34px #674f411a;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.spring-module .gesture-panel{left:24px;right:auto;bottom:120px;align-items:flex-start}.spring-module .gesture-panel__preview{border-color:#ffffff6b;background:#fff8f975;box-shadow:0 20px 44px #664d432e}.spring-module .gesture-panel__preview--scatter{border-color:#ff9fc4f5;box-shadow:0 20px 44px #ee6ea138}.spring-module .gesture-panel__preview--gather{border-color:#7bd4c4f5;box-shadow:0 20px 44px #52b5a133}.spring-module .gesture-panel__preview--zoom{border-color:#ffd98afa;box-shadow:0 20px 44px #ecbd5a33}.spring-module .gesture-panel__canvas{background:#5947428a}.spring-module .gesture-panel__badge{background:#6d524a3d;color:#fff8f6e0}.spring-module .gesture-panel__overlay,.spring-module .gesture-panel__error{background:#664a44a8}.spring-module .gesture-panel__tips{align-items:flex-start;color:#5d483fc7;text-align:left}.tree-module{position:relative;height:100vh;min-height:100vh;background:#050510;overflow:hidden}.tree-module__canvas{position:absolute;top:0;right:0;bottom:0;left:0}.tree-module__canvas>div,.tree-module__canvas canvas{width:100%!important;height:100%!important;display:block}.tree-module__overlay{position:absolute;left:0;width:100%;z-index:20;pointer-events:none}.tree-module__overlay--top{top:0}.tree-module__overlay--bottom{bottom:0}.tree-module__header,.tree-module__actions,.tree-module__notice{pointer-events:auto}.tree-module__header{display:flex;justify-content:space-between;gap:18px;padding:24px}.tree-module__header-actions{display:flex;align-items:flex-start;gap:12px}.tree-module__hero{max-width:560px;margin-left:auto;padding:24px 28px;border-radius:28px;background:linear-gradient(160deg,#030713b8,#0c102470);border:1px solid rgba(141,188,255,.12);color:#f2f8fff0;box-shadow:0 20px 60px #050a185c}.tree-module__hero .eyebrow{color:#b8d1ffb8}.tree-module__hero h1{margin-top:14px;color:#fff;font-size:clamp(2rem,5vw,4rem)}.tree-module__hero p{margin:14px 0 0;color:#e3eeffbd;line-height:1.7}.tree-module__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:0 24px 28px}.tree-module .button--ghost{background:#ffffff1a;border-color:#ffffff24;color:#f5f9ffe0}.tree-module .button--accent{background:linear-gradient(135deg,#41a8ff,#16c8d7);box-shadow:0 18px 34px #1886d752}.tree-module__notice{width:fit-content;max-width:calc(100% - 48px);margin:0 auto 14px;padding:10px 16px;border-radius:999px;background:#ffffff1f;color:#f8fbffdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.gesture-panel{position:absolute;right:24px;bottom:116px;z-index:30;display:flex;flex-direction:column;align-items:flex-end;gap:12px;opacity:0;transform:translateY(8px);transition:opacity .24s ease,transform .24s ease}.gesture-panel--visible{opacity:1;transform:translateY(0)}.gesture-panel__preview{position:relative;width:200px;overflow:hidden;border-radius:20px;border:2px solid rgba(255,255,255,.16);background:#0009;box-shadow:0 18px 40px #01051457}.gesture-panel__preview--scatter{border-color:#ff81ade0;box-shadow:0 18px 40px #ff4b8f47}.gesture-panel__preview--gather{border-color:#73dbffe0;box-shadow:0 18px 40px #45c0ff47}.gesture-panel__preview--zoom{border-color:#ffdc63e6;box-shadow:0 18px 40px #f8bf463d}.gesture-panel__preview--error{border-color:#ff7171e6}.gesture-panel__video{position:absolute;opacity:0;pointer-events:none}.gesture-panel__canvas{width:200px;height:150px;display:block;background:#000000d9}.gesture-panel__overlay,.gesture-panel__error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:18px;background:#000000bd;color:#f3f8ffeb;text-align:center}.gesture-panel__badge{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;gap:8px;padding:10px 12px;background:#0000005c;color:#e8f1ffcc;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gesture-panel__tips{display:flex;flex-direction:column;align-items:flex-end;gap:6px;max-width:260px;color:#e8f1ffbd;font-size:.78rem;line-height:1.4;text-align:right}@media(max-width:900px){.home-hero,.module-grid,.module-grid--feature,.season-page__grid,.anniversary-layout,.anniversary-composer__grid,.anniversary-feature{grid-template-columns:1fr}.anniversary-counter{min-height:180px}.home-section__header,.anniversary-list__header{flex-direction:column;align-items:flex-start}}@media(max-width:720px){.home-page,.module-shell{padding:22px 16px 32px}.home-page__header,.module-shell__topbar,.tree-module__header,.spring-module__header{flex-direction:column;align-items:flex-start}.tree-module__header,.spring-module__header{padding:16px}.tree-module__hero,.spring-module__hero{width:100%;margin-left:0}.tree-module__actions,.spring-module__actions{padding:0 16px 20px}.gesture-panel{right:16px;bottom:122px}.spring-module .gesture-panel{left:16px;right:auto;bottom:96px}.spring-module__selection{max-width:calc(100% - 32px);padding-inline:12px}.spring-module__selection-meta{min-width:132px}.anniversary-row{grid-template-columns:1fr}.anniversary-row__actions{justify-content:space-between}}@supports (height: 100dvh){.spring-module,.tree-module{height:100dvh;min-height:100dvh}}
