:root{color-scheme:only light;font-family:Avenir Next,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--ink-strong: #11203a;--ink-soft: #59667b;--ink-faint: #8490a5;--surface: rgba(255, 247, 238, .94);--surface-strong: #fffaf4;--surface-muted: rgba(255, 255, 255, .2);--line: rgba(17, 32, 58, .08);--line-strong: rgba(17, 32, 58, .16);--accent: #ef6f48;--accent-strong: #d6522b;--accent-soft: #ffd7c7;--mint: #79c9b1;--mint-soft: #daf6ee;--sky-soft: #dce9ff;--danger: #c54444;--shadow: 0 22px 60px rgba(7, 14, 28, .18), 0 3px 12px rgba(7, 14, 28, .06)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-height:100svh;background:radial-gradient(circle at top left,rgba(255,203,170,.22),transparent 32%),radial-gradient(circle at top right,rgba(121,201,177,.22),transparent 28%),linear-gradient(180deg,#18304d,#0d1827 52%,#09111c);color:var(--ink-strong)}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}#root{display:flex;justify-content:center}.app-shell{width:min(100%,480px);min-height:100svh;padding:calc(18px + env(safe-area-inset-top)) 16px calc(28px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:16px}.card,.sheet{background:var(--surface);border:1px solid rgba(255,255,255,.45);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.card{border-radius:28px;padding:18px;animation:float-in .26s ease-out}.hero-card{background:radial-gradient(circle at top right,rgba(255,215,199,.82),transparent 36%),linear-gradient(180deg,#fff8f1fa,#fff2e9f5)}.compact-hero-card{display:flex;flex-direction:column;padding:16px;gap:12px;background:radial-gradient(circle at top right,rgba(255,215,199,.62),transparent 34%),linear-gradient(180deg,#fffaf5f7,#fff5edf5)}.calendar-topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:6px 4px}.calendar-topbar-center{min-width:0;text-align:center;color:#fffaf4}.calendar-topbar-label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fffaf4b8}.calendar-topbar-month{display:block;margin-top:2px;font-size:20px;font-weight:700;letter-spacing:-.03em}.calendar-nav-group,.calendar-inline-meta,.calendar-inline-note,.detail-panel-header,.cell-status-dots,.inline-detail-empty-copy{display:flex}.calendar-nav-group{gap:8px}.onboarding-hero{min-height:220px;justify-content:space-between}.boot-card{margin-top:max(16vh,72px)}.tip-card{background:radial-gradient(circle at top left,rgba(220,233,255,.85),transparent 42%),var(--surface)}.card-header,.sheet-header,.month-header,.hero-actions,.compact-hero-header,.compact-hero-actions,.compact-status-card,.sync-row,.settings-row,.cell-topline,.cell-illustration,.sheet-footer,.calendar-footer,.pill-row,.status-metrics,.hero-copy,.pair-status-art,.detail-summary-card,.detail-summary-copy,.compact-status-copy,.detail-card,.invite-banner,.weekday-row,.top-banner{display:flex}.hero-copy,.card,.detail-list,.form-stack,.field,.compact-hero-body,.month-title-block,.sheet,.sheet-footer,.detail-summary-card,.detail-summary-copy,.compact-status-copy,.settings-card{flex-direction:column}.hero-copy,.form-stack,.detail-list,.sheet,.compact-hero-body,.detail-summary-card,.detail-summary-copy,.settings-card{gap:14px}.card-header,.sheet-header,.hero-actions,.compact-hero-header,.sync-row,.settings-row,.calendar-footer{justify-content:space-between;align-items:center}.month-header{justify-content:space-between;align-items:flex-start;gap:12px}.compact-status-card,.detail-summary-card,.detail-summary-copy{align-items:center}.compact-hero-body{display:flex}.sheet-footer{gap:10px}.status-metrics{gap:12px}.pill-row{flex-wrap:wrap;gap:8px}.top-banner{padding:12px 14px;border-radius:18px;background:#fff1e82e;border:1px solid rgba(255,255,255,.18);color:#fff5ef;font-size:14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.calendar-link-button{min-height:32px;padding:0;border:none;background:transparent;color:var(--accent-strong);font-weight:700}.eyebrow{margin:0;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint)}h1,h2,p{margin:0}h1{font-size:clamp(28px,8vw,40px);line-height:1.05;letter-spacing:-.04em}.compact-hero-title{font-size:clamp(24px,7vw,30px)}h2{font-size:24px;line-height:1.1;letter-spacing:-.03em}.hero-text,.invite-help,.sheet-note,.detail-subtitle,.calendar-footer,.tip-list,.field-label{color:var(--ink-soft)}.hero-text,.invite-help,.sheet-note,.calendar-footer{font-size:14px}.metric-card,.detail-card,.settings-card{border:1px solid var(--line)}.metric-card{flex:1;min-width:0;padding:14px;border-radius:20px;background:#ffffffa3}.metric-card strong{display:block;margin-top:6px;font-size:24px}.metric-label{font-size:13px;color:var(--ink-faint)}.primary-button,.secondary-button,.danger-button,.icon-button,.nav-button,.segment{border:none;transition:transform .14s ease,opacity .14s ease,background .14s ease}.primary-button,.secondary-button,.danger-button{min-height:48px;padding:0 16px;border-radius:16px;font-weight:700}.primary-button{color:#fff;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%)}.secondary-button{color:var(--ink-strong);background:#11203a0f}.danger-button{color:#fff;background:linear-gradient(180deg,#d16464,#b74343)}.primary-button:active,.secondary-button:active,.danger-button:active,.icon-button:active,.nav-button:active,.segment:active{transform:translateY(1px)}.icon-button,.nav-button{min-width:44px;min-height:44px;padding:0 14px;border-radius:14px;color:var(--ink-strong);background:#11203a0f}.calendar-topbar-button,.calendar-nav-button{min-width:38px;min-height:38px;padding:0 12px;border-radius:999px;color:#fffaf4;background:#fffaf41f;border:1px solid rgba(255,250,244,.16)}.calendar-nav-button{padding:0;font-size:22px;line-height:1}.segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;border-radius:20px;background:#11203a0d}.segment{min-height:44px;border-radius:14px;color:var(--ink-soft);background:transparent}.segment.is-active{color:var(--ink-strong);background:#fff;box-shadow:0 8px 20px #11203a14}.field{gap:8px}.field-label{font-size:13px;font-weight:600}.text-input{width:100%;min-height:48px;padding:0 14px;border-radius:16px;border:1px solid var(--line-strong);background:#ffffffe0;color:var(--ink-strong);outline:none}.text-input:focus{border-color:#ef6f487a;box-shadow:0 0 0 4px #ef6f481f}.invite-input{letter-spacing:.4em;text-align:center;font-size:18px}.info-pill,.tiny-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.info-pill{min-height:34px;padding:0 12px;background:#11203a0f;color:var(--ink-soft);font-size:13px}.tiny-pill{min-height:22px;padding:0 9px;background:var(--accent-soft);color:var(--accent-strong);font-size:11px;font-weight:700}.invite-banner{gap:14px;align-items:center;justify-content:space-between;padding:14px;border-radius:20px;background:#ffffffa3;border:1px solid var(--line)}.invite-code{min-width:128px;padding:12px 14px;border-radius:16px;background:var(--ink-strong);color:#fff;text-align:center;font-size:22px;font-weight:800;letter-spacing:.22em}.sync-row,.calendar-footer{gap:12px;flex-wrap:wrap}.calendar-inline-meta,.calendar-inline-note{justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.calendar-inline-meta{margin-bottom:8px;color:var(--ink-faint);font-size:13px}.calendar-inline-note{margin-top:12px;color:var(--ink-soft);font-size:13px}.compact-hero-actions{gap:10px;flex-wrap:wrap}.compact-hero-actions .primary-button{flex:1 1 176px}.compact-hero-actions .secondary-button{flex:1 1 124px}.compact-status-card,.detail-summary-card{padding:14px;border-radius:22px;border:1px solid var(--line);background:#ffffffad}.compact-status-card{gap:12px;justify-content:flex-start}.compact-status-copy{gap:2px;min-width:0}.compact-status-copy strong,.detail-summary-copy strong{font-size:16px}.compact-status-copy span{color:var(--ink-soft);font-size:14px}.sync-row{color:var(--ink-faint);font-size:13px}.weekday-row{margin-top:16px;margin-bottom:10px;gap:8px}.weekday-row span{flex:1;text-align:center;font-size:12px;color:var(--ink-faint)}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.month-card.is-illustrated{padding:16px 14px 14px;background:radial-gradient(circle at top center,rgba(255,227,213,.48),transparent 36%),linear-gradient(180deg,#fffbf7fa,#fff5eef2)}.calendar-grid.is-illustrated{gap:6px}.calendar-cell{min-height:92px;padding:9px 8px;border-radius:18px;border:1px solid rgba(17,32,58,.06);background:#ffffffbd;text-align:left;display:flex;flex-direction:column;justify-content:space-between;gap:10px}.calendar-grid.is-illustrated .calendar-cell{min-height:72px;padding:6px 4px 8px;gap:6px;border-radius:22px;border-color:transparent;background:transparent;box-shadow:none}.calendar-cell.is-muted{opacity:.48}.calendar-cell.is-today{border-color:#ef6f485c}.calendar-grid.is-illustrated .calendar-cell.is-today{border-color:#ef6f482e}.calendar-cell.is-selected{background:#fff;box-shadow:0 10px 24px #11203a1a}.calendar-grid.is-illustrated .calendar-cell.is-selected{background:#ffffff9e;border-color:#11203a14;box-shadow:none}.cell-topline{align-items:center;gap:4px}.calendar-grid.is-illustrated .cell-topline{justify-content:center;min-height:34px}.cell-day-number{font-size:15px;font-weight:700}.day-badge{min-width:32px;min-height:32px;padding:0 8px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:var(--ink-strong)}.day-badge.is-selected:not(.is-today){background:#11203a0f}.day-badge.is-today{background:linear-gradient(180deg,#ff8c47,#ef6f48);color:#fff;box-shadow:0 8px 18px #ef6f4847}.cell-illustration{flex:1;justify-content:center}.cell-status-dots{justify-content:center;align-items:center;gap:7px;min-height:12px}.status-dot{width:6px;height:6px;border-radius:999px;display:inline-block}.status-dot.is-self.is-checked{background:var(--accent)}.status-dot.is-self.is-empty{background:#ef6f4833}.status-dot.is-friend.is-checked{background:#4ca58a}.status-dot.is-friend.is-empty{background:#4ca58a33}.cell-statuses{display:flex;gap:6px;flex-wrap:wrap}.status-chip{min-width:28px;min-height:24px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.status-chip.is-self.is-checked{background:var(--accent-soft);color:var(--accent-strong)}.status-chip.is-self.is-empty{background:#ef6f481f;color:var(--accent-strong)}.status-chip.is-friend.is-checked{background:var(--mint-soft);color:#267760}.status-chip.is-friend.is-empty{background:#79c9b129;color:#267760}.cell-footer{font-size:11px;color:var(--ink-faint)}.pair-status-art{justify-content:center;gap:8px;color:var(--ink-strong)}.pair-status-art.is-cell{min-height:34px}.pair-status-art.is-compact{min-width:82px}.pair-status-art.is-panel{min-height:58px}.pair-status-art.is-detail{min-height:72px}.pair-status-slot{width:34px;height:34px;border-radius:13px;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center}.calendar-grid.is-illustrated .pair-status-slot{width:28px;height:28px;border-radius:11px}.pair-status-art.is-compact .pair-status-slot{width:38px;height:38px;border-radius:15px}.pair-status-art.is-panel .pair-status-slot{width:46px;height:46px;border-radius:17px}.pair-status-art.is-detail .pair-status-slot{width:54px;height:54px;border-radius:18px}.pair-status-slot.is-self.is-checked{background:var(--accent-soft);color:var(--accent-strong)}.pair-status-slot.is-self.is-empty{background:#ef6f481f;color:var(--accent-strong)}.pair-status-slot.is-friend.is-checked{background:var(--mint-soft);color:#267760}.pair-status-slot.is-friend.is-empty{background:#79c9b129;color:#267760}.state-icon{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.9}.calendar-grid.is-illustrated .state-icon{width:15px;height:15px}.pair-status-art.is-compact .state-icon{width:20px;height:20px}.pair-status-art.is-panel .state-icon{width:24px;height:24px}.pair-status-art.is-detail .state-icon{width:28px;height:28px}.state-icon-heart{fill:currentColor;stroke:none}.pair-status-art.is-both{color:#df5b79}.pair-status-art.is-cell.is-both .state-icon-heart{width:28px;height:28px;filter:drop-shadow(0 4px 10px rgba(223,91,121,.18))}.pair-status-art.is-compact.is-both .state-icon-heart{width:40px;height:40px;filter:drop-shadow(0 8px 14px rgba(223,91,121,.18))}.pair-status-art.is-panel.is-both .state-icon-heart{width:48px;height:48px;filter:drop-shadow(0 10px 18px rgba(223,91,121,.18))}.pair-status-art.is-detail.is-both .state-icon-heart{width:60px;height:60px;filter:drop-shadow(0 12px 20px rgba(223,91,121,.18))}.calendar-footer{margin-top:14px}.tip-list{margin:0;padding-left:18px;display:grid;gap:8px;font-size:14px}.sheet-backdrop{position:fixed;inset:0;background:#09111c61;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:flex-end;padding:16px 16px calc(18px + env(safe-area-inset-bottom));z-index:20}.sheet{width:min(100%,480px);max-height:82svh;overflow:auto;border-radius:28px;padding:20px;gap:18px;animation:sheet-up .22s ease-out}.detail-list{display:grid;gap:10px}.detail-card,.settings-card{padding:14px;border-radius:20px;background:#ffffffb8}.detail-card{justify-content:space-between;align-items:center;gap:12px}.inline-detail-card{display:flex;flex-direction:column;gap:16px;padding:18px;background:radial-gradient(circle at top right,rgba(255,220,202,.5),transparent 34%),linear-gradient(180deg,#fff9f3fa,#fff3ebf5)}.inline-detail-card.is-empty{min-height:120px;justify-content:center;background:radial-gradient(circle at top center,rgba(255,228,213,.34),transparent 34%),linear-gradient(180deg,#fffbf7fa,#fff6f0f5)}.detail-panel-header{justify-content:space-between;align-items:flex-start;gap:12px}.detail-panel-title{display:flex;flex-direction:column;gap:4px}.inline-detail-empty-copy{flex-direction:column;align-items:center;gap:6px;text-align:center}.detail-summary-copy{gap:4px;text-align:center}.detail-panel-footer .primary-button{width:100%}.detail-name{font-weight:700}.settings-card{gap:10px}.settings-row-wrap{align-items:flex-start}.toast{position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom));transform:translate(-50%);min-width:min(88vw,360px);max-width:min(88vw,360px);padding:14px 16px;border-radius:18px;color:#fff;box-shadow:0 18px 40px #070e1c38;z-index:30}.toast-success{background:#286f59f2}.toast-error{background:#a43d3df2}.toast-info{background:#11203aeb}@keyframes float-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes sheet-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(min-width:520px){.app-shell{padding-top:28px}.calendar-cell{min-height:106px}.calendar-grid.is-illustrated .calendar-cell{min-height:82px}}
