:root {
  --navy: #0B0D26;
  --navy-2: #111642;
  --pink: #E6007A;
  --orange: #FF8A00;
  --teal: #00B39E;
  --light: #F6F8FC;
  --white: #FFFFFF;
  --text: #14172E;
  --muted: #667085;
  --border: #E7EAF2;
  --shadow: 0 24px 80px rgba(11, 13, 38, .10);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: var(--light); color: var(--text); line-height: 1.5; }
a { color: inherit; }
.container { width: min(1200px, 92%); margin: auto; }
.topbar { background: var(--navy); color: rgba(255,255,255,.82); font-size: 13px; padding: 9px 0; }
.topbar .container { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.topbar strong { color: var(--teal); }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.90); backdrop-filter: blur(18px); border-bottom: 1px solid rgba(231,234,242,.9); }
.nav { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.brand-mark { width: 52px; height: 52px; border-radius: 50%; border: 10px solid var(--navy); border-right-color: transparent; position: relative; flex: 0 0 auto; background: white; }
.brand-mark::before { content: ""; position: absolute; left: 18px; top: 11px; width: 35px; height: 7px; border-radius: 99px; background: var(--pink); box-shadow: 0 12px 0 var(--orange), 0 24px 0 var(--teal); }
.brand-text { line-height: 1; }
.brand-text strong { display: block; font-size: 17px; font-weight: 950; letter-spacing: 0; }
.brand-text span { display: block; color: var(--muted); font-size: 12px; font-weight: 700; margin-top: 5px; }
.navlinks { display: flex; align-items: center; gap: 8px; padding: 7px; border: 1px solid var(--border); border-radius: 999px; background: rgba(246,248,252,.82); }
.navlinks a { text-decoration: none; font-size: 14px; font-weight: 850; color: #30344D; padding: 9px 12px; border-radius: 999px; }
.navlinks a:hover { color: var(--navy); background: white; box-shadow: 0 8px 24px rgba(11,13,38,.07); }
.actions { display: flex; gap: 10px; align-items: center; }
.header-link { color: var(--navy); font-weight: 900; font-size: 14px; text-decoration: none; padding: 10px 4px; }
.header-link:hover { color: var(--teal); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; border-radius: 999px; padding: 13px 19px; border: 0; text-decoration: none; font-weight: 900; font-size: 14px; cursor: pointer; transition: .2s ease; white-space: nowrap; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--navy); color: white; box-shadow: 0 14px 34px rgba(11,13,38,.22); }
.btn-secondary { background: #EEF2F8; color: var(--navy); }
.btn-teal { background: var(--teal); color: white; box-shadow: 0 14px 34px rgba(0,179,158,.24); }
.btn-white { background: white; color: var(--navy); }
.btn-ghost { background: rgba(255,255,255,.12); color: white; border: 1px solid rgba(255,255,255,.24); }
.hero { color: white; background: radial-gradient(circle at 16% 20%, rgba(230,0,122,.30), transparent 28%), radial-gradient(circle at 72% 18%, rgba(0,179,158,.28), transparent 30%), radial-gradient(circle at 92% 78%, rgba(255,138,0,.18), transparent 28%), linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 58%, #091128 100%); padding: 72px 0 34px; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.06fr .94fr; gap: 48px; align-items: center; }
.label { display: inline-flex; align-items: center; gap: 10px; padding: 8px 13px; border-radius: 999px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); color: #D8FFF8; font-weight: 900; font-size: 13px; margin-bottom: 20px; }
.label::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--teal); }
h1 { font-size: clamp(46px, 4rem, 88px); line-height: .92; letter-spacing: 0; max-width: 820px; margin-bottom: 24px; }
.hero-lead { color: #D7DAEA; font-size: 20px; max-width: 650px; margin-bottom: 30px; }
.hero-actions, .trust-row { display: flex; gap: 13px; flex-wrap: wrap; }
.trust-row { margin-top: 34px; color: rgba(255,255,255,.72); font-weight: 800; font-size: 14px; gap: 18px; }
.dashboard { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); border-radius: 34px; padding: 18px; box-shadow: 0 40px 100px rgba(0,0,0,.26); backdrop-filter: blur(18px); }
.dash-top { background: white; color: var(--navy); border-radius: 26px; padding: 24px; margin-bottom: 14px; }
.dash-top small { color: var(--muted); font-weight: 800; }
.dash-top h2 { font-size: 38px; letter-spacing: 0; line-height: .98; margin: 8px 0 18px; }
.progress { height: 11px; border-radius: 999px; background: #EEF2F8; overflow: hidden; }
.progress span { display: block; height: 100%; width: 72%; background: linear-gradient(90deg, var(--pink), var(--orange), var(--teal)); border-radius: inherit; }
.dash-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.dash-card { background: rgba(255,255,255,.11); border: 1px solid rgba(255,255,255,.13); border-radius: 22px; padding: 19px; }
.dash-card strong { display: block; color: white; font-size: 28px; letter-spacing: 0; }
.dash-card span { color: #CAD0EA; font-size: 13px; font-weight: 700; }
.search-panel { margin-top: -36px; position: relative; z-index: 5; }
.search-box { background: white; border-radius: 28px; padding: 18px; box-shadow: var(--shadow); display: grid; grid-template-columns: 1.3fr 1fr 1fr auto; gap: 12px; border: 1px solid var(--border); }
.field, input, select, textarea { background: #F7F8FC; border: 1px solid #EEF1F7; border-radius: 18px; padding: 13px 15px; font: inherit; }
.field label, .form-label { display: block; color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px; }
.page-hero { color: white; padding: 72px 0 54px; background: radial-gradient(circle at 12% 0%, rgba(230,0,122,.22), transparent 28%), radial-gradient(circle at 88% 12%, rgba(0,179,158,.24), transparent 30%), linear-gradient(135deg, var(--navy), #131943 62%, #07101E); }
.page-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 36px; align-items: end; }
.page-hero h1 { color: white; margin: 12px 0 18px; }
.page-hero p { color: #D7DAEA; font-size: 20px; max-width: 760px; }
.page-hero aside { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); border-radius: 26px; padding: 24px; display: grid; gap: 8px; }
.page-hero aside strong { font-size: 24px; line-height: 1.05; }
.page-hero aside span { color: #CBD2EA; font-weight: 750; }
.listing-section { padding-top: 42px; }
.empty-state { background: white; border: 1px solid var(--border); border-radius: 28px; padding: 34px; text-align: center; box-shadow: var(--shadow); }
.empty-state h2 { color: var(--navy); margin-bottom: 8px; }
.article-index-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; }
.article-index-card { background: white; border: 1px solid var(--border); border-radius: 30px; overflow: hidden; text-decoration: none; box-shadow: 0 16px 42px rgba(11,13,38,.05); display: grid; grid-template-rows: 180px 1fr; }
.article-index-card.featured { grid-column: span 2; grid-row: span 2; grid-template-rows: 360px 1fr; }
.article-index-media { background: radial-gradient(circle at 78% 18%, rgba(0,179,158,.45), transparent 28%), linear-gradient(135deg, #25305F, var(--navy)); }
.article-index-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.article-index-body { padding: 24px; }
.article-index-body span, .product-body span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.article-index-body h2 { font-size: 24px; line-height: 1.08; margin: 10px 0; }
.article-index-card.featured h2 { font-size: 38px; }
.article-index-body p { color: var(--muted); font-weight: 720; margin-bottom: 16px; }
.article-index-body small { color: var(--muted); font-weight: 850; }
.event-index-list { display: grid; gap: 14px; }
.event-index-card { background: white; border: 1px solid var(--border); border-radius: 28px; padding: 18px; text-decoration: none; box-shadow: 0 14px 38px rgba(11,13,38,.045); display: grid; grid-template-columns: 84px minmax(0,1fr) 180px; gap: 18px; align-items: center; }
.event-index-card:hover { transform: translateY(-2px); box-shadow: 0 22px 54px rgba(11,13,38,.08); }
.event-index-main span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.event-index-main h2 { font-size: 25px; line-height: 1.08; margin: 6px 0; }
.event-index-main p { color: var(--muted); font-weight: 750; }
.event-index-side { justify-self: end; text-align: right; display: grid; gap: 4px; }
.event-index-side strong { color: var(--navy); }
.event-index-side small { color: var(--muted); font-weight: 850; }
.shop-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.product-card { background: white; border: 1px solid var(--border); border-radius: 28px; overflow: hidden; text-decoration: none; box-shadow: 0 16px 42px rgba(11,13,38,.05); }
.product-media { min-height: 230px; background: radial-gradient(circle at 80% 0%, rgba(255,138,0,.28), transparent 30%), linear-gradient(145deg, #172153, var(--navy)); }
.product-media img { width: 100%; height: 230px; object-fit: cover; display: block; }
.product-body { padding: 22px; display: grid; gap: 9px; }
.product-body h2 { font-size: 22px; line-height: 1.1; }
.product-body p { color: var(--muted); font-weight: 720; }
.product-body strong { margin-top: 6px; font-size: 20px; color: var(--navy); }
.forum-page { padding-top: 42px; }
.forum-layout-page { display: grid; grid-template-columns: 360px minmax(0,1fr); gap: 22px; align-items: start; }
.forum-categories-panel, .forum-topic-panel, .contact-info-card, .contact-form { background: white; border: 1px solid var(--border); border-radius: 30px; box-shadow: var(--shadow); }
.forum-categories-panel { padding: 24px; position: sticky; top: 104px; }
.forum-categories-panel h2, .forum-topic-panel h2, .contact-info-card h2 { color: var(--navy); font-size: 28px; line-height: 1; margin-bottom: 18px; }
.forum-category-list { display: grid; gap: 10px; }
.forum-category-list a { display: grid; gap: 5px; background: #F7F8FC; border: 1px solid var(--border); border-radius: 18px; padding: 15px; text-decoration: none; }
.forum-category-list strong { color: var(--navy); }
.forum-category-list span { color: var(--muted); font-size: 14px; font-weight: 720; }
.forum-topic-panel { padding: 0; overflow: hidden; }
.forum-topic-head { padding: 24px; background: linear-gradient(135deg, var(--navy), #172153); color: white; display: flex; justify-content: space-between; gap: 18px; align-items: center; }
.forum-topic-head h2 { color: white; margin-bottom: 4px; }
.forum-topic-head p { color: #CBD2EA; }
.forum-topic-list { display: grid; }
.forum-topic-list a { display: grid; grid-template-columns: minmax(0,1fr) 92px; gap: 18px; padding: 22px 24px; border-top: 1px solid var(--border); text-decoration: none; align-items: center; }
.forum-topic-list span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.forum-topic-list h3 { font-size: 22px; margin: 7px 0; line-height: 1.12; }
.forum-topic-list p { color: var(--muted); font-weight: 720; }
.forum-topic-list > a > strong { text-align: center; color: var(--navy); font-size: 26px; }
.forum-topic-list small { display: block; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.contact-page { padding-top: 42px; }
.contact-layout { display: grid; grid-template-columns: 390px minmax(0,1fr); gap: 22px; align-items: start; }
.contact-info-card { padding: 26px; }
.contact-info-list { display: grid; gap: 12px; }
.contact-info-list p { background: #F7F8FC; border: 1px solid var(--border); border-radius: 18px; padding: 15px; display: grid; gap: 4px; }
.contact-info-list strong { color: var(--navy); }
.contact-info-list span { color: var(--muted); font-weight: 720; }
.contact-form { padding: 24px; display: grid; gap: 16px; }
.contact-form label { display: grid; gap: 7px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.contact-form input, .contact-form select, .contact-form textarea { background: #F7F8FC; border: 1px solid var(--border); border-radius: 16px; padding: 13px 15px; text-transform: none; letter-spacing: 0; font-weight: 650; }
.contact-form textarea { min-height: 170px; resize: vertical; }
.success-message { background: #E8FBF7; color: #047A6C; border-radius: 16px; padding: 14px; font-weight: 850; }
.home-hero { color: white; padding: 86px 0 74px; background: radial-gradient(circle at 8% 10%, rgba(230,0,122,.28), transparent 26%), radial-gradient(circle at 85% 12%, rgba(0,179,158,.24), transparent 28%), linear-gradient(135deg, #0B0D26 0%, #141943 55%, #090A1C 100%); overflow: hidden; }
.home-hero-inner { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(340px, .72fr); gap: 42px; align-items: end; }
.home-hero-inner-simple { grid-template-columns: minmax(0, 900px); }
.home-copy h1 { font-size: clamp(44px, 4.6rem, 82px); line-height: .95; margin: 16px 0 22px; max-width: 850px; }
.eyebrow { color: #BDF7EF; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; font-size: 12px; }
.hero-featured-article a { display: block; overflow: hidden; color: white; text-decoration: none; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18); border-radius: 30px; backdrop-filter: blur(16px); box-shadow: 0 36px 90px rgba(0,0,0,.22); }
.hero-featured-media { min-height: 220px; position: relative; background: radial-gradient(circle at 80% 10%, rgba(0,179,158,.42), transparent 28%), linear-gradient(135deg, #25305F, #0B0D26); overflow: hidden; }
.hero-featured-media img { width: 100%; height: 100%; min-height: 220px; object-fit: cover; display: block; }
.hero-featured-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,13,38,.08), rgba(11,13,38,.52)); }
.hero-featured-media span { position: absolute; left: 22px; bottom: 18px; z-index: 1; background: white; color: var(--teal); border-radius: 999px; padding: 8px 12px; font-size: 12px; font-weight: 950; }
.hero-featured-body { padding: 26px; }
.hero-featured-body strong { color: #BDF7EF; text-transform: uppercase; letter-spacing: .08em; font-size: 11px; }
.hero-featured-body h2 { font-size: 31px; line-height: 1.04; margin: 12px 0 10px; }
.hero-featured-body p { color: #D7DAEA; margin-bottom: 18px; }
.hero-featured-body em { color: white; font-style: normal; font-weight: 950; text-decoration: none; }
.hero-featured-article a:hover .hero-featured-body em { color: #BDF7EF; }
.event-search-panel { margin-top: -42px; }
.event-search { background: white; border: 1px solid var(--border); border-radius: 28px; box-shadow: var(--shadow); padding: 16px; display: grid; grid-template-columns: 1.3fr 1fr 1fr .75fr auto; gap: 12px; align-items: stretch; }
.event-search label { display: grid; gap: 6px; background: #F7F8FC; border: 1px solid #EEF1F7; border-radius: 18px; padding: 11px 14px; min-width: 0; }
.event-search span { color: #667085; font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.event-search input, .event-search select { border: 0; background: transparent; border-radius: 0; padding: 0; min-height: 28px; color: var(--text); font-weight: 850; outline: none; width: 100%; }
.event-search select { appearance: none; -webkit-appearance: none; cursor: pointer; padding-right: 26px; }
.select-shell { position: relative; display: flex; align-items: center; min-width: 0; }
.select-shell::after { content: ""; position: absolute; right: 4px; width: 9px; height: 9px; border-right: 2px solid var(--muted); border-bottom: 2px solid var(--muted); transform: rotate(45deg); pointer-events: none; margin-top: -4px; }
.event-search label:focus-within { border-color: rgba(0,179,158,.38); background: white; box-shadow: 0 0 0 4px rgba(0,179,158,.09); }
.event-search button { border-radius: 22px; min-height: 72px; }
.inline-event-search { margin-bottom: 26px; box-shadow: 0 14px 42px rgba(11,13,38,.06); }
.home-stats-section { padding: 42px 0 20px; }
.home-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.home-stats div { background: white; border: 1px solid var(--border); border-radius: 24px; padding: 22px; box-shadow: 0 12px 34px rgba(11,13,38,.045); }
.home-stats strong { display: block; color: var(--navy); font-size: 28px; line-height: 1; margin-bottom: 8px; }
.home-stats span { color: var(--muted); font-weight: 750; font-size: 14px; }
.project-pillars { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.project-pillars article { background: white; border: 1px solid var(--border); border-radius: 24px; padding: 22px; box-shadow: 0 12px 34px rgba(11,13,38,.045); min-height: 190px; display: flex; flex-direction: column; justify-content: space-between; }
.project-pillars span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.project-pillars strong { display: block; color: var(--navy); font-size: 21px; line-height: 1.12; margin: 14px 0 10px; }
.project-pillars p { color: var(--muted); font-weight: 720; font-size: 14px; }
.agenda-home-section { background: linear-gradient(180deg, var(--light), #FFFFFF); }
.agenda-showcase { display: grid; grid-template-columns: .96fr 1.04fr; gap: 22px; align-items: stretch; }
.agenda-spotlight { min-height: 460px; color: white; display: flex; flex-direction: column; justify-content: flex-end; text-decoration: none; border-radius: 34px; padding: 32px; background: radial-gradient(circle at 85% 12%, rgba(255,138,0,.30), transparent 30%), radial-gradient(circle at 20% 0%, rgba(230,0,122,.25), transparent 26%), linear-gradient(145deg, var(--navy), #172153); box-shadow: var(--shadow); overflow: hidden; position: relative; }
.agenda-spotlight::before { content: ""; position: absolute; width: 240px; height: 240px; border: 38px solid rgba(255,255,255,.08); border-radius: 50%; top: -78px; right: -72px; }
.agenda-spotlight > * { position: relative; }
.agenda-spotlight h3 { font-size: clamp(34px, 3.2rem, 54px); line-height: 1; margin: 18px 0 12px; max-width: 680px; }
.agenda-spotlight p { color: #D7DAEA; max-width: 620px; }
.agenda-meta { margin-top: 26px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.agenda-meta strong { background: white; color: var(--navy); padding: 12px 15px; border-radius: 16px; font-size: 20px; }
.agenda-meta span { color: #D7DAEA; font-weight: 850; }
.agenda-list-home { display: grid; gap: 14px; }
.agenda-list-home a { display: grid; grid-template-columns: 76px minmax(0,1fr); gap: 16px; align-items: center; min-height: 108px; background: white; border: 1px solid var(--border); border-radius: 26px; padding: 18px; text-decoration: none; box-shadow: 0 14px 36px rgba(11,13,38,.045); }
.agenda-list-home a:hover { transform: translateY(-2px); box-shadow: 0 20px 52px rgba(11,13,38,.08); }
.agenda-list-home span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.agenda-list-home h3 { margin: 5px 0 4px; font-size: 21px; line-height: 1.12; }
.agenda-list-home p { color: var(--muted); font-weight: 750; }
.event-feature-grid { display: grid; grid-template-columns: 1.15fr 1fr 1fr; gap: 16px; }
.event-card { min-height: 190px; display: flex; flex-direction: column; justify-content: space-between; gap: 20px; background: white; border: 1px solid var(--border); border-radius: 28px; padding: 22px; text-decoration: none; box-shadow: 0 16px 42px rgba(11,13,38,.05); }
.event-card-large { grid-row: span 2; min-height: 396px; color: white; background: radial-gradient(circle at 85% 0%, rgba(255,138,0,.24), transparent 30%), linear-gradient(145deg, var(--navy), #182055); }
.event-card h3 { font-size: 24px; line-height: 1.08; margin: 12px 0 8px; }
.event-card-large h3 { font-size: 38px; }
.event-card p { color: var(--muted); font-weight: 750; }
.event-card-large p { color: #D7DAEA; }
.event-date { width: 76px; height: 76px; border-radius: 22px; display: grid; place-items: center; text-align: center; background: #F1F4FA; color: var(--navy); }
.event-date.compact { width: 68px; height: 68px; border-radius: 20px; }
.event-card-large .event-date { background: white; }
.event-date strong { font-size: 27px; line-height: 1; }
.event-date span { display: block; color: var(--pink); font-size: 12px; font-weight: 950; }
.section-cta { margin-top: 24px; }
.white-band { background: white; }
.newsroom-grid { display: grid; grid-template-columns: 1.15fr 1fr 1fr; gap: 18px; }
.news-card { display: grid; grid-template-rows: 150px 1fr; background: white; border: 1px solid var(--border); border-radius: 28px; overflow: hidden; text-decoration: none; box-shadow: 0 16px 42px rgba(11,13,38,.05); }
.news-card-main { grid-row: span 2; grid-template-rows: 290px 1fr; }
.news-visual { background: radial-gradient(circle at 78% 18%, rgba(0,179,158,.45), transparent 28%), linear-gradient(135deg, #25305F, var(--navy)); }
.news-card:nth-child(2) .news-visual { background: linear-gradient(135deg, var(--pink), #26305E); }
.news-card:nth-child(3) .news-visual { background: linear-gradient(135deg, var(--orange), #25305F); }
.news-card:nth-child(4) .news-visual { background: linear-gradient(135deg, var(--teal), #172153); }
.news-body { padding: 22px; }
.news-body span { color: var(--teal); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.news-body h3 { margin: 10px 0 10px; font-size: 24px; line-height: 1.08; }
.news-card-main .news-body h3 { font-size: 34px; }
.news-body p { color: var(--muted); font-weight: 700; }
.magazine-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 20px; }
.magazine-lead { min-height: 430px; border-radius: 32px; padding: 32px; color: white; text-decoration: none; display: flex; flex-direction: column; justify-content: end; background: radial-gradient(circle at 85% 10%, rgba(0,179,158,.40), transparent 28%), linear-gradient(140deg, #252F5D, #0B0D26); }
.magazine-lead h3 { font-size: 42px; line-height: 1.02; margin: 18px 0 12px; }
.magazine-lead p { color: #D7DAEA; }
.magazine-list { display: grid; gap: 14px; }
.magazine-list a { display: grid; gap: 8px; background: #F7F8FC; border: 1px solid var(--border); border-radius: 22px; padding: 22px; text-decoration: none; }
.magazine-list span { color: var(--teal); text-transform: uppercase; font-size: 12px; letter-spacing: .08em; font-weight: 950; }
.magazine-list strong { font-size: 20px; line-height: 1.15; }
.module-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.module-card { background: white; border: 1px solid var(--border); border-radius: 24px; padding: 24px; text-decoration: none; box-shadow: 0 16px 40px rgba(11,13,38,.045); }
.module-card h3 { margin: 16px 0 8px; font-size: 24px; }
.module-card p { color: var(--muted); }
.module-dot { width: 42px; height: 8px; border-radius: 99px; display: block; }
.community-band { color: white; background: linear-gradient(135deg, var(--navy), #141943); }
.community-layout { display: grid; grid-template-columns: .85fr 1.15fr; gap: 32px; align-items: center; }
.community-layout h2 { font-size: clamp(34px, 3.2rem, 56px); line-height: 1; margin: 18px 0; }
.community-layout p { color: #D7DAEA; margin-bottom: 22px; }
.community-topics { display: grid; gap: 12px; }
.community-topics a { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); border-radius: 20px; padding: 18px; display: grid; gap: 6px; text-decoration: none; }
.community-topics span { color: #CBD2EA; font-size: 14px; }
section { padding: 72px 0; }
.section-head { display: flex; justify-content: space-between; gap: 24px; align-items: end; margin-bottom: 30px; }
.section-head h2 { font-size: clamp(34px, 3.2rem, 56px); line-height: .96; letter-spacing: 0; }
.section-head p, .muted { color: var(--muted); }
.feature-grid, .card-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.feature, .card { background: white; border: 1px solid var(--border); border-radius: 28px; padding: 26px; box-shadow: 0 16px 46px rgba(11,13,38,.05); }
.feature-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 20px; color: white; font-size: 25px; margin-bottom: 23px; }
.pink { background: var(--pink); } .orange { background: var(--orange); } .teal { background: var(--teal); }
.content-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; }
.article-large { min-height: 470px; border-radius: 34px; padding: 32px; color: white; display: flex; flex-direction: column; justify-content: end; background: linear-gradient(180deg, rgba(11,13,38,.12), rgba(11,13,38,.92)), radial-gradient(circle at 70% 20%, rgba(0,179,158,.55), transparent 25%), linear-gradient(135deg, #25305F, #0B0D26); overflow: hidden; position: relative; text-decoration: none; }
.article-large h3 { font-size: 42px; line-height: 1; letter-spacing: 0; margin-bottom: 12px; position: relative; }
.article-large p { color: #D7DAEA; max-width: 560px; position: relative; }
.article-list, .event-list { display: grid; gap: 16px; }
.article-mini { background: white; border: 1px solid var(--border); border-radius: 26px; padding: 22px; display: grid; grid-template-columns: 72px 1fr; gap: 16px; align-items: center; text-decoration: none; }
.thumb { width: 72px; height: 72px; border-radius: 20px; background: linear-gradient(135deg, var(--pink), var(--orange), var(--teal)); object-fit: cover; }
.article-mini small { color: var(--teal); font-weight: 900; text-transform: uppercase; letter-spacing: .07em; }
.agenda-wrap { display: grid; grid-template-columns: .82fr 1.18fr; gap: 24px; }
.calendar-card { background: var(--navy); color: white; border-radius: 32px; padding: 28px; min-height: 420px; }
.month-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 8px; margin-top: 22px; }
.day { aspect-ratio: 1; display: grid; place-items: center; border-radius: 13px; background: rgba(255,255,255,.08); color: rgba(255,255,255,.75); font-size: 13px; font-weight: 800; }
.day.active { background: var(--teal); color: white; }
.event { background: white; border: 1px solid var(--border); border-radius: 26px; padding: 20px; display: grid; grid-template-columns: 84px 1fr auto; gap: 18px; align-items: center; text-decoration: none; }
.date { height: 84px; border-radius: 22px; background: #F1F4FA; color: var(--navy); display: grid; place-items: center; text-align: center; font-weight: 950; font-size: 25px; }
.date span { display: block; color: var(--pink); font-size: 12px; letter-spacing: .08em; }
.tag { border-radius: 999px; padding: 8px 12px; background: #EEF9F7; color: var(--teal); font-size: 12px; font-weight: 950; }
.forum { background: white; border: 1px solid var(--border); border-radius: 34px; overflow: hidden; box-shadow: var(--shadow); }
.forum-top { background: var(--navy); color: white; padding: 26px; display: flex; justify-content: space-between; gap: 18px; align-items: center; }
.topic { display: grid; grid-template-columns: 1fr 130px 110px; gap: 16px; padding: 22px 26px; border-top: 1px solid var(--border); align-items: center; text-decoration: none; }
.partners-home { background: #FFFFFF; }
.partner-logo-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.partner-logo-card { min-height: 132px; background: #FFFFFF; border: 1px solid var(--border); border-radius: 24px; display: grid; place-items: center; padding: 24px; text-align: center; text-decoration: none; box-shadow: 0 12px 34px rgba(11,13,38,.045); transition: .2s ease; }
.partner-logo-card:hover { transform: translateY(-2px); box-shadow: 0 22px 54px rgba(11,13,38,.09); border-color: rgba(0,179,158,.28); }
.partner-logo-card img { max-width: 180px; max-height: 72px; object-fit: contain; }
.partner-logo-card span { font-size: 18px; font-weight: 950; color: var(--navy); position: relative; padding-top: 20px; }
.partner-logo-card span::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 92px; height: 7px; border-radius: 99px; background: linear-gradient(90deg, var(--pink), var(--orange), var(--teal)); }
.partner-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.partner { background: white; border: 1px solid var(--border); border-radius: 28px; padding: 24px; min-height: 180px; display: flex; flex-direction: column; justify-content: space-between; box-shadow: 0 14px 38px rgba(11,13,38,.045); text-decoration: none; }
.partner-mark { width: 74%; height: 38px; border-radius: 13px; background: linear-gradient(90deg, var(--pink), var(--orange), var(--teal)); opacity: .95; object-fit: contain; }
.newsletter { border-radius: 38px; padding: 46px; color: white; background: radial-gradient(circle at 20% 0%, rgba(230,0,122,.34), transparent 30%), radial-gradient(circle at 80% 0%, rgba(0,179,158,.28), transparent 33%), var(--navy); display: grid; grid-template-columns: 1fr .9fr; gap: 24px; align-items: center; }
.newsletter h2 { font-size: clamp(32px, 3rem, 54px); line-height: .98; letter-spacing: 0; }
.newsletter p { color: #D7DAEA; margin-top: 12px; }
.signup, .form-card { background: white; border-radius: 24px; padding: 16px; display: flex; gap: 10px; }
.signup input { flex: 1; }
.form-card { display: grid; gap: 14px; border: 1px solid var(--border); box-shadow: var(--shadow); }
.detail { background: white; border: 1px solid var(--border); border-radius: 34px; padding: clamp(24px, 3.5rem, 56px); box-shadow: var(--shadow); }
.detail h1 { color: var(--navy); font-size: clamp(38px, 3.7rem, 72px); }
.prose { color: #30344D; font-size: 18px; }
footer { padding: 46px 0; color: var(--muted); }
.footer-row { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; align-items: center; }
.footer-links { display: flex; gap: 18px; flex-wrap: wrap; font-weight: 800; }
.footer-links a { text-decoration: none; }
@media (max-width: 1120px) { .navlinks { display: none; } }
@media (max-width: 1020px) { .actions .header-link { display: none; } .hero-grid, .search-box, .feature-grid, .content-grid, .agenda-wrap, .newsletter, .card-grid, .home-hero-inner, .event-search, .magazine-layout, .module-grid, .community-layout, .agenda-showcase, .page-hero-grid, .forum-layout-page, .contact-layout { grid-template-columns: 1fr; } .home-stats, .project-pillars { grid-template-columns: repeat(2, 1fr); } .event-feature-grid, .newsroom-grid, .article-index-grid, .shop-grid { grid-template-columns: 1fr 1fr; } .article-index-card.featured { grid-column: span 2; } .partner-grid, .partner-logo-grid { grid-template-columns: repeat(2,1fr); } .event, .event-index-card { grid-template-columns: 74px 1fr; } .event-index-side { grid-column: 2; justify-self: start; text-align: left; } .event .tag { grid-column: 2; width: fit-content; } .topic { grid-template-columns: 1fr; } .event-search button { min-height: 54px; } .forum-categories-panel { position: static; } }
@media (max-width: 560px) { .topbar { display: none; } .brand-text span { display: none; } .dash-grid, .partner-grid, .partner-logo-grid, .home-stats, .project-pillars, .event-feature-grid, .newsroom-grid, .article-index-grid, .shop-grid, .form-row { grid-template-columns: 1fr; } .article-index-card.featured { grid-column: auto; grid-row: auto; grid-template-rows: 220px 1fr; } .newsletter, .calendar-card { padding: 28px; } .signup { flex-direction: column; } section { padding: 54px 0; } .page-hero { padding: 52px 0 42px; } .page-hero h1 { font-size: 42px; } .home-hero { padding-top: 56px; } .home-copy h1 { font-size: 44px; } .magazine-lead h3, .event-card-large h3, .news-card-main .news-body h3, .agenda-spotlight h3, .article-index-card.featured h2 { font-size: 32px; } .news-card-main { grid-row: auto; } .agenda-spotlight { min-height: 380px; padding: 26px; } .forum-topic-head { align-items: stretch; flex-direction: column; } .forum-topic-list a, .event-index-card { grid-template-columns: 1fr; } .event-index-side { grid-column: auto; } }
