:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0}h1{font-size:3.2em;line-height:1.1;margin:0 0 .5em}html,body,#root{height:100%;margin:0;padding:0;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}.app-container{display:flex;flex-direction:column;min-height:100vh;height:100vh;background-color:#fafbfc;color:#213547}.main-content{flex:1;display:flex;flex-direction:column;min-height:0;position:relative;width:100%}.header{background-color:#f0f0f0;color:#000;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000001a}.logo{font-size:20px;font-weight:700}.main-menu{display:flex;align-items:center}.main-menu a,.main-menu .notification-menu-item{margin-left:25px;text-decoration:none;color:#333;font-weight:500}.notification-menu-item{position:relative;display:inline-flex;align-items:center}.notification-menu-item a{margin-left:0}.notification-badge{background-color:#ff6b35;color:#fff;border-radius:50%;padding:2px 6px;font-size:11px;font-weight:700;position:absolute;top:-8px;right:-8px;min-width:16px;text-align:center;line-height:1.2;box-shadow:0 1px 2px #0003}.main-menu a:hover{color:#646cff}.hamburger-menu{display:flex;flex-direction:column;align-items:flex-end}.hamburger-menu button{font-size:28px;background:none;border:1px solid transparent;color:#333;cursor:pointer;padding:8px;border-radius:8px}.hamburger-menu button:hover{background-color:#0000000d}.hamburger-menu .menu{display:flex;flex-direction:column;background-color:#f0f0f0;border:1px solid #ccc;margin-top:5px;position:absolute;top:100%;right:0;width:200px;box-shadow:0 4px 8px #0000001a;z-index:999}.hamburger-menu .menu a,.hamburger-menu .menu .notification-menu-item{padding:12px 20px;text-decoration:none;color:#333;display:flex;align-items:center;position:relative}.hamburger-menu .menu .notification-menu-item a{padding:0}.footer{background-color:#f0f0f0;color:#333;text-align:center;padding:20px;border-top:1px solid #ddd}.footer a{color:#333;text-decoration:none;margin:0 15px}.footer a:hover{color:#646cff}@media (prefers-color-scheme: dark){.app-container{background-color:#242424;color:#ffffffde}.header{background-color:#1a1a1a;color:#e0e0e0;border-bottom:1px solid #333}.header .logo{color:#f0f0f0}.header .main-menu a{color:#ccc}.header .main-menu a:hover{color:#fff}.header .hamburger-menu button{color:#fff;background-color:transparent}.header .hamburger-menu button:hover{background-color:#ffffff1a}.header .hamburger-menu .menu{background-color:#2c2c2c;border:1px solid #444;box-shadow:0 4px 12px #0000004d}.header .hamburger-menu .menu a{color:#ccc;border-bottom-color:#444}.header .hamburger-menu .menu a:hover{background-color:#383838;color:#fff}.footer{background-color:#1a1a1a;color:#aaa;border-top:1px solid #333}.footer a{color:#ccc;margin:0 15px}.footer a:hover{color:#fff}}.error-report-btn{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;margin-left:25px;transition:all .2s ease;display:flex;align-items:center;gap:4px;box-shadow:0 2px 8px #ff6b3533}.error-report-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}.error-report-btn:active{transform:translateY(0)}.hamburger-menu .error-report-btn{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;padding:12px 20px;margin:8px 0;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;width:100%;text-align:left;transition:all .2s ease;display:flex;align-items:center;gap:8px}.hamburger-menu .error-report-btn:hover{background:linear-gradient(135deg,#e55a2b,#e8841a);transform:translateY(-1px)}.error-report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.error-report-modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.error-report-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.error-report-header h2{margin:0;font-size:1.5em;font-weight:600}.close-btn{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:#fff3}.error-report-form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.error-report-form .form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333!important;font-size:.9em}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.form-group small{color:#666;font-size:12px;margin-top:4px;display:block}.file-input-container{display:flex;align-items:center;gap:12px;margin-bottom:4px}.file-select-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.file-select-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.file-select-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.file-count{color:#667eea;font-size:13px;font-weight:500;background-color:#f0f4ff;padding:4px 8px;border-radius:4px;border:1px solid #e0e8ff}.image-preview{margin-top:15px;padding:15px;border:1px solid #e0e0e0;border-radius:6px;background-color:#f9f9f9}.image-preview h4{margin:0 0 12px;color:#333;font-size:14px}.image-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.image-item{position:relative;border:1px solid #ddd;border-radius:6px;overflow:hidden;background:#fff}.preview-image{width:100%;height:100px;object-fit:cover;display:block}.remove-image-btn{position:absolute;top:4px;right:4px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.remove-image-btn:hover{background:#f00c}.image-name{display:block;padding:6px 8px;font-size:11px;color:#666;border-top:1px solid #eee;background:#f8f9fa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.system-info{margin:20px 0;padding:15px;background-color:#f5f5f5;border-radius:6px;border-left:4px solid #667eea}.system-info h4{margin:0 0 10px;color:#333;font-size:14px}.info-item{margin-bottom:8px;font-size:12px;color:#666;word-break:break-all}.info-item strong{color:#333;margin-right:8px}.anti-robot-section{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:16px;margin-bottom:24px}.human-verification{display:flex;align-items:center;margin:16px 0}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:16px;font-weight:500;color:#333;gap:16px;line-height:18px}.human-checkbox,.anti-robot-section .human-checkbox,.form-group .human-checkbox{width:18px!important;height:18px!important;cursor:pointer;margin:0 12px 0 0!important;flex-shrink:0;max-width:18px!important;vertical-align:middle}.checkmark{display:none}.checkbox-label:hover{color:#007bff}.form-actions{display:flex;gap:12px;justify-content:flex-start;margin-top:24px;padding-top:20px;border-top:1px solid #e0e0e0}.cancel-btn,.clear-btn,.submit-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;flex:1;min-width:80px}.cancel-btn{background:#f5f5f5;color:#666}.cancel-btn:hover{background:#e8e8e8}.clear-btn{background:#ff6b35;color:#fff}.clear-btn:hover{background:#e55a2b;transform:translateY(-1px)}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.error-report-modal-overlay{padding:10px}.error-report-modal-content{max-height:95vh}.error-report-header{padding:16px 20px}.error-report-header h2{font-size:1.3em}.error-report-form{padding:20px}.form-row{grid-template-columns:1fr;gap:20px}.image-list{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.cancel-btn,.clear-btn,.submit-btn{width:100%}}@media (prefers-color-scheme: dark){.error-report-modal-content{background:#2c2c2c;color:#f0f0f0}.error-report-header{border-bottom-color:#444}.error-report-form .form-group label{color:#f0f0f0!important}.anti-robot-section{background-color:#1a1a1a;border-color:#444}.checkbox-label{color:#f0f0f0}.checkbox-label:hover{color:#66b3ff}.human-checkbox{background-color:#1a1a1a;border-color:#555}.form-group input,.form-group textarea{background:#1a1a1a;border-color:#444;color:#f0f0f0}.form-group small{color:#ccc}.form-group input:focus,.form-group textarea:focus{border-color:#8ab4f8;box-shadow:0 0 0 3px #8ab4f81a}.image-preview{background-color:#1a1a1a;border-color:#444}.image-item{border-color:#444;background:#1a1a1a}.image-name{background:#333;border-top-color:#444;color:#ccc}.system-info{background-color:#1a1a1a;border-left-color:#8ab4f8}.system-info h4{color:#f0f0f0}.info-item{color:#ccc}.info-item strong{color:#f0f0f0}.form-actions{border-top-color:#444}.cancel-btn{background:#444;color:#ccc}.cancel-btn:hover{background:#555}.file-count{color:#8ab4f8;background-color:#8ab4f81a;border-color:#8ab4f84d}}.maintenance-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b6b,#ee5a24,#f39c12);background-size:400% 400%;animation:gradientShift 10s ease infinite;padding:20px}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.maintenance-content{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 40px #0000001a;animation:slideIn .8s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.maintenance-icon{font-size:4rem;margin-bottom:20px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.maintenance-title{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:20px;letter-spacing:1px}.maintenance-message{color:#555;font-size:1.1rem;line-height:1.6;margin-bottom:30px}.maintenance-schedule{background:#f8f9fa;border-radius:10px;padding:20px;margin-bottom:30px;border-left:4px solid #ff6b6b}.maintenance-schedule h2{color:#2c3e50;font-size:1.2rem;margin-bottom:10px;font-weight:600}.maintenance-time{color:#e74c3c;font-size:1.3rem;font-weight:700;margin:0}.maintenance-notice{color:#666;font-size:1rem;line-height:1.5;margin-bottom:30px}.maintenance-footer{border-top:1px solid #eee;padding-top:20px;color:#999;font-size:.9rem}@media (max-width: 768px){.maintenance-container{padding:15px}.maintenance-content{padding:30px 20px}.maintenance-icon{font-size:3rem}.maintenance-title{font-size:1.5rem}.maintenance-message{font-size:1rem}.maintenance-time{font-size:1.1rem}}@media (prefers-color-scheme: dark){.maintenance-content{background:#2c3e50;color:#ecf0f1}.maintenance-title{color:#ecf0f1}.maintenance-schedule{background:#34495e}.maintenance-schedule h2{color:#ecf0f1}.maintenance-footer{border-top:1px solid #555;color:#bdc3c7}}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ff6b35b3}70%{transform:scale(1.05);box-shadow:0 0 0 10px #ff6b3500}to{transform:scale(1);box-shadow:0 0 #ff6b3500}}.pulse-animation{animation:pulse 2s infinite}.spinner{border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 16px}.map-message{display:flex;align-items:center;justify-content:center;height:calc(100vh - 140px);background-color:#f8f9fa;color:#333}.loading-content{text-align:center;padding:20px}.loading-content p{margin:8px 0;font-size:16px;color:#666}.loading-fallback{margin-top:20px;padding:16px;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px}.loading-fallback p{margin-bottom:12px;color:#856404;font-size:14px}.reload-button{background-color:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .2s}.reload-button:hover{background-color:#0056b3}@media (prefers-color-scheme: dark){.map-message{background-color:#1a1a1a;color:#f0f0f0}.loading-content p{color:#ccc}.loading-fallback{background-color:#3d2914;border-color:#8b6914}.loading-fallback p{color:#d4a574}.spinner{border-color:#333;border-top-color:#007bff}}.map-component-wrapper{position:relative;width:100%;height:calc(100vh - 140px);display:flex;flex-direction:column;overflow:hidden;pointer-events:auto}@media (min-width: 769px){.map-component-wrapper{height:calc(100vh - 140px)}}.main-map-container{flex:1 1 auto;width:100%;min-height:300px;background-color:#e0e0e0;position:relative;overflow:hidden}.main-map-container .gm-control-active,.main-map-container .gm-svpc,.main-map-container .gm-bundled-control,.main-map-container .gmnoprint,.main-map-container [class*=gm-style-mtc],.main-map-container button[aria-label=ズームイン],.main-map-container button[aria-label=ズームアウト],.main-map-container button[aria-label=全画面表示にする],.main-map-container div[controlwidth],.main-map-container div[controlheight]{display:none!important;visibility:hidden!important}.main-map-instance{width:100%!important;height:100%!important;position:absolute;top:0;left:0;right:0;bottom:0}.main-map-instance{pointer-events:auto!important}@media (max-width: 768px),(pointer: coarse){.map-controls-overlay{max-width:220px;right:5px;top:5px}.map-button{font-size:13px;padding:8px 12px;min-height:44px;min-width:44px;touch-action:manipulation}.current-location-btn{transform:scale(1);transition:transform .1s ease,opacity .1s ease;touch-action:manipulation}.current-location-btn:active{transform:scale(.95);opacity:.8}.location-hint,.zoom-hint{font-size:12px;padding:8px 12px}.map-component-wrapper *{-webkit-tap-highlight-color:transparent}.main-map-container{-webkit-overflow-scrolling:touch}}.map-component-wrapper.fullscreen-map-active{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999}.map-controls-overlay{position:absolute;top:10px;right:10px;z-index:10;display:flex;flex-direction:column;align-items:center;pointer-events:none;gap:10px;max-width:280px;min-width:160px;isolation:isolate}.map-button{pointer-events:auto;padding:10px 15px;background-color:#fff;border:1px solid #ccc;border-radius:5px;cursor:pointer;font-size:14px;box-shadow:0 2px 5px #0003;color:#333;transition:background-color .2s ease,box-shadow .2s ease;text-align:center;word-wrap:break-word;line-height:1.2;box-sizing:border-box}.map-button:hover{background-color:#f0f0f0;box-shadow:0 3px 7px #00000040}.map-button.reload-btn{font-size:18px;padding:8px 12px}.map-controls-overlay .map-button.current-location-btn,.map-controls-overlay .map-button.fullscreen-btn,.map-controls-overlay .map-button.reload-btn,.map-controls-overlay .map-button.settings-btn,.map-controls-overlay .checkin-section .map-button.checkin-btn{width:100%!important;min-width:100%!important;max-width:100%!important;height:44px!important;min-height:44px!important;max-height:44px!important;text-align:center;padding:8px 15px!important;box-sizing:border-box!important;display:flex!important;align-items:center!important;justify-content:center!important;margin:0!important;line-height:1!important}.current-location-btn{font-weight:700}.map-button.fullscreen-btn{font-size:12px}.map-button.settings-btn{font-size:20px}.location-adjust-panel{background-color:#fff;padding:10px;border-radius:5px;box-shadow:0 2px 5px #0003;display:flex;gap:8px;align-items:center}.location-input{width:90px;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px;box-sizing:border-box}.location-input:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 .1rem #007bff40}.adjust-btn{background-color:#5cb85c;color:#fff;border-color:#4cae4c}.adjust-btn:hover{background-color:#4cae4c}.custom-div-icon{background-clip:padding-box;border-radius:50%;display:flex;justify-content:center;align-items:center}.current-location-marker,.shrine-marker{display:flex;justify-content:center;align-items:center}.shrine-marker-blue{filter:hue-rotate(0deg)}.shrine-marker-green{filter:hue-rotate(120deg)}.shrine-marker-red{filter:hue-rotate(0deg) saturate(1.5)}.leaflet-div-icon{background:transparent!important;border:none!important}.custom-blue-icon{background-color:#007bffb3;border:2px solid white;border-radius:50%;box-shadow:0 0 5px #00000080}.map-controls-overlay .checkin-btn{background-color:#ffc107;color:#212529;border-radius:5px;border:1px solid #c69500}.map-controls-overlay .checkin-btn:hover:not(:disabled){background-color:#e0a800}.map-controls-overlay .checkin-btn:disabled{background-color:#ffc107;opacity:.65;cursor:not-allowed}.gm-style .gm-style-iw-c{padding:0 8px 8px!important;margin:0!important;transform:translateY(-8px)!important}.gm-style .gm-style-iw-t{background:transparent!important}.gm-style .gm-style-iw-d{overflow:hidden!important;padding:0!important;margin:0!important}.gm-style .gm-style-iw-ch{padding:0!important;margin:0!important}.gm-style .gm-style-iw{display:block!important;visibility:visible!important;padding-top:0!important;margin-top:0!important}.gm-style .gm-style-iw-chr{padding:0!important;margin:0!important}.gm-style .gm-style-iw-tc,.gm-style .gm-style-iw button[aria-label=閉じる],.gm-style .gm-style-iw button[title=閉じる],.gm-style .gm-style-iw button[aria-label=Close],.gm-style .gm-style-iw button[title=Close],.gm-style .gm-style-iw .gm-ui-hover-effect{display:none!important}.gm-style .gm-style-iw-t:after{display:none!important}.info-window-content{padding:0;margin:0;min-width:200px;max-width:300px;position:relative}.gm-style-iw-d button[type=button],.gm-style-iw-ch button[type=button],div[style*="position: relative"] button[type=button]{position:absolute!important;top:8px!important;right:8px!important;background-color:#ffffffe6!important;border:1px solid #ccc!important;border-radius:50%!important;width:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;font-size:14px!important;color:#333!important;z-index:1000!important;padding:0!important;margin:0!important;box-shadow:0 2px 4px #0003!important}.gm-style-iw-d button[type=button]:hover,.gm-style-iw-ch button[type=button]:hover,div[style*="position: relative"] button[type=button]:hover{background-color:#f0f0f0!important;border-color:#999!important}.info-window-content h3{margin:0 0 8px;padding:0;font-size:16px;font-weight:700;color:#2c3e50;line-height:1.2}.info-window-content>*:first-child{margin-top:0!important;padding-top:0!important}.info-window-content h3:first-child{margin-top:-4px!important;padding-top:4px!important}.info-window-content p{margin:0 0 12px;padding:0;font-size:14px;color:#666;line-height:1.4}.info-window-content .button-container{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.info-window-content .info-window-button{display:inline-block;padding:6px 12px;font-size:13px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;text-decoration:none;white-space:nowrap;flex:1;min-width:80px;text-align:center}.info-window-content .info-window-button:hover{background-color:#0056b3}.info-window-content .info-window-button.edit-btn{background-color:#28a745}.info-window-content .info-window-button.edit-btn:hover{background-color:#218838}.manual-search-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1010}.manual-search-content{background-color:#fff;padding:20px 25px;border-radius:8px;box-shadow:0 4px 15px #0003;width:90%;max-width:500px;text-align:center}.manual-search-content p{margin-bottom:15px;font-size:.95em}.manual-search-input-wrapper{position:relative;margin-bottom:15px}.manual-search-input{width:calc(100% - 24px);padding:10px 12px;margin-bottom:15px;border:1px solid #ccc;border-radius:4px;font-size:1em}.manual-search-content .map-button{margin:5px}.manual-search-content .cancel-search-button{background-color:#6c757d;color:#fff}.manual-search-content .cancel-search-button:hover{background-color:#5a6268}.login-reminder{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px 20px;border-radius:10px;margin:15px 0;text-align:center}.login-message{margin:0!important;font-size:.95em;line-height:1.5}.login-message strong{font-weight:700}.checkin-section{display:flex;flex-direction:column;align-items:center;gap:5px;width:100%}.checkin-login-hint{background:#667eeae6;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;white-space:nowrap;box-shadow:0 2px 5px #0003;animation:pulse 2s infinite}.hint-text{font-weight:500}@keyframes pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.manual-search-results-list{list-style:none;padding:0;margin-top:20px;max-height:200px;overflow-y:auto;text-align:left;border-top:1px solid #eee}.manual-search-results-list li{padding:10px 12px;border-bottom:1px solid #eee;cursor:pointer;display:flex;align-items:flex-start;gap:8px}.manual-search-results-list li div{flex:1;display:flex;flex-direction:column;gap:4px}.manual-search-results-list li:last-child{border-bottom:none}.manual-search-results-list li:hover{background-color:#f0f0f0}.manual-search-results-list li strong{display:block;font-size:1.05em}.manual-search-results-list li small{color:#666}.manual-search-results-list .prediction-icon{font-size:1.1em;color:#777}.location-hint,.zoom-hint{background-color:#ff6b35f2;color:#fff;padding:10px 15px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 12px #0000004d;margin-bottom:10px;text-align:center;animation:fadeIn .5s ease-in;width:auto;max-width:280px;min-width:200px;box-sizing:border-box;word-wrap:break-word;line-height:1.4;display:inline-block}.zoom-hint{background-color:#28a745f2}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-color-scheme: dark){.manual-search-content{background-color:#2c2c2c;color:#ffffffde}.manual-search-content p{color:#ffffffde}.manual-search-input{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.manual-search-input:focus{border-color:#007bff}.manual-search-input::placeholder{color:#888}.manual-search-results-list{border-top-color:#444}.manual-search-results-list li{border-bottom-color:#444}.manual-search-results-list li:hover{background-color:#333}.manual-search-results-list li small,.manual-search-results-list .prediction-icon{color:#aaa}.cancel-search-button{background-color:#6c757d;color:#fff}.cancel-search-button:hover{background-color:#545b62}}.main-map-container{flex-grow:1;width:100%;height:100%;min-height:400px}.main-map-instance{width:100%;height:100%}.inari-shrine-marker{background-color:#ff6b35;border:3px solid white;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;box-shadow:0 2px 8px #0000004d;transition:transform .2s ease,box-shadow .2s ease}.inari-shrine-marker:hover{transform:scale(1.1);box-shadow:0 4px 12px #0006}.shrine-info-popup{position:relative!important;z-index:999999!important;max-width:420px!important;overflow:hidden!important;box-sizing:border-box!important}.shrine-info-popup div{word-break:break-word!important;overflow-wrap:break-word!important;white-space:normal!important}@media (max-width: 768px){.gm-style .gm-style-iw-ch,.gm-style .gm-style-iw-c,.gm-style .gm-style-iw,.gm-style .gm-style-iw-d,div.gm-style-iw-ch,div.gm-style-iw-c,div.gm-style-iw,div.gm-style-iw-d,div[id].gm-style-iw-ch{max-width:90vw!important;width:calc(90vw - 20px)!important;max-height:500px!important;min-height:0!important;height:auto!important;overflow-x:hidden!important;overflow-y:visible!important;box-sizing:border-box!important}.gm-style-iw-ch>*,.gm-style-iw-c>*,.gm-style-iw>*,.gm-style-iw-d>*{max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box!important}.shrine-info-popup{max-width:90vw!important;width:calc(90vw - 20px)!important;overflow-x:hidden!important;box-sizing:border-box!important}.shrine-info-popup div,.shrine-info-popup div[style],.shrine-info-popup div[style*=住所],.shrine-info-popup div[style*="color: #666"]{max-width:100%!important;width:100%!important;overflow-wrap:anywhere!important;word-break:break-all!important;-webkit-hyphens:auto!important;hyphens:auto!important;white-space:normal!important;overflow:hidden!important;overflow-x:hidden!important;box-sizing:border-box!important}.shrine-info-popup *{max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box!important}.shrine-info-popup div[style*=flexDirection]{flex-direction:column!important;justify-content:center!important;align-items:center!important;gap:8px!important;width:100%!important;overflow-x:hidden!important}.shrine-info-popup button{font-size:13px!important;padding:10px 16px!important;min-width:0!important;max-width:100%!important;width:200px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;box-sizing:border-box!important}}body:has(.shrine-info-popup) .gm-style .cluster-icon{pointer-events:none!important}@media (max-width: 768px){.map-controls-overlay{top:5px;right:5px;gap:5px;max-width:200px;min-width:120px}.map-button{font-size:12px;padding:8px 10px;min-height:40px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.map-button.settings-btn{font-size:18px}.map-controls-overlay .map-button.current-location-btn,.map-controls-overlay .map-button.fullscreen-btn,.map-controls-overlay .map-button.settings-btn,.map-controls-overlay .checkin-section .map-button.checkin-btn{height:44px!important;min-height:44px!important;max-height:44px!important;width:100%!important;min-width:100%!important;max-width:100%!important;padding:8px 10px!important}.main-map-container{-webkit-overflow-scrolling:touch}.map-component-wrapper{position:relative;width:100%;height:100vh;overflow:hidden;pointer-events:auto}.location-hint,.zoom-hint{font-size:12px;padding:8px 12px;max-width:240px;min-width:180px}}.custom-blue-icon{background-color:#007bff;border:2px solid white;border-radius:50%;box-shadow:0 2px 6px #0000004d}.custom-ainari-icon{background:linear-gradient(45deg,#ff6b35,gold);border:3px solid #fff;border-radius:50%;box-shadow:0 3px 10px #ff6b3580;position:relative;animation:ainari-glow 2s infinite alternate}.custom-ainari-icon:before{content:"🦊";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:16px;line-height:1}@keyframes ainari-glow{0%{box-shadow:0 3px 10px #ff6b3580}to{box-shadow:0 3px 15px #ff6b35cc,0 0 20px #ffd7004d}}.main-map-container{position:relative;width:100%;height:100%;pointer-events:auto}.main-map-instance{width:100%;height:100%;pointer-events:auto}.search-box-overlay{position:absolute;top:20px;left:20px;right:20px;z-index:1000;display:flex;justify-content:center;pointer-events:none}.search-box-overlay .shrine-search-box{pointer-events:auto;max-width:400px;width:100%}@media (max-width: 768px){.search-box-overlay{top:10px;left:10px;right:10px}.search-box-overlay .shrine-search-box{max-width:none}}.site-stats-overlay{position:absolute;bottom:10px;left:10px;z-index:10;background-color:#fffffff2;padding:8px 14px;border-radius:8px;box-shadow:0 2px 8px #00000026;display:flex;align-items:center;gap:8px;font-size:13px;pointer-events:auto}.stats-item{display:flex;align-items:center;gap:4px}.stats-icon{font-size:14px}.stats-label{color:#666;font-size:11px}.stats-value{font-weight:700;color:#333;font-size:14px}.stats-unit{color:#666;font-size:11px}.stats-divider{color:#ccc;font-weight:300}@media (max-width: 768px){.site-stats-overlay{bottom:8px;left:8px;padding:6px 10px;font-size:11px;gap:6px}.stats-icon{font-size:12px}.stats-label{font-size:10px}.stats-value{font-size:12px}.stats-unit{font-size:10px}}@media (prefers-color-scheme: dark){.site-stats-overlay{background-color:#282828f2}.stats-label,.stats-unit{color:#aaa}.stats-value{color:#f0f0f0}.stats-divider{color:#555}}.recent-checkins-panel{flex:0 0 auto;background-color:#fff;border-top:1px solid #e0e0e0;padding:12px 16px;min-height:150px;max-height:180px;overflow-y:auto}.recent-checkins-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.recent-checkins-title{margin:0;font-size:14px;font-weight:700;color:#333;display:flex;align-items:center;gap:6px}.recent-checkins-title:before{content:"🦊"}.view-all-link{font-size:13px;color:#ff6b35;text-decoration:none;font-weight:500}.view-all-link:hover{text-decoration:underline}.recent-checkins-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:10px}.recent-checkin-item{flex:1 1 calc(50% - 10px);min-width:250px;max-width:calc(50% - 5px);background-color:#f9f9f9;border-radius:8px;padding:10px 12px;border-left:3px solid #ff6b35}.checkin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.checkin-shrine-name{font-weight:700;font-size:13px;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}.checkin-date{font-size:11px;color:#888}.checkin-comment{font-size:12px;color:#555;margin:4px 0;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.checkin-nickname{font-size:11px;color:#999;font-style:italic}.recent-checkins-table{width:100%;border-collapse:collapse;font-size:13px}.recent-checkins-table thead{background-color:#f5f5f5}.recent-checkins-table th{padding:8px 10px;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #ddd;font-size:12px}.recent-checkins-table td{padding:8px 10px;border-bottom:1px solid #eee;color:#333}.recent-checkins-table tbody tr:hover{background-color:#fafafa}.th-prefecture,.td-prefecture{width:80px}.th-shrine,.td-shrine{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.th-date,.td-date{width:100px;white-space:nowrap;color:#666;font-size:12px}@media (prefers-color-scheme: dark){.recent-checkins-panel{background-color:#1a1a1a;border-top-color:#333}.recent-checkins-title{color:#f0f0f0}.view-all-link{color:#ff8c5a}.recent-checkin-item{background-color:#2a2a2a}.checkin-shrine-name{color:#f0f0f0}.checkin-date{color:#aaa}.checkin-comment{color:#ccc}.checkin-nickname{color:#888}.recent-checkins-table thead{background-color:#252525}.recent-checkins-table th{color:#bbb;border-bottom-color:#444}.recent-checkins-table td{color:#ddd;border-bottom-color:#333}.recent-checkins-table tbody tr:hover{background-color:#2a2a2a}.td-date{color:#aaa}}.mobile-recent-checkins{display:none}@media (max-width: 768px){.mobile-recent-checkins{display:block;position:absolute;bottom:8px;left:8px;right:8px;z-index:10;background-color:#fffffff2;border-radius:10px;padding:10px 12px;box-shadow:0 2px 10px #00000026;max-width:calc(100% - 16px)}.mobile-checkins-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mobile-recent-checkins.collapsed .mobile-checkins-header{margin-bottom:0}.mobile-checkins-title{font-size:13px;font-weight:700;color:#333}.mobile-checkins-actions{display:flex;align-items:center;gap:10px}.mobile-view-all{font-size:12px;color:#ff6b35;text-decoration:none;font-weight:500}.mobile-view-all:hover{text-decoration:underline}.mobile-checkins-toggle{background:none;border:none;color:#888;font-size:12px;padding:4px 8px;cursor:pointer;border-radius:4px;transition:background-color .2s ease}.mobile-checkins-toggle:hover,.mobile-checkins-toggle:active{background-color:#0000000d}.mobile-checkins-table{width:100%;border-collapse:collapse;font-size:12px;background:transparent}.mobile-checkins-table thead{background-color:#f5f5f5cc}.mobile-checkins-table th{padding:6px 8px;text-align:left;font-weight:600;color:#555;border-bottom:1px solid #ddd;font-size:11px}.mobile-checkins-table td{padding:8px;border-bottom:1px solid #eee;color:#333}.mobile-checkins-table .th-prefecture,.mobile-checkins-table .td-prefecture{width:55px;white-space:nowrap;font-size:11px}.mobile-checkins-table .th-shrine,.mobile-checkins-table .td-shrine{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.mobile-checkins-table .th-date,.mobile-checkins-table .td-date{width:50px;white-space:nowrap;color:#666;font-size:11px}.mobile-checkin-row{cursor:pointer;transition:background-color .2s ease}.mobile-checkin-row:hover,.mobile-checkin-row:active{background-color:#fff8f5}.site-stats-overlay{bottom:auto;top:60px;left:8px}}@media (max-width: 374px){.mobile-checkins-table .th-prefecture,.mobile-checkins-table .td-prefecture{display:none}.mobile-checkins-table .th-shrine,.mobile-checkins-table .td-shrine{max-width:180px}.mobile-recent-checkins{padding:8px 10px}.mobile-checkins-title{font-size:12px}.mobile-view-all{font-size:11px}}@media (prefers-color-scheme: dark) and (max-width: 768px){.mobile-recent-checkins{background-color:#282828f2}.mobile-checkins-title{color:#f0f0f0}.mobile-view-all{color:#ff8c5a}.mobile-checkins-table thead{background-color:#252525cc}.mobile-checkins-table th{color:#aaa;border-bottom-color:#444}.mobile-checkins-table td{color:#ddd;border-bottom-color:#333}.mobile-checkins-table .td-date{color:#aaa}.mobile-checkin-row:hover,.mobile-checkin-row:active{background-color:#2a2a2a}.mobile-checkins-toggle{color:#aaa}.mobile-checkins-toggle:hover,.mobile-checkins-toggle:active{background-color:#ffffff1a}}.modal-content{background-color:#fff;border-radius:8px;position:relative;overflow:auto;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column}.modal-close-button{position:absolute;top:12px;right:12px;cursor:pointer;font-size:20px;color:#666;line-height:1;z-index:1001;padding:4px;background-color:transparent;border:none;width:28px;height:28px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:color .2s}.modal-close-button:hover{color:#333}@media (prefers-color-scheme: dark){.modal-content{background-color:#2c2c2c;color:#ffffffde}.modal-close-button{color:#aaa}.modal-close-button:hover{color:#fff}.modal-header{border-bottom-color:#444}.modal-title{color:#f0f0f0}}.modal-header{padding:20px 20px 0;border-bottom:1px solid #e0e0e0}.modal-title{margin:0 0 15px;font-size:1.5em;color:#333}.modal-body{padding:20px;flex:1;overflow-y:auto}@media (max-width: 768px){.modal-overlay{padding:10px}.modal-content{max-width:100%!important;max-height:100%!important}.modal-body{padding:15px}}.action-selection-modal{text-align:center}.action-selection-message{margin:0 0 24px;color:#666;font-size:14px;line-height:1.4}.action-selection-buttons{display:flex;flex-direction:column;gap:16px}.action-button{padding:16px 20px;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.past-visit-button{background-color:#ffc107;color:#212529}.past-visit-button:hover{background-color:#e0a800;transform:translateY(-1px)}.map-search-button{background-color:#007bff;color:#fff}.map-search-button:hover{background-color:#0056b3;transform:translateY(-1px)}.action-button.close-button{background-color:transparent;color:#666;border:1px solid #ddd;font-size:12px!important}.action-button.close-button:hover{background-color:#f0f0f0;color:#333;transform:translateY(-1px)}.login-notice{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin:16px 0 24px}.notice-text{margin:0 0 12px;color:#495057;font-size:14px;line-height:1.4}.quick-login-btn{background-color:#28a745;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .2s ease}.quick-login-btn:hover{background-color:#218838}.login-required{opacity:.6;cursor:not-allowed;position:relative}.login-required-badge{background-color:#dc3545;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;margin-left:8px}@media (prefers-color-scheme: dark){.action-selection-modal{color:#ffffffde}.action-selection-message{color:#aaa}.login-notice{background-color:#1a1a1a;border-color:#444}.notice-text{color:#ccc}.quick-login-btn{background-color:#4ade80;color:#000}.quick-login-btn:hover{background-color:#22c55e}.past-visit-button{background-color:#fbbf24;color:#000}.past-visit-button:hover{background-color:#f59e0b}.map-search-button{background-color:#3b82f6;color:#fff}.map-search-button:hover{background-color:#2563eb}.action-button.close-button{background-color:transparent;color:#aaa;border-color:#555}.action-button.close-button:hover{background-color:#444;color:#f0f0f0}.login-required-badge{background-color:#ef4444}}@media (min-width: 769px){.action-selection-modal{width:100%;max-width:480px;min-width:400px}.action-button{padding:14px 18px;font-size:15px}}.shrine-registration-content{margin-top:16px}.selected-shrine-info{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin-bottom:20px;text-align:left}.selected-shrine-info h3{margin:0 0 8px;font-size:18px;font-weight:700;color:#212529}.shrine-address{margin:4px 0;color:#666;font-size:14px;line-height:1.4}.shrine-rating{margin:4px 0;color:#ff9800;font-size:14px;font-weight:500}.register-shrine-button{background-color:#28a745;color:#fff}.register-shrine-button:hover{background-color:#218838;transform:translateY(-1px)}@media (prefers-color-scheme: dark){.selected-shrine-info{background-color:#1a1a1a;border-color:#444}.selected-shrine-info h3{color:#f0f0f0}.shrine-address{color:#aaa}.register-shrine-button{background-color:#4ade80;color:#000}.register-shrine-button:hover{background-color:#22c55e}}@media (max-width: 480px){.action-button{padding:14px 16px;font-size:15px}.selected-shrine-info{padding:12px}.selected-shrine-info h3{font-size:16px}}.shrine-search-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001}.shrine-search-modal-content{background-color:#fff;border-radius:12px;width:90%;max-width:500px;height:80%;max-height:600px;display:flex;flex-direction:column;box-shadow:0 8px 24px #0003}.shrine-search-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.shrine-search-header h2{margin:0;color:#333;font-size:20px;font-weight:700}.search-input-container{padding:16px 24px;border-bottom:1px solid #e0e0e0}.shrine-search-input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;box-sizing:border-box}.shrine-search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.search-loading{text-align:center;color:#666;font-size:14px;margin-top:8px}.search-results-container{flex:1;overflow-y:auto;padding:16px 24px}.search-hint{text-align:center;color:#666;padding:40px 20px}.search-hint p{margin:8px 0}.search-example{font-size:14px;color:#999}.no-results{text-align:center;color:#666;padding:40px 20px}.no-results p{margin:8px 0}.search-suggestion{font-size:14px;color:#999}.search-results-list{display:flex;flex-direction:column;gap:12px}.search-result-item{padding:16px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease}.search-result-item:hover{border-color:#007bff;background-color:#f8f9ff;box-shadow:0 2px 8px #007bff1a}.shrine-name{font-weight:700;color:#333;margin-bottom:4px}.shrine-address{font-size:14px;color:#666;margin-bottom:4px}.shrine-visit-count{color:#999}.shrine-search-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-start}.back-button{padding:10px 20px;background-color:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700}.back-button:hover{background-color:#545b62}@media (max-width: 768px){.shrine-search-modal-content{width:95%;height:85%}.shrine-search-header,.search-input-container,.search-results-container,.shrine-search-footer{padding-left:16px;padding-right:16px}}.search-results-container::-webkit-scrollbar{width:6px}.search-results-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.search-results-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.search-results-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (prefers-color-scheme: dark){.shrine-search-modal-content{background-color:#2c2c2c;color:#ffffffde}.shrine-search-header{border-bottom-color:#444}.shrine-search-header h2{color:#f0f0f0}.close-button{color:#aaa}.close-button:hover{background-color:#444;color:#f0f0f0}.search-input-container{border-bottom-color:#444}.shrine-search-input{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.shrine-search-input:focus{border-color:#007bff;background-color:#1a1a1a}.search-results-container{background-color:#2c2c2c}.search-hint,.no-results{color:#aaa}.search-example,.search-suggestion{color:#666}.search-result-item{background-color:#1a1a1a;border-color:#555}.search-result-item:hover{border-color:#007bff;background-color:#333}.shrine-name{color:#f0f0f0}.shrine-address,.shrine-visit-count{color:#d9d9d9}.shrine-search-footer{border-top-color:#444}.search-loading{color:#aaa}.back-button{padding:10px 20px;background-color:#fff;color:#6c757d;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700}.search-results-container::-webkit-scrollbar-track{background:#1a1a1a}.search-results-container::-webkit-scrollbar-thumb{background:#555}.search-results-container::-webkit-scrollbar-thumb:hover{background:#666}}.past-visit-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1002}.past-visit-modal-content{background-color:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90%;overflow-y:auto;box-shadow:0 8px 24px #0003}.past-visit-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.past-visit-header h3{margin:0;color:#333;font-size:16px;font-weight:700}.selected-shrine-info{padding:16px 24px;border-bottom:1px solid #e0e0e0}.shrine-info-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:4px}.selected-shrine-info h3{margin:0!important;color:#28a745!important;font-size:24px!important;font-weight:700!important;line-height:1.2!important;flex:1;min-width:0}.selected-shrine-info h3.shrine-name{font-size:24px!important}.star-button-header{background:none;border:none;font-size:28px;cursor:pointer;padding:0;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;flex-shrink:0}.star-button-header:hover{transform:scale(1.1)}.star-button-header.active{color:#ffc107;filter:drop-shadow(0 2px 4px rgba(255,193,7,.3))}.star-button-header:not(.active){color:#dee2e6}.star-button-header:not(.active):hover{color:#ffc107}.shrine-address{margin:0;color:#666;font-size:14px}.past-visit-form{padding:24px}.form-label.required:after{content:" *";color:#dc3545}.datetime-inputs{display:flex;gap:12px}.date-input,.time-input{flex:1;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:16px}.date-input:focus,.time-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.photo-input{width:100%;padding:8px;border:2px dashed #e0e0e0;border-radius:6px;background-color:#f8f9fa;cursor:pointer;color:transparent;box-sizing:border-box;max-width:100%;overflow:hidden}.photo-input::file-selector-button{color:#666}.photo-input::-webkit-file-upload-button{color:#666}.selected-photos{margin-top:8px;padding:8px 12px;background-color:#e7f3ff;border-radius:4px;color:#06c;font-size:14px}.photo-preview-container{margin-top:16px;display:flex;flex-direction:column;gap:12px}.photo-preview{position:relative;display:inline-block;max-width:200px;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;border:1px solid #ddd;background:#fff}.preview-image{width:100%;height:150px;object-fit:cover;display:block}.photo-change-btn{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s;align-self:flex-start}.photo-change-btn:hover{background:#545b62}.photo-input-hidden{display:none!important}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:12px}.public-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:12px;font-weight:600;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.comment-textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;resize:vertical;min-height:100px;box-sizing:border-box;font-family:inherit;transition:border-color .2s}.comment-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.comment-visibility-toggle{margin-top:12px;padding:12px;background:#f8f9fa;border-radius:8px}.comment-visibility-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.comment-visibility-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.comment-visibility-toggle span{font-size:14px;color:#495057}.form-actions{display:flex;align-items:stretch;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e0e0e0}.back-button,.submit-button{height:48px!important;padding:0 20px!important;margin:0!important;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box;white-space:nowrap;line-height:1!important;vertical-align:baseline!important}.submit-button{flex:2!important;background-color:#28a745!important;color:#fff!important;min-height:48px!important;max-height:48px!important}.submit-button:hover:not(:disabled){background-color:#218838!important}.back-button{flex:1!important;background-color:#6c757d!important;color:#fff!important;min-height:48px!important;max-height:48px!important}.back-button:hover:not(:disabled){background-color:#545b62!important}.back-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.past-visit-modal-content{width:95%}.past-visit-header,.selected-shrine-info,.past-visit-form{padding-left:16px;padding-right:16px}.photo-input{max-width:calc(100% - 16px);margin:0 auto}.past-visit-header h3{font-size:14px}.selected-shrine-info h3{font-size:20px!important}.star-button-header{font-size:24px;min-width:32px;height:32px}.shrine-info-header{gap:8px}.datetime-inputs{flex-direction:column}.form-actions{flex-direction:column;gap:8px}.back-button,.submit-button{flex:none;width:100%}.back-button{margin-bottom:24px!important}}.past-visit-modal-content::-webkit-scrollbar{width:6px}.past-visit-modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.past-visit-modal-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.past-visit-modal-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.login-required-label{color:#dc3545;font-size:12px;font-weight:400}.field-warning{color:#856404;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;padding:8px 12px;margin-bottom:8px;font-size:13px;line-height:1.4}.disabled-field{background-color:#f8f9fa;border-color:#dee2e6;color:#6c757d}.disabled-field::placeholder{color:#adb5bd;font-style:italic}.warning-text{color:#dc3545;font-size:12px;font-weight:700;margin-left:8px}@media (prefers-color-scheme: dark){.past-visit-modal-content{background-color:#2c2c2c;color:#ffffffde}.past-visit-header{border-bottom-color:#444}.past-visit-header h3{color:#f0f0f0}.close-button{color:#aaa}.close-button:hover{background-color:#444;color:#f0f0f0}.selected-shrine-info{border-bottom-color:#444}.selected-shrine-info h3{color:#4ade80!important;font-size:24px!important}.star-button-header:not(.active){color:#666}.star-button-header:not(.active):hover{color:#ffc107}.shrine-address{color:#d9d9d9}.back-button{flex:1;background-color:#fff;color:#6c757d}.back-button:hover:not(:disabled){background-color:#545b62;color:#fff}.form-label{color:#f0f0f0}.date-input,.time-input{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.date-input:focus,.time-input:focus{border-color:#007bff;background-color:#1a1a1a}.memo-textarea{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.memo-textarea:focus{border-color:#007bff;background-color:#1a1a1a}.photo-input{background-color:#1a1a1a;border-color:#555;color:transparent}.photo-input::file-selector-button{color:#aaa}.photo-input::-webkit-file-upload-button{color:#aaa}.photo-input:hover{border-color:#007bff;background-color:#333}.selected-photos{background-color:#1a4480;color:#87ceeb}.form-actions{border-top-color:#444}.login-required-label{color:#ff6b6b}.field-warning{color:#d4a574;background-color:#3d2914;border-color:#8b6914}.disabled-field{background-color:#1a1a1a;border-color:#444;color:#666}.disabled-field::placeholder{color:#555}.warning-text{color:#ff6b6b}.past-visit-modal-content::-webkit-scrollbar-track{background:#1a1a1a}.past-visit-modal-content::-webkit-scrollbar-thumb{background:#555}.past-visit-modal-content::-webkit-scrollbar-thumb:hover{background:#666}}.edit-shrine-modal{background:#fff;border-radius:8px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 25px #0000004d}.edit-shrine-modal h3{margin:0 0 20px;color:#333;font-size:1.2em;font-weight:700}.edit-shrine-modal .form-group{margin-bottom:16px}.edit-shrine-modal label{display:block;margin-bottom:4px;font-weight:500;color:#555}.edit-shrine-modal input,.edit-shrine-modal textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.edit-shrine-modal input:focus,.edit-shrine-modal textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.edit-shrine-modal input:disabled,.edit-shrine-modal textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.edit-shrine-modal textarea{resize:vertical;min-height:60px}.edit-shrine-modal .modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.edit-shrine-modal .submit-btn{background-color:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.edit-shrine-modal .submit-btn:hover:not(:disabled){background-color:#0056b3}.edit-shrine-modal .submit-btn:disabled{background-color:#6c757d;cursor:not-allowed}.edit-shrine-modal .cancel-btn{background-color:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.edit-shrine-modal .cancel-btn:hover:not(:disabled){background-color:#545b62}.edit-shrine-modal .cancel-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.edit-shrine-modal{width:95%;max-width:none;padding:20px;margin:10px}.edit-shrine-modal .modal-actions{flex-direction:column}.edit-shrine-modal .submit-btn,.edit-shrine-modal .cancel-btn{width:100%;padding:12px}}.shrine-search-box{position:relative;border:none;text-decoration:none;transition:all .3s ease}.shrine-search-box.collapsed{width:auto}.shrine-search-box.expanded{width:100%;max-width:400px}.search-icon-button{width:44px;height:44px;border-radius:50%;background-color:#fff;border:2px solid #ddd;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;padding:0}.search-icon-button:hover{background-color:#f8f9fa;box-shadow:0 4px 12px #00000026;transform:scale(1.05)}.search-icon-button:active{transform:scale(.95)}.shrine-search-box:after{display:none}.search-input-container{position:relative;display:flex;align-items:center;border:none;text-decoration:none;outline:none;animation:expandSearch .3s ease}@keyframes expandSearch{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.search-input-container:after,.search-input-container:before{display:none!important}.search-input{width:100%;padding:12px 76px 12px 16px;border:2px solid #ddd;border-radius:25px;font-size:16px;outline:none;transition:all .3s ease;background-color:#fff;box-shadow:0 2px 8px #0000001a;text-decoration:none;border-bottom:none}.search-input:focus{border-color:#007bff;box-shadow:0 2px 8px #007bff40}.search-icon{position:absolute;right:36px;display:flex;align-items:center;justify-content:center;color:#666;font-size:18px;pointer-events:none}.search-spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.clear-search{position:absolute;right:40px;background:none;border:none;font-size:18px;color:#999;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:24px;height:24px;transition:all .2s ease}.clear-search:hover{background-color:#f0f0f0;color:#666}.close-search{position:absolute;right:8px;background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:28px;height:28px;transition:all .2s ease;font-weight:700}.close-search:hover{background-color:#f0f0f0;color:#333}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:none;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:1000;margin-top:4px}.search-result-item{padding:12px 16px;cursor:pointer;transition:background-color .2s ease}.search-result-item:hover{background-color:#f8f9fa}.shrine-name{font-weight:700;color:#2c3e50;margin-bottom:4px;font-size:16px}.shrine-address{color:#666;font-size:14px;margin-bottom:4px;line-height:1.4}.shrine-visits{color:#007bff;font-size:12px;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.google-places-badge{background-color:#4285f4;color:#fff;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase}.rating{color:#ff9800;font-size:11px;font-weight:500}.no-results{padding:16px;text-align:center;color:#666;font-style:italic}.search-result-item mark{background-color:#fff3cd;color:#856404;padding:1px 2px;border-radius:2px;font-weight:700}@media (max-width: 768px){.shrine-search-box.expanded{max-width:100%}.search-icon-button{width:40px;height:40px;font-size:18px}.search-input{padding:10px 72px 10px 12px;font-size:14px}.search-input::placeholder{font-size:12px}.search-results{max-height:250px}.search-result-item{padding:10px 14px}.shrine-name{font-size:15px}.shrine-address{font-size:13px}.clear-search{right:36px}}@media (prefers-color-scheme: dark){.search-icon-button{background-color:#2c2c2c;border-color:#444}.search-icon-button:hover{background-color:#3c3c3c}.search-input{background-color:#2c2c2c;border-color:#444;color:#fff}.search-input:focus{border-color:#4dabf7;box-shadow:0 2px 8px #4dabf740}.search-results{background-color:#2c2c2c;border-color:#444}.search-result-item:hover{background-color:#3c3c3c}.shrine-name{color:#f0f0f0}.shrine-address{color:#ccc}.shrine-visits{color:#4dabf7}.no-results{color:#ccc}.clear-search:hover{background-color:#444;color:#ccc}.close-search{color:#ccc}.close-search:hover{background-color:#444;color:#fff}.search-result-item mark{background-color:#2d4a22;color:#90ee90}}.spot-registration-form-page-container{max-width:700px;margin:20px auto;padding:25px;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;position:relative}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.form-header h1{color:#333;font-size:2em;margin:0;flex-grow:1;text-align:center}.close-button{background:none;border:none;font-size:1.8em;cursor:pointer;color:#666;padding:5px 10px;border-radius:50%;transition:all .2s ease;position:absolute;top:15px;right:15px;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.close-button:hover{background-color:#f0f0f0;color:#333;transform:scale(1.1)}.close-button:active{transform:scale(.95)}.spot-registration-actual-form div:not(.location-input-group){margin-bottom:18px}.spot-registration-actual-form label{display:block;font-weight:600;margin-bottom:6px;color:#444;font-size:.95em}.spot-registration-actual-form input[type=text],.spot-registration-actual-form input[type=number],.spot-registration-actual-form textarea{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:5px;box-sizing:border-box;font-size:1rem;background-color:#fff;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.spot-registration-actual-form input[type=text]:-webkit-autofill,.spot-registration-actual-form input[type=number]:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px #fff inset!important;-webkit-text-fill-color:#000!important;background-color:#fff!important}.spot-registration-actual-form input[type=text]:valid,.spot-registration-actual-form input[type=number]:valid{background-color:#fff}.spot-registration-actual-form input[type=text]:focus,.spot-registration-actual-form input[type=number]:focus,.spot-registration-actual-form textarea:focus{border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.spot-registration-actual-form textarea{min-height:120px;resize:vertical}.location-input-section{margin-bottom:18px}.location-input-group{display:flex;gap:12px;margin-bottom:10px}.location-input-group>div{flex:1}.location-input-group>div label{margin-bottom:4px}.form-button{display:inline-block;padding:10px 18px;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;text-align:center;transition:background-color .2s ease,transform .1s ease}.form-button:hover{opacity:.9}.form-button:active{transform:scale(.98)}.get-location-button{background-color:#007bff}.get-location-button:hover{background-color:#0056b3}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #FF6B35;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px;vertical-align:middle}@media (prefers-color-scheme: dark){.loading-spinner{border-color:#444;border-top-color:#ff8c42}}.submit-button.loading{pointer-events:none}.submit-button.loading .loading-spinner{border:2px solid rgba(255,255,255,.3);border-top:2px solid #ffffff}.form-map-wrapper{margin-top:30px;border-top:1px solid #e0e0e0;padding-top:25px}.map-instruction{text-align:center;margin-bottom:15px;color:#555;font-size:.9em}.form-leaflet-map-container{width:100%;height:300px;border-radius:6px;border:1px solid #ccc;box-shadow:inset 0 1px 3px #0000001a}@media (max-width: 768px){.form-leaflet-map-container{height:250px}.spot-registration-form-page-container{padding:15px}}.form-actions{display:flex;gap:15px;justify-content:flex-start;margin-top:25px;flex-wrap:wrap}.back-button{background-color:#6c757d;color:#fff;border:none;padding:12px 20px;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s ease,transform .1s ease}.back-button:hover:not(:disabled){background-color:#5a6268;transform:translateY(-1px)}.back-button:active:not(:disabled){transform:translateY(0)}.back-button:disabled{background-color:#adb5bd;cursor:not-allowed;transform:none}@media (max-width: 480px){.form-actions{flex-direction:column;gap:10px}.form-actions button{width:100%}}@media (prefers-color-scheme: dark){.spot-registration-form-page-container{background-color:#2c2c2c;color:#ffffffde;box-shadow:0 4px 12px #0000004d}.form-header h1{color:#f0f0f0}.close-button{color:#aaa}.close-button:hover{background-color:#444;color:#f0f0f0}.spot-registration-actual-form label{color:#f0f0f0!important}.spot-registration-actual-form input[type=text],.spot-registration-actual-form input[type=number],.spot-registration-actual-form input[type=date],.spot-registration-actual-form input[type=time],.spot-registration-actual-form textarea{background-color:#1a1a1a!important;border-color:#555;color:#ffffffde}.spot-registration-actual-form input[type=text]:focus,.spot-registration-actual-form input[type=number]:focus,.spot-registration-actual-form input[type=date]:focus,.spot-registration-actual-form input[type=time]:focus,.spot-registration-actual-form textarea:focus{border-color:#007bff;background-color:#1a1a1a!important;box-shadow:0 0 0 .2rem #007bff40}.spot-registration-actual-form input[type=text]::placeholder,.spot-registration-actual-form textarea::placeholder{color:#888}.spot-registration-actual-form input[type=text]:-webkit-autofill,.spot-registration-actual-form input[type=number]:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px #1a1a1a inset!important;-webkit-text-fill-color:rgba(255,255,255,.87)!important;background-color:#1a1a1a!important}.map-instruction{color:#ccc}.form-leaflet-map-container{border-color:#555}.get-location-button{background-color:#0d6efd;color:#fff}.get-location-button:hover:not(:disabled){background-color:#0b5ed7}.submit-button{background-color:#198754;color:#fff}.submit-button:hover:not(:disabled){background-color:#157347}.datetime-inputs{gap:12px}.date-input,.time-input{background-color:#1a1a1a!important;border-color:#555;color:#ffffffde}.date-input:focus,.time-input:focus{border-color:#007bff;background-color:#1a1a1a!important}.form-label{color:#f0f0f0!important}.form-label.required:after{color:#ff6b6b}.spot-registration-actual-form .form-label,.spot-registration-actual-form .form-label.required,.spot-registration-form-page-container label,.spot-registration-form-page-container .form-label,.spot-registration-form-page-container .form-group label,.spot-registration-actual-form label[for=visit-memo]{color:#f0f0f0!important}}.address-hint{display:flex;align-items:flex-start;gap:8px;margin-top:8px;padding:10px 12px;background-color:#e7f3ff;border:1px solid #b8daff;border-radius:5px;font-size:.85em}.hint-icon{flex-shrink:0;font-size:1.1em;line-height:1;margin-top:2px}.hint-text{flex:1;color:#06c;line-height:1.4}@media (prefers-color-scheme: dark){.address-hint{background-color:#1a3d5c;border-color:#2a5a8a}.hint-text{color:#87ceeb}}.address-hint.warning{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.address-hint.warning .hint-text{color:#856404}@media (prefers-color-scheme: dark){.address-hint.warning{background-color:#3d2914;border-color:#8b6914;color:#d4a574}.address-hint.warning .hint-text{color:#d4a574}}.google-places-info{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;padding:16px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px #4285f433}.google-places-info h3{margin:0 0 12px;font-size:18px;font-weight:700}.places-details p{margin:6px 0;font-size:14px;line-height:1.4}.places-details strong{font-weight:600}.places-source{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.3);font-size:12px;opacity:.9;display:flex;align-items:center;gap:8px}.google-badge{background-color:#fff3;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase}@media (max-width: 768px){.google-places-info{padding:12px}.google-places-info h3{font-size:16px}.places-details p{font-size:13px}}.comment-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.photo-input{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:.9em;cursor:pointer}.photo-preview-container{margin-top:12px;position:relative;display:inline-block}.photo-preview{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:block}.photo-remove-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;padding:0;background-color:#0009;color:#fff;border:2px solid white;border-radius:50%;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.photo-remove-btn:hover{background-color:#dc3545;transform:scale(1.1)}.photo-remove-btn:active{transform:scale(.95)}@media (prefers-color-scheme: dark){.photo-input{background-color:#1a1a1a;border-color:#444;color:#ffffffde}.photo-preview{box-shadow:0 2px 8px #00000080}}.confirm-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1003}.confirm-modal-content{background-color:#fff;border-radius:8px;width:90%;max-width:480px;box-shadow:0 8px 24px #0003;overflow:hidden}.confirm-modal-header{padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.confirm-modal-header h3{margin:0;color:#333;font-size:18px;font-weight:700}.confirm-modal-body{padding:24px}.confirm-modal-message{margin:0;color:#555;font-size:14px;line-height:1.5;white-space:pre-line}.confirm-modal-actions{display:flex;gap:12px;padding:16px 24px 24px;border-top:1px solid #e0e0e0;align-items:stretch}.confirm-modal-button{flex:1;height:48px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;transition:all .2s ease;box-sizing:border-box;line-height:1;display:flex;align-items:center;justify-content:center;padding:0 16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.confirm-button{background-color:#007bff;color:#fff;height:48px!important;min-height:48px!important;max-height:48px!important}.confirm-button:hover{background-color:#0056b3;transform:translateY(-1px)}.confirm-button:active{transform:translateY(0)}.cancel-button{background-color:#6c757d;color:#fff;height:48px!important;min-height:48px!important;max-height:48px!important}.cancel-button:hover{background-color:#5a6268;transform:translateY(-1px)}.cancel-button:active{transform:translateY(0)}@media (prefers-color-scheme: dark){.confirm-modal-content{background-color:#2c2c2c;color:#ffffffde}.confirm-modal-header{border-bottom-color:#444}.confirm-modal-header h3{color:#f0f0f0}.confirm-modal-message{color:#ccc}.confirm-modal-actions{border-top-color:#444}.confirm-button{background-color:#0d6efd;border:1px solid #0d6efd}.confirm-button:hover{background-color:#0b5ed7;border-color:#0b5ed7}.cancel-button{background-color:#495057;border:1px solid #6c757d}.cancel-button:hover{background-color:#343a40;border-color:#495057}}@media (max-width: 768px){.confirm-modal-actions{flex-direction:column;gap:8px}.confirm-modal-button{width:100%;flex:none}}@media (max-width: 480px){.confirm-modal-content{width:95%;margin:20px}.confirm-modal-actions{display:grid!important;grid-template-columns:1fr;grid-template-rows:48px 48px;gap:8px;align-items:stretch}.confirm-modal-button{width:100%!important;height:48px!important;min-height:48px!important;max-height:48px!important;flex:none!important;padding:0!important;margin:0!important;border:none!important;border-radius:6px!important;font-size:14px!important;font-weight:700!important;cursor:pointer!important;box-sizing:border-box!important;line-height:1!important;display:flex!important;align-items:center!important;justify-content:center!important}.confirm-button,.cancel-button{height:48px!important;min-height:48px!important;max-height:48px!important}}@media (max-width: 480px) and (prefers-color-scheme: dark){.confirm-button{background-color:#0d6efd!important;border:1px solid #0d6efd!important;color:#fff!important}.confirm-button:hover{background-color:#0b5ed7!important;border-color:#0b5ed7!important}.cancel-button{background-color:#495057!important;border:1px solid #6c757d!important;color:#fff!important}.cancel-button:hover{background-color:#343a40!important;border-color:#495057!important}}.loading-spinner-container{display:flex;align-items:center;justify-content:center;min-height:200px;padding:40px 20px;width:100%;box-sizing:border-box;flex-shrink:0}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;width:auto;height:auto;flex-shrink:0}.spinner-ring{display:inline-block;border-radius:50%;border:2px solid #f3f3f3!important;border-top:2px solid #FF6B35!important;animation:spinner-ring 1s linear infinite;box-sizing:border-box;flex-shrink:0;position:relative;aspect-ratio:1;width:60px;height:60px;transform-origin:center center}.loading-spinner.small .spinner-ring{width:40px!important;height:40px!important;border-width:2px!important;border-color:#f3f3f3!important;border-top-color:#ff6b35!important;min-width:40px;min-height:40px;max-width:40px;max-height:40px;aspect-ratio:1}.loading-spinner.medium .spinner-ring{width:60px!important;height:60px!important;border-width:2px!important;border-color:#f3f3f3!important;border-top-color:#ff6b35!important;min-width:60px;min-height:60px;max-width:60px;max-height:60px;aspect-ratio:1}.loading-spinner.large{width:auto;height:auto;flex-shrink:0}.loading-spinner.large .spinner-ring{width:80px!important;height:80px!important;border-width:3px!important;border-color:#f3f3f3!important;border-top-color:#ff6b35!important;min-width:80px!important;min-height:80px!important;max-width:80px!important;max-height:80px!important;aspect-ratio:1!important;border-radius:50%!important;flex-shrink:0!important;box-sizing:border-box!important}@keyframes spinner-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-content{text-align:center;max-width:300px}.loading-message{color:#2c3e50;font-size:1.2em;margin:0 0 8px;font-weight:600}.loading-submessage{color:#666;font-size:.9em;margin:0;line-height:1.4}@media (prefers-color-scheme: dark){.loading-message{color:#f0f0f0}.loading-submessage{color:#d9d9d9}.spinner-ring{border-color:#444!important;border-top-color:#ff8c42!important}}@media (max-width: 768px){.loading-spinner-container{min-height:150px;padding:30px 20px;width:100%!important;box-sizing:border-box!important}.loading-spinner{gap:15px;width:auto!important;height:auto!important}.loading-message{font-size:1.1em}.loading-submessage{font-size:.85em}.spinner-ring{aspect-ratio:1!important;border-radius:50%!important}}@media (max-width: 480px){.loading-spinner-container{min-height:120px;padding:20px 15px;width:100%!important;box-sizing:border-box!important}.loading-spinner{width:auto!important;height:auto!important}.loading-message{font-size:1em}.loading-submessage{font-size:.8em}.spinner-ring{aspect-ratio:1!important;border-radius:50%!important}}.login-page-container{display:flex;justify-content:center;align-items:flex-start;padding:20px;min-height:calc(100vh - 120px);background-color:#f4f6f8;box-sizing:border-box}@media (max-width: 768px){.login-page-container{padding:10px;align-items:center;min-height:calc(100vh - 80px)}}.login-form-wrapper{background-color:#fff;padding:30px 40px;border-radius:8px;box-shadow:0 4px 15px #0000001a;width:100%;max-width:420px;text-align:center;box-sizing:border-box}@media (max-width: 768px){.login-form-wrapper{padding:20px;margin:0;border-radius:12px;max-width:100%;min-height:auto}}@media (max-width: 480px){.login-form-wrapper{padding:16px;border-radius:8px}}.login-form-wrapper h1{margin-bottom:25px;color:#333;font-size:1.8em}@media (max-width: 768px){.login-form-wrapper h1{font-size:1.6em;margin-bottom:20px}}@media (max-width: 480px){.login-form-wrapper h1{font-size:1.4em;margin-bottom:16px}}.form-group{margin-bottom:20px;text-align:left}@media (max-width: 768px){.form-group{margin-bottom:18px}}@media (max-width: 480px){.form-group{margin-bottom:16px}}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333!important;font-size:.9em}@media (max-width: 768px){.form-group input{padding:14px 16px;font-size:16px;border-radius:8px}}@media (max-width: 480px){.form-group input{padding:16px;font-size:16px}}.login-button{width:100%;padding:12px;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s ease,box-shadow .2s ease;display:flex;justify-content:center;align-items:center;gap:10px;min-height:44px}@media (max-width: 768px){.login-button{padding:16px;font-size:16px;border-radius:8px;min-height:48px}}@media (max-width: 480px){.login-button{padding:18px;font-size:16px;min-height:52px}}.login-button:disabled{background-color:#ccc;cursor:not-allowed}.email-login-button{background-color:#007bff;margin-bottom:15px}.email-login-button:hover:not(:disabled){background-color:#0056b3;box-shadow:0 2px 8px #00000026}.social-login-divider{margin:20px 0;text-align:center;color:#333;font-size:.9em;position:relative;white-space:nowrap;padding:0 20px}.social-login-divider span{background-color:#fff;padding:0 10px;position:relative;z-index:1}.google-login-button{background-color:#fff;color:#444;border:1px solid #ddd;margin-bottom:20px}.google-login-button:hover:not(:disabled){background-color:#f8f8f8;border-color:#ccc;box-shadow:0 2px 8px #0000001a}.google-logo{width:20px;height:20px}.form-footer-links{margin-top:25px;font-size:.9em;color:#555}.form-footer-links p{margin:8px 0}.form-footer-links a{color:#007bff;text-decoration:none}.form-footer-links a:hover{text-decoration:underline;color:#0056b3}.error-message{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:10px;border-radius:5px;margin-bottom:20px;font-size:.9em}@media (max-width: 768px){.error-message{padding:12px;border-radius:8px;font-size:.9em;line-height:1.4}}@media (max-width: 480px){.error-message{padding:10px;font-size:.88em}}.spinner{border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;width:16px;height:16px;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.google-login-button .spinner{border-top-color:#4285f4}.google-signin-button-container{display:flex;justify-content:center;align-items:center;margin-top:15px;margin-bottom:20px;background-color:transparent;min-height:40px;width:100%}@media (max-width: 768px){.google-signin-button-container{margin-top:20px;margin-bottom:25px;min-height:48px}}@media (max-width: 480px){.google-signin-button-container{margin-top:16px;margin-bottom:20px}}.mode-toggle{text-align:center;margin-bottom:15px}.mode-toggle-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:.9em;text-decoration:underline;padding:0}.mode-toggle-button:hover{color:#0056b3}.mode-toggle-button:focus{outline:2px solid #007bff;outline-offset:2px}.terms-agreement{margin:15px 0;padding:0 10px}.login-form .terms-agreement{padding:0;margin:20px 0}.login-form .checkbox-label{gap:12px;align-items:center}.login-form .terms-checkbox{margin:0 4px 0 0}.signup-terms-notice{color:#dc3545;font-size:.8em;margin:10px 0 0;text-align:center;line-height:1.4}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85em;line-height:1.3;width:100%}@media (max-width: 768px){.checkbox-label{gap:12px;font-size:.9em;line-height:1.4;align-items:flex-start;padding:8px 0}}@media (max-width: 480px){.checkbox-label{gap:10px;font-size:.88em}}.terms-checkbox{margin:0;flex-shrink:0;width:16px!important;height:16px!important;min-width:16px;padding:0!important;background-color:#fff!important;border:2px solid #ccc!important;border-radius:3px!important;cursor:pointer!important;position:relative;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important}@media (max-width: 768px){.terms-checkbox{width:20px!important;height:20px!important;min-width:20px;border-radius:4px!important}}@media (max-width: 480px){.terms-checkbox{width:18px!important;height:18px!important;min-width:18px}}.terms-checkbox:checked{background-color:#007bff!important;border-color:#007bff!important}.terms-checkbox:checked:after{content:"✓";position:absolute;top:-2px;left:1px;color:#fff;font-size:12px;font-weight:700;line-height:1}.terms-checkbox:focus{outline:2px solid #007bff;outline-offset:2px}.terms-text{color:#333;flex:1;word-wrap:break-word;overflow-wrap:break-word}.terms-link{color:#007bff;text-decoration:none;margin:0}.terms-link:hover{text-decoration:underline;color:#0056b3}.terms-required-notice{text-align:center;color:#dc3545;font-size:.8em;margin:8px 0 0;padding:0 10px;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;max-width:100%;box-sizing:border-box}.google-signin-button-container.disabled{opacity:.5;pointer-events:none;transition:opacity .3s ease}.google-signin-button-container.loading{opacity:.6;pointer-events:none}.login-page{color-scheme:light;background-color:#fff!important;color:#333!important}@media (prefers-color-scheme: dark){.login-page{background-color:#fff!important;color:#333!important}.login-page *{color:inherit!important}.login-page .google-signin-button-container{background-color:transparent!important}.login-page .social-login-divider{color:#333!important}.login-page .social-login-divider span{background-color:#fff!important}.login-page .google-signin-button-container iframe,.login-page .google-signin-button-container div,.login-page .google-signin-button-container span,.login-page .google-signin-button-container button{background-color:#fff!important;color:#000!important}.login-page div[data-client-id]{background-color:#fff!important}.login-page div[data-client-id] *{background-color:#fff!important;color:#000!important}.login-page iframe[src*="accounts.google.com"],.login-page div[jsname]{background-color:#fff!important}.login-page div[jsname] *{background-color:#fff!important;color:#000!important}.login-page div[data-gsi-client-id]{background-color:#fff!important}.login-page div[data-gsi-client-id] *,.login-page [role=button]{background-color:#fff!important;color:#000!important}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;padding:0;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}@media (max-width: 768px){.modal-content{width:95%;max-width:none;margin:10px;border-radius:12px;max-height:85vh}}@media (max-width: 480px){.modal-content{width:calc(100% - 20px);margin:10px;border-radius:8px}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #eee;margin-bottom:0}.modal-header h2{margin:0;color:#333;font-size:1.5em}.modal-close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.modal-close-button:hover{background-color:#f0f0f0;color:#666}.reset-form{padding:30px}.reset-form p{color:#666;margin:0 0 20px;line-height:1.5}.reset-success{padding:30px;text-align:center}.reset-success h3{color:#28a745;margin:0 0 20px;font-size:1.3em}.reset-success p{color:#666;margin:0 0 25px;line-height:1.6}.reset-buttons{display:flex;gap:12px;margin:25px 0 0}@media (max-width: 480px){.reset-buttons{flex-direction:column;gap:8px}.reset-buttons .login-button,.reset-buttons .cancel-button{flex:none;min-height:48px}}.reset-buttons .login-button{flex:2;min-width:0;margin:0}.cancel-button{background:none;border:2px solid #ddd;color:#666;padding:12px 16px;border-radius:5px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;flex:1;min-width:80px;white-space:nowrap;margin:0;display:flex;align-items:center;justify-content:center}.photo-view-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;box-sizing:border-box}.photo-view-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:16px}.photo-close-button{position:absolute;top:-40px;right:0;background:#ffffffe6;border:none;border-radius:50%;width:32px;height:32px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;z-index:10000}.photo-close-button:hover{background:#fff}.photo-container{display:flex;align-items:center;justify-content:center;max-width:100%;max-height:calc(90vh - 60px)}.full-size-photo{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080}.photo-info{text-align:center}.photo-hint{color:#fffc;font-size:14px;margin:0}@media (max-width: 768px){.photo-view-modal-overlay{padding:10px}.photo-close-button{top:-35px;width:28px;height:28px;font-size:18px}.photo-container{max-height:calc(90vh - 50px)}.photo-hint{font-size:12px}}@media (max-width: 480px){.photo-view-modal-overlay{padding:5px}.photo-close-button{top:-30px;width:24px;height:24px;font-size:16px}.photo-container{max-height:calc(90vh - 40px)}}.photo-view-modal-overlay{animation:fadeIn .2s ease-out}.photo-view-modal-content{animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (prefers-color-scheme: dark){.photo-close-button{background:#3c3c3ce6;color:#ffffffe6}.photo-close-button:hover{background:#3c3c3c;color:#fff}}.datetime-inputs{display:flex;gap:16px;margin-bottom:16px}.date-input-group,.time-input-group{flex:1}.date-input-group label,.time-input-group label{display:block;margin-bottom:8px;font-weight:500;color:#495057;font-size:14px}.date-input,.time-input{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;box-sizing:border-box;transition:border-color .3s ease}.date-input:focus,.time-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}@media (max-width: 768px){.datetime-inputs{flex-direction:column;gap:12px}}.edit-visit-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1003}.edit-visit-modal-content{background-color:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90%;overflow-y:auto;box-shadow:0 8px 24px #0003}.edit-visit-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.edit-visit-header h3{margin:0;color:#333;font-size:18px;font-weight:700}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:4px;border-radius:4px}.close-button:hover{background-color:#f0f0f0;color:#333}.visit-info{padding:16px 24px;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.visit-info h3{margin:0 0 4px;color:#28a745;font-size:18px;font-weight:700}.visit-date{margin:0;color:#666;font-size:14px}.edit-visit-form{padding:24px}.form-section{margin-bottom:24px}.form-label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:700}.memo-textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;resize:vertical;min-height:100px;box-sizing:border-box}.memo-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.current-photo-section{margin-top:16px;margin-bottom:16px}.photo-preview{position:relative;display:inline-block;border-radius:6px;overflow:hidden;max-width:200px;border:1px solid #ddd;background:#fff}.preview-image{width:100%;height:150px;object-fit:cover;border-radius:6px;box-shadow:0 2px 8px #0000001a}.photo-remove-btn{position:absolute;top:4px;right:4px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-remove-btn:hover{background:#f00c}.file-name{font-size:12px;color:#666;margin-top:8px;word-break:break-word;text-align:center}.photo-input{width:100%;padding:8px;border:2px dashed #e0e0e0;border-radius:6px;background-color:#f8f9fa;cursor:pointer;box-sizing:border-box;max-width:100%;overflow:hidden}.photo-input:hover{border-color:#007bff;background-color:#f0f8ff}.new-photo-notice{margin-top:8px;padding:8px 12px;background-color:#e7f3ff;border-radius:4px;color:#06c;font-size:14px}.form-actions{display:flex;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e0e0e0}.cancel-button,.save-button{height:48px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;transition:background-color .2s}.save-button{flex:2;background-color:#28a745;color:#fff}.save-button:hover:not(:disabled){background-color:#218838}.cancel-button{flex:1;background-color:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){background-color:#545b62}.cancel-button:disabled,.save-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.edit-visit-modal-content{width:95%}.edit-visit-header,.visit-info,.edit-visit-form{padding-left:16px;padding-right:16px}.photo-input{max-width:calc(100% - 16px);margin:0 auto}.form-actions{flex-direction:column;gap:8px}.cancel-button,.save-button{flex:none;width:100%;height:48px!important;margin:0!important;padding:0 20px!important;display:flex!important;align-items:center!important;justify-content:center!important;white-space:nowrap;line-height:1!important}.save-button{background-color:#28a745!important}.save-button:hover:not(:disabled){background-color:#218838!important}.cancel-button{margin-bottom:24px!important}}.edit-visit-modal-content::-webkit-scrollbar{width:6px}.edit-visit-modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.edit-visit-modal-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.edit-visit-modal-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (prefers-color-scheme: dark){.edit-visit-modal-content{background-color:#2c2c2c;color:#ffffffde}.edit-visit-header{border-bottom-color:#444}.edit-visit-header h3{color:#f0f0f0}.close-button{color:#aaa}.close-button:hover{background-color:#444;color:#f0f0f0}.visit-info{background-color:#2c2c2c;border-bottom-color:#2c2c2c}.visit-info h3{color:#4ade80}.visit-date{color:#aaa}.form-label{color:#f0f0f0}.memo-textarea{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.memo-textarea:focus{border-color:#007bff}.photo-input{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.photo-input:hover{border-color:#007bff;background-color:#333}.new-photo-notice{background-color:#1a4480;color:#87ceeb}.form-actions{border-top-color:#444}.edit-visit-modal-content::-webkit-scrollbar-track{background:#1a1a1a}.edit-visit-modal-content::-webkit-scrollbar-thumb{background:#555}.edit-visit-modal-content::-webkit-scrollbar-thumb:hover{background:#666}}.comment-label-row{display:flex;justify-content:space-between;align-items:center}.public-badge{background-color:#28a745;color:#fff;padding:3px 10px;border-radius:12px;font-size:.8em;font-weight:600}.comment-visibility-toggle{margin-top:10px;padding:8px 0}.comment-visibility-toggle label{display:flex;align-items:center;cursor:pointer;font-weight:400;color:#666}.comment-visibility-toggle input[type=checkbox]{margin-right:8px;width:18px;height:18px;cursor:pointer}.comment-visibility-toggle span{font-size:.9em}@media (prefers-color-scheme: dark){.comment-visibility-toggle label{color:#d9d9d9}}.visited-shrines-page{padding:20px 20px 80px;max-width:1200px;margin:0 auto;min-height:100%;height:auto;box-sizing:border-box;position:relative;background:transparent;flex:1;overflow-y:auto}.visited-shrines-page .loading-spinner-container{display:flex!important;justify-content:center!important;align-items:center!important;min-height:300px;width:100%!important;box-sizing:border-box!important;flex-shrink:0!important}.visited-shrines-page .loading-spinner{width:auto!important;height:auto!important;flex-shrink:0!important}.visited-shrines-page .spinner-ring{flex-shrink:0!important;border-radius:50%!important;aspect-ratio:1!important;box-sizing:border-box!important;transform-origin:center center!important;border-color:transparent!important;border-top-color:#ff6b35!important}.visited-shrines-page .loading-spinner.large .spinner-ring{width:80px!important;height:80px!important;min-width:80px!important;min-height:80px!important;max-width:80px!important;max-height:80px!important}.page-header{text-align:center;margin-bottom:30px}.login-required{margin:10px auto;max-width:800px}.no-visits{text-align:center;padding:60px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:40px auto;max-width:500px}.no-visits h2{color:#2c3e50;margin-bottom:15px}.no-visits p{color:#666;margin-bottom:25px}.feature-preview{background:#fff;border-radius:15px;padding:40px;box-shadow:0 4px 15px #0000001a;margin-bottom:30px}.feature-preview h2{color:#2c3e50;text-align:center;margin-bottom:20px;font-size:1.8em}.feature-preview>p{text-align:center;color:#666;margin-bottom:30px;font-size:1.1em}.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:25px;margin:30px 0}.feature-item{display:flex;align-items:flex-start;gap:15px;padding:20px;border-radius:10px;background:#f8f9fa;transition:transform .3s ease}.feature-item:hover{transform:translateY(-3px);box-shadow:0 4px 15px #0000001a}.feature-icon{font-size:2em;min-width:50px;text-align:center}.feature-content h3{color:#2c3e50;margin-bottom:8px;font-size:1.1em}.feature-content p{color:#666;font-size:.95em;margin:0;line-height:1.4}.login-prompt{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:15px;padding:40px;text-align:center;box-shadow:0 8px 25px #00000026}.login-prompt h3{margin-bottom:15px;font-size:1.5em}.login-prompt p{margin-bottom:30px;font-size:1.1em;line-height:1.6;opacity:.95}.login-btn,.start-btn{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 30px;border-radius:25px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003}.login-btn:hover,.start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.login-btn.primary{background:#fff;color:#667eea;font-weight:700;box-shadow:0 4px 15px #ffffff4d}.login-btn.primary:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 6px 20px #fff6}.explore-btn{background:transparent;color:#fff;border:2px solid white;padding:12px 25px;border-radius:25px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s ease}.explore-btn:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;flex-wrap:wrap;gap:15px}.search-controls{flex:1;max-width:400px}.search-input-container{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:12px 45px 12px 16px;border:2px solid #e0e6ed;border-radius:8px;font-size:16px;line-height:1.5;color:#2c3e50;background-color:#f8f9fa;transition:all .3s ease;min-height:48px;height:48px;box-sizing:border-box;vertical-align:middle}.search-input:focus{outline:none;border-color:#3498db;background-color:#fff;box-shadow:0 0 0 3px #3498db1a}.search-input::placeholder{color:#95a5a6;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clear-search-btn{position:absolute;right:12px;background:none;border:none;color:#95a5a6;font-size:18px;cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:all .2s ease}.clear-search-btn:hover{background-color:#ecf0f1;color:#2c3e50}.filter-controls{display:flex;align-items:center;gap:8px}.favorite-filter-btn{padding:8px 16px;border:2px solid #e0e6ed;border-radius:6px;background-color:#fff;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.filter-icon{font-size:12px;display:inline-flex;align-items:center;transition:transform .2s ease}.favorite-filter-btn.active .filter-icon{transform:rotate(180deg)}.filter-text{display:inline-flex;align-items:center;gap:4px}.favorite-filter-btn:hover{border-color:#ffc107;background-color:#fffbf0}.favorite-filter-btn.active{background-color:#ffc107;border-color:#ffc107;color:#212529;font-weight:600}.favorite-filter-btn.active:hover{background-color:#e0a800;border-color:#e0a800}.sort-controls{display:flex;align-items:center;gap:10px}.sort-controls label{font-weight:500;color:#2c3e50}.sort-select{padding:8px 15px;border:1px solid #ddd;border-radius:5px;font-size:14px;background:#fff;cursor:pointer}.sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.summary{font-size:1.1em;color:#2c3e50}.total-count strong{color:#667eea;font-size:1.2em}.no-search-results{text-align:center;padding:60px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:40px auto;max-width:500px}.no-search-results h2{color:#2c3e50;margin-bottom:15px;font-size:1.5em}.no-search-results p{color:#666;margin-bottom:25px;font-size:1.1em}.clear-search-link{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 25px;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.clear-search-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.shrines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px}.shrine-card{background:#fff;border-radius:15px;padding:25px;box-shadow:0 4px 15px #0000001a;cursor:pointer;transition:all .3s ease;border:2px solid transparent;position:relative}.shrine-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026;border-color:#667eea}.shrine-card:after{content:"クリックして詳細を見る →";position:absolute;bottom:10px;right:15px;font-size:12px;color:#999;opacity:0;transition:opacity .3s ease}.shrine-card:hover:after{opacity:1}.shrine-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f8f9fa;gap:20px}.shrine-header-right{display:flex;align-items:flex-start;gap:12px}.star-button-card{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px}.star-button-card:hover{background-color:#ffc1071a;transform:scale(1.1)}.star-button-card.active{color:#ffc107;filter:drop-shadow(0 2px 4px rgba(255,193,7,.3))}.star-button-card:not(.active){color:#999}.star-button-card:not(.active):hover{color:#ffc107}.shrine-name{color:#2c3e50;font-size:1.3em;margin:0;flex:1}.visited-shrines-page .visit-count{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9em;font-weight:700;white-space:nowrap;min-width:fit-content;box-shadow:0 2px 8px #667eea4d}.shrine-details{color:#555}.address{margin-bottom:15px;font-size:.95em;color:#666}.visit-dates{margin-bottom:20px}.date-info{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9em}.date-info .label{color:#777;font-weight:500}.date-info .date{color:#2c3e50;font-weight:700}.recent-visits{margin-top:20px;padding-top:15px;border-top:1px solid #eee}.recent-visits h4{color:#2c3e50;font-size:.95em;margin-bottom:10px;font-weight:600}.visit-item{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;font-size:.85em;gap:10px}.visit-date{color:#667eea;font-weight:500;min-width:80px}.visit-memo{color:#555;font-style:italic;flex:1;text-align:right}@media (max-width: 768px){.visited-shrines-page{padding:10px}.page-header h1{font-size:2em}.controls{flex-direction:column;gap:15px;align-items:stretch}.search-controls{max-width:100%;order:1}.search-input{font-size:16px;padding:14px 45px 14px 12px;min-height:52px;height:52px;line-height:1.5}.search-input::placeholder{font-size:13px}.clear-search-btn{width:36px;height:36px;right:10px}.filter-controls{justify-content:center;order:2}.sort-controls{justify-content:center;order:3}.summary{text-align:center;order:4}.shrines-grid{grid-template-columns:1fr;gap:15px}.shrine-card{padding:20px}.shrine-header{flex-direction:column;gap:15px;align-items:stretch}.shrine-header-right{flex-direction:row;justify-content:space-between;align-items:center;width:100%}.shrine-name{margin-bottom:8px}.visit-count{align-self:flex-start;margin-top:0}.visit-item{flex-direction:column;gap:5px}.visit-memo{text-align:left}.feature-preview{padding:25px 20px}.feature-list{grid-template-columns:1fr;gap:15px}.feature-item{padding:15px}.login-prompt{padding:25px 20px}.login-buttons{flex-direction:column;align-items:center}.login-btn,.explore-btn{width:100%;max-width:250px}}@media (prefers-color-scheme: dark){.visited-shrines-page{color:#ffffffde}.page-header h1{color:#f0f0f0}.page-header .subtitle{color:#aaa}.loading,.no-visits,.controls,.shrine-card{background:#2c2c2c;color:#ffffffde}.loading h2,.no-visits h2,.shrine-name,.date-info .date,.recent-visits h4{color:#f0f0f0}.feature-preview{background:#2c2c2c;color:#ffffffde}.feature-preview h2{color:#f0f0f0}.feature-item{background:#1a1a1a}.feature-content h3{color:#f0f0f0}.feature-content p{color:#aaa}.sort-controls label{color:#f0f0f0}.sort-select{background:#1a1a1a;color:#fff;border-color:#444}.summary,.total-count{color:#f0f0f0}.total-count strong{color:#8ab4f8}.shrine-header{border-bottom-color:#444}.shrine-name{color:#f0f0f0}.recent-visits{border-top-color:#444}.address,.date-info .label{color:#d9d9d9}.visit-memo{color:#ccc}.star-button-card:not(.active){color:#666}.star-button-card:not(.active):hover{color:#ffc107}.search-input{background-color:#1a1a1a;border-color:#444;color:#ffffffde}.search-input:focus{border-color:#8ab4f8;background-color:#1a1a1a}.search-input::placeholder{color:#888;font-size:14px}.clear-search-btn{color:#888}.clear-search-btn:hover{color:#f0f0f0}.visit-stats{background:#2c2c2c;border-color:#444}.stat-item{color:#d9d9d9}.visit-indicators .indicator{background:#444;color:#d9d9d9}}.visit-summary{margin-top:16px}.visit-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px;padding:8px 12px;background:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.stat-item{font-size:.85em;color:#555;font-weight:500}.stat-item.photos{color:#007bff}.stat-item.memos{color:#28a745}.visit-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.visit-item:last-child{border-bottom:none}.visit-indicators{display:flex;gap:4px}.visit-indicators .indicator{font-size:.8em;padding:2px 4px;background:#f0f0f0;border-radius:3px;opacity:.8}.visit-indicators .indicator.photo{background:#e3f2fd;color:#1976d2}.visit-indicators .indicator.memo{background:#e8f5e8;color:#388e3c}@media (max-width: 768px){.visited-shrines-page{padding:16px 16px 100px}.visit-stats{flex-direction:column;gap:8px;padding:8px 10px}.visit-item{flex-direction:column;align-items:flex-start;gap:4px}.visit-indicators{align-self:flex-end}}@media (max-width: 480px){.visited-shrines-page{padding:12px 12px 120px}}.delete-button-card{background-color:#dc3545;color:#fff;border:none;padding:6px 8px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s,transform .1s;margin-left:4px;display:flex;align-items:center;justify-content:center;min-width:32px;height:28px}.recent-visits-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.expand-button{background:#f8f9fa;color:#495057;border:1px solid #dee2e6;padding:4px 8px;border-radius:4px;font-size:.75em;cursor:pointer;transition:all .2s ease}.expand-button:hover{background:#e9ecef;border-color:#adb5bd}.visit-item.detailed{display:flex;flex-direction:column;padding:10px 0;border-bottom:1px solid #f0f0f0;gap:8px}.visit-item.detailed .visit-main-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:10px}.visit-main-info{display:flex;align-items:center;gap:10px;flex:1}.visit-actions{display:flex;flex-direction:row;gap:8px;margin-left:10px;flex-shrink:0;align-items:center}.edit-time-button,.edit-content-button,.delete-visit-button{background:none;border:1px solid #dee2e6;padding:4px 6px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;width:32px;height:32px;flex-shrink:0}.edit-time-button:hover{background:#e3f2fd;border-color:#2196f3}.edit-content-button:hover{background:#f3e5f5;border-color:#9c27b0}.delete-visit-button:hover{background:#ffebee;border-color:#f44336}.edit-time-modal{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:90%;box-shadow:0 10px 30px #0000004d}.edit-time-modal h3{margin:0 0 16px;color:#2c3e50;text-align:center}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#495057}.form-group input[type=date],.form-group input[type=time]{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.edit-time-actions{display:flex;gap:12px;justify-content:space-between;margin-top:20px}.save-btn{background:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;font-size:16px;transition:background-color .2s;flex:1;min-width:120px}.save-btn:hover{background:#0056b3}@media (min-width: 769px){.visit-item.detailed{flex-direction:row!important;align-items:center!important}.visit-main-info{flex:1}.visit-actions{flex-direction:row!important;margin-left:10px!important;align-self:center}}@media (max-width: 768px){.visit-item.detailed{flex-direction:column;align-items:flex-start;gap:8px}.visit-main-info{width:100%}.visit-actions{align-self:flex-end;margin-left:0}.expand-button{font-size:.7em;padding:3px 6px}.edit-time-actions,.delete-confirm-actions{flex-direction:column;gap:8px}.save-btn,.cancel-btn,.confirm-delete-btn{width:100%;min-width:unset;padding:14px 20px;font-size:16px}}.delete-button-card:hover{background-color:#c82333;transform:scale(1.05)}.delete-button-card:active{transform:scale(.95)}.delete-confirm-actions{display:flex;gap:12px;justify-content:space-between}.cancel-btn{background-color:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .2s;flex:1;min-width:120px}.confirm-delete-btn{background-color:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .2s;flex:1;min-width:120px}.visit-details{margin-top:8px;padding:8px 0;border-top:1px solid #f0f0f0;display:flex;flex-direction:column;gap:8px}.visit-photo-preview{display:flex;align-items:center}.mini-photo-preview{width:60px;height:60px;object-fit:cover;border-radius:6px;border:2px solid #e0e0e0;cursor:pointer;transition:all .2s ease}.mini-photo-preview:hover{border-color:#007bff;transform:scale(1.05)}.visit-memo-preview{background:#f8f9fa;padding:8px 12px;border-radius:6px;border-left:3px solid #28a745;margin-bottom:6px}.memo-label{font-weight:600;margin-right:6px;color:#28a745}.memo-text{font-size:.85em;color:#555;line-height:1.4;font-style:italic}.visit-comment-preview{background:#e3f2fd;padding:8px 12px;border-radius:6px;border-left:3px solid #2196f3;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.comment-label{font-weight:600;margin-right:6px;color:#2196f3}.comment-text{font-size:.85em;color:#555;line-height:1.4;flex:1}.public-indicator{background:#28a745;color:#fff;padding:2px 8px;border-radius:10px;font-size:.75em;font-weight:600;white-space:nowrap}@media (prefers-color-scheme: dark){.visit-memo-preview{background:#2c3e2f;border-left-color:#4caf50}.memo-label{color:#66bb6a}.memo-text{color:#ccc}.visit-comment-preview{background:#1e2f3e;border-left-color:#42a5f5}.comment-label{color:#64b5f6}.comment-text{color:#ccc}.public-indicator{background:#4caf50;color:#fff}.delete-confirm-modal{background:#2c2c2c;color:#ffffffde}.delete-confirm-modal h3{color:#f87171}.delete-confirm-modal p{color:#d9d9d9}.delete-confirm-modal ul{color:#b3b3b3}.visit-details{border-top-color:#444}.mini-photo-preview{border-color:#555}.mini-photo-preview:hover{border-color:#8ab4f8}.visit-memo-preview{background:#2c2c2c;border-left-color:#66bb6a}.memo-text{color:#d9d9d9}}.replies-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.replies-modal-content{background-color:#fff;border-radius:12px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 30px #0000004d}.replies-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.replies-header h3{margin:0;font-size:1.2em;color:#333}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:#f0f0f0}.replies-list{flex:1;overflow-y:auto;padding:20px;min-height:200px}.no-replies{text-align:center;padding:40px 20px;color:#666}.reply-item{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:12px}.reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.reply-author{font-weight:600;color:#333;font-size:.9em}.own-reply{color:#28a745;font-size:.85em;margin-left:6px}.reply-date{font-size:.8em;color:#666}.reply-content{margin-bottom:8px;line-height:1.5}.reply-content p{margin:0;color:#333;font-size:.95em}.reply-actions{display:flex;gap:8px}.reply-like-btn{background:none;border:1px solid #ddd;border-radius:16px;padding:4px 10px;cursor:pointer;font-size:.85em;transition:all .2s;display:flex;align-items:center;gap:4px}.reply-like-btn:hover{background:#f0f0f0;border-color:#bbb}.reply-like-btn.liked{background:#ffe0e0;border-color:#ff6b6b;color:#ff6b6b}.reply-delete-btn{background:none;border:1px solid #ddd;border-radius:16px;padding:4px 10px;cursor:pointer;font-size:.85em;transition:all .2s;display:flex;align-items:center;justify-content:center}.reply-delete-btn:hover{background:#ffebee;border-color:#ef5350;color:#ef5350}.reply-input-section{border-top:1px solid #e0e0e0;padding:15px 20px;display:flex;flex-direction:column;gap:10px}.reply-input-section textarea{width:100%;padding:10px;border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:.95em;resize:vertical;box-sizing:border-box}.reply-input-section textarea:focus{outline:none;border-color:#4caf50}.send-reply-btn{align-self:flex-end;background-color:#28a745;color:#fff;border:none;border-radius:6px;padding:8px 20px;cursor:pointer;font-size:.95em;font-weight:500;transition:background-color .2s}.send-reply-btn:hover:not(:disabled){background-color:#218838}.send-reply-btn:disabled{background-color:#8fbc8f;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.replies-modal-content{max-height:90vh}.replies-header,.replies-list{padding:15px}.reply-input-section{padding:12px 15px}}@media (prefers-color-scheme: dark){.replies-modal-content{background-color:#2c2c2c;color:#ffffffde}.replies-header{border-bottom-color:#444}.replies-header h3{color:#f0f0f0}.close-btn{color:#d9d9d9}.close-btn:hover{background-color:#444}.no-replies{color:#d9d9d9}.reply-item{background:#1a1a1a}.reply-author{color:#f0f0f0}.reply-date{color:#b3b3b3}.reply-content p{color:#d9d9d9}.reply-like-btn{border-color:#444;color:#d9d9d9}.reply-like-btn:hover{background:#333;border-color:#555}.reply-like-btn.liked{background:#4d1f1f;border-color:#ff6b6b;color:#ff6b6b}.reply-delete-btn{border-color:#444;color:#d9d9d9}.reply-delete-btn:hover{background:#4d1f1f;border-color:#ef5350;color:#ef5350}.reply-input-section{border-top-color:#444}.reply-input-section textarea{background-color:#1a1a1a;border-color:#444;color:#ffffffde}.reply-input-section textarea:focus{border-color:#8ab4f8}}.shrine-detail-page{padding:15px 15px 80px;max-width:800px;margin:0 auto;min-height:calc(100vh - 200px);overflow-y:auto;height:auto;max-height:calc(100vh - 140px);box-sizing:border-box}.shrine-detail-page .loading-spinner-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 300px);padding:40px 20px;width:100%;box-sizing:border-box;position:relative;z-index:1000;background-color:#fffffff2}@media (prefers-color-scheme: dark){.shrine-detail-page .loading-spinner-container{background-color:#2c2c2cf2}}.shrine-detail-header{margin-bottom:30px}.back-button{border:none;color:#007bff;font-size:16px;cursor:pointer;padding:8px 16px;border-radius:6px;transition:background-color .2s;margin-bottom:20px}.back-button:hover{background-color:#f8f9fa}.shrine-detail-header .back-button{margin-bottom:20px!important}.shrine-info{background:#fff;border-radius:8px;padding:18px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #28a745}.shrine-header-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.shrine-name{color:#2c3e50;margin:0;font-weight:700;flex:1}.edit-shrine-btn{background-color:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap;display:flex;align-items:center;gap:4px}.edit-shrine-btn:hover{background-color:#218838}.edit-shrine-btn:active{background-color:#1e7e34}.shrine-address{color:#666;font-size:16px;margin:0 0 16px}.visit-summary{font-size:18px;font-weight:700;display:flex;flex-direction:column;gap:8px}.shrine-detail-page .visit-count{color:#2c3e50;background-color:#e7f3ff;padding:4px 8px;border-radius:6px;font-size:18px;display:inline-block;width:100%;text-align:center}.user-visit-count{color:#155724;background-color:#d4edda;padding:4px 8px;border-radius:6px;font-size:18px;display:inline-block;width:100%;text-align:center}.shrine-actions{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.delete-shrine-btn{background-color:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.delete-shrine-btn:hover{background-color:#c82333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.delete-confirm-modal{background:#fff;border-radius:12px;padding:32px;max-width:500px;width:100%;box-shadow:0 10px 40px #0003;text-align:left}.delete-confirm-modal h3{color:#dc3545;margin:0 0 16px;font-size:20px;font-weight:700}.delete-confirm-modal p{color:#2c3e50;margin:0 0 16px;line-height:1.5}.delete-confirm-modal ul{color:#666;margin:0 0 24px;padding-left:20px}.delete-confirm-modal li{margin:8px 0}.delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-btn{background-color:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;transition:background-color .2s}.cancel-btn:hover{background-color:#5a6268}.confirm-delete-btn{background-color:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;transition:background-color .2s}.confirm-delete-btn:hover{background-color:#c82333}.visits-section{margin-top:25px}.visits-section h3{color:#2c3e50;font-size:1.5em;margin-bottom:15px;padding-bottom:6px;border-bottom:2px solid #e0e0e0}.no-visits{text-align:center;padding:25px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#666}.visits-list{display:flex;flex-direction:column;gap:15px}.visit-card{background:#fff;border-radius:8px;padding:18px;box-shadow:0 2px 8px #00000014;border:1px solid #e0e0e0;transition:transform .2s,box-shadow .2s}.visit-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001f}.visit-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #f0f0f0;gap:12px}.visit-info{flex:1;display:flex;flex-direction:column;gap:4px}.visitor-name{font-weight:600;color:#2c3e50;font-size:1.1em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:.75em;font-weight:600;color:#fff;white-space:nowrap}.own-visit{color:#667eea;font-weight:500;font-size:.9em}.visit-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.visit-date{display:flex;flex-direction:column;gap:4px}.visit-date .date{font-size:18px;font-weight:700;color:#2c3e50}.visit-date .time{font-size:14px;color:#666}.visit-number{background-color:#e7f3ff;color:#06c;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700;display:inline-block;white-space:nowrap}.edit-visit-btn{background:none;border:1px solid #dee2e6;padding:4px 6px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;width:32px;height:32px;flex-shrink:0}.edit-visit-btn:hover{background:#f3e5f5;border-color:#9c27b0}.delete-visit-btn{background:none;border:1px solid #dee2e6;padding:4px 6px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;width:32px;height:32px;flex-shrink:0}.delete-visit-btn:hover{background:#ffebee;border-color:#f44336}.visit-memo{margin-bottom:15px}.visit-memo h4{color:#2c3e50;font-size:16px;margin:0 0 8px;display:flex;align-items:center;gap:8px}.visit-memo p{color:#555;line-height:1.6;margin:0;padding:12px;background-color:#f8f9fa;border-radius:8px;border-left:3px solid #28a745;text-align:left}.visit-photos{margin-bottom:12px}.visit-photos h4{color:#2c3e50;font-size:16px;margin:0 0 12px;display:flex;align-items:center;gap:8px}.photos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;max-width:400px}.photo-item{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:1;cursor:pointer;transition:transform .2s;max-width:150px;min-height:120px;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center}.photo-item:hover{transform:scale(1.02)}.visit-photo{width:100%;height:100%;object-fit:cover;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:block;background-color:#f8f9fa}.simple-visit{text-align:center;padding:12px}.simple-visit-text{color:#666;font-style:italic;margin:0}.loading,.error{text-align:center;padding:60px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:40px auto;max-width:500px}.loading h2,.error h2{color:#2c3e50;margin-bottom:15px}.loading p,.error p{color:#666;margin-bottom:25px}.back-btn{background-color:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;transition:background-color .2s}.back-btn:hover{background-color:#0056b3}@media (max-width: 768px){.shrine-detail-page{padding:12px 12px 100px;max-height:calc(100vh - 120px)}.shrine-detail-page .loading-spinner-container{min-height:calc(100vh - 200px);padding:30px 15px;margin:0;position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;background-color:#fffffffa}.shrine-detail-page .loading-spinner{gap:15px}.shrine-detail-page .loading-message{font-size:1.1em}.shrine-detail-page .loading-submessage{font-size:.9em}@media (prefers-color-scheme: dark){.shrine-detail-page .loading-spinner-container{background-color:#2c2c2cfa!important}}.shrine-info{padding:15px}.shrine-header-row{flex-direction:column;align-items:flex-start;gap:10px}.edit-shrine-btn{font-size:13px;padding:6px 12px}.visit-header{flex-direction:column;gap:12px;align-items:flex-start}.visit-actions{align-self:flex-end;flex-direction:row;align-items:center}.photos-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}@media (max-width: 480px){.shrine-detail-page{padding:12px 12px 120px;max-height:calc(100vh - 100px)}.shrine-detail-page .loading-spinner-container{min-height:calc(100vh - 180px);padding:20px 10px}.shrine-detail-page .loading-spinner{gap:12px}.shrine-detail-page .loading-message{font-size:1em}.shrine-detail-page .loading-submessage{font-size:.85em}@media (prefers-color-scheme: dark){.shrine-detail-page .loading-spinner-container{background-color:#2c2c2cfa!important}}.visit-card{padding:14px}.photos-grid{grid-template-columns:1fr 1fr;max-width:250px}}@media (prefers-color-scheme: dark){.shrine-detail-page{color:#ffffffde}.back-button{color:#4dabf7}.back-button:hover{background-color:#2c2c2c}.shrine-info,.visit-card,.loading,.error,.no-visits{background:#2c2c2c;color:#ffffffde;border-color:#444}.shrine-name,.visits-section h3,.visit-memo h4,.visit-photos h4,.loading h2,.error h2{color:#f0f0f0}.shrine-address,.visit-date .time,.loading p,.error p,.simple-visit-text{color:#d9d9d9}.visit-date .date{color:#f0f0f0}.visit-memo p{background-color:#1a1a1a;color:#ffffffde;text-align:left}.visits-section h3,.visit-header{border-bottom-color:#444}.visitor-name{color:#f0f0f0}.own-visit{color:#8ab4f8}.visit-number{background-color:#1a4480;color:#87ceeb}.edit-visit-btn{background:none;border-color:#4a5568;color:#ffffffde}.edit-visit-btn:hover{background:#553c9a;border-color:#7c3aed}.delete-visit-btn{background:none;border-color:#4a5568;color:#ffffffde}.delete-visit-btn:hover{background:#7f1d1d;border-color:#dc2626}.shrine-detail-page .visit-count{color:#f0f0f0;background-color:#1a4480}.user-visit-count{color:#e6ffed;background-color:#1e4d2b}.photo-item{background-color:#333}.visit-photo{background-color:#2c2c2c}.shrine-actions{border-top-color:#444}.delete-confirm-modal{background:#2c2c2c;color:#ffffffde}.delete-confirm-modal h3{color:#f87171}.delete-confirm-modal p{color:#d9d9d9}.delete-confirm-modal ul{color:#b3b3b3}.edit-shrine-btn{background-color:#2d6a3e;color:#ffffffe6}.edit-shrine-btn:hover{background-color:#25562f}.edit-shrine-btn:active{background-color:#1d4525}}.public-comments-section{margin-bottom:30px;background:#f8f9fa;border-radius:8px;padding:20px}.public-comments-section h3{margin-top:0;margin-bottom:20px;color:#333;font-size:1.3em}.no-comments{text-align:center;padding:30px;color:#666}.comments-list{display:flex;flex-direction:column;gap:15px}.comment-card{background:#fff;border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.commenter-info{font-weight:600;color:#333;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.own-comment{color:#28a745;font-size:.85em;margin-left:6px}.comment-date{font-size:.85em;color:#666}.comment-content{margin-bottom:12px;line-height:1.6}.comment-content p{margin:0;color:#333}.comment-actions{display:flex;gap:10px}.like-btn,.reply-btn{background:none;border:1px solid #ddd;border-radius:20px;padding:6px 12px;cursor:pointer;font-size:.9em;transition:all .2s;display:flex;align-items:center;gap:4px}.like-btn:hover,.reply-btn:hover{background:#f0f0f0;border-color:#bbb}.like-btn:active,.reply-btn:active{transform:scale(.95)}.like-btn.liked{background:#ffe0e0;border-color:#ff6b6b;color:#ff6b6b}@media (prefers-color-scheme: dark){.public-comments-section{background:#2c2c2c}.public-comments-section h3{color:#f0f0f0}.no-comments{color:#d9d9d9}.comment-card{background:#1a1a1a}.commenter-info{color:#f0f0f0}.comment-date{color:#b3b3b3}.comment-content p{color:#d9d9d9}.like-btn,.reply-btn{border-color:#444;color:#d9d9d9}.like-btn:hover,.reply-btn:hover{background:#333;border-color:#555}.like-btn.liked{background:#4d1f1f;border-color:#ff6b6b;color:#ff6b6b}}.password-reset-page{display:flex;justify-content:center;align-items:flex-start;padding-top:50px;min-height:calc(100vh - 150px);background-color:#f4f6f8}.reset-container{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 4px 15px #0000001a;width:100%;max-width:500px;text-align:center}.reset-container h1{margin-bottom:25px;color:#333;font-size:1.8em}.user-info{background-color:#e7f3ff;padding:15px;border-radius:5px;margin-bottom:25px;color:#06c;border-left:4px solid #0066cc}.reset-form{text-align:left}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#555;font-size:.9em}.form-group input{width:100%;padding:12px 15px;border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:1rem;background-color:#f8f9fa;color:#333}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 .1rem #007bff40;outline:none}.reset-button{width:100%;padding:12px;margin-bottom:15px;border:none;border-radius:5px;background-color:#007bff;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s ease}.reset-button:hover:not(:disabled){background-color:#0056b3;box-shadow:0 2px 8px #00000026}.reset-button:disabled{background-color:#ccc;cursor:not-allowed}.cancel-button{width:100%;padding:12px;background:none;border:2px solid #ddd;color:#666;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease}.cancel-button:hover{background-color:#f8f9fa;border-color:#ccc;color:#555}.login-button{width:100%;padding:12px;border:none;border-radius:5px;background-color:#007bff;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s ease;margin-top:20px}.login-button:hover{background-color:#0056b3;box-shadow:0 2px 8px #00000026}.error-message{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:15px;border-radius:5px;margin-bottom:20px;font-size:.9em;text-align:left}.success-message{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb;padding:30px;border-radius:5px;margin-bottom:20px}.success-message h2{color:#155724;margin-bottom:15px}.loading{padding:40px;color:#666}.loading h2{color:#333;margin-bottom:15px}.invalid-link{padding:30px;color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:5px}.invalid-link p{margin-bottom:20px}@media (prefers-color-scheme: dark){.password-reset-page{background-color:#1a1a1a}.reset-container{background-color:#2c2c2c;color:#ffffffde;box-shadow:0 4px 15px #0000004d}.reset-container h1{color:#f0f0f0}.user-info{background-color:#1a365d;color:#63b3ed;border-left-color:#63b3ed}.form-group label{color:#ccc}.form-group input{background-color:#1a1a1a;border-color:#555;color:#ffffffde}.form-group input:focus{border-color:#007bff;background-color:#1a1a1a}.form-group input::placeholder{color:#888}.cancel-button{border-color:#555;color:#ccc}.cancel-button:hover{background-color:#1a1a1a;border-color:#666;color:#fff}.error-message{color:#ff6b6b;background-color:#3d1a1a;border-color:#6b2c2c}.success-message{color:#4ade80;background-color:#1a3d1a;border-color:#2c6b2c}.success-message h2{color:#4ade80}.loading{color:#ccc}.loading h2{color:#f0f0f0}.invalid-link{color:#ff6b6b;background-color:#3d1a1a;border-color:#6b2c2c}}.announcement-page{padding:20px;max-width:800px;margin:0 auto;min-height:calc(100vh - 140px)}.page-header{text-align:center;margin-bottom:30px;padding:20px 0}.page-header h1{color:#ff6b35;font-size:2.2rem;margin-bottom:10px;font-weight:700}.subtitle{color:#666;font-size:1.1rem;margin-bottom:20px}.unread-summary{display:flex;align-items:center;justify-content:center;gap:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:10px;margin-top:20px}.unread-count{font-weight:700;font-size:1.1rem}.mark-all-read-btn{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.mark-all-read-btn:hover{background-color:#ffffff4d}.controls{margin-bottom:25px;display:flex;justify-content:center}.filter-controls{display:flex;align-items:center;gap:10px}.filter-controls label{font-weight:500;color:#333}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;font-size:1rem;background-color:#fff;cursor:pointer}.filter-select:focus{border-color:#ff6b35;outline:none;box-shadow:0 0 0 2px #ff6b3533}.login-required{text-align:center;padding:40px 20px}.login-prompt h3{color:#333;margin-bottom:15px;font-size:1.5rem}.login-prompt p{color:#666;line-height:1.6;margin-bottom:25px}.login-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.login-btn,.explore-btn{padding:12px 25px;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.login-btn.primary{background-color:#ff6b35;color:#fff}.login-btn.primary:hover{background-color:#e55a2b;transform:translateY(-2px)}.explore-btn{background-color:#f8f9fa;color:#333;border:1px solid #ddd}.explore-btn:hover{background-color:#e9ecef;transform:translateY(-2px)}.no-announcements{text-align:center;padding:60px 20px;color:#666}.no-announcements h2{color:#333;margin-bottom:15px}.no-announcements p{line-height:1.6;margin-bottom:25px}.start-btn{background-color:#28a745;color:#fff;padding:12px 25px;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.start-btn:hover{background-color:#218838;transform:translateY(-2px)}.announcements-list{display:flex;flex-direction:column;gap:15px}.announcement-card{background-color:#fff;border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.announcement-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#ff6b35}.announcement-card.unread{border-left:4px solid #ff6b35;background-color:#fff9f7}.announcement-header{display:flex;align-items:flex-start;gap:15px;margin-bottom:15px}.notification-icon{font-size:2rem;line-height:1;min-width:40px}.notification-content{flex-grow:1}.notification-title{font-size:1.2rem;font-weight:700;color:#333;margin:0 0 5px}.notification-date{font-size:.9rem;color:#666}.unread-indicator{background-color:#ff6b35;color:#fff;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:700;white-space:nowrap}.notification-message{color:#333;line-height:1.5;margin-bottom:12px;font-size:1rem}.shrine-info{margin-bottom:10px}.announcement-page .shrine-name{background-color:#f8f9fa;color:#495057;padding:6px 12px;border-radius:6px;font-size:.9rem;font-weight:500;display:inline-block}.action-hint{color:#6c757d;font-size:.85rem;font-style:italic;text-align:right;margin-top:10px}.loading{text-align:center;padding:60px 20px;color:#666}.loading h2{color:#333;margin-bottom:10px}@media (max-width: 768px){.announcement-page{padding:15px}.page-header h1{font-size:1.8rem}.announcement-header{gap:12px}.notification-icon{font-size:1.5rem;min-width:30px}.notification-title{font-size:1.1rem}.login-buttons{flex-direction:column;align-items:center}.login-btn,.explore-btn{width:100%;max-width:250px}}@media (prefers-color-scheme: dark){.announcement-page{background-color:#1a1a1a;color:#e9ecef}.page-header h1{color:#ff8a65}.subtitle{color:#adb5bd}.announcement-card{background-color:#2d3748;border-color:#4a5568;color:#e9ecef}.announcement-card:hover{border-color:#ff8a65}.announcement-card.unread{background-color:#2a1f1a;border-left-color:#ff8a65}.notification-title{color:#e9ecef}.notification-date{color:#adb5bd}.notification-message{color:#cbd5e0}.announcement-page .shrine-name{background-color:#4a5568;color:#e9ecef}.filter-select{background-color:#2d3748;border-color:#4a5568;color:#e9ecef}.filter-select:focus{border-color:#ff8a65;box-shadow:0 0 0 2px #ff8a6533}}.usage-guide-section{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 4px 6px #0000001a}.usage-guide-section h2{color:#2c3e50;font-size:2rem;margin-bottom:30px;text-align:center;font-weight:700}.feature-title{color:#667eea;font-size:1.5rem;margin-bottom:15px;font-weight:700}.feature-description{font-size:1.05rem;color:#34495e;line-height:1.6;margin-bottom:25px}.guide-content{margin-top:25px;margin-bottom:40px;padding:25px;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a}.guide-content:last-child{margin-bottom:0}.guide-content>p{font-size:1.1rem;color:#34495e;text-align:center;margin-bottom:25px}.guide-steps{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.step{display:flex;align-items:flex-start;gap:15px;background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 4px #0000001a}.step-number{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:1.2rem;border-radius:50%;flex-shrink:0}.step-content{flex:1}.step-content strong{display:block;color:#2c3e50;font-size:1.1rem;margin-bottom:5px}.step-content p{color:#7f8c8d;margin:0}.guide-tips{margin-top:20px;padding:15px 20px;background:#f8f9fa;border-left:4px solid #667eea;border-radius:6px}.guide-tips strong{color:#667eea;display:block;margin-bottom:10px;font-size:1.1rem}.guide-tips ul{list-style:none;padding:0;margin:0}.guide-tips li{color:#34495e;position:relative;padding:8px 0 8px 20px}.guide-tips li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700}.badge-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin:20px 0}.tier{padding:15px;background:linear-gradient(135deg,#f5f7fa,#e8eef5);border-radius:8px;text-align:center;font-size:1rem;color:#2c3e50;border:2px solid #e0e7ef;transition:transform .2s,box-shadow .2s}.tier:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.tier strong{display:block;margin-top:5px;color:#667eea}@media (prefers-color-scheme: dark){.usage-guide-section{background:linear-gradient(135deg,#2c3e50,#34495e)}.usage-guide-section h2{color:#ecf0f1}.feature-title{color:#8b9dff}.feature-description{color:#bdc3c7}.guide-content{background:#34495e}.guide-content>p{color:#bdc3c7}.step{background:#2c3e50;border:1px solid #4a5568}.step-content strong{color:#ecf0f1}.step-content p{color:#95a5a6}.guide-tips{background:#2c3e50;border-left-color:#8b9dff}.guide-tips strong{color:#8b9dff}.guide-tips li{color:#bdc3c7}.guide-tips li:before{color:#66bb6a}.tier{background:linear-gradient(135deg,#2c3e50,#34495e);border-color:#4a5568;color:#ecf0f1}.tier strong{color:#8b9dff}}.usage-guide-container{max-width:800px;margin:0 auto;padding:20px;background-color:#fff;min-height:100vh}.usage-guide-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.usage-guide-header h1{color:#333;font-size:28px;margin:0}.usage-guide-content{line-height:1.6}.guide-section{margin-bottom:40px;padding:25px;background-color:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.guide-section h2{color:#28a745;font-size:22px;margin:0 0 20px;display:flex;align-items:center;gap:8px}.guide-item{margin-bottom:25px}.guide-item:last-child{margin-bottom:0}.guide-item h3{color:#333;font-size:18px;margin:0 0 12px;font-weight:600}.guide-item ul,.guide-item ol{margin:0;padding-left:20px}.guide-item li{margin-bottom:8px;color:#555}.guide-item p{margin:12px 0;color:#555}.guide-note{background-color:#e7f3ff;border:1px solid #b8daff;border-radius:6px;padding:12px;margin:15px 0;color:#06c!important}.marker-example{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:8px;vertical-align:middle}.marker-example.green{background-color:#28a745}.marker-example.blue{background-color:#007bff}.marker-example.gold{background-color:gold}.usage-guide-footer{text-align:center;margin-top:40px;padding-top:30px;border-top:2px solid #e0e0e0}.back-button{background-color:#007bff;color:#fff;border:none;padding:15px 30px;font-size:18px;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:600}.back-button:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.back-button:active{transform:translateY(0)}@media (prefers-color-scheme: dark){.usage-guide-container{background-color:#1a1a1a;color:#ffffffde}.usage-guide-header{border-bottom-color:#444}.usage-guide-header h1{color:#f0f0f0}.guide-section{background-color:#2c2c2c;border-left-color:#4ade80}.guide-section h2{color:#4ade80}.guide-item h3{color:#f0f0f0}.guide-item li,.guide-item p{color:#ccc}.guide-note{background-color:#1a3d5c;border-color:#2a5a8a;color:#87ceeb!important}.usage-guide-footer{border-top-color:#444}.back-button{background-color:#0d6efd;color:#fff}.back-button:hover{background-color:#0b5ed7;box-shadow:0 4px 12px #0d6efd4d}}@media (max-width: 768px){.usage-guide-container{padding:15px}.usage-guide-header h1{font-size:24px}.guide-section{padding:20px 15px}.guide-section h2{font-size:20px}.guide-item h3{font-size:16px}.back-button{width:100%;padding:12px 20px;font-size:16px}}@media (max-width: 480px){.usage-guide-header{flex-direction:column;align-items:flex-start;gap:15px}.usage-guide-header .back-button{margin-right:0;align-self:flex-start}.usage-guide-header h1{font-size:22px}.guide-section{padding:15px}.guide-item ul,.guide-item ol{padding-left:15px}}.account-page{padding:20px 20px 80px;max-width:800px;margin:0 auto;min-height:calc(100vh - 200px);background:transparent}.page-header{text-align:center;margin-bottom:40px;position:relative}.close-btn{position:absolute;top:0;right:0;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:8px 12px;font-size:16px;cursor:pointer;transition:all .3s ease;color:#495057;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.close-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.page-header h1{color:#2c3e50;font-size:2.5em;margin-bottom:10px}.page-header .subtitle{color:#7f8c8d;font-size:1.1em;margin:0}.loading{text-align:center;padding:60px 20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:40px auto;max-width:500px}.account-content{display:flex;flex-direction:column;gap:30px}.profile-section{background:#fff;border-radius:15px;padding:30px;box-shadow:0 4px 15px #0000001a}.profile-header{display:flex;align-items:center;gap:20px;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f8f9fa}.avatar{font-size:4em;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 15px #667eea4d}.user-info{flex:1}.email{font-size:1.2em;font-weight:600;color:#2c3e50;margin-bottom:5px}.member-since{color:#7f8c8d;font-size:.9em}.profile-details{display:flex;flex-direction:column;gap:20px}.field-group{display:flex;flex-direction:column;gap:10px}.field-label{font-weight:600;color:#2c3e50;font-size:1.1em}.nickname-display{display:flex;align-items:center;gap:15px;padding:12px 16px;background:#f8f9fa;border-radius:8px;border:2px solid #e9ecef}.nickname-text{flex:1;font-size:1.1em;color:#495057}.edit-btn{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9em;cursor:pointer;transition:all .3s ease}.edit-btn:hover{background:#5a67d8;transform:translateY(-1px)}.nickname-edit{display:flex;flex-direction:column;gap:12px}.nickname-input{padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:1.1em;transition:border-color .3s ease}.nickname-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.nickname-actions{display:flex;gap:12px}.save-btn{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .3s ease;flex:1}.save-btn:hover:not(:disabled){background:#218838}.save-btn:disabled{background:#6c757d;cursor:not-allowed}.cancel-btn{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .3s ease;flex:1}.cancel-btn:hover:not(:disabled){background:#5a6268}.nickname-notice{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);padding:16px;border-radius:8px;border-left:4px solid #667eea}.nickname-notice p{margin:0 0 8px;color:#2c3e50;font-size:.9em;line-height:1.5}.nickname-notice p:last-child{margin-bottom:0}.account-actions{display:flex;flex-direction:column;gap:15px;margin-bottom:40px}.action-btn{padding:16px 24px;border:none;border-radius:12px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:8px}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.action-btn.secondary{background:#f8f9fa;color:#495057;border:2px solid #e9ecef}.action-btn.secondary:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.action-btn.danger{background:#dc3545;color:#fff;box-shadow:0 4px 15px #dc35454d}.action-btn.danger:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 6px 20px #dc354566}@media (max-width: 768px){.account-page{padding:15px 15px 100px;min-height:calc(100vh - 180px)}.page-header h1{font-size:2em}.profile-section{padding:20px}.profile-header{flex-direction:column;text-align:center;gap:15px}.avatar{font-size:3em;width:60px;height:60px}.nickname-actions{flex-direction:column}.action-btn{padding:14px 20px;font-size:1em}}@media (max-width: 480px){.account-page{padding:12px 12px 120px;min-height:calc(100vh - 160px)}.profile-section{padding:16px}}@media (prefers-color-scheme: dark){.account-page{color:#ffffffde}.page-header h1{color:#f0f0f0}.page-header .subtitle{color:#aaa}.loading,.profile-section{background:#2c2c2c;color:#ffffffde}.profile-header{border-bottom-color:#444}.email,.field-label{color:#f0f0f0}.member-since{color:#d9d9d9}.nickname-display{background:#1a1a1a;border-color:#444}.nickname-text{color:#d9d9d9}.nickname-input{background:#1a1a1a;color:#fff;border-color:#444}.nickname-input:focus{border-color:#8ab4f8}.nickname-notice{background:#2c2c2c;border-left-color:#8ab4f8}.nickname-notice p{color:#d9d9d9}.action-btn.secondary{background:#1a1a1a;color:#d9d9d9;border-color:#444}.action-btn.secondary:hover{background:#2c2c2c;border-color:#666}.close-btn{background:#1a1a1a;border-color:#444;color:#d9d9d9}.close-btn:hover{background:#2c2c2c;border-color:#666}}.badge-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;transition:all .2s ease}.badge-item:hover{background-color:#0000000d;transform:translateY(-2px)}.badge-icon{display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:700;flex-shrink:0;box-shadow:0 2px 8px #00000026}.badge-info{display:flex;flex-direction:column;gap:4px}.badge-name-text{font-weight:600;color:#333}.badge-description-text{font-size:.85em;color:#666;line-height:1.3}.badge-small .badge-icon{width:32px;height:32px;font-size:1.2em}.badge-small .badge-name-text{font-size:.9em}.badge-small .badge-description-text{font-size:.75em}.badge-medium .badge-icon{width:48px;height:48px;font-size:1.8em}.badge-medium .badge-name-text{font-size:1em}.badge-large .badge-icon{width:64px;height:64px;font-size:2.5em}.badge-large .badge-name-text{font-size:1.2em}.badge-large .badge-description-text{font-size:.95em}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;padding:20px 0}.badge-grid .badge-item{background-color:#f8f9fa;border:1px solid #e9ecef;padding:15px}.badge-locked{opacity:.4;filter:grayscale(100%)}.badge-locked:hover{opacity:.6}@media (max-width: 768px){.badge-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.badge-item{padding:6px}}@media (prefers-color-scheme: dark){.badge-item:hover{background-color:#ffffff1a}.badge-name-text{color:#f0f0f0}.badge-description-text{color:#ccc}.badge-grid .badge-item{background-color:#2c2c2c;border-color:#444}}.badges-page{max-width:1200px;margin:0 auto;padding:20px 20px 80px;min-height:100vh}.loading-message{text-align:center;padding:60px 20px;color:#666;font-size:1.2em}.badges-header{text-align:center;margin-bottom:30px}.badges-header h1{margin:0;font-size:2em;color:#333}.badge-selection-info{display:flex;gap:15px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);padding:20px;border-radius:12px;margin-bottom:25px;border-left:5px solid #2196F3;box-shadow:0 2px 8px #0000001a}.info-icon{font-size:2em;flex-shrink:0}.info-content{flex:1}.info-content strong{display:block;color:#1976d2;font-size:1.1em;margin-bottom:8px}.info-content p{margin:0;color:#424242;line-height:1.5}.badges-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stats-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;text-align:center;color:#fff;box-shadow:0 4px 12px #0000001a}.stats-number{font-size:2.5em;font-weight:700;margin-bottom:8px}.stats-label{font-size:1em;opacity:.95}.next-badge-section{background-color:#f8f9fa;padding:25px;border-radius:12px;margin-bottom:30px}.next-badge-section h3{margin:0 0 20px;font-size:1.5em;color:#333}.next-badge-card{background-color:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #0000001a}.progress-section{margin-top:20px}.progress-bar{width:100%;height:12px;background-color:#e9ecef;border-radius:6px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:6px}.progress-text{text-align:center;color:#666;font-size:.95em;font-weight:500}.badges-tabs{display:flex;gap:10px;margin-bottom:25px;border-bottom:2px solid #e9ecef;overflow-x:auto}.badges-tabs .tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1em;font-weight:500;color:#666;transition:all .2s;white-space:nowrap}.badges-tabs .tab:hover{color:#667eea}.badges-tabs .tab.active{color:#667eea;border-bottom-color:#667eea}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:30px}.badge-card{background-color:#fff;border:2px solid #e9ecef;border-radius:12px;padding:20px;transition:all .3s ease}.badge-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-4px)}.badge-card.badge-locked{opacity:.5;filter:grayscale(80%)}.badge-card.badge-locked:hover{opacity:.7;transform:translateY(-2px)}.earned-date{margin-top:12px;padding:6px 12px;background-color:#28a745;color:#fff;border-radius:20px;text-align:center;font-size:.85em;font-weight:600}.no-badges{text-align:center;padding:60px 20px;color:#999}.no-badges p{font-size:1.1em}@media (max-width: 768px){.badges-page{padding:15px 15px 80px}.badges-header{flex-direction:column;align-items:flex-start;gap:15px}.badges-header h1{font-size:1.6em}.badges-stats{grid-template-columns:1fr}.stats-number{font-size:2em}.badges-grid{grid-template-columns:1fr;gap:15px}.next-badge-section{padding:20px}}@media (prefers-color-scheme: dark){.badges-page{background-color:#1a1a1a;color:#ffffffde}.badges-header h1{color:#f0f0f0}.back-button{background-color:#2c2c2c;color:#fff}.back-button:hover{background-color:#3c3c3c}.next-badge-section{background-color:#2c2c2c}.next-badge-section h3{color:#f0f0f0}.next-badge-card{background-color:#1a1a1a}.progress-bar{background-color:#3c3c3c}.progress-text{color:#ccc}.badges-tabs{border-bottom-color:#444}.badges-tabs .tab{color:#ccc}.badges-tabs .tab:hover{color:#8ab4f8}.badges-tabs .tab.active{color:#8ab4f8;border-bottom-color:#8ab4f8}.badge-card{background-color:#2c2c2c;border-color:#444}.no-badges{color:#666}.badge-selection-info{background:linear-gradient(135deg,#1e3a5f,#2c5282);border-left-color:#4299e1}.info-content strong{color:#63b3ed}.info-content p{color:#cbd5e0}}.badge-card.badge-selected{border:3px solid #4CAF50;box-shadow:0 0 15px #4caf504d;transform:scale(1.02)}.earned-status{margin-top:12px;text-align:center;font-size:.9em}.selected-badge-label{color:#4caf50;font-weight:700;display:inline-flex;align-items:center;gap:4px}.select-badge-label{color:#999;font-size:.85em}.badge-card:hover .select-badge-label{color:#4caf50}@media (prefers-color-scheme: dark){.badge-card.badge-selected{border-color:#66bb6a;box-shadow:0 0 15px #66bb6a66}.selected-badge-label{color:#66bb6a}.select-badge-label{color:#666}.badge-card:hover .select-badge-label{color:#66bb6a}}.recent-checkins-page{padding:20px;max-width:900px;margin:0 auto;background-color:#f5f5f5}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.loading-container .spinner{border:3px solid #f3f3f3;border-top:3px solid #ff6b35;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{margin-top:16px;color:#666}.page-header{text-align:center;margin-bottom:24px}.page-header h1{margin:0;font-size:24px;color:#333;display:flex;align-items:center;justify-content:center;gap:8px}.page-header h1:before{content:"🦊"}.page-subtitle{margin:8px 0 0;font-size:14px;color:#666}.stats-summary{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.stat-card{flex:1;min-width:100px;background:linear-gradient(135deg,#fff,#fafafa);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #00000014;border:1px solid #eee}.stat-icon{font-size:28px}.stat-content{display:flex;flex-direction:column}.stat-number{font-size:22px;font-weight:700;color:#333;line-height:1.2}.stat-label{font-size:11px;color:#888}.checkins-container{max-height:calc(100vh - 380px);min-height:200px;overflow-y:auto;padding-right:4px;margin-bottom:16px}.checkins-container::-webkit-scrollbar{width:6px}.checkins-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.checkins-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.checkins-container::-webkit-scrollbar-thumb:hover{background:#bbb}.checkins-table{width:100%;border-collapse:collapse;font-size:14px;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #00000014}.checkins-table thead{background-color:#f5f5f5}.checkins-table th{padding:12px 10px;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #ddd;font-size:12px}.checkins-table td{padding:12px 10px;border-bottom:1px solid #eee;color:#333;vertical-align:top}.checkin-row{cursor:pointer;transition:background-color .2s ease}.checkin-row:hover{background-color:#fff8f5}.th-prefecture,.td-prefecture{width:70px;white-space:nowrap}.th-shrine,.td-shrine{max-width:300px}.td-shrine .shrine-name{font-weight:500;color:#333;margin:0;font-size:14px}.td-shrine .shrine-address-small{font-size:11px;color:#888;margin-top:4px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.th-date,.td-date{width:70px;white-space:nowrap;color:#666;font-size:13px}.th-link,.td-link{width:24px;text-align:center;padding-right:8px!important}.link-arrow{font-size:20px;color:#ccc;font-weight:700;transition:color .2s ease,transform .2s ease;display:inline-block}.checkin-row:hover .link-arrow{color:#ff6b35;transform:translate(2px)}.checkins-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000000f}.pagination-btn{padding:8px 16px;border:1px solid #ddd;background:#fff;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f5f5f5;border-color:#ccc}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:13px;color:#666}.checkin-card{background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;border-left:4px solid #ff6b35;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.checkin-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.checkin-card:active{transform:translateY(0)}.checkin-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:12px}.shrine-name{margin:0;font-size:16px;font-weight:700;color:#333;flex:1}.visit-date{font-size:12px;color:#888;white-space:nowrap}.shrine-address{margin:0 0 8px;font-size:12px;color:#666}.checkin-comment-text{margin:12px 0;font-size:14px;color:#444;line-height:1.6;background-color:#f9f9f9;padding:12px;border-radius:8px;border-left:3px solid #ddd}.checkin-photo-container{margin:12px 0;border-radius:8px;overflow:hidden}.checkin-photo{width:100%;max-height:300px;object-fit:cover;display:block}.checkin-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid #eee}.visitor-nickname{display:flex;align-items:center;gap:6px;font-size:13px;color:#666}.nickname-icon{font-size:14px}.view-detail-hint{font-size:11px;color:#999}.no-checkins{text-align:center;padding:60px 20px;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.no-checkins-icon{font-size:48px;display:block;margin-bottom:16px}.no-checkins p{margin:0;font-size:16px;color:#666}.no-checkins-hint{margin-top:8px!important;font-size:13px!important;color:#999!important}@media (max-width: 768px){.recent-checkins-page{padding:16px}.page-header h1{font-size:20px}.stats-summary{gap:8px}.stat-card{padding:12px;gap:8px}.stat-icon{font-size:24px}.stat-number{font-size:18px}.checkins-container{max-height:calc(100vh - 420px)}.checkin-card{padding:14px}.checkins-table{font-size:13px}.checkins-table th,.checkins-table td{padding:10px 8px}.th-prefecture,.td-prefecture{width:55px;font-size:12px}.td-shrine .shrine-name{font-size:13px}.td-shrine .shrine-address-small{font-size:10px;-webkit-line-clamp:1}.th-date,.td-date{width:55px;font-size:12px}.shrine-name{font-size:15px}.checkin-comment-text{font-size:13px;padding:10px}.pagination{gap:8px;padding:10px}.pagination-btn{padding:6px 12px;font-size:13px}.pagination-info{font-size:12px}}@media (prefers-color-scheme: dark){.recent-checkins-page{background-color:#121212}.page-header h1{color:#f0f0f0}.page-subtitle{color:#aaa}.stat-card{background:linear-gradient(135deg,#1e1e1e,#252525);border-color:#333}.stat-number{color:#f0f0f0}.stat-label{color:#aaa}.checkin-card{background-color:#1e1e1e}.checkins-table{background:#1e1e1e;box-shadow:0 2px 8px #0000004d}.checkins-table thead{background-color:#252525}.checkins-table th{color:#aaa;border-bottom-color:#444}.checkins-table td{border-bottom-color:#333;color:#ddd}.checkin-row:hover{background-color:#2a2a2a}.td-shrine .shrine-name{color:#f0f0f0}.td-shrine .shrine-address-small{color:#888}.checkins-table .td-prefecture{color:#ddd}.checkins-table .td-date{color:#aaa}.link-arrow{color:#888}.checkin-row:hover .link-arrow{color:#ff6b35}.shrine-name{color:#f0f0f0}.visit-date{color:#aaa}.shrine-address{color:#999}.checkin-comment-text{background-color:#252525;color:#ddd;border-left-color:#444}.checkin-card-footer{border-top-color:#333}.visitor-nickname{color:#aaa}.view-detail-hint{color:#666}.no-checkins{background-color:#1e1e1e}.no-checkins p{color:#aaa}.checkins-container::-webkit-scrollbar-track{background:#252525}.checkins-container::-webkit-scrollbar-thumb{background:#444}.checkins-container::-webkit-scrollbar-thumb:hover{background:#555}.pagination{background:#1e1e1e;box-shadow:0 1px 4px #0000004d}.pagination-btn{background:#252525;border-color:#444;color:#ddd}.pagination-btn:hover:not(:disabled){background:#333;border-color:#555}.pagination-info{color:#aaa}}.badge-notification-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.badge-notification-content{background:linear-gradient(135deg,#667eea,#764ba2);padding:40px;border-radius:20px;box-shadow:0 10px 40px #0000004d;max-width:400px;width:90%;text-align:center;animation:scaleIn .4s cubic-bezier(.68,-.55,.265,1.55);color:#fff}@keyframes scaleIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.badge-celebration{display:flex;justify-content:center;align-items:center;gap:15px;margin-bottom:25px}.badge-celebration h2{font-size:1.8em;margin:0;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.confetti{font-size:2.5em;animation:bounce .6s ease-in-out infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.badge-display{margin:30px 0}.badge-icon-large{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:4em;margin:0 auto 20px;box-shadow:0 8px 20px #0000004d;animation:pulse 1.5s ease-in-out infinite;background-color:#fff}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.badge-name{font-size:1.8em;font-weight:700;margin:15px 0 10px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.badge-description{font-size:1.1em;color:#fffffff2;margin:10px 0;line-height:1.5}.badge-close-button{background-color:#fff3;color:#fff;border:2px solid white;padding:12px 40px;border-radius:30px;font-size:1.1em;font-weight:600;cursor:pointer;margin-top:20px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge-close-button:hover{background-color:#fff;color:#667eea;transform:translateY(-2px);box-shadow:0 5px 15px #ffffff4d}@media (max-width: 768px){.badge-notification-content{padding:30px 20px}.badge-celebration h2{font-size:1.5em}.badge-icon-large{width:100px;height:100px;font-size:3em}.badge-name{font-size:1.5em}.badge-description{font-size:1em}}@media (prefers-color-scheme: dark){.badge-notification-overlay{background-color:#000000d9}}.nickname-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.nickname-prompt-modal{background-color:#fff;border-radius:16px;padding:28px;max-width:400px;width:100%;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.prompt-header{text-align:center;margin-bottom:16px}.prompt-icon{font-size:48px;display:block;margin-bottom:12px}.prompt-header h2{margin:0;font-size:20px;color:#333}.prompt-description{text-align:center;font-size:14px;color:#666;line-height:1.6;margin:0 0 20px}.nickname-form{display:flex;flex-direction:column;gap:16px}.input-group{position:relative}.nickname-input{width:100%;padding:14px 60px 14px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:10px;transition:border-color .2s ease;box-sizing:border-box}.nickname-input:focus{outline:none;border-color:#ff6b35}.char-count{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:12px;color:#999}.error-message{margin:0;font-size:13px;color:#dc3545;text-align:center}.button-group{display:flex;flex-direction:column;gap:10px}.btn-primary{padding:14px 20px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(135deg,#ff6b35,#ff8c5a);border:none;border-radius:10px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:12px 20px;font-size:14px;color:#666;background-color:transparent;border:1px solid #ddd;border-radius:10px;cursor:pointer;transition:background-color .2s ease}.btn-secondary:hover{background-color:#f5f5f5}.link-to-account{display:block;width:100%;margin-top:16px;padding:0;font-size:13px;color:#888;background:none;border:none;cursor:pointer;text-decoration:underline;text-align:center}.link-to-account:hover{color:#ff6b35}@media (max-width: 480px){.nickname-prompt-modal{padding:24px 20px}.prompt-icon{font-size:40px}.prompt-header h2{font-size:18px}.prompt-description{font-size:13px}.nickname-input{padding:12px 55px 12px 14px;font-size:15px}.btn-primary{padding:12px 16px;font-size:15px}.btn-secondary{padding:10px 16px;font-size:13px}}@media (prefers-color-scheme: dark){.nickname-prompt-modal{background-color:#1e1e1e}.prompt-header h2{color:#f0f0f0}.prompt-description{color:#aaa}.nickname-input{background-color:#2a2a2a;border-color:#444;color:#f0f0f0}.nickname-input:focus{border-color:#ff6b35}.char-count{color:#777}.btn-secondary{color:#aaa;border-color:#444}.btn-secondary:hover{background-color:#2a2a2a}.link-to-account{color:#888}}
