:root{
--bg:#0b1020; --fg:#e7ecff; --muted:#b6c0e6;
--brand:#6ea8fe; --card:#111632; --accent:#8ef5c6;
--edge-fade:linear-gradient(90deg, rgba(11,16,32,1) 0%, rgba(11,16,32,0) 16%, rgba(11,16,32,0) 84%, rgba(11,16,32,1) 100%);
}
body{
margin:0;
font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
font-optical-sizing:auto;
font-variation-settings:"slnt" 0;
background:var(--bg); color:var(--fg); line-height:1.75;
text-rendering:optimizeLegibility; -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:1700px;margin:0 auto;padding:0 20px}
.site-header{position:sticky;top:0;background:rgba(11,16,32,.75);backdrop-filter:saturate(1.15) blur(10px);z-index:9;border-bottom:1px solid #1b2245}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px}
.brand img{width:60px;height:28px}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-pill{
position:relative; display:inline-flex; align-items:center; height:36px; padding:0 14px;
border-radius:999px; font-weight:700; letter-spacing:.2px; color:var(--fg);
background:
radial-gradient(80% 250% at 100% 0%, rgba(142,245,198,.18), transparent 60%),
linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
border:1px solid #263057;
box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 0 0 0 rgba(110,168,254,.0);
transition:.25s transform, .25s box-shadow, .25s border-color;
}
.nav-pill:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(110,168,254,.18);border-color:#3450a8}
.btn{background:var(--brand);color:#ffffff;padding:10px 14px;border-radius:12px;font-weight:800;display:inline-block;border:0}
.btn.small{padding:8px 12px;border-radius:10px}
.hero{padding:60px 0;background:radial-gradient(1200px 400px at 70% -10%, #243065, transparent)}
.hero-grid{display:grid;grid-template-columns:1.1fr 1.1fr .9fr;gap:24px;align-items:flex-start;}

.fullname{opacity:.95;font-weight:800;margin-top:-6px}
.meta{list-style:none;padding:0;margin:10px 0 12px;color:var(--muted)}
.meta li{margin:4px 0}
.countdown{display:flex;gap:12px;margin-top:6px}
.countdown div{background:var(--card);padding:10px 14px;border-radius:12px;text-align:center;border:1px solid #1f2647}
.countdown span{font-size:28px;font-weight:900;display:block;letter-spacing:.5px}

.section.alt{background:linear-gradient(180deg,#0c1228,#0b1020)}
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.prose{white-space:pre-wrap}
.dates{width:100%;border-collapse:collapse}
.dates td{border-bottom:1px solid #1f2647;padding:6px 8px}
.dates .date{white-space:nowrap;font-weight:800}
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.topic-grid.pretty .topic-card{
display:flex;
align-items:center;
justify-content:center;
text-align:center;
padding:16px 18px;
min-height:120px;
border:1px solid #26316a;
border-radius:14px;
background:rgba(10,15,33,.35);
transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.topic-grid.pretty .topic-card:hover{
transform:translateY(-3px);
border-color:#3b4aa0;
box-shadow:0 14px 28px rgba(20,30,60,.35);
}
.topic-grid.pretty .topic-card h3{
position:relative;
margin:0;
font-size:20px;
font-weight:800;
letter-spacing:.2px;
padding-top:18px;
}
.topic-grid.pretty .topic-card h3::before{
content:"";
position:absolute;
top:0;
left:50%;
transform:translateX(-50%);
width:120px;
height:4px;
border-radius:2px;
background:linear-gradient(90deg,#7bd4ff 0%, #8ef5c6 100%);
opacity:.95;
}
.timeline{position:relative;margin-left:10px;padding-left:20px}
.timeline:before{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:#263057}
.tl-item{position:relative;margin:2px 0;padding-left:24px}
.tl-dot{position:absolute;left:2px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--brand);border:2px solid #0a0f21;box-shadow:0 0 0 3px rgba(110,168,254,.2)}
.tl-content{background:var(--card);border:1px solid #1f2647;border-radius:12px;padding:10px 12px}
.carousel{position:relative;overflow:hidden}
.carousel .mask{position:absolute;top:0;bottom:0;width:14%;pointer-events:none;z-index:2}
.carousel .mask-left{left:0;background:linear-gradient(90deg, rgba(11,16,32,1), rgba(11,16,32,0))}
.carousel .mask-right{right:0;background:linear-gradient(90deg, rgba(11,16,32,0), rgba(11,16,32,1))}
.track{
display:flex;gap:16px;align-items:center;will-change:transform;
padding:8px 0;
}
.j-item{
display:inline-flex;align-items:center;gap:10px;
background:var(--card);border:1px solid #1f2647;border-radius:14px;
padding:10px 12px; height:56px; min-width:180px;
transition:.2s transform,.2s border-color;
}
.j-item:hover{transform:translateY(-2px);border-color:#3352cc}
.j-item img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}
.j-item span{font-weight:800;letter-spacing:.2px}
.committee-grid{
display:grid;grid-template-columns:repeat(3,1fr);gap:16px
}
.m-card{
background:var(--card);border:1px solid #1f2647;border-radius:16px;padding:16px;
transition:.25s transform,.25s border-color,.25s box-shadow;
}
.m-card:hover{transform:translateY(-3px);border-color:#3b4aa0;box-shadow:0 14px 28px rgba(20,30,60,.35)}
.m-card h3{margin:0 0 6px 0;font-weight:900}
.m-card .muted{color:var(--muted)}
.m-card .tag{display:inline-block;margin-top:8px;padding:4px 8px; font-size: 14px;border-radius:999px;background:rgba(110,168,254,.18);border:1px solid #3a4fb8;font-weight:800}
.tag{
  color: #ffffff;
  display:inline-block;
  margin-top:8px;          /* 注意：在 h2 里视觉不明显，见下一条 */
  padding:4px 8px;
  font-size:12px;
  border-radius:999px;
  background:rgba(110,168,254,0.18); /* 你的原文件写成了 18，alpha 应该是 0~1 */
  border:1px solid #3a4fb8;
  font-weight:300;
}
.rules{display:grid;gap:8px}
.rule{background:var(--card);border:1px solid #1f2647;border-radius:12px;padding:10px 12px}
.sponsor-cards{display:grid;gap:10px}
.sp-card{background:var(--card);border:1px solid #1f2647;border-radius:12px;padding:10px 12px}
.footer{border-top:1px solid #20274a;padding:20px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
.reg-form label{display:block;margin-bottom:10px}
.reg-form input,.reg-form textarea{width:100%;padding:10px;border-radius:10px;border:1px solid #263057;background:#0a0f21;color:var(--fg)}
.reg-form textarea{min-height:90px;resize:vertical}
[data-reveal]{opacity:0; transform:translateY(10px); transition:opacity 1.6s ease, transform 1.6s ease}
[data-reveal].revealed{opacity:1; transform:none}
.avatar{width:200px;height:200px;border-radius:999px;border:2px solid #2f3a73;object-fit:cover;background:#0a0f21}
.sponsor-regions{display:flex;gap:16px;align-items:center;overflow-x:auto;padding-bottom:8px}
.sponsor-grid{display:flex;gap:16px;padding-left: 55px;}
.sponsor-slot{border:1px solid #1f2647;border-radius:12px;background:#0a0f21;padding:10px;display:flex;align-items:center;justify-content:center;min-height:90px}
.sponsor-slot img{height:90px;max-height:90px;width:auto;object-fit:contain}
.journals-center{display:flex;justify-content:center}
.journals-list{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.j-pill{
display:inline-flex;align-items:center;justify-content:center;
padding:10px 16px;border-radius:999px;
font-size:26px;font-weight:900;letter-spacing:.2px;
background:rgba(255,255,255,.06);
border:1px solid #28305b;
}
.sponsor-regions{display:flex;flex-wrap:wrap;gap:16px;align-items:center;padding-bottom:8px;overflow-x:visible}
.sponsor-grid{display:flex;flex-wrap:wrap;gap:16px}
.sponsor-slot{border:0;background:transparent;padding:0;display:flex;align-items:center;justify-content:center}
.sponsor-slot img{height:90px;max-height:90px;width:auto;object-fit:contain}
.nav-actions{display:flex; align-items:center}
.nav-list{display:flex; align-items:center; gap:10px; list-style:none; margin:0; padding:0}
.nav-link{display:inline-flex; align-items:center; gap:6px; padding:10px 12px; border-radius:999px;
text-decoration:none; font-weight:700; color:var(--fg);}
.nav-link:hover{background:#161d3f}
.has-submenu{position:relative}
.dropdown-toggle{cursor:pointer; background:transparent; border:0; font:inherit; color:inherit}
.dropdown-toggle .chev{transition:transform .2s ease}
.has-submenu[aria-expanded="true"] .dropdown-toggle .chev{transform:rotate(180deg)}
.dropdown-menu{
position:absolute; top:calc(100% + 8px); left:0; min-width:200px;
background:var(--card); border:1px solid #1f2647; border-radius:12px;
box-shadow:0 18px 40px rgba(0,0,0,.35);
opacity:0; transform:translateY(-4px); pointer-events:none; transition:.18s ease;
padding:8px; z-index:40;
}
.has-submenu.open > .dropdown-menu{opacity:1; transform:none; pointer-events:auto}
.dropdown-item{display:block; padding:10px 12px; border-radius:8px; color:var(--fg); font-weight:700; text-decoration:none}
.dropdown-item:hover{background:#161d3f}
.hero-slim{padding:36px 0;background:radial-gradient(1000px 300px at 70% -10%, #243065, transparent)}
.list-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:16px;
align-items:start;
}
.panel{
background:var(--card);
border:1px solid #1f2647;
border-radius:16px;
padding:18px;
transition:.25s transform,.25s border-color,.25s box-shadow;
}
.panel:hover{transform:translateY(-3px);border-color:#3b4aa0;box-shadow:0 14px 28px rgba(20,30,60,.35)}
.panel h2{margin:4px 0 10px 0;font-weight:900}
.panel-kicker{
display:inline-block; padding:4px 10px; margin-bottom:6px;
border-radius:999px; font-size:12px; font-weight:800; letter-spacing:.3px;
background:rgba(110,168,254,.18); border:1px solid #3a4fb8; color:var(--fg);
}
.checklist{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.checklist li{
position:relative; padding-left:26px; line-height:1.6;
}
.checklist li::before{
content:""; position:absolute; left:0; top:.55em;
width:16px; height:16px; border-radius:4px; border:2px solid #3a4fb8;
background:
radial-gradient(60% 60% at 50% 50%, #8ef5c6 0 50%, transparent 55% 100%),
linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
box-shadow:0 0 0 2px rgba(110,168,254,.12);
}
.checklist.columns-2{grid-template-columns:1fr 1fr}
.checklist.columns-1{grid-template-columns:1fr}
.prose-justify{
text-align: justify;
text-justify: inter-word;
hyphens: auto;
line-height: 1.75;
}
.prose-justify:last-child{
text-align-last: justify;
}
.journals-list{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.journal{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.08);padding:10px 10px;border-radius:14px;background:rgba(185, 185, 185, 0.082)}
.journal-cover{width:auto;height:90px;object-fit:cover;border-radius:8px;border:1px }
.journal .j-pill{margin:0}
:root{
--bg:#0b1020; --fg:#e7ecff; --muted:#b6c0e6;
--brand:#6ea8fe; --card:#111632; --accent:#8ef5c6;
--border:#1b2245;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
background:var(--bg);color:var(--fg);line-height:1.75}
a{color:#b7c3ff;text-decoration:none}

.site-header{position:sticky;top:0;background:rgba(11,16,32,.75);
-webkit-backdrop-filter:saturate(1.15) blur(10px);backdrop-filter:saturate(1.15) blur(10px);
z-index:9;border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px;color: #8ef5c6;}
.brand img{height:22px}
.nav-actions{display:flex;align-items:center}
.nav-list{display:flex;gap:14px;list-style:none;margin:0;padding:0}
.nav-item{position:relative}
.nav-link{display:inline-flex; align-items:center; gap:6px; padding:10px 12px; border-radius:19px;
text-decoration:none; font-weight:700; color:var(--fg);}
.nav-link:hover,.nav-link.is-active{background:rgba(255,255,255,.06)}
.nav-item.has-submenu .dropdown-toggle{background:transparent;border:0;color:inherit;font:inherit;
display:inline-flex;align-items:center;gap:6px;padding:10px 12px;border-radius:999px;cursor:pointer}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;min-width:184px;
background:rgba(14,20,45,.98);border:1px solid var(--border);border-radius:12px;padding:8px;
box-shadow:0 18px 40px rgba(0,0,0,.35)}
.nav-item.has-submenu:hover .dropdown-menu{display:block}
.dropdown-item{display:block;padding:8px 10px;border-radius:8px;color:inherit}
.dropdown-item:hover{background:rgba(255,255,255,.06)}
.muted{opacity:.85}
#topics .topics-hero{text-align:center;margin:22px 0 10px 0}
#topics .topic-title{font-weight:900;letter-spacing:.5px;font-size:clamp(28px,4.2vw,42px)}
#topics .topic-card{
background:var(--card);border:1px solid #263057;border-radius:16px;
padding:18px;margin-bottom:18px;box-shadow:0 14px 28px rgba(20,30,60,.35);
}
#topics .topics{columns:1;column-gap:0;margin:0;padding:0;list-style:none}
#topics .topics li{margin:8px 0;padding-left:18px;position:relative;line-height:1.65}
#topics .topics li::before{content:"▹";position:absolute;left:0;top:0;color:var(--accent)}
.footer{margin:26px 0 40px;border-top:1px solid rgba(255,255,255,.08);padding-top:14px;opacity:.9}
:root{
--co-border:#1f2647;
--co-card: rgba(12,16,36,.6);
}
body{font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial}

.muted{opacity:.85}
.card:hover{transform:translateY(-2px);border-color:#3b4aa0;box-shadow:0 10px 20px rgba(20,30,60,.35)}
h2.kicker{font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:#aeb7ff;margin:0 0 8px 0}
.item{ font-size: 18px; display:flex;align-items:flex-start;gap:12px;padding:12px 0;padding-left: 40px;border-bottom:1px dashed var(--co-border)}
.item:last-child{border-bottom:none}
.badge{border:1px solid #3a4fb8;border-radius:999px;padding:2px 8px;font-size:12px;margin-left:8px}
.table-wrap{overflow:auto;border:1px solid var(--co-border);border-radius:16px}
table{width:100%;border-collapse:collapse;background:rgba(255,255,255,.02)}
th,td{padding:12px 10px;border-bottom:1px solid var(--co-border);text-align:left}
th{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:#aeb7ff;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0))}
tr:hover td{background:rgba(255,255,255,.02)}
.country{font-weight:800;opacity:.85;white-space:nowrap}
:root{
--prog-green:#14856f;
--prog-green-2:#0f6c59;
--prog-border:#1b2245;
--pill:#f89e8b;
}

.prog{display:grid;gap:20px}
.day-row{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:flex-start}
.day-badge{display:flex;align-items:center;gap:12px}
.badge-icon{width:42px;height:42px;border-radius:50%;background:var(--pill);display:grid;place-items:center;box-shadow:0 4px 10px rgba(0,0,0,.25);border:2px solid rgba(255,255,255,.35)}
.badge-icon svg{width:24px;height:24px}
.badge-title{font-size:20px;font-weight:800}
.panel{background:linear-gradient(135deg,var(--prog-green),var(--prog-green-2));border-radius:8px;border:1px solid rgba(0,0,0,.18);color:#fff;padding:16px 18px}
.slot{display:flex;gap:16px;align-items:center;padding:10px 0}
.time{min-width:140px;font-weight:900}
.dotline{flex:1;border-bottom:2px dashed rgba(255,255,255,.8);transform:translateY(-2px)}
.title{font-weight:800}
.desc{opacity:.95;margin-left:156px;margin-top:-6px;margin-bottom:10px}
.label{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.5);font-size:12px;margin-left:8px}
:root{
--spk-accent:#3a4fb8;
--spk-border:#1f2647;
--spk-card: rgba(12,16,36,.6);
}
.hero-spk{padding:48px 0;background:radial-gradient(1000px 300px at 70% -10%, #243065, transparent);}

.muted{opacity:.85}
.filters{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px}
.search{flex:1 1 260px;display:flex;align-items:center;gap:8px;border:1px solid var(--spk-border);border-radius:12px;padding:8px 12px;background:rgba(255,255,255,.02)}
.search input{flex:1;border:none;outline:none;background:transparent;color:inherit}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--spk-border);border-radius:999px;cursor:pointer;font-weight:700}
.chip[data-active="true"]{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.reset{margin-left:auto;}
.grid{display:grid;gap:16px}
.grid.cards{grid-template-columns:repeat(3,1fr)}
.card.speaker{
background:var(--spk-card);border:1px solid var(--spk-border);border-radius:16px;padding:14px;
display:grid;grid-template-columns:92px 1fr;gap:12px;align-items:center;
transition:.25s transform,.25s border-color,.25s box-shadow;
}
.card.speaker:hover{transform:translateY(-3px);border-color:#3b4aa0;box-shadow:0 14px 28px rgba(20,30,60,.35)}
.avatar{width:92px;height:92px;border-radius:20px;object-fit:cover;border:2px solid rgba(138,160,255,.35)}
.spk-name{margin:0;font-size:20px;font-weight:900}
.spk-meta{margin:2px 0 6px 0;opacity:.85;font-style:italic}
.badge{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid #3a4fb8;font-size:12px;margin-right:6px}
.btn{
appearance:none;display:inline-flex;align-items:center;gap:8px;
padding:8px 12px;border-radius:12px;border:1px solid var(--spk-border);
text-decoration:none;font-weight:700;transition:.2s transform,.2s box-shadow,.2s border-color
}
.btn.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.btn.ghost{background:transparent;color:#e6ecff}
.modal{position:fixed;inset:0;background:rgba(5,8,18,.6);backdrop-filter:saturate(120%) blur(6px);display:none;align-items:flex-start;justify-content:center;padding:30px 16px;z-index:2000}
.modal[open]{display:flex}
.modal-card{max-width:900px;width:100%;background:#0b1020;color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:16px;box-shadow:0 30px 60px rgba(0,0,0,.6);overflow:hidden}
.modal-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.18);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,0));color:#fff}
.modal-body{padding:18px;color:#fff;line-height:1.8;max-height:65vh;overflow:auto}
.close{margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:10px;padding:6px 12px;cursor:pointer;font-weight:800}
.bio{opacity:1;color:#fff;line-height:1.85}
.abstract{margin-top:14px;border-top:1px dashed rgba(255,255,255,.25);padding-top:12px;color:#fff}
:root{
--cfp-accent:#3a4fb8;
--cfp-bg: radial-gradient(1000px 300px at 70% -10%, #243065, transparent);
--card-bg: rgba(12,16,36,.6);
--border: #1f2647;
}
.hero-cfp{padding:48px 0;background:var(--cfp-bg);}

.muted{opacity:.85}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.btn{
appearance:none;display:inline-flex;align-items:center;gap:8px;
padding:10px 16px;border-radius:12px;border:1px solid var(--border);
text-decoration:none;font-weight:700;transition:.2s transform,.2s box-shadow,.2s border-color
}
.btn.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.btn.ghost{background:transparent;color:#e6ecff}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(20,30,60,.35)}
.alt{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(0,0,0,0))}
.grid{display:grid;gap:16px}
.grid.two{grid-template-columns:1fr 1fr}
.grid.three{grid-template-columns:repeat(3,1fr)}

.card:hover{transform:translateY(-3px);border-color:#3b4aa0;box-shadow:0 14px 28px rgba(20,30,60,.35)}
h2.kicker{font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:#aeb7ff;margin:0 0 8px 0}

.timeline{position:relative;padding-left:20px;display:grid;gap:12px}
.timeline::before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:#3a4fb8}
.titem{position:relative;padding-left:16px}
.titem::before{content:"";position:absolute;left:-2px;top:.35em;width:10px;height:10px;border:2px solid #8ef5c6;border-radius:50%;background:#142040}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid #3a4fb8;font-size:12px;margin-left:8px}
.topics{columns:2;column-gap:24px}
.topics li{break-inside:avoid;margin:6px 0;padding-left:18px;position:relative;line-height:1.55}
.topics li::before{content:"▹";position:absolute;left:0;top:0;color:#8ef5c6}
details.faq{border:1px solid var(--border);border-radius:14px;padding:14px;background:rgba(255,255,255,.02)}
details.faq summary{cursor:pointer;font-weight:800;outline:none}
.foot-note{font-size:15px;opacity:.8}
:root{
--v-border:#1f2647;
--v-card:#0f1532;
--v-soft: rgba(255,255,255,.04);
}

.hero{padding:56px 0;background:radial-gradient(1000px 300px at 70% -10%, #243065, transparent)}
.lede{opacity:.9;max-width:880px}
.feature{display:grid;grid-template-columns:1.15fr .85fr;gap:20px;align-items:center}
.feature.reverse{grid-template-columns:.85fr 1.15fr}
.feature.reverse .figure{order:2}
.feature.reverse .content{order:1}
.content{
background:var(--v-soft);
border:1px solid var(--v-border);
border-radius:16px;
padding:18px 18px 16px 18px;
}
.content h2{margin:0 0 8px 0;font-weight:900}
.content p{line-height:1.8;margin:10px 0}
.pillrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.pill{border:1px solid var(--v-border);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,0));border-radius:999px;padding:8px 12px;font-weight:800}
.figure{
position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--v-border);background:#0c1024
}
.figure img{display:block;width:100%;height:100%;object-fit:cover}
.caption{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.45);backdrop-filter:saturate(120%) blur(2px);padding:6px 10px;border-radius:10px;font-size:12px}
.mosaic{display:grid;gap:10px;grid-template-columns:2fr 1fr;grid-auto-rows:170px}
.mosaic img{width:100%;height:100%;object-fit:cover;border-radius:14px;border:1px solid var(--v-border)}
.mosaic .tall{grid-row:span 2}
.mosaic .wide{grid-column:span 2}
.list{list-style:none;padding-left:0;display:grid;gap:8px}
.list li{position:relative;padding-left:18px}
.list li::before{content:"▹";position:absolute;left:0;top:0;color:#8ef5c6}
.btn{appearance:none;display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;border:1px solid var(--v-border);text-decoration:none;font-weight:700}
.btn.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.subnav{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
:root{
--visa-border:#1f2647;
--visa-card: rgba(12,16,36,.6);
}
.hero-visa{padding:48px 0;background:radial-gradient(1000px 300px at 70% -10%, #243065, transparent);}

.muted{opacity:.85}
.grid{display:grid;gap:16px}
.grid.two{grid-template-columns:1fr 1fr}
.card:hover{transform:translateY(-3px);border-color:#3b4aa0;box-shadow:0 14px 28px rgba(20,30,60,.35)}
h2.kicker{font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:#aeb7ff;margin:0 0 8px 0}
.btn{appearance:none;display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;border:1px solid var(--visa-border);text-decoration:none;font-weight:700}
.btn.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.btn.ghost{background:transparent;color:#e6ecff}
.timeline{position:relative;padding-left:20px;display:grid;gap:12px}
.timeline::before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:#3a4fb8}
.titem{position:relative;padding-left:16px}
.titem::before{content:"";position:absolute;left:-2px;top:.35em;width:10px;height:10px;border:2px solid #8ef5c6;border-radius:50%;background:#142040}
ul.check{list-style:none;padding-left:0;display:grid;gap:8px}
ul.check li{position:relative;padding-left:22px}
ul.check li::before{content:"✓";position:absolute;left:0;top:0;color:#8ef5c6;font-weight:900}
details.faq{border:1px solid var(--visa-border);border-radius:14px;padding:14px;background:rgba(255,255,255,.02)}
details.faq summary{cursor:pointer;font-weight:800;outline:none}
:root{
--c-border:#1f2647;
--c-card: rgba(12,16,36,.6);
}

.hero{padding:4px 0;background:radial-gradient(1000px 300px at 70% -10%, #243065, transparent);}
.page-title{margin:0 0 8px 0;font-size:40px;font-weight:900;letter-spacing:.2px; color: #8ef5c6;}
.muted{opacity:.85}
.section{padding: 28px 0;}
.grid{display:grid;gap:16px}
.grid.two{grid-template-columns:1fr 1fr}
h2.kicker{font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:#aeb7ff;margin:0 0 8px 0}
.profile{display:grid;grid-template-columns:84px 1fr;gap:12px;align-items:center}
.avatar{width:84px;height:84px;border-radius:50%;object-fit:cover;border:2px solid rgba(138,160,255,.35);background:linear-gradient(180deg,#5a6dde,#3547a6)}
.name{margin:0;font-weight:900;font-size:18px}
.role{margin:0;opacity:.9}
.contacts a{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--c-border);border-radius:12px;padding:8px 12px;text-decoration:none;font-weight:700}
.contacts a.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.contacts{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.faq{border:1px solid var(--c-border);border-radius:14px;padding:14px;background:rgba(255,255,255,.02)}
.faq summary{cursor:pointer;font-weight:800;outline:none}
form.contact{display:grid;gap:10px}
.field{display:grid;gap:6px}
.field input,.field textarea{
background:rgba(255,255,255,.02);border:1px solid var(--c-border);border-radius:12px;
padding:10px 12px;color:inherit;outline:none
}
.btn{appearance:none;display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;border:1px solid var(--c-border);text-decoration:none;font-weight:700}
.btn.primary{background:linear-gradient(180deg,#4f62d1,#3a4fb8);color:#fff;border-color:#3547a6}
.note{font-size:13px;opacity:.8}
.map{border:1px solid var(--c-border);border-radius:16px;overflow:hidden}
.copy{cursor:pointer;border:1px dashed var(--c-border);padding:4px 8px;border-radius:10px;margin-left:6px;font-size:12px}
.hero-cta{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:20px;
  margin-top:10px;
}
.countdown{
  display:flex;
  gap:12px;
}
.countdown div{
  background:var(--card);
  padding:10px 14px;
  border-radius:12px;
  text-align:center;
  border:1px solid #1f2647;
}
.countdown span{
  font-size:28px;
  font-weight:900;
  display:block;
  letter-spacing:.5px;
}

.hero-title-row {
  display: flex;
  align-items: center;
  gap: 26px; 
}

.register {
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  text-decoration: none;
}

.register{
background:#8ef5c6;
color:#0b1222 !important;
border-radius:9px;
padding:12px 16px;
line-height:1;
box-shadow:0 0 0 0 rgba(142,245,198,.6);
transition:
transform .25s ease,
box-shadow .45s cubic-bezier(.2,.6,.2,1),
filter .25s ease,
background-color .25s ease;
font-weight: 800;
}
.register[href*="register"]:hover,
.register[href*="register"]:focus-visible{
transform:translateY(-2px);
filter:saturate(1.05);
box-shadow:0 8px 20px 0 rgba(142,245,198,.35);
}
.register[href*="register"]:active{
transform:translateY(0);
box-shadow:0 4px 12px 0 rgba(142,245,198,.3);
}
.register[href*="register"].is-active{
background:#8ef5c6;
color:#0b1222 !important;
box-shadow:0 10px 24px 0 rgba(142,245,198,.38);
}
.footer-graphic{background:#0b0f1f;border-top:1px solid #20274a}
.footer-graphic .fgrid{
display:grid;
grid-template-columns:1.2fr 1fr 1fr 1.2fr;
gap:24px;
align-items:start;
padding:28px 0;
}
.footer-graphic h4{margin:0 0 8px 0;font-size:18px;font-weight:900;letter-spacing:.3px}
.footer-graphic ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-graphic a{color:var(--fg)}
.footer-graphic .fbrand img{max-width:180px;display:block;margin-bottom:10px;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35))}
.footer-graphic .fcontact li{display:flex;align-items:center;gap:10px}
.footer-graphic .fcontact svg{width:18px;height:18px;opacity:.9;flex:none}
.footer-graphic .copyright{border-top:1px solid #20274a;background:#0a0f1f}
.footer-graphic .copyright p{margin:0;padding:10px 0;opacity:.9;font-size:14px}
.has-submenu:hover > .dropdown-menu,
.has-submenu:focus-within > .dropdown-menu,
.has-submenu[aria-expanded="true"] > .dropdown-menu{
opacity:1; transform:none; pointer-events:auto;
}
.has-submenu{ --dd-gap:0px; position:relative; }
.dropdown-menu{ top:100%; margin-top:0; }
.has-submenu:hover .dropdown-toggle .chev,
.has-submenu:focus-within .dropdown-toggle .chev{ transform:rotate(180deg); }
img, video, canvas, svg { max-width: 100%; height: auto; }
.wrap { max-width: 1400px; margin: 0 auto; padding: 20px 16px; }
:root{
--fs-h1: clamp(28px, 6vw, 48px);
--fs-h2: clamp(22px, 5vw, 32px);
--fs-body: clamp(14px, 3.8vw, 18px);
}
h1{ font-size: var(--fs-h1); }
h2{ font-size: var(--fs-h2); }
body, .prose, p, li{ font-size: var(--fs-body); line-height: 1.75; }
.hamburger{
display:none; background:transparent; border:0; font-size:28px; line-height:1;
color:var(--fg); padding:6px 10px; border-radius:10px;
}
.mobile-drawer[hidden]{ display:none; }
.mobile-drawer{
position:fixed; inset:0; z-index:2000; display:grid; grid-template-rows:auto 1fr;
background:rgba(5,8,18,.7); backdrop-filter: blur(6px);
}
.drawer-head{
display:flex; align-items:center; gap:10px; padding:12px 16px;
background:var(--card); border-bottom:1px solid #1f2647; color:var(--fg); font-weight:900;
}
.drawer-close{ margin-left:auto; background:transparent; border:1px solid #3a4fb8; color:var(--fg); border-radius:10px; padding:6px 10px; font-weight:800; }
.drawer-nav{
overflow:auto; background:var(--bg); padding:14px 16px 24px;
display:grid; gap:8px;
}
.drawer-nav a{
display:block; padding:12px 14px; border:1px solid #1f2647; border-radius:12px; text-decoration:none; color:var(--fg); font-weight:800;
}
.drawer-nav details{ border:1px solid #1f2647; border-radius:12px; padding:8px 12px; background:rgba(255,255,255,.02) }
.drawer-nav summary{ cursor:pointer; font-weight:900; outline:none }
.drawer-nav details a{ margin-top:6px; }
:root{
--brand:#3b4aa0;
--brand-2:#8ef5c6;
--ink:#0d1220;
--muted:#d4d4d4;
--bg:#0a0f1c;
--card:#10162a;
--line:rgba(255,255,255,.08);
--ring:rgba(142,245,198,.35);
}
html,body{scroll-behavior:smooth}
a{transition:color .2s ease}
.btn{transition:transform .15s ease, box-shadow .2s ease}
.btn:active{transform:translateY(1px)}
.btn.primary{box-shadow:0 8px 20px rgba(62, 149, 245, .18)}
.btn.primary:hover{box-shadow:0 10px 28px rgba(62, 149, 245, .26)}
.nav-link{position:relative}
.nav-link::after{
content:""; position:absolute; left:8px; right:8px; bottom:6px; height:2px;
background:linear-gradient(90deg, var(--brand), var(--brand-2));
opacity:0; transform:scaleX(0); transform-origin:center; transition:all .25s ease;
}
.nav-link:hover::after{opacity:1; transform:scaleX(1)}
.card{
background:var(--card);
border:1px solid var(--line);
border-radius:16px;
box-shadow:0 6px 24px rgba(0,0,0,.22);
transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
transform:translateY(-3px);
border-color:var(--brand);
box-shadow:0 16px 36px rgba(13,18,32,.45);
}
.badge,.pill{
background:linear-gradient(135deg, rgba(59,74,160,.2), rgba(142,245,198,.18));
border:1px solid var(--line);
color:#dfe7ff;
}
.chip{transition:background .2s ease, border-color .2s ease}
.chip[data-active="true"]{
background:rgba(142,245,198,.16);
border-color:var(--brand-2);
}
.dropdown-menu{
transform:translateY(8px);
opacity:0; pointer-events:none; transition:opacity .15s ease, transform .15s ease;
}
.has-submenu[aria-expanded="true"] .dropdown-menu,
.has-submenu .dropdown-menu[aria-expanded="true"]{
opacity:1; pointer-events:auto; transform:translateY(0);
}
[data-reveal]{opacity:0; transform:translateY(12px); transition:opacity .5s ease, transform .5s ease}
.revealed{opacity:1 !important; transform:translateY(0) !important}
.brand-title{font-size:24px !important; font-weight:700}
.mt-10{margin-top:10px !important}
.mt-8{margin-top:8px !important}
.row-flex{display:flex !important}
.gap-8{gap:8px !important}
.wrap .cta-row{display:flex; gap:10px; flex-wrap:wrap}
.avatar-sm{width:64px !important; height:64px !important; border-radius:12px !important; object-fit:cover}
.nav-link[href*="register"], .nav-link[href*="Register"], .nav-link.is-registration{ position:static }
.nav-link[href*="register"]::after,
.nav-link[href*="Register"]::after,
.nav-link.is-registration::after{ content:none; display:none }
:root{
--content-width: 1480px;
}
.site-header{ width:100% }
.nav{
max-width: var(--content-width);
margin: 0 auto;
padding: 0 24px;
display:flex;
align-items:center;
justify-content:space-between;
}
.faq-list details.faq summary{cursor:pointer;font-weight:800}
.faq-list details.faq[hidden]{display:none !important}
.faq-chips .nav-pill{height:32px;padding:0 12px}
.faq-controls .btn.small{height:32px}
.notice-wrap{max-width:1100px;margin:0 auto;padding:24px}
.card.table-card{background:var(--card);border:1px solid var(--line);border-radius: 12px;box-shadow:0 12px 36px rgba(0,0,0,.28)}
.notice-table{width:100%;border-collapse:separate;border-spacing:0;color:#dfe7ff}
.notice-table thead th{
text-align:left; font-size:12px; letter-spacing:.08em; text-transform:uppercase;
color: #bfc7ff; padding:16px 18px; border-bottom:1px solid var(--line);}
.notice-table tbody tr{background:transparent; transition:background .2s ease}
.notice-table tbody tr + tr td{border-top:1px solid rgba(255,255,255,.04)}
.notice-table tbody td{padding:16px 18px; vertical-align:middle}
.notice-table tbody tr:hover{background:rgba(255,255,255,.03)}
.notice-table .cat{font-weight:700}
.notice-table .title{font-weight:600}
.pill-view{
display:inline-flex; align-items:center; gap:6px;
padding:8px 12px; border-radius:999px; border:1px solid var(--line);
text-decoration:none; color:#dfe7ff;
transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
font-size:13px; }
.pill-view:hover{border-color:var(--brand); box-shadow:0 8px 20px var(--ring); transform:translateY(-1px)}
.modal-backdrop{position:fixed; inset:0; background:rgba(2,8,21,.55); display:none; align-items:center; justify-content:center; z-index:1000}
.modal-backdrop[aria-hidden="false"]{display:flex}
.modal{width:min(760px, 92vw); background:var(--card); border:1px solid var(--line); border-radius:16px; box-shadow:0 20px 64px rgba(0,0,0,.45)}
.modal-header{display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--line)}
.modal-title{font-size:18px; font-weight:800}
.modal-body{padding:18px}
.modal-meta{display:flex; gap:16px; color:#9fb0d0; font-size:14px; margin-bottom:8px}
.btn-close{background:transparent; border:0; color:#cbd6ff; font-size:20px; cursor:pointer}
.news-wrap{max-width:1320px;margin:0 auto;padding:28px}
.breadcrumb{font-size:14px;color:#9fb0d0}
.breadcrumb a{color:#c8d3ff;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.news-header{margin-top:12px;margin-bottom:18px}
.news-title{font-size:34px;font-weight:900;letter-spacing:.2px}
.news-meta{display:flex;gap:16px;color:#9fb0d0;margin-top:6px}
.news-hero{margin:16px 0;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.news-hero img{width:100%;height:360px;object-fit:cover;display:block}
.news-body{display:grid;grid-template-columns: 2.2fr 1fr; gap:24px; align-items:start}
.news-content{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 10px 28px rgba(0,0,0,.28)}
.news-content h2{margin:16px 0 8px}
.news-content p{line-height:1.7;color:#dfe7ff}
.news-side{position:sticky; top:24px}
.side-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 10px 28px rgba(0,0,0,.22)}
.side-card h3{font-size:16px;letter-spacing:.06em;color:#bfc7ff;text-transform:uppercase;margin-bottom:8px}
.side-list{list-style:none;margin:0;padding:0}
.side-list li+li{margin-top:10px;border-top:1px dashed var(--line);padding-top:10px}
.side-list a{color:#dfe7ff;text-decoration:none}
.side-list a:hover{color:#8ef5c6}
.back-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;text-decoration:none;color:#dfe7ff;border:1px solid var(--line);padding:10px 14px;border-radius:999px}
.back-link:hover{border-color:var(--brand);box-shadow:0 8px 20px var(--ring);transform:translateY(-1px)}
.program-hero .title{margin:0 0 6px;font-size:42px;letter-spacing:.3px}
.program-hero .sub{margin:0;color:var(--muted)}
.program-wrap{max-width:1100px;margin:0 auto;padding:0 20px}
.day-card{background:var(--card);border:1px solid #1f2647;border-radius:16px;margin:16px 0;overflow:hidden}
.day-head{padding:16px 18px;border-bottom:1px solid #1f2647}
.day-head h2{margin:0;font-size:22px;font-weight:900;letter-spacing:.3px}
.day-head .tag{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;
background:radial-gradient(100% 200% at 100% 0%, rgba(142,245,198,.18), rgba(142,245,198,0));
border:1px solid #2a3a6a;color:var(--fg);font-size:12px;font-weight:800}
.day-grid{display:grid;grid-template-columns:1fr 420px;gap:18px;padding:12px 18px}
@media (max-width:1000px){.day-grid{grid-template-columns:1fr}}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{display:grid;grid-template-columns:140px 1fr auto;gap:10px;align-items:center;
padding:12px 0;border-bottom:1px dashed #28305b}
.timeline li:last-child{border-bottom:0}
.timeline .time{white-space:nowrap;font-weight:900;letter-spacing:.2px}
.timeline .title{font-weight:800}
.timeline .room{opacity:.8;font-size:13px}
.timeline li.em .title strong{font-weight:900;color:var(--accent)}
.photo-box{margin:0;border-radius:12px;overflow:hidden;border:1px solid #1f2647;
background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))}
.photo-box img{display:block;width:100%;height:auto}
.photo-box figcaption{padding:8px 12px;color:var(--muted);font-size:13px}
.note{opacity:.75;font-size:13px;margin:8px 2px}
.day-card, .day-card * { outline: 0 !important; }
.day-card,
.day-card .timeline,
.day-card .timeline li,
.day-card .photo-box { border-left: 0 !important; }
.day-card::before, .day-card::after,
.day-card .timeline::before, .day-card .timeline::after {
content: none !important;
display: none !important;}
.lead{opacity:.9}
.pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media (max-width: 960px){.pricing-grid{grid-template-columns:1fr}}
.card{background:var(--surface, #0b1222);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;}
.card h3{margin:0 0 8px}
.price{font-size:28px;font-weight:700}
.unit{font-size:14px;opacity:.8;margin-left:4px}
.kicker{letter-spacing:.08em;text-transform:uppercase;font-size:12px;opacity:.7;margin:0 0 6px}
.bullets{margin:8px 0 0 0;padding-left:18px}
.bullets li{margin:6px 0}
.pill{display:inline-block;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:4px 10px;font-size:12px;margin-right:6px}
.grid-2{display:grid;grid-template-columns:1.4fr .8fr;gap:16px}
@media (max-width: 960px){.grid-2{grid-template-columns:1fr}}
table.pricetable{width:100%;border-collapse:collapse;margin-top:8px}
table.pricetable th,table.pricetable td{border-bottom:1px dashed rgba(255,255,255,.12);padding:10px 8px;text-align:left}
.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.btn{display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.14)}
.btn-primary{background:#3b4aa0;color:#fff;border-color:#3b4aa0}
.note{font-size:12px;opacity:.8;margin-top:6px}
details{border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 14px}
details+details{margin-top:10px}
summary{cursor:pointer;font-weight:600}
.ex-wrap{max-width:1100px;margin:0 auto;padding:24px}
.hero-simple h1{margin:0 0 6px}
.hero-simple .lead{opacity:.9}
.ex-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:18px}
.ex-grid .card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 10px 28px rgba(0,0,0,.22)}
.ex-grid h2.kicker{letter-spacing:.08em;text-transform:uppercase;font-size:12px;color:#bfc7ff;margin:0 0 8px}
.ex-grid h3{margin:0 0 8px}
.price{font-size:28px;font-weight:800}
.unit{font-size:14px;opacity:.8;margin-left:6px}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.gallery img{width:100%;height:160px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.note{font-size:12px;opacity:.8;margin-top:8px}
.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.btn{display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid var(--line)}
.table-card{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 36px rgba(0,0,0,.28)}
.ex-table{width:100%;border-collapse:separate;border-spacing:0}
.ex-table thead th{text-align:left;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#bfc7ff;padding:14px 16px;border-bottom:1px solid var(--line)}
.ex-table tbody td{padding:14px 16px;border-top:1px dashed rgba(255,255,255,.06)}
@media (max-width: 720px){
.hero{padding:36px 0}
.wrap{padding:0 14px}
.two-col,.hero-grid{display:grid;grid-template-columns:1.1fr 1.1fr .9fr;height:auto}
table{width:100%;border-collapse:collapse}
:where(.wrap){max-width:1100px;margin-inline:auto;padding-inline:16px}

/* 1) Grid utility classes expected by markup on multiple pages */
.grid{display:grid;gap:16px}
.grid.two,.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three,.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.four,.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid.cards{grid-template-columns:repeat(3,minmax(0,1fr))}
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
}

@media (max-width: 1000px){
  .grid.two,.grid-2,
  .grid.three,.grid-3,
  .grid.four,.grid-4,
  .grid.cards,
  .two-col{grid-template-columns:1fr}
  .day-row{grid-template-columns:1fr}
}

:root{scroll-padding-top:72px}

.table-wrap{overflow:auto}

@supports not (backdrop-filter: blur(2px)){
  .modal{background:rgba(0,0,0,.6)}
}

.dropdown-menu{z-index:1000}

h1,h2,h3,h4,p{margin-block:0.5em}

.hero__aside{
  display: grid;
  gap: 14px;
  align-items: start;
}

.hero__aside .card{
  padding: 0;
  position: relative;
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
}

.hero__aside .card img{
  display: block;
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: inherit;
}

.hero__aside .cap{
  position: absolute;
  left: 12px;
  bottom: 12px;
  padding: 4px 10px;
  background: rgba(0,0,0,.55);
  color: #fff;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
}

@media (min-width: 900px){
  .hero__aside .card img{
    height: clamp(160px, 20vw, 220px);
  }
}


.hero__aside figure > img{
  height: 220px;
  width: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
  max-height: none;
}

.mosaic figure.tile{
  position: relative;
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--v-border, #1f2647);
  background: #0c1024;
}
.mosaic figure.tile > img{
  display: block;
  width: 100%;
  height: 100%; 
  object-fit: cover;
}
.mosaic figure.tile .cap{
  position: absolute;
  left: 10px;
  bottom: 10px;
  padding: 4px 10px;
  background: rgba(0,0,0,.55);
  color: #fff;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
}

.mosaic .row-2{ grid-row: span 2; }

.fill-stretch{
  width:100%;
  height:100%;
  object-fit:fill;
  display:block;
}

.section .card .item a {
  text-decoration: underline;
  text-underline-offset: 6px;
  padding-left: 40px;

}

/* 鼠标悬停时变色 */
.section .card .item a:hover {
  color: #ffffff;
}

.about-right{
  display:flex;
  flex-direction:column;
  gap:16px;
  padding-top: 50%;
}

.intro-video-card{
  background:var(--card);
  border:1px solid #1f2647;
  border-radius:16px;
  padding:12px;
}

.intro-video{
  width:100%;
  height: 300px;
  border-radius:12px;
  display:block;
}
/* 调整important dates字体 */
aside.card #importantDates {
  font-size: 22px;
}

aside.card #importantDates + table.dates td {
  font-size: 16px;   
  font-family: "Segoe UI", Arial, sans-serif;
}
#about aside.card {
  margin-top: 50px;
}
.hero-grid > aside.card {
  margin-top: 110px;
}

.hero-logo{display:flex;align-items:center;margin-top: 50px;}
.hero-logo img{width:100%;max-width:400px;filter:drop-shadow(0 20px 40px rgba(8,12,28,.6));}
.floorplan-card > .card {
  margin-left: auto;
  margin-right: auto;
  margin: 16px auto;
}



/* === Main Topics (Topics Section) === */
#topics .topics-wrap {
  position: relative;
  z-index: 1;
}

#topics .topics-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.5fr);
  gap: 24px;
  align-items: stretch;
  margin-top: 16px;
}

/* 右侧内容卡片 */
#topics .topics-content {
  border-radius: 22px;
  padding: 24px 26px;
  box-shadow:
    0 20px 45px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(142, 245, 198, 0.1);
  backdrop-filter: blur(16px);
}

/* 分组标题 */
#topics .topics-group + .topics-group {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

#topics .topics-group-title {
  font-size: 1.02rem;
  font-weight: 600;
  margin: 0 0 10px 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #e6f6f0;
}

#topics .topics-group-title::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 24px;
  background: radial-gradient(circle at 30% 30%, #8ef5c6, #2bbd88);
  box-shadow: 0 0 12px rgba(142, 245, 198, 0.9);
}

/* 子项排布：tag 样式 */
#topics .topics-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px 10px;
}

#topics .topics-item {
  position: relative;
  font-size: 0.9rem;
  line-height: 1.5;
  padding: 8px 12px 8px 22px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 0% 0%, rgba(142, 245, 198, 0.18), rgba(12, 25, 32, 0.98));
  border: 1px solid rgba(142, 245, 198, 0.16);
  color: #e4f4ee;
  white-space: normal;
}

#topics .topics-item::before {
  content: "";
  position: absolute;
  left: 9px;
  top: 15px;
  transform: translateY(0);
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #8ef5c6;
  box-shadow: 0 0 0 3px rgba(142, 245, 198, 0.26);
}

#topics .topics-item:hover {
  border-color: rgba(142, 245, 198, 0.5);
  box-shadow: 0 0 0 1px rgba(142, 245, 198, 0.4);
  transform: translateY(-1px);
  transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

/* 响应式：窄屏下上下布局 */
@media (max-width: 900px) {
  #topics .topics-grid {
    grid-template-columns: 1fr;
  }

  #topics .topics-content {
    padding: 18px 18px;
    border-radius: 18px;
  }
}
.intro-image-wrapper {
  margin-top: 16px;      /* 文字和图片之间留一点空隙 */
}

.intro-image {
  display: block;
  max-width: 600px;      /* 你想要的最大宽度，随便改 */
  width: 100%;           /* 在小屏幕自动缩小，不会超出布局 */
  height: auto;          /* 保持比例 */
  border-radius: 8px;    /* 可选：圆角 */
}
