@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.8/dist/web/static/pretendard.css";:root{--bg-color:#fff;--bg-secondary:#f2f4f6;--bg-widget:#fff;--text-main:#1f2228;--text-secondary:#8b95a1;--primary-color:#a8d7c2;--primary-color-hover:#96c5b0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--glass-bg:#ffffffd9;--glass-border:#ffffff4d;--border-color:#e5e8eb}*{box-sizing:border-box;margin:0;padding:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,sans-serif}body{background-color:var(--bg-secondary);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{background-color:var(--bg-secondary);max-width:480px;min-height:100vh;box-shadow:var(--shadow-md);flex-direction:column;margin:0 auto;display:flex;position:relative}::-webkit-scrollbar{display:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}a{color:inherit;text-decoration:none}app-container{background-color:var(--bg-color);flex-direction:column;height:100vh;animation:.5s fadeIn;display:flex;position:relative;overflow:hidden}.theme-yangyangi{--primary-color:#f1b5c1;--primary-color-hover:#e0a3af}.theme-taekongi{--primary-color:#a8d7c2;--primary-color-hover:#96c5b0}.main-content{flex:1;padding-bottom:80px;overflow-y:auto}.splash-screen{z-index:99999;background-color:#fff;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.splash-logo-container{justify-content:center;align-items:center;display:flex;position:relative}.splash-logo-glow{filter:blur(60px);opacity:.35;z-index:1;background:#a8d7c2;border-radius:50%;width:140px;height:140px;position:absolute}.splash-logo-img{z-index:2;mix-blend-mode:multiply;width:380px;max-width:80vw;height:auto;position:relative;transform:translateY(-60px)}@keyframes heartbeat{0%{transform:scale(1)}15%{transform:scale(1.05)}30%{transform:scale(1)}45%{transform:scale(1.1)}60%{transform:scale(1)}to{transform:scale(1)}}.select-screen{background-color:#fff;flex-direction:column;justify-content:center;align-items:center;height:100vh;padding:0 24px;display:flex}.select-mini-logo{mix-blend-mode:multiply;width:240px;height:auto;margin-bottom:10px;transform:translateY(-60px)}.select-title{color:var(--text-main);letter-spacing:-.02em;margin-bottom:40px;font-size:1.6rem;font-weight:700}.cards-container{justify-content:center;gap:20px;width:100%;margin-bottom:40px;display:flex}.user-card{cursor:pointer;background-color:#fff;border:1px solid #00000014;border-radius:28px;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:145px;height:195px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;box-shadow:0 15px 35px #0000001a,0 5px 15px #0000000d,inset 0 -4px 10px #00000005}.user-card:hover{transform:translateY(-8px);box-shadow:0 25px 45px #00000026}.user-card:first-child:hover,.user-card.selected-yangyangi:hover{border-color:#f1b5c1}.user-card:nth-child(2):hover,.user-card.selected-taekongi:hover{border-color:#a8d7c2}.user-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff80,#0000);border-radius:28px 28px 0 0;height:50%;position:absolute;top:0;left:0;right:0}.user-card:active{transform:scale(.95)}.profile-img-wrapper{width:80px;height:80px;box-shadow:var(--shadow-sm);background-color:#fff;border:1px solid #0000000d;border-radius:50%;transition:all .3s;position:relative;overflow:hidden}.profile-img-wrapper:after{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 2px 6px #00000026}.profile-img-wrapper img{object-fit:cover;width:100%;height:100%}.user-name{color:var(--text-main);font-size:1.1rem;font-weight:700}.selected-yangyangi{border-color:#f1b5c1;transform:translateY(-8px);box-shadow:0 10px 30px #f1b5c166}.selected-yangyangi .profile-img-wrapper{box-shadow:0 0 0 4px #f1b5c1}.selected-taekongi{border-color:#a8d7c2;transform:translateY(-8px);box-shadow:0 10px 30px #a8d7c266}.selected-taekongi .profile-img-wrapper{box-shadow:0 0 0 4px #a8d7c2}.enter-button-wrapper{opacity:0;pointer-events:none;width:100%;padding:0 20px;transition:all .4s;transform:translateY(20px)}.enter-button-wrapper.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.enter-button{width:100%;color:var(--text-main);-webkit-backdrop-filter:blur(12px);background:#fff3;border:1px solid #ffffff4d;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px;font-size:1.1rem;font-weight:700;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 4px 15px #0000000d}.enter-button.btn-yangyangi{background:linear-gradient(135deg,#f1b5c1e6,#f1b5c180);border-color:#f1b5c1b3;box-shadow:0 4px 20px #f1b5c14d}.enter-button.btn-taekongi{background:linear-gradient(135deg,#a8d7c2e6,#a8d7c280);border-color:#a8d7c2b3;box-shadow:0 4px 20px #a8d7c24d}.enter-button:active{opacity:.8;transform:scale(.98)}.fade-in{animation:.8s forwards fadeInOnly}.fade-out{animation:.8s forwards fadeOutOnly}@keyframes fadeInOnly{0%{opacity:0}to{opacity:1}}@keyframes fadeOutOnly{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.05)}}.header{z-index:10;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);justify-content:center;align-items:center;height:60px;display:flex;position:sticky;top:0}.header h1{color:var(--text-main);letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.bottom-nav{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);width:100%;max-width:480px;height:80px;padding-bottom:env(safe-area-inset-bottom,16px);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0}.nav-item{height:100%;color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.nav-item.active{color:var(--primary-color);transform:translateY(-2px)}.nav-item .icon-container{transition:transform .3s;position:relative}.nav-item.active .icon-container{transform:scale(1.1)}.nav-icon{stroke:currentColor;stroke-width:2px;fill:none;width:24px;height:24px}.nav-item.active .nav-icon{fill:currentColor;stroke-width:1.5px}.nav-label{opacity:.8;font-size:.65rem;font-weight:600}.nav-item.active .nav-label{opacity:1}.nav-item:after{content:"";background-color:var(--primary-color);opacity:0;border-radius:50%;width:4px;height:4px;transition:all .3s;position:absolute;bottom:-4px;transform:scale(0)}.nav-item.active:after{opacity:1;transform:scale(1)}.page-container{flex-direction:column;gap:24px;padding:24px 20px;animation:.4s fadeInOnly;display:flex}.greeting-section{padding-top:10px}.greeting-text{color:var(--text-main);letter-spacing:-.02em;margin-bottom:8px;font-size:1.5rem;font-weight:700;line-height:1.3}.greeting-subtext{color:var(--text-secondary);font-size:.95rem}.highlight{color:var(--primary-color)}.widget-card{background-color:var(--bg-widget);border:1px solid #00000005;border-radius:24px;padding:24px;transition:transform .2s;box-shadow:0 4px 20px #00000008}.widget-card:active{transform:scale(.98)}.widget-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cal-nav-btn{background:var(--bg-secondary);color:var(--text-main);border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.cal-nav-btn:active{transform:scale(.9)}.widget-title{align-items:center;gap:8px;font-size:1.15rem;font-weight:700;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:8px;width:100%;margin-bottom:12px;display:grid}.calendar-day-header{text-align:center;color:var(--text-secondary);margin-bottom:8px;font-size:.75rem;font-weight:600}.calendar-cell{aspect-ratio:1;color:var(--text-main);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;font-size:.95rem;font-weight:600;display:flex;position:relative}.calendar-cell.empty{visibility:hidden}.calendar-cell.today{background-color:var(--primary-color);color:#fff;box-shadow:0 2px 8px #0000001a}.event-dot{background-color:var(--primary-color);border-radius:50%;width:5px;height:5px;margin-top:2px}.special-heart{filter:drop-shadow(0 2px 4px #ffb6c180);animation:1.5s infinite heartbeat;position:absolute;top:-4px;right:-4px}.action-button{background-color:var(--bg-widget);width:100%;color:var(--primary-color);border:1px solid var(--primary-color);border-radius:16px;justify-content:center;align-items:center;gap:6px;padding:16px;font-size:1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 10px #00000005}.action-button:active{background-color:var(--primary-color);color:#fff;transform:scale(.98)}.event-list-section{padding:0 4px}.event-item{background-color:var(--bg-widget);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:20px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:18px 20px;display:flex}.special-event-item{background:linear-gradient(to right, var(--bg-widget), #ffb6c10d);border-color:#ffb6c1}.event-info{flex-direction:column;gap:4px;display:flex}.event-title{color:var(--text-main);font-size:1.05rem;font-weight:700}.special-event-item .event-title{color:#ffb6c1;text-shadow:0 1px 2px #ffb6c133}.event-time{color:var(--text-secondary);font-size:.85rem;font-weight:500}.bottom-sheet-overlay{-webkit-backdrop-filter:blur(4px);z-index:2000;opacity:0;pointer-events:none;background:#00000080;align-items:flex-end;transition:opacity .3s;display:flex;position:fixed;inset:0}.bottom-sheet-overlay.open{opacity:1;pointer-events:auto}.bottom-sheet{background:var(--bg-color);border-radius:32px 32px 0 0;width:100%;max-width:480px;margin:0 auto;padding:28px 24px 40px;transition:transform .4s cubic-bezier(.175,.885,.32,1.1);transform:translateY(100%);box-shadow:0 -10px 40px #0000001a}.bottom-sheet-overlay.open .bottom-sheet{transform:translateY(0)}.bottom-sheet-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.bottom-sheet-header h3{color:var(--text-main);margin:0;font-size:1.3rem}.form-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.form-group.row{flex-direction:row;gap:16px}.form-group label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.form-group input{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-main);border-radius:16px;outline:none;padding:16px;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:var(--primary-color)}.save-button{background-color:var(--primary-color);color:#fff;border:none;border-radius:20px;width:100%;margin-top:10px;padding:18px;font-size:1.1rem;font-weight:700;box-shadow:0 4px 15px #0000001a}.save-button:active{transform:scale(.98)}.global-sound-control{z-index:100;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-color);width:40px;height:40px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.global-sound-control:active{transform:scale(.9)}.celebration-overlay{-webkit-backdrop-filter:blur(10px);z-index:2000;background:#000000b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.celebration-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);text-align:center;z-index:2005;border:1px solid #ffffff4d;border-radius:32px;flex-direction:column;align-items:center;gap:24px;padding:40px 24px;display:flex;box-shadow:0 20px 50px #0003}.celebration-photo-wrapper{border:4px solid #fff;border-radius:50%;width:140px;height:140px;animation:3s ease-in-out infinite float;overflow:hidden;box-shadow:0 0 0 4px #ffb6c1,0 10px 30px #ffb6c166}.celebration-photo-wrapper img{object-fit:cover;width:100%;height:100%}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.celebration-text{color:var(--text-main);letter-spacing:-.02em;font-size:1.3rem;font-weight:700;line-height:1.4}.celebration-close{color:#fff;background:linear-gradient(135deg,#ffb6c1,#fca5b1);border:none;border-radius:100px;padding:16px 32px;font-size:1.1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 15px #ffb6c14d}.celebration-close:active{transform:scale(.95)}.theme-board-container{background-color:var(--bg-color);padding:24px 20px 100px}.theme-board-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.theme-board-title-area h2{color:var(--text-main);font-size:1.8rem;font-weight:800;line-height:1.25}.create-theme-round-btn{background:linear-gradient(135deg, var(--primary-color), #bc52e0);color:#fff;text-align:center;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;margin-left:16px;font-size:.8rem;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 4px 15px #ffb6c180}.create-theme-round-btn:active{transform:scale(.9)}.theme-filters-section{margin-bottom:24px}.filter-label{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.theme-filters{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.theme-filters::-webkit-scrollbar{display:none}.theme-filter-btn{background:var(--bg-widget);color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;border-radius:20px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.theme-filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.date-filter-wrapper{margin-top:8px}.theme-date-select{border:1px solid var(--border-color);background:var(--bg-widget);color:var(--text-main);border-radius:12px;outline:none;padding:10px 16px;font-size:.95rem;font-weight:600}.theme-list{flex-direction:column;gap:24px;display:flex}.theme-card{background:var(--bg-widget);border:1px solid var(--border-color);border-radius:24px;overflow:hidden;box-shadow:0 4px 20px #0000000f}.theme-card-collage{background:var(--bg-secondary);aspect-ratio:4/3;gap:2px;width:100%;display:grid}.theme-card-collage.count-1{grid-template-columns:1fr}.theme-card-collage.count-2{grid-template-columns:1fr 1fr}.theme-card-collage.count-3{grid-template-rows:1fr 1fr;grid-template-columns:2fr 1fr}.theme-card-collage.count-3 .collage-slot:first-child{grid-row:1/3}.theme-card-collage.count-4{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.collage-slot{position:relative;overflow:hidden}.collage-slot img{object-fit:cover;width:100%;height:100%;display:block}.collage-more-overlay{color:#fff;background:#00000080;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex;position:absolute;inset:0}.theme-card-empty-photo{aspect-ratio:4/3;background:var(--bg-secondary);color:var(--text-secondary);justify-content:center;align-items:center;font-size:.95rem;display:flex}.theme-card-content{padding:20px}.theme-card-info-top{justify-content:space-between;align-items:flex-start;margin-bottom:4px;display:flex}.theme-card-title{color:var(--text-main);font-size:1.15rem;font-weight:700;line-height:1.3}.theme-card-date{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem}.theme-card-category-badge{color:var(--primary-color);background-color:#ffb6c126;border-radius:12px;margin-bottom:12px;padding:4px 10px;font-size:.75rem;font-weight:700;display:inline-block}.theme-taekongi .theme-card-category-badge{background-color:#87ceeb26}.theme-card-desc{color:var(--text-main);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.theme-card-footer{color:var(--text-secondary);align-items:center;gap:6px;font-size:.85rem;font-weight:500;display:flex}.photo-modal-overlay{-webkit-backdrop-filter:blur(15px);z-index:3000;opacity:0;pointer-events:none;background:#000000d9;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.photo-modal-overlay.open{opacity:1;pointer-events:auto}.photo-modal-content{border-radius:24px;width:90%;max-width:440px;transition:transform .4s cubic-bezier(.175,.885,.32,1.1);position:relative;overflow:hidden;transform:scale(.95);box-shadow:0 20px 40px #00000080}.photo-modal-overlay.open .photo-modal-content{transform:scale(1)}.photo-modal-content img{width:100%;display:block}.photo-modal-footer{-webkit-backdrop-filter:blur(10px);background:#141414e6;border-top:1px solid #ffffff1a;padding:20px}.photo-modal-title{color:#fff;margin-bottom:6px;font-size:1.1rem;font-weight:700}.photo-modal-caption{color:#ffffffb3;font-size:.9rem;line-height:1.4}.calendar-cell.selected-date{background:var(--primary-color);border-radius:10px}.calendar-cell.selected-date span{color:#fff;font-weight:700}.day-detail-panel{background:var(--bg-widget);border:1px solid var(--border-color);border-radius:20px;margin-bottom:16px;padding:16px 18px;animation:.25s fadeInDown}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.day-detail-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.day-detail-date{color:var(--primary-color);letter-spacing:-.02em;font-size:1.05rem;font-weight:800}.day-empty-state{text-align:center;padding:14px 0}.day-empty-state span{color:var(--text-secondary);font-size:.95rem;font-weight:700}.day-empty-state p{color:var(--text-secondary);opacity:.6;margin-top:4px;font-size:.78rem}.day-event-list{flex-direction:column;gap:8px;display:flex}.day-event-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:10px;padding:10px 12px;display:flex}.day-event-item.special{background:linear-gradient(135deg,#ffb6c11f,#ffb6c10a);border-color:#ffb6c14d}.day-event-time{color:var(--primary-color);white-space:nowrap;min-width:60px;font-size:.78rem;font-weight:700}.day-event-title{color:var(--text-main);flex:1;font-size:.9rem;font-weight:600}.day-add-btn{background:var(--bg-card);border:1.5px solid var(--border-color);width:34px;height:34px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.day-add-btn:active{transform:scale(.9)}.event-date-badge{background:var(--primary-color);border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:38px;padding:4px 6px;display:flex}.event-badge-month{color:#fffc;font-size:.62rem;font-weight:700;line-height:1}.event-badge-day{color:#fff;font-size:1rem;font-weight:800;line-height:1.2}.news-tab-container{padding-bottom:0}.news-sticky-header{z-index:1000;-webkit-backdrop-filter:blur(24px);background:#ffffffe0;border-bottom:1px solid #00000012;padding:10px 16px 8px;position:sticky;top:0}.news-category-chips{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.news-category-chips::-webkit-scrollbar{display:none}.news-chip{background:var(--bg-widget);color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:6px 16px;font-size:.82rem;font-weight:600;transition:all .25s}.news-chip.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 3px 8px #0000001a}.news-list-container{flex-direction:column;padding-top:4px;display:flex}.news-section-header{align-items:center;padding:14px 0 8px;display:flex}.news-section-title{color:#8e8e93;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:700}.news-grid-2col{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.news-grid-card{background:var(--bg-widget);border:1px solid var(--border-color);cursor:pointer;border-radius:14px;transition:transform .15s;overflow:hidden;box-shadow:0 2px 8px #0000000a}.news-grid-card:active{transform:scale(.97)}.news-grid-img{aspect-ratio:4/3;width:100%;overflow:hidden}.news-grid-img img{object-fit:cover;width:100%;height:100%;display:block}.news-grid-info{padding:8px 10px 10px}.news-grid-title{color:var(--text-main);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:5px;font-size:.82rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.news-grid-source{color:var(--text-secondary);font-size:.7rem;font-weight:500}.news-banner-card{background:var(--bg-widget);border:1px solid var(--border-color);cursor:pointer;border-radius:14px;align-items:stretch;margin-bottom:10px;transition:transform .15s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000000a}.news-banner-card:active{transform:scale(.98)}.news-banner-card img{object-fit:cover;flex-shrink:0;width:100px;height:80px;display:block}.news-banner-info{flex-direction:column;flex:1;justify-content:center;gap:4px;min-width:0;padding:10px 12px;display:flex}.news-banner-title{color:var(--text-main);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.news-digest-section{background:var(--bg-widget);border:1px solid var(--border-color);border-radius:16px;margin-top:4px;padding:0 14px;overflow:hidden}.news-digest-list{flex-direction:column;display:flex}.news-digest-row{border-bottom:1px solid var(--border-color);cursor:pointer;align-items:center;gap:8px;padding:12px 0;display:flex}.news-digest-row:last-child{border-bottom:none}.news-digest-row:active{opacity:.6}.news-digest-info{flex:1;min-width:0}.news-digest-title{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:.88rem;font-weight:600;overflow:hidden}.news-digest-source{color:var(--text-secondary);font-size:.72rem}.news-card{background:var(--bg-widget);border:1px solid var(--border-color);cursor:pointer;border-radius:24px;transition:transform .2s;overflow:hidden;box-shadow:0 8px 25px #0000000f}.news-card:active{transform:scale(.98)}.news-card.text-only{flex-direction:column;justify-content:center;padding:8px 0;display:flex}.news-card.text-only .news-title{font-size:1.25rem;line-height:1.45}.news-img-wrapper{aspect-ratio:16/9;width:100%;overflow:hidden}.news-card.arch-style .news-img-wrapper{aspect-ratio:4/3}.news-img-wrapper img{object-fit:cover;width:100%;height:100%;display:block}.news-card-content{padding:16px 20px}.news-title{color:var(--text-main);letter-spacing:-.02em;margin-bottom:12px;font-size:1.15rem;font-weight:700;line-height:1.35}.text-digest-card{padding:20px}.text-digest-header{border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:12px}.text-digest-list{flex-direction:column;gap:16px;margin:0;padding:0;list-style:none;display:flex}.text-digest-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding-bottom:16px}.text-digest-item:last-child{border-bottom:none;padding-bottom:0}.text-digest-item:active .news-title-small{color:var(--primary-color)}.news-card.arch-style .news-title{font-size:1.35rem;font-weight:800}.news-meta{justify-content:space-between;align-items:center;display:flex}.news-source{color:var(--text-secondary);font-size:.8rem;font-weight:500}.bookmark-btn{background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.bookmark-btn:active{background:var(--bg-secondary);transform:scale(.9)}.modal-close-btn{-webkit-backdrop-filter:blur(8px);color:#fff;z-index:3010;background:#fff3;border:1px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.modal-close-btn:active{transform:scale(.9)}.intereal-container{background-color:var(--bg-main);width:100%;height:calc(100vh - 84px);position:relative;overflow:hidden}.intereal-iframe{opacity:0;border:none;width:100%;height:100%;transition:opacity .8s ease-in-out}.intereal-iframe.loaded{opacity:1}.loading-overlay{background:var(--bg-main);z-index:10;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .5s;display:flex;position:absolute;top:0;left:0}.architectural-loader{border:1.5px solid var(--primary-color);width:50px;height:50px;margin-bottom:24px;animation:2.5s ease-in-out infinite box-draw;position:relative}.architectural-loader:before{content:"";background:#007aff26;width:1px;height:80px;position:absolute;top:-15px;left:50%;transform:translate(-50%)}.architectural-loader:after{content:"";background:#007aff26;width:80px;height:1px;position:absolute;top:50%;left:-15px;transform:translateY(-50%)}@keyframes box-draw{0%{border-color:var(--primary-color);border-radius:4px;transform:rotate(0)scale(.95)}50%{border-color:#5856d6;border-radius:50%;transform:rotate(180deg)scale(1.05)}to{border-color:var(--primary-color);border-radius:4px;transform:rotate(360deg)scale(.95)}}.loading-text{letter-spacing:3px;color:var(--text-secondary);text-transform:uppercase;font-family:Outfit,sans-serif;font-size:.85rem;animation:2s infinite pulse-text}@keyframes pulse-text{0%,to{opacity:.4;transform:translateY(0)}50%{opacity:.9;transform:translateY(-2px)}}.dudung-chat-container{background:var(--bg-main);flex-direction:column;height:calc(100vh - 84px);display:flex;position:relative;overflow:hidden}.dudung-chat-header{-webkit-backdrop-filter:blur(24px);z-index:10;background:#ffffffbf;border-bottom:1px solid #00000014;flex-shrink:0;padding:12px 16px}.partner-info{align-items:center;gap:12px;display:flex}.chat-profile-wrap{background:0 0;border:1px solid #0000000d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;overflow:hidden;box-shadow:0 2px 8px #00000014}.chat-profile-wrap.small{width:32px;height:32px}.chat-profile-wrap.msg-avatar{align-self:flex-end;width:36px;height:36px;margin-bottom:2px}.chat-profile-wrap.emoji-tab-avatar{width:26px;height:26px}.chat-profile-img{object-fit:cover;border-radius:0;width:100%;height:100%}.my-info-wrap{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.my-name-label{color:var(--text-secondary);font-size:.78rem;font-weight:600}.partner-name{color:#1c1c1e;font-size:1rem;font-weight:700}.partner-status{color:#636366;align-items:center;gap:6px;margin-top:2px;font-size:.8rem;font-weight:500;display:flex}.status-dot{background:#8e8e93;border-radius:50%;width:8px;height:8px}.status-dot.online{background:#34c759;box-shadow:0 0 8px #34c75966}.dudung-messages-wrapper{background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.dudung-messages{z-index:1;flex-direction:column;flex:1;gap:4px;padding:16px 12px 8px;display:flex;overflow-y:auto;background:0 0!important}.chat-watermark{clip-path:inset(0 0 22%);opacity:.1;pointer-events:none;z-index:0;background-image:url(/assets/LOGOImage.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:280px;height:280px;position:absolute;top:calc(51% + 5px);left:50%;transform:translate(-50%,-50%)}.msg-row,.chat-empty-state,.date-divider{z-index:1;position:relative}.dudung-messages::-webkit-scrollbar{width:4px}.dudung-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.date-divider{justify-content:center;align-items:center;margin:12px 0 8px;display:flex}.date-divider span{color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);background:#ffffff0f;border-radius:20px;padding:4px 14px;font-size:.75rem}.msg-row{align-items:flex-end;gap:8px;max-width:100%;animation:.25s cubic-bezier(.34,1.56,.64,1) msgSlideUp;display:flex}@keyframes msgSlideUp{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.msg-row.mine{flex-direction:row-reverse}.msg-avatar-bubble{border-radius:50%;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:34px;height:34px;margin-bottom:2px;font-size:1rem;display:flex}.msg-body{flex-direction:column;gap:3px;max-width:72%;display:flex}.msg-sender-name{color:var(--text-secondary);margin-left:4px;font-size:.75rem;font-weight:500}.msg-row-inner{align-items:flex-end;gap:5px;display:flex}.msg-row.mine .msg-row-inner{flex-direction:row-reverse}.msg-bubble{word-break:break-word;border-radius:20px 20px 20px 4px;padding:10px 14px;font-size:.965rem;line-height:1.5;box-shadow:0 3px 10px #0000002e;color:#fff!important}.msg-bubble.bubble-mine{border:none;border-radius:20px 20px 4px}.msg-bubble.bubble-theirs{border:none;border-radius:20px 20px 20px 4px}.msg-row.mine .msg-bubble{border:none;border-radius:20px 20px 4px;box-shadow:0 4px 16px #0003;color:#fff!important}.msg-emoji-img{border-radius:8px;max-width:100px;max-height:100px;display:block}.msg-emoji-text{padding:4px 0;font-size:2.5rem;line-height:1;display:block;background:0 0!important;border:none!important}.msg-meta{flex-direction:column;align-items:center;gap:2px;padding-bottom:4px;display:flex}.msg-time{color:var(--text-secondary);white-space:nowrap;font-size:.68rem}.unread-badge{color:#ffb300;font-size:.68rem;font-weight:700;line-height:1}.emoji-panel{background:rgba(var(--bg-widget-rgb,28, 28, 30), .95);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border-color);flex-shrink:0;max-height:280px;padding:0;animation:.2s panelSlideUp}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.emoji-tabs{border-bottom:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 12px 6px;display:flex}.emoji-tab-btn{cursor:pointer;opacity:.55;color:var(--text-main);background:0 0;border:2px solid #0000;border-radius:20px;align-items:center;gap:6px;padding:5px 12px 5px 6px;font-size:.85rem;font-weight:600;transition:all .15s;display:flex}.emoji-tab-btn.active{background:var(--bg-secondary);opacity:1;border-color:currentColor}.emoji-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:auto;padding:6px;transition:all .15s;display:flex}.emoji-close-btn:active{transform:scale(.85)}.emoji-sticker-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:56px;gap:4px;max-height:240px;padding:8px 10px;display:grid;overflow-y:auto}.emoji-sticker-item{cursor:pointer;box-sizing:border-box;background:#ffffff0f;border:none;border-radius:8px;justify-content:center;align-items:center;width:100%;height:56px;padding:3px;transition:background .12s,transform .12s;display:flex;overflow:hidden}.emoji-sticker-item:active{background:#ffffff26;transform:scale(.85)}.emoji-sticker-item img{object-fit:contain;pointer-events:none;width:100%;height:100%;font-size:0;display:block}.msg-emoji-sticker{border-radius:8px;width:auto;max-width:106px;height:auto;max-height:106px;display:block}.msg-bubble.bubble-media{box-shadow:none;border-style:solid;border-width:3px;padding:6px;background:0 0!important}.msg-photo-img{object-fit:cover;border-radius:12px;width:auto;max-width:180px;height:auto;max-height:180px;display:block}.upload-progress-bar{background:#ffffff0d;flex-shrink:0;align-items:center;height:30px;display:flex;position:relative;overflow:hidden}.upload-progress-fill{background:var(--primary-color);opacity:.3;transition:width .2s;position:absolute;top:0;bottom:0;left:0}.upload-progress-text{z-index:1;color:var(--text-secondary);padding:0 14px;font-size:.78rem;font-weight:600;position:relative}.chat-error-bar{color:#fff;text-align:center;cursor:pointer;background:#ff3b30;flex-shrink:0;padding:8px 16px;font-size:.82rem}.chat-empty-state{text-align:center;color:var(--text-secondary);margin-top:60px;font-size:.95rem}.dudung-input-bar{-webkit-backdrop-filter:blur(24px);background:#ffffffd9;border-top:1px solid #00000014;flex-shrink:0;align-items:flex-end;gap:8px;padding:10px 12px;display:flex}.input-action-btn{color:#8e8e93;cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .15s;display:flex}.input-action-btn:hover{color:#333;background:#0000000a}.input-action-btn:active{transform:scale(.88)}.dudung-text-input{color:#1c1c1e;resize:none;background:#0000000a;border:none;border-radius:20px;outline:none;flex:1;max-height:100px;padding:10px 16px;font-family:inherit;font-size:.96rem;line-height:1.45;transition:background .2s}.dudung-text-input:focus{border-color:var(--primary-color);background:#0000000f}.dudung-text-input::placeholder{color:var(--text-secondary);opacity:.6}.send-btn{color:#fff;cursor:pointer;opacity:.4;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.send-btn.active{opacity:1;transform:scale(1);box-shadow:0 4px 14px #0000004d}.send-btn:disabled{cursor:default}.send-btn.active:active{transform:scale(.88)}.lightbox-overlay{z-index:9999;background:#000000eb;flex-direction:column;justify-content:center;align-items:center;animation:.18s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-toolbar{z-index:1;position:absolute;top:16px;right:16px}.lightbox-close{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s;display:flex}.lightbox-close:hover{background:#ffffff47}.lightbox-img{object-fit:contain;border-radius:12px;max-width:92vw;max-height:80vh;animation:.2s zoomIn;box-shadow:0 20px 60px #0009}@keyframes zoomIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.lightbox-hint{color:#fff6;letter-spacing:.02em;margin-top:16px;font-size:.78rem}.nav-btn{color:#fff;cursor:pointer;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.nav-btn:hover:not(:disabled){background:#ffffff4d;transform:translateY(-50%)scale(1.05)}.nav-btn:disabled{opacity:.15;cursor:not-allowed}.prev-btn{left:16px}.next-btn{right:16px}.gallery-slide-container{-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.gallery-slide-container img{object-fit:contain;max-width:100%;max-height:80vh;transition:transform .2s ease-out}.gallery-counter{letter-spacing:2px;background:#00000080;border-radius:12px;margin-bottom:8px;padding:4px 12px;font-size:.85rem;display:inline-block}.theme-action-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:.82rem}.theme-action-btn:hover{color:var(--text-main);font-weight:600}.theme-action-btn.delete:hover{color:#ff3b30}.goldtree-settings-panel{z-index:3000;justify-content:flex-end;display:flex;position:absolute;inset:0;overflow:hidden}.settings-blur-bg{-webkit-backdrop-filter:blur(8px);background:#0006;animation:.3s fadeIn;position:absolute;inset:0}.settings-sheet{-webkit-backdrop-filter:blur(34px)saturate(180%);background:#ffffffb8;border-left:1px solid #fff6;flex-direction:column;width:85%;max-width:380px;height:100%;animation:.4s cubic-bezier(.16,1,.3,1) slideInRight;display:flex;position:relative;box-shadow:-10px 0 40px #00000026}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.sheet-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex}.sheet-title{color:#1c1c1e;letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.sheet-close{color:#1c1c1e;background:#0000000a;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.sheet-close:active{background:#00000014;transform:scale(.9)}.sheet-body{flex-direction:column;flex:1;gap:20px;padding:20px;display:flex;overflow-y:auto}.settings-card{background:#fff9;border:1px solid #fffc;border-radius:24px;padding:20px;box-shadow:0 4px 15px #00000008}.card-title{color:#8e8e93;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:.8rem;font-weight:700}.settings-line{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.settings-line:last-child{border-bottom:none}.settings-line.clickable:active{opacity:.6}.line-info{flex-direction:column;gap:2px;display:flex}.line-label{color:#1c1c1e;font-size:.98rem;font-weight:600}.line-sub{color:#8e8e93;font-size:.8rem}.gold-toggle{cursor:pointer;background:#e9e9ea;border-radius:15px;width:52px;height:30px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.gold-toggle.on{background:#34c759;box-shadow:0 0 12px #34c7594d}.gold-handle{background:#fff;border-radius:50%;width:26px;height:26px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px;box-shadow:0 2px 5px #00000026}.gold-toggle.on .gold-handle{transform:translate(22px)}.sheet-footer{text-align:center;border-top:1px solid #0000000f;padding:24px}.footer-logo{color:#1c1c1e;opacity:.15;letter-spacing:4px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:900}.step-control{gap:6px;display:flex}.step-btn{color:#8e8e93;cursor:pointer;background:#0000000a;border:1.5px solid #00000014;border-radius:10px;width:40px;height:32px;font-size:.82rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1)}.step-btn.active{color:#fff;border-color:#0000;transform:scale(1.05);box-shadow:0 3px 8px #00000026}.step-btn:disabled{opacity:.3;cursor:not-allowed}.step-btn:not(:disabled):active{transform:scale(.95)}.line-disabled{opacity:.35;pointer-events:none}.settings-trigger{color:#636366;flex-shrink:0;margin-left:8px;margin-right:0;transition:transform .25s,color .2s}.settings-trigger:active{color:var(--primary-color);transform:rotate(45deg)}.chat-dark-mode{background:#1c1c1e!important}.chat-dark-mode .dudung-messages-wrapper{background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.1'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.chat-dark-mode .dudung-chat-header{border-bottom-color:#ffffff1a;background:#1c1c1ecc!important}.chat-dark-mode .partner-name{color:#fff}.chat-dark-mode .header-icon-btn svg{color:#8e8e93!important}.passcode-gate-overlay{z-index:999999;background-color:#fff;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.passcode-container{flex-direction:column;align-items:center;width:100%;max-width:400px;padding:40px 20px;display:flex}.passcode-header{text-align:center;margin-bottom:40px}.passcode-logo-wrap{justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 20px;display:flex}.passcode-logo{mix-blend-mode:multiply;width:100%;height:auto}.passcode-title{color:var(--text-main);margin-bottom:8px;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700}.passcode-subtitle{color:var(--text-secondary);font-size:.9rem}.passcode-dots{gap:20px;margin-bottom:60px;display:flex}.dot{border:1.5px solid var(--border-color);background:0 0;border-radius:50%;width:14px;height:14px;transition:all .2s cubic-bezier(.4,0,.2,1)}.dot.filled{background:var(--primary-color);border-color:var(--primary-color);transform:scale(1.2)}.dot.error{background:#ff3b30;border-color:#ff3b30}.passcode-keypad{grid-template-columns:repeat(3,1fr);gap:24px;width:100%;max-width:320px;display:grid}.key-btn{width:72px;height:72px;color:var(--text-main);cursor:pointer;background:#00000008;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.6rem;font-weight:500;transition:all .2s;display:flex}.key-btn:active{background:#0000001a;transform:scale(.9)}.key-btn.empty{cursor:default;background:0 0}.key-btn.action-btn{color:var(--text-secondary);background:0 0}.passcode-footer{color:var(--text-secondary);opacity:.6;align-items:center;gap:6px;margin-top:60px;font-size:.75rem;display:flex}.shake{animation:.4s cubic-bezier(.36,.07,.19,.97) both shake}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}
