:root{font-family:Noto Sans JP,sans-serif;line-height:1.7;font-weight:400;color-scheme:light;color:#333;background-color:#f7ecd5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.font-noto-serif{font-family:"Noto Serif JP",serif}.font-zen-maru{font-family:Zen Maru Gothic,sans-serif}body{margin:0;min-width:320px;min-height:100vh;background-color:#f7ecd5;padding:0}#root{width:100%;max-width:100%;padding:0;min-height:100vh}.container{width:100%;max-width:800px;margin:0 auto;background-color:#f7ecd5;border:none;border-radius:8px;box-shadow:0 2px 20px #0000000d}.header{padding:1.25rem;border-bottom:1px solid #e8e2d9;background-color:#f7ecd5;border-radius:8px 8px 0 0}.header h3{margin:0;font-size:1.25rem;font-weight:400;text-align:center;color:#5c4c3c;letter-spacing:1px}.tab-navigation{display:flex;border-bottom:1px solid #e8e2d9;margin-bottom:0;background-color:#f7ecd5}.tab-item{padding:1rem 1.5rem;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s;color:#a99e8c;font-size:.95rem;letter-spacing:.5px}.tab-item.active{border-bottom:3px solid #71624f;font-weight:700;color:#5c4c3c}.tab-content{display:none;background-color:#f7ecd5}.tab-content.active{display:block}form{padding:2rem;background-color:#f7ecd5}.form-row{margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:1.2rem;padding:0 4px}.form-group{margin-bottom:1.5rem;flex:1 1 300px;padding:0 8px}.date-group{flex:0 1 200px}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#5c4c3c;font-size:.9rem}.required{color:#985e50;margin-left:.25rem}.form-group input[type=text],.form-group input[type=date],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:.9rem 1rem;border:1px solid #e8e2d9;border-radius:4px;font-size:.9rem;background-color:#fcfbfa;color:#333;transition:border-color .2s,box-shadow .2s;margin:8px 0;box-sizing:border-box}.form-group input[type=text]:focus,.form-group input[type=date]:focus,.form-group input[type=number]:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#a99e8c;box-shadow:0 0 0 3px #a99e8c1a}.taste-section{margin-bottom:1.5rem}.slider-group{margin-bottom:1.25rem}.slider-container{display:flex;align-items:center;margin-bottom:.5rem}.slider-label{width:80px;font-size:.85rem;color:#786b5e}.slider-label-left{text-align:left}.slider-label-right{text-align:right}input[type=range]{flex:1;margin:0 10px;height:5px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e8e2d9;border-radius:5px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:15px;height:15px;border-radius:50%;background:#71624f;cursor:pointer}input[type=range]::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:#71624f;cursor:pointer;border:none}.scale-labels{display:flex;justify-content:space-between;font-size:.85rem;color:#a99e8c}.flavor-section{margin-top:1rem}.flavor-options{display:flex;flex-wrap:wrap;margin-top:8px;background-color:#f7ecd5;border:1px solid #e8e2d9;border-radius:8px;padding:12px;box-shadow:inset 0 1px 3px #00000008}.flavor-section label{margin-bottom:8px;display:inline-block}.checkbox-group{display:flex;flex-wrap:wrap;gap:8px;width:100%}.checkbox-label{display:flex;align-items:center;margin-right:8px;margin-bottom:8px;padding:8px 14px;font-size:.85rem;color:#5c4c3c;background-color:#fff;border-radius:20px;border:1px solid #e8e2d9;cursor:pointer;transition:all .2s}.checkbox-label:hover{background-color:#efe9e1;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.checkbox-label input[type=checkbox]{margin-right:6px;position:relative;top:-1px}.checkbox-label input[type=checkbox]:checked+span{font-weight:600;color:#71624f}.checkbox-label input[type=checkbox]:checked{accent-color:#71624f}.checkbox-label:has(input[type=checkbox]:checked){background-color:#efe9e1;border-color:#d0c3b3;box-shadow:0 2px 4px #0000000d}.form-group input[type=number]{max-width:100px;text-align:center;font-size:1.1rem;font-weight:500}.form-buttons{display:flex;justify-content:space-between;margin-top:2rem;padding:0 8px}.btn-reset,.btn-submit{padding:.8rem 2rem;border:none;border-radius:4px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.btn-reset{background-color:#f2ede7;color:#5c4c3c;flex:0 0 auto;margin-right:1rem}.btn-submit{background-color:#8b5e3c;color:#fff;flex:1 1 auto}.btn-reset:hover{background-color:#e8e2d9;transform:translateY(-1px)}.btn-submit:hover{background-color:#6b482e;transform:translateY(-1px)}.btn-submit:disabled{background-color:#b3a99e;cursor:not-allowed}.image-upload-group{margin-bottom:20px}.image-upload-container{display:flex;flex-direction:column}.image-input{margin-bottom:10px}.image-preview-wrapper{width:100%;min-height:160px;border:2px dashed #e8e2d9;border-radius:8px;overflow:hidden;position:relative;background-color:#fcfbfa}.image-placeholder{width:100%;height:160px;display:flex;align-items:center;justify-content:center;color:#a99e8c;font-size:14px}.image-preview{width:100%;position:relative}.image-preview img{width:100%;max-height:300px;object-fit:contain;display:block}.remove-image-btn{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:50%;background-color:#5c4c3cb3;color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.remove-image-btn:hover{background-color:#5c4c3ce6}.coffee-list-container{padding:20px;max-width:1200px;margin:0 auto}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-header h2{color:#5c4c3c;font-weight:400;font-size:1.5rem;margin:0}.refresh-button{background-color:#8b5e3c;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .2s;font-size:.9rem}.refresh-button:hover{background-color:#6b482e}.loading,.error-message,.no-data{text-align:center;padding:30px;font-size:18px;color:#a99e8c}.error-message{color:#985e50}.coffee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.coffee-card{background-color:#f7ecd5;border-radius:8px;box-shadow:0 2px 10px #0000000d;overflow:hidden;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.coffee-card:hover{transform:translateY(-5px);box-shadow:0 5px 15px #0000001a}.coffee-card-header{padding:15px 20px;background-color:#f7ecd5;border-bottom:1px solid #e8e2d9;display:flex;justify-content:space-between;align-items:center}.coffee-card-header h3{margin:0;font-size:18px;color:#5c4c3c;font-weight:400}.coffee-rating{display:flex}.star{font-size:18px;margin-left:2px}.star.filled{color:#d0a97e}.star.half-filled{position:relative;color:#e8e2d9}.star.half-filled:before{content:"★";position:absolute;color:#d0a97e;width:50%;overflow:hidden}.star.empty{color:#e8e2d9}.coffee-details{padding:18px 20px}.coffee-detail-item{margin-bottom:8px;display:flex}.coffee-detail-item .label{font-weight:700;width:80px;color:#786b5e;margin-right:12px;flex-shrink:0}.coffee-detail-item span:last-child{color:#000}.coffee-flavor-tags{display:flex;flex-wrap:wrap;margin:15px 0;gap:8px}.flavor-tag{background-color:#71624f;color:#fff;padding:4px 12px;border-radius:16px;font-size:12px;margin-right:0;box-shadow:0 1px 3px #0000001a}.coffee-comment{margin-top:15px;padding-top:15px;border-top:1px dashed #e8e2d9}.coffee-comment p{margin:0;font-size:14px;color:#333;line-height:1.6;word-break:break-word}.coffee-image{width:100%;height:180px;background-color:#f7ecd5;overflow:hidden;position:relative}.coffee-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.coffee-image img:hover{transform:scale(1.05)}.no-image{display:flex;align-items:center;justify-content:center;height:100%;color:#a99e8c;font-size:12px;background-color:#f7ecd5}.image-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#50463ce6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.modal-content{position:relative;max-width:90%;max-height:90%;background-color:#fff;padding:5px;border-radius:8px;box-shadow:0 5px 15px #0000004d;cursor:default}.modal-content img{display:block;max-width:100%;max-height:80vh;object-fit:contain;border-radius:4px}.close-modal{position:absolute;top:-15px;right:-15px;width:30px;height:30px;background-color:#fff;border:1px solid #e8e2d9;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:#5c4c3c;box-shadow:0 2px 5px #0003}.close-modal:hover{background-color:#f0ece6}@media (max-width: 768px){.form-row{flex-direction:column}.form-group,.date-group{flex:1 1 100%}.checkbox-group{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.form-buttons{flex-direction:row;justify-content:space-between;gap:10px}.btn-reset,.btn-submit{width:48%}}@media (max-width: 480px){form{padding:1rem}.slider-container{flex-direction:row;align-items:center;justify-content:space-between;width:100%}.slider-label{width:60px;margin-bottom:0}input[type=range]{width:60%;margin:0 5px}.scale-labels{width:100%}}
