:root {
  --dopp-navy: #1769aa;
  --dopp-dark: #0f4f85;
  --dopp-gold: #c79a45;
  --dopp-light: #f6f8fb;
  --dopp-line: rgba(23, 105, 170, .14);
}

.dopp-shell { width: min(1160px, calc(100% - 32px)); margin-inline: auto; }
.dopp-site-ready * { box-sizing: border-box; }
.dopp-homepage .entry-header,
.dopp-homepage .page-title,
.dopp-homepage .title-size-default,
.dopp-homepage .breadcrumbs,
.dopp-homepage .wd-breadcrumbs,
.dopp-homepage .wd-page-title { display: none !important; }
.dopp-homepage .main-page-wrapper,
.dopp-homepage .site-content,
.dopp-homepage .content-layout-wrapper,
.dopp-homepage .entry-content,
.dopp-homepage .wpb-content-wrapper { padding-top: 0 !important; margin-top: 0 !important; }
.dopp-homepage .container,
.dopp-homepage .container-fluid { margin-top: 0 !important; }
.dopp-home { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); overflow-x: hidden; background: #fff; }
.dopp-header { position: relative; z-index: 90; background: linear-gradient(90deg, #1769aa, #0f75bd); color: #fff; box-shadow: 0 8px 24px rgba(15,79,133,.18); }
.dopp-header-inner { min-height: 78px; display: flex; align-items: center; gap: 22px; }
.dopp-brand { display: inline-flex; align-items: center; gap: 12px; color: #fff; text-decoration: none; min-width: 210px; }
.dopp-brand img { max-height: 54px; width: auto; display: block; }
.dopp-brand strong { font-size: 25px; line-height: .95; letter-spacing: 0; max-width: 150px; }
.dopp-brand-mark { color: var(--dopp-gold); width: 44px; height: 44px; display: grid; place-items: center; border: 2px solid currentColor; border-radius: 6px; }
.dopp-menu-panel { display: flex; align-items: center; gap: 20px; flex: 1; }
.dopp-nav { display: flex; align-items: center; justify-content: center; gap: 20px; flex: 1; }
.dopp-nav a { color: #fff; font-weight: 700; text-decoration: none; font-size: 13px; }
.dopp-nav a:hover { color: var(--dopp-gold); }
.dopp-header-actions { display: flex; gap: 10px; align-items: center; }
.dopp-btn { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 18px; border-radius: 5px; font-size: 14px; font-weight: 800; text-decoration: none; border: 1px solid transparent; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.dopp-btn:hover { transform: translateY(-1px); }
.dopp-btn-ghost { color: #fff; border-color: rgba(255,255,255,.55); }
.dopp-btn-gold { color: #fff; background: linear-gradient(180deg, #d7ad5e, #b4812d); box-shadow: 0 10px 22px rgba(199,154,69,.28); }
.dopp-btn-large { min-height: 48px; padding-inline: 24px; }
.dopp-menu-toggle { display: none !important; margin-left: auto; background: transparent !important; border: 1px solid rgba(255,255,255,.45) !important; border-radius: 5px; width: 42px; height: 38px; padding: 0 !important; box-shadow: none !important; }
.dopp-menu-toggle span { display: block !important; width: 20px; height: 2px; margin: 4px auto; background: #fff !important; border-radius: 2px; opacity: 1 !important; }

.dopp-hero { position: relative; color: #fff; overflow: hidden; margin-top: 0 !important; background: #0f4f85; }
.dopp-hero:before { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(90deg, rgba(15,79,133,.86) 0%, rgba(23,105,170,.66) 48%, rgba(15,79,133,.24) 100%); pointer-events: none; }
.dopp-hero-slides, .dopp-hero-slide { position: absolute; inset: 0; }
.dopp-hero-slide { opacity: 0; background-image: var(--dopp-hero-image); background-size: cover; background-position: center right; transform: scale(1.02); transition: opacity .7s ease, transform 4s ease; }
.dopp-hero-slide.is-active { opacity: 1; transform: scale(1); }
.dopp-hero-grid { position: relative; z-index: 2; min-height: 560px; display: grid; grid-template-columns: 1fr .45fr; align-items: center; gap: 32px; padding-block: 58px; }
.dopp-hero h1 { margin: 0 0 18px; font-size: clamp(34px, 5vw, 53px); line-height: 1.12; color: #fff; letter-spacing: 0; }
.dopp-hero h1 span { color: var(--dopp-gold); }
.dopp-hero p { max-width: 610px; margin: 0 0 28px; color: rgba(255,255,255,.9); font-size: 18px; line-height: 1.65; }
.dopp-hero-features { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin: 0 0 28px; }
.dopp-hero-features div { min-width: 0; }
.dopp-hero-features .dopp-icon { color: var(--dopp-gold); font-size: 30px; margin-bottom: 8px; }
.dopp-hero-features strong { display: block; color: var(--dopp-gold); font-size: 13px; line-height: 1.2; }
.dopp-hero-features small { display: block; color: rgba(255,255,255,.78); font-size: 11px; line-height: 1.35; }
.dopp-hero-side { min-height: 330px; position: relative; }
.dopp-badge { position: absolute; right: 12px; bottom: 8px; width: 145px; height: 145px; display: grid; place-items: center; text-align: center; padding: 18px; border-radius: 999px; color: #fff; font-weight: 900; font-size: 13px; line-height: 1.25; border: 3px solid var(--dopp-gold); background: radial-gradient(circle, rgba(23,105,170,.96), rgba(15,79,133,.96)); box-shadow: 0 14px 34px rgba(15,79,133,.34); }

.dopp-section { padding: 34px 0 22px; background: #fff; }
.dopp-section-title { display: flex; align-items: center; justify-content: center; gap: 28px; margin: 0 0 20px; }
.dopp-section-title span, .dopp-block-head span, .dopp-announcements h2 span { display: inline-block; width: 70px; height: 1px; background: var(--dopp-gold); }
.dopp-section-title h2, .dopp-block-head h2, .dopp-announcements h2 { margin: 0; color: var(--dopp-navy); font-size: 24px; font-weight: 900; letter-spacing: 0; }
.dopp-category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.dopp-category-card { min-height: 112px; display: grid; grid-template-columns: 64px 1fr; gap: 18px; align-items: center; padding: 22px; border-radius: 8px; background: #fff; color: var(--dopp-navy); text-decoration: none; box-shadow: 0 10px 30px rgba(23,105,170,.08); border: 1px solid rgba(23,105,170,.07); }
.dopp-category-card:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(23,105,170,.14); }
.dopp-category-icon { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 6px; color: #fff; background: linear-gradient(135deg, #2284ce, #1769aa); }
.dopp-category-card.is-gold .dopp-category-icon { background: linear-gradient(135deg, #d7ad5e, #9f6e24); }
.dopp-category-card h3 { margin: 0 0 7px; color: var(--dopp-navy); font-size: 14px; font-weight: 900; line-height: 1.25; }
.dopp-category-card p { margin: 0; color: #b4812d; font-size: 13px; font-weight: 700; }

.dopp-cta { margin: 22px 0 16px; min-height: 250px; display: grid; grid-template-columns: 1fr 1.25fr; gap: 20px; align-items: center; padding: 34px 38px; color: #fff; border-radius: 8px; background-image: linear-gradient(90deg, rgba(15,79,133,.92), rgba(23,105,170,.78)), var(--dopp-cta-image); background-size: cover; background-position: center; box-shadow: 0 14px 34px rgba(23,105,170,.18); }
.dopp-cta h2 { margin: 0 0 14px; color: #fff; font-size: 27px; line-height: 1.18; font-weight: 900; letter-spacing: 0; }
.dopp-cta h2 span { color: var(--dopp-gold); }
.dopp-cta p { margin: 0 0 22px; color: rgba(255,255,255,.9); line-height: 1.6; }
.dopp-cta-icons { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.dopp-cta-icons div { min-height: 110px; display: grid; place-items: center; align-content: center; gap: 12px; text-align: center; }
.dopp-cta-icons .dopp-icon { width: 64px; height: 64px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.78); border-radius: 999px; color: #fff; font-size: 28px; }
.dopp-cta-icons strong { color: #fff; font-size: 14px; line-height: 1.35; }

.dopp-stats { margin: 0 0 16px; display: grid; grid-template-columns: repeat(4, 1fr); background: #fff; border: 1px solid var(--dopp-line); border-radius: 8px; box-shadow: 0 10px 28px rgba(23,105,170,.08); }
.dopp-stats div { min-height: 92px; display: grid; grid-template-columns: 48px auto; align-content: center; column-gap: 16px; padding: 18px 28px; border-right: 1px solid var(--dopp-line); }
.dopp-stats div:last-child { border-right: 0; }
.dopp-stats .dopp-icon { grid-row: span 2; color: var(--dopp-navy); font-size: 34px; align-self: center; }
.dopp-stats strong { color: var(--dopp-navy); font-size: 26px; line-height: 1; }
.dopp-stats span { color: #5d6a7b; font-size: 14px; }

.dopp-lower-grid { display: grid; grid-template-columns: .72fr 1.28fr; gap: 24px; align-items: stretch; margin-bottom: 24px; }
.dopp-announcements, .dopp-courses { padding: 24px 28px; background: #fff; border-radius: 8px; box-shadow: 0 10px 30px rgba(23,105,170,.08); border: 1px solid rgba(23,105,170,.08); }
.dopp-announcements article { display: grid; grid-template-columns: 34px 1fr; gap: 14px; margin: 18px 0; }
.dopp-announcements .dopp-icon { color: var(--dopp-navy); font-size: 25px; }
.dopp-announcements h3, .dopp-course-card h3 { margin: 0 0 6px; color: var(--dopp-navy); font-size: 15px; font-weight: 900; line-height: 1.3; }
.dopp-announcements p, .dopp-course-card p { margin: 0 0 5px; color: #3d4858; font-size: 13px; line-height: 1.45; }
.dopp-announcements time { color: #8a96a6; font-size: 11px; }
.dopp-link, .dopp-block-head a, .dopp-course-card a { color: var(--dopp-navy); text-decoration: none; font-weight: 900; font-size: 13px; }
.dopp-block-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; }
.dopp-course-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dopp-course-card { overflow: hidden; border-radius: 8px; background: #fff; border: 1px solid var(--dopp-line); box-shadow: 0 8px 20px rgba(23,105,170,.07); }
.dopp-course-card img { width: 100%; aspect-ratio: 3 / 1.45; object-fit: cover; display: block; background: var(--dopp-light); }
.dopp-course-card div { padding: 14px; }
.dopp-course-card small { display: flex; gap: 8px; align-items: center; color: #5d6a7b; margin: 10px 0 12px; font-size: 11px; }

.dopp-newsletter { margin: 0 0 0; min-height: 92px; display: grid; grid-template-columns: 72px 1fr minmax(320px, 460px); gap: 20px; align-items: center; padding: 22px 38px; color: #fff; border-radius: 8px 8px 0 0; background: linear-gradient(90deg, #1769aa, #0f75bd); }
.dopp-newsletter > .dopp-icon { font-size: 46px; color: #fff; }
.dopp-newsletter h2 { margin: 0 0 5px; color: #fff; font-size: 20px; }
.dopp-newsletter p { margin: 0; color: rgba(255,255,255,.86); }
.dopp-newsletter form { display: grid; grid-template-columns: 1fr 130px; }
.dopp-newsletter input { min-height: 48px; border: 0; border-radius: 5px 0 0 5px; padding: 0 18px; }
.dopp-newsletter button { border: 0; border-radius: 0 5px 5px 0; background: var(--dopp-gold); color: #fff; font-weight: 900; cursor: pointer; }

.dopp-footer { background: linear-gradient(110deg, #0f4f85, #1769aa); color: rgba(255,255,255,.86); padding: 34px 0 18px; }
.dopp-footer-grid { display: grid; grid-template-columns: 1.35fr repeat(4, 1fr); gap: 30px; }
.dopp-footer-logo { display: flex; align-items: center; gap: 12px; color: #fff; font-size: 23px; line-height: 1; font-weight: 900; }
.dopp-footer-logo img { max-height: 48px; width: auto; }
.dopp-footer p { line-height: 1.6; font-size: 13px; }
.dopp-socials { display: flex; gap: 9px; }
.dopp-socials a { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 999px; background: rgba(255,255,255,.09); color: #fff; text-decoration: none; font-size: 12px; }
.dopp-footer h3 { color: #fff; margin: 0 0 16px; font-size: 14px; }
.dopp-footer-col a { display: block; color: rgba(255,255,255,.82); text-decoration: none; margin: 0 0 9px; font-size: 13px; }
.dopp-copyright { margin-top: 28px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.1); text-align: center; font-size: 12px; }

.dopp-pmpro-wrap { color: #fff; background-image: linear-gradient(90deg, rgba(15,79,133,.92), rgba(23,105,170,.76)), var(--dopp-page-image); background-size: cover; background-position: center; }
.dopp-pmpro-head h1 { margin: 0 0 10px; color: #fff; font-size: clamp(30px, 4vw, 44px); }
.dopp-pmpro-head p { margin: 0; max-width: 720px; color: rgba(255,255,255,.88); }
.dopp-page-layout { display: grid; grid-template-columns: 1fr; gap: 28px; padding-block: 36px; }
.dopp-page-layout.has-sidebar { grid-template-columns: minmax(0, 1fr) 300px; }
.dopp-page-content, .dopp-sidebar, .dopp-pmpro-card { background: #fff; border: 1px solid var(--dopp-line); border-radius: 8px; padding: 30px; box-shadow: 0 12px 30px rgba(23,105,170,.08); }
.dopp-featured img { width: 100%; border-radius: 8px; margin-bottom: 24px; }
.dopp-pmpro-wrap { padding: 46px 0; }
.dopp-pmpro-head { margin-bottom: 22px; }
.dopp-pmpro-card, .dopp-pmpro-card h1, .dopp-pmpro-card h2, .dopp-pmpro-card h3 { color: var(--dopp-navy); }
.dopp-pmpro-card input, .dopp-pmpro-card select { border: 1px solid var(--dopp-line); border-radius: 5px; min-height: 42px; }
.dopp-pmpro-card .pmpro_btn, .dopp-pmpro-card input[type=submit] { background: var(--dopp-gold); color: #fff; border: 0; border-radius: 5px; padding: 12px 18px; font-weight: 900; }

.dopp-course-category,
.dopp-topic-content,
.dopp-course-detail { margin: 0 auto; padding: 10px 0 6px; }
.dopp-content-hero { display: grid; grid-template-columns: 74px 1fr; gap: 18px; align-items: center; margin: 0 0 22px; padding: 26px 30px; border-radius: 8px; color: #fff; background: linear-gradient(110deg, #1769aa, #2383cb); box-shadow: 0 14px 32px rgba(23,105,170,.16); }
.dopp-content-hero > .dopp-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 8px; color: #fff; background: rgba(255,255,255,.14); font-size: 34px; }
.dopp-content-hero h2 { margin: 0 0 7px; color: #fff; font-size: clamp(24px, 3vw, 34px); line-height: 1.15; letter-spacing: 0; }
.dopp-content-hero p { margin: 0; color: rgba(255,255,255,.88); line-height: 1.55; }
.dopp-subcategory-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.dopp-subcategory-card { min-height: 178px; display: flex; flex-direction: column; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 22px; color: var(--dopp-navy); text-decoration: none; border: 1px solid var(--dopp-line); border-radius: 8px; background: #fff; box-shadow: 0 10px 26px rgba(23,105,170,.08); }
.dopp-subcategory-card:hover { transform: translateY(-2px); box-shadow: 0 18px 34px rgba(23,105,170,.14); }
.dopp-subcategory-card .dopp-icon { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 8px; color: #fff; background: linear-gradient(135deg, #2383cb, #1769aa); font-size: 28px; }
.dopp-subcategory-card h3 { margin: 0; color: var(--dopp-navy); font-size: 17px; line-height: 1.32; letter-spacing: 0; }
.dopp-subcategory-card p { margin: 0; color: #b4812d; font-weight: 900; font-size: 13px; }
.dopp-topic-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.dopp-topic-item { display: grid; grid-template-columns: 46px 1fr; gap: 14px; align-items: start; min-height: 84px; padding: 17px 18px; border: 1px solid var(--dopp-line); border-radius: 8px; background: #fff; box-shadow: 0 8px 22px rgba(23,105,170,.06); }
.dopp-topic-item span { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 999px; color: #fff; background: var(--dopp-gold); font-weight: 900; font-size: 13px; }
.dopp-topic-item h3 { margin: 6px 0 0; color: var(--dopp-navy); font-size: 15px; line-height: 1.42; letter-spacing: 0; }
.dopp-empty-state,
.dopp-detail-panel { padding: 28px; border: 1px solid var(--dopp-line); border-radius: 8px; background: #fff; box-shadow: 0 10px 26px rgba(23,105,170,.08); }
.dopp-empty-state .dopp-icon { color: var(--dopp-gold); font-size: 42px; margin-bottom: 14px; }
.dopp-empty-state h3,
.dopp-detail-panel h3 { margin: 0 0 10px; color: var(--dopp-navy); font-size: 22px; line-height: 1.2; }
.dopp-empty-state p,
.dopp-detail-panel p { margin: 0 0 18px; color: #3d4858; line-height: 1.7; }

.dopp-team-section { padding: 6px 0; }
.dopp-team-hero { display: grid; grid-template-columns: 96px 1fr; gap: 22px; align-items: center; margin-bottom: 22px; padding: 30px; border-radius: 8px; color: #fff; background: linear-gradient(115deg, #1769aa, #2383cb); box-shadow: 0 14px 32px rgba(23,105,170,.16); }
.dopp-team-hero > span { width: 76px; height: 76px; display: grid; place-items: center; border-radius: 999px; border: 2px solid rgba(255,255,255,.46); color: #fff; background: rgba(255,255,255,.12); font-size: 30px; font-weight: 900; }
.dopp-team-hero h2 { margin: 0 0 8px; color: #fff; font-size: clamp(26px, 3vw, 38px); line-height: 1.12; letter-spacing: 0; }
.dopp-team-hero p { max-width: 820px; margin: 0; color: rgba(255,255,255,.88); font-size: 16px; line-height: 1.65; }
.dopp-team-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.dopp-team-section.is-academic .dopp-team-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.dopp-team-card { position: relative; min-height: 178px; display: grid; grid-template-columns: 76px 1fr; gap: 18px; align-items: start; padding: 24px; border: 1px solid var(--dopp-line); border-radius: 8px; background: linear-gradient(180deg, #fff, #f8fbff); box-shadow: 0 10px 28px rgba(23,105,170,.08); overflow: hidden; text-decoration: none; }
.dopp-team-card.is-clickable:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(23,105,170,.14); }
.dopp-team-card:before { content: ""; position: absolute; inset: 0 auto 0 0; width: 5px; background: var(--dopp-navy); }
.dopp-team-card.is-gold:before { background: var(--dopp-gold); }
.dopp-team-avatar { width: 64px; height: 64px; display: grid; place-items: center; border-radius: 8px; color: #fff; background: linear-gradient(135deg, #2383cb, #1769aa); font-size: 22px; font-weight: 900; letter-spacing: 0; box-shadow: 0 12px 24px rgba(23,105,170,.16); }
.dopp-team-card.is-gold .dopp-team-avatar { background: linear-gradient(135deg, #d7ad5e, #b4812d); }
.dopp-team-photo { width: 64px; height: 64px; display: block; border-radius: 8px; object-fit: cover; object-position: center; box-shadow: 0 12px 24px rgba(23,105,170,.16); }
.dopp-team-copy h3 { margin: 0 0 8px; color: var(--dopp-navy); font-size: 21px; line-height: 1.18; letter-spacing: 0; }
.dopp-team-copy strong { display: block; margin-bottom: 9px; color: #b4812d; font-size: 13px; line-height: 1.35; text-transform: uppercase; letter-spacing: 0; }
.dopp-team-copy p { margin: 0; color: #3d4858; line-height: 1.6; font-size: 14px; }
.dopp-team-copy em { display: inline-block; margin-top: 12px; color: var(--dopp-navy); font-style: normal; font-size: 13px; font-weight: 900; }

.dopp-profile { padding: 6px 0; }
.dopp-profile-hero { display: grid; grid-template-columns: 300px 1fr; gap: 30px; align-items: center; margin-bottom: 24px; padding: 30px; border-radius: 8px; color: #fff; background: linear-gradient(115deg, #1769aa, #2383cb); box-shadow: 0 14px 32px rgba(23,105,170,.16); }
.dopp-profile-hero img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; border: 3px solid rgba(255,255,255,.32); box-shadow: 0 18px 34px rgba(0,0,0,.18); }
.dopp-profile-back { display: inline-flex; margin-bottom: 12px; color: #fff; text-decoration: none; font-weight: 900; opacity: .86; }
.dopp-profile-hero h2 { margin: 0 0 9px; color: #fff; font-size: clamp(30px, 4vw, 46px); line-height: 1.08; letter-spacing: 0; }
.dopp-profile-hero strong { display: block; margin-bottom: 12px; color: var(--dopp-gold); font-size: 15px; text-transform: uppercase; }
.dopp-profile-hero p { max-width: 760px; margin: 0; color: rgba(255,255,255,.9); font-size: 17px; line-height: 1.65; }
.dopp-profile-panel,
.dopp-profile-list { padding: 26px; border: 1px solid var(--dopp-line); border-radius: 8px; background: #fff; box-shadow: 0 10px 26px rgba(23,105,170,.08); }
.dopp-profile-panel { margin-bottom: 18px; }
.dopp-profile-panel h3,
.dopp-profile-list h3 { margin: 0 0 14px; color: var(--dopp-navy); font-size: 22px; line-height: 1.2; }
.dopp-profile-panel p { margin: 0 0 14px; color: #3d4858; line-height: 1.75; }
.dopp-profile-panel p:last-child { margin-bottom: 0; }
.dopp-profile-columns { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; align-items: start; }
.dopp-profile-list span { display: inline-flex; margin-bottom: 10px; padding: 6px 10px; border-radius: 999px; color: #fff; background: var(--dopp-gold); font-size: 12px; font-weight: 900; }
.dopp-profile-list ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 9px; }
.dopp-profile-list li { position: relative; padding-left: 20px; color: #3d4858; line-height: 1.5; }
.dopp-profile-list li:before { content: ""; position: absolute; left: 0; top: .68em; width: 7px; height: 7px; border-radius: 999px; background: var(--dopp-gold); }

.dopp-icon { display: inline-flex; align-items: center; justify-content: center; width: 1em; height: 1em; vertical-align: -.16em; line-height: 1; flex: 0 0 auto; }
.dopp-icon svg { width: 1em; height: 1em; display: block; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.dopp-icon-mail { font-size: 52px; }

@media (max-width: 1024px) {
  .dopp-header-inner { position: relative; padding-block: 12px; }
  .dopp-menu-toggle { display: inline-grid !important; align-content: center; }
  .dopp-menu-panel { display: none; position: absolute; left: 0; right: 0; top: 100%; z-index: 120; padding: 18px; background: linear-gradient(180deg, #1769aa, #0f75bd); border-top: 1px solid rgba(255,255,255,.16); box-shadow: 0 18px 34px rgba(15,79,133,.26); }
  .dopp-header.is-open .dopp-menu-panel { display: grid; gap: 18px; }
  .dopp-nav { flex-direction: column; align-items: flex-start; justify-content: flex-start; gap: 14px; width: 100%; }
  .dopp-header-actions { width: 100%; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.1); }
  .dopp-hero-grid, .dopp-cta, .dopp-lower-grid { grid-template-columns: 1fr; }
  .dopp-category-grid { grid-template-columns: repeat(2, 1fr); }
  .dopp-subcategory-grid, .dopp-topic-list { grid-template-columns: repeat(2, 1fr); }
  .dopp-team-section.is-academic .dopp-team-grid, .dopp-team-grid { grid-template-columns: repeat(2, 1fr); }
  .dopp-profile-hero, .dopp-profile-columns { grid-template-columns: 1fr; }
  .dopp-stats { grid-template-columns: repeat(2, 1fr); }
  .dopp-course-grid { grid-template-columns: 1fr; }
  .dopp-newsletter { grid-template-columns: 52px 1fr; }
  .dopp-newsletter form, .dopp-newsletter-shortcode { grid-column: 1 / -1; }
  .dopp-footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
  .dopp-shell { width: min(100% - 22px, 1160px); }
  .dopp-brand { min-width: 0; }
  .dopp-brand strong { font-size: 20px; max-width: 130px; }
  .dopp-hero-grid { padding-block: 30px; }
  .dopp-hero-features, .dopp-category-grid, .dopp-cta-icons, .dopp-stats, .dopp-footer-grid, .dopp-page-layout.has-sidebar { grid-template-columns: 1fr; }
  .dopp-subcategory-grid, .dopp-topic-list, .dopp-content-hero { grid-template-columns: 1fr; }
  .dopp-team-hero, .dopp-team-section.is-academic .dopp-team-grid, .dopp-team-grid, .dopp-team-card { grid-template-columns: 1fr; }
  .dopp-profile-hero, .dopp-profile-columns { grid-template-columns: 1fr; }
  .dopp-hero h1 { font-size: 34px; }
  .dopp-hero-grid { grid-template-columns: 1fr; min-height: 540px; }
  .dopp-hero-side { min-height: 120px; }
  .dopp-badge { width: 118px; height: 118px; font-size: 11px; }
  .dopp-section-title { gap: 12px; }
  .dopp-section-title span { width: 32px; }
  .dopp-cta { padding: 26px 20px; }
  .dopp-stats div { border-right: 0; border-bottom: 1px solid var(--dopp-line); }
  .dopp-newsletter { grid-template-columns: 1fr; padding: 22px; border-radius: 8px 8px 0 0; }
  .dopp-newsletter form { grid-template-columns: 1fr; gap: 10px; }
  .dopp-newsletter input, .dopp-newsletter button { border-radius: 5px; }
  .dopp-header-actions { flex-direction: column; align-items: stretch; }
}
