/* ============================================
   C7数字炼金公会 - 主样式表 cg-style.css
   CSS前缀: cg-
   设计风格: 羊皮纸中世纪手绘风
   ============================================ */

/* --- Google Fonts 本地化替代 --- */
@import url('https://fonts.googleapis.com/css2?family=Uncial+Antiqua&family=Noto+Serif+SC:wght@400;600;700&family=MedievalSharp&display=swap');

/* --- CSS Variables --- */
:root {
  --cg-parchment: #D2B48C;
  --cg-ink-brown: #8B4513;
  --cg-gold: #FFD700;
  --cg-wax-red: #800000;
  --cg-bg: #F5DEB3;
  --cg-text: #362419;
  --cg-text-light: #7A5C43;
  --cg-silver: #C0C0C0;
  --cg-bronze: #CD7F32;
  --cg-shadow: 0 2px 8px rgba(139,69,19,0.2);
  --cg-font-title: 'Uncial Antiqua', 'MedievalSharp', cursive;
  --cg-font-body: 'Noto Serif SC', 'Georgia', serif;
  --cg-radius: 2px;
  --cg-container: 1200px;
}

/* --- Reset & Base --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--cg-font-body);
  color: var(--cg-text);
  background-color: var(--cg-bg);
  line-height: 1.8;
  overflow-x: hidden;
}
a { color: var(--cg-ink-brown); text-decoration: none; transition: color 0.3s; }
a:hover { color: var(--cg-gold); }
img { max-width: 100%; height: auto; display: block; border-radius: var(--cg-radius); }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-family: var(--cg-font-title); color: var(--cg-ink-brown); line-height: 1.3; }

/* --- Container --- */
.cg-container { max-width: var(--cg-container); margin: 0 auto; padding: 0 20px; }

/* --- Navigation --- */
.cg-nav {
  background: linear-gradient(180deg, #5C3317 0%, #3E2210 100%);
  background-size: cover;
  position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
  border-bottom: 3px solid var(--cg-gold);
}
.cg-nav-inner {
  max-width: var(--cg-container);
  margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between;
  height: 70px;
}
.cg-nav-logo { display: flex; align-items: center; gap: 10px; }
.cg-nav-logo img { height: 50px; width: auto; border-radius: 0; }
.cg-nav-logo span { font-family: var(--cg-font-title); color: var(--cg-gold); font-size: 1.5rem; }
.cg-nav-links { display: flex; align-items: center; gap: 6px; }
.cg-nav-links a {
  color: #F5DEB3; font-size: 0.95rem; padding: 8px 12px;
  position: relative; transition: color 0.3s;
  font-family: var(--cg-font-body); font-weight: 600;
}
.cg-nav-links a::after {
  content: ''; position: absolute; bottom: 2px; left: 50%; width: 0;
  height: 2px; background: var(--cg-gold);
  transition: all 0.3s; transform: translateX(-50%);
  border-radius: 2px;
}
.cg-nav-links a:hover { color: var(--cg-gold); }
.cg-nav-links a:hover::after { width: 80%; }
.cg-nav-cta {
  background: var(--cg-wax-red); color: #F5DEB3 !important;
  padding: 10px 20px !important; border-radius: var(--cg-radius);
  font-weight: 700; border: 1px solid #a00000;
  transition: all 0.3s; box-shadow: 0 0 10px rgba(128,0,0,0.3);
}
.cg-nav-cta:hover {
  background: #a00000; box-shadow: 0 0 20px rgba(255,215,0,0.4);
  color: var(--cg-gold) !important;
}
.cg-nav-cta::after { display: none !important; }

/* Hamburger */
.cg-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 5px; }
.cg-hamburger span { display: block; width: 28px; height: 3px; background: var(--cg-gold); border-radius: 2px; transition: 0.3s; }

/* --- Hero Banner --- */
.cg-hero {
  min-height: 100vh; position: relative; display: flex; align-items: center; justify-content: center;
  background: url('../images/cg-hero-astrolabe.webp') center/cover no-repeat;
  text-align: center; overflow: hidden;
}
.cg-hero::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(245,222,179,0.85) 0%, rgba(210,180,140,0.9) 50%, rgba(139,69,19,0.7) 100%);
}
.cg-hero-content { position: relative; z-index: 2; max-width: 900px; padding: 40px 20px; }
.cg-hero-badge {
  display: inline-block; background: var(--cg-wax-red); color: #F5DEB3;
  padding: 8px 24px; font-size: 0.9rem; border-radius: var(--cg-radius);
  margin-bottom: 24px; font-weight: 600;
  box-shadow: 0 2px 8px rgba(128,0,0,0.3);
}
.cg-hero h1 { font-size: 3.5rem; margin-bottom: 20px; color: var(--cg-ink-brown); }
.cg-hero h1 .cg-text-gold {
  background: linear-gradient(135deg, var(--cg-gold), #FFA500);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.cg-hero-subtitle { color: var(--cg-text-light); font-size: 1.1rem; max-width: 640px; margin: 0 auto 32px; line-height: 1.9; }
.cg-hero-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 48px; }
.cg-btn-primary {
  background: linear-gradient(135deg, var(--cg-gold), #FFA500);
  color: var(--cg-text); padding: 14px 32px; font-weight: 700;
  border-radius: var(--cg-radius); font-size: 1.05rem;
  box-shadow: var(--cg-shadow); transition: all 0.3s; border: none; cursor: pointer;
  font-family: var(--cg-font-body);
}
.cg-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(255,215,0,0.4); color: var(--cg-text); }
.cg-btn-outline {
  background: transparent; color: var(--cg-ink-brown); padding: 14px 32px;
  font-weight: 700; border-radius: var(--cg-radius); font-size: 1.05rem;
  border: 2px solid var(--cg-ink-brown); transition: all 0.3s; cursor: pointer;
  font-family: var(--cg-font-body);
}
.cg-btn-outline:hover { background: var(--cg-ink-brown); color: #F5DEB3; }
.cg-hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cg-hero-stat { text-align: center; }
.cg-hero-stat-num { font-family: var(--cg-font-title); font-size: 2rem; color: var(--cg-gold); display: block; text-shadow: 1px 1px 2px rgba(0,0,0,0.2); }
.cg-hero-stat-label { font-size: 0.85rem; color: var(--cg-text-light); }

/* --- Section Base --- */
.cg-section { padding: 80px 0; }
.cg-section-title {
  text-align: center; font-size: 2.2rem; margin-bottom: 16px;
  color: var(--cg-ink-brown); position: relative; padding-bottom: 16px;
}
.cg-section-title::after {
  content: ''; position: absolute; bottom: 0; left: 50%;
  transform: translateX(-50%); width: 80px; height: 3px;
  background: linear-gradient(90deg, transparent, var(--cg-gold), transparent);
}
.cg-section-desc { text-align: center; color: var(--cg-text-light); max-width: 700px; margin: 0 auto 48px; font-size: 1rem; }

/* --- Bulletin (王国公报) --- */
.cg-bulletin { background: url('../images/cg-parchment-bg.webp') center/cover; }
.cg-bulletin-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cg-lotto-card {
  background: rgba(245,222,179,0.9); border: 2px solid var(--cg-parchment);
  border-radius: var(--cg-radius); padding: 24px; box-shadow: var(--cg-shadow);
  transition: transform 0.3s;
}
.cg-lotto-card:hover { transform: translateY(-4px); }
.cg-lotto-card-flag {
  display: inline-block; background: var(--cg-wax-red); color: #F5DEB3;
  padding: 4px 12px; font-size: 0.8rem; border-radius: var(--cg-radius);
  margin-bottom: 12px; font-weight: 600;
}
.cg-lotto-card h3 { font-size: 1.2rem; margin-bottom: 8px; }
.cg-lotto-card-numbers { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }
.cg-lotto-num {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cg-gold), #FFA500);
  color: var(--cg-text); display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 0.9rem; box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
.cg-lotto-num.cg-special { background: linear-gradient(135deg, var(--cg-wax-red), #a00000); color: #F5DEB3; }
.cg-lotto-card-note { font-size: 0.85rem; color: var(--cg-text-light); font-style: italic; margin-top: 8px; }

/* --- Video Section --- */
.cg-video-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cg-video-card {
  background: rgba(62,34,16,0.9); border-radius: var(--cg-radius);
  overflow: hidden; box-shadow: var(--cg-shadow); position: relative;
  border: 3px solid #5C3317;
}
.cg-video-card video { width: 100%; display: block; aspect-ratio: 16/9; object-fit: cover; }
.cg-video-card-duration {
  position: absolute; top: 12px; right: 12px;
  background: rgba(0,0,0,0.7); color: var(--cg-gold);
  padding: 4px 10px; font-size: 0.8rem; border-radius: var(--cg-radius);
  font-family: var(--cg-font-title);
}
.cg-video-card-info { padding: 16px; }
.cg-video-card-info h3 { color: var(--cg-gold); font-size: 1.1rem; margin-bottom: 8px; }
.cg-video-card-info p { color: #D2B48C; font-size: 0.9rem; }

/* --- Ranking --- */
.cg-ranking-wrap { display: grid; grid-template-columns: 1fr 1.5fr; gap: 40px; align-items: start; }
.cg-podium { display: flex; align-items: flex-end; justify-content: center; gap: 16px; padding: 40px 0; }
.cg-podium-item { text-align: center; }
.cg-podium-avatar {
  width: 70px; height: 70px; border-radius: 50%; margin: 0 auto 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; font-weight: 700; font-family: var(--cg-font-title);
}
.cg-podium-gold .cg-podium-avatar { background: linear-gradient(135deg, #FFD700, #FFA500); color: #362419; border: 3px solid #FFD700; }
.cg-podium-silver .cg-podium-avatar { background: linear-gradient(135deg, #C0C0C0, #A0A0A0); color: #362419; border: 3px solid #C0C0C0; }
.cg-podium-bronze .cg-podium-avatar { background: linear-gradient(135deg, #CD7F32, #A0522D); color: #F5DEB3; border: 3px solid #CD7F32; }
.cg-podium-base { padding: 12px 20px; border-radius: var(--cg-radius) var(--cg-radius) 0 0; min-width: 100px; }
.cg-podium-gold .cg-podium-base { background: linear-gradient(0deg, #B8860B, #FFD700); height: 100px; }
.cg-podium-silver .cg-podium-base { background: linear-gradient(0deg, #808080, #C0C0C0); height: 75px; }
.cg-podium-bronze .cg-podium-base { background: linear-gradient(0deg, #8B4513, #CD7F32); height: 55px; }
.cg-podium-name { font-weight: 700; font-size: 0.9rem; margin-top: 4px; }
.cg-podium-amount { font-size: 0.8rem; color: var(--cg-text-light); }

.cg-ranking-table {
  width: 100%; border-collapse: collapse;
  background: rgba(245,222,179,0.9); box-shadow: var(--cg-shadow);
  border-radius: var(--cg-radius); overflow: hidden;
}
.cg-ranking-table th {
  background: var(--cg-ink-brown); color: var(--cg-gold);
  padding: 12px 16px; text-align: left; font-family: var(--cg-font-title); font-size: 0.9rem;
}
.cg-ranking-table td { padding: 12px 16px; border-bottom: 1px solid rgba(139,69,19,0.15); font-size: 0.9rem; }
.cg-ranking-table tr:hover { background: rgba(255,215,0,0.1); }
.cg-rank-1 { color: #FFD700; font-weight: 700; }
.cg-rank-2 { color: #C0C0C0; font-weight: 700; }
.cg-rank-3 { color: #CD7F32; font-weight: 700; }

/* --- Strategy Cards --- */
.cg-strategy-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cg-strategy-card {
  background: rgba(245,222,179,0.95); border: 2px solid var(--cg-parchment);
  border-radius: var(--cg-radius); padding: 28px; box-shadow: var(--cg-shadow);
  transition: transform 0.3s; position: relative; overflow: hidden;
}
.cg-strategy-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--cg-gold), var(--cg-wax-red));
}
.cg-strategy-card:hover { transform: translateY(-4px); }
.cg-strategy-card-icon { font-size: 2.5rem; margin-bottom: 16px; }
.cg-strategy-card h3 { font-size: 1.15rem; margin-bottom: 12px; }
.cg-strategy-card p { font-size: 0.9rem; color: var(--cg-text-light); margin-bottom: 16px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.cg-strategy-card a { color: var(--cg-gold); font-weight: 600; font-size: 0.9rem; }

/* --- Guild Recruit --- */
.cg-guild-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
.cg-guild-info {
  background: rgba(245,222,179,0.95); padding: 40px; border-radius: var(--cg-radius);
  box-shadow: var(--cg-shadow); border: 2px solid var(--cg-parchment);
}
.cg-guild-info h3 { font-size: 1.6rem; margin-bottom: 20px; }
.cg-guild-info ul { padding-left: 0; }
.cg-guild-info li { padding: 10px 0 10px 32px; position: relative; font-size: 0.95rem; border-bottom: 1px dashed rgba(139,69,19,0.2); }
.cg-guild-info li::before { content: '✦'; position: absolute; left: 0; color: var(--cg-gold); font-size: 1.1rem; }
.cg-guild-form {
  background: linear-gradient(135deg, #5C3317, #3E2210); padding: 40px;
  border-radius: var(--cg-radius); box-shadow: var(--cg-shadow);
  border: 2px solid #7A5C43;
}
.cg-guild-form h4 { color: var(--cg-gold); font-size: 1.3rem; margin-bottom: 24px; }
.cg-form-input {
  width: 100%; padding: 12px 16px; margin-bottom: 16px;
  background: rgba(245,222,179,0.15); border: 1px solid #7A5C43;
  border-radius: var(--cg-radius); color: #F5DEB3; font-size: 0.95rem;
  font-family: var(--cg-font-body); transition: border-color 0.3s;
}
.cg-form-input::placeholder { color: #A08060; }
.cg-form-input:focus { outline: none; border-color: var(--cg-gold); }
.cg-form-textarea { min-height: 80px; resize: vertical; }
.cg-btn-seal {
  background: var(--cg-wax-red); color: #F5DEB3; padding: 14px 32px;
  border: none; border-radius: var(--cg-radius); font-size: 1rem;
  font-weight: 700; cursor: pointer; transition: all 0.3s; width: 100%;
  font-family: var(--cg-font-body);
}
.cg-btn-seal:hover { background: #a00000; box-shadow: 0 0 20px rgba(255,215,0,0.3); }

/* --- Crystal Ball --- */
.cg-crystal { text-align: center; background: linear-gradient(180deg, var(--cg-bg), #E8D5B0); }
.cg-crystal-ball-wrap {
  width: 220px; height: 220px; margin: 0 auto 32px;
  border-radius: 50%; position: relative;
  background: radial-gradient(circle at 35% 35%, rgba(255,255,255,0.4), rgba(139,69,19,0.1), rgba(128,0,128,0.15));
  box-shadow: 0 0 40px rgba(255,215,0,0.3), inset 0 0 30px rgba(255,215,0,0.1);
  animation: cg-pulse-light 3s ease-in-out infinite;
  overflow: hidden;
}
.cg-crystal-ball-wrap img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
@keyframes cg-pulse-light {
  0%, 100% { box-shadow: 0 0 40px rgba(255,215,0,0.3), inset 0 0 30px rgba(255,215,0,0.1); }
  50% { box-shadow: 0 0 60px rgba(255,215,0,0.5), inset 0 0 40px rgba(255,215,0,0.2); }
}
.cg-crystal-input-wrap {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 24px;
}
.cg-crystal-input {
  width: 50px; height: 50px; text-align: center; font-size: 1.2rem; font-weight: 700;
  border: 2px solid var(--cg-parchment); border-radius: var(--cg-radius);
  background: rgba(245,222,179,0.8); color: var(--cg-text);
  font-family: var(--cg-font-body);
}
.cg-crystal-input:focus { outline: none; border-color: var(--cg-gold); }
.cg-crystal-result {
  background: rgba(245,222,179,0.9); padding: 24px; border-radius: var(--cg-radius);
  box-shadow: var(--cg-shadow); max-width: 500px; margin: 24px auto 0;
  display: none;
}
.cg-crystal-result.cg-active { display: block; }
.cg-crystal-hall { margin-top: 32px; }
.cg-crystal-hall h4 { font-size: 1.1rem; margin-bottom: 16px; color: var(--cg-gold); }

/* --- History Scrolls --- */
.cg-scrolls-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cg-report-card {
  display: grid; grid-template-columns: 1fr 1.5fr; gap: 0;
  background: rgba(245,222,179,0.95); border-radius: var(--cg-radius);
  overflow: hidden; box-shadow: var(--cg-shadow); transition: transform 0.3s;
  border: 2px solid var(--cg-parchment);
}
.cg-report-card:hover { transform: translateY(-4px); }
.cg-report-card-img { overflow: hidden; }
.cg-report-card-img img { width: 100%; height: 100%; object-fit: cover; }
.cg-report-card-body { padding: 20px; }
.cg-report-card-body h3 { font-size: 1.05rem; margin-bottom: 8px; }
.cg-report-card-body p { font-size: 0.85rem; color: var(--cg-text-light); margin-bottom: 12px; }
.cg-report-card-meta { font-size: 0.8rem; color: var(--cg-text-light); }
.cg-report-card-meta span { display: block; }

/* --- Lucky Gallery --- */
.cg-gallery-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.cg-gallery-item {
  position: relative; overflow: hidden; border-radius: var(--cg-radius);
  box-shadow: var(--cg-shadow); cursor: pointer; aspect-ratio: 1;
}
.cg-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.cg-gallery-item:hover img { transform: scale(1.08); }
.cg-gallery-overlay {
  position: absolute; inset: 0; background: rgba(54,36,25,0.85);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s; padding: 16px; text-align: center;
}
.cg-gallery-item:hover .cg-gallery-overlay { opacity: 1; }
.cg-gallery-overlay h4 { color: var(--cg-gold); font-size: 1rem; margin-bottom: 8px; }
.cg-gallery-overlay p { color: #D2B48C; font-size: 0.8rem; }

/* --- Tavern (酒馆热议) --- */
.cg-tavern { background: url('../images/cg-tavern-board.webp') center/cover; position: relative; }
.cg-tavern::before { content: ''; position: absolute; inset: 0; background: rgba(62,34,16,0.92); }
.cg-tavern .cg-container { position: relative; z-index: 2; }
.cg-tavern .cg-section-title { color: var(--cg-gold); }
.cg-tavern .cg-section-title::after { background: linear-gradient(90deg, transparent, var(--cg-gold), transparent); }
.cg-tavern .cg-section-desc { color: #D2B48C; }
.cg-tavern-comments { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cg-tavern-comment {
  background: rgba(245,222,179,0.12); border: 1px solid rgba(255,215,0,0.2);
  border-radius: var(--cg-radius); padding: 24px; transition: transform 0.3s;
}
.cg-tavern-comment:hover { transform: translateY(-4px); border-color: var(--cg-gold); }
.cg-tavern-comment-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.cg-tavern-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--cg-gold); display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: var(--cg-text); font-size: 1.1rem;
}
.cg-tavern-name { color: var(--cg-gold); font-weight: 700; font-size: 0.95rem; }
.cg-tavern-time { color: #A08060; font-size: 0.8rem; }
.cg-tavern-comment p { color: #D2B48C; font-size: 0.9rem; line-height: 1.7; }

/* --- Certification --- */
.cg-cert { background: url('../images/cg-stone-texture.webp') center/cover; position: relative; }
.cg-cert::before { content: ''; position: absolute; inset: 0; background: rgba(30,20,10,0.88); }
.cg-cert .cg-container { position: relative; z-index: 2; }
.cg-cert .cg-section-title { color: var(--cg-gold); }
.cg-cert .cg-section-title::after { background: linear-gradient(90deg, transparent, var(--cg-gold), transparent); }
.cg-cert-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.cg-cert-item { text-align: center; }
.cg-cert-item img { max-width: 280px; margin: 0 auto 16px; box-shadow: 0 4px 20px rgba(0,0,0,0.4); }
.cg-cert-item h4 { color: var(--cg-gold); font-size: 1.1rem; margin-bottom: 8px; }
.cg-cert-item p { color: #D2B48C; font-size: 0.9rem; }

/* --- Footer --- */
.cg-footer {
  background: linear-gradient(180deg, #3E2210, #2A1508);
  color: #D2B48C; padding: 60px 0 0; border-top: 3px solid var(--cg-gold);
}
.cg-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 40px; margin-bottom: 40px; }
.cg-footer-col h4 { color: var(--cg-gold); font-size: 1.1rem; margin-bottom: 16px; font-family: var(--cg-font-title); }
.cg-footer-col p { font-size: 0.9rem; line-height: 1.8; margin-bottom: 12px; }
.cg-footer-col ul li { margin-bottom: 8px; }
.cg-footer-col ul li a { color: #D2B48C; font-size: 0.9rem; transition: color 0.3s; }
.cg-footer-col ul li a:hover { color: var(--cg-gold); }
.cg-footer-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.cg-footer-logo img { height: 40px; }
.cg-footer-logo span { font-family: var(--cg-font-title); color: var(--cg-gold); font-size: 1.3rem; }
.cg-footer-social { display: flex; gap: 12px; margin-top: 16px; }
.cg-footer-social a {
  width: 36px; height: 36px; border-radius: 50%; border: 1px solid #7A5C43;
  display: flex; align-items: center; justify-content: center;
  color: #D2B48C; transition: all 0.3s; font-size: 0.9rem;
}
.cg-footer-social a:hover { border-color: var(--cg-gold); color: var(--cg-gold); background: rgba(255,215,0,0.1); }
.cg-footer-seo {
  padding: 20px 0; border-top: 1px solid rgba(122,92,67,0.3);
  font-size: 0.75rem; color: #7A5C43; text-align: center; line-height: 1.8;
}
.cg-footer-bottom {
  padding: 20px 0; border-top: 1px solid rgba(122,92,67,0.3);
  text-align: center; font-size: 0.85rem; color: #7A5C43;
}
.cg-footer-bottom p { margin-bottom: 4px; }

/* --- Breadcrumb --- */
.cg-breadcrumb {
  padding: 16px 0; font-size: 0.85rem; color: var(--cg-text-light);
}
.cg-breadcrumb a { color: var(--cg-ink-brown); }
.cg-breadcrumb span { margin: 0 8px; color: var(--cg-text-light); }

/* --- Page Hero (Inner pages) --- */
.cg-page-hero {
  padding: 120px 0 60px; text-align: center; position: relative;
  background-size: cover; background-position: center;
}
.cg-page-hero::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(245,222,179,0.9), rgba(210,180,140,0.95));
}
.cg-page-hero .cg-container { position: relative; z-index: 2; }
.cg-page-hero h1 { font-size: 2.5rem; margin-bottom: 16px; }
.cg-page-hero p { color: var(--cg-text-light); max-width: 600px; margin: 0 auto; }

/* --- Article Content --- */
.cg-article { padding: 60px 0; }
.cg-article-content { max-width: 900px; margin: 0 auto; }
.cg-article-content h2 { font-size: 1.6rem; margin: 40px 0 16px; padding-bottom: 8px; border-bottom: 2px solid rgba(139,69,19,0.2); }
.cg-article-content h3 { font-size: 1.3rem; margin: 32px 0 12px; }
.cg-article-content p { margin-bottom: 20px; text-align: justify; }
.cg-article-content img { margin: 24px auto; box-shadow: var(--cg-shadow); }
.cg-article-content blockquote {
  border-left: 4px solid var(--cg-gold); padding: 16px 24px; margin: 24px 0;
  background: rgba(255,215,0,0.08); font-style: italic; color: var(--cg-text-light);
}
.cg-article-content table {
  width: 100%; border-collapse: collapse; margin: 24px 0;
  background: rgba(245,222,179,0.9); box-shadow: var(--cg-shadow);
}
.cg-article-content th {
  background: var(--cg-ink-brown); color: var(--cg-gold); padding: 12px;
  text-align: left; font-family: var(--cg-font-title);
}
.cg-article-content td { padding: 10px 12px; border-bottom: 1px solid rgba(139,69,19,0.15); }
.cg-article-links { margin-top: 40px; padding-top: 24px; border-top: 2px solid rgba(139,69,19,0.2); }
.cg-article-links h4 { margin-bottom: 12px; }
.cg-article-links ul li { padding: 6px 0; }
.cg-article-links ul li a { color: var(--cg-gold); }

/* --- FAQ --- */
.cg-faq-item { border-bottom: 1px solid rgba(139,69,19,0.2); padding: 16px 0; }
.cg-faq-question {
  font-weight: 700; cursor: pointer; display: flex; justify-content: space-between;
  align-items: center; font-size: 1.05rem; color: var(--cg-ink-brown);
}
.cg-faq-question::after { content: '+'; font-size: 1.5rem; color: var(--cg-gold); transition: transform 0.3s; }
.cg-faq-question.cg-active::after { transform: rotate(45deg); }
.cg-faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s; padding: 0; }
.cg-faq-answer.cg-active { max-height: 500px; padding-top: 12px; }
.cg-faq-answer p { color: var(--cg-text-light); font-size: 0.95rem; }

/* --- Live Draw Page --- */
.cg-draw-machine {
  max-width: 700px; margin: 0 auto 40px; text-align: center;
  background: rgba(245,222,179,0.9); padding: 40px; border-radius: var(--cg-radius);
  box-shadow: var(--cg-shadow); border: 3px solid var(--cg-parchment);
}
.cg-draw-machine img { max-width: 100%; margin: 0 auto 24px; border-radius: var(--cg-radius); }
.cg-draw-result { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin: 24px 0; min-height: 60px; }
.cg-draw-ball {
  width: 50px; height: 50px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cg-gold), #FFA500);
  color: var(--cg-text); display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1.1rem; box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  animation: cg-float-up 0.5s ease-out;
}
@keyframes cg-float-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.cg-draw-select {
  padding: 12px 20px; background: rgba(245,222,179,0.8); border: 2px solid var(--cg-parchment);
  border-radius: var(--cg-radius); font-size: 1rem; color: var(--cg-text);
  font-family: var(--cg-font-body); cursor: pointer; margin-bottom: 20px;
}
.cg-draw-history { margin-top: 40px; }

/* --- APP Download --- */
.cg-app-hero { text-align: center; padding: 80px 0; }
.cg-app-hero img { max-width: 600px; margin: 0 auto 32px; border-radius: var(--cg-radius); box-shadow: var(--cg-shadow); }
.cg-app-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin: 32px 0; }
.cg-app-btn {
  display: inline-flex; align-items: center; gap: 10px;
  background: linear-gradient(135deg, #5C3317, #3E2210); color: #F5DEB3;
  padding: 14px 28px; border-radius: var(--cg-radius); font-weight: 700;
  border: 2px solid #7A5C43; transition: all 0.3s; font-size: 0.95rem;
}
.cg-app-btn:hover { border-color: var(--cg-gold); color: var(--cg-gold); box-shadow: 0 0 15px rgba(255,215,0,0.3); }
.cg-app-qr { max-width: 200px; margin: 32px auto; padding: 16px; background: #fff; border-radius: var(--cg-radius); box-shadow: var(--cg-shadow); }

/* --- Utility --- */
.cg-text-gold { color: var(--cg-gold) !important; }
.cg-text-center { text-align: center; }
.cg-mb-0 { margin-bottom: 0; }
.cg-mt-40 { margin-top: 40px; }
.cg-parchment-bg { background: url('../images/cg-parchment-bg.webp') center/cover; }
.cg-ink-divider {
  height: 30px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 30'%3E%3Cpath d='M0,15 Q300,0 600,15 T1200,15' fill='none' stroke='%238B4513' stroke-width='2' opacity='0.3'/%3E%3C/svg%3E") center/contain no-repeat;
  margin: 0;
}
