:root{
  --ink:#172027;
  --muted:#64727d;
  --paper:#f4efe5;
  --paper-2:#fffdf8;
  --line:#d9d0c1;
  --bronze:#9f642e;
  --bronze-dark:#70411f;
  --teal:#214e55;
  --teal-2:#2e6970;
  --gold:#d4a95c;
  --shadow:0 18px 48px rgba(38,31,20,.12);
  --shadow-sm:0 8px 24px rgba(38,31,20,.09);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;line-height:1.55}
a{color:inherit}
button,input,select{font:inherit}
button{cursor:pointer}
.site-header{position:sticky;top:0;z-index:50;background:rgba(22,31,38,.96);color:#fff;border-bottom:1px solid rgba(255,255,255,.12);backdrop-filter:blur(12px)}
.header-inner{max-width:1480px;margin:auto;min-height:72px;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:800;letter-spacing:.02em}
.brand-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(145deg,var(--gold),#8c5429);font-family:Georgia,serif;font-size:24px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.22)}
.brand-text small{display:block;color:#d9c9aa;font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.brand-text span{font-family:Georgia,"Times New Roman",serif;font-size:20px}
.header-nav{display:flex;align-items:center;gap:8px}
.header-nav a{color:#fff;text-decoration:none;padding:10px 12px;border-radius:10px;font-size:14px}
.header-nav a:hover{background:rgba(255,255,255,.1)}
.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 10% 20%,rgba(212,169,92,.25),transparent 28%),radial-gradient(circle at 90% 10%,rgba(65,124,129,.24),transparent 30%),linear-gradient(135deg,#172027 0%,#203840 55%,#102b31 100%);color:#fff}
.hero:after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,black,transparent 90%);pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:1480px;margin:auto;padding:70px 28px 58px;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:54px;align-items:end}
.eyebrow{display:inline-flex;gap:8px;align-items:center;color:#f1d59d;text-transform:uppercase;letter-spacing:.17em;font-weight:800;font-size:12px}
.hero h1{font-family:Georgia,"Times New Roman",serif;font-size:clamp(42px,6vw,78px);line-height:.99;max-width:920px;margin:14px 0 20px;font-weight:700}
.hero-copy{font-size:18px;max-width:820px;color:#dfe8e8;margin:0}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.stat{padding:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:16px;backdrop-filter:blur(6px)}
.stat strong{display:block;font-family:Georgia,serif;font-size:32px;color:#f0c87a;line-height:1}
.stat span{display:block;margin-top:7px;color:#d5dfdf;font-size:13px}
.controls-wrap{position:relative;z-index:4;max-width:1480px;margin:-26px auto 0;padding:0 28px}
.controls{background:var(--paper-2);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px;padding:18px;display:grid;grid-template-columns:minmax(280px,1.5fr) repeat(2,minmax(170px,.55fr)) auto;gap:12px;align-items:center}
.search-box{position:relative}
.search-box input{width:100%;height:48px;border:1px solid #cfc6b7;border-radius:13px;background:#fff;padding:0 48px 0 44px;outline:none}
.search-box input:focus,select:focus{border-color:var(--teal-2);box-shadow:0 0 0 3px rgba(46,105,112,.12)}
.search-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted)}
.clear-search{position:absolute;right:9px;top:50%;transform:translateY(-50%);border:0;background:transparent;border-radius:8px;padding:6px;color:var(--muted);display:none}
select{height:48px;border:1px solid #cfc6b7;border-radius:13px;background:#fff;padding:0 38px 0 13px;color:var(--ink);outline:none}
.group-toggle{display:flex;background:#ebe5da;border-radius:13px;padding:4px;white-space:nowrap}
.group-toggle button{border:0;background:transparent;padding:9px 13px;border-radius:10px;color:#59666e;font-weight:700;font-size:13px}
.group-toggle button.active{background:#fff;color:var(--teal);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.main-shell{max-width:1480px;margin:0 auto;padding:44px 28px 80px}
.collection-summary{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:26px}
.collection-summary h2{font-family:Georgia,serif;font-size:33px;margin:0}
.collection-summary p{margin:5px 0 0;color:var(--muted)}
.results-count{font-size:14px;font-weight:800;color:var(--teal);background:#e3ece9;border-radius:999px;padding:8px 12px}
.group-section{margin:0 0 44px;scroll-margin-top:100px}
.group-header{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line);padding-bottom:13px;margin-bottom:18px}
.group-icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;color:#fff;font-size:22px;font-family:Georgia,serif;box-shadow:var(--shadow-sm)}
.group-heading h3{font-family:Georgia,serif;font-size:27px;margin:0;line-height:1.1}
.group-heading p{margin:4px 0 0;color:var(--muted);font-size:13px}
.group-count{margin-left:auto;color:var(--muted);font-weight:800;font-size:13px}
.card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.civ-card{position:relative;display:flex;flex-direction:column;min-height:270px;background:var(--paper-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;text-decoration:none;box-shadow:0 4px 18px rgba(38,31,20,.055);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.civ-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#bda98b}
.card-banner{height:72px;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--accent),#172027)}
.card-banner:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.23),transparent 23%),repeating-linear-gradient(45deg,rgba(255,255,255,.055) 0 2px,transparent 2px 11px)}
.card-glyph{position:absolute;z-index:1;right:18px;top:8px;color:rgba(255,255,255,.78);font-family:Georgia,serif;font-size:43px}
.card-region{position:absolute;z-index:1;left:15px;bottom:11px;color:#fff;font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:800}
.card-body{display:flex;flex-direction:column;flex:1;padding:18px}
.card-era{align-self:flex-start;background:#eee8dc;color:#6a5945;border-radius:999px;padding:4px 8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.civ-card h4{font-family:Georgia,serif;font-size:22px;line-height:1.08;margin:11px 0 4px}
.card-alt{color:var(--bronze-dark);font-size:12px;min-height:18px}
.card-desc{color:#59666e;font-size:13px;margin:12px 0 16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;border-top:1px solid #e6ded2;padding-top:11px;font-size:12px;color:var(--muted)}
.card-link{font-weight:800;color:var(--teal)}
.empty-state{display:none;text-align:center;background:var(--paper-2);border:1px dashed #bfb4a4;border-radius:20px;padding:54px 20px}
.empty-state h3{font-family:Georgia,serif;font-size:26px;margin:0 0 8px}
.empty-state p{color:var(--muted);margin:0}
.site-footer{background:#172027;color:#c9d2d3;padding:34px 28px}
.footer-inner{max-width:1480px;margin:auto;display:flex;justify-content:space-between;gap:28px;align-items:center}
.footer-inner p{margin:0;max-width:860px;font-size:13px}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer-links a{color:#f0c87a;font-size:13px}

/* Detail page */
.detail-hero{position:relative;background:linear-gradient(135deg,#172027,#214e55);color:#fff;overflow:hidden}
.detail-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,var(--accent),transparent 36%);opacity:.45}
.detail-hero-inner{position:relative;z-index:1;max-width:1380px;margin:auto;padding:72px 28px 54px;display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:48px;align-items:end}
.breadcrumb{display:flex;gap:8px;align-items:center;color:#d5dfdf;font-size:13px;margin-bottom:20px}
.breadcrumb a{color:#f0c87a}
.detail-hero h1{font-family:Georgia,serif;font-size:clamp(45px,7vw,86px);line-height:.95;margin:0 0 13px}
.alt-names{font-size:16px;color:#efd8aa;margin-bottom:18px}
.detail-lede{font-size:18px;max-width:850px;color:#e3ebeb;margin:0}
.detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.meta-box{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:16px}
.meta-box span{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:10px;color:#cbd7d8;font-weight:800}
.meta-box strong{display:block;margin-top:6px;font-family:Georgia,serif;font-size:18px}
.detail-nav{position:sticky;top:72px;z-index:35;background:rgba(255,253,248,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}
.detail-nav-inner{max-width:1380px;margin:auto;padding:0 28px;display:flex;align-items:center;gap:7px;overflow-x:auto}
.detail-nav a{text-decoration:none;padding:15px 11px;font-size:13px;font-weight:800;color:#53616a;white-space:nowrap;border-bottom:3px solid transparent}
.detail-nav a:hover{color:var(--teal);border-color:var(--gold)}
.detail-main{max-width:1380px;margin:auto;padding:48px 28px 90px}
.detail-section{scroll-margin-top:145px;margin-bottom:58px}
.section-heading{display:flex;align-items:center;gap:13px;margin-bottom:20px}
.section-number{width:35px;height:35px;border-radius:11px;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:Georgia,serif}
.section-heading h2{font-family:Georgia,serif;font-size:32px;margin:0}
.overview-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:24px}
.panel{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.panel p:first-child{margin-top:0}
.panel p:last-child{margin-bottom:0}
.known-panel{background:linear-gradient(145deg,#214e55,#18383e);color:#fff;border:0}
.known-panel .label{color:#e9c780;text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:800}
.known-panel p{font-family:Georgia,serif;font-size:23px;line-height:1.25;margin:10px 0 0}
.timeline{position:relative;margin-left:12px}
.timeline:before{content:"";position:absolute;left:14px;top:8px;bottom:8px;width:2px;background:#c9b99e}
.timeline-item{position:relative;display:grid;grid-template-columns:28px 150px 1fr;gap:17px;margin:0 0 24px}
.timeline-dot{width:28px;height:28px;border-radius:50%;background:var(--paper-2);border:7px solid var(--bronze);z-index:1}
.timeline-date{font-weight:800;color:var(--bronze-dark);padding-top:2px}
.timeline-content{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:18px}
.timeline-content h3{font-family:Georgia,serif;margin:0 0 5px;font-size:20px}
.timeline-content p{margin:0;color:#59666e}
.achievement-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.achievement{background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow-sm)}
.achievement-icon{width:44px;height:44px;border-radius:13px;background:#e5ece9;color:var(--teal);display:grid;place-items:center;font-size:21px;margin-bottom:15px}
.achievement h3{font-family:Georgia,serif;margin:0 0 8px;font-size:21px}
.achievement p{margin:0;color:#59666e;font-size:14px}
.balance-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.balance-panel{border-radius:18px;padding:25px;border:1px solid var(--line);background:var(--paper-2)}
.balance-panel h3{font-family:Georgia,serif;font-size:24px;margin:0 0 11px}
.balance-panel.strength{border-top:5px solid #487b68}
.balance-panel.weakness{border-top:5px solid #a35f4e}
.balance-panel p{margin:0;color:#59666e}
.fall-panel{background:linear-gradient(135deg,#302b29,#5c3e31);color:#fff;border:0;position:relative;overflow:hidden}
.fall-panel:after{content:"⌛";position:absolute;right:28px;bottom:-22px;font-size:110px;opacity:.09}
.fall-panel h3{font-family:Georgia,serif;font-size:26px;margin:0 0 10px;color:#f0c87a}
.fall-panel p{font-size:17px;max-width:1050px;margin:0;color:#f2ece4}
.resource-tools{display:grid;grid-template-columns:minmax(260px,1fr) auto;gap:16px;align-items:center;margin-bottom:18px}
.resource-search{position:relative}
.resource-search input{width:100%;height:48px;border:1px solid #cfc6b7;border-radius:13px;background:#fff;padding:0 15px 0 43px;outline:none}
.resource-chips{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.resource-chip{border:1px solid #cfc6b7;background:#fff;border-radius:999px;padding:8px 11px;font-size:12px;font-weight:800;color:#59666e}
.resource-chip.active{background:var(--teal);border-color:var(--teal);color:#fff}
.resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.resource-card{display:flex;flex-direction:column;background:var(--paper-2);border:1px solid var(--line);border-radius:17px;padding:20px;text-decoration:none;min-height:205px;transition:.18s ease;box-shadow:0 4px 15px rgba(38,31,20,.05)}
.resource-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:#b99d75}
.resource-type{display:inline-flex;align-self:flex-start;background:#eee8dc;border-radius:999px;padding:5px 8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#685847}
.resource-card h3{font-family:Georgia,serif;margin:13px 0 8px;font-size:20px;line-height:1.15}
.resource-card p{margin:0;color:#64727d;font-size:13px}
.resource-source{margin-top:auto;padding-top:13px;font-size:12px;font-weight:800;color:var(--teal)}
.related-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.related-card{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:18px;text-decoration:none}
.related-card:hover{border-color:#b99d75;box-shadow:var(--shadow-sm)}
.related-card span{font-size:11px;color:var(--bronze-dark);font-weight:800}
.related-card h3{font-family:Georgia,serif;margin:6px 0 4px;font-size:20px}
.related-card p{font-size:12px;color:var(--muted);margin:0}
.detail-pager{display:flex;justify-content:space-between;gap:14px;margin-top:45px}
.pager-link{display:flex;align-items:center;gap:10px;text-decoration:none;border:1px solid var(--line);background:var(--paper-2);border-radius:14px;padding:12px 16px;font-weight:800;color:var(--teal)}
.pager-link:hover{box-shadow:var(--shadow-sm)}
.error-page{max-width:760px;margin:80px auto;padding:40px;background:#fff;border:1px solid var(--line);border-radius:20px;text-align:center}

@media(max-width:1160px){
 .card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
 .achievement-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .resource-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .controls{grid-template-columns:1fr 1fr 1fr}.group-toggle{grid-column:1/-1;justify-self:start}
}
@media(max-width:820px){
 .hero-inner,.detail-hero-inner,.overview-grid{grid-template-columns:1fr}
 .hero-inner{padding-top:52px}.hero-stats{max-width:520px}.detail-meta{max-width:600px}
 .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .controls{grid-template-columns:1fr}.group-toggle{grid-column:auto;width:100%}.group-toggle button{flex:1}
 .resource-tools{grid-template-columns:1fr}.resource-chips{justify-content:flex-start}
 .balance-grid{grid-template-columns:1fr}
 .timeline-item{grid-template-columns:28px 105px 1fr}
 .footer-inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:570px){
 .header-inner{padding:0 16px}.brand-text small{display:none}.header-nav{display:none}
 .hero-inner,.main-shell,.controls-wrap,.detail-hero-inner,.detail-main{padding-left:16px;padding-right:16px}
 .hero h1{font-size:43px}.hero-stats{grid-template-columns:1fr 1fr}.stat strong{font-size:25px}
 .card-grid,.achievement-grid,.resource-grid,.related-grid{grid-template-columns:1fr}
 .collection-summary{align-items:flex-start;flex-direction:column}
 .timeline-item{grid-template-columns:28px 1fr;gap:12px}.timeline-date{grid-column:2}.timeline-content{grid-column:2}
 .detail-meta{grid-template-columns:1fr}.detail-nav{top:72px}
 .detail-pager{flex-direction:column}.pager-link{justify-content:center}
}

/* Expanded culture and population content */
.meta-box small{display:block;margin-top:7px;color:#d5dfdf;font-size:11px;line-height:1.35}
.population-meta{grid-column:1/-1;background:rgba(240,200,122,.13);border-color:rgba(240,200,122,.3)}
.population-meta strong{font-size:16px;line-height:1.25}
.overview-side{display:grid;gap:18px;align-content:start}
.overview-copy>p{font-size:15px;line-height:1.7;color:#4f5e67}
.lead-detail{font-size:16px!important;color:#35434b!important}
.population-panel{border-top:5px solid var(--gold)}
.population-panel .label{display:block;color:var(--bronze-dark);text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:800}
.population-panel h3{font-family:Georgia,serif;font-size:22px;line-height:1.25;margin:10px 0 12px}
.population-panel p{font-size:13px;line-height:1.55;color:#59666e}
.inline-source{display:inline-flex;margin-top:10px;font-size:12px;font-weight:800;color:var(--teal);text-decoration:none}
.inline-source:hover{text-decoration:underline}
.section-intro{max-width:970px;margin:-5px 0 22px;color:#63717a;line-height:1.65}
.expanded-achievement-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.culture-card{padding:26px;border-top:5px solid var(--teal)}
.culture-card h3{font-size:24px;margin-bottom:14px}
.culture-card .expanded-copy p,.balance-panel .expanded-copy p,.fall-panel .expanded-copy p{margin:0 0 12px;line-height:1.62}
.culture-card .expanded-copy p:last-child,.balance-panel .expanded-copy p:last-child,.fall-panel .expanded-copy p:last-child{margin-bottom:0}
.culture-card .expanded-copy p{font-size:14px;color:#59666e}
.culture-card .expanded-copy .lead-detail{font-size:15px!important;font-weight:650;color:#39474f!important}
.art-card{border-top-color:#9a6a3f}.music-card{border-top-color:#8b5f83}.science-card{border-top-color:#4e7d78}.writing-card{border-top-color:#5f6e98}
.architecture-card{border-top-color:#8a7650}.government-card{border-top-color:#9b584b}.religion-card{border-top-color:#75609a}.family-card{border-top-color:#4f7a5e}
.balance-panel .expanded-copy p{color:#59666e}
.fall-panel .expanded-copy{position:relative;z-index:1;max-width:1080px}
.fall-panel .expanded-copy p{font-size:16px;color:#f2ece4}
@media(max-width:820px){
  .expanded-achievement-grid{grid-template-columns:1fr}
  .population-meta{grid-column:auto}
}
@media(max-width:570px){
  .culture-card{padding:21px}
  .culture-card h3{font-size:22px}
}


/* Population range and expanded timeline revision */
.card-population{margin:14px 0 4px;padding:10px 11px;border-radius:9px;background:#f4efe6;border-left:3px solid var(--accent);display:grid;gap:3px}
.card-population span{font-size:10px;line-height:1.2;text-transform:uppercase;letter-spacing:.09em;font-weight:800;color:#7a6a55}
.card-population strong{font-size:12px;line-height:1.35;color:#29343a}
.population-facts{display:grid;grid-template-columns:1fr;gap:3px;margin:12px 0}
.population-facts p{margin:0}
.population-method{margin-top:14px;padding:12px;border-radius:9px;background:#f5f1e9;border:1px solid #e3d8c8}
.population-method strong{display:block;margin-bottom:4px;color:#5b4630;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.population-method p{margin:0}
.timeline-category{display:inline-block;margin-bottom:7px;padding:4px 8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 14%,white);border:1px solid color-mix(in srgb,var(--accent) 28%,white);color:var(--accent);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.timeline-content p{max-width:920px;line-height:1.7}
.timeline-item{padding-bottom:30px}
@media (min-width:760px){.population-facts{grid-template-columns:1fr 1fr}.population-facts p:first-child{grid-column:1/-1}}

/* Maps and entertainment update */
.entertainment-card{border-top-color:#b06a4a}
.mini-map-panel .label{display:block;color:var(--bronze-dark);text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:800;margin-bottom:10px}
.mini-map-panel .map-card{border:0;padding:0;background:transparent;box-shadow:none}
.mini-map-caption{margin:10px 0 0;color:#66757f;font-size:12px;line-height:1.55}
.map-card{background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow-sm)}
.map-header{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:12px}
.map-header h3{font-family:Georgia,serif;font-size:24px;line-height:1.2;margin:0 0 4px}
.map-header p{margin:0;color:#65737c;line-height:1.5;max-width:760px}
.culture-map{display:block;width:100%;height:auto;border-radius:18px;border:1px solid #cfdce0;background:#cfe2e9}
.map-ocean{fill:#dcecf2}
.map-water-bg{fill:#cfe2eb;opacity:.95}
.map-land{fill:#efe1c7;stroke:#bca888;stroke-width:2.5;stroke-linejoin:round}
.map-country{fill:rgba(255,255,255,.12);stroke:#7e766d;stroke-width:2.2;stroke-dasharray:9 7;stroke-linejoin:round}
.map-country-label{font-family:Arial,sans-serif;font-size:21px;font-weight:700;fill:#574c40;letter-spacing:.02em}
.map-river{fill:none;stroke:#3d8db0;stroke-width:7;stroke-linecap:round;stroke-linejoin:round;opacity:.94}
.map-water-label{font-family:Arial,sans-serif;font-size:22px;font-style:italic;fill:#3b7ea0}
.map-water-label.sea{font-size:25px;opacity:.88}
.map-area{fill:color-mix(in srgb,var(--map-accent, var(--accent)) 58%, transparent);stroke:var(--map-accent, var(--accent));stroke-width:5;opacity:.95}
.map-area-label{font-family:Arial,sans-serif;font-size:24px;font-weight:800;fill:#2b353b;paint-order:stroke;stroke:#fff;stroke-width:5;stroke-linejoin:round}
.map-legend{display:flex;flex-wrap:wrap;gap:14px 22px;margin-top:13px;font-size:13px;font-weight:700;color:#5e6c74}
.map-legend span{display:inline-flex;align-items:center;gap:8px}
.map-legend i{display:inline-block;flex:0 0 auto}
.map-legend-area{width:18px;height:18px;border-radius:50%;background:color-mix(in srgb,var(--accent) 65%, transparent);border:2px solid var(--accent)}
.map-legend-river{width:24px;height:0;border-top:4px solid #3d8db0}
.map-legend-country{width:24px;height:14px;border:2px dashed #7e766d;border-radius:4px;background:rgba(255,255,255,.35)}
.map-note{margin:11px 0 0;color:#68757f;font-size:12px;line-height:1.55}
#map .map-card{padding:22px}
#map .culture-map{min-height:360px}
@media(max-width:820px){
  .map-country-label{font-size:18px}
  .map-water-label{font-size:18px}
  .map-water-label.sea{font-size:21px}
  .map-area-label{font-size:20px}
}
@media(max-width:570px){
  .map-card{padding:14px}
  .map-header h3{font-size:21px}
  .map-country-label{font-size:15px}
  .map-water-label{font-size:15px}
  .map-water-label.sea{font-size:17px}
  .map-area-label{font-size:17px}
  .map-legend{gap:10px 14px;font-size:12px}
}

/* Accurate interactive geography maps */
.accurate-map-card{background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:20px;box-shadow:var(--shadow-sm)}
.accurate-map-heading{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:14px}
.accurate-map-heading h3{font-family:Georgia,serif;font-size:25px;line-height:1.2;margin:0}
.accurate-map-heading p{max-width:640px;margin:2px 0 0;color:#617079;line-height:1.55}
.geo-culture-map{width:100%;overflow:hidden;border:1px solid #bdcbd1;border-radius:16px;background:#dcecf2;isolation:isolate}
.full-geo-map{height:590px}
.mini-geo-map{height:295px}
.mini-map-panel .geo-culture-map{margin-top:10px}
.accurate-map-legend{display:flex;flex-wrap:wrap;gap:13px 22px;margin-top:14px;color:#596971;font-size:13px;font-weight:750}
.accurate-map-legend span{display:inline-flex;align-items:center;gap:8px}
.accurate-map-legend i{display:inline-block;flex:0 0 auto}
.ancient-area-key{width:20px;height:20px;border-radius:50%;background:color-mix(in srgb,var(--accent) 25%,transparent);border:3px dashed var(--accent)}
.waterway-key{width:27px;height:0;border-top:5px solid #287da1;border-radius:999px}
.modern-map-key{width:26px;height:18px;border:1px solid #8b969c;background:linear-gradient(135deg,#efe1c7 0 48%,#dcecf2 48% 100%);border-radius:4px}
.culture-map-marker-wrap{background:transparent;border:0}
.culture-map-marker{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--marker-color);color:white;border:3px solid white;box-shadow:0 3px 12px rgba(20,32,38,.38);font-size:15px;font-weight:900}
.map-load-message{height:100%;display:grid;place-content:center;text-align:center;padding:24px;color:#53636c;background:linear-gradient(135deg,#e8f1f4,#f3eee5)}
.map-load-message strong{font-family:Georgia,serif;font-size:20px;margin-bottom:6px}
.map-load-message span{font-size:13px}
@media(max-width:820px){
  .accurate-map-heading{display:block}
  .accurate-map-heading p{margin-top:7px}
  .full-geo-map{height:500px}
}
@media(max-width:570px){
  .accurate-map-card{padding:14px}
  .full-geo-map{height:420px}
  .mini-geo-map{height:250px}
  .accurate-map-heading h3{font-size:22px}
  .accurate-map-legend{gap:10px 14px;font-size:12px}
}

/* Fully bundled offline geographic maps */
.geo-culture-map{position:relative;touch-action:none;cursor:grab;background:#dcecf2}
.geo-culture-map.is-dragging{cursor:grabbing}
.offline-map-svg{display:block;width:100%;height:100%;background:#dcecf2;border-radius:15px;user-select:none}
.offline-ocean{fill:#dcecf2}
.offline-grid{stroke:#b8d2dc;stroke-width:1;opacity:.55;stroke-dasharray:5 7}
.offline-country{fill:#efe3c9;stroke:#80786c;stroke-width:1.6;vector-effect:non-scaling-stroke;stroke-linejoin:round}
.offline-country:hover{fill:#f5ead4}
.offline-country-label{font:700 14px/1 Arial,sans-serif;fill:#514a42;text-anchor:middle;paint-order:stroke;stroke:#f7f0e4;stroke-width:3px;stroke-linejoin:round;pointer-events:none}
.offline-river{fill:none;stroke:#287da1;stroke-width:4;opacity:.88;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}
.offline-river-label{font:italic 700 13px/1 Arial,sans-serif;fill:#236d8d;text-anchor:middle;paint-order:stroke;stroke:#edf7fa;stroke-width:3px;pointer-events:none}
.offline-sea-label{font:italic 700 16px/1 Georgia,serif;fill:#3f82a0;text-anchor:middle;letter-spacing:.04em;opacity:.9;paint-order:stroke;stroke:#e8f3f6;stroke-width:3px;pointer-events:none}
.offline-culture-zone{fill:color-mix(in srgb,var(--zone-color) 28%,transparent);stroke:var(--zone-color);stroke-width:4;stroke-dasharray:10 7;vector-effect:non-scaling-stroke}
.offline-center-ring{fill:#fff;stroke:var(--zone-color);stroke-width:4;vector-effect:non-scaling-stroke}
.offline-center-dot{fill:var(--accent)}
.offline-culture-label{font:800 17px/1.1 Georgia,serif;fill:#27333a;paint-order:stroke;stroke:#fff;stroke-width:5px;stroke-linejoin:round;pointer-events:none}
.offline-map-toolbar{position:absolute;z-index:5;top:12px;left:12px;display:grid;gap:5px}
.offline-map-toolbar button{width:36px;height:36px;border:1px solid #aebfc6;border-radius:8px;background:rgba(255,255,255,.94);color:#33434b;font-size:22px;font-weight:800;line-height:1;box-shadow:0 2px 8px rgba(24,38,45,.18);cursor:pointer}
.offline-map-toolbar button:hover{background:#fff;border-color:#79939f}
.offline-map-status{position:absolute;z-index:4;left:58px;right:12px;top:12px;display:flex;justify-content:flex-end;gap:8px;pointer-events:none}
.offline-map-status span{background:rgba(255,255,255,.9);border:1px solid rgba(120,140,148,.45);border-radius:999px;padding:6px 9px;font-size:11px;font-weight:800;color:#4d5d65;box-shadow:0 2px 8px rgba(24,38,45,.1)}
.offline-map-attribution{position:absolute;right:8px;bottom:6px;max-width:75%;background:rgba(255,255,255,.88);border-radius:5px;padding:3px 6px;font-size:9px;line-height:1.25;color:#52636b;text-align:right;pointer-events:none}
@media(max-width:570px){
  .offline-country-label{font-size:12px}
  .offline-river-label{font-size:11px}
  .offline-sea-label{font-size:13px}
  .offline-culture-label{font-size:14px}
  .offline-map-toolbar button{width:32px;height:32px;font-size:19px}
  .offline-map-status{left:50px;flex-direction:column;align-items:flex-end}
  .offline-map-status span{font-size:9px;padding:4px 7px}
  .offline-map-attribution{font-size:8px;max-width:88%}
}
.sports-entertainment-card{border-top-color:#b06a4a}

/* First-visit homepage splash screen */
.home-splash[hidden]{display:none}
.home-splash{position:fixed;inset:0;z-index:100000;display:grid;place-items:center;padding:24px;background:rgba(245,245,245,.18);opacity:0;transition:opacity .6s ease}
.home-splash.is-visible{opacity:1}
.home-splash.is-closing{opacity:0}
.home-splash-panel{width:min(860px,92vw);aspect-ratio:16/9;display:grid;place-items:center;overflow:hidden;background:#fff;border:1px solid rgba(53,62,67,.12);border-radius:24px;box-shadow:0 34px 90px rgba(24,31,35,.28),0 10px 28px rgba(24,31,35,.16);transform:translateY(18px) scale(.97);transition:transform .7s cubic-bezier(.2,.75,.25,1)}
.home-splash.is-visible .home-splash-panel{transform:translateY(0) scale(1)}
.home-splash.is-closing .home-splash-panel{transform:translateY(-10px) scale(.985)}
.home-splash-panel img{display:block;width:100%;height:100%;object-fit:contain;background:#fff}
body.splash-active{overflow:hidden}
body.splash-active> :not(.home-splash):not(script){filter:grayscale(1);pointer-events:none;user-select:none;transition:filter .45s ease}
@media(max-width:570px){
  .home-splash{padding:14px}
  .home-splash-panel{width:96vw;border-radius:17px;box-shadow:0 24px 58px rgba(24,31,35,.25),0 8px 20px rgba(24,31,35,.14)}
}

/* Compact homepage introduction */
.hero-inner{grid-template-columns:1fr;max-width:1380px;padding-top:42px;padding-bottom:38px;gap:0;align-items:center}
.hero-content{max-width:820px}
.hero h1{font-size:clamp(36px,4.5vw,58px);line-height:1.02;margin:10px 0 12px;max-width:760px}
.hero-copy{font-size:17px;line-height:1.55;max-width:760px}
@media(max-width:570px){
  .hero-inner{padding-top:34px;padding-bottom:32px}
  .hero h1{font-size:36px}
  .hero-copy{font-size:16px}
}

/* Keep tile banner titles clear of the right-side icon */
.card-banner{
  min-height:78px;
  height:auto;
}
.card-region{
  left:15px;
  right:78px;
  bottom:10px;
  max-width:calc(100% - 93px);
  line-height:1.28;
  white-space:normal;
  overflow-wrap:break-word;
  word-break:normal;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
}
.card-glyph{
  right:16px;
  top:10px;
  width:48px;
  text-align:center;
}
