.page-wrapper{box-sizing:border-box;background:#f3f4f6;flex-direction:column;width:100%;min-height:100vh;display:flex;overflow-x:hidden}.page-wrapper *{box-sizing:border-box}.skip-link{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link:focus{clip:auto;white-space:normal;color:#fff;z-index:50;background:#2563eb;width:auto;height:auto;margin:0;padding:.5rem;position:absolute;top:0;left:0;overflow:visible}.main-content{width:100%;padding-top:var(--header-height,5.5rem);flex-grow:1;overflow-x:hidden}.suggestions-hero-section{color:#fff;background:linear-gradient(#1e40af,#1e3a8a);width:100%;padding:5rem 0;overflow-x:hidden}.suggestions-hero-container{text-align:center;width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}.suggestions-hero-content{max-width:56rem;margin:0 auto}.suggestions-hero-title{font-size:2.25rem;font-weight:700;line-height:1.2}.suggestions-hero-description{color:#e5e7eb;margin-top:1.5rem;font-size:1.25rem}.suggestions-content-section{background:#f9fafb;width:100%;padding:5rem 0;overflow-x:hidden}.suggestions-container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}.suggestions-submit-wrapper{justify-content:flex-end;margin-bottom:2rem;display:flex}.suggestions-submit-btn{color:#fff;cursor:pointer;background:#1e40af;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.suggestions-submit-btn:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.submit-btn-icon{width:1.25rem;height:1.25rem}.suggestions-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.suggestions-empty-state{text-align:center;color:#6b7280;grid-column:1/-1;padding:3rem 1rem;font-size:1.125rem}.suggestion-modal-overlay{z-index:9999;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.suggestion-modal-content{background:#fff;border-radius:.5rem;width:100%;max-width:28rem;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.suggestion-modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.suggestion-modal-title{color:#111827;font-size:1.5rem;font-weight:700}.suggestion-modal-close{cursor:pointer;color:#9ca3af;background:0 0;border:none;padding:.25rem;transition:color .2s}.suggestion-modal-close:hover{color:#4b5563}.modal-close-icon{width:1.5rem;height:1.5rem}.suggestion-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;display:flex}.form-label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500}.form-input,.form-textarea,.form-select{border:1px solid #d1d5db;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:100px}.form-hint{color:#6b7280;margin-top:.25rem;font-size:.75rem}.captcha-wrapper{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.captcha-display{letter-spacing:.25rem;color:#374151;-webkit-user-select:none;user-select:none;background:#f3f4f6;border:2px solid #d1d5db;border-radius:.375rem;padding:.5rem 1rem;font-family:Courier New,monospace;font-size:1.25rem;font-weight:700;display:inline-block}.captcha-refresh-btn{cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;transition:all .2s}.captcha-refresh-btn:hover{background:#e5e7eb}.captcha-refresh-icon{color:#374151;width:1.25rem;height:1.25rem}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.form-submit-btn,.form-cancel-btn{cursor:pointer;border:none;border-radius:.5rem;flex:1;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s}.form-submit-btn{color:#fff;background:#1e40af}.form-submit-btn:hover{background:#1e3a8a}.form-cancel-btn{color:#374151;background:#e5e7eb}.form-cancel-btn:hover{background:#d1d5db}.form-submit-btn:disabled,.form-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.suggestion-form-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.captcha-display-svg{background:#f3f4f6;border:2px solid #d1d5db;border-radius:.375rem;align-items:center;min-width:150px;min-height:50px;padding:.25rem .5rem;display:inline-flex}.captcha-display-svg svg{max-width:150px;max-height:50px}.suggestions-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.suggestions-filter-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;align-items:center;gap:.75rem;padding:.5rem 1rem;transition:all .2s;display:flex}.suggestions-filter-wrapper:hover,.suggestions-filter-wrapper:focus-within{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.filter-icon{color:#6b7280;width:1.25rem;height:1.25rem}.suggestions-filter-select{color:#111827;cursor:pointer;background:0 0;border:none;outline:none;padding-right:1.5rem;font-size:.875rem;font-weight:500}.suggestions-filter-select:focus{box-shadow:none}.suggestion-card{background:#fff;border:1px solid #0000;border-radius:.75rem;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000001a}.suggestion-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.suggestion-card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.suggestion-category-badge{border-radius:9999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.category-feature{color:#1e40af;background:#dbeafe}.category-improvement{color:#166534;background:#dcfce7}.category-bug{color:#991b1b;background:#fee2e2}.category-other{color:#4b5563;background:#f3f4f6}.suggestion-date{color:#6b7280;align-items:center;gap:.25rem;font-size:.75rem;display:flex}.suggestion-meta-icon{width:.875rem;height:.875rem}.suggestion-card-title{color:#111827;margin:0;font-size:1.125rem;font-weight:600;line-height:1.4}.suggestion-card-description{color:#4b5563;flex-grow:1;margin:0;font-size:.875rem;line-height:1.6}.suggestion-expand-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;margin-left:.25rem;padding:0;font-size:.875rem;font-weight:500}.suggestion-expand-btn:hover{text-decoration:underline}.suggestion-card-footer{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.suggestion-author{color:#6b7280;align-items:center;gap:.25rem;font-size:.75rem;display:flex}.suggestion-votes{align-items:center;gap:.5rem;display:flex}.vote-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:9999px;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.75rem;transition:all .2s;display:inline-flex}.vote-btn:hover:not(:disabled){background:#f3f4f6}.vote-btn:disabled{opacity:.6;cursor:not-allowed}.vote-icon{width:.875rem;height:.875rem}.vote-count{font-weight:500}.vote-like.active{color:#16a34a;background:#dcfce7;border-color:#22c55e}.vote-dislike.active{color:#dc2626;background:#fee2e2;border-color:#ef4444}.suggestion-skeleton-card{background:#fff;border-radius:.75rem;flex-direction:column;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 1px 3px #0000001a}.skeleton-header{justify-content:space-between;align-items:center;display:flex}.skeleton-category{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:9999px;width:80px;height:24px;animation:1.5s infinite shimmer}.skeleton-date{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:.25rem;width:70px;height:16px;animation:1.5s infinite shimmer}.skeleton-title{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:.25rem;width:80%;height:24px;animation:1.5s infinite shimmer}.skeleton-text{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:.25rem;width:100%;height:14px;animation:1.5s infinite shimmer}.skeleton-text.short{width:60%}.skeleton-footer{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.skeleton-author{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:.25rem;width:100px;height:16px;animation:1.5s infinite shimmer}.skeleton-votes{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%) 0 0/200% 100%;border-radius:9999px;gap:.5rem;width:120px;height:28px;animation:1.5s infinite shimmer;display:flex}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.suggestions-grid-full{grid-column:1/-1;justify-content:center;align-items:center;padding:3rem 1rem;display:flex}.suggestions-empty-state-box{text-align:center;padding:2rem}.empty-state-icon{margin-bottom:1rem;font-size:3rem}.empty-state-message{color:#6b7280;margin:0;font-size:1.125rem}.suggestions-error-state{text-align:center;padding:2rem}.error-state-icon{color:#ef4444;width:3rem;height:3rem;margin-bottom:1rem}.error-state-message{color:#6b7280;margin:0 0 1rem;font-size:1rem}.error-retry-button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background .2s;display:inline-flex}.error-retry-button:hover{background:#1d4ed8}.retry-icon{width:1rem;height:1rem}.suggestions-pagination{justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;display:flex}.pagination-button{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;justify-content:center;align-items:center;min-width:2.5rem;height:2.5rem;padding:.5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.pagination-button:hover:not(:disabled):not(.active){background:#f3f4f6;border-color:#d1d5db}.pagination-button.active{color:#fff;background:#2563eb;border-color:#2563eb}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-icon{width:1rem;height:1rem}.pagination-ellipsis{color:#6b7280;padding:0 .5rem}.suggestions-stats{text-align:center;color:#6b7280;margin-top:1.5rem;font-size:.875rem}@media (max-width:640px){.suggestions-hero-section{padding:3rem 0}.suggestions-hero-title{font-size:1.5rem}.suggestions-hero-description{font-size:1rem}.suggestions-content-section{padding:3rem 0}.suggestions-submit-wrapper{justify-content:center}}.submit-btn-content{justify-content:center;align-items:center;gap:.5rem;display:flex}.submit-icon{width:1rem;height:1rem}.submit-icon.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
