/* ===== wc_rose: 世界杯玫红 · 粉色风暴 ===== */
:root {
    --tpl-primary: #c05080; --tpl-primary-dark: #a04070; --tpl-secondary: #f8bbd0;
    --tpl-accent: #f8bbd0; --tpl-btn-bg: #c05080; --tpl-btn-color: #fff;
    --tpl-hero-from: #1a050f; --tpl-hero-via: #2d0a1e; --tpl-hero-to: #1a050f;
    --tpl-hero-strong: #f8bbd0; --tpl-sec-from: #1a050f; --tpl-sec-to: #2d0a1e;
    --tpl-app-from: #1a050f; --tpl-app-to: #2d0a1e;
    --tpl-brand-mark: linear-gradient(135deg, #c05080, #f8bbd0);
    --tpl-about-bg: linear-gradient(135deg, #1a050f, #2d0a1e);
    --tpl-article-hero: linear-gradient(135deg, #1a050f, #2d0a1e);
    --tpl-faq-icon-bg: linear-gradient(135deg, #c05080, #f8bbd0);
    --tpl-faq-line: linear-gradient(to bottom, #c05080, #f8bbd0);
    --tpl-world-map: linear-gradient(135deg, #1a050f, #2d0a1e);
    --tpl-placeholder-bg: linear-gradient(135deg, #1a050f, #2d0a1e);
}
body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", Arial, sans-serif; background: #fdf2f6; color: #333; }
a { transition: all 0.3s; } img { max-width: 100%; height: auto; }
.hover-effect { transition: transform 0.3s, box-shadow 0.3s; }
.hover-effect:hover { transform: translateY(-5px); box-shadow: 0 .5rem 1rem rgba(192,80,128,.18) !important; }
.article-content { line-height: 1.9; color: #333; font-size: 16px; }
.article-content h2, .article-content h3, .article-content h4 { margin-top: 1.6em; margin-bottom: .8em; font-weight: 700; color: #222; }
.article-content h3 { font-size: 1.25rem; border-left: 4px solid var(--tpl-primary); padding-left: 12px; }
.article-content p { margin-bottom: 1.2em; }
.article-content img { max-width: 100%; height: auto; border-radius: 8px; margin: 12px 0; }
.article-content ul, .article-content ol { padding-left: 1.5rem; margin-bottom: 1.2em; }
.article-hero { position: relative; min-height: 320px; background-size: cover; background-position: center; background-repeat: no-repeat; }
.article-hero .overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.65)); padding: 30px 16px; }
.article-hero h1 { font-size: 1.8rem; max-width: 900px; line-height: 1.4; }
@media (min-width: 768px) { .article-hero { min-height: 380px; } .article-hero h1 { font-size: 2.2rem; } }
.fanye .pagination, .fanye ul { display: inline-flex; list-style: none; padding: 0; margin: 0; gap: 6px; flex-wrap: wrap; justify-content: center; }
.fanye li, .fanye span, .fanye a { display: inline-block; }
.fanye a, .fanye span { padding: 8px 14px; border: 1px solid #dee2e6; border-radius: 6px; color: #495057; text-decoration: none; background: #fff; transition: all .2s; }
.fanye a:hover, .fanye li.active span, .fanye li.active a, .fanye .current { background: var(--tpl-primary); color: #fff; border-color: var(--tpl-primary); }
#hero-10.hero-10-section { position: relative; min-height: 480px; background: linear-gradient(135deg, var(--tpl-hero-from), var(--tpl-hero-via) 50%, var(--tpl-hero-to)); color: #fff; padding: 90px 16px; overflow: hidden; }
.hero-10-grid-bg { position: absolute; inset: 0; background-image: linear-gradient(rgba(248,187,208,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(248,187,208,.06) 1px, transparent 1px); background-size: 40px 40px; opacity: .5; }
.hero-10-container { position: relative; z-index: 2; max-width: 920px; margin: 0 auto; }
.hero-10-container h1 { font-size: 2.4rem; font-weight: 800; margin-bottom: 16px; }
.hero-10-container h1 strong { color: var(--tpl-hero-strong); }
.hero-10-container p { color: rgba(248,187,208,.85); font-size: 1.05rem; max-width: 760px; margin: 0 auto 28px; }
.hero-10-buttons { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }
.hero-10-buttons a { display: inline-flex; align-items: center; gap: 8px; padding: 12px 26px; border-radius: 50px; text-decoration: none; font-weight: 600; background: var(--tpl-btn-bg); color: var(--tpl-btn-color); transition: all .3s; border: 2px solid var(--tpl-btn-bg); }
.hero-10-buttons a:nth-child(2) { background: transparent; color: #fff; border-color: rgba(248,187,208,.5); }
.hero-10-buttons a:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(192,80,128,.3); }
@media (max-width: 576px) { .hero-10-container h1 { font-size: 1.7rem; } }
.faq-11-title { font-size: 1.7rem; font-weight: 800; color: var(--tpl-hero-from); }
.faq-11-desc { color: rgba(248,187,208,.6); }
.faq-11-timeline { position: relative; max-width: 880px; margin: 0 auto; padding-left: 50px; }
.faq-11-timeline::before { content: ''; position: absolute; left: 18px; top: 0; bottom: 0; width: 2px; background: var(--tpl-faq-line); }
.faq-11-step { position: relative; margin-bottom: 28px; background: #2d0a1e; border-radius: 12px; padding: 20px 22px; box-shadow: 0 2px 8px rgba(0,0,0,.2); border: 1px solid rgba(248,187,208,.2); }
.faq-11-icon { position: absolute; left: -50px; top: 18px; width: 38px; height: 38px; border-radius: 50%; background: var(--tpl-faq-icon-bg); color: #fff; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.faq-11-step h5 { font-size: 1.05rem; font-weight: 700; margin-bottom: 8px; color: #f8bbd0; }
.faq-11-step p { color: rgba(248,187,208,.7); margin: 0; line-height: 1.7; }
#app-14 { background: linear-gradient(135deg, var(--tpl-app-from), var(--tpl-app-to)); color: #fff; }
.app14-rating-box { background: rgba(248,187,208,.12); border: 1px solid rgba(248,187,208,.2); color: #f8bbd0; }
.btn-glass { background: rgba(248,187,208,.18); color: #fff !important; border: 1px solid rgba(248,187,208,.35); backdrop-filter: blur(6px); }
.btn-glass:hover { background: rgba(248,187,208,.32); color: #fff; }
.py-6 { padding-top: 4.5rem !important; padding-bottom: 4.5rem !important; }
.site-brand-text { font-size: 22px; color: #c05080 !important; text-decoration: none; display: inline-flex; align-items: center; }
.site-brand-text .brand-mark { width: 36px; height: 36px; border-radius: 8px; background: var(--tpl-brand-mark); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 16px; }
#header-7 .navbar-nav .nav-link { color: #555; font-size: 15px; }
#header-7 .navbar-nav .nav-link.active, #header-7 .navbar-nav .nav-link:hover { color: var(--tpl-primary) !important; }
#footer-12 a:hover { color: #f8bbd0 !important; }
.list-card-placeholder, .news-placeholder, .rel-thumb-placeholder, .list-no-img { background: var(--tpl-placeholder-bg); }
.list-no-img::before { content: '\f03e'; font-family: 'Font Awesome 6 Free'; font-weight: 900; color: rgba(192,80,128,.75); font-size: 1.5rem; display: flex; align-items: center; justify-content: center; height: 100%; }
