:root{--bg-primary:#faf6f0;--bg-secondary:#f3ece0;--text-primary:#3c3530;--text-secondary:#7a6e67;--text-muted:#a69990;--accent-pink:#d48888;--accent-pink-hover:#c37474;--accent-pink-light:#f7e8e8;--accent-pink-rgb:212, 136, 136;--accent-gold:#d9a05b;--accent-gold-light:#fbf1e4;--accent-green:#859980;--accent-green-light:#eff3ee;--accent-red:#c96f6f;--accent-red-light:#fcebeb;--card-bg:#ffffffd9;--card-border:#fff9;--card-shadow:0 8px 32px 0 #c7b6a91f;--border-radius-sm:8px;--border-radius-md:16px;--border-radius-lg:24px;--focus-ring:3px solid #d4888880;--transition-speed:.3s;--lock-overlay-bg:#faf6f0b3}body.dark-theme{--bg-primary:#151312;--bg-secondary:#221e1c;--text-primary:#f0e8e0;--text-secondary:#beb1a5;--text-muted:#8c7e73;--accent-pink:#e9a9a9;--accent-pink-hover:#f1c3c3;--accent-pink-light:#2d2323;--accent-pink-rgb:233, 169, 169;--accent-gold:#e8b87c;--accent-gold-light:#2e261d;--accent-green:#a4bba0;--accent-green-light:#222921;--accent-red:#e08b8b;--accent-red-light:#331e1e;--card-bg:#1e1b19d9;--card-border:#ffffff0d;--card-shadow:0 8px 32px 0 #00000059;--lock-overlay-bg:#151312b3}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px;overflow-x:hidden}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color var(--transition-speed) ease, color var(--transition-speed) ease;padding-bottom:calc(90px + env(safe-area-inset-bottom,0px));flex-direction:column;font-family:Outfit,Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;display:flex;position:relative;overflow-x:hidden}.app-root-container{flex-direction:column;width:100%;min-height:100vh;display:flex;position:relative;overflow-x:hidden}.bg-blobs-container{z-index:-1;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.blob{filter:blur(120px);z-index:-1;opacity:.45;pointer-events:none;border-radius:50%;position:absolute}.blob-1{background:radial-gradient(circle, rgba(var(--accent-pink-rgb), .3) 0%, #0000 70%);width:500px;height:500px;animation:20s infinite alternate float-slow;top:-100px;right:-100px}.blob-2{background:radial-gradient(circle,#d9a05b33 0%,#0000 70%);width:400px;height:400px;animation:25s infinite alternate-reverse float-slow;bottom:20%;left:-100px}@keyframes float-slow{0%{transform:translate(0)scale(1)}to{transform:translate(40px,60px)scale(1.1)}}h1,h2,h3,h4{color:var(--text-primary);font-weight:700;line-height:1.3}a,button,input,select,textarea{color:inherit;font-family:inherit;font-size:1rem}button{cursor:pointer;background:0 0;border:none;transition:all .2s cubic-bezier(.4,0,.2,1)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:var(--focus-ring);outline-offset:2px}.screen{opacity:1;transition:opacity .3s}.screen.hidden{opacity:0;display:none!important}.app-header{z-index:100;background:var(--bg-primary);border-bottom:1px solid var(--card-border);transition:background-color var(--transition-speed) ease;padding:.8rem 0;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;max-width:900px;margin:0 auto;padding:0 1.5rem;display:flex}.brand{flex-direction:column;display:flex}.brand.clickable{cursor:pointer;transition:opacity .2s,transform .2s}.brand.clickable:hover{opacity:.8;transform:scale(1.01)}.brand.clickable:active{transform:scale(.99)}.brand-title{letter-spacing:-.5px;font-size:1.15rem;font-weight:700}.brand-cursive{color:var(--accent-pink);margin-bottom:-5px;font-family:Zhi Mang Xing,Outfit,cursive;font-size:1.5rem}.btn-icon{background:var(--card-bg);border:1px solid var(--card-border);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000d}.btn-icon:hover{background:var(--bg-secondary);transform:translateY(-2px)scale(1.05)}.sun-icon,.moon-icon,.settings-icon{width:18px;height:18px;transition:transform .4s cubic-bezier(.16,1,.3,1)}.btn-icon:hover .settings-icon{transform:rotate(45deg)}.header-actions{align-items:center;gap:.75rem;display:flex}.header-actions .week-selector-bar{box-shadow:none;z-index:101;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:0;padding:0;display:flex}@media (width<=576px){.header-actions .custom-dropdown{min-width:130px}.header-actions .dropdown-trigger{gap:.4rem;padding:.4rem .6rem;font-size:.75rem}.brand-title{font-size:.95rem}.brand-cursive{font-size:1.25rem}}.app-main{box-sizing:border-box;flex:1;width:100%;max-width:900px;margin:1.5rem auto 0;padding:0 1.5rem}.hero-banner{border-radius:var(--border-radius-lg);width:100%;height:240px;box-shadow:var(--card-shadow);margin-bottom:1.5rem;position:relative;overflow:hidden}.banner-img{object-fit:cover;width:100%;height:100%;display:block}.banner-overlay{color:#fff;background:linear-gradient(#0000 0%,#000000bf 100%);flex-direction:column;justify-content:flex-end;padding:2rem 1.5rem 1.5rem;display:flex;position:absolute;bottom:0;left:0;right:0}.banner-overlay h2{color:#fff;margin-bottom:.4rem;font-size:1.6rem;font-weight:700}.banner-overlay p{color:#ffffffd9;max-width:550px;font-size:.9rem}.nav-tabs{bottom:calc(1.8rem + env(safe-area-inset-bottom,0px));box-sizing:border-box;z-index:1000;-webkit-backdrop-filter:blur(20px);background:#fff3;border:1px solid #ffffff4d;border-radius:100px;width:calc(100% - 3rem);max-width:480px;margin-bottom:0;padding:.45rem;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0000000a}body.dark-theme .nav-tabs{background:#0003;border:1px solid #ffffff14;box-shadow:0 10px 30px #00000040}.nav-tabs-indicator{z-index:0;pointer-events:none;background:#ffffffb3;border:1px solid #ffffff80;border-radius:100px;width:0;transition:transform .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1);position:absolute;top:.45rem;bottom:.45rem;left:0;box-shadow:0 4px 12px #0000000f}body.dark-theme .nav-tabs-indicator{background:#ffffff1f;border:1px solid #ffffff1a}.tab-btn{color:var(--text-secondary);cursor:pointer;z-index:1;background:0 0;border:none;border-radius:100px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.8rem .5rem;font-size:.85rem;font-weight:600;transition:color .25s;display:flex}.tab-icon{width:16px;height:16px;transition:transform .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-pink)}.tab-btn.active .tab-icon{transform:scale(1.1)}.tab-panel{display:none}.tab-panel.active{display:block}#screen-app{padding-bottom:0}body.no-scroll{overflow:hidden}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;opacity:0;pointer-events:none;visibility:hidden;background:#0006;justify-content:center;align-items:center;transition:opacity .3s,visibility .3s;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none!important}.modal-overlay.active{opacity:1;pointer-events:auto;visibility:visible}.modal-card{background:var(--bg-primary);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);opacity:0;flex-direction:column;width:90%;max-width:500px;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s;display:flex;overflow:hidden;transform:scale(.92)translateY(15px);box-shadow:0 20px 40px #00000026}.modal-overlay.active .modal-card{opacity:1;transform:scale(1)translateY(0)}.modal-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:600}.btn-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s,color .2s;display:flex}.btn-close:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.btn-close svg{width:20px;height:20px}.modal-body{max-height:70vh;padding:1.5rem;overflow-y:auto}.settings-section{margin-bottom:1.5rem}.settings-section:last-child{margin-bottom:0}.settings-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.85rem;font-weight:600}.settings-row{background:var(--card-bg);border-radius:var(--border-radius-md);border:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.settings-info{flex-direction:column;gap:.25rem;padding-right:1rem;display:flex}.settings-title{color:var(--text-primary);font-size:1rem;font-weight:600}.settings-desc{color:var(--text-secondary);font-size:.85rem;line-height:1.35}.room-settings-box{background:var(--card-bg);border-radius:var(--border-radius-md);border:1px solid var(--card-border);flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.room-settings-box .settings-desc{margin-bottom:.5rem}.settings-actions-vertical{flex-direction:column;gap:.75rem;display:flex}@media (width<=600px){.modal-overlay{align-items:flex-end}.modal-card{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;border-bottom:none;width:100%;max-height:85vh;transform:translateY(100%)}.modal-overlay.active .modal-card{transform:translateY(0)}}.week-selector-bar{z-index:50;background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--card-border);border-radius:var(--border-radius-md);box-shadow:var(--card-shadow);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:.75rem 1.25rem;display:flex;position:relative}.week-selector-bar label{color:var(--text-secondary);font-size:.95rem;font-weight:500}.custom-dropdown{min-width:180px;position:relative}.dropdown-trigger{background:var(--bg-secondary);border:1px solid var(--card-border);width:100%;color:var(--text-primary);cursor:pointer;transition:all var(--transition-speed) ease;-webkit-user-select:none;user-select:none;border-radius:20px;justify-content:space-between;align-items:center;gap:.8rem;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;display:flex}.dropdown-trigger:hover{background:var(--accent-pink-light);border-color:rgba(var(--accent-pink-rgb), .3)}body.dark-theme .dropdown-trigger:hover{background:rgba(var(--accent-pink-rgb), .15);border-color:rgba(var(--accent-pink-rgb), .4)}.dropdown-trigger:focus-visible{outline:var(--focus-ring);outline-offset:2px}.dropdown-arrow{color:var(--text-muted);justify-content:center;align-items:center;display:flex}.arrow-svg{width:12px;height:12px;transition:transform .25s}.custom-dropdown.active .arrow-svg{transform:rotate(180deg)}.dropdown-menu{background:var(--bg-primary);border:1px solid var(--card-border);border-radius:var(--border-radius-md);z-index:1100;transform-origin:100% 0;flex-direction:column;gap:.2rem;width:280px;max-height:250px;padding:.4rem;animation:.2s cubic-bezier(.16,1,.3,1) dropdown-fade-in;display:none;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto;box-shadow:0 10px 30px #0000001f}.custom-dropdown.active .dropdown-menu{display:flex}@keyframes dropdown-fade-in{0%{opacity:0;transform:scale(.95)translateY(-5px)}to{opacity:1;transform:scale(1)translateY(0)}}.dropdown-item{border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;justify-content:space-between;align-items:center;padding:.55rem .85rem;font-size:.85rem;transition:all .15s;display:flex}.dropdown-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.dropdown-item.active{background:var(--accent-pink-light);color:var(--accent-pink);font-weight:600}body.dark-theme .dropdown-item.active{background:rgba(var(--accent-pink-rgb), .15);color:var(--accent-pink)}.dropdown-menu::-webkit-scrollbar{width:8px}.dropdown-menu::-webkit-scrollbar-track{background:0 0;margin:8px 0}.dropdown-menu::-webkit-scrollbar-thumb{background:var(--text-muted);border:2px solid var(--bg-primary);border-radius:10px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);box-shadow:var(--card-shadow);margin-bottom:1.2rem;padding:1.5rem;transition:box-shadow .2s;position:relative}.card h3{align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:1.2rem;display:flex}.section-desc{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.85rem;line-height:1.5}.card-badge{background:var(--accent-pink-light);color:var(--accent-pink);border-radius:50px;padding:.2rem .6rem;font-size:.7rem;font-weight:600;position:absolute;top:1.25rem;right:1.25rem}.form-standard{flex-direction:column;gap:1.2rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.form-standard input[type=text]{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:var(--border-radius-sm);width:100%;min-height:48px;color:var(--text-primary);padding:.75rem 1rem;font-size:1rem;transition:all .2s;box-shadow:inset 0 1px 2px #00000005}.form-standard input[type=text]:focus{border-color:var(--accent-pink);background:var(--card-bg)}.btn-full{width:100%}.onboarding-card{max-width:450px;margin:3rem auto}.share-box{background:var(--bg-secondary);border-radius:var(--border-radius-sm);border:1px solid var(--card-border);gap:.5rem;margin:1.5rem 0;padding:.4rem;display:flex}.share-box input[type=text]{color:var(--text-secondary);text-overflow:ellipsis;background:0 0;border:none;outline:none;flex:1;padding:.5rem;font-size:.9rem;overflow:hidden}.share-box button{white-space:nowrap;padding:.5rem 1rem;font-size:.85rem}.onboarding-actions{margin-top:1rem}.join-info-card{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--card-border);margin-bottom:1.5rem;padding:1.5rem}.status-card{text-align:center;border:2px dashed var(--accent-pink);flex-direction:column;align-items:center;gap:1rem;display:flex}.status-header{align-items:center;gap:.5rem;display:flex}.status-indicator-dot{border-radius:50%;width:10px;height:10px}.status-indicator-dot.pending{background-color:var(--accent-gold);box-shadow:0 0 10px var(--accent-gold)}.status-indicator-dot.ready{background-color:var(--accent-green);box-shadow:0 0 10px var(--accent-green)}.status-description{max-width:500px;color:var(--text-secondary);font-size:.9rem}.filling-progress{justify-content:center;align-items:center;gap:1.2rem;width:100%;max-width:280px;margin:1.2rem auto;display:flex}.partner-progress-card{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--card-border);flex-direction:column;flex:1;align-items:center;gap:.4rem;padding:.8rem .5rem;display:flex}.avatar-circle{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:700;display:flex}.partner-a-avatar{background-color:var(--accent-pink)}.partner-b-avatar{background-color:var(--accent-gold)}.progress-details{text-align:center;flex-direction:column;align-items:center;width:100%;font-size:.8rem;display:flex;overflow:hidden}.partner-name{white-space:nowrap;text-overflow:ellipsis;width:100%;font-weight:600;overflow:hidden}.fill-status{font-weight:500}.fill-status.complete{color:var(--accent-green)}.fill-status.pending{color:var(--text-muted)}.heart-divider{color:var(--accent-pink);font-size:1.7rem;animation:1.5s infinite heartbeat}@keyframes heartbeat{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.status-actions{margin-top:.25rem}.report-section{transition:all var(--transition-speed) ease;position:relative}.report-section.locked{pointer-events:none;-webkit-user-select:none;user-select:none;min-height:400px}.report-section.locked>:not(.lock-overlay){filter:blur(8px)}.report-section:not(.locked) .lock-overlay{display:none}.lock-overlay{z-index:10;background:var(--lock-overlay-bg);color:var(--text-primary);text-align:center;border-radius:var(--border-radius-lg);-webkit-backdrop-filter:contrast(.85);flex-direction:column;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:absolute;inset:0}.lock-icon{width:40px;height:40px;color:var(--accent-pink);margin-bottom:.8rem}.lock-overlay h3{margin-bottom:.4rem;font-size:1.3rem}.lock-overlay p{max-width:400px;color:var(--text-secondary);font-size:.85rem}.report-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.2rem;display:grid}.report-grid .full-width{grid-column:span 2}@media (width<=768px){.report-grid{grid-template-columns:1fr}.report-grid .full-width{grid-column:span 1}}.report-card-summary{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:260px;display:flex}.harmony-score-container{flex-direction:column;align-items:center;margin-bottom:1.2rem;display:flex}.harmony-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);font-size:.85rem;font-weight:500}.harmony-value{color:var(--accent-pink);margin:.4rem 0;font-family:Outfit,sans-serif;font-size:4.5rem;font-weight:800;line-height:1.1}.harmony-level{background-color:var(--accent-pink-light);color:var(--accent-pink);border-radius:50px;padding:.25rem 1rem;font-size:1rem;font-weight:700}.weekly-verdict{color:var(--text-secondary);max-width:320px;font-size:.9rem;line-height:1.5}.report-card-chart{text-align:center;flex-direction:column;align-items:center;min-height:380px;display:flex}.chart-desc{color:var(--text-muted);margin-bottom:.8rem;font-size:.8rem}.chart-wrapper{aspect-ratio:1;justify-content:center;align-items:center;width:100%;max-width:330px;display:flex}.radar-svg{width:100%;height:100%}.chart-legend{gap:1.2rem;margin-top:.8rem;font-size:.8rem;display:flex}.legend-item{align-items:center;gap:.4rem;display:flex}.legend-color{border-radius:50%;width:10px;height:10px;display:inline-block}.legend-color.color-a{background-color:var(--accent-pink)}.legend-color.color-b{background-color:var(--accent-gold)}.breakdown-list{flex-direction:column;gap:1rem;margin-top:.8rem;display:flex}.breakdown-item{flex-direction:column;gap:.3rem;display:flex}.breakdown-info{justify-content:space-between;font-size:.85rem;font-weight:500;display:flex}.breakdown-dim-name{color:var(--text-primary)}.breakdown-vals{color:var(--text-secondary)}.breakdown-bars-group{flex-direction:column;gap:5px;width:100%;display:flex}.breakdown-track{background-color:var(--bg-secondary);border-radius:4px;width:100%;height:6px;position:relative;overflow:hidden}.breakdown-bar-fill{border-radius:4px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0}.breakdown-bar-fill.bar-a{background-color:var(--accent-pink);opacity:.9}.breakdown-bar-fill.bar-b{background-color:var(--accent-gold);opacity:.9}.conflict-badge-container{text-align:center;flex-direction:column;align-items:center;gap:.8rem;padding:1rem 0;display:flex}.badge-art{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:2rem;display:flex;box-shadow:0 4px 15px #0000000d}.badge-art.perfect{background-color:var(--accent-green-light);border:2px solid var(--accent-green)}.badge-art.good{background-color:var(--accent-gold-light);border:2px solid var(--accent-gold)}.badge-art.warning{background-color:var(--accent-red-light);border:2px solid var(--accent-red)}.conflict-badge-name{font-size:1.15rem;font-weight:700}.conflict-badge-desc{color:var(--text-secondary);max-width:300px;font-size:.85rem;line-height:1.5}.messages-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;width:100%;margin-bottom:1.2rem;display:flex}.whisper-tabs{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:30px;align-items:center;gap:4px;padding:4px;display:inline-flex;box-shadow:inset 0 1px 3px #0000000a}.whisper-tab{height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:20px;justify-content:center;align-items:center;padding:0 1.2rem;font-size:.85rem;font-weight:600;line-height:1;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.whisper-tab:hover{color:var(--text-primary)}.whisper-tab:not(.active):hover{transform:translateY(-.5px)}.whisper-tab.active{background:var(--card-bg);color:var(--accent-pink);box-shadow:0 3px 8px #0000000f}body.dark-theme .whisper-tab.active{color:var(--accent-pink);box-shadow:0 3px 8px #00000040}.letters-container{background:var(--bg-secondary);border-radius:var(--border-radius-lg);background-image:radial-gradient(#856e5f26 1.5px,#0000 1.5px),radial-gradient(#856e5f14 1px,#0000 1px);background-position:0 0,12px 12px;background-size:24px 24px,12px 12px;border:1px dashed #856e5f40;justify-content:center;align-items:center;width:100%;min-height:300px;margin-top:.5rem;padding:2.8rem 1.8rem 2.2rem;display:flex;position:relative;box-shadow:inset 0 2px 8px #0000000a}body.dark-theme .letters-container{background-image:radial-gradient(#f0e8e00d 1.5px,#0000 1.5px),radial-gradient(#f0e8e008 1px,#0000 1px);border:1px dashed #f0e8e01f;box-shadow:inset 0 2px 8px #0003}.letter-card{z-index:1;border:none;border-radius:2px;width:100%;max-width:400px;padding:2.2rem 1.8rem 1.8rem;transition:opacity .3s,transform .3s;display:block;position:relative;box-shadow:0 6px 15px #0000000d}.letter-card:hover{transform:translateY(-2px)}.letter-card-tape{-webkit-backdrop-filter:blur(1.5px);z-index:10;pointer-events:none;clip-path:polygon(2px 0,100% 0,calc(100% - 2px) 4px,100% 8px,calc(100% - 3px) 12px,100% 16px,calc(100% - 2px) 20px,100% 24px,calc(100% - 1px) 100%,0% 100%,3px 24px,1px 20px,3px 16px,1px 12px,2px 8px,0 4px);opacity:.85;height:28px;position:absolute;top:-15px;left:50%;box-shadow:0 1px 2px #0000000d}.partner-a-letter .letter-card-tape{background:repeating-linear-gradient(45deg,#d4888859,#d4888859 4px,#d4888873 4px 8px);border-left:1px solid #d4888833;border-right:1px solid #d4888833;width:115px;transform:translate(-53%)rotate(-3.5deg)}.partner-b-letter .letter-card-tape{background:repeating-linear-gradient(-45deg,#d9a05b59,#d9a05b59 4px,#d9a05b73 4px 8px);border-left:1px solid #d9a05b33;border-right:1px solid #d9a05b33;width:95px;transform:translate(-47%)rotate(2.5deg)}body.dark-theme .partner-a-letter .letter-card-tape{background:repeating-linear-gradient(45deg,#e9a9a940,#e9a9a940 4px,#e9a9a959 4px 8px);border-left:1px solid #e9a9a926;border-right:1px solid #e9a9a926}body.dark-theme .partner-b-letter .letter-card-tape{background:repeating-linear-gradient(-45deg,#e8b87c40,#e8b87c40 4px,#e8b87c59 4px 8px);border-left:1px solid #e8b87c26;border-right:1px solid #e8b87c26}.partner-a-letter{color:#4a3434;background:linear-gradient(135deg,#fff2f2 0%,#fef0f0 100%);border-bottom:2px solid #f6d1d1}.partner-b-letter{color:#4a3f34;background:linear-gradient(135deg,#fffbf0 0%,#fef9eb 100%);border-bottom:2px solid #f6e6c2}body.dark-theme .partner-a-letter{color:#f7e8e8;background:linear-gradient(135deg,#382424 0%,#2f1d1d 100%);border-bottom:2px solid #5a3838}body.dark-theme .partner-b-letter{color:#fbf1e4;background:linear-gradient(135deg,#3b3122 0%,#2f271a 100%);border-bottom:2px solid #574631}@media (width>=601px){.partner-a-letter{transform:rotate(-.8deg)}.partner-b-letter{transform:rotate(.6deg)}}.letter-card.hidden{display:none!important}.letter-body{width:100%;margin-top:.2rem}.whisper-list{text-align:left;flex-direction:column;gap:.9rem;display:flex}.whisper-item{border-bottom:1px dashed #0000000f;padding-bottom:.9rem}body.dark-theme .whisper-item{border-bottom:1px dashed #ffffff14}.whisper-item:last-child{border-bottom:none;padding-bottom:0}.whisper-label{align-items:center;gap:.3rem;margin-bottom:.3rem;font-size:.85rem;font-weight:700;display:flex}.partner-a-letter .whisper-label.label-happy{color:#d46a6a}.partner-a-letter .whisper-label.label-improve{color:#d9903b}.partner-a-letter .whisper-label.label-action{color:#5f8558}.partner-b-letter .whisper-label.label-happy{color:#d46a6a}.partner-b-letter .whisper-label.label-improve{color:#d9903b}.partner-b-letter .whisper-label.label-action{color:#5f8558}body.dark-theme .partner-a-letter .whisper-label.label-happy,body.dark-theme .partner-b-letter .whisper-label.label-happy{color:#e9a9a9}body.dark-theme .partner-a-letter .whisper-label.label-improve,body.dark-theme .partner-b-letter .whisper-label.label-improve{color:#e8b87c}body.dark-theme .partner-a-letter .whisper-label.label-action,body.dark-theme .partner-b-letter .whisper-label.label-action{color:#a4bba0}.whisper-icon{font-size:.95rem}.whisper-content{color:inherit;opacity:.9;word-break:break-all;white-space:pre-wrap;margin:0;font-size:.92rem;line-height:1.6}@media (width<=600px){.messages-header-row{flex-direction:column;align-items:stretch;gap:.6rem}.whisper-tabs{justify-content:center;align-self:center;width:100%;display:flex}.whisper-tab{text-align:center;flex:1}.letters-container{min-height:250px;padding:2.2rem 1rem 1.5rem}.letter-card{padding:1.8rem 1.2rem 1.2rem}}.rubric-form-element{flex-direction:column;gap:.5rem;display:flex}.identity-confirm-box{background:var(--accent-pink-light);border-radius:var(--border-radius-md);border:1px solid var(--card-border);align-items:center;gap:.8rem;margin-top:.5rem;padding:1rem 1.25rem;display:flex}.identity-confirm-details{flex-direction:column;align-items:flex-start;display:flex}.identity-role{color:var(--accent-pink);font-size:.8rem;font-weight:600}.identity-name{font-size:1.05rem;font-weight:700}.share-invite-shortcut{color:var(--text-secondary);margin-top:.8rem;font-size:.8rem}.share-invite-shortcut a{color:var(--accent-pink);font-weight:600;text-decoration:underline}.form-group-rubric{flex-direction:column;gap:.8rem;margin-bottom:1.8rem;display:flex}.form-group-rubric:last-child{margin-bottom:.4rem}.rubric-header{flex-direction:column;gap:.2rem;display:flex}.rubric-title{color:var(--text-primary);font-size:1.05rem;font-weight:600}.rubric-hint{color:var(--text-secondary);font-size:.8rem}.score-slider-container{width:100%;margin-top:.4rem;padding:0 .4rem}.score-slider{appearance:none;background:var(--bg-secondary);cursor:pointer;width:100%;height:8px;accent-color:var(--accent-pink);border-radius:4px;outline:none}.score-slider::-webkit-slider-thumb{appearance:none;background:var(--accent-pink);border:3px solid var(--bg-primary);cursor:pointer;border-radius:50%;width:24px;height:24px;transition:transform .1s;box-shadow:0 2px 6px #00000026}.score-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.score-slider::-moz-range-thumb{background:var(--accent-pink);border:3px solid var(--bg-primary);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 2px 6px #00000026}.score-slider::-moz-range-thumb:hover{transform:scale(1.2)}.slider-ticks{color:var(--text-muted);justify-content:space-between;margin-top:.3rem;padding:0 .2rem;font-size:.75rem;font-weight:600;display:flex}.score-description{color:var(--accent-pink);background-color:var(--accent-pink-light);border-radius:var(--border-radius-sm);border-left:3px solid var(--accent-pink);align-items:center;min-height:38px;padding:.6rem 1rem;font-size:.85rem;font-weight:500;display:flex}.form-group-toggle{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--card-border);justify-content:space-between;align-items:center;margin-bottom:1.2rem;padding:.8rem 1.2rem;display:flex}.toggle-label-group{flex-direction:column;gap:.15rem;display:flex}.toggle-title{font-size:.95rem;font-weight:600}.toggle-desc{color:var(--text-secondary);font-size:.8rem}.switch-container{width:48px;height:26px;display:inline-block;position:relative}.switch-container input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:var(--text-muted);border-radius:34px;transition:all .4s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:4px;left:4px}.switch-container input:checked+.switch-slider{background-color:var(--accent-pink)}.switch-container input:checked+.switch-slider:before{transform:translate(22px)}.switch-container input:focus-visible+.switch-slider{outline:var(--focus-ring);outline-offset:2px}.conflict-details-group{flex-direction:column;gap:.8rem;animation:.3s cubic-bezier(.4,0,.2,1) forwards slide-down;display:flex;overflow:hidden}.conflict-details-group.hidden{display:none}@keyframes slide-down{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:500px;transform:translateY(0)}}.radio-group-title{color:var(--text-secondary);font-size:.9rem;font-weight:600}.conflict-options{flex-direction:column;gap:.8rem;display:flex}.conflict-option-card{cursor:pointer;position:relative}.conflict-option-card input[type=radio]{accent-color:var(--accent-pink);position:absolute;top:1.25rem;left:1.25rem}.conflict-option-card .option-content{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:2px solid #0000;gap:.8rem;padding:1rem 1rem 1rem 2.8rem;transition:all .2s;display:flex}.conflict-option-card:hover .option-content{background:var(--card-bg)}.option-icon{font-size:1.25rem;line-height:1.2}.option-text{text-align:left;flex-direction:column;align-items:flex-start;gap:.2rem;display:flex}.option-name{font-size:.95rem;font-weight:600}.option-impact{font-size:.75rem;font-weight:500}.text-penalty{color:var(--accent-red)}.text-bonus{color:var(--accent-gold)}.text-double-bonus{color:var(--accent-green)}.conflict-option-card.penalty input[type=radio]:checked+.option-content{border-color:var(--accent-red);background-color:var(--accent-red-light)}.conflict-option-card.bonus input[type=radio]:checked+.option-content{border-color:var(--accent-gold);background-color:var(--accent-gold-light)}.conflict-option-card.double-bonus input[type=radio]:checked+.option-content{border-color:var(--accent-green);background-color:var(--accent-green-light)}.conflict-option-card input[type=radio]:focus-visible+.option-content{outline:var(--focus-ring);outline-offset:2px}.custom-textarea{border:1px solid var(--card-border);background:var(--bg-secondary);border-radius:var(--border-radius-md);resize:vertical;width:100%;min-height:100px;padding:.8rem;font-size:1rem;line-height:1.5;transition:all .2s}.custom-textarea:focus{border-color:var(--accent-pink);background-color:var(--card-bg)}.form-submit-container{justify-content:center;margin:1.2rem 0 2.5rem;display:flex}.btn{border-radius:50px;justify-content:center;align-items:center;padding:.55rem 1.25rem;font-size:.95rem;font-weight:600;display:inline-flex;box-shadow:0 4px 10px #0000000d}.btn-primary{background:var(--accent-pink);color:#fff}.btn-primary:hover{background:var(--accent-pink-hover);box-shadow:0 6px 15px rgba(var(--accent-pink-rgb), .3);transform:translateY(-2px)}.btn-large{border-radius:50px;padding:.85rem 2.5rem;font-size:1.05rem}#submit-rubric-btn{letter-spacing:.5px;background:linear-gradient(135deg, var(--accent-pink) 0%, #ff7eb3 100%);box-shadow:0 8px 25px rgba(var(--accent-pink-rgb), .3);cursor:pointer;border:none;width:100%;max-width:380px;padding:1rem 4rem;font-size:1.15rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1)}#submit-rubric-btn:hover{box-shadow:0 12px 30px rgba(var(--accent-pink-rgb), .4);background:linear-gradient(135deg, var(--accent-pink-hover) 0%, #ff85b9 100%);transform:translateY(-3px)scale(1.02)}#submit-rubric-btn:active{transform:translateY(-1px)scale(.98)}.btn-danger-outline{border:1px solid var(--accent-red);color:var(--accent-red)}.btn-danger-outline:hover{background-color:var(--accent-red-light);transform:translateY(-2px)}.history-intro-card{text-align:left}.history-stats{grid-template-columns:1fr 1fr 1fr;gap:.8rem;margin-top:1.2rem;display:grid}.stat-box{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--card-border);flex-direction:column;align-items:center;gap:.2rem;padding:1rem .4rem;display:flex}.stat-num{color:var(--accent-pink);font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:800;line-height:1.1}.stat-label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.history-chart-card{margin-top:1.5rem}.history-chart-card h3{margin-bottom:.25rem}.history-chart-card .chart-desc{color:var(--text-secondary);margin-bottom:1rem;font-size:.85rem}.line-chart-wrapper{width:100%;padding:.5rem 0}.line-chart-svg{overflow:visible}.history-list{flex-direction:column;gap:.8rem;margin-top:.8rem;display:flex}.history-item-row{background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--card-border);cursor:pointer;justify-content:space-between;align-items:center;padding:1rem 1.25rem;transition:all .2s;display:flex}.history-item-row:hover{background:var(--card-bg);border-color:var(--accent-pink);transform:translate(4px)}.history-item-info{text-align:left;flex-direction:column;align-items:flex-start;gap:.15rem;display:flex}.history-week-name{font-size:.95rem;font-weight:700}.history-summary-text{color:var(--text-secondary);font-size:.8rem}.history-item-score-group{align-items:center;gap:1.2rem;display:flex}.history-score-display{flex-direction:column;align-items:flex-end;display:flex}.history-score-label{color:var(--text-muted);font-size:.7rem}.history-score-val{color:var(--accent-pink);font-size:1.2rem;font-weight:700}.history-arrow{color:var(--text-muted);font-size:.9rem}.empty-state{text-align:center;color:var(--text-muted);padding:2.5rem 0;font-size:.9rem}.room-settings-card{margin-top:2rem}.settings-actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:.5rem;display:flex}.settings-actions button{flex:1;min-width:150px}.rating-standards-card{border:1px solid var(--card-border)}.standards-list{flex-direction:column;gap:.6rem;margin-top:.5rem;list-style:none;display:flex}.standards-list li{color:var(--text-secondary);text-align:left;align-items:center;gap:.8rem;font-size:.85rem;display:flex}.standards-list li span{background:var(--accent-pink-light);color:var(--accent-pink);text-align:center;border-radius:4px;min-width:38px;padding:.15rem .5rem;font-size:.8rem;font-weight:700}.form-group-textarea{text-align:left;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.form-group-textarea label{color:var(--text-secondary);font-size:.95rem;font-weight:600}.insights-content{flex-direction:column;gap:1rem;display:flex}.insight-card{border-radius:var(--border-radius-md);text-align:left;border:1.5px solid #0000;align-items:flex-start;gap:1rem;padding:1.25rem;font-size:.9rem;line-height:1.5;display:flex}.insight-card.warning{background-color:var(--accent-red-light);border-color:var(--accent-red);color:var(--text-primary)}.insight-card.info{background-color:var(--accent-gold-light);border-color:var(--accent-gold);color:var(--text-primary)}.insight-card.success{background-color:var(--accent-green-light);border-color:var(--accent-green);color:var(--text-primary)}.insight-icon{flex-shrink:0;font-size:1.4rem;line-height:1}.insight-text{flex-direction:column;gap:.2rem;display:flex}.insight-text strong{color:var(--text-primary);font-size:.95rem;font-weight:700}.insights-loading{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2.5rem 1.5rem;display:flex}.loading-spinner{border:4px solid var(--accent-pink-light);border-top-color:var(--accent-pink);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spinner-rotation}.loading-text{color:var(--text-secondary);font-size:.95rem;animation:2s ease-in-out infinite text-pulse}@keyframes spinner-rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes text-pulse{0%,to{opacity:.6}50%{opacity:1}}.report-card-actions{margin-top:1rem}.report-card-actions h3{margin-bottom:.25rem}.card-desc{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.8rem}.action-list{flex-direction:column;gap:.8rem;padding:0;list-style:none;display:flex}.action-item{background-color:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-sm);transition:transform var(--transition-speed) ease, box-shadow var(--transition-speed) ease;align-items:center;gap:.75rem;padding:.85rem 1.25rem;display:flex}.action-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.action-number{background-color:var(--accent-pink);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.8rem;font-weight:700;display:flex}.action-text{color:var(--text-primary);text-align:left;font-size:.9rem}.action-empty{color:var(--text-muted);text-align:center;padding:1rem;font-size:.9rem}.app-footer{border-top:1px solid var(--card-border);color:var(--text-muted);z-index:10;justify-content:center;align-items:center;margin-top:1rem;padding:1rem 0;font-size:.75rem;display:flex}@media (width<=500px){html{font-size:14px}.app-main{margin:1rem auto;padding:0 1rem}.card{padding:1.25rem}.hero-banner{height:160px}.banner-overlay h2{font-size:1.3rem}.filling-progress{flex-direction:row;gap:.6rem;max-width:260px;margin:1rem auto}.partner-progress-card{padding:.6rem .3rem}.heart-divider{margin:0}.history-stats{grid-template-columns:1fr 1fr 1fr;gap:.5rem}.stat-box{padding:.75rem .25rem}.stat-num{font-size:1.5rem}.stat-label{font-size:.65rem}.settings-actions{flex-direction:column}}.toast-container{z-index:9999;animation:.3s cubic-bezier(.16,1,.3,1) forwards toast-slide-in;position:fixed;top:2rem;left:50%;transform:translate(-50%)}.toast-content{-webkit-backdrop-filter:blur(20px)saturate(180%);color:var(--text-primary);white-space:nowrap;background:#fff;border:1px solid #0000001f;border-radius:50px;align-items:center;gap:.75rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;display:flex;box-shadow:0 10px 30px #00000014}body.dark-theme .toast-content{background:#19191e;border-color:#0006;box-shadow:0 10px 30px #0000004d}.toast-icon{font-size:1.1rem}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.comment-toggle-section{flex-direction:column;align-items:flex-start;gap:.4rem;width:100%;margin-top:.6rem;display:flex}.toggle-comment-btn{color:var(--text-secondary);background:rgba(var(--accent-pink-rgb), .08);border:1px solid rgba(var(--accent-pink-rgb), .15);cursor:pointer;border-radius:12px;padding:.35rem .75rem;font-size:.75rem;font-weight:500;transition:all .2s}.toggle-comment-btn:hover{background:rgba(var(--accent-pink-rgb), .15);color:var(--accent-pink)}.toggle-comment-btn.active{background:var(--accent-pink-light);border-color:rgba(var(--accent-pink-rgb), .3);color:var(--accent-pink)}body.dark-theme .toggle-comment-btn{background:#ffffff08;border:1px solid #ffffff0f}body.dark-theme .toggle-comment-btn:hover{background:rgba(var(--accent-pink-rgb), .2);color:var(--accent-pink)}body.dark-theme .toggle-comment-btn.active{background:rgba(var(--accent-pink-rgb), .15);border-color:rgba(var(--accent-pink-rgb), .3);color:var(--accent-pink)}.comment-textarea{resize:vertical;border:1px solid var(--card-border);width:100%;min-height:55px;max-height:120px;color:var(--text-primary);background:#ffffff73;border-radius:8px;padding:.5rem .75rem;font-size:.85rem;line-height:1.4;transition:border-color .2s,background-color .2s}body.dark-theme .comment-textarea{background:#0003;border:1px solid #ffffff0d}.comment-textarea:focus{border-color:var(--accent-pink);background:#fff9;outline:none}body.dark-theme .comment-textarea:focus{border-color:var(--accent-pink);background:#0000004d}.report-card-comments{margin-top:1.5rem}.detail-category-title{color:var(--text-secondary);border-left:3px solid var(--accent-pink);margin:1.25rem 0 .75rem;padding-left:.5rem;font-size:.95rem;font-weight:600}.comments-detail-list{flex-direction:column;gap:.6rem;display:flex}.detail-item-box{border:1px solid var(--card-border);border-radius:var(--border-radius-md);background:#fff6;transition:all .25s cubic-bezier(.16,1,.3,1);overflow:hidden}body.dark-theme .detail-item-box{background:#ffffff05;border-color:#ffffff0d}.detail-item-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.9rem 1.25rem;display:flex}.detail-item-title-group{align-items:center;gap:.5rem;display:flex}.detail-item-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.comment-indicator-badge{background:rgba(var(--accent-pink-rgb), .1);color:var(--accent-pink);border-radius:8px;padding:.15rem .4rem;font-size:.7rem;font-weight:500}body.dark-theme .comment-indicator-badge{background:rgba(var(--accent-pink-rgb), .15)}.detail-item-scores-summary{align-items:center;gap:1rem;display:flex}.score-summary-span{color:var(--text-secondary);font-size:.8rem}.score-summary-span strong{color:var(--text-primary)}.expand-chevron{color:var(--text-muted);align-items:center;display:flex}.chevron-icon{width:14px;height:14px;transition:transform .25s}.detail-item-box.expanded .chevron-icon{transform:rotate(180deg)}.detail-item-box.expanded{background:#ffffffbf;box-shadow:0 4px 15px #00000005}body.dark-theme .detail-item-box.expanded{background:#ffffff0a}.detail-item-body{border-top:1px solid var(--card-border);background:#fff3;padding:1.25rem}body.dark-theme .detail-item-body{background:#0000001a}.detail-eval-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=768px){.detail-eval-grid{grid-template-columns:1fr;gap:1.25rem}}.eval-col h5{color:var(--text-primary);border-bottom:1px dashed var(--card-border);margin-bottom:.75rem;padding-bottom:.4rem;font-size:.85rem;font-weight:600}.eval-sub-row{justify-content:space-between;margin-bottom:.4rem;font-size:.8rem;display:flex}.sub-row-label{color:var(--text-secondary)}.sub-row-value{color:var(--text-primary);font-weight:600}.eval-comment-bubble{background:var(--bg-primary);border:1px solid var(--card-border);color:var(--text-secondary);word-break:break-all;border-radius:12px;margin-top:.25rem;padding:.6rem .8rem;font-size:.8rem;line-height:1.45;position:relative}.eval-comment-bubble.empty{border:1px dashed var(--card-border);color:var(--text-muted);text-align:center;background:0 0;border-radius:8px;padding:.4rem}.eval-comment-bubble.self-bubble{border-left:3px solid var(--accent-pink)}.eval-comment-bubble.partner-bubble{border-left:3px solid var(--accent-gold)}.eval-comment-bubble.feel-bubble{border-left:3px solid var(--accent-pink)}.mt-3{margin-top:.75rem!important}.mt-4{margin-top:1.25rem!important}
