@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&display=swap";.birthday-page{min-height:100vh;padding:28px 16px 56px;background:radial-gradient(circle at top left,rgba(223,239,255,.85),transparent 28%),linear-gradient(180deg,#fff9fb,#eef6ff 54%,#f6fbff);font-family:Trebuchet MS,Segoe UI,sans-serif;color:#17315d}.birthday-shell{max-width:1180px;margin:0 auto}.birthday-state{display:flex;min-height:70vh;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px}.birthday-loader-icon{font-size:58px}.birthday-back-button,.birthday-secondary-button,.birthday-primary-button,.birthday-like-button,.birthday-person-chip,.birthday-banner-person,.birthday-link-button{font:inherit}.birthday-back-button{display:inline-flex;align-items:center;gap:8px;margin-bottom:20px;border:1px solid #d7e3f4;border-radius:14px;background:#fff;color:#1d3f7a;padding:10px 16px;cursor:pointer;font-weight:700;box-shadow:0 10px 24px #17315d14}.birthday-hero-card,.birthday-info-card{background:#fff;border:1px solid rgba(106,150,212,.18);box-shadow:0 22px 50px #17315d1a}.birthday-hero-card{position:relative;overflow:hidden;border-radius:28px;padding:34px 32px 72px}.birthday-wave{position:absolute;left:-10%;width:120%;pointer-events:none}.birthday-wave-top-dark{top:-56px;height:126px;background:#244693;border-bottom-left-radius:55% 100%;border-bottom-right-radius:52% 100%}.birthday-wave-top-light{top:-18px;height:96px;background:#5ca2d8;border-bottom-left-radius:48% 100%;border-bottom-right-radius:62% 100%}.birthday-wave-bottom-light{bottom:-30px;height:130px;background:#5ca2d8;border-top-left-radius:62% 100%;border-top-right-radius:48% 100%}.birthday-wave-bottom-dark{bottom:-74px;height:132px;background:#3b56a7;border-top-left-radius:50% 100%;border-top-right-radius:60% 100%}.birthday-confetti-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.birthday-confetti{position:absolute;width:18px;height:10px;border-radius:14px 14px 4px 4px;background:#75b2ed6b;filter:blur(.2px);animation-name:birthdayFloatConfetti;animation-iteration-count:infinite;animation-timing-function:ease-in-out}.birthday-hero-content{position:relative;z-index:1;text-align:center}.birthday-hero-logo{width:72px;max-width:22vw;margin-bottom:10px;-o-object-fit:contain;object-fit:contain}.birthday-hero-title{margin:0 0 22px;color:#244693;font-size:clamp(2.3rem,3.8vw,4.3rem);line-height:.98;letter-spacing:.04em;font-weight:900}.birthday-banner-grid{--columns: 1;display:grid;justify-content:center;gap:18px 18px;grid-template-columns:repeat(var(--columns),minmax(150px,1fr));max-width:980px;margin:0 auto 22px}.birthday-banner-grid.count-1{--columns: 1;max-width:310px}.birthday-banner-grid.count-2{--columns: 2;max-width:760px}.birthday-banner-grid.count-3{--columns: 3;max-width:940px}.birthday-banner-grid.count-4{--columns: 4;max-width:1050px}.birthday-banner-grid.count-5,.birthday-banner-grid.count-6,.birthday-banner-grid.count-many{--columns: 3;max-width:1020px}.birthday-banner-person{display:flex;flex-direction:column;align-items:center;gap:10px;border:0;background:transparent;padding:0;min-width:0}.birthday-banner-person.is-linked{cursor:pointer}.birthday-banner-person:disabled{cursor:default}.birthday-banner-person.is-linked:hover .birthday-banner-frame{transform:translateY(-3px)}.birthday-banner-frame{position:relative;display:flex;align-items:center;justify-content:center;width:calc(var(--photo-size, 170px) + 54px);height:calc(var(--photo-size, 170px) + 34px);transition:transform .2s ease}.birthday-banner-frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:36% 36% 34% 34%/28% 28% 40% 40%;background:linear-gradient(180deg,#244693,#18346e)}.birthday-banner-frame-inner{position:relative;z-index:1;width:calc(var(--photo-size, 170px) + 22px);height:calc(var(--photo-size, 170px) + 8px);border-radius:35% 35% 32% 32%/26% 26% 42% 42%;background:radial-gradient(circle at 35% 20%,#89a8c7,#456684 45%,#1c304c);display:flex;align-items:flex-end;justify-content:center;overflow:hidden;padding-top:10px}.birthday-banner-photo{border:0;border-radius:0;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;width:var(--photo-size, 170px)!important;height:var(--photo-size, 170px)!important;max-width:100%}.birthday-banner-ribbon{position:relative;width:min(220px,100%);margin-top:-8px;padding:12px 22px 14px;border-radius:20px;background:linear-gradient(90deg,#2b5b9e,#1d4d90 46%,#163a7f);color:#fff;font-size:clamp(1rem,1.7vw,1.4rem);font-weight:900;letter-spacing:.03em;text-transform:uppercase;box-shadow:0 10px 28px #1d3f7a33}.birthday-banner-ribbon:before,.birthday-banner-ribbon:after{content:"";position:absolute;top:0;width:34px;height:100%;background:linear-gradient(180deg,#c7dcff,#87a8f2 48%,#cad9ff)}.birthday-banner-ribbon:before{left:-12px;clip-path:polygon(0 0,100% 0,74% 100%,0 84%);border-top-left-radius:12px;border-bottom-left-radius:12px}.birthday-banner-ribbon:after{right:-12px;clip-path:polygon(26% 0,100% 0,100% 84%,0 100%);border-top-right-radius:12px;border-bottom-right-radius:12px}.birthday-hero-message-wrap{display:flex;justify-content:center;margin-top:6px}.birthday-hero-message{max-width:760px;margin:0;color:#284a87;font-size:clamp(1rem,1.55vw,1.2rem);line-height:1.55;font-weight:600;background:#ffffffe0;border:1px solid rgba(151,184,231,.5);border-radius:22px;padding:16px 24px;box-shadow:0 16px 34px #2446931a}.birthday-info-card{margin-top:18px;border-radius:22px;padding:22px 24px}.birthday-stats-card{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px}.birthday-section-heading,.birthday-card-title{display:flex;align-items:center;gap:10px;margin-bottom:16px;color:#18346e;font-size:1.05rem;font-weight:800}.birthday-chip-list{display:flex;flex-wrap:wrap;gap:10px}.birthday-person-chip{display:inline-flex;align-items:center;gap:10px;border:1px solid #dbe6f4;border-radius:999px;background:#f7fbff;color:#1b417f;padding:8px 14px 8px 10px;cursor:pointer;font-weight:700}.birthday-chip-avatar{border-radius:50%}.birthday-like-button{display:inline-flex;align-items:center;gap:10px;border:1px solid #d9e7f8;border-radius:14px;background:#fff;color:#1d4d90;padding:11px 16px;cursor:pointer;font-weight:800}.birthday-like-button.is-liked{color:#d83b6c;border-color:#f4bfd0;background:#fff3f7}.birthday-wish-count{display:inline-flex;align-items:center;gap:10px;color:#5d7091;font-weight:700}.birthday-textarea{width:100%;min-height:112px;resize:vertical;border:1.5px solid #d7e4f3;border-radius:16px;padding:16px 18px;outline:none;box-sizing:border-box;font:inherit;color:#284a87;background:#fbfdff}.birthday-textarea-shell{position:relative}.birthday-textarea:focus{border-color:#5d8dd6;box-shadow:0 0 0 4px #5d8dd61f}.birthday-textarea-small{min-height:84px}.birthday-editor-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}.birthday-editor-actions-end{justify-content:flex-end}.birthday-posting-label{color:#6880a8;font-size:.95rem}.birthday-editor-help{margin-top:6px;color:#7a8fb3;font-size:.9rem}.birthday-primary-button,.birthday-secondary-button{display:inline-flex;align-items:center;gap:8px;border-radius:14px;padding:11px 18px;font-weight:800;cursor:pointer}.birthday-primary-button{border:0;background:linear-gradient(135deg,#28529a,#4d88d2);color:#fff;box-shadow:0 12px 28px #28529a2e}.birthday-primary-button:disabled,.birthday-secondary-button:disabled,.birthday-like-button:disabled,.birthday-link-button:disabled{opacity:.6;cursor:not-allowed}.birthday-secondary-button{border:1px solid #d7e4f3;background:#fff;color:#1d4d90}.birthday-comments-list{display:flex;flex-direction:column;gap:18px}.birthday-thread{border-bottom:1px solid #edf3fa;padding-bottom:18px}.birthday-thread:last-child{border-bottom:0;padding-bottom:0}.birthday-comment-row,.birthday-reply-row,.birthday-reply-editor{display:flex;gap:12px}.birthday-reply-row,.birthday-reply-editor{margin-top:12px;margin-left:48px}.birthday-avatar{flex-shrink:0;border-radius:14px;-o-object-fit:cover;object-fit:cover;box-shadow:0 8px 18px #233d6a1f}.birthday-avatar-fallback{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3462a6,#699fe3);color:#fff;font-weight:900;font-size:1rem}.birthday-comment-bubble{flex:1;min-width:0;border:1px solid #e4edf8;border-radius:18px;padding:14px 16px;background:#f9fbff}.birthday-comment-meta{display:flex;justify-content:space-between;gap:10px;margin-bottom:6px;flex-wrap:wrap}.birthday-comment-author{font-weight:800;color:#17315d}.birthday-comment-time{color:#8a9ab7;font-size:.86rem}.birthday-comment-text{margin:0 0 10px;color:#385784;line-height:1.55;white-space:pre-wrap;word-break:break-word}.birthday-mention-text{display:inline-block;margin:0 1px;padding:1px 8px;border-radius:999px;background:#d1e4ffb8;color:#1d4d90;font-weight:800}.birthday-mention-popover{position:absolute;left:0;right:0;top:calc(100% + 10px);z-index:20;overflow:hidden;border:1px solid #d7e4f3;border-radius:18px;background:#fff;box-shadow:0 18px 36px #17315d29}.birthday-mention-header{padding:10px 14px;border-bottom:1px solid #edf3fa;color:#6b7fa2;font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.birthday-mention-list{display:flex;flex-direction:column}.birthday-mention-item{display:flex;align-items:center;gap:12px;border:0;background:transparent;padding:12px 14px;text-align:left;cursor:pointer}.birthday-mention-item+.birthday-mention-item{border-top:1px solid #f2f6fb}.birthday-mention-item.is-selected,.birthday-mention-item:hover{background:#f4f8ff}.birthday-mention-copy{min-width:0;display:flex;flex-direction:column}.birthday-mention-name{color:#17315d;font-weight:800}.birthday-mention-role{color:#7b8fae;font-size:.85rem}.birthday-comment-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.birthday-link-button{display:inline-flex;align-items:center;gap:6px;border:0;padding:0;background:transparent;color:#5e6f92;cursor:pointer;font-weight:700}.birthday-link-button.is-liked{color:#d83b6c}.birthday-reply-editor-body{flex:1}.birthday-empty-state{text-align:center;color:#6e82a5;padding:28px 0 10px}.birthday-empty-icon{font-size:2rem;margin-bottom:8px}.birthday-banner-grid.count-1 .birthday-banner-frame{--photo-size: 196px}.birthday-banner-grid.count-2 .birthday-banner-frame{--photo-size: 176px}.birthday-banner-grid.count-3 .birthday-banner-frame,.birthday-banner-grid.count-4 .birthday-banner-frame{--photo-size: 150px}.birthday-banner-grid.count-5 .birthday-banner-frame,.birthday-banner-grid.count-6 .birthday-banner-frame,.birthday-banner-grid.count-many .birthday-banner-frame{--photo-size: 132px}@keyframes birthdayFloatConfetti{0%,to{transform:translateY(0) translate(0) rotate(0);opacity:.18}50%{transform:translateY(16px) translate(6px) rotate(18deg);opacity:.6}}@media (max-width: 1100px){.birthday-banner-grid.count-4,.birthday-banner-grid.count-5,.birthday-banner-grid.count-6,.birthday-banner-grid.count-many{--columns: 3}}@media (max-width: 860px){.birthday-page{padding:20px 12px 40px}.birthday-hero-card,.birthday-info-card{border-radius:22px}.birthday-hero-card{padding:30px 18px 64px}.birthday-banner-grid{gap:18px 12px}.birthday-banner-grid.count-3,.birthday-banner-grid.count-4,.birthday-banner-grid.count-5,.birthday-banner-grid.count-6,.birthday-banner-grid.count-many{--columns: 2;max-width:720px}.birthday-banner-grid.count-3 .birthday-banner-frame,.birthday-banner-grid.count-4 .birthday-banner-frame,.birthday-banner-grid.count-5 .birthday-banner-frame,.birthday-banner-grid.count-6 .birthday-banner-frame,.birthday-banner-grid.count-many .birthday-banner-frame{--photo-size: 136px}.birthday-banner-ribbon{width:min(180px,100%);padding:12px 16px 14px;font-size:1.1rem}.birthday-hero-message{padding:14px 18px}.birthday-stats-card{justify-content:center}.birthday-reply-row,.birthday-reply-editor{margin-left:16px}}@media (max-width: 560px){.birthday-banner-grid,.birthday-banner-grid.count-2,.birthday-banner-grid.count-3,.birthday-banner-grid.count-4,.birthday-banner-grid.count-5,.birthday-banner-grid.count-6,.birthday-banner-grid.count-many{--columns: 1;max-width:280px}.birthday-banner-grid .birthday-banner-frame{--photo-size: 164px}.birthday-hero-logo{width:72px}.birthday-info-card{padding:18px 16px}.birthday-editor-actions{align-items:stretch}.birthday-primary-button,.birthday-secondary-button,.birthday-like-button,.birthday-back-button{justify-content:center}.birthday-primary-button{width:100%}.birthday-reply-row,.birthday-reply-editor{margin-left:0}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #0865f0;--primary-dark: #3730a3;--primary-light: #e0e7ff;--accent: #06b6d4;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg: #f8fafc;--surface: #ffffff;--surface2: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--sidebar-w: 260px;--sidebar-collapsed: 72px;--navbar-h: 64px;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);--shadow-lg: 0 8px 32px rgba(0,0,0,.12)}@media (max-width: 639px){:root{--sidebar-w: 100%;--navbar-h: 56px}}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}html,body,#root{width:100%;height:100%}h1,h2,h3,h4,h5{letter-spacing:-.01em}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.page-enter{animation:fadeSlide .35s ease forwards}.fade-in{animation:fadeIn .3s ease forwards}.slide-in{animation:slideIn .3s ease forwards}@keyframes fadeSlide{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(-12px);opacity:0}to{transform:translate(0);opacity:1}}.container{width:100%;margin:0 auto;padding:0 16px}@media (min-width: 640px){.container{max-width:640px;padding:0 20px}}@media (min-width: 768px){.container{max-width:768px;padding:0 24px}}@media (min-width: 1024px){.container{max-width:1024px;padding:0 28px}}@media (min-width: 1280px){.container{max-width:1280px;padding:0 32px}}@media (min-width: 1536px){.container{max-width:1536px;padding:0 40px}}.grid{display:grid;width:100%}.grid-cols-1{grid-template-columns:1fr}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}@media (min-width: 640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.md\:gap-6{gap:24px}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.align-center{align-items:center}.gap-3{gap:12px}@media (max-width: 639px){h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}body{font-size:14px}}@media (min-width: 640px){h1{font-size:28px}h2{font-size:24px}h3{font-size:20px}}.mobile-hide{display:none}.mobile-show{display:block}@media (min-width: 768px){.mobile-hide{display:block}.mobile-show{display:none}}button,input,select,textarea{font-family:DM Sans,sans-serif}button{transition:all .2s cubic-bezier(.4,0,.2,1)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0865f01a}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.scrollable{overflow-y:auto;overflow-x:hidden}.scrollable::-webkit-scrollbar{width:6px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);transition:all .2s}@media (min-width: 768px){.card{padding:20px}}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-light)}
