:root{--bg:#f9f3f1;--surface:#fff;--surface-soft:#fff8f6;--ink:#3d2b3d;--ink-soft:#6f6072;--accent:#e16aa3;--accent-strong:#c74486;--accent-soft:#e16aa329;--mint:#74b3ce;--gold:#f4b76b;--stroke:#3d2b3d1f;--shadow:0 24px 60px #3d2b3d1f;--font-body:"Space Grotesk", "Work Sans", sans-serif;--font-display:"Fraunces", "DM Serif Display", serif;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}*{box-sizing:border-box}body{font-family:var(--font-body);color:var(--ink);background:radial-gradient(circle at top,#fff8f3 0%,#f9f3f1 40%,#f4edf0 100%);min-height:100vh;margin:0}body.modal-open{overflow:hidden}img{max-width:100%;display:block}button,input{font:inherit}#root{min-height:100vh}.page{width:min(1400px,94vw);margin:0 auto;padding:32px 0 56px}.controls{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;display:flex}.control-row{flex-wrap:wrap;align-items:center;gap:12px;width:100%;display:flex}.section-title{width:100%;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;margin:0 0 8px;font-size:14px}.search{background:var(--surface);border:1px solid var(--stroke);border-radius:16px;flex:320px;align-items:center;gap:10px;padding:12px 16px;display:flex;box-shadow:0 10px 30px #3d2b3d14}.search input{width:100%;color:var(--ink);background:0 0;border:none;outline:none}.sort-control{color:var(--ink-soft);flex:0 220px;gap:6px;font-size:12px;display:grid}.sort-control select{border:1px solid var(--stroke);background:var(--surface);width:100%;color:var(--ink);border-radius:16px;padding:12px 14px;box-shadow:0 10px 30px #3d2b3d14}.search-icon{flex-shrink:0;width:18px;height:18px;position:relative}.search-icon:before{content:"";border:2px solid var(--ink-soft);border-radius:50%;width:12px;height:12px;position:absolute;top:0;left:0}.search-icon:after{content:"";background:var(--ink-soft);border-radius:2px;width:8px;height:2px;position:absolute;bottom:2px;right:-1px;transform:rotate(45deg)}.filters{flex-wrap:wrap;gap:10px;display:flex}.chip{border:1px solid var(--stroke);background:var(--surface);color:var(--ink-soft);cursor:pointer;border-radius:999px;padding:8px 16px;transition:all .2s}.tabs{background:var(--surface);border:1px solid var(--stroke);border-radius:999px;gap:8px;margin:12px 0 20px;padding:6px;display:inline-flex}.tab{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:8px 16px;transition:all .2s}.tab.active{background:var(--accent);color:#fff;box-shadow:0 10px 20px #e16aa340}.chip.active{background:var(--accent);color:#fff;border-color:#0000;box-shadow:0 12px 24px #e16aa347}.layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:24px;display:grid}.grid{gap:16px;display:grid}.card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;align-items:flex-start;gap:8px;margin:0 0 4px;font-size:16px;line-height:1.3;display:-webkit-box;overflow:hidden}.card-title .rank-dot{flex-shrink:0;margin-top:6px}.summary-header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.summary-header h2{margin:0 0 6px;font-size:20px}.summary-header em{color:var(--accent-strong);font-style:normal}.summary-controls{gap:10px;display:grid}.summary-controls input{border:1px solid var(--stroke);background:var(--surface-soft);border-radius:12px;padding:10px 12px}.summary-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.summary-card{border:1px solid var(--stroke);content-visibility:auto;contain-intrinsic-size:140px 160px;background:#fff;border-radius:16px;gap:10px;padding:14px;display:grid}.summary-card h3{margin:0;font-size:16px}.summary-meta{color:var(--ink-soft);justify-content:flex-end;align-items:center;gap:8px;font-size:12px;display:flex}.summary-senders{flex-wrap:wrap;gap:6px;display:flex}.sender-tag{background:var(--surface-soft);border:1px solid var(--stroke);color:var(--ink-soft);border-radius:999px;padding:4px 8px;font-size:11px}.grid-inner{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.card{background:var(--surface);border:1px solid var(--stroke);text-align:left;cursor:pointer;content-visibility:auto;contain-intrinsic-size:140px 160px;border-radius:16px;gap:8px;padding:12px;transition:box-shadow .2s,transform .2s;display:grid}.card.rank-do{background:linear-gradient(135deg,#e4535a52 0%,#fff5f6 70%);border-color:#e4535a59}.card.rank-cam{background:linear-gradient(135deg,#f4b76b57 0%,#fff7ec 70%);border-color:#f4b76b66}.card.rank-tim{background:linear-gradient(135deg,#9c6ade52 0%,#f6f0ff 70%);border-color:#9c6ade61}.card.rank-lam{background:linear-gradient(135deg,#74b3ce52 0%,#eef7fb 70%);border-color:#74b3ce61}.card:hover{box-shadow:0 16px 36px #3d2b3d1f}.card.selected{border-color:var(--accent-strong);transform:translateY(-2px);box-shadow:0 22px 46px #e16aa347,0 0 0 2px #e16aa338}.card.is-disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.card.is-disabled:hover{box-shadow:none}.rank-dot{border-radius:50%;width:10px;height:10px}.rank-do{background:#e4535a}.rank-cam{background:var(--gold)}.rank-tim{background:#9c6ade}.rank-lam{background:var(--mint)}.points{color:var(--ink-soft);font-size:12px}.card-main{align-items:center;gap:12px;display:flex}.flower-thumb{width:42px;height:42px;color:var(--accent-strong);background:linear-gradient(135deg,#ffd1e1,#fff1c7);border-radius:16px;flex-shrink:0;place-items:center;font-weight:600;display:grid;position:relative;overflow:hidden}.flower-image{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .2s;display:block}.flower-thumb.has-image .flower-image{opacity:1}.flower-letter{z-index:1}.flower-thumb.has-image .flower-letter{display:none}.card-info h3{margin:0 0 4px;font-size:15px}.card-info p{color:var(--ink-soft);margin:0;font-size:12px}.side{gap:16px;display:grid}.side-card{background:var(--surface);border:1px solid var(--stroke);border-radius:20px;padding:16px;box-shadow:0 16px 40px #3d2b3d1a}.side-header{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:12px;display:flex}.side-actions{flex-wrap:wrap;gap:8px;display:flex}.reset-btn{border:1px solid var(--stroke);color:var(--ink-soft);cursor:pointer;background:#fff;border-radius:999px;padding:6px 12px;font-size:12px}.reset-btn:disabled{opacity:.6;cursor:not-allowed}.side-header h2{margin:0;font-size:18px}.side-list{gap:12px;width:100%;max-height:280px;padding-right:4px;display:grid;overflow:auto}.side-history{border-top:1px solid var(--stroke);gap:10px;margin-top:14px;padding-top:14px;display:grid}.side-history h3{color:var(--ink-soft);margin:0;font-size:14px}.side-history-list{flex-wrap:wrap;gap:8px;display:flex}.history-pill{color:var(--ink);text-align:left;cursor:pointer;background:linear-gradient(135deg,#e16aa314,#f4b76b1a);border:1px solid #e16aa338;border-radius:999px;gap:2px;padding:8px 10px;display:grid}.history-pill strong{font-size:12px}.history-pill span{color:var(--ink-soft);font-size:11px}.side-item{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;width:100%;font-size:13px;display:grid}.side-item span{color:var(--ink-soft);margin-top:2px;display:block}.side-dot{background:var(--accent);border-radius:50%;width:8px;height:8px}.ghost{color:var(--accent-strong);cursor:pointer;background:0 0;border:none}.form{background:var(--surface);border:1px solid var(--stroke);border-radius:20px;gap:12px;padding:16px;display:grid}.sender-panel{background:var(--surface-soft);border:1px solid var(--stroke);border-radius:16px;gap:8px;padding:12px;display:grid}.sender-header{color:var(--ink-soft);justify-content:space-between;font-size:12px;display:flex}.sender-header em{color:var(--accent-strong);font-style:normal}.sender-search{border:1px solid var(--stroke);background:#fff;border-radius:12px;padding:8px 10px}.unlock-btn{border:1px dashed var(--stroke);background:var(--surface-soft);color:var(--ink-soft);cursor:pointer;text-align:center;border-radius:12px;padding:8px 12px;font-size:12px}.sender-list{scrollbar-width:thin;scrollbar-color:#3d2b3d59 transparent;gap:8px;max-height:280px;padding-right:4px;display:grid;overflow-y:auto}.sender-list::-webkit-scrollbar{width:8px}.sender-list::-webkit-scrollbar-thumb{background:#3d2b3d33;border-radius:999px}.sender-chip{border:1px solid var(--stroke);background:#fff;border-radius:12px;align-items:center;gap:8px;padding:6px;display:flex}.sender-chip.locked{background:linear-gradient(135deg,#e16aa333,#fff 72%);border-color:#c74486b8;position:relative;box-shadow:inset 0 0 0 1px #e16aa329,0 8px 18px #c7448614}.sender-chip.locked:before{content:"";background:var(--accent-strong);border-radius:999px;width:4px;position:absolute;top:8px;bottom:8px;left:0}.sender-select{text-align:left;cursor:pointer;background:0 0;border:none;flex:1;gap:2px;padding:4px 6px;display:grid}.sender-select:disabled{cursor:progress;opacity:.7}.sender-chip.locked .sender-select{padding-left:10px}.sender-select span{color:var(--ink-soft);font-size:12px}.sender-chip.locked .sender-select strong{color:var(--accent-strong)}.sender-chip.locked .sender-select span{color:var(--accent-strong);opacity:.8}.sender-status{white-space:nowrap;border:1px solid var(--stroke);background:var(--surface-soft);color:var(--ink-soft);border-radius:999px;align-self:center;padding:4px 8px;font-size:11px}.sender-status.locked{color:var(--accent-strong);text-transform:uppercase;letter-spacing:.04em;background:#c7448633;border-color:#c744868c;font-weight:600}.sender-lock{border:1px solid var(--stroke);background:var(--surface-soft);color:var(--ink-soft);cursor:pointer;white-space:nowrap;border-radius:999px;padding:6px 10px;font-size:12px}.sender-lock.active{color:var(--accent-strong);background:#c744862e;border-color:#c74486a6;font-weight:600}.sender-lock:disabled{opacity:.6;cursor:not-allowed}.form h2{margin:0;font-size:18px}.form label{color:var(--ink-soft);gap:6px;font-size:13px;display:grid}.form input{border:1px solid var(--stroke);background:var(--surface-soft);color:var(--ink);border-radius:12px;padding:10px 12px}.primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:14px;padding:12px 16px;font-weight:600;transition:transform .2s}.primary:hover{transform:translateY(-2px)}.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.status{border-radius:12px;padding:10px 12px;font-size:13px}.status.error{color:#b8325b;background:#ffe7ea}.status.info{color:#9a5a1f;background:#fff3dd}.status.success{color:#2f6b4f;background:#e8f5ee}.note{color:var(--ink-soft);margin:0;font-size:12px}.note-highlight{color:var(--ink);background:linear-gradient(135deg,#e16aa31f,#f4b76b29);border:1px solid #e16aa333;border-radius:14px;padding:12px 14px;font-size:13px;line-height:1.55;box-shadow:0 10px 24px #3d2b3d14}.modal-backdrop{z-index:50;background:#20141e73;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--stroke);border-radius:20px;gap:16px;width:min(520px,92vw);padding:20px;display:grid;box-shadow:0 24px 60px #20141e3d}.modal-header h3{margin:0 0 6px;font-size:18px}.modal-body{gap:10px;font-size:14px;display:grid}.modal-row{grid-template-columns:80px 1fr;gap:10px;display:grid}.modal-label{color:var(--ink-soft);font-weight:600}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.muted{color:var(--ink-soft);margin:0}.people{gap:20px;display:grid}.people-header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.people-header h2{color:var(--ink);margin:0 0 6px;font-size:24px;font-weight:700}.people-header em{color:var(--accent-strong);font-style:normal}.people-controls{gap:12px;display:grid}.people-search-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.people-search-row input{border:1px solid var(--stroke);background:var(--surface);min-width:220px;color:var(--ink);border-radius:12px;flex:1;padding:12px 14px;font-size:14px}.people-search-row input::placeholder{color:var(--ink-soft)}.people-sort-control{color:var(--ink-soft);gap:4px;min-width:170px;font-size:12px;display:grid}.people-sort-control select{border:1px solid var(--stroke);background:var(--surface);color:var(--ink);border-radius:10px;padding:10px 12px;font-size:13px}.people-actions{flex-wrap:wrap;gap:8px;display:flex}.expand-collapse-btn{border:1px solid var(--stroke);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:500;transition:all .2s}.expand-collapse-btn:hover:not(:disabled){background:var(--surface-soft);box-shadow:0 4px 12px #3d2b3d14}.expand-collapse-btn:disabled{opacity:.5;cursor:not-allowed}.people-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));align-items:start;gap:16px;display:grid}.people-card{border:1px solid var(--stroke);background:#fff;border-radius:14px;padding:0;transition:all .2s;display:grid;overflow:hidden;box-shadow:0 2px 6px #3d2b3d0f}.people-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 20px #3d2b3d1a}.people-header-btn{background:linear-gradient(135deg, var(--surface) 0%, var(--surface-soft) 100%);cursor:pointer;text-align:left;border:none;justify-content:space-between;align-items:center;gap:12px;padding:16px;transition:all .2s;display:flex}.people-card:hover .people-header-btn{background:linear-gradient(135deg, var(--surface-soft) 0%, #f5f3f7 100%)}.people-info{flex:1;gap:4px;min-width:0;display:grid}.people-name{word-break:break-word;color:var(--ink);margin:0;font-size:15px;font-weight:700;line-height:1.3}.people-ingame{color:var(--ink-soft);margin-top:2px;font-size:13px;font-weight:400;display:block}.people-count{color:var(--ink-soft);font-size:12px;font-weight:500}.expand-icon{color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:13px;transition:transform .2s;display:flex}.people-flowers{border-top:1px solid var(--stroke);background:var(--surface-soft);grid-template-columns:1fr 1fr;gap:0;max-height:400px;padding:0;display:grid;overflow-y:auto}.flower-item{border-right:1px solid var(--stroke);border-bottom:1px solid var(--stroke);align-items:center;gap:8px;padding:10px 12px;font-size:13px;transition:background .2s;display:flex}.flower-item:nth-child(2n){border-right:none}.flower-item:hover{background:#fff}.flower-name{color:var(--ink);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;min-width:0;line-height:1.3;display:-webkit-box;overflow:hidden}@media (width<=1024px){.layout{grid-template-columns:1fr}.grid-inner{grid-template-columns:repeat(2,minmax(0,1fr))}.people-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (width<=640px){.layout{flex-direction:column;align-items:stretch;display:flex}.side{order:-1}.page{width:min(100%,94vw);padding:20px 0 40px}.controls{gap:12px}.search{border-radius:14px;padding:10px 12px}.people-grid{grid-template-columns:1fr}.people-search-row{flex-direction:column}.people-search-row input{width:100%}.people-sort-control{width:100%;min-width:0}.people-sort-control select{width:100%}.people-actions{justify-content:stretch}.expand-collapse-btn{text-align:center;flex:1}.filters{gap:8px}.chip{padding:6px 12px;font-size:13px}.tabs{justify-content:space-between;width:100%}.tab{text-align:center;flex:1}.summary{margin-top:20px}.summary-header{flex-direction:column;align-items:flex-start;gap:6px}.grid-inner{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.card{border-radius:11px;gap:6px;padding:7px}.card-main{gap:6px}.flower-thumb{border-radius:8px;width:28px;height:28px}.side-card,.form{box-sizing:border-box;border-radius:16px;align-self:stretch;width:100%;max-width:520px;margin:0 auto;padding:14px}.sender-list{max-height:320px;padding-bottom:4px;position:relative}.sender-chip{flex-direction:column;align-items:stretch;gap:6px;padding:6px 8px}.sender-status{align-self:flex-start}.sender-lock,.primary{width:100%}.side-header{flex-direction:row;justify-content:space-between;align-items:center;gap:10px}.side-list{max-height:360px}.card-info h3{font-size:12.5px;line-height:1.25}.card-info p{font-size:10px}.sender-list{box-shadow:inset 0 -14px 14px -12px #3d2b3d47}.sender-list:after{content:"";pointer-events:none;background:linear-gradient(#f8f0f200,#f8f0f2f2);height:16px;margin-top:-16px;display:block;position:sticky;bottom:0}.card,.card:hover,.card.selected{transform:none}.card{content-visibility:visible;contain-intrinsic-size:auto}.sender-select{align-items:center;gap:2px;padding:2px 6px}.sender-select strong{-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;font-size:13px;line-height:1.25;display:-webkit-box;overflow:hidden}.sender-select span{color:var(--ink-soft);font-size:11px}}@media (width>=1200px){.layout{grid-template-columns:minmax(0,1fr) 380px}}@media (width>=1400px){.layout{grid-template-columns:minmax(0,1fr) 420px}}
