:root {
  --navy: #071b2e;
  --navy-2: #0b2740;
  --navy-3: #123650;
  --ink: #10283d;
  --muted: #627384;
  --light: #f3f6f7;
  --line: #dce4e7;
  --white: #fff;
  --coral: #f05c45;
  --coral-dark: #d94732;
  --mint: #64d7b2;
  --mint-dark: #31ad88;
  --yellow: #ffd978;
  --radius: 22px;
  --shadow: 0 22px 60px rgba(7, 27, 46, 0.12);
  --font-display: "Manrope", sans-serif;
  --font-body: "DM Sans", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
body { margin: 0; color: var(--ink); background: var(--white); font-family: var(--font-body); line-height: 1.6; -webkit-font-smoothing: antialiased; }
body, button { font-family: var(--font-body); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.section { padding: 112px 0; }
.section-dark { color: var(--white); background: var(--navy); }
.section-light { background: var(--light); }
.section-white { background: var(--white); }
.skip-link { position: fixed; z-index: 1000; left: 16px; top: -60px; padding: 10px 16px; color: var(--white); background: var(--coral); border-radius: 8px; transition: top .2s; }
.skip-link:focus { top: 16px; }

.site-header { position: absolute; z-index: 20; width: 100%; top: 0; border-bottom: 1px solid rgba(255,255,255,.12); }
.header-inner { min-height: 82px; display: flex; align-items: center; justify-content: space-between; }
.brand { color: var(--white); display: inline-flex; align-items: center; }
.brand-logo { width: clamp(205px, 21vw, 300px); height: auto; aspect-ratio: 1588 / 464; object-fit: contain; }

.button { min-height: 54px; padding: 0 25px; border: 0; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; gap: 14px; color: var(--white); font-weight: 700; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-coral { background: var(--coral); box-shadow: 0 10px 25px rgba(240,92,69,.22); }
.button-coral:hover { background: var(--coral-dark); box-shadow: 0 14px 32px rgba(240,92,69,.35); }
.button-small { min-height: 44px; padding-inline: 21px; font-size: 14px; }
.button-white { color: var(--navy); background: var(--white); box-shadow: 0 10px 30px rgba(0,0,0,.12); }
.button-white:hover { background: #eef9f5; }
.button-full { width: 100%; }

.hero { min-height: 830px; padding: 155px 0 90px; overflow: hidden; position: relative; }
.hero::before { content: ""; position: absolute; width: 620px; height: 620px; border-radius: 50%; right: -140px; top: 40px; background: radial-gradient(circle, rgba(45,173,136,.17), transparent 68%); }
.hero-grid-bg { position: absolute; inset: 0; opacity: .08; background-image: linear-gradient(rgba(255,255,255,.2) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.2) 1px, transparent 1px); background-size: 64px 64px; mask-image: linear-gradient(to right, transparent, #000); }
.hero-layout { position: relative; z-index: 1; display: grid; grid-template-columns: 1.12fr .88fr; align-items: center; gap: 72px; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 8px 13px; border: 1px solid rgba(100,215,178,.34); border-radius: 100px; color: #bdf0df; background: rgba(100,215,178,.09); font-size: 12px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 0 5px rgba(100,215,178,.12); }
h1, h2, h3 { margin-top: 0; font-family: var(--font-display); }
.hero h1 { max-width: 760px; margin: 23px 0 22px; font-size: clamp(42px, 4.3vw, 67px); line-height: 1.05; letter-spacing: -.05em; }
.hero h1 span { color: var(--mint); }
.hero-lead { max-width: 720px; color: #c5d0d9; font-size: 18px; line-height: 1.65; }
.hero blockquote { max-width: 700px; margin: 26px 0; padding: 17px 20px; border-left: 3px solid var(--coral); color: #edf4f6; background: rgba(255,255,255,.055); font-size: 15px; font-weight: 600; font-style: italic; }
.event-chips { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 26px; }
.event-chip { display: flex; align-items: center; gap: 8px; padding: 9px 13px; border: 1px solid rgba(255,255,255,.14); border-radius: 6px; color: #e4edf1; background: rgba(255,255,255,.045); font-size: 13px; }
.event-chip .icon { color: var(--mint); font-size: 16px; }
.hero-actions { display: flex; align-items: center; gap: 25px; margin-top: 34px; }
.text-link { padding: 11px 0 6px; border-bottom: 1px solid rgba(255,255,255,.35); color: #e7eef1; font-size: 14px; font-weight: 700; transition: color .2s, border-color .2s; }
.text-link:hover { color: var(--mint); border-color: var(--mint); }
.trust-line { display: flex; align-items: center; gap: 8px; margin: 18px 0 0; color: #91a4b3; font-size: 12px; }
.trust-line span { color: var(--mint); }

.hero-visual { position: relative; min-height: 590px; }
.visual-glow { position: absolute; inset: 80px 0 70px; border-radius: 50%; filter: blur(18px); background: radial-gradient(circle, rgba(78,213,175,.27), rgba(12,55,78,.08) 55%, transparent 70%); }
.visual-core { position: absolute; inset: 105px 15px 85px; overflow: hidden; border: 1px solid rgba(133,228,201,.22); border-radius: 50% 50% 20px 20px; background: linear-gradient(180deg, rgba(17,63,84,.8), rgba(6,27,46,.85)); box-shadow: inset 0 0 50px rgba(100,215,178,.08), 0 40px 80px rgba(0,0,0,.28); }
.visual-core::before { content: ""; position: absolute; inset: 0; opacity: .25; background-image: linear-gradient(rgba(100,215,178,.18) 1px, transparent 1px), linear-gradient(90deg, rgba(100,215,178,.18) 1px, transparent 1px); background-size: 35px 35px; }
.route-lines i { position: absolute; height: 1px; background: linear-gradient(90deg, transparent, var(--mint), transparent); transform-origin: left; opacity: .5; }
.route-lines i:nth-child(1) { width: 230px; top: 50%; left: 3%; transform: rotate(12deg); }
.route-lines i:nth-child(2) { width: 280px; top: 38%; right: -10%; transform: rotate(-22deg); }
.route-lines i:nth-child(3) { width: 200px; top: 67%; left: 30%; transform: rotate(33deg); }
.route-lines i:nth-child(4) { width: 190px; top: 22%; left: 15%; transform: rotate(-8deg); }
.ai-orbit { position: absolute; width: 215px; height: 215px; left: 50%; top: 42%; transform: translate(-50%,-50%); }
.orbit { position: absolute; inset: 0; border: 1px solid rgba(100,215,178,.35); border-radius: 50%; }
.orbit-1 { animation: spin 12s linear infinite; }
.orbit-1::before, .orbit-2::before { content: ""; position: absolute; width: 7px; height: 7px; border-radius: 50%; top: 11px; left: 55px; background: var(--mint); box-shadow: 0 0 15px var(--mint); }
.orbit-2 { inset: 22px; border-style: dashed; animation: spin 18s linear infinite reverse; }
.orbit-2::before { top: auto; bottom: 2px; left: 44px; background: var(--coral); box-shadow: 0 0 15px var(--coral); }
.ai-node { position: absolute; inset: 48px; display: flex; flex-direction: column; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.22); border-radius: 50%; color: var(--white); background: radial-gradient(circle at 35% 25%, #327a78, #102d48 68%); box-shadow: 0 0 40px rgba(100,215,178,.25); font: 800 34px/1 var(--font-display); letter-spacing: -.05em; }
.ai-node span { margin-top: 3px; color: var(--mint); font-size: 13px; letter-spacing: .16em; }
.satellite { position: absolute; width: 32px; height: 32px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.22); border-radius: 50%; color: var(--mint); background: #153c54; font-size: 13px; }
.s1 { top: 15px; right: 12px; }.s2 { bottom: 20px; left: 3px; }.s3 { bottom: 2px; right: 45px; }
.warehouse { position: absolute; z-index: 2; width: 210px; height: 78px; left: 50%; bottom: 4px; transform: translateX(-50%); border: 1px solid rgba(255,255,255,.22); border-bottom: 0; background: rgba(8,30,48,.95); }
.warehouse .roof { position: absolute; width: 166px; height: 55px; top: -30px; left: 20px; border-top: 2px solid rgba(100,215,178,.55); transform: skewY(-11deg); background: linear-gradient(160deg, rgba(56,118,125,.55), rgba(10,36,55,.9)); }
.warehouse .bay { position: absolute; width: 41px; height: 48px; bottom: 0; border: 1px solid rgba(255,255,255,.2); background: repeating-linear-gradient(0deg, rgba(255,255,255,.1) 0 1px, transparent 1px 9px); }
.warehouse .b1 { left: 28px; }.warehouse .b2 { left: 84px; }.warehouse .b3 { right: 28px; }
.data-card { position: absolute; z-index: 4; width: 265px; padding: 17px; border: 1px solid rgba(255,255,255,.16); border-radius: 12px; background: rgba(13,46,67,.9); backdrop-filter: blur(12px); box-shadow: 0 18px 45px rgba(0,0,0,.25); }
.card-top { top: 22px; right: -22px; }
.card-bottom { bottom: 10px; left: -30px; }
.data-label { color: #8ca9b8; font-size: 9px; font-weight: 700; letter-spacing: .15em; }
.compliance-score { display: flex; align-items: center; gap: 14px; margin-top: 12px; }
.score-ring { width: 59px; height: 59px; display: flex; align-items: baseline; justify-content: center; padding-top: 17px; border-radius: 50%; background: radial-gradient(circle closest-side, #12334b 80%, transparent 81%), conic-gradient(var(--mint) 82%, rgba(255,255,255,.1) 0); }
.score-ring strong { font: 700 18px/1 var(--font-display); }.score-ring small { font-size: 8px; }
.compliance-score > div:last-child { display: flex; flex-direction: column; font-size: 12px; }.compliance-score span { margin-top: 3px; color: #8ea3b0; font-size: 10px; }
.card-bottom ul { list-style: none; padding: 0; margin: 10px 0 0; }
.card-bottom li { display: flex; align-items: center; justify-content: space-between; padding: 7px 0; border-top: 1px solid rgba(255,255,255,.08); color: #dce7eb; font-size: 10px; }
.card-bottom b { color: var(--mint); }.card-bottom em { color: var(--yellow); font-size: 9px; font-style: normal; }
.floating-label { position: absolute; z-index: 5; padding: 7px 10px; border: 1px solid rgba(255,255,255,.14); border-radius: 4px; color: #c5d6dd; background: rgba(6,27,46,.8); font-size: 8px; font-weight: 700; letter-spacing: .1em; }
.floating-label span { color: var(--mint); }.label-a { left: 0; top: 155px; }.label-b { right: -25px; bottom: 160px; }
@keyframes spin { to { transform: rotate(360deg); } }

.event-strip { border-bottom: 1px solid #e1e8ea; background: var(--white); }
.strip-inner { min-height: 78px; display: flex; justify-content: space-between; align-items: center; gap: 30px; }
.strip-inner p { display: flex; align-items: center; gap: 18px; margin: 0; color: var(--muted); font-size: 13px; }
.strip-inner p:first-child strong { padding-right: 18px; border-right: 1px solid var(--line); color: var(--coral); font: 800 19px/1 var(--font-display); }
.strip-inner p:last-child span { font-size: 10px; text-transform: uppercase; letter-spacing: .1em; }
.strip-inner p:last-child strong { color: var(--navy); font-size: 12px; letter-spacing: .06em; }

.section-heading { max-width: 790px; margin-bottom: 55px; }
.section-heading.centered { margin-inline: auto; text-align: center; }
.section-kicker { display: block; margin-bottom: 15px; color: var(--coral); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.section-kicker.light { color: var(--mint); }
.section-heading h2, .learning-intro h2, .audience-copy h2, .speaker-copy h2, .guide-copy h2, .registration-copy h2, .final-inner h2 { margin-bottom: 22px; color: var(--navy); font-size: clamp(34px, 4vw, 51px); line-height: 1.12; letter-spacing: -.045em; }
.section-heading h2 span { color: var(--mint-dark); }
.section-heading > p, .learning-intro > p, .audience-copy > p { margin: 0; color: var(--muted); font-size: 17px; line-height: 1.7; }
.problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.problem-card { position: relative; min-height: 315px; padding: 32px; overflow: hidden; border: 1px solid #e1e8ea; border-radius: var(--radius); background: var(--white); box-shadow: 0 10px 30px rgba(7,27,46,.04); transition: transform .25s, box-shadow .25s, border-color .25s; }
.problem-card:hover { transform: translateY(-7px); border-color: rgba(49,173,136,.4); box-shadow: var(--shadow); }
.card-number { position: absolute; right: 25px; top: 20px; color: #e4eaed; font: 800 44px/1 var(--font-display); }
.line-icon { width: 52px; height: 52px; display: grid; place-items: center; margin-bottom: 33px; border-radius: 12px; font-size: 27px; font-weight: 700; }
.inventory-icon { color: #247e71; background: #e2f5ee; }.risk-icon { color: #d24d38; background: #fee9e5; }.evidence-icon { color: #3e70a0; background: #e5f0fa; }
.problem-card h3 { margin-bottom: 13px; font-size: 21px; letter-spacing: -.025em; }
.problem-card p { margin: 0; color: var(--muted); font-size: 14px; }
.card-tag { position: absolute; bottom: 25px; left: 32px; padding-top: 12px; border-top: 1px solid var(--line); color: #92a0aa; font-size: 9px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }

.learning-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 90px; align-items: start; }
.learning-intro { position: sticky; top: 120px; }
.deadline-card { margin-top: 45px; padding: 25px; border-radius: 14px; color: var(--white); background: var(--navy); box-shadow: var(--shadow); }
.deadline-card span { color: var(--mint); font-size: 10px; font-weight: 800; letter-spacing: .14em; }
.deadline-card strong { display: block; margin: 6px 0; font: 700 28px/1.2 var(--font-display); }
.deadline-card p { margin: 0; color: #9eafba; font-size: 13px; }
.benefits-list { border-top: 1px solid var(--line); }
.benefit { display: grid; grid-template-columns: 65px 1fr; gap: 20px; padding: 27px 12px; border-bottom: 1px solid var(--line); transition: padding-left .2s, background .2s; }
.benefit:hover { padding-left: 22px; background: #f8faf9; }
.benefit > span { color: var(--mint-dark); font: 800 13px/1.5 var(--font-display); }
.benefit h3 { margin-bottom: 7px; color: var(--navy); font-size: 19px; }
.benefit p { margin: 0; color: var(--muted); font-size: 14px; }

.agenda-section { position: relative; overflow: hidden; color: var(--white); background: var(--navy); }
.agenda-section::before { content: ""; position: absolute; width: 700px; height: 700px; right: -350px; top: 0; border: 1px solid rgba(100,215,178,.1); border-radius: 50%; box-shadow: 0 0 0 80px rgba(100,215,178,.025), 0 0 0 160px rgba(100,215,178,.018); }
.agenda-heading { position: relative; max-width: none; display: grid; grid-template-columns: 1fr 420px; gap: 100px; align-items: end; }
.agenda-heading h2 { margin: 0; color: var(--white); }
.agenda-heading p { color: #9cb0bd; font-size: 16px; }
.agenda-timeline { position: relative; }
.agenda-timeline::before { content: ""; position: absolute; left: 49px; top: 40px; bottom: 40px; width: 1px; background: linear-gradient(var(--mint), rgba(100,215,178,.08)); }
.agenda-item { position: relative; display: grid; grid-template-columns: 100px 1fr 35px; gap: 28px; align-items: center; min-height: 125px; padding: 21px 25px 21px 0; border-bottom: 1px solid rgba(255,255,255,.12); transition: background .2s, padding-left .2s; }
.agenda-item:first-child { border-top: 1px solid rgba(255,255,255,.12); }
.agenda-item:hover { padding-left: 15px; background: rgba(255,255,255,.035); }
.agenda-time { z-index: 1; display: flex; flex-direction: column; align-items: center; }
.agenda-time strong { width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid var(--mint); border-radius: 50%; color: var(--mint); background: var(--navy); font: 700 13px/1 var(--font-display); }
.agenda-time span { margin-top: 7px; color: #79909f; font-size: 9px; text-transform: uppercase; }
.agenda-copy h3 { margin-bottom: 8px; color: #f5f8f9; font-size: 19px; }
.agenda-copy p { max-width: 790px; margin: 0; color: #8fa4b1; font-size: 13px; }
.agenda-arrow { color: var(--mint); font-size: 20px; }

.audience-layout { display: grid; grid-template-columns: .7fr 1.3fr; gap: 80px; align-items: center; }
.audience-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 13px; }
.profile-card { display: flex; align-items: center; gap: 17px; min-height: 72px; padding: 16px 21px; border: 1px solid #dce4e6; border-radius: 10px; background: var(--white); font-weight: 700; font-size: 14px; transition: transform .2s, border-color .2s; }
.profile-card:hover { transform: translateX(5px); border-color: var(--mint-dark); }
.profile-card span { color: var(--mint-dark); font-size: 10px; font-weight: 800; }

.speaker-section { background: var(--white); }
.speaker-card { display: grid; grid-template-columns: minmax(280px, .78fr) 1.22fr; align-items: center; gap: 34px; overflow: hidden; padding: 28px; border-radius: 28px; background: var(--light); box-shadow: var(--shadow); }
.speaker-portrait { width: 100%; aspect-ratio: 1; position: relative; display: grid; place-items: center; overflow: hidden; border-radius: 24px; background: linear-gradient(145deg, #113a51, #071b2e); }
.speaker-portrait::before { content: ""; position: absolute; inset: 0; opacity: .17; background-image: linear-gradient(rgba(255,255,255,.2) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.2) 1px, transparent 1px); background-size: 35px 35px; transform: perspective(500px) rotateX(55deg) scale(1.5); }
.portrait-halo { position: absolute; width: 305px; height: 305px; border: 1px solid rgba(100,215,178,.32); border-radius: 28px; box-shadow: 0 0 0 26px rgba(100,215,178,.035), 0 0 0 52px rgba(100,215,178,.02); transform: rotate(-4deg); }
.speaker-photo-frame { position: relative; z-index: 1; width: min(80%, 320px); aspect-ratio: 1; overflow: hidden; border: 8px solid rgba(7,27,46,.66); border-radius: 22px; background: #f5f5f5; box-shadow: 0 0 0 1px rgba(100,215,178,.32), 0 22px 52px rgba(0,0,0,.34); }
.speaker-photo { width: 100%; height: 100%; object-fit: cover; object-position: center center; transform: scale(1.38) translateY(-13%); transform-origin: center top; }
.speaker-portrait::after { content: ""; position: absolute; z-index: 0; width: 245px; height: 58px; left: 50%; bottom: 58px; transform: translateX(-50%); border-radius: 50%; background: rgba(0,0,0,.24); filter: blur(16px); }
.expert-badge { position: absolute; z-index: 2; right: 34px; bottom: 32px; width: 74px; height: 74px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); background: var(--mint); text-align: center; font-size: 8px; font-weight: 800; line-height: 1.3; letter-spacing: .08em; transform: rotate(8deg); }
.speaker-copy { padding: 28px 34px 28px 0; }
.speaker-copy h2 { font-size: clamp(30px, 3.2vw, 43px); }
.speaker-name { margin: 32px 0 22px; padding-left: 18px; border-left: 3px solid var(--coral); }
.speaker-name h3 { margin: 0; font-size: 22px; }.speaker-name p { margin: 3px 0 0; color: var(--muted); font-size: 13px; }
.speaker-copy > p { color: var(--muted); font-size: 15px; }
.linkedin-link { display: inline-flex; align-items: center; gap: 9px; margin-top: 17px; color: var(--navy); font-size: 13px; font-weight: 800; }
.linkedin-link span { width: 27px; height: 27px; display: grid; place-items: center; border-radius: 4px; color: var(--white); background: #0a66c2; font-size: 12px; }

.guide-section { position: relative; overflow: hidden; color: var(--white); background: #0d3148; }
.guide-section::before { content: ""; position: absolute; inset: 0; opacity: .11; background-image: radial-gradient(var(--mint) 1px, transparent 1px); background-size: 25px 25px; mask-image: linear-gradient(to right, transparent, #000); }
.guide-layout { position: relative; display: grid; grid-template-columns: 1fr .9fr; gap: 80px; align-items: center; }
.guide-copy h2 { color: var(--white); }
.guide-copy > p { max-width: 600px; color: #b5c5ce; font-size: 16px; }
.check-list { list-style: none; padding: 0; margin: 27px 0 32px; display: grid; gap: 10px; }
.check-list li { display: flex; align-items: center; gap: 11px; color: #d8e4e8; font-size: 13px; }
.check-list li::before { content: "✓"; width: 21px; height: 21px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); background: var(--mint); font-size: 11px; font-weight: 800; }
.guide-visual { position: relative; min-height: 475px; display: grid; place-items: center; perspective: 1000px; }
.guide-shadow { position: absolute; width: 340px; height: 80px; bottom: 20px; border-radius: 50%; filter: blur(20px); background: rgba(0,0,0,.4); }
.guide-book { position: relative; width: 300px; height: 395px; transform: rotateY(-13deg) rotateX(4deg) rotateZ(2deg); transform-style: preserve-3d; filter: drop-shadow(30px 30px 25px rgba(0,0,0,.32)); }
.guide-spine { position: absolute; width: 29px; height: 100%; left: -24px; transform: rotateY(-28deg); transform-origin: right; background: #071b2e; }
.guide-cover { position: absolute; inset: 0; overflow: hidden; padding: 32px; border: 1px solid rgba(255,255,255,.15); color: var(--white); background: linear-gradient(150deg, #0d3852, #071b2e 68%); }
.mini-brand { font: 800 13px/1 var(--font-display); }.mini-brand small { margin-left: 3px; font-size: 5px; letter-spacing: .13em; }
.guide-cover > span { display: block; margin-top: 72px; color: var(--mint); font-size: 9px; font-weight: 800; letter-spacing: .2em; }
.guide-cover h3 { margin: 12px 0 5px; font-size: 40px; line-height: 1; letter-spacing: -.05em; }.guide-cover h3 b { color: var(--mint); }
.guide-cover p { margin: 0; color: #bdccd3; font-size: 13px; }
.cover-grid { position: absolute; width: 250px; height: 200px; right: -100px; bottom: -65px; border: 1px solid rgba(100,215,178,.2); border-radius: 50%; box-shadow: 0 0 0 30px rgba(100,215,178,.04), 0 0 0 60px rgba(100,215,178,.025); }
.cover-check { position: absolute; right: 35px; bottom: 30px; width: 47px; height: 47px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); background: var(--mint); font-size: 25px; font-weight: 800; }
.download-label { position: absolute; right: 10px; bottom: 20px; padding: 10px 13px; color: var(--navy); background: var(--yellow); box-shadow: 0 10px 25px rgba(0,0,0,.2); font-size: 8px; font-weight: 800; letter-spacing: .12em; transform: rotate(-3deg); }

.cta-band { position: relative; overflow: hidden; padding: 77px 0; color: var(--white); background: var(--coral); }
.cta-pattern { position: absolute; inset: 0; opacity: .12; background: repeating-linear-gradient(135deg, transparent 0 35px, #fff 35px 36px); }
.cta-band-inner { position: relative; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 80px; }
.cta-band h2 { max-width: 780px; margin: 0 0 13px; font-size: clamp(31px, 3.3vw, 46px); line-height: 1.14; letter-spacing: -.04em; }
.cta-band p { max-width: 780px; margin: 0; color: #ffe4df; }
.cta-band .section-kicker { color: #fff2df; }

.registration-section { background: var(--light); }
.registration-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 90px; align-items: start; }
.registration-copy { position: sticky; top: 120px; padding-top: 25px; }
.registration-copy > p { color: var(--muted); font-size: 17px; }
.registration-details { margin: 40px 0 30px; border-top: 1px solid var(--line); }
.registration-details > div { display: grid; grid-template-columns: 60px 1fr; align-items: center; padding: 18px 0; border-bottom: 1px solid var(--line); }
.registration-details > div > span { color: var(--coral); font: 800 23px/1 var(--font-display); }
.registration-details p { display: flex; flex-direction: column; margin: 0; color: var(--muted); font-size: 12px; }.registration-details strong { color: var(--navy); font-size: 15px; }
.privacy-note { display: flex; gap: 13px; padding: 17px; border-radius: 10px; background: #e6efef; }
.privacy-note > span { color: var(--mint-dark); font-size: 20px; }.privacy-note p { margin: 0; color: var(--muted); font-size: 11px; }.privacy-note strong { display: block; color: var(--ink); }
.registration-card { padding: 45px; border-radius: 22px; background: var(--white); box-shadow: var(--shadow); }
.registration-card-kicker { color: var(--coral); font-size: 9px; font-weight: 800; letter-spacing: .15em; }
.registration-card h3 { margin: 9px 0 15px; color: var(--navy); font-size: 30px; line-height: 1.15; }
.registration-card > p { margin: 0 0 28px; color: var(--muted); font-size: 15px; }
.registration-card-note { margin: 15px 0 0; color: #81919b; text-align: center; font-size: 11px; }

.final-section { padding: 105px 0; color: var(--white); background: var(--navy); text-align: center; }
.final-inner { max-width: 870px; }
.final-icon { width: 58px; height: 58px; display: grid; place-items: center; margin: 0 auto 28px; border: 1px solid var(--mint); border-radius: 50%; color: var(--mint); font: 800 17px/1 var(--font-display); }
.final-inner h2 { color: var(--white); }.final-inner h2 span { color: var(--mint); }
.final-inner p { max-width: 760px; margin: 0 auto 32px; color: #a8bac5; }
.site-footer { color: #8296a4; background: #04121f; }
.footer-inner { min-height: 115px; display: flex; align-items: center; justify-content: space-between; gap: 30px; }
.footer-brand .brand-logo { width: 245px; opacity: .92; }
.footer-inner > p { font-size: 11px; }
.footer-inner nav { display: flex; gap: 22px; font-size: 11px; }.footer-inner nav a:hover { color: var(--white); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .12s; }.delay-2 { transition-delay: .24s; }

@media (max-width: 1050px) {
  .hero-layout { grid-template-columns: 1fr; }
  .hero { padding-top: 140px; }
  .hero-copy { max-width: 820px; }
  .hero-visual { width: min(600px, 100%); margin-inline: auto; }
  .learning-layout, .registration-layout { gap: 55px; }
  .audience-layout { grid-template-columns: 1fr; gap: 50px; }
  .speaker-copy { padding: 50px; }
}

@media (max-width: 820px) {
  .section { padding: 82px 0; }
  .problem-grid { grid-template-columns: 1fr; }
  .problem-card { min-height: 275px; }
  .learning-layout, .guide-layout, .registration-layout { grid-template-columns: 1fr; }
  .learning-intro, .registration-copy { position: static; }
  .deadline-card { max-width: 460px; }
  .agenda-heading { grid-template-columns: 1fr; gap: 15px; }
  .speaker-card { grid-template-columns: 1fr; padding: 22px; }
  .speaker-portrait { aspect-ratio: 1.08; max-height: 430px; }
  .guide-copy { order: 1; }.guide-visual { order: 2; }
  .cta-band-inner { grid-template-columns: 1fr; gap: 30px; }
}

@media (max-width: 600px) {
  .container { width: min(100% - 28px, 1180px); }
  .site-header { position: absolute; }
  .header-inner { min-height: 70px; }
  .brand-logo { width: 188px; }
  .button-small { min-height: 39px; padding-inline: 15px; font-size: 12px; }
  .hero { min-height: auto; padding: 118px 0 70px; }
  .hero h1 { font-size: 39px; }
  .hero-lead { font-size: 16px; }
  .hero blockquote { font-size: 14px; }
  .hero-actions { align-items: stretch; flex-direction: column; gap: 12px; }
  .hero-actions .button { width: 100%; }
  .text-link { align-self: center; }
  .event-chips { display: grid; grid-template-columns: repeat(2, 1fr); }
  .event-chip { padding: 9px 8px; font-size: 11px; }
  .hero-visual { min-height: 490px; margin-top: 20px; }
  .visual-core { inset: 90px 0 80px; }
  .data-card { width: 225px; }
  .card-top { right: -5px; }.card-bottom { left: -4px; }
  .label-a, .label-b { display: none; }
  .ai-orbit { transform: translate(-50%,-50%) scale(.82); }
  .strip-inner { padding: 20px 0; align-items: flex-start; flex-direction: column; gap: 15px; }
  .strip-inner p:first-child { align-items: flex-start; }
  .section-heading h2, .learning-intro h2, .audience-copy h2, .speaker-copy h2, .guide-copy h2, .registration-copy h2, .final-inner h2 { font-size: 34px; }
  .section-heading { margin-bottom: 38px; }
  .problem-card { padding: 27px; }
  .learning-layout { gap: 45px; }
  .benefit { grid-template-columns: 38px 1fr; padding-inline: 3px; }
  .agenda-item { grid-template-columns: 62px 1fr; gap: 14px; padding-right: 3px; }
  .agenda-timeline::before { left: 21px; }
  .agenda-arrow { display: none; }
  .agenda-copy h3 { font-size: 16px; }
  .audience-grid { grid-template-columns: 1fr; }
  .speaker-portrait { aspect-ratio: 1.05; max-height: 330px; }
  .speaker-photo-frame { width: min(80%, 260px); border-width: 6px; border-radius: 18px; }
  .portrait-halo { width: 250px; height: 250px; border-radius: 22px; }
  .speaker-copy { padding: 37px 26px 42px; }
  .guide-visual { min-height: 430px; transform: scale(.9); }
  .guide-book { width: 280px; height: 370px; }
  .cta-band { padding: 65px 0; }
  .registration-card { padding: 30px 20px; }
  .footer-inner { padding: 35px 0; align-items: flex-start; flex-direction: column; }
  .footer-inner nav { flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
