﻿:root {
  --ink: #152025;
  --muted: #5d6b70;
  --paper: #fbfaf6;
  --cream: #f4efe4;
  --teal: #006f79;
  --teal-dark: #004d56;
  --red: #c84636;
  --gold: #c59a42;
  --line: rgba(21, 32, 37, .14);
  --shadow: 0 22px 60px rgba(18, 34, 39, .14);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; color: var(--ink); background: var(--paper); line-height: 1.6; }
a { color: inherit; }
img { max-width: 100%; display: block; }
.container { width: min(1120px, calc(100% - 40px)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(251, 250, 246, .94); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
.nav { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand { display: flex; align-items: center; text-decoration: none; }
.brand img { width: 68px; height: 68px; object-fit: contain; display: block; flex: 0 0 auto; }
.brand-copy { display: grid; align-content: center; gap: 0; margin-left: 14px; color: var(--ink); }
.brand-copy span { font-size: 13px; font-weight: 700; line-height: 1.22; max-width: 240px; letter-spacing: .01em; color: var(--ink); text-wrap: balance; }
.nav-toggle { display: none; width: 48px; height: 48px; border: 1px solid var(--line); border-radius: 8px; background: white; align-items: center; justify-content: center; padding: 0; cursor: pointer; }
.nav-toggle span { display: block; width: 20px; height: 2px; background: var(--ink); margin: 3px 0; transition: transform .2s ease, opacity .2s ease; }
.nav-toggle[aria-expanded='true'] span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded='true'] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded='true'] span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
.nav-links { display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap; gap: 8px 14px; font-size: 13px; font-weight: 700; }
.nav-links a { text-decoration: none; color: var(--ink); white-space: nowrap; }
.nav-group { position: relative; display: flex; align-items: center; }
.nav-group::before { content: ''; position: absolute; left: 0; right: 0; top: 100%; height: 14px; display: none; }
.nav-group:hover::before, .nav-group:focus-within::before { display: block; }
.nav-parent::after { content: '▾'; font-size: 11px; margin-left: 6px; color: var(--muted); }
.nav-submenu { position: absolute; top: calc(100% + 12px); left: 0; min-width: 190px; background: white; border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 18px 44px rgba(21,32,37,.12); padding: 8px; display: none; z-index: 30; }
.nav-submenu a { display: block; padding: 10px 12px; border-radius: 8px; white-space: normal; }
.nav-submenu a:hover { background: rgba(0,111,121,.08); color: var(--teal); }
.nav-group:hover .nav-submenu, .nav-group:focus-within .nav-submenu { display: block; }
.nav-links a:hover { color: var(--teal); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 46px; padding: 12px 18px; border-radius: 6px; text-decoration: none; font-weight: 700; border: 1px solid transparent; }
.btn-primary { background: var(--teal); color: white; }
.btn-primary:hover { background: var(--teal-dark); }
.btn-outline { border-color: rgba(255,255,255,.72); color: white; background: rgba(255,255,255,.08); }
.btn-outline:hover { background: rgba(255,255,255,.18); }
.btn-light { border-color: var(--teal); color: var(--teal); background: white; }
.hero { min-height: calc(100vh - 74px); display: grid; align-items: end; position: relative; overflow: hidden; color: white; }
.hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,23,28,.84), rgba(5,23,28,.48) 54%, rgba(5,23,28,.18)); }
.hero-content { position: relative; z-index: 1; padding: 88px 0 72px; max-width: 780px; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; color: var(--gold); font-size: 13px; text-transform: uppercase; font-weight: 800; letter-spacing: 0; }
.eyebrow::before { content: ''; width: 10px; height: 10px; background: currentColor; }
h1, h2, h3 { line-height: 1.12; margin: 0; letter-spacing: 0; }
h1 { font-size: clamp(42px, 7vw, 78px); margin-top: 18px; max-width: 860px; }
.hero p { font-size: clamp(18px, 2vw, 22px); max-width: 700px; margin: 24px 0 0; color: rgba(255,255,255,.9); }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
section { padding: 82px 0; }
.section-soft { background: var(--cream); }
.section-head { max-width: 760px; margin-bottom: 34px; }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; }
.section-head h2 { font-size: clamp(30px, 4vw, 48px); margin-top: 12px; }
.section-head p { color: var(--muted); font-size: 18px; margin: 18px 0 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.card { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 26px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.card h3 { font-size: 22px; margin-bottom: 10px; }
.card p { color: var(--muted); margin: 0; }
.feature-image { border-radius: 8px; overflow: hidden; box-shadow: var(--shadow); min-height: 360px; }
.feature-image picture { display: block; width: 100%; height: 100%; }
.feature-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.feature-image.cover-frame { min-height: 0; height: auto; aspect-ratio: 16 / 10; }
.feature-image.cover-frame picture,
.feature-image.cover-frame img { width: 100%; height: 100%; }
.feature-image.cover-frame img { object-position: center 42%; }
.list { display: grid; gap: 12px; padding: 0; margin: 0; list-style: none; }
.list li { padding-left: 28px; position: relative; color: var(--muted); }
.list li::before { content: ''; width: 9px; height: 9px; background: var(--red); position: absolute; left: 0; top: .7em; }
.band { background: var(--teal); color: white; }
.band p { color: rgba(255,255,255,.84); }
.page-hero { padding: 72px 0 42px; background: linear-gradient(135deg, var(--teal-dark), var(--teal)); color: white; }
.page-hero h1 { font-size: clamp(36px, 5.5vw, 58px); max-width: 900px; }
.page-hero p { max-width: 760px; color: rgba(255,255,255,.88); font-size: 18px; }
.page-hero-compact { padding: 60px 0 32px; }
.page-hero-compact h1 { font-size: clamp(34px, 5vw, 52px); }
.page-hero-compact p { max-width: 700px; }
.page-hero .card-facts span { border-color: rgba(255,255,255,.24); color: rgba(255,255,255,.86); background: rgba(255,255,255,.08); }
.tile-link { display: block; text-decoration: none; overflow: hidden; padding: 0; }
.tile-link img { height: 220px; width: 100%; object-fit: cover; }
.tile-body { padding: 24px; }
.cooperation-case-grid { align-items: stretch; }
.cooperation-case-grid .tile-link { height: 100%; background: white; border-radius: 8px; border: 1px solid var(--line); box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.cooperation-case-grid .tile-link picture { display: block; }
.cooperation-case-grid .tile-link img { height: 220px; width: 100%; object-fit: cover; }
.cooperation-case-grid .tile-body { display: grid; gap: 10px; align-content: start; min-height: 210px; }
.cooperation-case-grid .tile-body h3 { font-size: 22px; margin: 0; line-height: 1.28; }
.cooperation-case-grid .tile-body p { margin: 0; color: var(--muted); line-height: 1.7; }
.contact-box { display: grid; grid-template-columns: .88fr 1.12fr; gap: 28px; align-items: start; }
.contact-panel { background: white; border-radius: 8px; padding: 30px; border: 1px solid var(--line); display: grid; gap: 18px; }
.contact-panel a { color: var(--teal); font-weight: 700; }
.contact-details { display: grid; gap: 6px; }
.contact-details p { margin: 0; }
.contact-panel-media { min-height: 220px; margin-top: 4px; }
.contact-panel-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 56%; }
.contact-form-card { background: white; border-radius: 8px; padding: 30px; border: 1px solid var(--line); }
.contact-form-card h3 { margin-bottom: 12px; }
.contact-form { display: grid; gap: 16px; margin-top: 18px; }
.contact-form label { display: grid; gap: 8px; font-weight: 700; color: var(--navy); }
.contact-form label span { font-size: 14px; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 6px; padding: 12px 14px; font: inherit; color: var(--navy); background: #fff; }
.contact-form textarea { resize: vertical; min-height: 140px; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { outline: 2px solid rgba(11,127,135,.18); border-color: var(--teal); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-note { margin: -2px 0 0; font-size: 14px; color: var(--muted); }
.form-note a { color: var(--teal); font-weight: 700; }
.form-actions { display: grid; gap: 12px; align-items: center; }
.form-status { margin: 0; min-height: 24px; font-size: 14px; color: var(--muted); }
.form-status.success { color: #0a7b52; }
.form-status.error { color: #b42318; }
.contact-page-box { align-items: stretch; }
.hp-field { position: absolute !important; left: -9999px !important; opacity: 0 !important; pointer-events: none !important; }
.footer { padding: 36px 0; background: #101a1e; color: rgba(255,255,255,.78); }
.footer-grid { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer a { color: white; text-decoration: none; }
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.gallery-grid img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; }
.gallery-grid figure { margin: 0; background: white; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.gallery-grid figure img { border-radius: 0; display: block; }
.gallery-grid figcaption { padding: 13px 14px 15px; color: var(--navy); font-weight: 800; font-size: 14px; line-height: 1.35; }
.zh body, .zh { font-family: Arial, 'Microsoft YaHei', 'PingFang SC', sans-serif; }
@media (max-width: 1100px) {
  .nav { align-items: flex-start; padding: 14px 0; flex-direction: column; }
  .brand img { width: 60px; height: 60px; }
  .brand-copy span { font-size: 13px; max-width: 250px; }
  .nav-links { width: 100%; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; gap: 16px; padding-bottom: 6px; }
}
@media (max-width: 860px) {
  .hero { min-height: 700px; }
  .grid-2, .grid-3, .contact-box, .gallery-grid, .form-grid { grid-template-columns: 1fr; }
  section { padding: 58px 0; }
  .feature-image { min-height: 260px; }
  .feature-image.cover-frame { min-height: 0; aspect-ratio: 16 / 10; }
  .nav { min-height: 74px; align-items: center; justify-content: space-between; flex-direction: row; padding: 12px 0; position: relative; }
  .brand img { width: 52px; height: 52px; }
  .brand-copy { margin-left: 10px; }
  .brand-copy span { font-size: 10.5px; max-width: 145px; line-height: 1.15; }
  .nav-toggle { display: inline-flex; }
  .nav-links { display: none; position: absolute; top: calc(100% + 8px); left: 0; right: 0; background: rgba(251, 250, 246, .98); border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 18px 44px rgba(21,32,37,.12); padding: 12px; flex-direction: column; align-items: stretch; gap: 4px; overflow: visible; }
  .nav-links.is-open { display: flex; }
  .nav-links a { padding: 12px 10px; border-radius: 8px; }
  .nav-links a:hover { background: rgba(0,111,121,.08); }
  .nav-group { display: grid; }
  .nav-group::before { display: none; }
  .nav-group:hover::before, .nav-group:focus-within::before { display: none; }
  .nav-parent::after { float: right; }
  .nav-group:hover .nav-submenu, .nav-group:focus-within .nav-submenu { display: none; }
  .nav-group.is-expanded .nav-submenu { display: block; }
  .nav-submenu { position: static; display: none; min-width: 0; box-shadow: none; border: 0; border-left: 2px solid rgba(0,111,121,.14); border-radius: 0; padding: 4px 0 2px 14px; margin: 2px 0 8px; background: transparent; }
  .nav-submenu a { padding: 9px 10px; font-size: 13px; color: var(--muted); }
  .nav-submenu a:hover { background: rgba(0,111,121,.06); color: var(--teal); }
  .contact-panel-media { min-height: 200px; }
}

.tour-hero { min-height: 680px; display: grid; align-items: end; position: relative; overflow: hidden; color: white; }
.tour-hero > picture { position: absolute; inset: 0; width: 100%; height: 100%; }
.tour-hero > picture img, .tour-hero > img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tour-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,23,28,.86), rgba(5,23,28,.52) 56%, rgba(5,23,28,.18)); }
.ich-detail-hero { min-height: 540px; }
.ich-detail-hero::after { background: linear-gradient(90deg, rgba(5,23,28,.58), rgba(5,23,28,.34) 56%, rgba(5,23,28,.14)); }
.ich-detail-hero .hero-content { max-width: 760px; padding: 72px 0 58px; }
.ich-detail-hero h1 { font-size: clamp(36px, 5.2vw, 60px); max-width: 820px; }
.ich-detail-hero p { font-size: 18px; max-width: 700px; color: rgba(255,255,255,.9); }
.tour-facts { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 24px; }
.tour-facts span { border: 1px solid rgba(255,255,255,.42); background: rgba(255,255,255,.12); color: white; border-radius: 999px; padding: 8px 12px; font-weight: 700; font-size: 14px; }
.tour-gallery { width: min(1120px, calc(100% - 40px)); margin: -64px auto 0; position: relative; z-index: 2; display: grid; grid-template-columns: 1.3fr .85fr .85fr; gap: 14px; }
.tour-gallery picture { display: block; }
.tour-gallery img { width: 100%; height: 280px; object-fit: cover; border-radius: 8px; box-shadow: var(--shadow); display: block; }
.tour-gallery picture:first-child img, .tour-gallery img:first-child { height: 360px; }
.timeline { display: grid; gap: 16px; }
.timeline-item { display: grid; grid-template-columns: 120px 1fr; gap: 22px; padding: 24px; background: white; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.timeline-day { color: var(--teal); font-weight: 800; text-transform: uppercase; letter-spacing: .02em; }
.timeline-item h3 { margin-bottom: 8px; }
.timeline-item p { margin: 0; color: var(--muted); }
@media (max-width: 860px) {
  .tour-hero { min-height: 720px; }
  .ich-detail-hero { min-height: 620px; }
  .tour-gallery { grid-template-columns: 1fr; margin-top: 20px; }
  .tour-gallery img, .tour-gallery picture:first-child img, .tour-gallery img:first-child { height: 240px; }
  .timeline-item { grid-template-columns: 1fr; gap: 8px; }
}

.card-facts { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0 14px; }
.card-facts span { display: inline-flex; border: 1px solid var(--line); border-radius: 999px; padding: 5px 9px; color: var(--teal); font-size: 12px; font-weight: 800; background: rgba(0,111,121,.06); }
.tour-card, .event-card { display: flex; flex-direction: column; height: 100%; }
.tour-card .tile-body, .event-card .tile-body { display: flex; flex-direction: column; align-items: flex-start; gap: 0; flex: 1; }
.tour-card .tile-body p, .event-card .tile-body p { margin-bottom: 0; }
.tour-card-featured { border-color: rgba(197,154,66,.55); box-shadow: 0 18px 50px rgba(197,154,66,.16); }
.tour-card-featured .tile-body { background: linear-gradient(180deg, #fff, #fbf5e8); }
.category-pills { display: flex; flex-wrap: wrap; gap: 12px; }
.category-pills span { display: inline-flex; padding: 10px 14px; border-radius: 999px; background: white; border: 1px solid var(--line); color: var(--teal); font-weight: 800; box-shadow: 0 10px 28px rgba(21,32,37,.05); }

.newsletter-hero { min-height: 680px; display: grid; align-items: end; position: relative; overflow: hidden; color: white; }
.newsletter-hero > picture { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.newsletter-hero > picture img, .newsletter-hero > img { width: 100%; height: 100%; object-fit: cover; display: block; }
.newsletter-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,23,28,.88), rgba(5,23,28,.58) 56%, rgba(5,23,28,.2)); }
.newsletter-card-featured { border-color: rgba(0,111,121,.34); box-shadow: 0 18px 50px rgba(0,111,121,.16); }
.newsletter-card-featured .tile-body { background: linear-gradient(180deg, #fff, #edf7f6); }
.newsletter-card-placeholder { border-style: dashed; border-color: rgba(0,111,121,.25); background: linear-gradient(180deg, #fff, #f8fbfb); box-shadow: none; }
.newsletter-card-placeholder .tile-body { background: transparent; }
.newsletter-card-placeholder h3 { color: var(--teal-dark); }
.newsletter-feature { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: center; }
.newsletter-text { max-width: 820px; }
.newsletter-text h2, .newsletter-feature h2 { font-size: clamp(30px, 4vw, 48px); margin-top: 12px; }
.newsletter-text p { color: var(--muted); font-size: 18px; }
.newsletter-meta { margin-top: 20px; }
.newsletter-hero ~ section .feature-image { min-height: 0; aspect-ratio: 4 / 3; }
.newsletter-hero ~ section .feature-image img { width: 100%; height: 100%; object-fit: cover; }
.newsletter-reverse .feature-image { order: -1; }
code { background: rgba(0,111,121,.08); color: var(--teal-dark); padding: 2px 5px; border-radius: 4px; }
@media (max-width: 860px) {
  .newsletter-hero { min-height: 720px; }
  .newsletter-feature { grid-template-columns: 1fr; }
  .newsletter-hero ~ section .feature-image { aspect-ratio: 16 / 10; }
  .newsletter-reverse .feature-image { order: 0; }
}


.mini-points { display: flex; gap: 10px; flex-wrap: wrap; margin: 22px 0 26px; }
.mini-points span { display: inline-flex; border: 1px solid var(--line); background: white; color: var(--teal); border-radius: 999px; padding: 8px 12px; font-size: 13px; font-weight: 800; }
.ich-mini-stats { gap: 12px; margin: 24px 0 14px; }
.mini-points .ich-mini-stat { display: inline-flex; align-items: center; min-height: 0; padding: 0; border: 0; border-radius: 0; background: transparent; color: rgba(255,255,255,.92); font-size: 14px; font-weight: 700; box-shadow: none; cursor: default; pointer-events: none; }
.ich-mini-stat + .ich-mini-stat::before { content: "·"; margin-right: 12px; color: rgba(255,255,255,.52); }
.ich-mini-stat + .ich-mini-stat { margin-left: 0; }
.service-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; align-items: stretch; }
.service-card { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 22px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.service-card strong { display: block; font-size: 18px; line-height: 1.2; margin-bottom: 10px; }
.service-card span { display: block; color: var(--muted); line-height: 1.75; }
.service-card p { margin: 0; color: var(--muted); line-height: 1.75; }
.cooperation-support-grid .service-card { height: 100%; }
.cooperation-support-grid .service-card strong { font-size: 19px; }
.cooperation-support-grid .service-card span { line-height: 1.72; }
.process { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; counter-reset: process; }
.process > div { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 26px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.process span { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 999px; background: var(--teal); color: white; font-weight: 800; margin-bottom: 16px; }
.process h3 { font-size: 22px; margin-bottom: 8px; }
.process p { color: var(--muted); margin: 0; }
@media (max-width: 860px) {
  .service-grid, .process { grid-template-columns: 1fr; }
}

.travel-services-hero { background: linear-gradient(120deg, rgba(0,77,86,.98), rgba(0,111,121,.88)), url('/assets/images/china-travel.jpeg') center/cover; }
.travel-booking-panel { display: grid; gap: 28px; }
.travel-booking-copy { max-width: 720px; }
.travel-booking-copy p { color: var(--muted); font-size: 18px; }
.travel-widget-shell { background: white; border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 18px 42px rgba(16,26,30,.08); overflow: hidden; }
.travel-widget-frame { display: block; width: 100%; min-height: 360px; border: 0; }
.partner-note { display: grid; grid-template-columns: 1.2fr .8fr; gap: 24px; align-items: center; padding: 26px 30px; background: white; border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.partner-note h2 { font-size: clamp(24px, 3vw, 34px); margin-top: 10px; }
.partner-note p { margin: 14px 0 0; color: var(--muted); }
.partner-list { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 12px; }
.partner-list span { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 10px 16px; border-radius: 999px; border: 1px solid rgba(0,111,121,.18); background: rgba(0,111,121,.06); color: var(--teal-dark); font-weight: 800; }
.travel-service-grid { grid-template-columns: 1.15fr .85fr; }
.travel-service-card { display: grid; align-content: start; gap: 12px; }
.travel-service-card h3 { font-size: 26px; }
.travel-service-card p { margin: 0 0 8px; color: var(--muted); }
.travel-service-card .btn { justify-self: start; margin-top: 8px; }
.travel-service-kicker { color: var(--gold); font-size: 12px; font-weight: 800; text-transform: uppercase; }
.tripcom-widget-frame { min-height: 400px; }
.affiliate-disclosure { font-size: 13px; color: var(--muted); margin-top: 12px; grid-column: 1 / -1; }
@media (max-width: 860px) {
  .travel-service-grid { grid-template-columns: 1fr; }
  .partner-note { grid-template-columns: 1fr; padding: 22px; }
  .partner-list { justify-content: flex-start; }
  .travel-widget-frame { min-height: 420px; }
}

.ich-note-card h3 { margin-top: 10px; margin-bottom: 10px; }
.ich-note-card p { margin: 0; color: var(--muted); }
.ich-meta-table { background: white; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.ich-meta-row { display: grid; grid-template-columns: 220px 1fr; gap: 24px; padding: 18px 22px; border-top: 1px solid var(--line); }
.ich-meta-row:first-child { border-top: 0; }
.ich-meta-row strong { color: var(--teal-dark); font-size: 13px; text-transform: uppercase; letter-spacing: .04em; }
.ich-meta-row div { color: var(--ink); line-height: 1.7; }
.ich-meta-row a { color: var(--teal-dark); text-decoration: none; font-weight: 700; }
.ich-meta-row a:hover { text-decoration: underline; }
.ich-detail-gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.ich-detail-gallery figure { margin: 0; }
.ich-detail-gallery img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; border-radius: 8px; display: block; }
.ich-text-section { padding: 52px 0; }
.ich-text-section .prose { max-width: 860px; }
.ich-text-section .prose p { margin: 0 0 16px; color: var(--ink); }
.ich-text-section .prose p:last-child { margin-bottom: 0; }
.ich-text-section .prose strong { color: var(--teal-dark); }
.ich-text-section-muted { background: #f6f1e7; }
.ich-text-section-mid { background: #f6f0e6; }
.ich-text-section-plain { background: #fcfaf5; }
.ich-text-section-lead { padding: 56px 0 48px; }
.ich-category-nav { display: flex; flex-wrap: wrap; gap: 12px; position: sticky; top: 0; z-index: 10; background: white; padding: 12px 0; }
.ich-category-nav a { display: inline-flex; align-items: center; padding: 10px 14px; border-radius: 999px; background: white; border: 1px solid var(--line); text-decoration: none; font-weight: 800; color: var(--teal-dark); box-shadow: 0 10px 28px rgba(21,32,37,.05); }
.ich-category-alt { font-size: 17px; color: var(--teal-dark); margin-top: 14px; margin-bottom: 8px; }
.ich-item-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.ich-category-section:nth-child(odd) { background: #f9fafb; }
.ich-item-card { display: grid; grid-template-columns: 40px 1fr; gap: 16px; padding: 16px; background: white; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.ich-item-order { display: flex; align-items: flex-start; justify-content: center; width: 40px; height: 40px; border-radius: 999px; background: rgba(0,111,121,.08); color: var(--teal-dark); font-weight: 800; font-size: 16px; padding-top: 9px; }
.ich-item-copy h3 { font-size: 20px; margin-bottom: 10px; }
.ich-line { display: grid; gap: 4px; margin: 0 0 12px; color: var(--muted); }
.ich-line strong { color: var(--ink); font-size: 13px; text-transform: uppercase; }
.ich-line span { font-size: 16px; color: var(--ink); }
.ich-line em { color: var(--muted); font-style: normal; }
.ich-item-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.ich-item-meta a, .ich-flag { display: inline-flex; align-items: center; min-height: 36px; padding: 8px 12px; border-radius: 999px; font-size: 13px; font-weight: 800; text-decoration: none; }
.ich-item-meta a { background: rgba(0,111,121,.08); color: var(--teal-dark); }
.ich-flag { background: rgba(197,154,66,.14); color: #7a5d1f; }
.ich-flag--muted { display: inline-flex; align-items: center; min-height: 36px; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 800; background: #f0f0f0; color: var(--muted); }
.ich-also-in { display: block; font-size: 11px; color: var(--muted); margin-top: 6px; }
@media (max-width: 860px) {
  .ich-meta-row { grid-template-columns: 1fr; gap: 8px; padding: 16px 18px; }
  .ich-detail-gallery { grid-template-columns: 1fr; }
  .ich-item-grid { grid-template-columns: 1fr; gap: 20px; }
  .ich-item-card {
    grid-template-columns: 1fr;
    padding: 20px 18px;
  }
  .ich-item-order { width: 46px; height: 46px; padding-top: 9px; }
  .ich-item-copy h3 { font-size: 18px; margin-bottom: 12px; }
  .ich-line { gap: 6px; margin: 0 0 14px; }
  .ich-item-meta { gap: 8px; margin-top: 12px; }
  .ich-item-meta a, .ich-flag { padding: 6px 10px; font-size: 12px; }
  .ich-also-in { font-size: 12px; margin-top: 10px; }
  .ich-text-section { padding: 42px 0; }
  .ich-text-section-lead { padding: 46px 0 40px; }
  .ich-category-nav { position: static; }
  .ich-category-nav a { padding: 8px 12px; font-size: 13px; }
  .ich-mini-stats { gap: 8px; }
  .mini-points .ich-mini-stat { font-size: 13px; line-height: 1.6; }
  .ich-mini-stat + .ich-mini-stat::before { margin-right: 8px; }
}


.footer { padding: 52px 0 24px; background: #101a1e; color: rgba(255,255,255,.78); }
.footer-main { display: grid; grid-template-columns: 1.15fr 1.85fr; gap: 42px; align-items: start; }
.footer-brand strong { display: block; color: white; font-size: 24px; margin-bottom: 8px; }
.footer-brand p { margin: 0 0 12px; max-width: 440px; }
.footer-columns { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.footer-column h3 { color: white; font-size: 15px; margin-bottom: 12px; }
.footer-column a { display: block; color: rgba(255,255,255,.86); text-decoration: none; margin: 8px 0; }
.footer-column a:hover { color: white; }
.footer-subscribe { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-top: 30px; padding: 18px 22px; border: 1px solid rgba(255,255,255,.1); border-radius: 8px; background: rgba(255,255,255,.025); }
.footer-subscribe h3 { color: white; font-size: 17px; margin: 0 0 6px; }
.footer-subscribe p { margin: 0; color: rgba(255,255,255,.68); max-width: 560px; }
.footer-subscribe-btn { min-height: 42px; padding: 10px 18px; white-space: nowrap; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.14); margin-top: 34px; padding-top: 18px; font-size: 13px; color: rgba(255,255,255,.58); }
.video-strip { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(280px, 340px); gap: 18px; overflow-x: auto; padding: 4px 4px 18px; scroll-snap-type: x mandatory; }
.video-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.video-card { display: block; overflow: hidden; background: white; border: 1px solid var(--line); border-radius: 8px; text-decoration: none; box-shadow: 0 12px 34px rgba(21,32,37,.06); scroll-snap-align: start; }
.video-thumb { position: relative; aspect-ratio: 16 / 9; background: #0d171b; overflow: hidden; }
.video-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .25s ease; }
.video-thumb span { position: absolute; right: 12px; bottom: 12px; background: rgba(16,26,30,.86); color: white; border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 800; }
.video-card:hover .video-thumb img { transform: scale(1.04); }
.video-body { padding: 18px; }
.video-body h3 { font-size: 19px; line-height: 1.25; }
.youtube-section .hero-actions { margin-top: 18px; }
@media (max-width: 860px) {
  .footer-main, .footer-columns, .video-grid { grid-template-columns: 1fr; }
  .footer-subscribe { flex-direction: column; align-items: flex-start; }
  .video-strip { grid-auto-columns: minmax(250px, 86vw); }
}


.home-live-group { margin-top: 48px; }
.home-live-group:first-of-type { margin-top: 0; }
.section-head.compact { margin-bottom: 20px; }
.section-head.compact h2 { font-size: clamp(26px, 3vw, 36px); }
.section-head.compact p { font-size: 17px; margin-top: 14px; }
.section-slim { padding: 52px 0; }
.home-live .tour-card-featured { background: white; }
.home-focus-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.home-focus-grid a { text-decoration: none; color: inherit; }
.home-about { align-items: stretch; }
.home-about .feature-image { min-height: 100%; height: 100%; }
.home-cooperation { align-items: stretch; }
.home-cooperation .feature-image { min-height: 100%; height: 100%; }
.home-cooperation .feature-image img { object-position: center 38%; }
.partnerships-start { align-items: stretch; }
.partnerships-start .feature-image { min-height: 100%; height: 100%; }
.partnerships-start .feature-image img { object-position: center 34%; }
.home-hero { min-height: min(680px, calc(88vh - 74px)); }
.home-hero .hero-content { padding: 72px 0 58px; }
.home-hero h1 { font-size: clamp(38px, 6vw, 68px); max-width: 780px; }
.home-live-actions { justify-content: center; margin-top: 28px; }
.home-case-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.home-activity-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.home-journey-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.news-archive-prompt { display: grid; grid-template-columns: 1.4fr auto; gap: 28px; align-items: center; }
.news-archive-prompt .hero-actions { margin-top: 0; justify-content: flex-start; }
.home-case-grid .tile-body,
.home-activity-grid .tile-body,
.home-journey-grid .tile-body { min-height: 190px; }
.home-card .tile-body { min-height: 210px; }
.home-card p { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.home-video-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 860px) {
  .home-hero { min-height: 620px; }
  .home-focus-grid,
  .home-case-grid,
  .home-activity-grid,
  .home-journey-grid,
  .home-video-grid,
  .news-archive-prompt { grid-template-columns: 1fr; }
  .news-archive-prompt .hero-actions { margin-top: 18px; }
}

.lang-switch { display: inline-flex; gap: 8px; margin-bottom: 18px; flex-wrap: wrap; }
.lang-switch a { display: inline-flex; align-items: center; justify-content: center; min-width: 56px; padding: 8px 14px; border-radius: 999px; border: 1px solid rgba(255,255,255,.36); color: rgba(255,255,255,.88); text-decoration: none; font-size: 14px; font-weight: 700; }
.lang-switch a.active { background: white; color: var(--teal-dark); border-color: white; }
.article-split { align-items: stretch; }
.media-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.media-card { background: white; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; box-shadow: 0 12px 34px rgba(21,32,37,.06); }
.media-frame { position: relative; aspect-ratio: 16 / 9; background: #0d171b; }
.media-frame iframe, .media-frame video { width: 100%; height: 100%; display: block; border: 0; }
.gallery-credit { display: block; color: var(--muted); font-size: 13px; margin-top: 4px; }
@media (max-width: 860px) {
  .media-grid { grid-template-columns: 1fr; }
}
