:root{--bg-main: #faf6f6;--primary: #d91c1f;--primary-dark: #ac0f10;--secondary: #f0b14a;--accent: #b01216;--text-main: #1f1a1a;--text-muted: #6e5555;--card-bg: #ffffff;--shadow: 0 12px 24px rgba(140, 24, 24, .08);font-size:15px}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:PingFang SC,Helvetica Neue,Arial,sans-serif;color:var(--text-main);background:var(--bg-main);line-height:1.6}.page{min-height:100vh;background:var(--bg-main)}img{max-width:100%;display:block}button{font:inherit}.hero{position:relative;background:linear-gradient(135deg,#d91c1ff5,#ac0f10e6);color:#fff;padding:3rem 1.25rem 4.5rem;overflow:hidden}.hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,rgba(249,176,50,.35),transparent 60%);z-index:1}.hero__content{position:relative;z-index:2;max-width:640px;margin:0 auto;text-align:center}.hero__badge{display:inline-flex;align-items:center;gap:.375rem;background:#ffffff38;border-radius:999px;padding:.3rem .8rem;font-size:.78rem;letter-spacing:.08em}.hero__title{margin:1.5rem 0 .75rem;font-size:clamp(1.8rem,7vw,2.5rem);font-weight:700;letter-spacing:.08em}.hero__subtitle{margin:0;font-size:.92rem;opacity:.9}.hero__cta{display:flex;justify-content:center;gap:.6rem;margin-top:1.2rem}.hero__button,.hero__link{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.2rem;font-size:.9rem;border-radius:999px;border:none;cursor:pointer;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease}.hero__button{background:#fff;color:var(--primary);box-shadow:0 15px 30px #0000001f}.hero__link{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.4)}.hero__button:active,.hero__link:active{transform:scale(.97)}.tab-panel{display:none}.tab-panel.is-active{display:block}.main{padding-bottom:calc(3.8rem + env(safe-area-inset-bottom,0px))}.section{margin-top:-2rem;padding:1rem .75rem;border-radius:1.25rem 1.25rem 0 0;position:relative;z-index:2}.section--intro{background:#fff;box-shadow:var(--shadow)}.section--vote{background:linear-gradient(180deg,#f9fcff,#f3f6ff)}.section--ranking{background:#fff}.section__header{text-align:center;margin-bottom:.75rem}.section__header h2{font-size:1.2rem;margin:0;font-weight:700}.section__header p{margin:.35rem 0 0;color:var(--text-muted);font-size:.85rem}.card{background:var(--card-bg);border-radius:.9rem;padding:.9rem;box-shadow:var(--shadow);margin-bottom:.9rem}.card--highlight{border:1px solid rgba(217,28,31,.18)}.card h3{margin-top:0;margin-bottom:.6rem;font-size:1.1rem}.card p{color:var(--text-muted);margin-bottom:0}.grid-list{display:grid;grid-template-columns:1fr;gap:.9rem;margin-top:0;margin-bottom:.9rem}.grid-list .card{margin-bottom:0}.prize-list{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}.prize-list li{display:flex;flex-direction:column;gap:.25rem;padding:.7rem;border-radius:.8rem;background:#d91c1f0d}.prize-list span{font-size:.9rem;color:var(--primary-dark)}.prize-list strong{font-size:1rem;color:var(--text-main)}.vote-search{position:relative;margin-bottom:1rem;display:flex;align-items:center}.vote-search__input{width:100%;padding:.7rem 2.5rem .7rem 1rem;border-radius:.8rem;border:1px solid rgba(172,15,16,.18);background:#ffffffe6;font-size:.85rem;color:var(--text-main);outline:none;transition:border-color .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.vote-search__input::placeholder{color:var(--text-muted)}.vote-search__input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #d91c1f1a}.vote-search__clear{position:absolute;right:.5rem;width:1.8rem;height:1.8rem;border-radius:50%;background:#ac0f101a;color:var(--primary);border:none;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease;-webkit-tap-highlight-color:transparent;outline:none}.vote-search__clear:hover,.vote-search__clear:active{background:#ac0f1033;transform:scale(1.1)}.vote-filters-wrapper{position:relative;margin-bottom:1.1rem}.vote-filters{display:flex;overflow-x:auto;gap:.5rem;padding:.15rem 0;scrollbar-width:none;-webkit-overflow-scrolling:touch}.vote-filters::-webkit-scrollbar{display:none}.vote-filters__indicator{position:absolute;right:-.2rem;top:50%;transform:translateY(-50%);width:2.5rem;height:2rem;display:flex;align-items:center;justify-content:flex-end;background:linear-gradient(to right,#fff0,#fffffff2 40%,#fffffff2);pointer-events:none;z-index:1}.vote-filters__indicator-triangle{width:0;height:0;border-left:.4rem solid var(--primary);border-top:.35rem solid transparent;border-bottom:.35rem solid transparent;margin-right:.1rem;animation:slide-right 1.5s ease-in-out infinite}@keyframes slide-right{0%,to{transform:translate(0);opacity:.6}50%{transform:translate(.3rem);opacity:1}}.vote-filters__item{flex:0 0 auto;padding:.5rem 1rem;border-radius:999px;background:#ffffffe6;border:1px solid rgba(172,15,16,.18);color:var(--primary);font-size:.85rem;letter-spacing:.04em;transition:all .2s ease;cursor:pointer;white-space:nowrap;min-width:fit-content;-webkit-tap-highlight-color:transparent;outline:none}.vote-filters__item.is-active{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-color:transparent}.toast{position:fixed;top:2rem;left:50%;transform:translate(-50%);z-index:1000;padding:.85rem 1.5rem;border-radius:.8rem;text-align:center;font-size:.9rem;font-weight:500;box-shadow:0 8px 24px #00000026;min-width:200px;max-width:90%}.toast--success{background:#fff;color:var(--primary);border:1px solid rgba(217,28,31,.2)}.toast--error{background:#fff;color:var(--primary-dark);border:1px solid rgba(172,15,16,.2)}.toast-enter-active,.toast-leave-active{transition:all .3s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(-50%) translateY(-20px)}.vote-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.vote-card{background:#fff;border-radius:.9rem;padding:0;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(217,28,31,.12);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.vote-card:active{transform:scale(.98)}.vote-card__image{width:100%;aspect-ratio:750 / 866;object-fit:cover;display:block}.vote-card__content-wrapper{padding:.7rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.vote-card__header{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.vote-card__tag{display:inline-flex;padding:.35rem .85rem;border-radius:999px;background:#d91c1f14;color:var(--primary);font-size:.75rem}.vote-card__category{font-size:.75rem;color:var(--primary);background:#d91c1f14;padding:.3rem .75rem;border-radius:999px}.vote-card__title{margin:0;font-size:.9rem;font-weight:600;line-height:1.4;height:2.52rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.vote-card__info{display:flex;flex-direction:column;gap:.35rem;font-size:.75rem;color:var(--text-muted)}.vote-card__info p{margin:0;line-height:1.4}.vote-card__label{color:var(--text-main);font-weight:500}.vote-card__votes{color:var(--primary);font-weight:600}.vote-card__actions{display:flex;gap:.5rem;margin-top:auto}.vote-card__share{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;border-radius:.5rem;background:#d91c1f1a;color:var(--primary);font-size:.8rem;border:1px solid rgba(217,28,31,.2);cursor:pointer;transition:transform .2s ease,background .2s ease;-webkit-tap-highlight-color:transparent;outline:none;flex:1}.vote-card__share:active{transform:scale(.97);background:#d91c1f26}.vote-card__action{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;border-radius:.5rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:.8rem;border:none;cursor:pointer;box-shadow:0 4px 8px #ac0f1026;transition:transform .2s ease;-webkit-tap-highlight-color:transparent;outline:none;flex:1}.vote-card__action:active:not(:disabled){transform:scale(.97)}.vote-card__action:disabled,.vote-card__action--disabled{opacity:.6;cursor:not-allowed;transform:none}.vote-empty,.vote-loading,.vote-error{grid-column:1 / -1;margin:0;padding:1.2rem .9rem;text-align:center;color:var(--text-muted);background:#d91c1f0a;border-radius:.8rem}.vote-loading{color:var(--primary)}.vote-error{color:var(--primary-dark);background:#ac0f1014}.vote-loading-overlay{grid-column:1 / -1;position:sticky;top:0;z-index:10;padding:.6rem;text-align:center;color:var(--primary);background:#d91c1f14;border-radius:.6rem;font-size:.85rem;margin-bottom:.5rem}.vote-card--loading{opacity:.6;pointer-events:none}.ranking-card{background:var(--card-bg);border-radius:.9rem;box-shadow:var(--shadow);padding:.9rem;border:1px solid rgba(217,28,31,.12);margin-top:1rem}.ranking-card__header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:.75rem}.ranking-card__updated{font-size:.8rem;color:var(--text-muted)}.ranking-loading,.ranking-error,.ranking-empty{margin:0;padding:1rem .75rem;text-align:center;color:var(--text-muted);background:#d91c1f0a;border-radius:.8rem}.ranking-loading{color:var(--primary)}.ranking-error{color:var(--primary-dark);background:#ac0f1014}.ranking-list{margin:0;padding:0;list-style:none;display:grid;gap:.5rem}.ranking-item{display:grid;grid-template-columns:42px 1fr auto;gap:.5rem;align-items:center;padding:.6rem .7rem;border-radius:.8rem;background:#d91c1f0f}.ranking-item__index{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;position:relative}.ranking-item__index--gold{background:linear-gradient(135deg,gold,#ffb300);box-shadow:0 4px 12px #ffd70066}.ranking-item__index--silver{background:linear-gradient(135deg,silver,#a0a0a0);box-shadow:0 4px 12px #c0c0c066}.ranking-item__index--bronze{background:linear-gradient(135deg,#cd7f32,#b87333);box-shadow:0 4px 12px #cd7f3266}.ranking-item__medal{font-size:1.5rem;line-height:1}.ranking-item--gold{background:#ffd70014;border:1px solid rgba(255,215,0,.2)}.ranking-item--silver{background:#c0c0c014;border:1px solid rgba(192,192,192,.2)}.ranking-item--bronze{background:#cd7f3214;border:1px solid rgba(205,127,50,.2)}.ranking-item__name{font-size:.9rem;font-weight:600;color:var(--text-main)}.ranking-item__votes{font-size:.8rem;color:var(--primary);font-weight:600}.tab-bar{position:fixed;left:0;right:0;bottom:env(safe-area-inset-bottom,0);z-index:10;display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border-radius:1rem 1rem 0 0;box-shadow:0 -10px 20px #8c181814;padding:.35rem .5rem calc(.35rem + env(safe-area-inset-bottom,0px))}.tab-bar__item{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.28rem;border-radius:.8rem;border:none;background:transparent;color:var(--text-muted);font-size:.62rem;cursor:pointer;transition:background .2s ease,color .2s ease;text-decoration:none;-webkit-tap-highlight-color:transparent;outline:none}.tab-bar__item.is-active{background:#d91c1f14;color:var(--primary)}.tab-bar__item:hover,.tab-bar__item:focus{background:#d91c1f0d}.tab-bar__icon{font-size:.8rem}.tab-bar__label{letter-spacing:.02em}.footer{text-align:center;padding:1rem;background:#101a2f;color:#ffffffb3;font-size:.85rem}@media (min-width: 768px){.hero{padding:4.5rem 2.5rem 7rem}.section{padding:4rem 2.5rem 3.75rem}.vote-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tab-bar{padding:.65rem 2.5rem 1rem}}.detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}.detail-panel{position:relative;background:#fff;border-radius:1rem;max-width:600px;width:100%;max-height:90vh;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column}.detail-close{position:absolute;top:1rem;right:1rem;width:2.5rem;height:2.5rem;border-radius:50%;background:#0009;color:#fff;border:none;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s ease;-webkit-tap-highlight-color:transparent;outline:none;box-shadow:0 4px 12px #0000004d}.detail-close:hover,.detail-close:active{background:#000000b3}.detail-content{display:flex;flex-direction:column;position:relative;min-height:300px;overflow-y:auto;flex:1;min-height:0}.detail-image{width:100%;height:auto;object-fit:contain;display:block;border-radius:1rem 1rem 0 0}.detail-info{padding:1.5rem}.detail-title{margin:0 0 1.2rem;font-size:1.3rem;font-weight:700;color:var(--text-main);line-height:1.4}.detail-meta{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem;padding:1rem;background:#d91c1f0d;border-radius:.8rem;border:1px solid rgba(217,28,31,.1)}.detail-meta__item{margin:0;font-size:.9rem;line-height:1.5}.detail-meta__label{color:var(--text-muted);font-weight:500}.detail-meta__value{color:var(--text-main);font-weight:600}.detail-meta__value--votes{color:var(--primary);font-size:1rem}.detail-description{margin-bottom:1.5rem}.detail-description__title{margin:0 0 .8rem;font-size:1.1rem;font-weight:600;color:var(--text-main)}.detail-description__content{margin:0;font-size:.9rem;line-height:1.8;color:var(--text-muted);white-space:pre-wrap;word-wrap:break-word}.detail-vote-btn{width:100%;padding:.85rem 1.5rem;border-radius:.6rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:1rem;font-weight:600;border:none;cursor:pointer;box-shadow:0 8px 16px #ac0f1033;transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent;outline:none}.detail-vote-btn:active:not(:disabled){transform:scale(.98)}.detail-vote-btn:disabled,.detail-vote-btn--disabled{opacity:.6;cursor:not-allowed;transform:none}.detail-enter-active,.detail-leave-active{transition:opacity .3s ease}.detail-enter-active .detail-panel,.detail-leave-active .detail-panel{transition:transform .3s ease,opacity .3s ease}.detail-enter-from,.detail-leave-to{opacity:0}.detail-enter-from .detail-panel,.detail-leave-to .detail-panel{transform:scale(.9) translateY(20px);opacity:0}.share-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:1001;display:flex;align-items:flex-start;justify-content:center;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.share-modal{position:relative;background:transparent;width:100%;max-width:90%;display:flex;flex-direction:column;align-items:center;padding:0;margin:1rem auto;min-height:min-content}@media (min-height: 600px){.share-modal-overlay{align-items:center}.share-modal{margin:auto}}.share-modal__image-wrapper{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.share-modal__close{position:absolute;top:.5rem;right:.5rem;width:2.5rem;height:2.5rem;border-radius:50%;background:#000000b3;color:#fff;border:2px solid rgba(255,255,255,.9);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s ease,transform .2s ease;-webkit-tap-highlight-color:transparent;outline:none;box-shadow:0 4px 12px #0006}.share-modal__close:hover,.share-modal__close:active{background:#000000e6;transform:scale(1.1)}.share-modal__image{width:100%;max-width:100%;height:auto;object-fit:contain;display:block;margin:0 auto 1rem;border-radius:0}.share-modal__hint{margin:0;font-size:.9rem;color:#fffffff2;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.5);font-weight:500;padding:.5rem 1rem;background:#0000004d;border-radius:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.share-modal-enter-active,.share-modal-leave-active{transition:opacity .3s ease}.share-modal-enter-active .share-modal,.share-modal-leave-active .share-modal{transition:transform .3s ease,opacity .3s ease}.share-modal-enter-from,.share-modal-leave-to{opacity:0}.share-modal-enter-from .share-modal,.share-modal-leave-to .share-modal{transform:scale(.9) translateY(20px);opacity:0}@media (min-width: 1024px){:root{font-size:17px}.hero{padding-bottom:8rem}.section{margin:-3.5rem auto 0;max-width:1100px}.section--vote{margin-top:-3rem}.vote-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-panel{max-width:700px}}
