@import"https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700;800&display=swap";@font-face{font-family:Jinghua;src:url(/jinghua-subset.woff2) format("woff2");font-display:swap;font-weight:400;font-style:normal}:root{--c-bg: #f7f1eb;--c-bg-soft: #fffaf7;--c-card: rgba(255, 252, 249, .94);--c-card-strong: #ffffff;--c-text: #221815;--c-text-soft: #6f5d56;--c-muted: #a9978e;--c-line: #eaded6;--c-accent: #d75c4b;--c-accent-strong: #bf4a3d;--c-accent-soft: #f7d8d1;--c-accent-pink: #c9476a;--c-male: #4c7fbe;--c-female: #c8578d;--shadow-soft: 0 8px 30px rgba(130, 88, 63, .08);--shadow-card: 0 12px 32px rgba(78, 45, 29, .08);--radius-xl: 28px;--radius-lg: 22px;--radius-md: 18px;--radius-sm: 14px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:focus{outline:none}html{background:var(--c-bg)}body{min-height:100vh;font-family:Noto Sans SC,sans-serif;color:var(--c-text);background:radial-gradient(circle at top,rgba(215,92,75,.14),transparent 28%),linear-gradient(180deg,#fff8f4 0%,var(--c-bg) 100%);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body,button,input,select,textarea{font:inherit}button,input,select,textarea{border:0}button{background:none;color:inherit}img{display:block;max-width:100%}#root{min-height:100vh}:focus-visible{outline:3px solid rgba(215,92,75,.2);outline-offset:2px}.app{min-height:100vh;max-width:560px;margin:0 auto;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.page{min-height:100vh}.content,.form-shell{padding:18px 16px 0}.eyebrow,.header-eyebrow{font-size:12px;line-height:1.3;letter-spacing:.14em;text-transform:uppercase;color:var(--c-accent)}.section-title{font-size:16px;font-weight:700;line-height:1.35}.section-sub{margin-top:4px;font-size:13px;line-height:1.5;color:var(--c-text-soft)}.header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;justify-content:space-between;padding:calc(12px + env(safe-area-inset-top,0px)) 16px 14px;background:#f7f1ebd6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(234,222,214,.9)}.header-title{font-size:20px;font-weight:800;line-height:1.2}.header-back,.header-action,.card-actions button{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .18s ease,color .18s ease,transform .18s ease}.header-back{width:38px;height:38px;flex:0 0 auto;border-radius:999px;background:#ffffff9e;border:1px solid rgba(234,222,214,.95)}.header-action{min-height:38px;padding:0 14px;border-radius:999px;background:#ffffffb8;border:1px solid rgba(234,222,214,.95);color:var(--c-accent);font-size:13px;font-weight:700}.header-action--muted{color:var(--c-text-soft)}.entry-page{display:flex;align-items:center;padding:28px 16px 32px}.entry{width:100%;display:grid;gap:18px;justify-items:center}.entry-brand{width:128px;height:128px;display:inline-flex;align-items:center;justify-content:center;border-radius:34px;background:linear-gradient(180deg,#ffffffd9,#fff7f2f2);box-shadow:var(--shadow-soft)}.entry-copy{width:100%;display:flex;justify-content:center}.entry-copy-frame{width:min(100%,360px);display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;column-gap:18px;padding:0 8px 0 12px}.entry-title{position:relative;justify-self:end;display:flex;flex-direction:column;align-items:center;gap:8px;font-family:Jinghua,"Noto Serif SC",Songti SC,serif;font-size:clamp(34px,10vw,48px);line-height:1;font-weight:400;letter-spacing:.03em;color:#2d201d;transform:translateY(-44px)}.entry-title:before{content:"";position:absolute;top:0;bottom:0;left:-18px;width:1px;background:#c9476a2e}.entry-title span{display:block}.entry-sub{max-width:20em;font-size:15px;line-height:1.65;color:var(--c-text-soft)}.entry-poem{width:auto;margin-top:0;padding:10px 18px 0 0;align-self:end;text-align:left;font-family:Jinghua,"Noto Serif SC",Songti SC,serif;color:var(--c-text)}.entry-poem-line{font-size:18px;line-height:1.8;letter-spacing:.02em;font-weight:400}.entry-poem-cite{display:block;margin-top:10px;font-family:Jinghua,"Noto Serif SC",Songti SC,serif;font-size:11px;line-height:1.5;letter-spacing:.04em;color:var(--c-text-soft);font-style:normal}.entry-panel,.form-section,.detail-card,.detail-summary,.stat-card,.code-card,.card,.photo-upload-area{background:var(--c-card);border:1px solid rgba(234,222,214,.95);box-shadow:var(--shadow-card)}.entry-panel,.form-section,.detail-card,.detail-summary,.code-card{border-radius:var(--radius-xl)}.entry-panel{width:min(100%,420px);margin-top:18px;padding:18px}.field-label,.field label{display:block;font-size:13px;font-weight:700;line-height:1.3;color:var(--c-text)}.field-hint{margin-top:8px;font-size:12px;line-height:1.5;color:var(--c-text-soft)}.entry-input,.field input,.field select,.field textarea{width:100%;margin-top:10px;padding:15px 16px;border-radius:var(--radius-md);border:1.5px solid var(--c-line);background:#ffffffd6;color:var(--c-text);font-size:16px;line-height:1.4;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.entry-input::placeholder,.field input::placeholder,.field textarea::placeholder{color:var(--c-muted)}.entry-input:focus,.field input:focus,.field select:focus,.field textarea:focus{border-color:#d75c4bb8;box-shadow:0 0 0 4px #d75c4b14}.entry-input{text-align:center;letter-spacing:.2em}.entry-btn,.form-btn,.primary-action{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;padding:0 18px;border-radius:18px;background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-pink) 100%);color:#fff;font-size:15px;font-weight:800;letter-spacing:.02em;cursor:pointer;box-shadow:0 12px 22px #c9476a38;transition:transform .18s ease,filter .18s ease}.entry-btn,.entry-err{margin-top:14px}.form-btn:disabled,.entry-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.form-btn.danger{background:#fff;color:#af4337;border:1.5px solid rgba(215,92,75,.26);box-shadow:none}.entry-err{font-size:13px;line-height:1.45;color:#b43d38}.section-intro{margin-bottom:14px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}.stat-card{min-height:88px;border-radius:22px;padding:14px 12px;display:flex;flex-direction:column;justify-content:space-between}.stat-value{font-size:26px;line-height:1;font-weight:800}.stat-label{font-size:12px;color:var(--c-text-soft)}.tabs{position:sticky;top:calc(66px + env(safe-area-inset-top,0px));z-index:15;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;padding:6px;border-radius:999px;background:#fffcf9d1;border:1px solid rgba(234,222,214,.95);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tabs--three{grid-template-columns:1fr 1fr 1fr}.tab{min-height:42px;border-radius:999px;font-size:14px;font-weight:700;color:var(--c-text-soft);cursor:pointer;transition:background-color .18s ease,color .18s ease}.tab.active{color:#fff;background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-pink) 100%);box-shadow:0 10px 18px #d75c4b33}.section-head{display:grid;gap:12px;margin-bottom:14px}.list{display:grid;gap:12px}.card,.code-card{width:100%;padding:14px;text-align:left}.card{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;border-radius:24px;cursor:pointer}.card-avatar{width:58px;height:58px;overflow:hidden;border-radius:20px;background:linear-gradient(180deg,#f4ebe4,#efe3da);display:flex;align-items:center;justify-content:center}.card-avatar img{width:100%;height:100%;object-fit:cover}.card-info{min-width:0}.card-name{display:flex;align-items:center;gap:6px;font-size:19px;font-weight:800;line-height:1.25}.card-tags,.code-guests{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.card-tag,.code-guest-tag{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#f7d8d16b;color:var(--c-text-soft);font-size:12px;font-weight:600}.card-cta{font-size:12px;font-weight:700;color:var(--c-accent)}.card-actions{display:flex;align-items:center}.card-actions button{width:40px;height:40px;border-radius:14px;background:#f7d8d157;border:1px solid rgba(234,222,214,.95);color:var(--c-text-soft)}.gender-dot{display:inline-flex;align-items:center;justify-content:center}.gender-dot.male{color:var(--c-male)}.gender-dot.female{color:var(--c-female)}.detail-page{padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}.detail-hero{margin:16px 16px 0;min-height:180px;overflow:hidden;border-radius:30px;background:linear-gradient(180deg,#fff7f2f2,#f4e8dff2);border:1px solid rgba(234,222,214,.95);box-shadow:var(--shadow-card)}.detail-hero--photo{padding:10px}.detail-hero img{width:100%;height:auto;max-height:72vh;object-fit:contain;border-radius:24px;background:#ffffffb3}.detail-hero--empty{min-height:148px}.detail-photo-placeholder{min-height:148px;display:grid;place-items:center;gap:10px;color:var(--c-text-soft);font-size:14px}.detail-avatar-placeholder{width:68px;height:68px;display:grid;place-items:center;border-radius:24px;background:#ffffffb8}.detail-body{padding:14px 16px 0}.detail-summary{margin-top:12px;position:relative;padding:18px}.detail-name-row{display:flex;align-items:center;gap:8px}.detail-name{font-size:28px;line-height:1.1;font-weight:800}.detail-card{margin-top:12px;padding:18px}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 10px;margin-top:14px}.detail-item{min-width:0}.detail-label{font-size:12px;line-height:1.4;color:var(--c-muted)}.detail-value{margin-top:4px;font-size:16px;font-weight:700;line-height:1.45}.detail-intro-text{margin-top:12px;font-size:15px;line-height:1.8;color:var(--c-text-soft);white-space:pre-wrap}.form-shell{display:grid;gap:12px}.form-section{padding:18px}.field{margin-top:14px}.field:first-of-type{margin-top:10px}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field textarea{min-height:116px;resize:vertical}.check-list{overflow:hidden;border-radius:20px;border:1px solid rgba(234,222,214,.95);background:#ffffffb8}.check-empty{padding:16px;font-size:13px;color:var(--c-text-soft);text-align:center}.check-item{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(234,222,214,.95);font-size:15px;color:var(--c-text);cursor:pointer}.check-item:last-child{border-bottom:none}.check-item input{width:18px;height:18px;accent-color:var(--c-accent)}.photo-upload-area{width:100%;min-height:120px;padding:20px;border-radius:22px;cursor:pointer;color:var(--c-text-soft);font-size:14px}.photo-preview{position:relative;border-radius:22px;background:linear-gradient(180deg,#fff7f2f2,#f4e8dff2)}.photo-preview img{width:100%;height:auto;max-height:60vh;object-fit:contain;border-radius:22px}.photo-preview-remove{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:999px;background:#221815ad;color:#fff;cursor:pointer}.form-footer{position:sticky;bottom:0;display:grid;gap:10px;margin-top:2px;padding:10px 0 calc(8px + env(safe-area-inset-bottom,0px));background:linear-gradient(180deg,#f7f1eb00,#f7f1ebeb 24%,#f7f1ebfa)}.code-card{border-radius:24px;cursor:pointer}.code-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.code-label{font-size:12px;color:var(--c-text-soft)}.code-value{margin-top:4px;font-size:28px;line-height:1;font-weight:800;letter-spacing:.12em;font-variant-numeric:tabular-nums}.code-meta{margin-top:10px;font-size:13px;line-height:1.5;color:var(--c-text-soft)}.empty{padding:72px 24px;text-align:center;font-size:14px;line-height:1.7;color:var(--c-text-soft)}.confirm-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;background:#2218156b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:confirm-fade .18s ease}.confirm-card{width:100%;max-width:340px;padding:22px 22px 18px;border-radius:var(--radius-xl);background:var(--c-card-strong);border:1px solid rgba(234,222,214,.95);box-shadow:0 24px 48px #4e2d1d38;animation:confirm-pop .22s cubic-bezier(.2,.9,.3,1.1)}.confirm-title{font-size:18px;font-weight:800;line-height:1.3;color:var(--c-text)}.confirm-message{margin-top:10px;font-size:14px;line-height:1.65;color:var(--c-text-soft)}.confirm-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}.confirm-btn{min-height:46px;padding:0 14px;border-radius:16px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .18s ease,filter .18s ease,background-color .18s ease}.confirm-btn--ghost{background:#f7f1ebe6;color:var(--c-text-soft);border:1.5px solid var(--c-line)}.confirm-btn--ghost:hover{background:#fff;color:var(--c-text)}.confirm-btn--danger{background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-pink) 100%);color:#fff;box-shadow:0 10px 20px #c9476a38}.confirm-btn--danger:hover{filter:brightness(1.03);transform:translateY(-1px)}.confirm-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}@keyframes confirm-fade{0%{opacity:0}to{opacity:1}}@keyframes confirm-pop{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.toast{position:fixed;left:50%;bottom:calc(28px + env(safe-area-inset-bottom,0px));z-index:40;transform:translate(-50%);max-width:calc(100vw - 32px);padding:12px 18px;border-radius:999px;background:#221815e6;color:#fff;font-size:13px;line-height:1.4;box-shadow:0 10px 28px #22181538;animation:toast-in .22s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.header-back:hover,.header-action:hover,.card-actions button:hover,.tab:hover,.card:hover,.code-card:hover,.photo-upload-area:hover{transform:translateY(-1px)}.entry-btn:hover,.form-btn:hover,.primary-action:hover{filter:brightness(1.02);transform:translateY(-1px)}@media (max-width: 360px){.entry-copy-frame{width:100%;column-gap:12px;padding-left:6px;padding-right:4px}.entry-title{font-size:31px;gap:6px;transform:translateY(-32px)}.entry-title:before{left:-12px}.entry-poem{padding-top:0;padding-right:12px}.entry-poem-line{font-size:16px}.stats-grid,.field-grid,.detail-grid{grid-template-columns:1fr}.code-value{font-size:24px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
