body{overflow:auto;background:#4b2336}.birthday-page{position:relative;display:grid;align-items:end;justify-items:center;min-height:100dvh;overflow-x:hidden;padding:clamp(22px,5vh,64px) clamp(14px,4vw,48px);background:linear-gradient(to bottom,#260e1c0a,#260e1c1f 50%,#260e1cad),url(../images/birthday-gift-dream.png);background-position:center 44%;background-size:cover;color:#fff7ea;font-family:Noto Sans SC,Microsoft YaHei,PingFang SC,system-ui,sans-serif}.birthday-page:before{position:absolute;inset:0;content:"";background:radial-gradient(circle at 50% 30%,rgba(255,228,169,.1),transparent 28%),radial-gradient(circle at 50% 96%,rgba(255,158,188,.22),transparent 34%);pointer-events:none}.birthday-glow{position:absolute;border-radius:50%;filter:blur(48px);opacity:.14;pointer-events:none}.birthday-glow-one{top:-18vmax;left:-16vmax;width:42vmax;height:42vmax;background:#ffd58b}.birthday-glow-two{right:-20vmax;bottom:-18vmax;width:44vmax;height:44vmax;background:#ff8fb4}.birthday-glow-three{left:50%;top:48%;width:min(760px,86vw);height:min(760px,86vw);background:#ffd59d5c;transform:translate(-50%,-50%)}.birthday-stars{position:absolute;inset:0;pointer-events:none}.birthday-stars i{position:absolute;width:3px;height:3px;border-radius:50%;background:#fff6d8eb;box-shadow:0 0 16px #ffdd9ce0;animation:twinkle 3.4s ease-in-out infinite}.birthday-card{position:relative;z-index:1;display:grid;justify-items:center;width:min(720px,100%)}.birthday-blessing{display:grid;justify-items:center;gap:7px;width:min(620px,calc(100% - 18px));padding:0 clamp(10px,3vw,24px);border:0;border-radius:0;background:transparent;box-shadow:none;text-align:center}.birthday-blessing p{margin:0;color:#fff9ef;font-family:Songti SC,STSong,"Noto Serif SC",serif;font-size:clamp(22px,3.2vw,34px);font-weight:500;letter-spacing:0;line-height:1.38;text-shadow:0 2px 16px rgba(61,18,39,.58),0 0 20px rgba(255,220,163,.18)}.birthday-blessing p:nth-child(2){color:#ffe1ad;font-size:clamp(28px,4.2vw,46px)}@keyframes twinkle{0%,to{opacity:.28;transform:scale(.75)}50%{opacity:1;transform:scale(1.2)}}@media(max-width:760px){.birthday-page{padding:18px 10px 46px;background-position:center top}.birthday-card{width:100%}.birthday-blessing{width:min(390px,calc(100% - 12px))}}@media(max-width:420px){.birthday-page{padding:14px 10px 42px}.birthday-blessing{gap:5px;padding:15px 14px}.birthday-blessing p{font-size:20px}.birthday-blessing p:nth-child(2){font-size:30px}}:root{color-scheme:dark;--night: #061326;--night-soft: rgba(7, 22, 40, .86);--surface: rgba(8, 24, 44, .9);--surface-soft: rgba(12, 35, 57, .72);--line: rgba(180, 205, 220, .2);--line-strong: rgba(230, 204, 163, .52);--ink: #f4ead8;--muted: #93aabd;--gold: #e6bf88;--gold-bright: #ffd091;--aqua: #86d8cf;--danger: #ef9f96;font-family:Noto Sans SC,Microsoft YaHei,PingFang SC,system-ui,sans-serif;background:var(--night);color:var(--ink)}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;height:100%;margin:0}body{overflow:hidden;background:var(--night)}button,input,select,textarea{font:inherit}button{color:inherit}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}.app-shell{position:relative;display:grid;grid-template-columns:clamp(220px,18vw,286px) minmax(0,1fr);grid-template-rows:86px minmax(0,1fr) clamp(236px,29vh,302px);width:100%;height:100dvh;overflow:hidden;isolation:isolate;background-color:var(--night);background-image:url(../images/night-sky.png);background-position:center;background-size:cover}.app-shell:before{position:absolute;inset:0;z-index:-1;content:"";background:#030e1d61;pointer-events:none}.app-header{grid-column:1 / -1;display:grid;grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr);align-items:center;gap:24px;padding:16px clamp(22px,3vw,54px);border-bottom:1px solid rgba(177,201,218,.1);background:#04112085;backdrop-filter:blur(14px);z-index:20}.brand{display:flex;flex-direction:column;align-items:flex-start;gap:1px;width:fit-content;padding:0;border:0;background:transparent;cursor:pointer}.brand strong{color:var(--gold);font-family:STKaiti,KaiTi,Songti SC,serif;font-size:clamp(28px,2.2vw,40px);font-weight:500;letter-spacing:.08em;line-height:1;text-shadow:0 0 24px rgba(230,191,136,.26)}.brand span{margin-left:3px;color:var(--muted);font-family:Songti SC,STSong,serif;font-size:12px;letter-spacing:.32em}.header-stats{display:flex;align-items:center;gap:20px;color:var(--muted);font-size:12px;letter-spacing:.12em}.header-stats span{display:flex;align-items:baseline;gap:6px;white-space:nowrap}.header-stats strong{color:var(--ink);font-family:Songti SC,STSong,serif;font-size:24px;font-weight:500}.header-stats i{width:1px;height:24px;background:var(--line)}.header-actions{display:flex;justify-content:flex-end;gap:8px}.header-actions button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:42px;padding:0 14px;border:1px solid var(--line);border-radius:999px;background:#081a2da8;color:#b7c8d5;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.header-actions button:hover{border-color:var(--line-strong);color:var(--ink);background:#122a40d1}.header-actions svg{width:18px;height:18px}.header-actions .header-add{border-color:#e6bf8880;background:#dcb982;color:#10233a;font-weight:700}.timeline-panel{position:relative;grid-column:1;grid-row:2 / 4;display:flex;flex-direction:column;min-height:0;padding:22px 16px 112px 24px;border-right:1px solid rgba(177,201,218,.12);background:#0411206b;backdrop-filter:blur(12px);z-index:8}.timeline-heading{display:flex;align-items:center;justify-content:space-between;padding:0 4px 17px 2px}.timeline-heading>div{display:flex;align-items:center;gap:10px;color:var(--gold);font-family:Songti SC,STSong,serif;letter-spacing:.1em}.timeline-heading i{width:32px;height:1px;background:var(--line-strong)}.play-button,.story-actions button{display:grid;place-items:center;width:34px;height:34px;padding:0;border:1px solid var(--line);border-radius:50%;background:var(--surface-soft);color:var(--gold);cursor:pointer}.timeline-list{position:relative;flex:1;min-height:0;overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(230,191,136,.35) transparent}.timeline-list:before{position:absolute;top:10px;bottom:10px;left:61px;width:1px;content:"";background:#a2bbcc45}.timeline-entry{position:relative;display:grid;grid-template-columns:45px 12px 78px minmax(0,1fr);align-items:center;gap:8px;width:100%;min-height:92px;padding:9px 8px 9px 0;border:1px solid transparent;border-radius:8px;background:transparent;text-align:left;cursor:pointer}.timeline-entry.is-selected{border-color:#e6bf8873;background:#10283fbd}.timeline-date{display:flex;flex-direction:column;align-items:flex-end;color:var(--muted);font-family:Songti SC,STSong,serif}.timeline-date strong{color:var(--ink);font-size:16px;font-weight:500}.timeline-date small{margin-top:3px;font-size:12px}.timeline-dot{position:relative;z-index:1;width:8px;height:8px;border:1px solid var(--gold);border-radius:50%;background:var(--night)}.is-selected .timeline-dot{background:var(--gold-bright);box-shadow:0 0 14px var(--gold)}.timeline-thumb{display:block;width:78px;height:58px;overflow:hidden;border:1px solid rgba(230,191,136,.35);border-radius:5px;background:#13283d}.timeline-thumb img{width:100%;height:100%;object-fit:cover}.timeline-photo-empty{width:100%;height:100%;background:#234356c2}.timeline-copy{display:flex;flex-direction:column;min-width:0;gap:4px}.timeline-copy strong{overflow:hidden;font-family:Songti SC,STSong,serif;font-size:15px;font-weight:500;text-overflow:ellipsis;white-space:nowrap}.timeline-copy small{color:var(--muted);font-size:11px;letter-spacing:.1em}.timeline-scrubber{display:grid;grid-template-columns:36px 1fr;align-items:center;gap:8px;padding:13px 4px 0;color:var(--muted);font-size:11px}.timeline-scrubber input{accent-color:var(--gold)}.timeline-caret{align-self:center;margin-top:10px;color:var(--gold)}.map-stage{position:relative;grid-column:2;grid-row:2;min-width:0;min-height:0;overflow:hidden}.map-canvas-shell,.map-canvas{width:100%;height:100%}.map-canvas{position:relative}.qa-map-snapshot{position:absolute;inset:0;width:100%;height:100%;object-fit:fill;mix-blend-mode:screen}.map-canvas canvas{display:block;cursor:grab}.map-canvas canvas:active{cursor:grabbing}.map-back,.map-location{position:absolute;z-index:5;top:22px;display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:999px;background:#051425c7;backdrop-filter:blur(12px)}.map-back{left:24px;min-height:40px;padding:0 15px;cursor:pointer}.map-location{right:26px;padding:8px 16px;pointer-events:none}.map-location svg{color:var(--gold)}.map-location div{display:flex;flex-direction:column}.map-location span{color:var(--muted);font-size:10px;letter-spacing:.16em}.map-location strong{font-family:Songti SC,STSong,serif;font-size:17px;font-weight:500}.map-loading,.archive-loading,.archive-error{position:absolute;z-index:10;left:50%;top:50%;padding:10px 16px;border:1px solid var(--line);border-radius:999px;background:#041120d6;color:var(--muted);transform:translate(-50%,-50%);backdrop-filter:blur(10px)}.municipality-hint{position:absolute;left:50%;bottom:18px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 18px;border:1px solid var(--line);border-radius:8px;background:#041120d6;transform:translate(-50%)}.municipality-hint span{color:var(--muted);font-size:11px}.map-fallback{display:grid;place-items:center;align-content:center;gap:20px;width:100%;height:100%;padding:30px;color:var(--muted);text-align:center}.fallback-region-list{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.fallback-region-list button{padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:var(--surface);cursor:pointer}.stats-rail{position:absolute;z-index:12;left:34px;bottom:24px;display:flex;flex-direction:column;gap:11px;color:var(--muted);font-family:Songti SC,STSong,serif;pointer-events:none}.stats-rail span{display:flex;align-items:center;gap:8px}.stats-rail svg{color:var(--gold)}.stats-rail strong{color:var(--ink);font-size:20px;font-weight:500}.story-panel{position:relative;z-index:10;grid-column:2;grid-row:3;display:grid;grid-template-columns:minmax(300px,42%) 1fr;gap:26px;min-height:0;margin:0 clamp(18px,2.5vw,44px) 18px;padding:14px;border:1px solid rgba(161,187,204,.26);border-radius:14px;background:#051426eb;box-shadow:0 24px 70px #00071275;backdrop-filter:blur(18px)}.story-panel:before{position:absolute;top:8px;left:50%;width:52px;height:4px;border-radius:999px;content:"";background:#aec5d547;transform:translate(-50%)}.story-photo{position:relative;min-height:0;overflow:hidden;border:1px solid rgba(230,191,136,.28);border-radius:9px;background:#10283d}.story-photo img{width:100%;height:100%;object-fit:cover}.story-photo-empty{display:grid;place-items:center;align-content:center;gap:8px;width:100%;height:100%;color:var(--muted)}.story-photo-empty svg{width:30px;height:30px;color:var(--gold)}.photo-count{position:absolute;right:10px;bottom:10px;padding:5px 9px;border-radius:999px;background:#020c18bd;font-size:11px}.story-content{display:flex;flex-direction:column;min-width:0;padding:13px 14px 6px 0}.story-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.story-kicker{color:var(--gold);font-family:Songti SC,STSong,serif;font-size:14px;letter-spacing:.12em}.story-content h2,.story-empty h2{margin:7px 0 0;font-family:Songti SC,STSong,serif;font-size:clamp(22px,2vw,30px);font-weight:500}.story-actions{display:flex;gap:7px}.story-text{flex:1;max-width:780px;margin:15px 0 12px;overflow:auto;color:#c1ccd4;font-family:Songti SC,STSong,serif;font-size:15px;line-height:1.9}.story-meta{display:flex;align-items:center;gap:18px;padding-top:12px;border-top:1px solid var(--line);color:var(--muted);font-size:12px}.story-meta>span{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.story-meta svg{width:17px;height:17px;color:var(--gold)}.mood-orb{width:9px;height:9px;border-radius:50%;background:var(--aqua);box-shadow:0 0 12px #86d8cfb3}.record-again{display:inline-flex;align-items:center;gap:6px;min-height:38px;margin-left:auto;padding:0 18px;border:0;border-radius:999px;background:var(--gold);color:#14263b;font-weight:700;cursor:pointer}.story-empty{grid-template-columns:1fr auto;align-items:center;padding:28px 34px}.story-empty p{max-width:620px;margin:10px 0 0;color:var(--muted);line-height:1.7}.primary-action,.ghost-action,.danger-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;padding:0 20px;border-radius:999px;cursor:pointer}.primary-action{border:0;background:var(--gold);color:#12253b;font-weight:700}.ghost-action{border:1px solid var(--line);background:transparent;color:var(--muted)}.danger-action{border:1px solid rgba(239,159,150,.5);background:#6423276b;color:#ffd5cf}.modal-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:22px;background:#000712c2;backdrop-filter:blur(15px)}.trip-editor,.data-manager{width:min(760px,100%);max-height:min(900px,calc(100dvh - 44px));overflow:auto;border:1px solid var(--line-strong);border-radius:16px;background:#0a2037;box-shadow:0 34px 90px #00040cb3}.trip-editor>header,.data-manager>header{position:sticky;top:0;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:24px 28px 18px;border-bottom:1px solid var(--line);background:#0a2037}.trip-editor header span,.data-manager header span{color:var(--gold);font-size:10px;letter-spacing:.25em}.trip-editor h2,.data-manager h2{margin:6px 0 0;font-family:Songti SC,STSong,serif;font-size:28px;font-weight:500}.trip-editor header button,.data-manager header button{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);border-radius:50%;background:transparent;cursor:pointer}.trip-editor form{display:grid;gap:18px;padding:22px 28px 28px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.trip-editor label{display:grid;gap:7px;color:#afc0ce;font-size:12px}.trip-editor input,.trip-editor select,.trip-editor textarea{width:100%;border:1px solid rgba(161,187,204,.24);border-radius:8px;background:#071a2f;color:var(--ink)}.trip-editor input,.trip-editor select{min-height:44px;padding:0 12px}.trip-editor textarea{min-height:126px;resize:vertical;padding:12px;line-height:1.7}.photo-editor{display:grid;gap:9px;color:#afc0ce;font-size:12px}.photo-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:9px}.editor-photo,.photo-picker{position:relative;display:grid;place-items:center;align-content:center;gap:4px;aspect-ratio:1;min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#0d2a43;color:var(--muted);cursor:pointer}.editor-photo img{width:100%;height:100%;object-fit:cover}.editor-photo>svg:last-child{position:absolute;top:5px;right:5px;padding:3px;border-radius:50%;background:#020a14c7}.editor-photo.is-removed{opacity:.3}.new-photo{padding:8px}.new-photo span{width:100%;overflow:hidden;font-size:9px;text-overflow:ellipsis;white-space:nowrap}.photo-picker input{position:absolute;width:1px;height:1px;opacity:0}.form-error,.data-status{margin:0;color:#ffc1b8;font-size:13px}.trip-editor footer{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.data-manager{width:min(620px,100%);padding-bottom:28px}.data-manager>p,.data-manager>.data-status{margin:20px 28px 0;color:var(--muted);line-height:1.7}.data-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:20px 28px 0}.data-actions button{display:grid;justify-items:start;gap:7px;min-height:130px;padding:18px;border:1px solid var(--line);border-radius:12px;background:#0c2943;text-align:left;cursor:pointer}.data-actions svg{width:28px;height:28px;color:var(--gold)}.data-actions strong{font-family:Songti SC,STSong,serif;font-size:18px;font-weight:500}.data-actions span{color:var(--muted);font-size:12px}.backup-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:20px 28px 0;padding:16px;border:1px solid var(--line-strong);border-radius:12px;background:#071a2f}.backup-preview div{display:flex;flex-direction:column;gap:4px}.backup-preview span,.backup-preview p{color:var(--muted);font-size:11px}.backup-preview strong{font-family:Songti SC,STSong,serif;font-size:17px;font-weight:500}.backup-preview p,.backup-preview button{grid-column:1 / -1}.toast{position:fixed;z-index:130;left:50%;bottom:26px;padding:11px 18px;border:1px solid var(--line-strong);border-radius:999px;background:#102a42;color:var(--ink);box-shadow:0 12px 36px #00040c80;transform:translate(-50%)}.calm-mode .map-canvas{opacity:.86}.calm-mode .brand strong,.calm-mode .is-selected .timeline-dot,.calm-mode .mood-orb{text-shadow:none;box-shadow:none}@media(max-width:1100px){.app-header{grid-template-columns:1fr auto}.header-stats{display:none}.timeline-panel{padding-left:14px}.timeline-entry{grid-template-columns:40px 10px 62px minmax(0,1fr)}.timeline-list:before{left:50px}.timeline-thumb{width:62px;height:50px}.story-meta{gap:10px}.story-meta>span:first-child{display:none}}@media(max-width:760px){.app-shell{display:grid;grid-template-columns:1fr;grid-template-rows:68px minmax(0,1fr) minmax(245px,39vh)}.app-header{position:relative;grid-column:1;grid-row:1;grid-template-columns:1fr;gap:8px;padding:11px 14px}.brand strong{font-size:27px}.brand span{display:none}.header-actions{position:absolute;top:16px;right:auto;left:150px;width:116px;gap:4px;justify-content:flex-start}.header-actions button{width:36px;min-height:36px;padding:0}.header-actions button span{display:none}.timeline-panel{position:absolute;z-index:18;top:72px;left:10px;right:10px;display:block;height:105px;padding:0;border:1px solid var(--line);border-radius:12px;background:#041120bd;overflow:hidden}.timeline-heading,.timeline-scrubber,.timeline-caret{display:none}.timeline-list{display:flex;gap:6px;height:100%;padding:7px;overflow-x:auto}.timeline-list:before{display:none}.timeline-entry{flex:0 0 156px;grid-template-columns:58px 1fr;grid-template-rows:1fr auto;min-height:88px;padding:5px}.timeline-date,.timeline-dot{display:none}.timeline-thumb{grid-row:1 / 3;width:58px;height:72px}.map-stage{grid-column:1;grid-row:2}.map-back{top:118px;left:12px}.map-location{top:118px;right:12px}.stats-rail{display:none}.story-panel{grid-column:1;grid-row:3;grid-template-columns:38% minmax(0,1fr);gap:12px;margin:0;padding:14px 12px 12px;border-right:0;border-bottom:0;border-left:0;border-radius:18px 18px 0 0}.story-content{padding:5px 0 0}.story-kicker{font-size:11px}.story-content h2,.story-empty h2{font-size:20px}.story-text{display:-webkit-box;flex:none;overflow:hidden;max-height:64px;margin:9px 0;font-size:13px;line-height:1.65;-webkit-box-orient:vertical;-webkit-line-clamp:3}.story-meta{align-items:stretch;gap:6px}.story-meta>span{display:none}.record-again{flex:1;min-width:0;margin:0}.story-empty{grid-template-columns:1fr;align-content:center;padding:28px 22px}.story-empty .primary-action{width:fit-content}.form-grid{grid-template-columns:1fr}.trip-editor,.data-manager{max-height:calc(100dvh - 20px)}.trip-editor>header,.data-manager>header,.trip-editor form{padding-right:18px;padding-left:18px}.photo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.data-actions,.backup-preview{grid-template-columns:1fr}.backup-preview div,.backup-preview p,.backup-preview button{grid-column:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
