.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.header-actions .btn-category{padding:8px 14px;background:#4caf50;color:#fff;border-radius:6px;text-decoration:none;font-size:14px;transition:opacity .2s ease}.header-actions .btn-category:hover{opacity:.85}.category-nav{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}@media (max-width: 768px){.category-nav{overflow-x:auto;white-space:nowrap;padding-bottom:6px}}.category-chip{padding:6px 12px;border:1px solid #ccc;border-radius:999px;font-size:13px;text-decoration:none;color:#333;background:#f9f9f9;transition:background .2s ease,color .2s ease}.category-chip:hover{background:#4caf50;color:#fff}a{color:inherit}body{background-color:#fff5eb;font-family:Hiragino Kaku Gothic ProN,sans-serif}.post-list{display:grid;grid-template-columns:1fr;gap:1.4rem}.post-wrapper{max-width:520px;margin:1.5rem auto;background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 3px 10px #0000001a}.post-card{background:#fff;border-radius:16px;box-shadow:0 3px 10px #00000014;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.post-card:hover{transform:translateY(-3px);box-shadow:0 6px 18px #0000001f}.post-image{width:100%;height:180px;-o-object-fit:cover;object-fit:cover;background:#e5e7eb}.post-image.no-image{display:flex;align-items:center;justify-content:center;color:#777;font-size:.9rem}.post-body{padding:1rem;flex:1;display:flex;flex-direction:column}.post-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.4rem;font-size:.85rem;color:#666;margin-bottom:.6rem}.badge{padding:2px 8px;border-radius:6px;font-size:12px;font-weight:700;white-space:nowrap}.badge-draft{background:#f59e0b;color:#fff}.badge-published{background:#22c55e;color:#fff}.difficulty{font-size:.85rem;white-space:nowrap}.star{color:#fbbf24}.post-title{font-size:1.1rem;font-weight:700;color:#333;margin:.2rem 0 .5rem;line-height:1.4}.post-text{font-size:.9rem;color:#555;line-height:1.6;margin-bottom:1rem}.post-actions{margin-top:auto;display:flex;justify-content:flex-end;gap:.5rem}.post-actions a{text-decoration:none;font-size:.85rem;padding:.45rem .9rem;border-radius:8px;color:#fff;transition:opacity .2s ease}.post-actions a:hover{opacity:.85}.btn-detail{background:#9dc5e4}.btn-edit{background:#6366f1}.pagination-wrapper{margin-top:2rem;display:flex;justify-content:center}.pagination-wrapper nav{display:block}.pagination-wrapper ul.pagination{display:flex;gap:.3rem;padding-left:0;margin:0}.pagination-wrapper .page-item{list-style:none}.pagination-wrapper .page-link{min-width:36px;height:36px;padding:0 .6rem;border-radius:8px;border:1px solid #e5e7eb;color:#333;display:flex;align-items:center;justify-content:center;font-size:.85rem;text-decoration:none}.pagination-wrapper .page-item.active .page-link{background-color:#6366f1;color:#fff;border-color:#6366f1}.pagination-wrapper .page-item.disabled .page-link{color:#aaa;pointer-events:none;background:#f3f4f6}.no-posts{text-align:center;color:#666;margin-top:2rem}@media (min-width: 600px){.post-list{grid-template-columns:repeat(2,1fr)}}@media (min-width: 900px){.post-list{grid-template-columns:repeat(3,1fr)}}.category-wrapper{max-width:520px;margin:1.5rem auto;background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 3px 10px #0000001a}.category-wrapper h2{text-align:center;margin-bottom:1.2rem;color:#333}.category-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.8rem}.category-item a{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:#f9fafb;border-radius:12px;text-decoration:none;color:#333;font-size:.95rem;transition:background .2s ease,transform .2s ease}.category-item a:hover{background:#4caf50;color:#fff;transform:translate(3px)}.category-item .count{font-size:.8rem;color:#666}.category-item a:hover .count{color:#fff}body{background-color:#e6f4fa;font-family:Hiragino Kaku Gothic ProN,sans-serif;margin:0;padding:0}.post-wrapper{max-width:500px;margin:1.5rem auto;background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 3px 10px #0000001a}.post-wrapper h2{text-align:center;margin-bottom:1.2rem;color:#333}.user-info{display:flex;align-items:center;margin-bottom:1.5rem}.user-icon{width:50px;height:50px;border-radius:50%;-o-object-fit:cover;object-fit:cover;margin-right:10px}.username{font-weight:700;color:#333;flex:1}.rating{text-align:right;font-size:.9rem;color:#666}.stars{color:#f7b500}.like-count{margin-left:8px;color:#444}.form-group{margin-bottom:1.2rem}label{display:block;font-weight:700;margin-bottom:.3rem;color:#555}input[type=text],select,textarea{width:100%;padding:.7rem;border:1px solid #ccc;border-radius:8px;font-size:1rem;box-sizing:border-box}input[type=file]{border:none;background:#f0f0f0;padding:.5rem;border-radius:8px}.button-group{display:flex;justify-content:space-between;gap:8px}button{flex:1;padding:.8rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .3s}.btn-cancel{background:#ccc;color:#333}button:hover{opacity:.85}.image-upload{text-align:center;margin-top:.5rem}.image-upload input[type=file]{display:none}.btn-upload{display:inline-block;background-color:#007bff;color:#fff;padding:.8rem 2rem;border-radius:9999px;font-size:1rem;font-weight:700;text-align:center;cursor:pointer;transition:background-color .3s,transform .2s;border:none}.btn-upload:hover{background-color:#06d;transform:scale(1.03)}@media (max-width: 480px){.post-wrapper{margin:.5rem;padding:1rem}.user-icon{width:40px;height:40px}button{font-size:.9rem;padding:.6rem}}.stars{font-size:1.8rem;color:#fbbf24;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin:.3rem 0 .8rem}.star{display:inline-block;margin-right:4px;transition:transform .2s}.star:hover{transform:scale(1.2)}.photo-comment-block{margin-bottom:1.5rem;border:1px solid #ddd;padding:1rem;border-radius:12px;background:#f9f9f9}.photo-comment-block textarea{margin-top:.7rem;width:100%;border-radius:8px;border:1px solid #ccc;padding:.6rem}.post-wrapper .preview{display:flex!important;justify-content:center!important;align-items:center!important;width:100%;margin-top:.8rem;text-align:center}.post-wrapper .preview img{display:block;width:120px;height:120px;border-radius:50%;-o-object-fit:cover;object-fit:cover;box-shadow:0 2px 6px #00000026;margin:0 auto}.toggle-btn{display:inline-block;margin-top:.8rem;padding:.6rem 1.4rem;font-size:.9rem;font-weight:700;color:#007bff;background:#f2f8ff;border:1px solid #b3d4fc;border-radius:9999px;cursor:pointer;transition:all .25s ease}.toggle-btn:hover{background:#e6f0ff;transform:scale(1.03)}.toggle-btn:after{content:"▼";display:inline-block;margin-left:.3rem;transition:transform .25s ease}.toggle-btn.active:after{transform:rotate(180deg)}.badge-draft{background:#f59e0b;color:#fff;font-size:12px;padding:2px 8px;border-radius:6px;margin-right:8px}.preview-wrapper{position:relative;display:inline-block}.preview-image{max-width:100%;border-radius:8px}.btn-remove{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:14px;cursor:pointer;line-height:1}.btn-remove:hover{background:#dc2626d9}body{background-color:#e6f4fa;font-family:Hiragino Kaku Gothic ProN,sans-serif}*,*:before,*:after{box-sizing:border-box}.hidden{display:none!important}.user-info{display:flex;align-items:center;margin-bottom:1.4rem}.user-icon{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;margin-right:10px}.username{font-weight:700;color:#333}.form-group{margin-bottom:1.3rem}label{display:block;font-weight:700;margin-bottom:.4rem;color:#555}input[type=text],textarea{width:100%;padding:.7rem;border:1px solid #ccc;border-radius:8px;font-size:1rem}textarea{resize:vertical}.stars{font-size:1.8rem;color:#fbbf24;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.star{margin-right:4px}.checkbox-group{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;font-size:.95rem}.checkbox-group label{display:flex;align-items:center;gap:.3rem;white-space:nowrap}.checkbox-group{transition:max-height .3s ease;overflow:hidden}.checkbox-group.expanded{max-height:1000px}.checkbox-group.collapsed{max-height:300px}.photo-comment-block{border:1px solid #ddd;background:#f9f9f9;padding:1rem;border-radius:12px;margin-bottom:1.2rem}.image-upload{text-align:center}.btn-upload{display:inline-block;margin-bottom:.6rem;background:#007bff;color:#fff;padding:.7rem 1.6rem;border-radius:9999px;font-weight:700;cursor:pointer}.preview img{max-width:100%;border-radius:8px;margin-bottom:.6rem}.button-group{display:flex;gap:8px;margin-top:1.5rem}button{flex:1;padding:.8rem;border-radius:8px;border:none;font-weight:700;cursor:pointer}.btn-cancel{background:#ccc}.btn-draft{background:#9dc5e4;color:#fff}.btn-submit{background:#2ba84a;color:#fff}.btn-remove{position:absolute;top:6px;right:6px;background:#0009;color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer}body{background-color:#faede2;font-family:sans-serif}.login-container{max-width:400px;margin:50px auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.login-container h1{text-align:center;font-size:1.5rem;margin-bottom:1.5rem;color:#333}.form-group{margin-bottom:1rem}label{display:block;margin-bottom:.5rem;font-weight:700;color:#555}input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}button{width:100%;padding:.75rem;background:#f59e0b;border:none;border-radius:8px;font-size:1rem;font-weight:700;color:#fff;cursor:pointer;transition:background .3s}button:hover{background:#d97706}.links{text-align:center;margin-top:1rem}.links a{color:#2563eb;text-decoration:none}.links a:hover{text-decoration:underline}.register-container{max-width:450px;margin:50px auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.register-container h1{text-align:center;font-size:1.5rem;margin-bottom:1.5rem;color:#333}
