*{box-sizing:border-box;margin:0;padding:0}:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Dongle,sans-serif;font-weight:400;line-height:1.5}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24'%3E%3Cg transform='rotate(-15 12 12)'%3E%3Cpath d='M12 3.5 Q 15.5 3.5 19.5 19 Q 20.5 20 19.5 19.5 Q 19 19.5 3.5 19.5 Q 2.5 19.5 2.5 19 Q 2.5 18.5 11.5 3.5 Q 12 3 12.5 3.5 Z' fill='%239ca3af' opacity='0.9' stroke='%239ca3af' stroke-width='0.3' stroke-linejoin='round' stroke-linecap='round'/%3E%3Cpath d='M12 7 Q 14.5 7 16.5 17 Q 17 17.5 16.5 17 Q 16 16.5 6.5 17 Q 6 17 5.5 17 Q 5.5 16.5 11.5 7 Q 12 6.5 12.5 7 Z' fill='%23d1d5db' stroke='%23d1d5db' stroke-width='0.3' stroke-linejoin='round' stroke-linecap='round'/%3E%3C/g%3E%3C/svg%3E") 12 12,auto;min-width:320px;min-height:100vh;margin:0;font-family:Dongle,sans-serif}a,button,[role=button],input[type=button],input[type=submit],.cursor-pointer,.village-place-card:not(.village-place-disabled),a:hover,button:hover,[role=button]:hover,input[type=button]:hover,input[type=submit]:hover,.cursor-pointer:hover,.village-place-card:not(.village-place-disabled):hover{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z' fill='%23FFF9C4'/%3E%3Cpath d='M12 4.5l2.32 4.7.1.2.22.03 5.18.76-3.75 3.65-.09.08-.02.12-.88 5.13L12 16.5l-4.68 2.46-.88-5.13-.02-.12-.09-.08-3.75-3.65 5.18-.76.22-.03.1-.2L12 4.5z' fill='%23FFF59D'/%3E%3C/svg%3E") 12 12,pointer}input[type=text],input[type=email],input[type=password],textarea,[contenteditable]{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'%3E%3Cg transform='rotate(-15 12 12)'%3E%3Cpath d='M12 2L20 18H4L12 2z' fill='%23D7B899'/%3E%3Cpath d='M12 5L17 17H7L12 5z' fill='%23C8A882'/%3E%3C/g%3E%3C/svg%3E") 12 12,text}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.home-container{background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.home-content{z-index:1;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem 1rem;position:relative}.home-logout-section{z-index:10;justify-content:flex-end;margin-top:.5rem;margin-bottom:1rem;display:flex;position:relative}.home-logout-button{color:#666;cursor:pointer;background-color:#f5f5f5;border:1px solid #ddd;border-radius:20px;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1rem;transition:all .3s}.home-logout-button:hover{color:#333;background-color:#e8e8e8}.home-sky-clouds{pointer-events:none;z-index:0;position:absolute;inset:-10%;overflow:hidden}.home-cloud{opacity:.98;background:#fff;border-radius:999px;animation:42s ease-in-out infinite home-cloud-float;position:absolute;overflow:visible;box-shadow:0 10px 28px #87ceeb40}.home-cloud:before,.home-cloud:after{content:"";background:#fff;border-radius:999px;position:absolute}.home-cloud:before{width:70%;height:85%;top:-35%;left:-18%}.home-cloud:after{width:80%;height:95%;top:-25%;right:-20%}.home-cloud.cloud-1{width:260px;height:110px;animation-duration:42s;top:14%;left:-25%}.home-cloud.cloud-2{width:320px;height:130px;animation-duration:52s;animation-direction:reverse;top:28%;right:-30%}.home-cloud.cloud-3{width:220px;height:110px;animation-duration:38s;top:45%;left:10%}.home-cloud.cloud-4{opacity:.95;width:200px;height:90px;animation-duration:46s;top:8%;right:18%}@keyframes home-cloud-float{0%{transform:translate(0,0)scale(1)}50%{transform:translate(60px,-6px)scale(1.02)}to{transform:translate(0,0)scale(1)}}.home-village-decoration{pointer-events:none;z-index:1;position:absolute;inset:0;overflow:hidden}.home-house,.home-tree,.home-star{opacity:.75;filter:drop-shadow(0 4px 8px #00000026);font-size:clamp(1.5rem,3vw,2.5rem);animation:6s ease-in-out infinite village-float;position:absolute}.home-house.house-1{font-size:clamp(2rem,4vw,3rem);animation-delay:0s;bottom:15%;left:8%}.home-house.house-2{font-size:clamp(1.8rem,3.8vw,2.8rem);animation-delay:1.5s;bottom:12%;right:12%}.home-house.house-3{font-size:clamp(1.7rem,3.5vw,2.6rem);animation-delay:3s;bottom:18%;left:50%;transform:translate(-50%)}.home-tree.tree-1{font-size:clamp(2.2rem,4.5vw,3.2rem);animation-delay:.5s;bottom:10%;left:20%}.home-tree.tree-2{font-size:clamp(2rem,4.2vw,2.9rem);animation-delay:2s;bottom:8%;right:25%}.home-tree.tree-3{font-size:clamp(2.1rem,4.3vw,3rem);animation-delay:4s;bottom:14%;left:75%}.home-star.star-1{opacity:.6;font-size:clamp(1.2rem,2.5vw,1.8rem);animation:3s ease-in-out infinite star-twinkle;top:20%;left:15%}.home-star.star-2{opacity:.5;font-size:clamp(1rem,2.2vw,1.5rem);animation:4s ease-in-out infinite star-twinkle;top:25%;right:20%}.home-star.star-3{opacity:.55;font-size:clamp(1.1rem,2.3vw,1.6rem);animation:3.5s ease-in-out infinite star-twinkle;top:30%;left:60%}.home-floating-stars{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.home-floating-stars .home-star{opacity:.5;filter:drop-shadow(0 2px 4px #ffd7004d);font-size:clamp(1rem,2vw,1.5rem);animation:15s ease-in-out infinite star-float;position:absolute}.home-floating-stars .home-star.star-1{animation-duration:18s;animation-delay:0s;top:10%;left:5%}.home-floating-stars .home-star.star-2{animation-duration:20s;animation-delay:2s;top:25%;left:80%}.home-floating-stars .home-star.star-3{animation-duration:16s;animation-delay:4s;top:45%;left:15%}.home-floating-stars .home-star.star-4{animation-duration:22s;animation-delay:1s;top:60%;left:70%}.home-floating-stars .home-star.star-5{animation-duration:19s;animation-delay:3s;top:15%;left:50%}.home-floating-stars .home-star.star-6{animation-duration:17s;animation-delay:5s;top:35%;left:30%}.home-floating-stars .home-star.star-7{animation-duration:21s;animation-delay:2.5s;top:55%;left:85%}.home-floating-stars .home-star.star-8{animation-duration:18s;animation-delay:4.5s;top:70%;left:20%}.home-floating-stars .home-star.star-9{animation-duration:19s;animation-delay:1.5s;top:40%;left:65%}.home-floating-stars .home-star.star-10{animation-duration:20s;animation-delay:3.5s;top:75%;left:55%}@keyframes star-float{0%,to{opacity:.4;transform:translate(0)scale(1)rotate(0)}25%{opacity:.6;transform:translate(30px,-20px)scale(1.1)rotate(5deg)}50%{opacity:.5;transform:translate(-20px,15px)scale(.9)rotate(-5deg)}75%{opacity:.55;transform:translate(20px,25px)scale(1.05)rotate(3deg)}}@keyframes village-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.05)}}@keyframes star-twinkle{0%,to{opacity:.4;transform:scale(1)rotate(0)}50%{opacity:.8;transform:scale(1.1)rotate(10deg)}}.home-title-section{text-align:center;z-index:1;margin-top:.5rem;margin-bottom:1rem;position:relative}.home-title-logo{z-index:2;width:clamp(22.5rem,31.5vw,360px);height:auto;margin:0 auto;display:block;position:relative}.home-title{letter-spacing:.06em;text-transform:lowercase;text-align:center;z-index:2;text-shadow:0 2px 4px #00000014,0 1px 2px #0000000d;margin:0;font-family:Dongle,sans-serif;font-size:clamp(5rem,7vw,80px);font-weight:700;line-height:1.2;position:relative}.home-title-mood{color:#f7dc6f;display:inline-block}.home-title-town{color:#d7b899;display:inline-block}.home-subtitle{color:#000;letter-spacing:.02em;-webkit-box-decoration-break:clone;box-decoration-break:clone;background:linear-gradient(#fff9 0%,#ffffffbf 50%,#fff9 100%);border-radius:3px;margin-bottom:2rem;padding:.15rem .3rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;line-height:1.8;display:inline}.home-guide-speech-bubble{z-index:11;text-align:right;position:absolute;top:-1.5rem;right:1.5rem}.home-guide-speech-bubble:after{content:"";filter:drop-shadow(0 2px 4px #0000001a);border-top:10px solid #ffe69e;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.home-guide-button{color:#4a5568;cursor:pointer;z-index:1;background:linear-gradient(135deg,#fff 0%,#ffe69e 100%);border:1px solid #00000014;border-radius:20px;padding:.2rem 1rem;font-family:Dongle,sans-serif;font-size:1.1rem;font-weight:400;transition:all .3s;position:relative;box-shadow:0 2px 8px #0000001a}.home-guide-button:hover{background:linear-gradient(135deg,#fff 0%,#ffe69e 100%);transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.home-guide-button:active{transform:translateY(0)}.home-guide-hint{display:none}.home-action-card{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;border:1px solid #fff9;border-radius:20px;max-width:500px;margin-top:.5rem;margin-left:auto;margin-right:auto;padding:2.5rem 1.5rem 1.5rem;position:relative;box-shadow:0 8px 24px #00000014,0 4px 8px #0000000a}.home-action-intro{border-bottom:1px solid #e5e7eb99;margin-bottom:1rem;padding-bottom:1rem}.home-action-intro-text{color:#4a5568;margin-bottom:.5rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;line-height:1.8}.home-action-intro-hint{color:#6b7280;margin:0;font-family:Dongle,sans-serif;font-size:1.3rem;font-style:italic;font-weight:400;line-height:1.6}.home-date-section{text-align:center;max-width:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background-color:#0000;border:none;border-radius:0;margin:0;padding:0}.home-date-label{color:#4a5568;margin-bottom:1rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;display:block}.home-portal-box{background:linear-gradient(135deg,#e0f6ff66 0%,#ffffff4d 100%);border:none;border-radius:20px;max-width:400px;margin:0 auto;padding:.6rem;animation:3s ease-in-out infinite portal-pulse;position:relative;overflow:hidden}.home-portal-box:before{content:"";z-index:0;opacity:.5;background:linear-gradient(135deg,#e0f6ff80,#f0faff80,#e0f6ff80) 0 0/300% 300%;border-radius:20px;animation:4s linear infinite portal-border;position:absolute;inset:0}.home-portal-glow{pointer-events:none;z-index:0;background:radial-gradient(circle,#e0f6ff40 0%,#0000 70%);animation:3s ease-in-out infinite alternate portal-glow;position:absolute;inset:-50%}.home-portal-content{z-index:1;position:relative}.home-date-input{color:#2d3748;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;background-color:#fffffff2;border:1.5px solid #e0f6ff99;border-radius:12px;width:100%;margin-bottom:.3rem;padding:.3rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;transition:all .3s;box-shadow:0 4px 12px #e0f6ff40}.home-date-input:hover{border-color:#e0f6ffe6;transform:translateY(-2px);box-shadow:0 6px 20px #e0f6ff59}.home-date-input:focus{border-color:#e0f6ff;outline:none;box-shadow:0 0 0 4px #e0f6ff40,0 8px 24px #e0f6ff73}.home-date-display{color:#6b7280;text-shadow:0 2px 4px #ffffffe6;margin-top:.75rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;line-height:1.6}@keyframes portal-pulse{0%,to{box-shadow:0 0 20px #e0f6ff4d,0 0 40px #e0f6ff33}50%{box-shadow:0 0 30px #e0f6ff73,0 0 60px #e0f6ff4d}}@keyframes portal-border{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes portal-border-rotate{0%{filter:hue-rotate()}to{filter:hue-rotate(360deg)}}@keyframes portal-glow{0%{opacity:.5;transform:scale(1)}to{opacity:.8;transform:scale(1.1)}}.home-date-hint{border-top:1px solid #e5e7ebcc;margin-top:.75rem;padding-top:.75rem}.home-date-toggle{color:#4a5568;cursor:pointer;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:.4rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;transition:all .2s;display:flex}.home-date-toggle:hover{background-color:#f3f4f6;border-color:#d1d5db}.home-date-toggle-icon{font-size:.75rem;transition:transform .3s;display:inline-block}.home-date-toggle-icon.open{transform:rotate(180deg)}.home-date-list{flex-wrap:wrap;justify-content:center;gap:.35rem;margin-top:.75rem;padding-top:.75rem;animation:.3s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.home-date-quick-select{cursor:pointer;color:#4a5568;background-color:#fff;border:1.5px solid #e5e7eb;border-radius:8px;padding:.3rem .6rem;font-family:Dongle,sans-serif;font-size:1rem;font-weight:400;transition:all .2s;box-shadow:0 2px 4px #0000000a}.home-date-quick-select:hover{background-color:#f9fafb;border-color:#d1d5db;transform:translateY(-2px);box-shadow:0 4px 8px #0000000f}.home-date-quick-select.active{color:#fff;background-color:#6bbfed;border-color:#6bbfed;box-shadow:0 4px 12px #6bbfed4d}.home-enter-section{text-align:center;border-top:1px solid #e5e7ebcc;margin-top:1rem;padding:1rem 0 0}.enter-village-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,tan 0%,#c8a882 100%);border:none;border-radius:30px;padding:.5rem 1.8rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #d2b48c4d}.enter-village-button:hover{background:linear-gradient(135deg,#deb887 0%,tan 100%);transform:translateY(-2px);box-shadow:0 6px 16px #d2b48c66}.enter-village-button:active{transform:translateY(-1px)}.enter-village-hint{color:#4a5568;margin-top:1rem;font-size:1rem;font-style:italic}@media (max-width:768px){.home-title-section{margin-bottom:2rem}.home-title-logo{width:clamp(18rem,72vw,31.5rem)}.home-title{letter-spacing:.03em;font-size:clamp(4rem,16vw,7rem)}.home-subtitle{padding:0 1rem;font-size:1rem;line-height:1.6}.home-content{padding:1rem}.home-guide-speech-bubble{top:-3rem;right:1rem}.home-action-card{margin-top:1.5rem;padding:3.5rem 1.5rem 1.5rem}.home-action-intro{margin-bottom:1.25rem;padding-bottom:1.25rem}.home-action-intro-text{font-size:1.15rem}.home-action-intro-hint{font-size:1rem}.home-portal-box{max-width:100%;padding:1.25rem}.home-date-input{padding:.65rem .9rem;font-size:1.05rem}.home-guide-button{padding:.3rem .9rem;font-size:.95rem}.enter-village-button{padding:.65rem 1.5rem;font-size:1.05rem}.home-house,.home-tree{opacity:.6;font-size:clamp(1.2rem,3vw,2rem)}.home-star{opacity:.4;font-size:clamp(.8rem,2vw,1.2rem)}}@media (min-width:769px) and (max-width:1024px){.home-title-logo{width:clamp(24.75rem,45vw,36rem)}.home-title{font-size:clamp(5.5rem,10vw,8rem)}}.emotion-sky{z-index:0;contain:layout style paint;isolation:isolate;width:100%;height:16rem;margin-bottom:-2rem;transition:background 1s ease-in-out;position:relative;overflow:visible;transform:translateZ(0)}.emotion-sky-clouds{contain:layout style paint;position:absolute;inset:0;overflow:visible}.emotion-sky-cloud{filter:blur(40px);will-change:transform;background:#ffffff4d;border-radius:50%;position:absolute}.cloud-1{width:8rem;height:4rem;top:2.5rem;left:5rem}.cloud-2{background:#fff3;width:10rem;height:5rem;top:5rem;right:8rem}.cloud-3{background:#ffffff40;width:7rem;height:3.5rem;top:4rem;left:50%;transform:translate(-50%)}.cloud-piece{filter:blur(50px);will-change:transform;backface-visibility:hidden;contain:layout style paint;background:#fffffff2;border-radius:50%;animation:30s ease-in-out infinite cloudFloat;transform:translateZ(0)}.cloud-piece-1{width:10rem;height:10rem;animation-delay:0s;top:1rem;left:5%}.cloud-piece-2{width:8rem;height:8rem;animation-delay:2s;top:.5rem;left:15%}.cloud-piece-3{width:12rem;height:12rem;animation-delay:4s;top:2rem;left:30%}.cloud-piece-4{width:9rem;height:9rem;animation-delay:1s;top:0;left:50%}.emotion-sky-cloudy .cloud-piece-1{height:12rem;top:.5rem}.emotion-sky-cloudy .cloud-piece-2{height:10rem;top:0}.emotion-sky-cloudy .cloud-piece-3{height:14rem;top:1rem}.emotion-sky-cloudy .cloud-piece-4{height:11rem;top:-.5rem}@keyframes cloudFloat{0%,to{transform:translate(0,0)}50%{transform:translate(5px,-3px)}}.emotion-sky-label{text-align:center;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.emotion-sky-label p{color:#ffffffe6;text-shadow:0 2px 4px #0000004d;justify-content:center;align-items:center;gap:.5rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:500;display:flex;position:relative}.emotion-sky-text{text-align:center}.emotion-sky-info-icon{color:#2d3748cc;cursor:help;width:1.5rem;height:1.5rem;text-shadow:none;background-color:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:600;transition:all .3s;display:inline-flex;position:absolute;left:calc(50% + 4rem);transform:translate(0);box-shadow:0 2px 4px #0003}.emotion-sky-info-icon:hover{background-color:#fff;transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.emotion-sky-tooltip{color:#fff;opacity:0;pointer-events:none;z-index:30;white-space:normal;text-align:center;background-color:#2d3748f2;border-radius:8px;min-width:250px;max-width:300px;padding:.75rem 1rem;font-family:Dongle,sans-serif;font-size:1rem;line-height:1.5;transition:opacity .3s,transform .3s;position:absolute;bottom:calc(100% + .75rem);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000004d}.emotion-sky-tooltip:after{content:"";border-top:6px solid #2d3748f2;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.emotion-sky-info-icon:hover .emotion-sky-tooltip{opacity:1;transform:translate(-50%)translateY(-4px)}.village-container{contain:layout style;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;flex-direction:column;min-height:100vh;font-family:Dongle,sans-serif;display:flex;position:relative;overflow:hidden;transform:translateZ(0)}.village-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:.5rem 2rem 2rem}.village-header{justify-content:space-between;align-items:center;gap:1rem;margin-top:.5rem;margin-bottom:1.5rem;display:flex;position:relative}.village-user-info{z-index:1;align-items:center;gap:.75rem;margin-left:auto;display:flex;position:relative}.village-user-name{color:#4a5568;font-size:1.5rem;font-weight:500}.village-logout-button{color:#666;cursor:pointer;background-color:#f5f5f5;border:1px solid #ddd;border-radius:20px;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1rem;transition:all .3s}.village-logout-button:hover{color:#333;background-color:#e8e8e8}.village-back-button{color:#fff;cursor:pointer;z-index:1;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.3rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s;position:relative}.village-back-button:hover{color:#fff;background-color:#c8a882;transform:translate(-2px)}.village-title{color:#2d3748;margin:0;font-size:3rem;font-weight:700}.village-date-display{text-align:center;pointer-events:none;z-index:0;width:100%;margin:0;position:absolute;left:50%;transform:translate(-50%)}.village-date-title{color:#2d3748;margin:0 0 .5rem;font-size:1.8rem;font-weight:700}.village-diary-status{background-color:#ffe69ee6;border-radius:30px;margin-bottom:1.5rem;padding:.3rem;box-shadow:0 2px 8px #0000001a}.diary-status-has,.diary-status-none{align-items:center;gap:.5rem;display:flex}.diary-status-icon{vertical-align:middle;justify-content:center;align-items:center;margin-left:.7rem;font-size:1.2rem;line-height:1;display:inline-flex}.diary-status-text{color:#2d3748;vertical-align:middle;font-size:1.3rem}.diary-status-has{color:#22c55e}.diary-status-none{color:#f59e0b;padding-left:.7rem}.village-places-section{margin-top:1rem}.village-places-title{color:#2d3748;margin-bottom:1.5rem;font-size:2.5rem;font-weight:700}.village-places-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.village-place-card{cursor:pointer;will-change:transform;background-color:#fffffff2;border:2px solid #0000;border-radius:30px;padding:1rem;transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;transform:translateZ(0);box-shadow:0 4px 12px #0000001a}.village-place-card:hover:not(.village-place-disabled){border-color:#4a5568;transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.village-place-disabled{opacity:.4;cursor:not-allowed;background-color:#f0f4f8;border:2px solid #c8c8c84d}.village-place-lock-badge{color:#fff;z-index:10;background-color:#64748bcc;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1rem;display:flex;position:absolute;top:.75rem;left:.75rem;box-shadow:0 2px 6px #00000026}.village-place-locked-message{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:100;background-color:#2d3748f2;border-radius:8px;padding:.5rem 1rem;font-size:1rem;transition:opacity .3s,transform .3s;position:absolute;top:-3.5rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.village-place-locked-message:after{content:"";border-top:6px solid #2d3748f2;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.village-place-disabled:hover .village-place-locked-message{opacity:1;transform:translate(-50%)translateY(-4px)}.village-place-icon{text-align:center;margin-top:1rem;margin-bottom:1rem;font-size:3rem}.village-place-name{color:#2d3748;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.8rem;font-weight:700;display:flex}.village-place-badge{color:#fff;text-align:center;background-color:#ef4444;border-radius:12px;min-width:20px;padding:.25rem .5rem;font-size:.9rem;font-weight:700;animation:1s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.village-place-description{color:#4a5568;margin-bottom:1rem;font-size:1.2rem;line-height:1.5}.village-place-hint{color:#9ca3af;text-align:right;font-size:1.1rem;font-weight:500}.village-place-disabled-hint{color:#ef4444;text-align:right;font-size:1.1rem;font-weight:500}@media (max-width:768px){.village-content{padding:1rem}.village-title{font-size:2.5rem}.village-date-title{font-size:1.5rem}.diary-status-text{font-size:1.15rem}.village-places-title{font-size:2rem}.village-place-name{font-size:1.5rem}.village-place-description{font-size:1.1rem}.village-back-button{font-size:1.15rem}.village-places-grid{grid-template-columns:1fr}.village-header{flex-direction:column;align-items:flex-start}}.floating-residents-container{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.floating-resident{opacity:.75;object-fit:cover;pointer-events:none;border-radius:50%;animation:ease-in-out infinite float-around;position:absolute}@keyframes float-around{0%{transform:translate(0)rotate(0)}33%{transform:translate(3px,-5px)rotate(1deg)}66%{transform:translate(-3px,-8px)rotate(-1deg)}to{transform:translate(0)rotate(0)}}.plaza-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.plaza-header{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:flex;position:relative}.plaza-header-content{background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.plaza-back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.plaza-back-button:hover{background-color:#c8a882;transform:translate(-2px)}.plaza-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.plaza-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.plaza-info-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:16px;width:100%;max-width:1200px;margin:1rem auto 2rem;padding:1.5rem;animation:.3s slideDown;box-shadow:0 4px 12px #e0f6ff33}.plaza-info-toggle{cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#dbeafe99 0%,#bfdbfe66 100%);border:1.5px solid #bfdbfe80;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;transition:all .3s;display:inline-flex}.plaza-info-toggle:hover{background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);transform:translateY(-1px);box-shadow:0 2px 6px #bfdbfe4d}.plaza-info-toggle-icon{font-size:1.1rem}.plaza-info-toggle-text{color:#2d3748;font-size:1.1rem;font-weight:600}.plaza-info-content-wrapper{padding:0}.plaza-info-title{color:#2d3748;margin-bottom:.75rem;font-size:1.6rem;font-weight:700}.plaza-info-cards{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.plaza-info-card{background:linear-gradient(135deg,#ffffffe6 0%,#f8fafce6 100%);border:1.5px solid #e0f6ff80;border-radius:12px;align-items:center;gap:.8rem;padding:1rem 1.2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #e0f6ff40}.plaza-info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff59}.plaza-info-icon{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-top:.15rem;font-size:2rem;line-height:1;display:inline-flex;transform:translateY(.1rem)}.plaza-info-content{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;display:flex}.plaza-info-text,.plaza-info-arrow,.plaza-info-result{vertical-align:middle;line-height:1.6;display:inline-block}.plaza-info-text{color:#4a5568;font-size:1.2rem;font-weight:500}.plaza-info-arrow{color:#9ca3af;font-size:1.3rem;font-weight:700}.plaza-info-result{color:#2d3748;font-size:1.2rem;font-weight:600}.plaza-content{flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto;display:flex}.plaza-section-title{color:#1f2937;margin-bottom:1rem;font-size:1.8rem;font-weight:700}.plaza-diaries-section{background:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;max-height:80vh;padding:1.5rem;overflow-y:auto;box-shadow:0 4px 12px #e0f6ff33}.plaza-empty{text-align:center;color:#6b7280;padding:3rem 1rem;font-size:1.4rem}.plaza-write-button{color:#5d4037;cursor:pointer;background:linear-gradient(135deg,#fff9c4 0%,#fff59d 100%);border:none;border-radius:30px;margin-top:1rem;padding:.75rem 1.5rem;font-size:1.1rem;font-weight:600;transition:all .3s}.plaza-write-button:hover{background:linear-gradient(135deg,#fff59d 0%,#fff176 100%);transform:translateY(-2px);box-shadow:0 4px 12px #fff59d66}.plaza-diaries-list{flex-direction:column;gap:.75rem;display:flex}.plaza-diary-card{cursor:pointer;background:#ffffffe6;border:2px solid #e5e7eb99;border-radius:16px;padding:1rem;transition:all .3s}.plaza-diary-card:hover{background:#e0f6ff33;border-color:#e0f6ffcc;transform:translate(4px);box-shadow:0 4px 12px #e0f6ff4d}.plaza-diary-card-selected{background:#e0f6ff4d;border-color:#e0f6ffe6;box-shadow:0 4px 12px #e0f6ff66}.plaza-diary-date{color:#6b7280;margin-bottom:.25rem;font-size:1.1rem}.plaza-diary-title{color:#1f2937;margin-bottom:.5rem;font-weight:600}.plaza-diary-preview{color:#4b5563;font-size:1.1rem;line-height:1.5}.plaza-conversation-section{background:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;max-height:80vh;padding:1.5rem;overflow-y:auto;box-shadow:0 4px 12px #e0f6ff33}.plaza-loading{text-align:center;color:#6b7280;padding:3rem 1rem}.plaza-loading p{color:#4b5563;margin-top:1rem;font-size:1.6rem;font-weight:500}.plaza-loading-spinner{border:4px solid #fbbf24;border-color:#fbbf24 #f97316 #ef4444 #8b5cf6;border-radius:50%;width:48px;height:48px;margin:0 auto 1rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.plaza-error{color:#991b1b;text-align:center;background:#fee2e2;border-radius:.5rem;padding:1rem}.plaza-emotions{background:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;margin-bottom:0;padding:1.5rem;box-shadow:0 4px 12px #e0f6ff33}.plaza-emotions h3{color:#1f2937;margin-bottom:1rem;font-size:1.8rem;font-weight:600}.plaza-emotion-scores{flex-direction:column;gap:.75rem;display:flex}.plaza-emotion-item{align-items:center;gap:.75rem;display:flex}.plaza-emotion-emoji{text-align:center;flex-shrink:0;width:3rem;font-size:1.8rem}.plaza-emotion-image{object-fit:contain;flex-shrink:0;width:3rem;height:3rem}.plaza-emotion-name{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:140px;font-size:1.4rem;font-weight:600;overflow:hidden}.plaza-emotion-bar{background:#f3f4f6;border-radius:4px;flex:1;height:8px;overflow:hidden}.plaza-emotion-bar-fill{height:100%;transition:width .3s}.plaza-emotion-score{text-align:right;color:#6b7280;min-width:40px;font-size:1.4rem;font-weight:600}.plaza-conversation-chat-wrapper{align-items:flex-start;gap:2rem;display:flex}.plaza-conversation{background:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;flex-direction:column;flex:1;min-height:500px;padding:1.5rem;display:flex;box-shadow:0 4px 12px #e0f6ff33}.plaza-conversation-title{color:#1f2937;margin-top:0;margin-bottom:1rem;font-size:1.8rem;font-weight:600}.plaza-conversation-messages{flex-direction:column;flex:1;gap:1rem;max-height:60vh;display:flex;overflow-y:auto}.plaza-message{gap:1rem;animation:.3s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.plaza-message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.8rem;display:flex;overflow:hidden;box-shadow:0 2px 4px #0000001a}.plaza-character-image{object-fit:cover;width:100%;height:100%}.plaza-message-content{background:#ffffffe6;border:1px solid #e0f6ff80;border-radius:16px;flex:1;padding:.75rem 1rem;box-shadow:0 2px 8px #e0f6ff33}.plaza-message-name{color:#374151;margin-bottom:.25rem;font-size:1.4rem;font-weight:600}.plaza-message-text{color:#1f2937;font-size:1.3rem;line-height:1.6}.plaza-empty-conversation{text-align:center;color:#6b7280;padding:3rem 1rem}.plaza-chat-section{background:#fffffff2;border:1px solid #e0f6ff4d;border-top:3px solid #e0f6ff99;border-radius:20px;flex-direction:column;flex:1;min-height:500px;padding:1.5rem;display:flex;box-shadow:0 4px 12px #e0f6ff33}.plaza-chat-header{border-bottom:2px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.plaza-chat-header h3{color:#1f2937;margin:0;font-size:1.8rem;font-weight:600}.plaza-chat-toggle{cursor:pointer;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.1rem;transition:all .2s}.plaza-chat-toggle:hover{background:#e5e7eb}.plaza-chat-messages{flex-direction:column;gap:1rem;max-height:400px;margin-bottom:1rem;padding:1rem 0;display:flex;overflow-y:auto}.plaza-chat-empty{text-align:center;color:#9ca3af;padding:2rem}.plaza-chat-message{gap:.75rem;animation:.3s fadeIn;display:flex}.plaza-chat-message-user{justify-content:flex-end}.plaza-chat-message-user .plaza-chat-message-text{color:#1f2937;background:linear-gradient(135deg,#e0f6ffe6 0%,#fffc 100%);border:1px solid #e0f6ff80;border-radius:1rem 1rem .25rem;max-width:70%;padding:.75rem 1rem;box-shadow:0 2px 4px #e0f6ff4d}.plaza-chat-message-character{justify-content:flex-start}.plaza-chat-message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.5rem;display:flex;overflow:hidden;box-shadow:0 2px 4px #0000001a}.plaza-chat-message-content{background:#ffffffe6;border:1px solid #e0f6ff80;border-radius:16px 16px 16px 4px;max-width:70%;padding:.75rem 1rem;box-shadow:0 2px 8px #e0f6ff33}.plaza-chat-message-name{color:#6b7280;margin-bottom:.25rem;font-size:1.2rem;font-weight:600}.plaza-chat-message-text{color:#1f2937;word-wrap:break-word;font-size:1.3rem;line-height:1.6}.plaza-chat-message-system{justify-content:center}.plaza-chat-message-system .plaza-chat-message-text{color:#6b7280;background:#f3f4f6;border-radius:1rem;padding:.5rem 1rem;font-size:1.1rem;font-style:italic}.plaza-chat-input-container{border-top:1px solid #e5e7eb;gap:.75rem;padding-top:1rem;display:flex}.plaza-chat-input{border:2px solid #e5e7eb;border-radius:.75rem;flex:1;padding:.75rem 1rem;font-family:Dongle,sans-serif;font-size:1.1rem;transition:all .2s}.plaza-chat-input::placeholder{color:#9ca3af;font-family:Dongle,sans-serif}.plaza-chat-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.plaza-chat-input:disabled{cursor:not-allowed;background:#f3f4f6}.plaza-chat-send-button{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#d7b899 0%,#c8a882 100%);border:none;border-radius:30px;padding:.75rem 1.5rem;font-family:Dongle,sans-serif;font-size:1.1rem;font-weight:600;transition:all .3s}.plaza-chat-send-button:hover:not(:disabled){background:linear-gradient(135deg,#c8a882 0%,#b89a7a 100%);transform:translateY(-2px);box-shadow:0 4px 12px #d7b89966}.plaza-chat-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width:968px){.plaza-back-button{margin-bottom:1rem;position:static;transform:none}.plaza-header{flex-direction:column;align-items:flex-start}.plaza-header-content{width:100%}.plaza-title,.plaza-subtitle{transform:none}.plaza-chat-messages{max-height:300px}.plaza-chat-message-user .plaza-chat-message-text,.plaza-chat-message-content{max-width:85%}.plaza-conversation-chat-wrapper{flex-direction:column}.plaza-conversation{min-height:auto;max-height:50vh}.plaza-chat-section{min-height:auto}.plaza-info-content{flex-direction:column;align-items:flex-start;gap:.3rem}.plaza-info-arrow{transform:rotate(90deg)}}.write-diary-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem 1rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.write-diary-header{grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:grid;position:relative}.write-diary-header-content{background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;justify-self:start;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.back-button:hover{background-color:#c8a882;transform:translate(-2px)}.write-diary-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.write-diary-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.write-diary-form{background:#fff;border-radius:1rem;max-width:800px;margin:0 auto;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.form-group{margin-bottom:1.5rem}.form-label{color:#374151;margin-bottom:.5rem;font-size:1.1rem;font-weight:600;display:block}.date-display{color:#374151;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:1.3rem}.form-input{border:2px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem;font-family:inherit;font-size:1.3rem;transition:border-color .2s}.form-input:focus{border-color:#d7b899;outline:none}.form-textarea{resize:vertical;border:2px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem;font-family:inherit;font-size:1.3rem;line-height:1.6;transition:border-color .2s}.form-textarea:focus{border-color:#d7b899;outline:none}.character-count{text-align:right;color:#9ca3af;margin-top:.25rem;font-size:.9rem}.emotions-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;display:grid}.emotion-button{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;font-family:inherit;transition:all .2s;display:flex}.emotion-button:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.emotion-button-selected{font-weight:600;box-shadow:0 2px 4px #0000001a}.emotion-emoji{font-size:3rem}.emotion-name{font-size:1.1rem}.submit-button{color:#2d3748;cursor:pointer;background:linear-gradient(135deg,#e0f6ff66 0%,#ffffff4d 100%);border:none;border-radius:.75rem;width:100%;margin-top:1rem;padding:1rem;font-family:inherit;font-size:1.4rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #e0f6ff4d}.analyze-buttons-container{justify-content:center;align-items:flex-start;gap:.5rem;width:100%;display:flex}.analyze-buttons-container .submit-button{flex:1;min-width:0;margin-top:0;padding:.5rem .75rem;font-size:1.1rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e0f6ff73}.submit-button:disabled{opacity:.6;cursor:not-allowed}.analyze-button-ml{color:#5d4037!important;background:linear-gradient(90deg,#fff9c4,#ffe989)!important}.analyze-button-ml:hover:not(:disabled){background:linear-gradient(90deg,#fff59d,#fff176)!important;box-shadow:0 4px 12px #fff59d66!important}.analyze-button-gpt{color:#3e2723!important;background:linear-gradient(90deg,#d7ccc8,#bcaaa4)!important}.analyze-button-gpt:hover:not(:disabled){background:linear-gradient(90deg,#bcaaa4,#a1887f)!important;box-shadow:0 4px 12px #bcaaa466!important}.analyze-button-wrapper{flex-direction:column;flex:1;align-items:center;gap:6px;min-width:0;display:flex;position:relative}.analyze-tooltip-container{margin-top:.25rem;display:inline-block;position:relative}.analyze-tooltip-icon{color:#fff;cursor:help;background-color:#9ca3af;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;transition:all .2s;display:inline-flex}.analyze-tooltip-icon:hover{background-color:#6b7280;transform:scale(1.1)}.analyze-tooltip{opacity:0;visibility:hidden;z-index:1000;color:#374151;pointer-events:none;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:280px;padding:12px;font-size:.95rem;line-height:1.5;transition:opacity .2s,visibility .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.analyze-tooltip:after{content:"";border:8px solid #0000;border-top-color:#fff;position:absolute;top:100%;left:50%;transform:translate(-50%)}.analyze-tooltip:before{content:"";z-index:-1;border:10px solid #0000;border-top-color:#e5e7eb;margin-top:-2px;position:absolute;top:100%;left:50%;transform:translate(-50%)}.analyze-tooltip-container:hover .analyze-tooltip{opacity:1;visibility:visible}.analyze-tooltip strong{color:#1f2937;margin-bottom:8px;font-size:1rem;font-weight:600;display:block}.analyze-tooltip p{margin:4px 0;font-size:.9rem;line-height:1.5}.save-message{text-align:center;white-space:pre-line;border-radius:.5rem;margin-bottom:1rem;padding:1rem;font-weight:500;line-height:1.6;animation:.3s slideIn}.save-message-success{color:#065f46;background:#d1fae5;border:1px solid #10b981}.save-message-error{color:#991b1b;background:#fee2e2;border:1px solid #ef4444}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.existing-diary-warning{color:#92400e;background:#fef3c7;border:2px solid #fbbf24;border-radius:.5rem;margin-bottom:1rem;padding:.8rem}.existing-diary-warning p{margin:.5rem 0;font-size:1.1rem}.existing-diary-warning-detail{color:#78350f;margin-top:.5rem;font-size:.85rem!important}.replace-confirm-dialog{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.replace-confirm-content{background:#fff;border-radius:1rem;width:90%;max-width:500px;max-height:90vh;padding:2rem;animation:.3s slideUp;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.replace-confirm-content h3{color:#1f2937;margin:0 0 1rem;font-size:1.8rem}.replace-confirm-content p{color:#374151;margin:.5rem 0;line-height:1.6}.replace-confirm-content ul{color:#4b5563;margin:1rem 0;padding-left:1.5rem}.replace-confirm-content li{margin:.5rem 0;line-height:1.6}.replace-confirm-question{color:#1f2937;font-weight:600;margin-top:1.5rem!important}.replace-confirm-buttons{gap:1rem;margin-top:1.5rem;display:flex}.replace-confirm-button{cursor:pointer;border:none;border-radius:.5rem;flex:1;padding:.75rem 1.5rem;font-family:inherit;font-size:1.3rem;font-weight:600;transition:all .2s}.replace-confirm-button-cancel{color:#374151;background:#f3f4f6}.replace-confirm-button-cancel:hover:not(:disabled){background:#e5e7eb}.replace-confirm-button-confirm{color:#fff;background:linear-gradient(90deg,#ef4444,#dc2626)}.replace-confirm-button-confirm:hover:not(:disabled){background:linear-gradient(90deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.replace-confirm-button:disabled{opacity:.6;cursor:not-allowed}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.save-success-popup{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.save-success-popup-content{text-align:center;background:#fff;border-radius:1.5rem;width:90%;max-width:500px;padding:2.5rem;animation:.3s slideUp;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.save-success-icon{margin-bottom:1rem;font-size:4rem;animation:.6s bounce}.save-success-title{color:#1f2937;margin:0 0 1rem;font-size:2rem;font-weight:700}.save-success-message{color:#374151;margin:1.5rem 0;font-size:1.2rem;line-height:1.8}.save-success-message p{margin:.5rem 0}.save-success-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#d7b899 0%,#c8a882 100%);border:none;border-radius:.75rem;width:100%;margin-top:1rem;padding:1rem 2rem;font-family:inherit;font-size:1.4rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #d7b8994d}.save-success-button:hover{background:linear-gradient(135deg,#c8a882 0%,#b89a7a 100%);transform:translateY(-2px);box-shadow:0 6px 20px #d7b89973}@media (max-width:768px){.write-diary-title{font-size:3rem}.write-diary-form{padding:1.5rem}.emotions-grid{grid-template-columns:repeat(3,1fr)}.back-button{margin-bottom:1rem;position:static;transform:none}.write-diary-header{text-align:left}.replace-confirm-content{padding:1.5rem}.replace-confirm-buttons{flex-direction:column}.save-success-popup-content{padding:2rem 1.5rem}.save-success-title{font-size:1.6rem}.save-success-message{font-size:1.1rem}.save-success-button{padding:.9rem 1.5rem;font-size:1.2rem}.analyze-buttons-container{flex-direction:column}.analyze-button-wrapper{width:100%}.analyze-tooltip{width:calc(100vw - 4rem);max-width:300px;left:0;transform:translate(0)}.analyze-tooltip:after,.analyze-tooltip:before{left:20px;transform:translate(0)}}.tree-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.tree-header{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:flex;position:relative}.tree-header-content{background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.tree-back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.tree-back-button:hover{background-color:#c8a882;transform:translate(-2px)}.tree-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.tree-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.tree-alerts{z-index:100;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:fixed;top:180px;right:2rem}.tree-date-notice{background:linear-gradient(135deg,#fff9c4fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;min-height:2.8rem;padding:.6rem 2rem .6rem .85rem;display:inline-flex;position:relative;box-shadow:0 2px 8px #f59e0b4d}.tree-date-notice-text{color:#78350f;font-size:1.1rem;font-weight:500;line-height:1.4}.tree-date-impact{background:linear-gradient(135deg,#fef3c7fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;min-height:2.8rem;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;position:relative;box-shadow:0 2px 8px #f59e0b4d}.tree-date-impact-icon{flex-shrink:0;font-size:1.2rem}.tree-date-impact-text{color:#78350f;font-size:1.1rem;font-weight:500;display:inline}.tree-date-impact-text strong{color:#92400e;font-size:1.15rem;font-weight:600}.tree-bonus-message{background:linear-gradient(135deg,#dcfce7fa 0%,#bbf7d0f2 100%);border:1.5px solid #22c55e80;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;display:inline-flex;position:relative;box-shadow:0 2px 8px #22c55e4d}.tree-bonus-icon{flex-shrink:0;font-size:1.2rem}.tree-bonus-text{color:#166534;font-size:1.1rem;font-weight:500;display:inline}.tree-bonus-text strong{color:#14532d;font-size:1.15rem;font-weight:600}.tree-alert-close{color:#78350f;cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;width:1.2rem;height:1.2rem;padding:.2rem .3rem;font-size:.7rem;line-height:1;transition:opacity .2s;display:flex;position:absolute;top:.3rem;right:.3rem}.tree-alert-close:hover{opacity:1}.tree-bonus-message .tree-alert-close{color:#166534}.tree-content{grid-template-columns:1fr 1fr;align-items:stretch;gap:2rem;max-width:1200px;margin:0 auto;display:grid}.tree-display-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.tree-visual{text-align:center;margin-bottom:2rem}.tree-emoji{margin-bottom:1rem;font-size:9rem;animation:2s ease-in-out infinite gentle-bounce}@keyframes gentle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.tree-progress-section{margin-bottom:2rem}.tree-progress-bar-container{background-color:#e5e7eb;border-radius:12px;width:100%;height:24px;margin-bottom:.5rem;overflow:hidden}.tree-progress-bar{background:linear-gradient(90deg,#22c55e 0%,#16a34a 100%);border-radius:12px;height:100%;transition:width .5s;animation:2s ease-in-out infinite progress-pulse}@keyframes progress-pulse{0%,to{opacity:1}50%{opacity:.8}}.tree-progress-info{justify-content:space-between;align-items:center;display:flex}.tree-progress-text{color:#4a5568;font-size:1.1rem}.tree-progress-percent{color:#22c55e;font-size:1.3rem;font-weight:700}.tree-fruit-message{text-align:center;background:linear-gradient(135deg,#fff9c4cc 0%,#fff59d99 100%);border:2px solid #fff59de6;border-radius:20px;margin-bottom:2rem;padding:2rem;animation:1s ease-in-out infinite celebrate;box-shadow:0 4px 12px #fff59d4d}@keyframes celebrate{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.tree-fruit-icon{margin-bottom:.5rem;font-size:3.5rem}.tree-fruit-text{color:#92400e;font-size:1.8rem;font-weight:700}.tree-stats{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.tree-stat-item{text-align:center;background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:16px;padding:1rem;box-shadow:0 2px 8px #e0f6ff33}.tree-stat-label{color:#6b7280;margin-bottom:.5rem;font-size:1.1rem;display:block}.tree-stat-value{color:#2d3748;font-size:1.8rem;font-weight:700;display:block}.tree-fruit-under{justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.tree-fruit-emoji-small{font-size:1.5rem}.tree-fruit-count-small{color:#92400e;font-size:1.2rem;font-weight:500}.tree-contribution-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.tree-contribution-title{color:#2d3748;margin-bottom:.5rem;font-size:1.8rem;font-weight:700}.tree-contribution-description{color:#6b7280;margin-bottom:1.5rem;font-size:1rem;line-height:1.5}.tree-contribution-list{flex-direction:column;gap:1rem;display:flex}.tree-contribution-item{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:12px;padding:1rem;box-shadow:0 2px 4px #0000000d}.tree-contribution-label{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.tree-contribution-emotion-wrapper{align-items:center;gap:.5rem;display:flex}.tree-contribution-emotion{color:#000;font-size:1.2rem;font-weight:600}.tree-contribution-info-tooltip-container{align-items:center;display:inline-flex;position:relative}.tree-contribution-info-icon{color:#fff;cursor:help;background-color:#9ca3af;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-style:normal;font-weight:700;transition:all .2s;display:inline-flex}.tree-contribution-info-icon:hover{background-color:#6b7280;transform:scale(1.1)}.tree-contribution-info-tooltip{opacity:0;visibility:hidden;z-index:1000;color:#374151;pointer-events:none;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:280px;padding:10px;font-size:.9rem;line-height:1.5;transition:opacity .2s,visibility .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.tree-contribution-info-tooltip:after{content:"";border:8px solid #0000;border-top-color:#fff;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tree-contribution-info-tooltip:before{content:"";z-index:-1;border:10px solid #0000;border-top-color:#e5e7eb;margin-top:-2px;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tree-contribution-info-tooltip-container:hover .tree-contribution-info-tooltip{opacity:1;visibility:visible}.tree-contribution-percent{color:#2d3748;font-size:1.3rem;font-weight:700}.tree-contribution-bar-container{background-color:#e5e7eb;border-radius:10px;width:100%;height:20px;margin-bottom:.5rem;overflow:hidden}.tree-contribution-bar{border-radius:10px;height:100%;transition:width .5s}.tree-contribution-score{color:#6b7280;text-align:right;font-size:.9rem}.tree-contribution-empty{color:#9ca3af;text-align:center;padding:2rem;font-size:1rem}.tree-info-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:16px;width:100%;max-width:900px;margin:1rem auto 2rem;padding:1.5rem;animation:.3s slideDown;box-shadow:0 4px 12px #e0f6ff33}.tree-info-toggle{cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#dbeafe99 0%,#bfdbfe66 100%);border:1.5px solid #bfdbfe80;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;transition:all .3s;display:inline-flex}.tree-info-toggle:hover{background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);transform:translateY(-1px);box-shadow:0 2px 6px #bfdbfe4d}.tree-info-toggle-icon{font-size:1.1rem}.tree-info-toggle-text{color:#2d3748;font-size:1.1rem;font-weight:600}.tree-info-content-wrapper{padding:0}.tree-info-title{color:#2d3748;margin-bottom:.75rem;font-size:1.6rem;font-weight:700}.tree-info-cards{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.tree-info-card{background:linear-gradient(135deg,#ffffffe6 0%,#f8fafce6 100%);border:1.5px solid #e0f6ff80;border-radius:12px;align-items:center;gap:.8rem;padding:1rem 1.2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #e0f6ff40}.tree-info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff59}.tree-info-icon{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-top:.15rem;font-size:2rem;line-height:1;display:inline-flex;transform:translateY(.1rem)}.tree-info-content{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;display:flex}.tree-info-text,.tree-info-arrow,.tree-info-result{vertical-align:middle;line-height:1.6;display:inline-block}.tree-info-text{color:#4a5568;font-size:1.2rem;font-weight:500}.tree-info-arrow{color:#9ca3af;font-size:1.3rem;font-weight:700}.tree-info-result{color:#2d3748;font-size:1.2rem;font-weight:600}.tree-stages-info{border-top:2px solid #e0f6ff80;margin-top:2rem;padding-top:2rem}.tree-stages-title{color:#2d3748;margin-bottom:1rem;font-size:1.4rem;font-weight:700}.tree-stages-list{flex-direction:column;gap:.75rem;display:flex}.tree-stage-item{background-color:#ffffffb3;border:1px solid #e0f6ff66;border-radius:12px;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:all .2s;display:flex}.tree-stage-item:hover{background-color:#ffffffe6;transform:translate(4px);box-shadow:0 2px 6px #e0f6ff4d}.tree-stage-emoji{text-align:center;flex-shrink:0;width:2.5rem;font-size:1.8rem}.tree-stage-detail{flex-direction:column;flex:1;gap:.25rem;display:flex}.tree-stage-name{color:#2d3748;font-size:1.2rem;font-weight:600}.tree-stage-threshold{color:#22c55e;font-size:1rem;font-weight:500}.tree-loading{text-align:center;color:#4a5568;padding:4rem;font-size:1.8rem}.tree-fruit-popup-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.tree-fruit-popup{background:linear-gradient(135deg,#fff9c4fa 0%,#fff59df2 100%);border:3px solid #fff59de6;border-radius:24px;width:90%;max-width:500px;padding:2.5rem;animation:.4s popupSlideIn;position:relative;box-shadow:0 8px 32px #0000004d}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(-30px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.tree-fruit-popup-content{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.tree-fruit-popup-icon{font-size:5rem;animation:1s ease-in-out infinite celebrateBounce}@keyframes celebrateBounce{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-15px)scale(1.1)}}.tree-fruit-popup-title{color:#92400e;text-align:center;font-size:1.8rem;font-weight:700;line-height:1.5}.tree-fruit-popup-close{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border:none;border-radius:30px;padding:.8rem 2rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #22c55e4d}.tree-fruit-popup-close:hover{background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.tree-fruit-popup-close:active{transform:translateY(0)}@media (max-width:768px){.tree-container{padding:1rem}.tree-content{grid-template-columns:1fr}.tree-emoji{font-size:6rem}.tree-stats{grid-template-columns:1fr}.tree-info-content{flex-direction:column;align-items:flex-start;gap:.3rem}.tree-info-arrow{transform:rotate(90deg)}}.well-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.well-header{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:flex;position:relative}.well-header-content{z-index:5;background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.well-back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.well-back-button:hover{background-color:#c8a882;transform:translate(-2px)}.well-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.well-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.well-alerts{z-index:100;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:fixed;top:180px;right:2rem}.well-date-notice{background:linear-gradient(135deg,#fff9c4fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;min-height:2.8rem;padding:.6rem 2rem .6rem .85rem;display:inline-flex;position:relative;box-shadow:0 2px 8px #f59e0b4d}.well-date-notice-text{color:#78350f;font-size:1.1rem;font-weight:500;line-height:1.4}.well-date-impact{background:linear-gradient(135deg,#fef3c7fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;min-height:2.8rem;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;position:relative;box-shadow:0 2px 8px #f59e0b4d}.well-date-impact-icon{flex-shrink:0;font-size:1.2rem}.well-date-impact-text{color:#78350f;font-size:1.1rem;font-weight:500;display:inline}.well-date-impact-text strong{color:#92400e;font-size:1.15rem;font-weight:600}.well-bonus-message{background:linear-gradient(135deg,#dbeafefa 0%,#bfdbfef2 100%);border:1.5px solid #3b82f680;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;display:inline-flex;position:relative;box-shadow:0 2px 8px #3b82f64d}.well-bonus-icon{flex-shrink:0;font-size:1.2rem}.well-bonus-text{color:#1e40af;font-size:1.1rem;font-weight:500;display:inline}.well-bonus-text strong{color:#1e3a8a;font-size:1.15rem;font-weight:600}.well-alert-close{color:#78350f;cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;width:1.2rem;height:1.2rem;padding:.2rem .3rem;font-size:.7rem;line-height:1;transition:opacity .2s;display:flex;position:absolute;top:.3rem;right:.3rem}.well-alert-close:hover{opacity:1}.well-bonus-message .well-alert-close{color:#1e40af}.well-reduced-message{background:linear-gradient(135deg,#dbeafefa 0%,#bfdbfef2 100%);border:1.5px solid #3b82f699;border-radius:8px;align-items:center;gap:.5rem;max-width:400px;min-height:2.8rem;margin-bottom:.75rem;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;position:relative;box-shadow:0 2px 8px #3b82f666}.well-reduced-icon{flex-shrink:0;font-size:1.3rem}.well-reduced-text{color:#1e40af;font-size:1.1rem;font-weight:500;display:inline}.well-reduced-text strong{color:#1d4ed8;font-weight:700}.well-reduced-message .well-alert-close{color:#1e40af}.well-warning-alert{background:linear-gradient(135deg,#fef3c7fa 0%,#fde68af2 100%);border:1.5px solid #f59e0b99;border-radius:8px;align-items:center;gap:.5rem;max-width:400px;min-height:2.8rem;padding:.6rem 2rem .6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;position:relative;box-shadow:0 2px 8px #f59e0b66}.well-warning-alert-icon{flex-shrink:0;font-size:1.3rem}.well-warning-alert-text{color:#78350f;font-size:1.1rem;font-weight:500;display:inline}.well-warning-alert .well-alert-close{color:#92400e}.well-content{grid-template-columns:1fr 1fr;align-items:stretch;gap:2rem;max-width:1200px;margin:0 auto;display:grid}.well-display-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.well-visual{margin-bottom:1.5rem;position:relative}.well-status-message{background:linear-gradient(135deg,#fffffff2 0%,#f8fafcf2 100%);border:2px solid #3b82f633;border-radius:16px;align-items:center;gap:1rem;margin-top:1rem;padding:1.2rem 1.5rem;display:flex;box-shadow:0 2px 8px #00000014}.well-status-message.well-status-overflowing{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:3px solid #f59e0b;animation:2s ease-in-out infinite warning-pulse-subtle;box-shadow:0 4px 16px #f59e0b4d}@keyframes warning-pulse-subtle{0%,to{transform:scale(1);box-shadow:0 4px 16px #f59e0b4d}50%{transform:scale(1.01);box-shadow:0 4px 20px #f59e0b66}}.well-status-message.well-status-overflowing .well-status-title{color:#92400e}.well-status-message.well-status-overflowing .well-status-description{color:#78350f}.well-reset-button{color:#1f2937;cursor:pointer;white-space:nowrap;background:#fff;border:2px solid #0003;border-radius:12px;flex-shrink:0;margin-left:auto;padding:.8rem 1.5rem;font-family:Dongle,sans-serif;font-size:1.1rem;font-weight:700;transition:all .3s;box-shadow:0 2px 8px #0000001a}.well-reset-button:hover{background:#f9fafb;border-color:#0000004d;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.well-reset-button:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a}.well-reset-confirm-popup{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.well-reset-confirm-content{text-align:center;background:#fff;border-radius:1.5rem;width:90%;max-width:500px;padding:2.5rem;animation:.3s slideUp;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.well-reset-confirm-icon{margin-bottom:1rem;font-size:4rem}.well-reset-confirm-title{color:#1f2937;margin:0 0 1rem;font-family:Dongle,sans-serif;font-size:2rem;font-weight:700}.well-reset-confirm-message{color:#374151;margin:1.5rem 0;font-family:Dongle,sans-serif;font-size:1.2rem;line-height:1.8}.well-reset-confirm-buttons{gap:1rem;margin-top:2rem;display:flex}.well-reset-confirm-button{cursor:pointer;border:none;border-radius:.75rem;flex:1;padding:1rem 2rem;font-family:Dongle,sans-serif;font-size:1.4rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #0000001a}.well-reset-confirm-button-cancel{color:#374151;background:#f3f4f6}.well-reset-confirm-button-cancel:hover{background:#e5e7eb;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.well-reset-confirm-button-confirm{color:#fff;background:linear-gradient(135deg,#d7b899 0%,#c8a882 100%)}.well-reset-confirm-button-confirm:hover{background:linear-gradient(135deg,#c8a882 0%,#b89a7a 100%);transform:translateY(-2px);box-shadow:0 6px 20px #d7b89973}.well-reset-confirm-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.well-reset-success-popup{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.well-reset-success-popup-content{text-align:center;background:#fff;border-radius:1.5rem;width:90%;max-width:500px;padding:2.5rem;animation:.3s slideUp;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.well-reset-success-icon{margin-bottom:1rem;font-size:4rem;animation:.6s bounce}.well-reset-success-title{color:#1f2937;margin:0 0 1rem;font-family:Dongle,sans-serif;font-size:2rem;font-weight:700}.well-reset-success-message{color:#374151;margin:1.5rem 0;font-family:Dongle,sans-serif;font-size:1.2rem;line-height:1.8}.well-reset-success-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#d7b899 0%,#c8a882 100%);border:none;border-radius:.75rem;width:100%;margin-top:1rem;padding:1rem 2rem;font-family:Dongle,sans-serif;font-size:1.4rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #d7b8994d}.well-reset-success-button:hover{background:linear-gradient(135deg,#c8a882 0%,#b89a7a 100%);transform:translateY(-2px);box-shadow:0 6px 20px #d7b89973}.well-status-emoji{flex-shrink:0;align-items:center;font-size:2rem;line-height:1;display:flex}.well-status-content{flex:1}.well-status-title{color:#1e3a8a;margin-bottom:.4rem;font-size:1.2rem;font-weight:700}.well-status-description{color:#4a5568;font-size:1rem;line-height:1.5}.well-structure{background:linear-gradient(#8b7355 0%,#6b5d4f 100%);border:10px solid #5a4a3a;border-radius:16px;width:360px;height:400px;margin:0 auto;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0003,0 10px 30px #0000004d}.well-water{background:linear-gradient(#bfdbfeb3 0%,#dbeafea6 50%,#e0f2fe99 100%);border-radius:0 0 6px 6px;transition:height .5s;position:absolute;bottom:0;left:0;right:0}.well-water-overflowing{background:linear-gradient(#b91c1c 0%,#dc2626 50%,#ef4444 100%);animation:1s ease-in-out infinite water-overflow}@keyframes water-overflow{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.well-water-wave{background:linear-gradient(90deg,#0000 0%,#ffffff4d 50%,#0000 100%);height:20px;animation:2s linear infinite wave;position:absolute;top:-10px;left:0;right:0}@keyframes wave{0%{transform:translate(-100%)}to{transform:translate(100%)}}.well-rim{z-index:10;background:linear-gradient(#9d8b6f 0%,#8b7355 100%);border:6px solid #5a4a3a;border-radius:20px;height:40px;position:absolute;top:-10px;left:-10px;right:-10px;box-shadow:0 4px 10px #0000004d,inset 0 2px 4px #ffffff1a}.well-water-level-text{color:#fffffff2;text-shadow:0 2px 4px #00000080,0 0 8px #0000004d;z-index:5;pointer-events:none;font-size:1.8rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.well-overflow-warning{text-align:center;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:3px solid #f59e0b;border-radius:12px;min-width:280px;padding:1.5rem;animation:1.5s ease-in-out infinite warning-pulse;position:absolute;top:-100px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #f59e0b66}@keyframes warning-pulse{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%)scale(1.05)}}.well-overflow-icon{margin-bottom:.5rem;font-size:3.5rem}.well-overflow-title{color:#92400e;margin-bottom:.5rem;font-size:1.8rem;font-weight:700}.well-overflow-message{color:#78350f;font-size:1.3rem;line-height:1.5}.well-info-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:16px;width:100%;max-width:900px;margin:1rem auto 2rem;padding:1.5rem;animation:.3s slideDown;box-shadow:0 4px 12px #e0f6ff33}.well-info-toggle{cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#dbeafe99 0%,#bfdbfe66 100%);border:1.5px solid #bfdbfe80;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;transition:all .3s;display:inline-flex}.well-info-toggle:hover{background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);transform:translateY(-1px);box-shadow:0 2px 6px #bfdbfe4d}.well-info-toggle-icon{font-size:1.1rem}.well-info-toggle-text{color:#2d3748;font-size:1.1rem;font-weight:600}.well-info-content-wrapper{padding:0}.well-info-title{color:#2d3748;margin-bottom:.75rem;font-size:1.6rem;font-weight:700}.well-info-cards{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.well-info-card{background:linear-gradient(135deg,#ffffffe6 0%,#f8fafce6 100%);border:1.5px solid #e0f6ff80;border-radius:12px;align-items:center;gap:.8rem;padding:1rem 1.2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #e0f6ff40}.well-info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff59}.well-info-icon{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-top:.15rem;font-size:2rem;line-height:1;display:inline-flex;transform:translateY(.1rem)}.well-info-content{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;display:flex}.well-info-text,.well-info-arrow,.well-info-result{vertical-align:middle;line-height:1.6;display:inline-block}.well-info-text{color:#4a5568;font-size:1.2rem;font-weight:500}.well-info-arrow{color:#9ca3af;font-size:1.3rem;font-weight:700}.well-info-result{color:#2d3748;font-size:1.2rem;font-weight:600}.well-comfort-message{background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border-radius:12px;margin-top:2rem;padding:1.5rem}.well-comfort-title{color:#1e40af;margin-bottom:.75rem;font-size:1.8rem;font-weight:700}.well-comfort-text{color:#1e3a8a;font-size:1.3rem;line-height:1.6}.well-warning-message{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-radius:12px;margin-top:2rem;padding:1.5rem}.well-warning-title{color:#92400e;margin-bottom:.75rem;font-size:1.8rem;font-weight:700}.well-warning-text{color:#78350f;font-size:1.3rem;line-height:1.6}.well-loading{text-align:center;color:#4a5568;padding:4rem;font-size:1.8rem}.well-contribution-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.well-contribution-title{color:#2d3748;margin-bottom:.5rem;font-size:1.8rem;font-weight:700}.well-contribution-description{color:#6b7280;margin-bottom:1.5rem;font-size:1rem;line-height:1.5}.well-contribution-list{flex-direction:column;gap:1rem;display:flex}.well-contribution-item{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:12px;padding:1rem;box-shadow:0 2px 4px #0000000d}.well-contribution-label{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.well-contribution-emotion-wrapper{align-items:center;gap:.5rem;display:flex}.well-contribution-emotion{color:#000;font-size:1.2rem;font-weight:600}.well-contribution-info-tooltip-container{align-items:center;display:inline-flex;position:relative}.well-contribution-info-icon{color:#fff;cursor:help;background-color:#9ca3af;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-style:normal;font-weight:700;transition:all .2s;display:inline-flex}.well-contribution-info-icon:hover{background-color:#6b7280;transform:scale(1.1)}.well-contribution-info-tooltip{opacity:0;visibility:hidden;z-index:1000;color:#374151;pointer-events:none;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:280px;padding:10px;font-size:.9rem;line-height:1.5;transition:opacity .2s,visibility .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.well-contribution-info-tooltip:after{content:"";border:8px solid #0000;border-top-color:#fff;position:absolute;top:100%;left:50%;transform:translate(-50%)}.well-contribution-info-tooltip:before{content:"";z-index:-1;border:10px solid #0000;border-top-color:#e5e7eb;margin-top:-2px;position:absolute;top:100%;left:50%;transform:translate(-50%)}.well-contribution-info-tooltip-container:hover .well-contribution-info-tooltip{opacity:1;visibility:visible}.well-contribution-percent{color:#2d3748;font-size:1.3rem;font-weight:700}.well-contribution-bar-container{background-color:#e5e7eb;border-radius:10px;width:100%;height:20px;margin-bottom:.5rem;overflow:hidden}.well-contribution-bar{border-radius:10px;height:100%;transition:width .5s}.well-contribution-score{color:#6b7280;text-align:right;font-size:.9rem}.well-contribution-empty{color:#9ca3af;text-align:center;padding:2rem;font-size:1rem}@media (max-width:768px){.well-container{padding:1rem}.well-content{grid-template-columns:1fr}.well-structure{width:300px;height:320px}.well-overflow-warning{min-width:240px;padding:1rem}.well-info-content{flex-direction:column;align-items:flex-start;gap:.3rem}.well-info-arrow{transform:rotate(90deg)}}.office-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem 3rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.office-header{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:flex;position:relative}.office-header-content{background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.office-back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.office-back-button:hover{background-color:#c8a882;transform:translate(-2px)}.office-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.office-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.office-alerts{z-index:100;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:fixed;top:180px;right:2rem}.office-date-notice{background:linear-gradient(135deg,#fff9c4fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;min-height:2.8rem;padding:.6rem .85rem;display:inline-flex;box-shadow:0 2px 8px #f59e0b4d}.office-date-notice-text{color:#78350f;font-size:1.1rem;font-weight:500;line-height:1.4}.office-date-impact{background:linear-gradient(135deg,#fef3c7fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;min-height:2.8rem;padding:.6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;box-shadow:0 2px 8px #f59e0b4d}.office-date-impact-icon{flex-shrink:0;font-size:1.2rem}.office-date-impact-text{color:#78350f;font-size:1.1rem;font-weight:500;display:inline}.office-info-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:16px;width:100%;max-width:1200px;margin:1rem auto 2rem;padding:1.5rem;animation:.3s slideDown;box-shadow:0 4px 12px #e0f6ff33}.office-info-toggle{cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#dbeafe99 0%,#bfdbfe66 100%);border:1.5px solid #bfdbfe80;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;transition:all .3s;display:inline-flex}.office-info-toggle:hover{background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);transform:translateY(-1px);box-shadow:0 2px 6px #bfdbfe4d}.office-info-toggle-icon{font-size:1.1rem}.office-info-toggle-text{color:#2d3748;font-size:1.1rem;font-weight:600}.office-info-content-wrapper{padding:0}.office-info-title{color:#2d3748;margin-bottom:.75rem;font-size:1.4rem;font-weight:700}.office-info-cards{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.office-info-card{background:linear-gradient(135deg,#ffffffe6 0%,#f8fafce6 100%);border:1.5px solid #e0f6ff80;border-radius:12px;align-items:center;gap:.8rem;padding:1rem 1.2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #e0f6ff40}.office-info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff59}.office-info-icon{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-top:.15rem;font-size:2rem;line-height:1;display:inline-flex;transform:translateY(.1rem)}.office-info-content{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;display:flex}.office-info-text,.office-info-arrow,.office-info-result{vertical-align:middle;line-height:1.6;display:inline-block}.office-info-text{color:#4a5568;font-size:1.2rem;font-weight:500}.office-info-arrow{color:#9ca3af;font-size:1.3rem;font-weight:700}.office-info-result{color:#2d3748;font-size:1.2rem;font-weight:600}.office-content{grid-template-columns:1fr 1fr;align-items:start;gap:2rem;max-width:1200px;margin:0 auto;display:grid}.office-section-title{color:#2d3748;text-align:left;margin-top:0;margin-bottom:1.5rem;font-size:1.7rem;font-weight:700}.office-overview-section{grid-column:1/-1;display:block}.office-overview-section .office-section-title{grid-column:1/-1}.office-overview-grid{display:contents}.office-donut-card,.office-contribution-card{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:1.75rem;box-shadow:0 4px 12px #e0f6ff33}.office-donut-card{width:100%}.office-contribution-card{grid-column:2}.office-donut-wrapper{align-items:center;gap:1.5rem;display:flex}.office-donut{width:220px;height:220px;box-shadow:none;background-color:#0000;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.office-donut-svg{border-radius:50%}.office-donut-center{background-color:#f9fafb;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:120px;height:120px;display:flex;box-shadow:inset 0 0 0 1px #d1d5dbcc}.office-donut-center-label{color:#6b7280;margin-bottom:.25rem;font-size:1.1rem}.office-donut-center-value{color:#111827;font-size:1.2rem;font-weight:700}.office-donut-legend{flex-direction:column;flex:1;gap:.5rem;display:flex}.office-donut-legend-item{color:#374151;grid-template-columns:14px 1fr auto;align-items:center;gap:.5rem;width:100%;font-size:1.3rem;display:grid}.office-donut-legend-color{border:1px solid #0000000f;border-radius:50%;width:14px;height:14px}.office-donut-legend-name{text-align:left;white-space:nowrap;font-weight:500}.office-donut-legend-value{color:#111827;text-align:right;white-space:nowrap;font-size:1.6rem;font-weight:600}.office-donut-empty{color:#6b7280;font-size:1.3rem}.office-donut-tooltip{color:#fff;pointer-events:none;z-index:1000;white-space:nowrap;background-color:#000000d9;border-radius:8px;margin-top:-.5rem;padding:.5rem .75rem;font-size:1.2rem;position:absolute;transform:translate(-50%,-100%);box-shadow:0 4px 12px #0000004d}.office-donut-tooltip-name{margin-bottom:.2rem;font-weight:600}.office-donut-tooltip-score{opacity:.9;font-weight:500}.office-contribution-description{color:#4b5563;margin-bottom:1rem;font-size:1.3rem}.office-contribution-bars{flex-direction:column;gap:1rem;display:flex}.office-contribution-item{flex-direction:column;gap:.4rem;display:flex}.office-contribution-label{justify-content:space-between;align-items:center;font-size:1.3rem;display:flex}.office-contribution-name{color:#111827;font-weight:600}.office-contribution-value{color:#4b5563;font-weight:500}.office-contribution-bar-container{background-color:#e5e7eb;border-radius:999px;width:100%;height:20px;overflow:hidden}.office-contribution-bar{border-radius:999px;height:100%;transition:width .3s}.office-contribution-bar.tree{background:linear-gradient(90deg,#4ade80,#16a34a)}.office-contribution-bar.well{background:linear-gradient(90deg,#60a5fa,#1d4ed8)}.office-contribution-total{color:#4b5563;margin-top:.5rem;font-size:1.6rem}.office-calendar-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.calendar-nav-button{cursor:pointer;color:#2d3748;background-color:#ffffffe6;border:2px solid #e0f6ff99;border-radius:16px;padding:.5rem 1rem;font-size:1.5rem;transition:all .3s}.calendar-nav-button:hover{background-color:#e0f6ff4d;border-color:#e0f6ffcc;transform:scale(1.05)}.calendar-month{color:#2d3748;font-size:1.5rem;font-weight:700}.calendar-grid{margin-bottom:2rem}.calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.5rem;display:grid}.calendar-weekday{text-align:center;color:#4a5568;padding:.5rem;font-size:1.3rem;font-weight:700}.calendar-days{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.calendar-day{aspect-ratio:1;cursor:pointer;background-color:#ffffffe6;border:2px solid #e5e7eb99;border-radius:12px;flex-direction:column;justify-content:flex-start;align-items:center;padding:.5rem;transition:all .3s;display:flex;position:relative}.calendar-day:hover{background-color:#e0f6ff33;border-color:#e0f6ffcc;transform:scale(1.05)}.calendar-day.empty{cursor:default;background-color:#0000;border:none}.calendar-day.today{background-color:#e0f6ff4d;border-color:#e0f6ffe6;font-weight:700;box-shadow:0 2px 8px #e0f6ff4d}.calendar-day.selected{background-color:#fff9c466;border-color:#fff59de6;box-shadow:0 4px 12px #fff59d66}.calendar-day-number{color:#2d3748;margin-bottom:.25rem;font-size:1.3rem}.calendar-emotion-dot{border-radius:50%;width:8px;height:8px;margin-top:auto}.calendar-diary-detail{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:16px;margin-top:2rem;padding:1.5rem;box-shadow:0 2px 8px #e0f6ff33}.diary-detail-title{color:#2d3748;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.diary-detail-empty{color:#6b7280;text-align:center;padding:2rem}.diary-detail-list{flex-direction:column;gap:1rem;display:flex}.diary-detail-item{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #e0f6ff26}.diary-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.diary-detail-item-title{color:#2d3748;flex:1;min-width:200px;font-size:1.6rem;font-weight:700}.diary-emotion-scores{flex-wrap:wrap;gap:.5rem;display:flex}.emotion-score-badge{border-radius:12px;padding:.25rem .75rem;font-size:.9rem;font-weight:500}.diary-detail-content{color:#4a5568;white-space:pre-wrap;line-height:1.6}.selected-date-emotion-graph{background-color:#ffffffb3;border:1px solid #e0f6ff66;border-radius:12px;margin-bottom:1.5rem;padding:1rem}.emotion-graph-title{color:#2d3748;margin-top:0;margin-bottom:.75rem;font-size:1.2rem;font-weight:700}.emotion-list{flex-direction:column;gap:.5rem;display:flex}.emotion-list-item{color:#2d3748;align-items:center;gap:.5rem;font-size:1.2rem;display:flex}.emotion-list-name{min-width:80px;font-weight:600}.emotion-list-value{color:#4a5568;font-weight:500}.office-stats-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #e0f6ff33}.stats-subtitle{color:#2d3748;text-align:left;margin-top:0;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.stats-emotion-bars{margin-bottom:2rem}.emotion-bars-container{flex-direction:column;gap:1rem;display:flex}.emotion-bar-item{flex-direction:column;gap:.5rem;display:flex}.emotion-bar-label{justify-content:space-between;align-items:center;display:flex}.emotion-bar-name{color:#2d3748;font-size:1.3rem;font-weight:500}.emotion-bar-value{color:#4a5568;font-size:1.3rem;font-weight:700}.emotion-bar-container{background-color:#e5e7eb;border-radius:8px;width:100%;height:16px;overflow:hidden}.emotion-bar{border-radius:12px;height:100%;transition:width .3s}.stats-trend-graph{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;margin-top:2rem;padding:1.75rem;box-shadow:0 4px 12px #e0f6ff33}.trend-graph-container{flex-direction:column;gap:1rem;display:flex}.trend-graph-labels{gap:1rem;margin-bottom:.5rem;display:flex}.trend-label{border-radius:8px;padding:.5rem 1rem;font-size:1.3rem;font-weight:500}.trend-label.positive{color:#166534;background-color:#dcfce7}.trend-label.negative{color:#991b1b;background-color:#fee2e2}.trend-graph-bars{background-color:#0000;border-radius:12px;justify-content:space-between;align-items:flex-end;gap:.5rem;height:200px;padding:1rem;display:flex;position:relative}.trend-day{z-index:1;flex-direction:column;flex:1;align-items:center;gap:.5rem;height:100%;display:flex;position:relative}.trend-day-bars{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:.25rem;width:100%;max-width:40px;display:flex;position:relative}.trend-bar{cursor:pointer;border-radius:4px 4px 0 0;width:100%;min-height:2px;transition:height .3s}.trend-bar:hover{opacity:.8;transform:scaleY(1.05)}.trend-bar.positive{background-color:#86efac}.trend-bar.negative{background-color:#fca5a5}.trend-day-label{color:#6b7280;text-align:center;white-space:nowrap;font-size:.9rem}@media (max-width:1024px){.office-content{grid-template-columns:1fr}}@media (max-width:768px){.office-container{padding:1rem}.office-info-content{flex-direction:column;align-items:flex-start;gap:.3rem}.office-info-arrow{transform:rotate(90deg)}.calendar-day{padding:.25rem;font-size:1.6rem}.calendar-emotion-dot{width:6px;height:6px}.trend-graph-bars{gap:.25rem;height:150px}.trend-day-bars{max-width:30px}.diary-detail-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.diary-similar-button{color:#1e40af;cursor:pointer;background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);border:1.5px solid #bfdbfeb3;border-radius:8px;margin-top:.75rem;padding:.35rem .9rem;font-family:Dongle,sans-serif;font-size:.95rem;font-weight:500;transition:all .3s}.diary-similar-button:hover:not(:disabled){background:linear-gradient(135deg,#bfdbfee6 0%,#93c5fdb3 100%);transform:translateY(-2px);box-shadow:0 4px 8px #bfdbfe66}.diary-similar-button:disabled{opacity:.6;cursor:not-allowed}.diary-action-buttons{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.diary-delete-button{color:#fff;cursor:pointer;background-color:#ef4444;border:none;border-radius:8px;align-items:center;height:auto;padding:.35rem .9rem;font-family:Dongle,sans-serif;font-size:.95rem;font-weight:500;transition:all .3s;display:inline-flex}.diary-delete-button:hover:not(:disabled){background-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 8px #ef44444d}.diary-delete-button:disabled{opacity:.6;cursor:not-allowed}.delete-dialog-overlay{z-index:10000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.delete-dialog-content{background-color:#fff;border-radius:16px;width:90%;max-width:400px;padding:2rem;animation:.2s ease-in-out fadeIn;box-shadow:0 8px 32px #0003}.delete-dialog-title{color:#2d3748;margin-bottom:1rem;font-family:Dongle,sans-serif;font-size:1.8rem;font-weight:700}.delete-dialog-message{color:#4a5568;margin-bottom:2rem;font-family:Dongle,sans-serif;font-size:1.3rem;line-height:1.6}.delete-dialog-buttons{justify-content:flex-end;gap:.75rem;display:flex}.delete-dialog-cancel-button,.delete-dialog-confirm-button{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:500;transition:all .2s}.delete-dialog-cancel-button{color:#4a5568;background-color:#e2e8f0}.delete-dialog-cancel-button:hover:not(:disabled){background-color:#cbd5e0}.delete-dialog-confirm-button{color:#fff;background:linear-gradient(135deg,#fca5a5e6 0%,#f87171b3 100%)}.delete-dialog-confirm-button:hover:not(:disabled){background:linear-gradient(135deg,#f87171e6 0%,#ef4444cc 100%);transform:translateY(-1px);box-shadow:0 4px 8px #f8717166}.delete-dialog-cancel-button:disabled,.delete-dialog-confirm-button:disabled{opacity:.6;cursor:not-allowed}.similar-diaries-section{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:16px;margin-top:2rem;padding:1.5rem;box-shadow:0 2px 8px #e0f6ff33}.similar-diaries-title{color:#2d3748;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.similar-diaries-loading,.similar-diaries-error,.similar-diaries-empty{text-align:center;color:#6b7280;padding:2rem;font-size:1.2rem}.similar-diaries-error{color:#991b1b;background-color:#fee2e2cc;border:1px solid #ef444480;border-radius:8px;padding:1rem}.similar-diaries-error-title{color:#dc2626;margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.similar-diaries-error-message{white-space:pre-line;line-height:1.6}.similar-diaries-list{flex-direction:column;gap:1rem;display:flex}.similar-diary-item{background-color:#ffffffe6;border:1px solid #e0f6ff66;border-radius:12px;padding:1rem;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #e0f6ff26}.similar-diary-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff40}.similar-diary-header{margin-bottom:.75rem}.similar-diary-meta{color:#6b7280;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:1rem;display:flex}.similar-diary-date{font-weight:500}.similar-diary-similarity{color:#1e40af;background-color:#dbeafe80;border-radius:8px;padding:.2rem .6rem;font-weight:600}.similar-diary-title{color:#2d3748;margin:0;font-size:1.4rem;font-weight:700}.similar-diary-content{color:#4a5568;white-space:pre-wrap;margin-top:.5rem;line-height:1.6}.stats-line-graph{background:#fffffff2;border:1px solid #e0f6ff66;border-radius:16px;margin-top:2rem;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.line-graph-container{width:100%;margin-top:1rem}.line-graph-svg{width:100%;max-width:100%;height:300px;display:block}.line-graph-legend{justify-content:center;gap:2rem;margin-top:1rem;font-family:Dongle,sans-serif;display:flex}.line-graph-legend-item{color:#4a5568;align-items:center;gap:.5rem;font-size:1.2rem;display:flex}.line-graph-legend-line{border-radius:2px;width:30px;height:3px}.line-graph-legend-line.positive{background-color:#22c55e}.line-graph-legend-line.negative{background-color:#ef4444}.office-additional-stats{grid-template-columns:repeat(2,1fr);align-items:start;gap:1.5rem;margin-top:2rem;display:grid}.streak-card .stats-subtitle,.activity-card .stats-subtitle{align-items:center;min-height:2rem;display:flex}@media (max-width:1024px){.office-additional-stats{grid-template-columns:1fr}}.stats-card{background:#fffffff2;border:1px solid #e0f6ff66;border-radius:16px;flex-direction:column;height:100%;padding:1.5rem;display:flex;box-shadow:0 2px 8px #0000001a}.streak-card{text-align:center;flex-direction:column;justify-content:flex-start;padding:1rem 1.5rem;display:flex}.streak-card .stats-subtitle{text-align:center;margin-bottom:.75rem}.streak-content{margin-top:1rem}.streak-number{color:#f59e0b;font-family:Dongle,sans-serif;font-size:3rem;font-weight:700;line-height:1}.streak-label{color:#6b7280;margin-top:.5rem;font-family:Dongle,sans-serif;font-size:1.3rem}.streak-message{color:#f59e0b;margin-top:.5rem;font-family:Dongle,sans-serif;font-size:1.1rem}.activity-card{padding:1rem 1.5rem}.activity-card .stats-subtitle{text-align:left;margin-bottom:.75rem}.activity-content{margin-top:0}.activity-item{width:100%;margin-bottom:1rem}.activity-item:last-child{margin-bottom:0}.activity-label{color:#6b7280;text-align:left;margin-bottom:.25rem;font-family:Dongle,sans-serif;font-size:1.2rem}.activity-value{align-items:baseline;gap:.25rem;margin-bottom:.25rem;display:flex}.activity-number{color:#2d3748;font-family:Dongle,sans-serif;font-size:2rem;font-weight:700}.activity-unit{color:#6b7280;font-family:Dongle,sans-serif;font-size:1.2rem}.activity-bar{background-color:#e5e7eb;border-radius:4px;width:100%;height:8px;overflow:hidden}.activity-bar-fill{background:linear-gradient(90deg,#22c55e 0%,#86efac 100%);border-radius:4px;height:100%;transition:width .3s}.averages-bar-chart{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.average-bar-item{align-items:center;gap:.75rem;width:100%;display:flex}.average-bar-label{color:#374151;align-items:center;gap:.5rem;min-width:80px;font-size:1.1rem;display:flex}.average-bar-color{border-radius:4px;flex-shrink:0;width:16px;height:16px}.average-bar-name{font-weight:500}.average-bar-container{background-color:#f3f4f6;border-radius:14px;flex:1;height:28px;position:relative;overflow:hidden}.average-bar-fill{border-radius:14px;min-width:0;height:100%;transition:width .3s}.average-bar-value{text-align:right;color:#374151;min-width:55px;font-size:1rem;font-weight:600}.weekday-content{justify-content:space-between;align-items:flex-end;gap:.5rem;height:200px;margin-top:1rem;display:flex}.weekday-item{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.weekday-bar-container{flex:1;justify-content:center;align-items:flex-end;width:100%;margin-bottom:.5rem;display:flex}.weekday-bar{background:linear-gradient(#60a5fa 0%,#93c5fd 100%);border-radius:4px 4px 0 0;width:100%;max-width:40px;min-height:4px;transition:height .3s}.weekday-label{color:#6b7280;margin-bottom:.25rem;font-family:Dongle,sans-serif;font-size:1.2rem}.weekday-count{color:#9ca3af;font-family:Dongle,sans-serif;font-size:1rem}.stats-empty{text-align:center;color:#9ca3af;padding:2rem 0;font-family:Dongle,sans-serif;font-size:1.2rem}@media (max-width:768px){.streak-number{font-size:3rem}.weekday-content{gap:.25rem;height:150px}.weekday-bar{max-width:30px}}.mailbox-container{z-index:1;background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;min-height:100vh;padding:2rem 3rem;font-family:Dongle,sans-serif;position:relative;overflow:hidden}.mailbox-header{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto 2rem;display:flex;position:relative}.mailbox-header-content{background:#fffffffa;border:2px solid #e0f6ff99;border-radius:50px;flex-direction:column;justify-content:center;align-items:center;width:fit-content;margin:0 auto;padding:.5rem 2.2rem;display:inline-flex;position:relative;box-shadow:0 4px 16px #00000026,0 2px 8px #e0f6ff4d}.mailbox-back-button{color:#fff;cursor:pointer;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.5rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s}.mailbox-back-button:hover{background-color:#c8a882;transform:translate(-2px)}.mailbox-title{color:#2d3748;z-index:1;margin-top:0;margin-bottom:.25rem;font-size:2.5rem;font-weight:700;line-height:1.2;position:relative}.mailbox-subtitle{color:#4a5568;z-index:1;margin-top:0;font-size:1rem;position:relative}.mailbox-alerts{z-index:100;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:fixed;top:180px;right:2rem}.mailbox-unread-notice{background:linear-gradient(135deg,#fef3c7fa 0%,#fef08af2 100%);border:1.5px solid #f59e0b80;border-radius:8px;align-items:center;gap:.5rem;max-width:360px;min-height:2.8rem;padding:.6rem .85rem;font-size:1.1rem;line-height:1.4;display:inline-flex;box-shadow:0 2px 8px #f59e0b4d}.mailbox-unread-notice-icon{flex-shrink:0;font-size:1.2rem}.mailbox-unread-notice-text{color:#78350f;font-size:1.1rem;font-weight:500;display:inline}.mailbox-unread-notice-text strong{color:#92400e;font-size:1.15rem;font-weight:600}.mailbox-content{grid-template-columns:1fr 1.5fr;gap:2rem;max-width:1200px;margin:0 auto;display:grid}.mailbox-section-title{color:#2d3748;margin-bottom:1.5rem;font-size:2rem;font-weight:700}.mailbox-letters-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;max-height:80vh;padding:2rem;overflow-y:auto;box-shadow:0 4px 12px #e0f6ff33}.mailbox-empty{text-align:center;color:#6b7280;padding:4rem 2rem}.mailbox-empty-icon{margin-bottom:1rem;font-size:4.5rem}.mailbox-empty-hint{color:#9ca3af;margin-top:1rem;font-size:1.3rem;line-height:1.6}.mailbox-letters-list{flex-direction:column;gap:1rem;display:flex}.mailbox-letter-card{cursor:pointer;background-color:#ffffffe6;border:2px solid #e5e7eb99;border-left:4px solid #e0f6ff66;border-radius:16px;padding:1.25rem;transition:all .3s;position:relative}.mailbox-letter-card:hover{background-color:#e0f6ff33;border-color:#e0f6ffcc;transform:translate(4px);box-shadow:0 4px 12px #e0f6ff4d}.mailbox-letter-card-selected{background-color:#e0f6ff4d;border-color:#e0f6ffe6;box-shadow:0 4px 12px #e0f6ff66}.mailbox-letter-unread{background-color:#fff9c433;border-left-width:6px;border-left-color:#fff9c4cc;font-weight:500}.mailbox-letter-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.mailbox-letter-icon{font-size:1.8rem}.mailbox-letter-unread-dot{color:#ef4444;font-size:.9rem;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.mailbox-letter-title{color:#2d3748;margin-bottom:.5rem;font-size:1.3rem;font-weight:700}.mailbox-letter-from{color:#6b7280;margin-bottom:.25rem;font-size:1.3rem}.mailbox-letter-date{color:#9ca3af;font-size:1.3rem}.mailbox-letter-detail-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:20px;max-height:80vh;padding:2rem;overflow-y:auto;box-shadow:0 4px 12px #e0f6ff33}.mailbox-letter-detail{flex-direction:column;display:flex}.mailbox-letter-detail-header{background:#ffffffe6;border:1px solid #e0f6ff66;border-radius:16px;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;padding:1.5rem;display:flex;box-shadow:0 2px 8px #e0f6ff33}.mailbox-letter-detail-icon{font-size:3.5rem}.mailbox-letter-detail-info{flex:1}.mailbox-letter-detail-title{color:#2d3748;margin-bottom:.75rem;font-size:1.8rem;font-weight:700}.mailbox-letter-detail-meta{color:#4a5568;flex-direction:column;gap:.25rem;font-size:1.3rem;display:flex}.mailbox-letter-detail-from{font-weight:500}.mailbox-letter-detail-date{color:#6b7280}.mailbox-letter-detail-content{color:#2d3748;white-space:pre-wrap;background:#ffffffe6;border:1px solid #e0f6ff66;border-radius:16px;flex:1;padding:1.5rem;font-size:1.5rem;line-height:1.8;box-shadow:0 2px 8px #e0f6ff33}.mailbox-letter-detail-line{margin-bottom:.75rem;font-size:1.5rem}.mailbox-letter-detail-line:last-child{margin-bottom:0}.mailbox-letter-detail-actions{justify-content:flex-end;margin-top:1.5rem;display:flex}.mailbox-delete-button{color:#fff;cursor:pointer;background-color:#ef4444;border:none;border-radius:8px;padding:.5rem 1.5rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:500;transition:all .3s}.mailbox-delete-button:hover{background-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 8px #ef44444d}.mailbox-letter-detail-empty{text-align:center;color:#6b7280;padding:4rem 2rem}.mailbox-letter-detail-empty-icon{margin-bottom:1rem;font-size:4.5rem}.mailbox-info-section{background-color:#fffffff2;border:1px solid #e0f6ff4d;border-radius:16px;width:100%;max-width:1200px;margin:1rem auto 2rem;padding:1.5rem;animation:.3s slideDown;box-shadow:0 4px 12px #e0f6ff33}.mailbox-info-toggle{cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#dbeafe99 0%,#bfdbfe66 100%);border:1.5px solid #bfdbfe80;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem 1rem;font-family:Dongle,sans-serif;transition:all .3s;display:inline-flex}.mailbox-info-toggle:hover{background:linear-gradient(135deg,#dbeafecc 0%,#bfdbfe99 100%);transform:translateY(-1px);box-shadow:0 2px 6px #bfdbfe4d}.mailbox-info-toggle-icon{font-size:1.1rem}.mailbox-info-toggle-text{color:#2d3748;font-size:1.1rem;font-weight:600}.mailbox-info-content-wrapper{padding:0}.mailbox-info-title{color:#2d3748;margin-bottom:.75rem;font-size:1.6rem;font-weight:700}.mailbox-info-cards{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.mailbox-info-card{background:linear-gradient(135deg,#ffffffe6 0%,#f8fafce6 100%);border:1.5px solid #e0f6ff80;border-radius:12px;align-items:center;gap:.8rem;padding:1rem 1.2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #e0f6ff40}.mailbox-info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e0f6ff59}.mailbox-info-icon{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-top:.15rem;font-size:2rem;line-height:1;display:inline-flex;transform:translateY(.1rem)}.mailbox-info-content{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;display:flex}.mailbox-info-text,.mailbox-info-arrow,.mailbox-info-result{vertical-align:middle;line-height:1.6;display:inline-block}.mailbox-info-text{color:#4a5568;font-size:1.2rem;font-weight:500}.mailbox-info-arrow{color:#9ca3af;font-size:1.3rem;font-weight:700}.mailbox-info-result{color:#2d3748;font-size:1.2rem;font-weight:600}@media (max-width:1024px){.mailbox-content{grid-template-columns:1fr}.mailbox-letters-section,.mailbox-letter-detail-section{max-height:none}}@media (max-width:768px){.mailbox-container{padding:1rem}.mailbox-title{font-size:2.5rem}.mailbox-subtitle{flex-direction:column;align-items:flex-start;gap:.5rem}.mailbox-info-content{flex-direction:column;align-items:flex-start;gap:.3rem}.mailbox-info-arrow{transform:rotate(90deg)}}.residents-intro{margin-bottom:4rem}.residents-intro-title{text-align:center;color:#5a4a3a;letter-spacing:.06em;margin-bottom:2rem;font-family:Dongle,sans-serif;font-size:2.5rem;font-weight:700}.residents-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1200px;margin:0 auto;display:grid}.resident-card{text-align:center;background:#fff;border:1px solid #e0f6ff;border-radius:.75rem;flex-direction:column;justify-content:flex-start;align-items:center;height:280px;padding:1.5rem;transition:box-shadow .3s;display:flex;position:relative;box-shadow:0 2px 6px #0000000f}.resident-card:hover{background:#fff;box-shadow:0 4px 12px #0000001f}.resident-avatar{color:#fff;z-index:1;aspect-ratio:1;border-radius:50%;justify-content:center;align-items:center;width:5rem;min-width:5rem;max-width:5rem;height:5rem;min-height:5rem;max-height:5rem;margin:2.5rem auto 1rem;font-size:1.5rem;font-weight:700;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 4px #0003}.resident-image,.resident-image-purple{object-fit:cover;aspect-ratio:1;border-radius:50%;width:100%;min-width:100%;height:100%;min-height:100%;display:block}.resident-name{color:#5a4a3a;letter-spacing:.05em;margin-bottom:.1rem;font-family:Dongle,sans-serif;font-size:1.7rem;font-weight:700}.resident-emotion{color:#6b5d4f;letter-spacing:.03em;margin-bottom:.1rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400}.resident-description{color:#6b5d4f;letter-spacing:.03em;font-family:Dongle,sans-serif;font-size:1.15rem;font-weight:400}.resident-speech-bubble{color:#5a4a3a;white-space:nowrap;z-index:10;letter-spacing:.03em;background:#fff;border:1px solid #e8e0d5;border-radius:2rem;padding:.3rem .8rem;font-family:Dongle,sans-serif;font-size:1.15rem;font-weight:400;animation:2s ease-in-out infinite float;position:absolute;top:.8rem;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #5a4a3a26}.resident-speech-bubble:after{content:"";border-top:6px solid #fff;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}@keyframes float{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-3px)}}.resident-intro-card{text-align:center;background:#fff;border:1px solid #e0f6ff;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:1.5rem;transition:box-shadow .3s;display:flex;box-shadow:0 2px 6px #0000000f}.resident-intro-card:hover{background:#fff;box-shadow:0 4px 12px #0000001f}.resident-intro-icon{margin-bottom:1rem;font-size:3rem}.resident-intro-title{color:#5a4a3a;letter-spacing:.05em;margin-bottom:.75rem;font-family:Dongle,sans-serif;font-size:1.7rem;font-weight:700}.resident-intro-text{color:#6b5d4f;letter-spacing:.03em;margin:0;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;line-height:1.6}@media (max-width:968px){.residents-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.residents-grid{grid-template-columns:1fr}}.guide-container{background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;flex-direction:column;min-height:100vh;font-family:Dongle,sans-serif;display:flex;position:relative;overflow:hidden}.guide-content{z-index:1;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.guide-header{text-align:center;margin-top:3rem;margin-bottom:3rem;position:relative}.guide-back-button{color:#fff;cursor:pointer;z-index:1;background-color:#d7b899;border:none;border-radius:30px;flex-shrink:0;padding:.3rem 1rem;font-family:Dongle,sans-serif;font-size:1.3rem;transition:all .3s;position:absolute;top:50%;left:0;transform:translateY(-50%)}.guide-back-button:hover{color:#fff;background-color:#c8a882;transform:translateY(-50%)translate(-2px)}.guide-title{color:#2d3748;letter-spacing:.08em;z-index:1;background:#fffffff2;border:1px solid #fff9;border-radius:35px;margin:0;padding:.4rem 3rem;font-family:Dongle,sans-serif;font-size:2.5rem;font-weight:700;display:inline-block;position:relative;box-shadow:0 4px 12px #0000001a,0 2px 4px #0000000d}.guide-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1;background:#fffffff2;border:1px solid #fff9;border-radius:1rem;margin-bottom:2rem;padding:2rem;position:relative;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000d}.guide-section-header{border-bottom:2px solid #e5e7eb99;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.guide-section-icon{font-size:2rem}.guide-section-title{color:#2d3748;letter-spacing:.06em;margin:0;font-family:Dongle,sans-serif;font-size:2.3rem;font-weight:700}.guide-section-content{line-height:1.8}.guide-intro-text{color:#4a5568;letter-spacing:.04em;margin-bottom:1rem;font-family:Dongle,sans-serif;font-size:1.4rem;font-weight:400}.guide-intro-text:last-child{margin-bottom:0}.guide-places-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.guide-place-card{text-align:center;background:#fffffff2;border:1px solid #fff9;border-radius:.75rem;padding:1.5rem;transition:transform .3s,box-shadow .3s;box-shadow:0 2px 6px #0000000f}.guide-place-card:hover{background:#fff;transform:translateY(-4px);box-shadow:0 8px 16px #0000001f}.guide-place-icon{margin-bottom:1rem;font-size:2.5rem}.guide-place-title{color:#2d3748;letter-spacing:.05em;margin-bottom:.75rem;font-family:Dongle,sans-serif;font-size:1.7rem;font-weight:700}.guide-place-description{color:#4a5568;letter-spacing:.03em;margin:0;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:400;line-height:1.6}@media (max-width:768px){.guide-title{font-size:2.2rem}.guide-section{padding:1.5rem}.guide-section-title{font-size:1.8rem}.guide-intro-text{font-size:1.25rem}.guide-place-title{font-size:1.5rem}.guide-place-description{font-size:1.15rem}.guide-back-button{margin-bottom:1rem;font-size:1.25rem;position:static;transform:none}.guide-header{position:static}}.guide-sky-clouds{pointer-events:none;z-index:0;position:absolute;inset:-10%;overflow:hidden}.guide-cloud{opacity:.98;background:#fff;border-radius:999px;animation:42s ease-in-out infinite guide-cloud-float;position:absolute;overflow:visible;box-shadow:0 10px 28px #87ceeb40}.guide-cloud:before,.guide-cloud:after{content:"";background:#fff;border-radius:999px;position:absolute}.guide-cloud:before{width:70%;height:85%;top:-35%;left:-18%}.guide-cloud:after{width:80%;height:95%;top:-25%;right:-20%}.guide-cloud.cloud-1{width:260px;height:110px;animation-duration:42s;top:14%;left:-25%}.guide-cloud.cloud-2{width:320px;height:130px;animation-duration:52s;animation-direction:reverse;top:28%;right:-30%}.guide-cloud.cloud-3{width:220px;height:110px;animation-duration:38s;top:45%;left:10%}.guide-cloud.cloud-4{opacity:.95;width:200px;height:90px;animation-duration:46s;top:8%;right:18%}@keyframes guide-cloud-float{0%{transform:translate(0,0)scale(1)}50%{transform:translate(60px,-6px)scale(1.02)}to{transform:translate(0,0)scale(1)}}.login-container{background:radial-gradient(circle,#ffffff80 6px,#0000 6px) 0 0/80px 80px,radial-gradient(circle,#ffffff80 6px,#0000 6px) 40px 40px/80px 80px,linear-gradient(#e0f6ff 0%,#fff 100%) 0 0/100% 100%;flex-direction:column;min-height:100vh;font-family:Dongle,sans-serif;display:flex;position:relative;overflow:hidden}.login-content{z-index:1;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.login-card{background:#fffffff2;border:2px solid #e0f6ff99;border-radius:30px;width:100%;max-width:450px;padding:3rem;box-shadow:0 8px 32px #0000001a}.login-title{color:#2d3748;text-align:center;margin-bottom:.5rem;font-size:3rem;font-weight:700}.login-subtitle{color:#4a5568;text-align:center;margin-bottom:2rem;font-size:1.3rem}.login-toggle{background:#f7fafc;border-radius:15px;gap:.5rem;margin-bottom:2rem;padding:.5rem;display:flex}.login-toggle-btn{color:#718096;cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;padding:.75rem 1rem;font-family:Dongle,sans-serif;font-size:1.2rem;transition:all .3s}.login-toggle-btn.active{color:#fff;background:#d7b899;font-weight:600}.login-form{flex-direction:column;gap:1.5rem;display:flex}.login-form-group{flex-direction:column;gap:.5rem;display:flex}.login-label{color:#2d3748;font-size:1.2rem;font-weight:600}.login-input{border:2px solid #e5e7eb;border-radius:10px;padding:.75rem 1rem;font-family:Dongle,sans-serif;font-size:1.1rem;transition:border-color .3s}.login-input:focus{border-color:#d7b899;outline:none}.login-error{color:#c33;text-align:center;background:#fee;border:1px solid #fcc;border-radius:10px;padding:.75rem 1rem;font-size:1rem}.login-submit-btn{color:#fff;cursor:pointer;background:#d7b899;border:none;border-radius:15px;margin-top:.5rem;padding:.9rem 1.5rem;font-family:Dongle,sans-serif;font-size:1.3rem;font-weight:600;transition:all .3s}.login-submit-btn:hover:not(:disabled){background:#c8a882;transform:translateY(-2px);box-shadow:0 4px 12px #d7b8994d}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-sky-clouds{pointer-events:none;z-index:0;position:absolute;inset:-10%;overflow:hidden}.login-cloud{opacity:.98;background:#fff;border-radius:999px;animation:42s ease-in-out infinite login-cloud-float;position:absolute;overflow:visible;box-shadow:0 10px 28px #87ceeb40}.login-cloud:before,.login-cloud:after{content:"";background:#fff;border-radius:999px;position:absolute}.login-cloud.cloud-1{width:200px;height:80px;animation-delay:0s;top:10%;left:5%}.login-cloud.cloud-1:before{width:120px;height:120px;top:-50px;left:20px}.login-cloud.cloud-1:after{width:100px;height:100px;top:-40px;right:20px}.login-cloud.cloud-2{width:180px;height:70px;animation-delay:-10s;top:30%;right:10%}.login-cloud.cloud-2:before{width:110px;height:110px;top:-45px;left:15px}.login-cloud.cloud-2:after{width:90px;height:90px;top:-35px;right:15px}.login-cloud.cloud-3{width:160px;height:60px;animation-delay:-20s;bottom:20%;left:15%}.login-cloud.cloud-3:before{width:100px;height:100px;top:-40px;left:10px}.login-cloud.cloud-3:after{width:80px;height:80px;top:-30px;right:10px}.login-cloud.cloud-4{width:140px;height:50px;animation-delay:-30s;bottom:10%;right:20%}.login-cloud.cloud-4:before{width:90px;height:90px;top:-35px;left:10px}.login-cloud.cloud-4:after{width:70px;height:70px;top:-25px;right:10px}@keyframes login-cloud-float{0%,to{transform:translate(0)}50%{transform:translate(30px,-20px)}}.App{width:100%;min-height:100vh}
