.navbar{position:fixed;top:0;left:0;right:0;background:var(--bg-primary);box-shadow:var(--shadow-md);height:64px;z-index:1000}.navbar-container{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg)}.navbar-logo{font-size:24px;font-weight:700;color:var(--primary-red);display:flex;align-items:center;gap:var(--spacing-md)}.navbar-subtitle{font-size:14px;font-weight:400;color:var(--text-secondary);display:none}.navbar-tags-row-mobile{display:none;gap:6px;margin-left:8px}.navbar-tag-link{border:none;background:var(--primary-red-bg);color:var(--primary-red);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500;cursor:pointer}.navbar-tag-link.active{background:var(--primary-red);color:#fff}@media (min-width: 769px){.navbar-subtitle{display:inline}.navbar-tags-row-mobile{display:none}}.navbar-mobile-toggle{display:none;background:none;border:none;font-size:24px;color:var(--text-primary);cursor:pointer;padding:var(--spacing-sm);line-height:1}.navbar-links{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-mobile-publish{display:none;background:var(--primary-red);color:#fff;border:none;border-radius:999px;padding:4px 12px;font-size:14px;font-weight:600;cursor:pointer}.navbar-link{color:var(--text-secondary);font-size:16px;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all .3s ease}.navbar-link:hover{color:var(--primary-red);background:var(--bg-hover)}.navbar-link.active{color:var(--primary-red);border-bottom:2px solid var(--primary-red)}.navbar-link-primary{background:var(--primary-red);color:var(--bg-primary);padding:var(--spacing-sm) var(--spacing-md)}.navbar-link-primary:hover{background:var(--primary-red-dark);color:var(--bg-primary)}.navbar-user{display:flex;align-items:center;gap:.75rem;margin-left:1rem}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-avatar-wrapper{position:relative;display:inline-block}.user-avatar-wrapper .user-avatar{display:flex;align-items:center;justify-content:center;background:#e0e0e0;color:#666;font-weight:600;font-size:14px}.user-avatar-wrapper .user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.username{color:#333;font-weight:500}.logout-button{background:transparent;border:1px solid #FF6B6B;color:#ff6b6b;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s}.logout-button:hover{background:#ff6b6b;color:#fff}@media (max-width: 768px){.navbar{height:48px}.navbar-container{padding:0 8px;position:relative;height:48px}.navbar-logo{font-size:16px;gap:4px}.navbar-subtitle{display:none}.navbar-tags-row-mobile{display:flex;flex:1;justify-content:flex-start;overflow-x:auto}.navbar-tag-link{font-size:10px;white-space:nowrap}.navbar-mobile-publish{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;background:var(--primary-red);color:#fff;border:none;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer}.navbar-mobile-toggle{display:block;z-index:1001;font-size:20px;padding:4px}.navbar-links,.navbar-links.mobile-open{display:none}.navbar-link{font-size:14px;padding:8px;text-align:left;border-radius:6px;margin-bottom:4px;display:block;width:100%}.navbar-link-primary{text-align:center;margin-top:4px;margin-bottom:4px}.navbar-user{flex-direction:column;align-items:stretch;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light);margin-left:0}.navbar-user .user-avatar{width:24px;height:24px;align-self:center}.navbar-user .user-avatar-wrapper{align-self:center}.navbar-user .username{text-align:center;font-size:12px}.notification-badge-mobile{position:absolute;top:-2px;right:-2px;background-color:#f44336;color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;border:1px solid white;z-index:10}.logout-button{width:100%;padding:8px;font-size:12px}}.star-rating{display:inline-flex;gap:2px;align-items:center}.star{font-size:14px;line-height:1;color:var(--gold);filter:grayscale(0);transition:transform .2s ease}.star-empty{filter:grayscale(1);opacity:.3}.star-rating.interactive .star{cursor:pointer}.star-rating.interactive .star:hover{transform:scale(1.1)}.image-gallery-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-in-out}.image-gallery-container{position:relative;width:90%;max-width:1200px;height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.image-gallery-close{position:absolute;top:20px;right:20px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);color:#fff;font-size:40px;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10001;transition:all .3s}.image-gallery-close:hover{background:#ff6b6bcc;border-color:#ff6b6be6;transform:scale(1.1);box-shadow:0 4px 12px #ff6b6b66}.image-gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);color:#fff;font-size:50px;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10001;transition:all .3s;-webkit-user-select:none;user-select:none}.image-gallery-nav:hover{background:#ff6b6bcc;border-color:#ff6b6be6;transform:translateY(-50%) scale(1.15);box-shadow:0 4px 12px #ff6b6b66}.image-gallery-prev{left:20px}.image-gallery-next{right:20px}.image-gallery-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#00000080;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;z-index:10001}.image-gallery-image-wrapper{width:100%;height:calc(90vh - 120px);display:flex;align-items:center;justify-content:center;overflow:hidden}.image-gallery-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;-webkit-user-select:none;user-select:none}.image-gallery-thumbnails{display:flex;gap:10px;padding:20px;overflow-x:auto;max-width:100%;justify-content:center}.image-gallery-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:8px;cursor:pointer;border:3px solid transparent;transition:all .2s;opacity:.6}.image-gallery-thumbnail:hover{opacity:1;transform:scale(1.1)}.image-gallery-thumbnail.active{border-color:#ff6b6b;opacity:1}@media (max-width: 768px){.image-gallery-container{width:100%;height:100vh}.image-gallery-image-wrapper{height:calc(100vh - 180px)}.image-gallery-nav{width:50px;height:50px;font-size:40px}.image-gallery-prev{left:10px}.image-gallery-next{right:10px}.image-gallery-thumbnail{width:60px;height:60px}}.comment-form{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.comment-input{width:100%;padding:var(--spacing-md);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:14px;font-family:inherit;color:var(--text-primary);resize:vertical;transition:border-color .3s ease}.comment-input:focus{border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b1a}.comment-form-images{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.comment-form-image{position:relative;width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-tertiary)}.comment-form-image img{width:100%;height:100%;object-fit:cover}.comment-form-image .remove-image{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:var(--radius-full);background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;cursor:pointer;border:none;transition:background .2s ease}.comment-form-image .remove-image:hover{background:#000c}.comment-form-actions{display:flex;justify-content:space-between;align-items:center}.image-upload-label{padding:var(--spacing-sm) var(--spacing-md);color:var(--primary-red);font-size:14px;cursor:pointer;border-radius:var(--radius-md);transition:background .3s ease}.image-upload-label:hover{background:var(--bg-hover)}.image-upload-label:has(input:disabled){opacity:.5;cursor:not-allowed}.submit-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-red);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:background .3s ease}.submit-button:hover:not(:disabled){background:var(--primary-red-dark)}@media (max-width: 768px){.comment-form{gap:var(--spacing-xs)}.comment-input{font-size:16px;padding:var(--spacing-md);min-height:80px}.comment-form-images{gap:var(--spacing-xs)}.comment-form-image{width:70px;height:70px}.comment-form-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.image-upload-label{width:100%;text-align:center;padding:var(--spacing-md);font-size:15px;min-height:44px;display:flex;align-items:center;justify-content:center}.submit-button{width:100%;padding:var(--spacing-md);font-size:15px;min-height:44px}}.comment-item{padding:var(--spacing-md);border-radius:var(--radius-md);background:var(--bg-secondary);margin-bottom:var(--spacing-sm)}.comment-header{margin-bottom:var(--spacing-xs)}.comment-author{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px;margin-bottom:var(--spacing-xs);cursor:pointer;transition:all .2s ease;padding:2px 4px;border-radius:var(--radius-sm);margin:-2px -4px;width:fit-content}.comment-author:hover{background:var(--bg-hover)}.comment-author:hover .comment-author-name{color:var(--primary-red)}.comment-author-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;transition:transform .2s ease}.comment-author:hover .comment-author-avatar{transform:scale(1.1)}.comment-author-name{font-weight:500;color:var(--text-primary);transition:color .2s ease}.comment-time{color:var(--text-tertiary);margin-left:var(--spacing-xs)}.comment-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.comment-text{color:var(--text-primary);font-size:14px;line-height:1.6;white-space:pre-wrap;margin:0}.comment-images{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-xs)}.comment-images img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;transition:transform .2s}.comment-image-clickable{cursor:pointer}.comment-images img:hover{transform:scale(1.05)}.comment-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xs)}.comment-action{background:none;border:none;color:var(--text-tertiary);font-size:12px;cursor:pointer;padding:var(--spacing-xs) 0;transition:color .3s ease}.comment-action:hover:not(:disabled){color:var(--primary-red)}.comment-action.liked{color:var(--primary-red)}.comment-action.delete-action:hover:not(:disabled){color:var(--error)}.comment-action:disabled{opacity:.5;cursor:not-allowed}.comment-reply-form{margin-top:var(--spacing-md);padding-left:var(--spacing-lg);border-left:2px solid var(--border-dark)}.comment-replies{margin-top:var(--spacing-md);padding-left:var(--spacing-lg);border-left:2px solid var(--border-light);display:flex;flex-direction:column;gap:var(--spacing-sm)}@media (max-width: 768px){.comment-item{padding:var(--spacing-sm)}.comment-author{font-size:12px}.comment-author-avatar{width:18px;height:18px}.comment-text{font-size:13px;line-height:1.6}.comment-images{gap:var(--spacing-xs)}.comment-images img{width:70px;height:70px}.comment-actions{gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.comment-action{font-size:13px;padding:var(--spacing-xs);min-height:32px}.comment-reply-form,.comment-replies{padding-left:var(--spacing-sm);margin-top:var(--spacing-sm)}}.comment-list{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.comment-list-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.empty-comments{text-align:center;padding:var(--spacing-xl);color:var(--text-tertiary);font-size:14px}.comments{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 768px){.comment-list{padding:var(--spacing-lg)}}.map-navigation{margin:var(--spacing-md) 0;padding:var(--spacing-md);background:var(--bg-primary);border:2px solid var(--border-medium);border-radius:var(--radius-lg)}.map-navigation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.map-navigation-title{display:flex;align-items:center;gap:var(--spacing-sm)}.map-icon{font-size:1.2rem}.map-label{font-size:.95rem;font-weight:600;color:var(--text-primary)}.map-navigation-btn{padding:var(--spacing-sm) var(--spacing-md);background:#f60;color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap}.map-navigation-btn:hover{background:#ff8533;transform:translateY(-1px);box-shadow:0 2px 8px #ff66004d}.map-navigation-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.map-address-display{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md)}.map-address-text{flex:1;font-size:.95rem;color:var(--text-primary);line-height:1.5;word-break:break-all}.map-address-toggle{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;color:var(--primary-red);border:1px solid var(--primary-red);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap}.map-address-toggle:hover{background:var(--primary-red-bg)}.map-coords{font-size:.85rem;color:var(--text-tertiary);font-family:monospace;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-sm)}.map-navigation-modes{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;padding-top:var(--spacing-sm);border-top:1px solid var(--border-light)}.map-mode-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.map-mode-buttons{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.map-mode-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s}.map-mode-btn:hover{background:var(--primary-red-bg);border-color:var(--primary-red);color:var(--primary-red)}.map-mode-btn.active{background:var(--primary-red);border-color:var(--primary-red);color:#fff}@media (max-width: 768px){.map-navigation-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.map-navigation-btn{width:100%}.map-navigation-modes{flex-direction:column;align-items:flex-start}.map-mode-buttons{width:100%}.map-mode-btn{flex:1;min-width:60px}}.report-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:10000;padding:20px}.report-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.report-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.report-modal-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.report-modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.report-modal-close:hover{background-color:#f5f5f5;color:#666}.report-modal-form{padding:24px}.report-modal-section{margin-bottom:24px}.report-modal-label{display:block;margin-bottom:12px;font-size:14px;font-weight:500;color:#333}.report-reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.report-reason-option{display:flex;align-items:center;padding:12px;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s}.report-reason-option:hover{border-color:#999;background-color:#f9f9f9}.report-reason-option input[type=radio]{margin-right:8px;cursor:pointer}.report-reason-option input[type=radio]:checked+span{color:#007bff;font-weight:500}.report-reason-option:has(input[type=radio]:checked){border-color:#007bff;background-color:#f0f7ff}.report-modal-textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:100px}.report-modal-textarea:focus{outline:none;border-color:#007bff}.report-modal-char-count{text-align:right;font-size:12px;color:#999;margin-top:4px}.report-modal-error{color:#dc3545;font-size:14px;margin-bottom:16px;padding:8px 12px;background-color:#fff5f5;border-radius:4px}.report-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.report-modal-cancel,.report-modal-submit{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.report-modal-cancel{background-color:#f5f5f5;color:#666}.report-modal-cancel:hover{background-color:#e8e8e8}.report-modal-submit{background-color:#007bff;color:#fff}.report-modal-submit:hover:not(:disabled){background-color:#0056b3}.report-modal-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.report-modal{max-width:100%;margin:10px}.report-reasons{grid-template-columns:1fr}.report-modal-actions{flex-direction:column-reverse}.report-modal-cancel,.report-modal-submit{width:100%}}.post-detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto;animation:fadeIn .3s ease}.post-detail-modal{position:relative;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;margin:auto}@keyframes slideUp{0%{opacity:0}to{opacity:1}}.modal-close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:24px;line-height:1;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:background .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0;transform:translateZ(0);will-change:auto;opacity:1}.modal-close-btn:hover{background:#000000b3}.modal-close-btn:active{transform:scale(.95)}.post-detail-modal-content{padding:0}.post-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-tertiary)}.cancel-rating-btn{background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-secondary);font-size:12px;padding:4px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;margin-left:var(--spacing-xs);white-space:nowrap;position:relative;z-index:1;pointer-events:auto}.cancel-rating-btn:hover{background:var(--bg-primary);border-color:var(--border-medium);color:var(--text-primary)}.cancel-rating-btn:active{transform:scale(.95)}.post-info{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.post-actions{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-light);flex-wrap:wrap}@media (max-width: 768px){.post-detail-modal-overlay{padding:0;align-items:flex-end}.post-detail-modal{max-width:100%;max-height:80vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUpMobile .3s ease}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-close-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;font-size:20px;background:#0009;transform:translateZ(0);will-change:auto;opacity:1}.post-images{grid-template-columns:1fr;padding:var(--spacing-xs);gap:var(--spacing-xs)}.post-images img{height:250px;border-radius:var(--radius-md)}.post-header{padding:var(--spacing-md)}.post-header h1{font-size:20px;line-height:1.4}.post-author{font-size:13px;flex-wrap:wrap}.post-rating-section{gap:var(--spacing-sm)}.post-rating{flex-wrap:wrap}.rating-text{font-size:16px}.user-rating-section{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);padding-top:var(--spacing-sm)}.user-rating-label{font-size:13px}.user-rating-stars{gap:2px}.rating-star-btn{font-size:20px;padding:var(--spacing-xs)}.cancel-rating-btn{margin-left:0;margin-top:var(--spacing-xs);align-self:flex-start}.post-body{padding:var(--spacing-md)}.post-content{font-size:15px;line-height:1.7;margin-bottom:var(--spacing-md)}.post-tags{gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.post-tags .tag{font-size:12px;padding:var(--spacing-xs) var(--spacing-sm)}.post-tags .tag.tag-ai{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.post-info{padding:var(--spacing-sm);gap:var(--spacing-xs)}.info-item{font-size:13px}.post-actions{flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md)}.action-button{flex:1;min-width:calc(50% - var(--spacing-xs));padding:var(--spacing-md);font-size:14px;text-align:center}.delete-button{width:100%;margin-top:var(--spacing-xs)}}.user-detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.user-detail-modal{position:relative;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;margin:auto}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-btn{position:fixed;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:24px;line-height:1;cursor:pointer;z-index:1002;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-close-btn:hover{background:#000000b3;transform:scale(1.1)}.user-detail-modal-content{padding:var(--spacing-xl)}.user-detail-header{display:flex;align-items:flex-start;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light);position:relative}.user-detail-avatar-section{flex-shrink:0}.user-detail-avatar,.user-detail-avatar-placeholder{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-red)}.user-detail-avatar-placeholder{background:var(--primary-red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700}.user-detail-info{flex:1}.user-detail-actions{flex-shrink:0;display:flex;align-items:flex-start;padding-top:var(--spacing-xs)}.user-detail-name-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.user-detail-username{font-size:28px;font-weight:700;color:var(--text-primary);margin:0}.user-detail-level{font-size:18px;color:var(--primary-red);font-weight:600}.user-detail-bio{font-size:16px;color:var(--text-secondary);margin:var(--spacing-sm) 0}.user-detail-stats{display:flex;gap:var(--spacing-xl);margin-top:var(--spacing-md);flex-wrap:wrap}.user-stat-item{display:flex;flex-direction:column;align-items:flex-start}.user-stat-item .stat-value{font-size:20px;font-weight:700;color:var(--primary-red)}.user-stat-item .stat-label{font-size:14px;color:var(--text-secondary)}.user-follow-btn{padding:10px 24px;border-radius:20px;border:2px solid var(--primary-red);background:linear-gradient(135deg,var(--primary-red) 0%,#ff6b6b 100%);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative;overflow:hidden;box-shadow:0 2px 8px #f4433633}.user-follow-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.user-follow-btn:hover:not(:disabled):before{width:300px;height:300px}.user-follow-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-red-dark) 0%,#ff5252 100%);border-color:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 6px 16px #f4433666}.user-follow-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #f4433633}.user-follow-btn.following{background:#fff;color:var(--primary-red);border-color:var(--primary-red);box-shadow:0 2px 8px #f4433626}.user-follow-btn.following:before{background:#f443361a}.user-follow-btn.following:hover:not(:disabled){background:var(--bg-hover);border-color:var(--primary-red-dark);color:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 6px 16px #f4433640}.user-follow-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.user-detail-tabs{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-light)}.user-detail-tab{padding:var(--spacing-md) var(--spacing-lg);border:none;background:transparent;color:var(--text-secondary);font-size:16px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .3s ease}.user-detail-tab:hover{color:var(--text-primary)}.user-detail-tab.active{color:var(--primary-red);border-bottom-color:var(--primary-red)}.user-detail-content{min-height:200px}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.empty-state{text-align:center;padding:var(--spacing-2xl)}@media (max-width: 768px){.user-detail-modal-overlay{padding:0;align-items:flex-end}.user-detail-modal{max-width:100%;max-height:80vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUpMobile .3s ease}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-close-btn{top:12px;right:12px;width:32px;height:32px;font-size:20px}.user-detail-modal-content{padding:var(--spacing-md)}.user-detail-header{flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.user-detail-actions{width:100%;margin-top:var(--spacing-md);display:flex;justify-content:center}.user-follow-btn{width:100%;max-width:200px}.user-detail-avatar,.user-detail-avatar-placeholder{width:60px;height:60px;font-size:24px}.user-detail-username{font-size:20px}.user-detail-level,.user-detail-bio{font-size:14px}.user-detail-stats{flex-direction:column;gap:var(--spacing-sm);width:100%}.user-stat-item{flex-direction:row;justify-content:space-between;width:100%}.user-detail-tabs{gap:var(--spacing-xs)}.user-detail-tab{padding:var(--spacing-sm);font-size:13px;flex:1}.posts-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}}.post-card{display:flex;flex-direction:column;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:0;transition:all .3s ease;text-decoration:none;color:inherit;height:100%;cursor:pointer;width:100%;min-width:0;box-sizing:border-box}.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.post-card-image{width:100%;height:200px;min-height:200px;overflow:hidden;background:var(--bg-tertiary);position:relative;cursor:pointer;transition:transform .2s;display:flex;align-items:center;justify-content:center}.post-card-image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;z-index:1}.post-card-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:14px;background:var(--bg-secondary)}.post-card-image:hover{transform:scale(1.05)}.post-card-image img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}.post-card-image-count{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;z-index:10;pointer-events:none}.post-card-content{flex:1;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);min-height:0}.post-card-header{display:flex;flex-direction:column;gap:var(--spacing-xs)}.post-card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card-author{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;padding:2px 4px;border-radius:var(--radius-sm);margin:-2px -4px}.post-card-author:hover{background:var(--bg-hover);color:var(--primary-red)}.author-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;transition:transform .2s ease}.post-card-author:hover .author-avatar{transform:scale(1.1)}.author-name{font-weight:500;transition:color .2s ease}.post-card-rating{display:flex;align-items:center;gap:var(--spacing-sm)}.post-card-rating-text{color:var(--text-primary);font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}.rating-count{color:var(--text-secondary);font-size:13px;font-weight:400}.post-card-description{color:var(--text-secondary);font-size:13px;line-height:1.5;flex:1;margin:var(--spacing-xs) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:0}.post-card-metadata-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.post-card-metadata-tags-compact{display:flex;flex-wrap:nowrap;gap:4px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:var(--spacing-xs)}.post-card-metadata-tags-compact::-webkit-scrollbar{display:none}.post-card-metadata-tag{background:var(--primary-blue-bg);color:var(--primary-blue);padding:3px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;border:1px solid var(--primary-blue);white-space:nowrap;flex-shrink:0;line-height:1.4}.post-card-metadata-tag-school{background:#fff3e0;color:#e65100;border-color:#ff9800}.post-card-metadata-tag-campus{background:#e3f2fd;color:#1565c0;border-color:#2196f3}.post-card-metadata-tag-dining{background:#f3e5f5;color:#6a1b9a;border-color:#9c27b0}.post-card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs);width:100%}.post-card-tag{background:var(--primary-red-bg);color:var(--primary-red);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:500;min-width:60px;max-width:100px;text-align:center;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:0 0 auto;box-sizing:border-box}.post-card-tag-ai{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.post-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-light)}.post-card-meta{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.post-card-location,.post-card-time{color:var(--text-tertiary);font-size:12px}.post-card-stats{display:flex;gap:var(--spacing-md);color:var(--text-tertiary);font-size:12px}@media (min-width: 769px){.post-card-image{height:180px;min-height:180px}.post-card-title{font-size:16px;-webkit-line-clamp:2}.post-card-description{font-size:13px;-webkit-line-clamp:2}}@media (max-width: 768px){.post-card{height:100%}.post-card-image{height:120px;min-height:120px}.post-card-no-image{font-size:11px}.post-card-image-count{font-size:10px;padding:2px 6px;top:4px;right:4px}.post-card-content{padding:8px;gap:4px}.post-card-title{font-size:13px;-webkit-line-clamp:2;line-height:1.3}.post-card-author{font-size:10px}.author-avatar{width:14px;height:14px}.post-card-rating{gap:4px}.post-card-rating-text{font-size:12px}.rating-count{font-size:10px}.post-card-description{font-size:11px;-webkit-line-clamp:2;margin:0;line-height:1.4}.post-card-metadata-tags{gap:2px;margin-bottom:2px}.post-card-metadata-tag{font-size:9px;padding:2px 4px;min-width:40px;flex:0 0 auto;box-sizing:border-box}.post-card-tags{gap:2px;margin-top:0;width:100%}.post-card-tag{font-size:9px;padding:2px 4px;min-width:45px;max-width:70px;flex:0 0 auto;box-sizing:border-box}.post-card-footer{flex-direction:column;align-items:flex-start;gap:4px;margin-top:auto;padding-top:6px;border-top:1px solid var(--border-light)}.post-card-meta{font-size:9px;gap:6px;flex:1;min-width:0;width:100%}.post-card-location{font-size:9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.post-card-time{font-size:9px;flex-shrink:0}.post-card-stats{font-size:9px;gap:8px;flex-shrink:0;width:100%;justify-content:flex-start}}.mobile-search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-in-out}.mobile-search-modal{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--bg-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:1001;display:flex;flex-direction:column;animation:slideUp .3s ease-out;box-shadow:0 -4px 20px #00000026;width:100%}.mobile-search-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:2px solid var(--pink-border);flex-shrink:0}.mobile-search-modal-header h2{color:var(--pink-primary);font-weight:700;font-size:18px;margin:0}.mobile-search-close-btn{width:32px;height:32px;border-radius:50%;background:var(--bg-secondary);color:var(--text-primary);font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;border:none;padding:0}.mobile-search-close-btn:hover{background:var(--pink-border);transform:rotate(90deg)}.mobile-search-modal-content{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch;background:var(--bg-primary);border-radius:var(--radius-lg)}.mobile-search-modal-content .keyword-search{margin-bottom:12px;gap:4px;display:flex;align-items:center}.mobile-search-modal-content .keyword-input{font-size:11px;padding:6px 8px;flex:1;min-width:0;height:32px;line-height:20px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.mobile-search-modal-content .keyword-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26}.mobile-search-modal-content .search-btn{padding:6px 10px;font-size:11px;height:32px;line-height:20px;white-space:nowrap;flex-shrink:0;min-width:fit-content;box-sizing:border-box;background:var(--pink-primary);border-radius:var(--radius-md);box-shadow:0 2px 4px #ff6b6b33;transition:all .3s ease;margin-left:4px;color:#fff;border:none;cursor:pointer}.mobile-search-modal-content .search-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.mobile-search-modal-content .sort-section{gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--pink-border)}.mobile-search-modal-content .sort-taste-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;margin-bottom:0}.mobile-search-modal-content .sort-row{gap:4px;flex-wrap:wrap;display:flex;align-items:center}.mobile-search-modal-content .sort-toggle-btn{padding:6px 14px;font-size:11px;height:32px;line-height:20px;flex-shrink:0;min-width:fit-content;box-sizing:border-box;border-radius:var(--radius-full);background:var(--bg-primary);border:2px solid var(--pink-border);color:var(--text-primary);transition:all .3s ease;cursor:pointer}.mobile-search-modal-content .sort-toggle-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.mobile-search-modal-content .sort-toggle-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 6px #ff6b6b4d}.mobile-search-modal-content .price-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.mobile-search-modal-content .filter-label{font-size:11px;color:var(--text-primary);font-weight:500;white-space:nowrap;flex-shrink:0}.mobile-search-modal-content .price-filter-container{display:flex;align-items:center;gap:4px;flex:1}.mobile-search-modal-content .price-filter-input{flex:1;min-width:0;padding:6px 8px;font-size:11px;height:32px;line-height:20px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.mobile-search-modal-content .price-filter-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26}.mobile-search-modal-content .price-filter-separator,.mobile-search-modal-content .price-filter-unit{color:var(--text-secondary);font-size:11px;flex-shrink:0}.mobile-search-modal-content .filter-row{display:flex;gap:8px;margin-bottom:8px}.mobile-search-modal-content .filter-item-row{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.mobile-search-modal-content .filter-select{flex:1;min-width:0;padding:6px 28px 6px 8px;font-size:11px;height:32px;line-height:20px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .3s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23FF6B6B' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.mobile-search-modal-content .filter-select:hover{background-color:var(--pink-lighter);border-color:var(--pink-primary)}.mobile-search-modal-content .filter-select:focus{background-color:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26;outline:none}.mobile-search-modal-content .tags-filter-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--pink-border)}.mobile-search-modal-content .tags-filter-title{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.mobile-search-modal-content .tag-input-wrapper{display:flex;gap:4px;margin-bottom:8px}.mobile-search-modal-content .tag-input{flex:1;padding:6px 8px;font-size:11px;height:32px;line-height:20px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.mobile-search-modal-content .tag-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26;outline:none}.mobile-search-modal-content .tag-add-btn{padding:6px 12px;font-size:11px;height:32px;line-height:20px;white-space:nowrap;flex-shrink:0;box-sizing:border-box;background:var(--pink-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease}.mobile-search-modal-content .tag-add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.mobile-search-modal-content .tags-filter{display:flex;flex-wrap:wrap;gap:6px}.mobile-search-modal-content .tag-filter-btn{padding:4px 10px;font-size:10px;height:24px;line-height:16px;box-sizing:border-box;border-radius:var(--radius-full);background:var(--bg-secondary);border:1px solid var(--pink-border);color:var(--text-primary);cursor:pointer;transition:all .3s ease;white-space:nowrap}.mobile-search-modal-content .tag-filter-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);transform:translateY(-1px)}.mobile-search-modal-content .tag-filter-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 4px #ff6b6b4d}.mobile-search-modal-content .no-tags-hint{font-size:11px;color:var(--text-tertiary);text-align:center;padding:var(--spacing-md)}.mobile-search-modal-content .clear-search-btn,.mobile-search-modal-content .mobile-clear-btn{padding:6px 12px;font-size:11px;height:32px;line-height:20px;white-space:nowrap;box-sizing:border-box;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--pink-border);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;margin-bottom:12px;width:100%}.mobile-search-modal-content .clear-search-btn:hover,.mobile-search-modal-content .mobile-clear-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);color:var(--pink-primary)}@media (min-width: 769px){.mobile-search-overlay,.mobile-search-modal{display:none}}.ai-recommend-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-in-out}.ai-recommend-modal{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--bg-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:1001;display:flex;flex-direction:column;animation:slideUp .3s ease-out;box-shadow:0 -4px 20px #00000026}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ai-recommend-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:2px solid var(--pink-border);flex-shrink:0}.ai-recommend-header h2{color:var(--pink-primary);font-weight:700;font-size:18px;margin:0}.ai-recommend-close-btn{width:32px;height:32px;border-radius:50%;background:var(--bg-secondary);color:var(--text-primary);font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;border:none;padding:0}.ai-recommend-close-btn:hover{background:var(--pink-border);transform:rotate(90deg)}.ai-recommend-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md);-webkit-overflow-scrolling:touch;min-height:0}.ai-message{display:flex;flex-direction:column;gap:var(--spacing-xs);max-width:85%;animation:fadeIn .3s ease-in-out}.ai-message-user{align-self:flex-end;align-items:flex-end}.ai-message-assistant{align-self:flex-start;align-items:flex-start}.ai-message-content{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);font-size:14px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.ai-message-user .ai-message-content{background:var(--pink-primary);color:#fff;border-bottom-right-radius:4px}.ai-message-assistant .ai-message-content{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px;border:1px solid var(--pink-border)}.ai-apply-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--pink-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;align-self:flex-start;margin-top:var(--spacing-xs)}.ai-apply-btn:hover{background:var(--pink-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b4d}.ai-recommended-dishes{margin-top:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.ai-dishes-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.ai-dish-card{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--pink-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.ai-dish-card:hover{background:var(--pink-lighter);border-color:var(--pink-primary);transform:translate(4px)}.ai-dish-image{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.ai-dish-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-xs);min-width:0}.ai-dish-title{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-dish-rating{font-size:12px;color:var(--pink-primary);font-weight:500}.ai-recommend-input{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--pink-border);flex-shrink:0;background:var(--bg-primary)}.ai-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--pink-border);border-radius:var(--radius-md);font-size:14px;background:var(--bg-secondary);color:var(--text-primary);transition:all .3s ease}.ai-input:focus{outline:none;border-color:var(--pink-primary);background:var(--bg-primary);box-shadow:0 2px 8px #ff6b6b26}.ai-input:disabled{opacity:.6;cursor:not-allowed}.ai-send-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--pink-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ai-send-btn:hover:not(:disabled){background:var(--pink-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b4d}.ai-send-btn:disabled{opacity:.6;cursor:not-allowed}@media (min-width: 769px){.ai-recommend-modal{bottom:auto;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);max-height:80vh;width:500px;border-radius:var(--radius-xl);animation:fadeInScale .3s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.ai-message{max-width:75%}}.home{padding:var(--spacing-xl) 0}.home-header{text-align:center;margin-bottom:var(--spacing-xl)}.home-layout{display:flex;gap:var(--spacing-md);align-items:flex-start}.search-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-md);flex-shrink:0;width:320px;min-width:320px;max-width:320px;box-sizing:border-box;position:fixed;top:calc(64px + var(--spacing-xs));left:max(calc((100vw - 1200px) / 2 + var(--spacing-md)),var(--spacing-md));max-height:calc(100vh - 80px);overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;z-index:100}.posts-list-wrapper{flex:1;display:flex;flex-direction:column;min-width:0}.posts-list{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);min-width:0}.search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--pink-border)}.search-header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.search-header h2{color:var(--pink-primary);font-weight:700;font-size:16px;margin:0}.search-header-left,.search-header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.search-toggle-btn{background:none;border:none;color:var(--text-secondary);font-size:16px;cursor:pointer;padding:var(--spacing-xs);transition:color .3s;display:none}.search-toggle-btn:hover{color:var(--primary-red)}.search-content{display:block}@media (min-width: 769px){.home-layout{flex-direction:row}.posts-list-wrapper{margin-left:340px}.search-header{margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--pink-border)}.search-header h2{font-size:16px;font-weight:700;color:var(--pink-primary);margin:0}.clear-search-btn{padding:2px 6px;font-size:10px}.keyword-search{margin-bottom:12px;gap:4px;display:flex;align-items:center}.keyword-input{font-size:11px;padding:6px 8px;flex:1;min-width:0;height:32px;line-height:20px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.keyword-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26}.search-btn{padding:6px 10px;font-size:11px;height:32px;line-height:20px;white-space:nowrap;flex-shrink:0;min-width:fit-content;box-sizing:border-box;background:var(--pink-primary);border-radius:var(--radius-md);box-shadow:0 2px 4px #ff6b6b33;transition:all .3s ease;margin-left:4px}.search-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.sort-section{gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--pink-border)}.sort-taste-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;margin-bottom:0}.sort-row{gap:4px;flex-wrap:wrap;display:flex;align-items:center}.sort-toggle-btn{padding:6px 14px;font-size:11px;height:32px;line-height:20px;flex-shrink:0;min-width:fit-content;box-sizing:border-box;border-radius:var(--radius-full);background:var(--bg-primary);border:2px solid var(--pink-border);color:var(--text-primary);transition:all .3s ease}.sort-toggle-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.sort-toggle-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 6px #ff6b6b4d}.price-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.price-filter-container{flex:1;min-width:0;gap:2px;display:flex;align-items:center}.price-filter-input{font-size:10px;padding:6px 8px;height:32px;line-height:20px;width:60px;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.price-filter-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.price-filter-separator{font-size:10px;flex-shrink:0;padding:0 1px}.price-filter-unit{font-size:10px;flex-shrink:0}.filter-item-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.filter-label{font-size:11px;white-space:nowrap;flex-shrink:0;width:42px;color:var(--text-secondary);font-weight:500}.filter-select{padding:6px 28px 6px 8px;font-size:10px;height:32px;line-height:20px;flex:1;min-width:0;box-sizing:border-box;background:var(--pink-bg);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23FF6B6B' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.filter-select:hover{background:var(--pink-lighter);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.filter-select:focus{background:var(--bg-primary);border-color:var(--pink-primary);box-shadow:0 0 0 3px #ff6b6b26}.tags-filter-section{margin-top:12px;padding:12px;background:var(--pink-bg);border-radius:var(--radius-lg);border:1px solid var(--pink-border)}.tags-filter-title{font-size:14px;margin-bottom:10px;font-weight:700;color:var(--pink-primary);padding-bottom:6px}.selected-tags-section{margin-bottom:10px;padding:6px;background:var(--pink-lighter);border-radius:var(--radius-sm);border:1px solid var(--pink-border)}.selected-tags-label{font-size:10px;font-weight:600;color:var(--pink-primary);margin-bottom:4px}.selected-tags-list{display:flex;flex-wrap:wrap;gap:4px}.selected-tag{background:var(--pink-primary)!important;border-color:var(--pink-primary)!important;color:#fff!important;font-weight:600;padding:3px 8px;font-size:10px;cursor:pointer;border-radius:10px;line-height:1.4}.selected-tag:hover{background:var(--pink-primary-dark)!important;transform:translateY(-1px)}.tag-input-wrapper{gap:4px;margin-bottom:10px;display:flex;align-items:center}.tag-input{font-size:11px;padding:6px 8px;flex:1;min-width:0;height:32px;line-height:20px;box-sizing:border-box;background:var(--bg-primary);border:2px solid var(--pink-border);border-radius:var(--radius-md);transition:all .3s ease}.tag-input:focus{background:var(--bg-primary);border-color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b26}.tag-add-btn{padding:6px 10px;font-size:10px;height:32px;line-height:20px;white-space:nowrap;flex-shrink:0;min-width:fit-content;box-sizing:border-box;background:var(--pink-primary);border-radius:var(--radius-md);box-shadow:0 2px 4px #ff6b6b33;transition:all .3s ease;margin-left:4px}.tag-add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.tags-filter{gap:4px;max-height:none}.tag-filter-btn{font-size:9px;padding:3px 8px;height:22px;line-height:16px;border-radius:10px;box-sizing:border-box;white-space:nowrap;min-width:fit-content;transition:all .2s ease;font-weight:500}.tag-filter-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.tag-filter-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 6px #ff6b6b4d;transform:translateY(-1px);font-weight:600}.active-filters{gap:4px;padding-top:4px;font-size:10px;margin-top:4px}.active-tag{font-size:9px;padding:2px 4px}.remove-filter{width:10px;height:10px;font-size:9px}.search-content{display:block!important;max-height:none!important;opacity:1!important}.search-toggle-btn{display:none!important}.posts-list{grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}}.search-header h2{font-size:1.25rem;color:var(--text-primary);margin:0}.keyword-search{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.keyword-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--pink-border);border-radius:var(--radius-lg);font-size:1rem;transition:all .3s ease;background:var(--pink-bg);color:var(--text-primary)}.keyword-input:focus{outline:none;border-color:var(--pink-primary);box-shadow:0 0 0 3px #ff6b6b26;background:var(--bg-primary);transform:translateY(-1px)}.keyword-input::placeholder{color:var(--text-tertiary)}.search-btn{background:var(--pink-primary);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ff6b6b33}.search-btn:hover{background:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.search-btn:active{transform:translateY(0)}.sort-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.sort-row,.filter-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.category-filters-section{margin-bottom:var(--spacing-sm);border-top:1px solid var(--border-light);padding-top:var(--spacing-sm)}.category-filters-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;transition:color .3s;border-radius:var(--radius-sm)}.category-filters-toggle:hover{color:var(--primary-red);background:var(--bg-secondary)}.category-filters-toggle .toggle-icon{font-size:10px;opacity:.7}.category-filters-content{margin-top:var(--spacing-xs);padding-left:var(--spacing-xs);width:100%;box-sizing:border-box;overflow:hidden;animation:slideDown .3s ease-out}.advanced-filters-section{margin-bottom:var(--spacing-md);border-top:1px solid var(--border-light);padding-top:var(--spacing-sm)}.advanced-filters-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;transition:color .3s;border-radius:var(--radius-sm)}.advanced-filters-toggle:hover{color:var(--primary-red);background:var(--bg-secondary)}.advanced-filters-toggle .toggle-icon{font-size:10px;opacity:.7}.advanced-filters-content{margin-top:var(--spacing-xs);padding-left:var(--spacing-xs);width:100%;box-sizing:border-box;overflow:hidden;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.filter-item{display:flex;align-items:center;gap:var(--spacing-xs)}.sort-label{font-size:.95rem;color:var(--text-secondary);font-weight:500}.sort-btn{background:var(--bg-primary);border:2px solid var(--pink-border);color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.sort-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.sort-toggle-btn{background:var(--bg-primary);border-color:var(--pink-border);color:var(--text-primary)}.sort-toggle-btn:hover{background:var(--pink-lighter);border-color:var(--pink-primary);color:var(--pink-primary);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.sort-toggle-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 6px #ff6b6b4d}.filter-label{font-size:.85rem;color:var(--text-secondary);font-weight:500;margin-left:var(--spacing-sm);white-space:nowrap}.filter-select{background:var(--pink-bg);border:2px solid var(--pink-border);color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:70px;max-width:100px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23FF6B6B' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}.filter-select:hover{border-color:var(--pink-primary);background:var(--pink-lighter);transform:translateY(-1px);box-shadow:0 2px 4px #ff6b6b26}.filter-select:focus{outline:none;border-color:var(--pink-primary);box-shadow:0 0 0 3px #ff6b6b26;background:var(--bg-primary)}.filter-select option{background:var(--bg-primary);color:var(--text-primary)}.price-filter-container{display:flex;align-items:center;gap:var(--spacing-xs)}.price-filter-input{width:70px;padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--pink-border);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-primary);background:var(--pink-bg);transition:all .3s ease}.price-filter-input:focus{outline:none;border-color:var(--pink-primary);box-shadow:0 0 0 3px #ff6b6b26;background:var(--bg-primary);transform:translateY(-1px)}.price-filter-input::placeholder{color:var(--text-tertiary);font-size:.8rem}.price-filter-separator{color:var(--text-secondary);font-size:.9rem;font-weight:500}.price-filter-unit{color:var(--text-secondary);font-size:.85rem;margin-left:var(--spacing-xs)}.tags-filter-section{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--pink-bg);border-radius:var(--radius-md);border:1px solid var(--pink-border);transition:all .3s ease}.tags-filter-title{font-size:12px;color:var(--pink-primary);margin-bottom:var(--spacing-sm);font-weight:700;padding-bottom:4px;border-bottom:1px solid var(--pink-border)}.tag-input-wrapper{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.tag-input{flex:1;padding:6px 10px;border:1px solid var(--pink-border);border-radius:var(--radius-md);font-size:11px;transition:all .2s ease;background:var(--bg-primary);color:var(--text-primary);height:28px;line-height:16px}.tag-input:focus{outline:none;border-color:var(--pink-primary);box-shadow:0 0 0 2px #ff6b6b26;transform:translateY(-1px)}.tag-input::placeholder{color:var(--text-tertiary);font-size:11px}.tag-add-btn{background:var(--pink-primary);color:#fff;border:none;padding:6px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:11px;font-weight:600;transition:all .2s ease;white-space:nowrap;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #ff6b6b33;height:28px;line-height:16px}.tag-add-btn:hover{background:var(--primary-red-dark);transform:translateY(-1px);box-shadow:0 2px 6px #ff6b6b4d}.random-recommend-btn{padding:6px 12px;background:linear-gradient(135deg,#9c27b0,#ba68c8);color:#fff;border:none;border-radius:var(--radius-md);font-size:11px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.random-recommend-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #9c27b066}.random-recommend-btn:active{transform:translateY(0)}.mobile-random-btn{width:100%;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.location-btn{padding:6px 12px;background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;border:none;border-radius:var(--radius-md);font-size:11px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 6px #4caf504d}.location-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.location-btn:active{transform:translateY(0)}.mobile-location-btn{width:100%;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.ai-recommend-btn{padding:6px 12px;background:linear-gradient(135deg,var(--pink-primary) 0%,#FF8E8E 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:11px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 6px #ff6b6b4d}.ai-recommend-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.ai-recommend-btn:active{transform:translateY(0)}.mobile-ai-btn{width:100%;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.recommend-buttons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.recommend-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;background:var(--bg-primary);border:1px solid var(--pink-border);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;height:60px}.recommend-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #ff6b6b33;border-color:var(--pink-primary);background:var(--pink-bg)}.recommend-icon{font-size:20px;margin-bottom:4px;line-height:1}.recommend-text{font-size:11px;font-weight:500;color:var(--text-primary)}.clear-search-container{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.clear-search-btn-block{width:100%;padding:8px;background:var(--pink-light);background-color:#ffeaea;border:1px solid var(--pink-border);color:var(--pink-primary);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.clear-search-btn-block:hover{background:var(--pink-primary);color:#fff;box-shadow:0 2px 8px #ff6b6b4d}.recommend-buttons{display:none}.tags-filter{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--spacing-md)}.tag-filter-btn{background:var(--tag-pink);border:1px solid var(--pink-border);color:var(--pink-primary);padding:4px 10px;border-radius:12px;cursor:pointer;font-size:11px;font-weight:500;transition:all .2s ease;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;position:relative;overflow:hidden;line-height:1.4}.tag-filter-btn[data-tag-type=type]{background:var(--tag-pink);border-color:#ffb3b3;color:#d32f2f}.tag-filter-btn[data-tag-type=region]{background:var(--tag-green);border-color:#a5d6a7;color:#2e7d32}.tag-filter-btn[data-tag-type=taste]{background:var(--tag-yellow);border-color:#ffe082;color:#f57c00}.tag-filter-btn[data-tag-type=other]{background:var(--tag-blue);border-color:#90caf9;color:#1976d2}.tag-filter-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a;border-width:1px}.tag-filter-btn[data-tag-type=type]:hover{background:#ffd6d6;border-color:var(--pink-primary)}.tag-filter-btn[data-tag-type=region]:hover{background:#c8e6c9;border-color:#66bb6a}.tag-filter-btn[data-tag-type=taste]:hover{background:#fff59d;border-color:#ffc107}.tag-filter-btn[data-tag-type=other]:hover{background:#bbdefb;border-color:#42a5f5}.tag-filter-btn.active{background:var(--pink-primary);border-color:var(--pink-primary);color:#fff;box-shadow:0 2px 6px #ff6b6b4d;transform:translateY(-1px);font-weight:600}.tag-filter-btn.active:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shine .6s ease}@keyframes shine{to{left:100%}}.no-tags-hint{color:var(--text-secondary);font-size:.9rem;padding:var(--spacing-lg);text-align:center}.active-filters{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light);font-size:.9rem;color:var(--text-secondary)}.active-tag{background:var(--primary-red-bg);color:var(--primary-red);padding:var(--spacing-xs) var(--spacing-sm);border-radius:16px;display:inline-flex;align-items:center;gap:var(--spacing-xs)}.remove-filter{background:none;border:none;color:var(--primary-red);cursor:pointer;font-size:1.2rem;line-height:1;padding:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.remove-filter:hover{background:#ff6b6b33}.home-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.home-header p{font-size:16px;color:var(--text-secondary)}.loading,.error{text-align:center;padding:var(--spacing-2xl);font-size:16px;color:var(--text-secondary)}.empty-state{text-align:center;padding:var(--spacing-2xl);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.empty-state-icon{font-size:64px;margin-bottom:var(--spacing-md)}.empty-state-text{font-size:16px;color:var(--text-secondary)}.mobile-notification-fab{position:fixed;bottom:88px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--pink-primary);color:#fff;border:none;box-shadow:0 4px 12px #ff6b6b66;cursor:pointer;z-index:999;display:none;align-items:center;justify-content:center;transition:all .3s ease;padding:0}.mobile-notification-fab:hover{transform:scale(1.1);box-shadow:0 6px 16px #ff6b6b80}.mobile-notification-fab:active{transform:scale(.95)}.notification-fab-badge{position:absolute;top:-4px;right:-4px;background-color:#f44336;color:#fff;border-radius:12px;min-width:20px;height:20px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 6px;border:2px solid white;box-shadow:0 2px 4px #0003}.mobile-search-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--pink-primary);color:#fff;border:none;box-shadow:0 4px 12px #ff6b6b66;cursor:pointer;z-index:999;display:none;align-items:center;justify-content:center;transition:all .3s ease;padding:0}.mobile-search-fab:hover{transform:scale(1.1);box-shadow:0 6px 16px #ff6b6b80}.mobile-search-fab:active{transform:scale(.95)}.mobile-search-content{width:100%}.mobile-clear-btn{width:100%;margin-bottom:var(--spacing-md)}@media (max-width: 768px){.home{padding:8px 0}.search-section{display:none}.mobile-notification-fab,.mobile-search-fab{display:flex}.home-layout{flex-direction:column}.posts-list-wrapper,.posts-list{width:100%}.home-layout{flex-direction:column;gap:6px}.search-section{width:100%;position:static;padding:8px;margin:0 8px 6px}.posts-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 8px}.search-header{margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border-light)}.search-header h2{font-size:13px;color:var(--text-primary);margin:0;font-weight:600}.search-toggle-btn{display:block;font-size:12px;padding:2px 4px}.search-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.search-content.expanded{max-height:2000px;transition:max-height .3s ease-in}.keyword-search{display:flex;gap:4px;margin-bottom:6px;align-items:center}.keyword-input{flex:1;min-width:0;padding:0 8px;height:20px;line-height:20px;border:1px solid var(--border-medium);border-radius:10px;font-size:11px;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.keyword-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 2px #ff6b6b26}.search-btn{background:var(--primary-red);color:#fff;border:none;padding:0 8px;height:20px;line-height:20px;border-radius:10px;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;box-sizing:border-box}.search-btn:hover{background:var(--primary-red-dark)}.sort-section{display:flex;flex-direction:column;gap:6px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border-light)}.sort-taste-row{display:flex;align-items:center;gap:4px;flex-wrap:nowrap;margin-bottom:0}.sort-price-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.sort-row{display:flex;align-items:center;gap:4px;flex-shrink:0}.sort-toggle-btn{background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-secondary);padding:0 8px;height:20px;line-height:20px;border-radius:10px;cursor:pointer;font-size:11px;font-weight:500;box-sizing:border-box}.sort-toggle-btn:hover{background:var(--primary-red-bg);border-color:var(--primary-red);color:var(--primary-red)}.sort-toggle-btn.active{background:var(--primary-red);border-color:var(--primary-red);color:#fff}.price-row{display:flex;align-items:center;gap:4px;margin-bottom:0;flex:1;min-width:0}.price-filter-container{display:flex;align-items:center;gap:2px;flex:1;min-width:0}.price-filter-input{width:50px;padding:0 6px;height:20px;line-height:20px;border:1px solid var(--border-medium);border-radius:10px;font-size:11px;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.price-filter-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 2px #ff6b6b26}.price-filter-separator,.price-filter-unit{font-size:11px;flex-shrink:0}.filter-row{display:flex;align-items:center;gap:4px;margin-bottom:0;flex-wrap:nowrap}.filter-item-row{display:flex;align-items:center;gap:4px;flex:1;min-width:0;margin-bottom:0}.filter-label{font-size:11px;color:var(--text-secondary);font-weight:500;white-space:nowrap;flex-shrink:0;width:36px}.filter-select{background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-primary);padding:0 20px 0 6px;height:20px;line-height:20px;border-radius:10px;font-size:11px;font-weight:500;cursor:pointer;flex:1;min-width:0;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.filter-select:hover{border-color:var(--primary-red);background-color:var(--primary-red-bg)}.filter-select:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 2px #ff6b6b26}.tags-filter-section{margin-top:6px}.tags-filter-title{font-size:11px;color:var(--text-primary);margin-bottom:6px;font-weight:500}.tag-input-wrapper{display:flex;gap:4px;margin-bottom:6px;align-items:center}.tag-input{flex:1;min-width:0;padding:0 8px;height:20px;line-height:20px;border:1px solid var(--border-medium);border-radius:10px;font-size:11px;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.tag-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 2px #ff6b6b26}.tag-add-btn{background:var(--primary-red);color:#fff;border:none;padding:0 8px;height:10px;line-height:10px;border-radius:10px;cursor:pointer;font-size:11px;font-weight:500;white-space:nowrap;flex-shrink:0;box-sizing:border-box}.tag-add-btn:hover{background:var(--primary-red-dark)}.tags-filter{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.tag-filter-btn{background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-secondary);padding:0 6px;height:10px;line-height:10px;border-radius:10px;cursor:pointer;font-size:11px;font-weight:500;box-sizing:border-box}.tag-filter-btn:hover{background:var(--primary-red-bg);border-color:var(--primary-red);color:var(--primary-red)}.tag-filter-btn.active{background:var(--primary-red);border-color:var(--primary-red);color:#fff}.clear-search-btn{background:var(--primary-red);color:#fff;border:none;padding:0 6px;height:18px;line-height:18px;border-radius:8px;cursor:pointer;font-size:10px;box-sizing:border-box;white-space:nowrap}.clear-search-btn:hover{background:var(--primary-red-dark)}.active-filters{display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding-top:8px;border-top:1px solid var(--border-light);font-size:10px;color:var(--text-secondary)}.active-tag{background:var(--primary-red-bg);color:var(--primary-red);padding:2px 6px;border-radius:10px;display:inline-flex;align-items:center;gap:4px}.remove-filter{background:none;border:none;color:var(--primary-red);cursor:pointer;font-size:12px;line-height:1;padding:0;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%}.remove-filter:hover{background:#ff6b6b33}}.loading-state{text-align:center;padding:var(--spacing-2xl);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--pink-border);border-top-color:var(--pink-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--spacing-md)}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:16px;color:var(--text-secondary)}.skeleton-post-card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;height:100%}.skeleton-post-image{width:100%;height:200px;background:var(--bg-tertiary)}.skeleton-post-content{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-post-title{height:20px;width:70%;margin-bottom:var(--spacing-xs)}.skeleton-post-text{height:14px;width:100%}.skeleton-post-text.short{width:60%}@media (min-width: 769px){.skeleton-post-image{height:180px}}@media (max-width: 768px){.skeleton-post-image{height:120px}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.pagination-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--pink-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:90px}.pagination-btn:hover:not(:disabled){background:var(--pink-hover);transform:translateY(-1px);box-shadow:0 4px 8px #ff6b6b4d}.pagination-btn:active:not(:disabled){transform:translateY(0)}.pagination-btn:disabled{background:var(--pink-border);cursor:not-allowed;opacity:.6}.pagination-page-input-wrapper{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--bg-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--pink-border)}.pagination-page-input{width:50px;text-align:center;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;padding:var(--spacing-xs);outline:none}.pagination-page-input:focus{background:var(--bg-primary);border-radius:var(--radius-sm)}.pagination-page-separator{color:var(--text-secondary);font-size:14px;font-weight:500}.pagination-total-pages{color:var(--text-secondary);font-size:14px;font-weight:500;min-width:20px}@media (max-width: 768px){.pagination{gap:var(--spacing-sm);padding:var(--spacing-sm)}.pagination-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:13px;min-width:70px}.pagination-page-input{width:40px;font-size:13px}.pagination-page-separator,.pagination-total-pages{font-size:13px}}.post-detail{padding:var(--spacing-xl) 0}.back-button{background:none;color:var(--primary-red);font-size:16px;margin-bottom:var(--spacing-lg);padding:var(--spacing-sm) 0;cursor:pointer;transition:color .3s ease}.back-button:hover{color:var(--primary-red-dark)}.post-detail-content{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:var(--spacing-xl)}.post-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary)}.post-images img{width:100%;height:300px;object-fit:cover;border-radius:var(--radius-md);cursor:pointer;transition:transform .3s ease}.post-image-clickable{cursor:pointer}.post-images img:hover{transform:scale(1.02)}.post-header{padding:var(--spacing-xl);border-bottom:1px solid var(--border-light)}.post-title-section{margin-bottom:var(--spacing-md)}.post-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.post-author{display:flex;align-items:center;gap:var(--spacing-sm);font-size:14px;color:var(--text-secondary)}.post-author-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.post-author-name{font-weight:500;color:var(--text-primary)}.post-time{color:var(--text-tertiary);margin-left:var(--spacing-sm)}.post-rating-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.post-rating{display:flex;align-items:center;gap:var(--spacing-sm)}.rating-text{color:var(--text-primary);font-size:18px;font-weight:600;display:flex;align-items:center;gap:6px}.rating-count{color:var(--text-secondary);font-size:15px;font-weight:400}.user-rating-section{display:flex;align-items:center;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.user-rating-label{font-size:14px;color:var(--text-secondary)}.user-rating-stars{display:flex;gap:4px}.rating-star-btn{background:none;border:none;font-size:24px;color:var(--border-medium);cursor:pointer;transition:all .2s;padding:0;line-height:1}.rating-star-btn:hover{color:#ffd93d;transform:scale(1.2)}.rating-star-btn.active{color:#ffd93d}.post-body{padding:var(--spacing-xl)}.post-content{font-size:16px;line-height:1.8;color:var(--text-primary);margin-bottom:var(--spacing-lg);white-space:pre-wrap}.post-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.post-tags .tag{background:var(--primary-red-bg);color:var(--primary-red);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:14px;font-weight:500}.post-tags .tag.tag-ai{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.post-info{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.info-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:14px}.info-icon{font-size:18px}.post-actions{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-light)}.action-button{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}.action-button:hover:not(:disabled){background:var(--bg-hover);color:var(--primary-red);border-color:var(--border-dark)}.action-button.liked{background:var(--primary-red-bg);color:var(--primary-red);border-color:var(--primary-red)}.action-button.favorited{background:#fff9e6;color:#ffd93d;border-color:#ffd93d}.delete-button{margin-left:auto}.delete-button:hover:not(:disabled){background:var(--error);color:#fff;border-color:var(--error)}.post-detail-skeleton{padding:var(--spacing-md)}.post-detail-skeleton{padding:var(--spacing-md);animation:fadeIn .2s ease-in-out}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading,.error{text-align:center;padding:var(--spacing-2xl);font-size:16px}.error{color:var(--error)}@media (max-width: 768px){.post-detail{padding:var(--spacing-md) 0}.back-button{font-size:14px;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);margin-left:var(--spacing-sm)}.post-detail-content{margin-bottom:var(--spacing-lg)}.post-images{grid-template-columns:1fr;padding:var(--spacing-xs);gap:var(--spacing-xs)}.post-images img{height:250px;border-radius:var(--radius-md)}.post-header{padding:var(--spacing-md)}.post-header h1{font-size:20px;line-height:1.4}.post-author{font-size:13px;flex-wrap:wrap}.post-rating-section{gap:var(--spacing-sm)}.post-rating{flex-wrap:wrap}.rating-text{font-size:16px}.user-rating-section{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);padding-top:var(--spacing-sm)}.user-rating-label{font-size:13px}.user-rating-stars{gap:2px}.rating-star-btn{font-size:20px;padding:var(--spacing-xs)}.post-body{padding:var(--spacing-md)}.post-content{font-size:15px;line-height:1.7;margin-bottom:var(--spacing-md)}.post-tags{gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.post-tags .tag{font-size:12px;padding:var(--spacing-xs) var(--spacing-sm)}.post-info{padding:var(--spacing-sm);gap:var(--spacing-xs)}.info-item{font-size:13px}.post-actions{flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md)}.action-button{flex:1;min-width:calc(50% - var(--spacing-xs));padding:var(--spacing-md);font-size:14px;text-align:center}.delete-button{margin-left:0;width:100%;margin-top:var(--spacing-xs)}}.address-search{padding:var(--spacing-md);margin:var(--spacing-md) 0;background:var(--bg-primary);border-radius:var(--radius-md)}.address-search-header{margin-bottom:var(--spacing-sm)}.address-label{font-size:14px;font-weight:500;color:var(--text-primary)}.address-search-container{position:relative;margin-bottom:var(--spacing-sm)}.address-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:14px;transition:border-color .3s}.address-search-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b1a}.address-loading{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-secondary)}.address-search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-height:300px;overflow-y:auto;z-index:100;margin-top:4px}.address-search-result-item{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .2s}.address-search-result-item:last-child{border-bottom:none}.address-search-result-item:hover,.address-search-result-item.hover{background:var(--bg-hover)}.result-name{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.result-address{font-size:12px;color:var(--text-secondary)}.address-selected{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--primary-red-bg);border:1px solid var(--primary-red);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.address-selected-content{flex:1}.address-selected-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.address-selected-value{font-size:14px;color:var(--text-primary);font-weight:500}.address-clear-btn{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.address-clear-btn:hover{color:var(--primary-red)}@media (max-width: 768px){.address-search{padding:8px;margin:8px 0}.address-label{font-size:12px}.address-search-input{padding:6px 10px;font-size:14px}.address-search-results{max-height:200px}.address-search-result-item{padding:6px 10px}.result-name{font-size:12px}.result-address{font-size:11px}.address-selected{padding:8px;margin-top:8px}.address-selected-label{font-size:11px}.address-selected-value{font-size:12px}}.create-post{padding:var(--spacing-xl) 0}.create-post-container{max-width:800px;margin:0 auto;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.create-post-container h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xl);text-align:center}.create-post-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:500;color:var(--text-primary);font-size:14px}.form-group input,.form-group textarea{padding:var(--spacing-md);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:16px;color:var(--text-primary);transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b1a}.form-group textarea{resize:vertical;min-height:120px}.rating-container{display:flex;align-items:center;gap:var(--spacing-md)}.rating-text{color:var(--text-secondary);font-size:14px}.image-upload{display:flex;flex-direction:column;gap:var(--spacing-md)}.file-input{display:none}.image-preview-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-md)}.image-preview{position:relative;width:100px;height:100px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:var(--radius-full);background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;cursor:pointer;transition:background .2s ease}.remove-image:hover{background:#000c}.image-upload-button{width:100px;height:100px;border:2px dashed var(--border-dark);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--primary-red);font-size:14px;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary)}.image-upload-button:hover{border-color:var(--primary-red);background:var(--primary-red-bg)}.category-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.category-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.category-label{font-size:14px;font-weight:500;color:var(--text-primary)}.select-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-right:2.5rem;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:14px;background:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;cursor:pointer;transition:border-color .3s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.select-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b1a}.custom-input{width:100%;padding:var(--spacing-md);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:16px;transition:border-color .3s}.custom-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b1a}.tag-input-container{display:flex;gap:var(--spacing-sm)}.tag-input-container input{flex:1}.add-tag-button{padding:var(--spacing-md) var(--spacing-lg);background:var(--primary-red);color:#fff;border-radius:var(--radius-md);font-weight:500;transition:background .3s ease}.add-tag-button:hover{background:var(--primary-red-dark)}.tags-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--primary-red-bg);color:var(--primary-red);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:14px}.remove-tag{background:none;border:none;color:var(--primary-red);font-size:18px;line-height:1;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.remove-tag:hover{color:var(--primary-red-dark)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:all .3s ease;cursor:pointer}.btn-primary{background:var(--primary-red);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){background:var(--primary-red-dark);box-shadow:var(--shadow-lg)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--primary-red);border:1px solid var(--border-dark)}.btn-secondary:hover{background:var(--bg-hover)}.error-message{background:var(--primary-red-bg);border-left:4px solid var(--error);color:var(--error);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:14px}.price-row{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-md);align-items:end}.price-input-group,.price-description-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.price-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.price-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.price-slider{width:100%;height:6px;border-radius:var(--radius-full);background:var(--bg-secondary);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.price-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-red);cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #ff6b6b4d}.price-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-red);cursor:pointer;border:none;transition:all .3s;box-shadow:0 2px 4px #ff6b6b4d}.price-input,.price-description-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:14px}.price-slider-container{display:flex;flex-direction:column;gap:var(--spacing-xs)}.price-slider{width:100%;height:8px;border-radius:var(--radius-full);background:var(--bg-secondary);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.price-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-red);cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #ff6b6b4d}.price-slider::-webkit-slider-thumb:hover{background:var(--primary-red-dark);transform:scale(1.1)}.price-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-red);cursor:pointer;border:none;transition:all .3s;box-shadow:0 2px 4px #ff6b6b4d}.price-slider::-moz-range-thumb:hover{background:var(--primary-red-dark);transform:scale(1.1)}.price-slider-info{display:flex;justify-content:space-between;align-items:center}.price-value{font-size:1.2rem;font-weight:600;color:var(--primary-red)}.price-range-hint{font-size:.85rem;color:var(--text-tertiary)}.price-input{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-medium);border-radius:var(--radius-md);font-size:1rem;font-weight:500;color:var(--text-primary);transition:all .3s}.price-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 3px #ff6b6b26}.title-input-wrapper{position:relative}.searching-indicator{position:absolute;top:100%;left:0;right:0;padding:4px 8px;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);border-radius:4px;margin-top:4px}.similar-posts-suggestion{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:2px solid var(--primary-red);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);margin-top:8px;z-index:100;max-height:400px;overflow-y:auto}.suggestion-header{display:flex;align-items:center;gap:8px;padding:12px;background:var(--primary-red-bg);border-bottom:1px solid var(--border-light)}.suggestion-icon{font-size:18px}.suggestion-text{flex:1;font-size:13px;color:var(--text-primary);font-weight:500}.suggestion-close{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.suggestion-close:hover{background:var(--bg-hover);color:var(--text-primary)}.similar-posts-list{padding:8px}.similar-post-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border-radius:var(--radius-sm);margin-bottom:8px;background:var(--bg-secondary);transition:all .2s}.similar-post-item:hover{background:var(--bg-hover)}.similar-post-info{flex:1;min-width:0}.similar-post-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.similar-post-meta{display:flex;gap:12px;font-size:12px;color:var(--text-secondary)}.use-as-comment-btn{padding:6px 12px;background:var(--primary-red);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.use-as-comment-btn:hover{background:var(--primary-red-dark)}@media (max-width: 768px){.similar-posts-suggestion{max-height:300px}.suggestion-header{padding:8px}.suggestion-text{font-size:11px}.similar-post-item{flex-direction:column;align-items:flex-start;padding:8px}.similar-post-title{font-size:12px}.similar-post-meta{font-size:10px;flex-direction:column;gap:4px}.use-as-comment-btn{width:100%;padding:8px;font-size:11px}}@media (max-width: 768px){.create-post{padding:8px 0}.create-post-container{padding:12px;margin:0 8px;border-radius:var(--radius-md)}.create-post-container h1{font-size:18px;margin-bottom:12px;font-weight:600}.create-post-form{gap:12px}.form-group{gap:6px}.form-group label{font-size:12px;font-weight:500;color:var(--text-secondary)}.category-row{grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs)}.category-label{font-size:12px}.form-group input,.form-group textarea,.select-input,.custom-input{font-size:14px;padding:8px 10px;border-radius:8px;border:1px solid var(--border-medium)}.form-group textarea{min-height:80px;resize:vertical}.rating-container{flex-direction:row;align-items:center;gap:8px;flex-wrap:wrap}.rating-text{font-size:12px}.image-preview-list{grid-template-columns:repeat(3,1fr);gap:8px}.image-preview,.image-upload-button{width:100%;aspect-ratio:1;min-width:0}.image-upload-button{font-size:12px;border-width:1.5px}.remove-image{width:20px;height:20px;font-size:16px;top:2px;right:2px}.price-row{grid-template-columns:1fr;gap:var(--spacing-xs)}.price-label{font-size:11px}.price-slider::-webkit-slider-thumb{width:16px;height:16px}.price-slider::-moz-range-thumb{width:16px;height:16px}.price-input,.price-description-input{padding:6px 8px;font-size:14px}.select-input{padding-right:2rem;background-position:right .5rem center;background-size:10px}.tag-input-container{flex-direction:row;gap:6px;align-items:center}.tag-input-container input{flex:1;min-width:0;font-size:14px;padding:6px 10px}.add-tag-button{padding:6px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}.tags-list{gap:6px;margin-top:6px}.tag{font-size:12px;padding:4px 8px;gap:4px}.remove-tag{width:14px;height:14px;font-size:14px}.form-actions{flex-direction:column-reverse;gap:8px;margin-top:12px;padding-top:12px}.btn{width:100%;padding:10px;font-size:14px;font-weight:500}.price-slider-container{gap:6px}.price-slider{height:6px}.price-slider::-webkit-slider-thumb{width:18px;height:18px}.price-slider::-moz-range-thumb{width:18px;height:18px}.price-slider-info{flex-direction:row;align-items:center;justify-content:space-between;gap:8px}.price-value{font-size:16px;font-weight:600}.price-range-hint{font-size:11px}.price-input{padding:6px 10px;font-size:14px;width:80px;margin-top:6px}.error-message{padding:8px 10px;font-size:12px;margin-bottom:8px}.select-input{font-size:14px;padding:8px 28px 8px 10px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:10px}.form-group:has(.address-upload){gap:6px}}.login-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#fff5f5,#ffe5e5)}.login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 4px 20px #ff6b6b26}.login-title{text-align:center;color:#ff6b6b;font-size:2rem;margin-bottom:2rem;font-weight:600}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#333;font-weight:500;font-size:.9rem}.form-group input{padding:.75rem;border:2px solid #E0E0E0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#ff6b6b}.error-message{background:#ffe5e5;color:#ff6b6b;padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center}.submit-button{background:#ff6b6b;color:#fff;border:none;padding:.875rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s;margin-top:.5rem}.submit-button:hover:not(:disabled){background:#ff5252}.submit-button:disabled{opacity:.6;cursor:not-allowed}.divider{display:flex;align-items:center;margin:1.5rem 0;color:#999}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.divider span{padding:0 1rem}.github-button{width:100%;background:#24292e;color:#fff;border:none;padding:.875rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background .3s}.github-button:hover{background:#1a1e22}.switch-mode{text-align:center;margin-top:1.5rem;color:#666;font-size:.9rem}.link-button{background:none;border:none;color:#ff6b6b;cursor:pointer;font-weight:600;text-decoration:underline;padding:0;font-size:inherit}.link-button:hover{color:#ff5252}.error-input{border-color:#ff6b6b!important}.error-hint{color:#ff6b6b;font-size:.85rem;margin-top:.25rem}.terms-row{flex-direction:row;align-items:center;gap:.25rem;margin-top:0;margin-bottom:0}.terms-label{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:#666;line-height:1.1}.terms-label input[type=checkbox]{width:16px;height:16px;vertical-align:middle}.terms-text{display:inline;line-height:1.1}.terms-link{display:inline;background:none;border:none;padding:0;margin:0;color:#1976d2;cursor:pointer;font-size:.85rem;text-decoration:underline}.terms-link:hover{color:#0d47a1}@media (max-width: 768px){.login-container{padding:var(--spacing-md);min-height:calc(100vh - 64px)}.login-card{padding:var(--spacing-xl);max-width:100%}.login-title{font-size:24px;margin-bottom:var(--spacing-lg)}.form-group input{font-size:16px;padding:var(--spacing-md)}.submit-button,.github-button{padding:var(--spacing-md);font-size:16px}.terms-label,.terms-link{font-size:.72rem;line-height:1.05}.switch-mode{font-size:14px}}.announcement{padding:var(--spacing-xl) var(--spacing-2xl);max-width:1400px;margin:0 auto;padding-top:calc(64px + var(--spacing-xl))}.announcement-container{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-2xl)}.announcement-container h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xl);text-align:center;border-bottom:2px solid var(--primary-red);padding-bottom:var(--spacing-md)}.announcement-section{margin-bottom:var(--spacing-xl)}.announcement-section h2{font-size:24px;font-weight:600;color:var(--primary-red);margin-bottom:var(--spacing-md);padding-left:var(--spacing-sm);border-left:4px solid var(--primary-red)}.announcement-content{padding-left:var(--spacing-md)}.announcement-content h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.announcement-content ul{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md);line-height:1.8}.announcement-content li{margin-bottom:var(--spacing-xs);color:var(--text-secondary)}.announcement-content li strong{color:var(--text-primary)}.notice-box{background:var(--primary-red-bg);border-left:4px solid var(--primary-red);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0}.notice-box strong{color:var(--primary-red);display:block;margin-bottom:var(--spacing-xs)}.notice-box ul{margin-top:var(--spacing-xs);margin-left:var(--spacing-md)}.notice-box p{margin-top:var(--spacing-xs);color:var(--text-secondary);line-height:1.8}.formula-box{background:var(--bg-secondary);border:1px solid var(--border-medium);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0;font-family:Courier New,monospace;font-size:14px;color:var(--text-primary);text-align:center;overflow-x:auto}.faq-item{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.faq-item strong{color:var(--primary-red);display:block;margin-bottom:var(--spacing-xs);font-size:16px}.faq-item p{color:var(--text-secondary);line-height:1.8;margin:0}.tech-cards{display:grid;grid-template-columns:repeat(4,auto);gap:var(--spacing-sm);margin-top:var(--spacing-md);justify-content:start}.tech-card{width:56px;height:56px;background:linear-gradient(135deg,#fff,#f8f9fa);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;flex-shrink:0}.tech-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ff6b6b0d,#ff8c8c05);opacity:0;transition:opacity .3s}.tech-card:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 6px 16px #ff6b6b26;border-color:var(--primary-red);background:linear-gradient(135deg,#fff,#fff5f5)}.tech-card:hover:before{opacity:1}.tech-icon-img{width:40px;height:40px;object-fit:contain;transition:transform .3s;position:relative;z-index:1}.tech-card:hover .tech-icon-img{transform:scale(1.1)}.dev-cards,.thanks-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);margin-top:var(--spacing-md)}.dev-card,.thanks-card{background:#fff;border:1.5px solid #e8e8e8;border-radius:16px;padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;box-shadow:0 2px 8px #0000000a}.dev-card:before,.thanks-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-red),#ff8c8c);transform:scaleX(0);transform-origin:left;transition:transform .3s}.dev-card:hover,.thanks-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #ff6b6b33;border-color:var(--primary-red);background:#fff5f5}.dev-card:hover:before,.thanks-card:hover:before{transform:scaleX(1)}.dev-avatar,.dev-icon,.thanks-avatar,.thanks-avatar-placeholder{flex-shrink:0;width:72px;height:72px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #f0f0f0;transition:all .3s;object-fit:cover}.dev-card:hover .dev-avatar,.dev-card:hover .dev-icon,.thanks-card:hover .thanks-avatar,.thanks-card:hover .thanks-avatar-placeholder{transform:scale(1.08);border-color:var(--primary-red);box-shadow:0 4px 12px #ff6b6b33}.dev-avatar,.thanks-avatar{object-fit:cover;border-radius:var(--radius-md)}.dev-icon{font-size:40px;border-radius:var(--radius-md)}.thanks-avatar-placeholder{color:#fff;font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-red),#ff8c8c);border-radius:var(--radius-md)}.tech-content,.dev-content,.thanks-content{flex:1;min-width:0}.tech-name,.dev-name,.thanks-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:6px;line-height:1.4}.dev-title,.thanks-title{font-size:13px;color:#666;margin-bottom:8px;line-height:1.4;font-weight:500}.tech-desc,.dev-desc,.thanks-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:0}.tech-card .tech-desc{margin-bottom:0}.dev-link,.thanks-link{font-size:12px;color:var(--primary-red);font-weight:500;display:inline-flex;align-items:center;gap:4px;margin-top:var(--spacing-xs)}.dev-link:after,.thanks-link:after{content:"→";transition:transform .2s}.dev-card:hover .dev-link:after,.thanks-card:hover .thanks-link:after{transform:translate(4px)}.thanks-link-no{font-size:12px;color:var(--text-secondary);font-style:italic;opacity:.7;margin-top:var(--spacing-xs)}@media (max-width: 768px){.announcement{padding:8px}.announcement-container{padding:var(--spacing-md)}.announcement-container h1{font-size:20px;margin-bottom:var(--spacing-sm)}.announcement-section h2{font-size:18px}.announcement-content h3{font-size:16px}.announcement-content ul{margin-left:var(--spacing-md)}.formula-box{font-size:12px;padding:var(--spacing-sm)}.faq-item{padding:var(--spacing-sm)}.faq-item strong{font-size:14px}.tech-cards{grid-template-columns:repeat(4,auto);gap:var(--spacing-sm);justify-content:flex-start}.tech-card{width:52px;height:52px;padding:6px}.tech-icon-img{width:38px;height:38px}.dev-cards,.thanks-cards{grid-template-columns:1fr;gap:var(--spacing-md)}.dev-card,.thanks-card{flex-direction:row;text-align:left;padding:var(--spacing-md)}.dev-avatar,.dev-icon,.thanks-avatar,.thanks-avatar-placeholder{margin:0;width:64px;height:64px}.dev-content,.thanks-content{text-align:left}.dev-name,.thanks-name{font-size:16px}.dev-title,.thanks-title{font-size:12px}.dev-desc,.thanks-desc{font-size:13px}}@media (max-width: 1200px) and (min-width: 769px){.tech-cards{grid-template-columns:repeat(4,1fr)}.dev-cards,.thanks-cards{grid-template-columns:repeat(2,1fr)}}.admin-dashboard{padding:var(--spacing-xl) var(--spacing-2xl);max-width:1400px;margin:0 auto;padding-top:calc(64px + var(--spacing-xl))}.admin-container{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-2xl)}.admin-container h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xl);text-align:center;border-bottom:2px solid var(--primary-red);padding-bottom:var(--spacing-md)}.admin-loading,.admin-error{text-align:center;padding:var(--spacing-lg);color:var(--text-secondary)}.admin-error{color:#d32f2f;background:#ffebee;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.admin-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg)}.admin-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.admin-card:hover{border-color:var(--primary-red);box-shadow:0 4px 12px #ff6b6b26}.admin-card.expanded{border-color:var(--primary-red);box-shadow:0 6px 20px #ff6b6b33}.admin-card-header{padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#fff,#fff5f5);border-bottom:1px solid #f0f0f0}.admin-card-title{font-size:18px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.admin-badge{background:var(--primary-red);color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.admin-card-arrow{font-size:14px;color:var(--text-secondary);transition:transform .3s}.admin-card.expanded .admin-card-arrow{transform:rotate(180deg)}.admin-card-content{padding:var(--spacing-lg);max-height:600px;overflow-y:auto}.admin-card-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.admin-card-filters button{padding:6px 12px;border:1px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.admin-card-filters button:hover{border-color:var(--primary-red);color:var(--primary-red)}.admin-card-filters button.active{background:var(--primary-red);color:#fff;border-color:var(--primary-red)}.admin-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);font-size:14px}.admin-reports-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-report-item{border:1px solid #e0e0e0;border-radius:8px;padding:var(--spacing-md);background:#fafafa}.admin-report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.admin-report-info{flex:1}.admin-report-type{font-weight:600;color:var(--primary-red);margin-bottom:4px;font-size:14px}.admin-report-reason{font-size:14px;color:var(--text-primary);margin-bottom:4px}.admin-report-meta{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.admin-report-description{font-size:13px;color:var(--text-secondary);margin-top:6px;padding:6px;background:#fff;border-radius:4px;border-left:3px solid var(--primary-red)}.admin-report-status{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.admin-report-status.pending{background:#fff3cd;color:#856404}.admin-report-status.approved{background:#d4edda;color:#155724}.admin-report-status.rejected{background:#f8d7da;color:#721c24}.admin-report-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-sm);align-items:center}.admin-report-handler{font-size:12px;color:var(--text-secondary)}.admin-addresses-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-address-item{border:1px solid #e0e0e0;border-radius:8px;padding:var(--spacing-md);background:#fafafa}.admin-address-info{margin-bottom:var(--spacing-sm)}.admin-address-title{font-weight:600;font-size:16px;margin-bottom:4px;color:var(--text-primary)}.admin-address-meta{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.admin-address-original{font-size:12px;color:#999;margin-top:4px}.admin-address-edit{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-address-search{margin-top:var(--spacing-sm)}.admin-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.admin-address-buttons{display:flex;gap:var(--spacing-sm)}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-stat-item{background:linear-gradient(135deg,#fff5f5,#fff);border:1px solid #ffe0e0;border-radius:8px;padding:var(--spacing-md);text-align:center}.admin-stat-label{font-size:13px;color:var(--text-secondary);margin-bottom:6px}.admin-stat-value{font-size:24px;font-weight:700;color:var(--primary-red)}.admin-top-users{margin-top:var(--spacing-lg)}.admin-top-users h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table thead{background:#f5f5f5}.admin-table th{padding:8px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid #e0e0e0}.admin-table td{padding:8px;border-bottom:1px solid #f0f0f0;color:var(--text-secondary)}.admin-table tbody tr:hover{background:#fafafa}.admin-btn-primary,.admin-btn-secondary,.admin-btn-view,.admin-btn-approve,.admin-btn-reject{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.admin-btn-primary{background:var(--primary-red);color:#fff}.admin-btn-primary:hover:not(:disabled){background:#d32f2f}.admin-btn-primary:disabled{opacity:.6;cursor:not-allowed}.admin-btn-secondary{background:#f5f5f5;color:var(--text-secondary)}.admin-btn-secondary:hover{background:#e0e0e0}.admin-btn-view{background:#2196f3;color:#fff}.admin-btn-view:hover{background:#1976d2}.admin-btn-approve{background:#4caf50;color:#fff}.admin-btn-approve:hover{background:#45a049}.admin-btn-reject{background:#f44336;color:#fff}.admin-btn-reject:hover{background:#da190b}@media (max-width: 768px){.admin-dashboard{padding:8px}.admin-container{padding:var(--spacing-md)}.admin-container h1{font-size:20px;margin-bottom:var(--spacing-sm)}.admin-cards-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.admin-card-header{padding:var(--spacing-md)}.admin-card-title{font-size:16px}.admin-card-content{padding:var(--spacing-md);max-height:400px}.admin-stats-grid{grid-template-columns:1fr}.admin-report-actions{flex-direction:column}.admin-report-actions button{width:100%}.admin-address-buttons{flex-direction:column}.admin-address-buttons button{width:100%}}.profile{padding:var(--spacing-lg) 0;padding-top:calc(64px + var(--spacing-md))}@media (max-width: 768px){.profile{padding-top:56px}}.profile-header{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md)}.profile-avatar-section{flex-shrink:0}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-red)}.profile-avatar-placeholder{width:80px;height:80px;border-radius:50%;background:var(--primary-red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;border:3px solid var(--primary-red)}.profile-info{flex:1}.profile-username{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.profile-bio{font-size:16px;color:var(--text-secondary);margin:var(--spacing-sm) 0}.profile-email{font-size:14px;color:var(--text-tertiary);margin:var(--spacing-xs) 0}.profile-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.profile-edit-btn,.profile-save-btn,.profile-cancel-btn,.profile-logout-btn,.profile-delete-btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all .3s;border:none;white-space:nowrap}.profile-edit-btn{background:var(--primary-red);color:#fff}.profile-edit-btn:hover{background:var(--primary-red-dark)}.profile-save-btn{background:var(--primary-red);color:#fff}.profile-save-btn:hover:not(:disabled){background:var(--primary-red-dark)}.profile-save-btn:disabled{opacity:.6;cursor:not-allowed}.profile-cancel-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-medium)}.profile-cancel-btn:hover:not(:disabled){background:var(--bg-hover)}.profile-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.profile-logout-btn{background:var(--primary-red);color:#fff}.profile-logout-btn:hover{background:var(--primary-red-dark)}.profile-delete-btn{background:#f44336;color:#fff}.profile-delete-btn:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 4px 8px #f4433666}.avatar-upload-label{position:relative;cursor:pointer;display:block}.avatar-upload-input{position:absolute;opacity:0;width:0;height:0}.avatar-upload-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:11px;color:var(--text-secondary);white-space:nowrap}.profile-username-input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--border-medium);border-radius:var(--radius-md);font-size:24px;font-weight:700;color:var(--text-primary);background:var(--bg-primary)}.profile-username-input:focus{outline:none;border-color:var(--primary-red)}.profile-username-input:disabled{opacity:.6;cursor:not-allowed}.username-change-hint{font-size:12px;color:var(--text-tertiary);margin:var(--spacing-xs) 0}.profile-error{font-size:12px;color:var(--error);margin:var(--spacing-xs) 0}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.stat-item{background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--spacing-md);text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--primary-red);margin-bottom:var(--spacing-xs)}.stat-label{font-size:13px;color:var(--text-secondary)}.profile-tabs{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-sm);box-shadow:var(--shadow-md)}.profile-tab{flex:1;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;background:transparent;color:var(--text-secondary);border:none}.profile-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.profile-tab.active{background:var(--primary-red);color:#fff}.profile-posts{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-md)}.profile-posts-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.profile-posts .posts-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-md);margin-left:0}.profile-posts .empty-state{text-align:center;padding:var(--spacing-2xl)}.profile-posts .empty-state-icon{font-size:64px;margin-bottom:var(--spacing-md)}.profile-posts .empty-state-text{font-size:16px;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.create-post-btn{background:var(--primary-red);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;font-size:16px;font-weight:500;transition:background .3s}.create-post-btn:hover{background:var(--primary-red-dark)}@media (max-width: 768px){.profile{padding:8px 0}.profile-header{flex-direction:column;text-align:center;padding:10px;gap:8px;margin-bottom:8px}.profile-avatar,.profile-avatar-placeholder{width:50px;height:50px;font-size:24px;border-width:2px}.profile-info{width:100%}.profile-username{font-size:16px;margin-bottom:4px}.profile-username-input{font-size:16px;padding:4px 8px}.profile-bio{font-size:11px;margin:2px 0}.profile-email{font-size:10px;margin:2px 0}.profile-actions{width:100%;gap:6px;justify-content:center;flex-wrap:wrap}.profile-edit-btn,.profile-save-btn,.profile-cancel-btn,.profile-logout-btn{flex:1;min-width:0;padding:6px 8px;font-size:12px;max-width:calc(50% - 3px)}.profile-delete-btn{flex:0 0 auto;padding:6px 12px;font-size:11px;margin-left:0;width:auto;min-width:80px}.profile-stats{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px;padding:0 8px}.stat-item{padding:8px 4px}.stat-value{font-size:18px;margin-bottom:2px}.stat-label{font-size:9px}.profile-tabs{flex-direction:row;gap:4px;padding:4px;margin:0 8px 8px}.profile-tab{padding:6px 8px;font-size:12px;flex:1}.profile-posts{padding:8px;margin:0 8px}.profile-posts-title{font-size:14px;margin-bottom:8px}.profile-posts .posts-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.empty-state{padding:var(--spacing-md)}.empty-state-icon{font-size:36px;margin-bottom:8px}.empty-state-text{font-size:11px;margin-bottom:8px}.create-post-btn{width:100%;padding:8px;font-size:12px}.avatar-upload-hint{font-size:9px;bottom:-16px}.username-change-hint,.profile-error{font-size:10px;margin:2px 0}}.following-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.following-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .3s ease}.following-item:hover{background:var(--bg-hover);transform:translate(4px);box-shadow:var(--shadow-md)}.following-avatar,.following-avatar-placeholder{width:50px;height:50px;border-radius:50%;flex-shrink:0;border:2px solid var(--primary-red)}.following-avatar{object-fit:cover}.following-avatar-placeholder{background:var(--primary-red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.following-info{flex:1;min-width:0}.following-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.following-bio{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.following-arrow{font-size:20px;color:var(--text-tertiary);flex-shrink:0}@media (max-width: 768px){.following-item{padding:var(--spacing-sm);gap:var(--spacing-sm)}.following-avatar,.following-avatar-placeholder{width:40px;height:40px;font-size:16px}.following-name{font-size:14px}.following-bio{font-size:11px}.following-arrow{font-size:16px}}.leaderboard{padding:var(--spacing-lg) var(--spacing-xl);max-width:1200px;margin:0 auto;padding-top:calc(64px + var(--spacing-lg))}.leaderboard-header{margin-bottom:var(--spacing-xl)}.leaderboard-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.leaderboard-tabs{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.leaderboard-tab{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}.leaderboard-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.leaderboard-tab.active{background:var(--primary-red);color:#fff;border-color:var(--primary-red)}.leaderboard-loading,.leaderboard-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary);font-size:16px}.leaderboard-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.leaderboard-posts{margin-top:var(--spacing-md)}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.post-rank-wrapper{position:relative;width:100%;height:100%;display:flex;flex-direction:column}.post-rank-badge{position:absolute;top:8px;left:8px;z-index:10;background:#ffffffe6;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.rank-medal-small{font-size:20px}.rank-number-small{font-size:14px;font-weight:700;color:var(--primary-red)}.post-value-label{position:absolute;top:8px;right:8px;z-index:10;background:var(--primary-red);color:#fff;padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;box-shadow:0 2px 4px #0003}.post-rank-wrapper>div:last-child{cursor:pointer;width:100%;flex:1;min-width:0}.leaderboard-item{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-lg);cursor:pointer;transition:all .3s ease}.leaderboard-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.leaderboard-rank{flex-shrink:0;width:50px;text-align:center}.rank-medal{font-size:32px}.rank-number{font-size:24px;font-weight:700;color:var(--text-secondary)}.leaderboard-user{flex:1;display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar,.user-avatar-placeholder{width:60px;height:60px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--primary-red)}.user-avatar-placeholder{background:var(--primary-red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.user-info{flex:1;min-width:0}.user-name-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.user-name{font-size:18px;font-weight:600;color:var(--text-primary)}.user-level{font-size:14px;color:var(--primary-red);font-weight:500}.user-bio{font-size:14px;color:var(--text-secondary);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-stats{display:flex;align-items:center;gap:var(--spacing-md);font-size:13px}.user-value{color:var(--primary-red);font-weight:600}.user-exp{color:var(--text-tertiary)}@media (max-width: 768px){.leaderboard{padding:56px 8px 8px}.leaderboard-header h1{font-size:20px;margin-bottom:8px}.leaderboard-tabs{gap:4px;margin-bottom:8px}.leaderboard-tab{padding:6px 10px;font-size:12px;flex:1;min-width:0}.leaderboard-item{padding:10px;gap:8px}.leaderboard-rank{width:30px}.rank-medal{font-size:24px}.rank-number{font-size:18px}.user-avatar,.user-avatar-placeholder{width:40px;height:40px;font-size:18px}.user-name{font-size:14px}.user-level,.user-bio{font-size:11px}.user-stats{font-size:10px;flex-direction:column;align-items:flex-start;gap:2px}.posts-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs);width:100%}.post-rank-wrapper{width:100%;min-width:0;box-sizing:border-box}.post-rank-wrapper>div:last-child{width:100%;min-width:0}.post-rank-badge{width:24px;height:24px;top:4px;left:4px}.rank-medal-small{font-size:16px}.rank-number-small{font-size:12px}.post-value-label{top:4px;right:4px;padding:2px 6px;font-size:10px}}.notifications-page{min-height:calc(100vh - 200px);padding:20px;max-width:800px;margin:0 auto}.notifications-container{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.notifications-header h1{margin:0;font-size:24px;color:#333}.mark-all-read-btn{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .3s}.mark-all-read-btn:hover:not(:disabled){background:#45a049}.mark-all-read-btn:disabled{opacity:.6;cursor:not-allowed}.loading{text-align:center;padding:40px;color:#666}.empty-notifications{text-align:center;padding:60px 20px;color:#999}.empty-notifications p{font-size:16px}.notifications-list{display:flex;flex-direction:column;gap:12px}.notification-item{display:flex;align-items:flex-start;padding:16px;border-radius:8px;cursor:pointer;transition:background .2s;position:relative;border:1px solid #e0e0e0}.notification-item:hover{background:#f5f5f5}.notification-item.unread{background:#e3f2fd;border-color:#2196f3}.notification-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;margin-right:12px;flex-shrink:0}.notification-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:20px;color:#666;font-weight:700}.notification-content{flex:1;min-width:0}.notification-text{font-size:15px;line-height:1.5;margin-bottom:4px}.actor-name{font-weight:600;color:#333}.notification-action{color:#666}.notification-post-title{font-size:14px;color:#999;margin-top:4px;margin-bottom:4px;font-style:italic}.notification-time{font-size:12px;color:#999;margin-top:4px}.unread-indicator{width:8px;height:8px;border-radius:50%;background:#2196f3;margin-left:12px;flex-shrink:0;margin-top:8px}@media (max-width: 768px){.notifications-page{padding:10px}.notifications-container{padding:15px}.notifications-header{flex-direction:column;align-items:flex-start;gap:10px}.mark-all-read-btn{width:100%}.notification-item{padding:12px}.notification-avatar{width:40px;height:40px}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:64px;max-width:1200px;width:100%;margin:0 auto;padding-left:var(--spacing-md);padding-right:var(--spacing-md);position:relative}.page-transition-wrapper{animation:fadeIn .2s ease-in-out;min-height:calc(100vh - 64px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.main-content{padding-top:64px;padding-left:var(--spacing-sm);padding-right:var(--spacing-sm);padding-bottom:var(--spacing-md)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-red: #FF6B6B;--primary-red-dark: #FF5252;--primary-red-light: #FFB3B3;--primary-red-bg: #FFE5E5;--primary-red-bg-light: #FFF5F5;--pink-primary: #FF6B6B;--pink-light: #FFE5E5;--pink-lighter: #FFF0F0;--pink-bg: #FFF8F8;--pink-border: #FFD6D6;--tag-pink: #FFE5E5;--tag-green: #E8F5E9;--tag-yellow: #FFF9E6;--tag-blue: #E3F2FD;--tag-purple: #F3E5F5;--gold: #FFD93D;--gold-dark: #FFC107;--gold-light: #FFF9C4;--text-primary: #2C2C2C;--text-secondary: #666666;--text-tertiary: #999999;--text-disabled: #CCCCCC;--bg-primary: #FFFFFF;--bg-secondary: #FFF5F5;--bg-tertiary: #FFE5E5;--bg-hover: #FFF0F0;--border-light: #F0F0F0;--border-medium: #E0E0E0;--border-dark: #FFB3B3;--success: #51CF66;--warning: #FFA726;--error: #FF5252;--info: #42A5F5;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(255, 107, 107, .05);--shadow-md: 0 2px 8px rgba(255, 107, 107, .1);--shadow-lg: 0 4px 16px rgba(255, 107, 107, .15);--shadow-xl: 0 8px 24px rgba(255, 107, 107, .2)}html{overflow-y:scroll}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-y:scroll}#root{min-height:100vh}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea{font-family:inherit;outline:none}img{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}*{scrollbar-width:thin;scrollbar-color:var(--border-medium) var(--bg-secondary)}@media (max-width: 768px){button,a,input[type=button],input[type=submit]{min-height:44px;min-width:44px}html,body{-webkit-overflow-scrolling:touch}html{overflow-y:auto}*{-webkit-tap-highlight-color:transparent}}
