:root{
  color-scheme:dark;
  --bg:#030406;
  --panel:rgba(255,255,255,.033);
  --panel2:rgba(255,255,255,.047);
  --line:rgba(255,255,255,.105);
  --line2:rgba(255,255,255,.065);
  --text:#f4f4f5;
  --muted:rgba(244,244,245,.62);
  --green:#d8c27a;
  --green2:#e7c76a;
  --gold:#e7c76a;
  --blue:#bfc4ca;
  --red:#c79778;
  --violet:#c8bdaf;
  --amber:#d99a35;
  --r:18px;
  --r2:24px}
*{box-sizing:border-box}
html{background:#000;scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(ellipse 72% 40% at 50% -8%,rgba(217,154,53,.060),transparent 66%),
    radial-gradient(ellipse 52% 34% at 10% 5%,rgba(231,199,106,.028),transparent 62%),
    var(--bg);
  color:var(--text);
  font-family:'Be Vietnam Pro',Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:15px;
  line-height:1.68;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased}
body.mp-index-motion{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
a{color:inherit;text-decoration:none}
img,svg,canvas,video{max-width:100%}
button,input{font:inherit}
[id]{scroll-margin-top:84px}
.dkc-main-anchor{position:absolute;top:0}

.dkc-logo-img{width:30px;height:30px;object-fit:contain;border-radius:8px}
.dkc-logo-text{font-size:13px;color:var(--dkc-gold)}
.dkc-ai-nav{color:#f0d982}#dkc-top-btn{position:fixed;right:16px;bottom:18px;z-index:997;width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:rgba(0,0,0,.68);color:#fff}


.container{width:min(1120px,calc(100% - 32px));margin:0 auto}
.section{padding:76px 0;border-top:1px solid var(--line2)}
.section:first-of-type{border-top:0}
.section-label,.master-kicker,.bc-source-line,.na-section-title,.n9-kicker{
  color:var(--green2);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:900;margin-bottom:12px}
.section-title{font-size:clamp(2.15rem,4.8vw,3.75rem);line-height:1.06;letter-spacing:-.045em;color:#fff;margin:0 0 22px;font-weight:950}
.section-title span{color:var(--green2)}
.section-note,.hero-sub,p{color:var(--muted)}
.hero,.bc-hero{padding:108px 0 76px;background:radial-gradient(ellipse 82% 62% at 50% 0%,rgba(31,79,43,.20),rgba(3,3,3,.88) 70%,#030406)}
.hero-title,.bc-hero h1{font-size:clamp(2.4rem,6vw,5rem);line-height:.98;letter-spacing:-.065em;color:#fff;margin:0 0 20px;font-weight:950}
.hero-sub,.bc-hero p{max-width:780px;margin:0 auto 22px;font-size:15px;line-height:1.76}
.hero-author{color:#91c89f;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.hero-badge,.astro-tag,.pl-tag,.na-tag,.n9-tag-row span,.timing-chip,.syc-asset,.htu-phase-badge,.htu-conv,.bc-yn,.astro-pill{
  display:inline-flex;align-items:center;gap:7px;padding:5px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--dkc-gold);font-size:11.5px;font-weight:800;line-height:1.2}
.hero-nav,.hero-cycle-bar,.bc-year-nav{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:24px}
.hero-nav a,.hcb-item,.mini-entry{
  border:1px solid var(--line);background:var(--panel);border-radius:999px;padding:8px 12px;color:#d6e3d9;font-size:12px;font-weight:800}
.orbs,.orb{display:none}


th{color:#a7d6af;text-transform:uppercase;font-size:10.5px;letter-spacing:.10em}
th,td{padding:12px 14px;border-bottom:1px solid var(--line2);vertical-align:top}
tr:last-child td{border-bottom:0}
.card,.pl-card,.astro-dict-card,.aspect-compact-card,.eclipse-card,.na-flow-card,.na-year-card,.n9-panel,.n9-axis-card,.n9-cycle-item,.n9-year-card,.bc-year-block,.bc-dim,.btc-phase-card,.btc-dash-item,.dkc-btc-tcs-card,.master-visual,.cycle-brief,.deep-card,.syc-card,.crypto-strip,#dkc-chart-section,.core-logic-row,.strategy-master-card,.year-map .box{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);backdrop-filter:blur(13px) saturate(1.04);-webkit-backdrop-filter:blur(13px) saturate(1.04);box-shadow:none}
.footer-wrap,.dkc-footer-unified,.mp-site-footer{padding:38px 22px 24px;background:#020202;border-top:1px solid var(--line2);color:#9fafA2;font-size:12px}
.dkc-footer-inner{width:min(1120px,100%);margin:0 auto}.dkc-footer-cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;margin-top:24px}.dkc-footer-col-title,.dkc-footer-brand{color:#fff;font-weight:900}.dkc-footer-col a{display:block;color:#c7d5ca;margin:5px 0}.dkc-footer-bottom{margin-top:24px;padding-top:16px;border-top:1px solid var(--line2);color:#8c9b8f}


.hcb-bull,.hm-buy,.syc-buy,.phase-dca{background:rgba(74,190,112,.13);color:#95d3a5;border-color:rgba(74,190,112,.22)}
.hcb-neutral,.hm-hold,.syc-hold,.phase-pre{background:rgba(76,160,210,.12);color:#9bc7d9;border-color:rgba(76,160,210,.22)}
.hcb-warning,.hm-dist,.syc-dist,.phase-profit,.phase-dist{background:rgba(218,155,54,.13);color:#d99a35;border-color:rgba(218,155,54,.23)}
.hcb-danger,.hm-exit,.syc-exit{background:rgba(205,98,98,.13);color:#c79778;border-color:rgba(205,98,98,.23)}
.hcb-pivot{background:rgba(155,138,192,.13);color:#b2a5cc;border-color:rgba(155,138,192,.22)}

@media(max-width:920px){.section{padding:58px 0}.container{width:min(100% - 28px,1120px)}.dkc-footer-cols{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:560px){
  body{font-size:14px}.section-title{font-size:clamp(1.95rem,10vw,2.55rem)}.hero,.bc-hero{padding-top:94px}.dkc-footer-cols{grid-template-columns:1fr}
}


#master{padding-top:98px}.master-visual{padding:22px;margin-bottom:24px}.master-chart-svg{display:block;margin-bottom:14px}.master-visual>.dkc-chart-note{display:block;clear:both;margin-top:12px}
.cycle-brief{padding:18px 20px;margin:22px 0}.cycle-brief-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.cycle-brief-grid div{padding:12px;border-radius:14px;background:rgba(255,255,255,.026);border:1px solid var(--line2)}.cycle-brief-grid strong{display:block;color:#fff;font-size:12px;font-weight:900;margin-bottom:6px}.cycle-brief-grid span{display:block;color:rgba(224,231,221,.72);font-size:12px;line-height:1.55}
.htu-wrap{margin-bottom:28px}.htu-year-link{font-size:1.15rem;font-weight:950}.htu-note,.htu-strat-2{color:#9fb1a3;font-size:11px}.syc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.syc-card{padding:0}.syc-header{padding:16px 18px;border-bottom:1px solid var(--line2)}.syc-year{font-size:2rem;color:#fff;font-weight:950}.syc-timing{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--line2)}.syc-ti{padding:10px 12px;border-right:1px solid var(--line2)}.syc-section{padding:14px 18px;border-bottom:1px solid var(--line2)}.syc-assets{display:flex;flex-wrap:wrap;gap:7px;padding:12px 18px}
@media(max-width:980px){.cycle-brief-grid{grid-template-columns:repeat(2,1fr)}.syc-grid{grid-template-columns:1fr}}
@media(max-width:640px){.cycle-brief-grid,.syc-timing{grid-template-columns:1fr}}

html,
body{
  opacity:1;
  visibility:visible;
  filter:none;
  overflow-x:hidden}

body *,
body *::before,
body *::after{
  filter:none}

body::before,
body::after,
html::before,
html::after,
.hero::before,
.hero::after,
.bc-hero::before,
.bc-hero::after,
.section::before,
.section::after,
#master::before,
#master::after,
main::before,
main::after{
  display:none;
  content:none;
  opacity:0;
  visibility:hidden;
  pointer-events:none}

.hero,
.section,
.container,
.bc-hero,
.bc-main,
#master,
main,
footer,
.dkc-footer-unified,
.mp-site-footer,
.hero *,
.section *,
.container *,
.bc-hero *,
.bc-main *,
#master *,
main *,
footer *,
.dkc-footer-unified *,
.mp-site-footer *{
  opacity:1;
  visibility:visible;
  transform:none;
  filter:none}


.year-nav,
.master-year-nav,
.syc-year-nav,
.year-selector,
#year-selector,
[id*="year-nav"],
[class*="year-nav"]{
  width:min(920px,100%);
  margin:22px auto 28px;
  padding:16px;
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  border:1px solid rgba(215,189,104,.10);
  border-radius:22px;
  background:rgba(255,255,255,.033)}

.year-nav::before,
.master-year-nav::before,
.syc-year-nav::before,
.year-selector::before,
#year-selector::before,
[id*="year-nav"]::before,
[class*="year-nav"]::before{
  content:"Chọn năm để xem chi tiết";
  flex:0 0 100%;
  display:block;
  margin:0 0 6px;
  color:#e7c76a;
  font-size:11px;
  line-height:1.2;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:950;
  text-align:center}

.year-nav a,
.master-year-nav a,
.syc-year-nav a,
.year-selector a,
#year-selector a,
[id*="year-nav"] a,
[class*="year-nav"] a,
.year-nav button,
.master-year-nav button,
.syc-year-nav button,
.year-selector button,
#year-selector button,
[id*="year-nav"] button,
[class*="year-nav"] button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  min-height:30px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(215,189,104,.10);
  background:rgba(255,255,255,.032);
  color:rgba(255,255,255,.76);
  font-size:12px;
  line-height:1;
  font-weight:900;
  white-space:nowrap}


.master-detail > p:first-child,
.master-detail > .year-list,
.master-detail > .year-picker{
  text-align:center}


.master-chart-card,
.cycle-chart-card,
.chart-card,
.chart-panel,
#strategyChart,
#cycleChart,
[id*="chart"],
[class*="chart"]{
  max-width:100%}

.master-chart-wrap,
.cycle-chart-wrap,
.chart-wrap,
.chart-shell,
[class*="chart-wrap"],
[class*="chart-shell"]{
  width:100%;
  min-height:360px}

canvas#strategyChart,
canvas#cycleChart,
canvas[id*="chart"],
svg.master-chart-svg,
svg[class*="chart"]{
  width:100%;
  min-height:300px;
  height:clamp(300px,36vw,440px);
  display:block}

.master-visual,
#dkc-chart-section,
.chart-section{
  padding:22px}


.master-chart-tabs,
.chart-tabs,
[class*="chart-tabs"]{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:12px 0 14px}

.master-chart-tabs button,
.chart-tabs button,
[class*="chart-tabs"] button{
  border-radius:999px;
  padding:6px 9px;
  border:1px solid rgba(215,189,104,.10);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.78);
  font-size:13px;
  font-weight:690}

body.mp-master .dkc-chart-tab{
  cursor:pointer;
  transition:border-color .18s ease,background .18s ease,color .18s ease}
body.mp-master .dkc-chart-tab:hover{
  border-color:rgba(215,189,104,.26);
  color:#fff}
body.mp-master .dkc-chart-tab.active{
  border-color:rgba(215,189,104,.44);
  background:rgba(215,189,104,.12);
  color:#f0d982}
body.mp-master .dkc-chart-tab-compare{
  margin-left:auto}
body.mp-master .dkc-chart-readout{
  display:grid;
  grid-template-columns:minmax(130px,.32fr) minmax(0,1fr);
  gap:16px;
  align-items:start;
  min-height:9px;
  margin:0 0 12px;
  padding:9px 12px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
  background:rgba(255,255,255,.022)}
body.mp-master .dkc-chart-readout strong{
  color:#fff;
  font-size:11px;
  font-weight:690}
body.mp-master .dkc-chart-readout span{
  color:rgba(255,255,255,.62);
  font-size:11px;
  line-height:1.55}
.dkc-chart-heading{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.dkc-chart-heading h3{margin:0}
.dkc-chart-method-btn{
  flex:0 0 28px;
  width:28px;
  height:28px;
  padding:0;
  border:1px solid rgba(255,255,255,.14);
  border-radius:50%;
  background:#090909;
  color:rgba(255,255,255,.68);
  font-size:13px;
  font-weight:650;
  cursor:pointer;
}
.dkc-chart-method-btn:hover,
.dkc-chart-method-btn[aria-expanded="true"]{
  border-color:rgba(215,189,104,.45);
  color:#e2c45f;
}
.dkc-chart-method{
  margin:12px 0 14px;
  padding:12px 14px;
  border-left:2px solid rgba(215,189,104,.42);
  background:rgba(255,255,255,.022);
}
.dkc-chart-method[hidden]{display:none}
.dkc-chart-method p{
  margin:0 0 5px;
  color:rgba(255,255,255,.62);
  font-size:12px;
  line-height:1.55;
}
.dkc-chart-method p:last-child{margin-bottom:0}
.dkc-chart-method strong{color:rgba(255,255,255,.86);font-weight:650}


.strategy-table,
.asset-table,
.syc-table,
table{
  width:100%;
  border-collapse:collapse}

.strategy-table th,
.strategy-table td,
.asset-table th,
.asset-table td,
.syc-table th,
.syc-table td,
table th,
table td{
  padding:14px 16px;
  vertical-align:top;
  border-bottom:1px solid rgba(255,255,255,.060);
  line-height:1.55}

.strategy-table th,
.asset-table th,
.syc-table th,
table th{
  color:#e7c76a;
  font-size:10.5px;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:950}

.strategy-table td,
.asset-table td,
.syc-table td,
table td{
  color:#e5eee7;
  font-size:13.5px}


.crypto-note,
.stock-note,
.bds-note,
.real-estate-note,
.asset-note,
.asset-specific,
[class*="crypto"],
[class*="stock"],
[class*="bds"],
[class*="real-estate"]{
  text-transform:none}

.crypto-note,
.stock-note,
.bds-note,
.real-estate-note,
.asset-specific,
.asset-note{
  padding:18px 20px;
  margin:18px 0;
  border:1px solid rgba(215,189,104,.10);
  border-radius:18px;
  background:rgba(255,255,255,.026);
  color:#c7d2ca;
  line-height:1.68}

.crypto-note h3,
.stock-note h3,
.bds-note h3,
.real-estate-note h3,
.asset-specific h3,
.asset-note h3{
  margin:0 0 10px;
  color:#e7c76a;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:950}


h2:has(+ .crypto-note),
h2:has(+ .stock-note),
h2:has(+ .bds-note),
h3:has(+ .crypto-note),
h3:has(+ .stock-note),
h3:has(+ .bds-note){
  margin-top:28px}


.delay-logo,
.latency-logo,
.logo-delay,
.sector-logo,
.rotation-logo,
.delay-visual,
.logo-visual,
.sector-visual,
[class*="delay-logo"],
[class*="latency-logo"],
[class*="logo-delay"],
[class*="sector-logo"],
[class*="rotation-logo"],
[class*="delay-visual"],
[class*="logo-visual"],
[class*="sector-visual"]{
  display:none}
h2,
h3,
.section-title,
.section-label{
  position:relative}


.sector-rotation-title::before,
[class*="sector"] .section-label::before,
[class*="rotation"] .section-label::before{
  content:"↻";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  margin-right:8px;
  border-radius:999px;
  border:1px solid rgba(231,199,106,.20);
  background:rgba(231,199,106,.10);
  color:#e7c76a;
  font-size:13px;
  font-weight:950;
  vertical-align:middle}


@media(max-width:980px){
  .year-nav,
  .master-year-nav,
  .syc-year-nav,
  .year-selector,
  #year-selector,
  [id*="year-nav"],
  [class*="year-nav"]{
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    border-radius:18px;
    scrollbar-width:none}

  .year-nav::before,
  .master-year-nav::before,
  .syc-year-nav::before,
  .year-selector::before,
  #year-selector::before,
  [id*="year-nav"]::before,
  [class*="year-nav"]::before{
    display:none}

  canvas#strategyChart,
  canvas#cycleChart,
  canvas[id*="chart"],
  svg.master-chart-svg,
  svg[class*="chart"]{
    min-height:260px;
    height:320px}
}


@media (max-width: 768px){
  body.mp-master .hl-chart-area{
    width:100%;
    max-width:100%;
    overflow:visible;
    margin-bottom:18px}
  body.mp-master #dkc-chart-section{
    width:100%;
    max-width:100%;
    margin:22px 0 18px;
    padding:18px 14px 16px;
    border-radius:18px;
    overflow:hidden}
  body.mp-master #dkc-chart-section h3{
    font-size:1.12rem;
    line-height:1.25;
    letter-spacing:.08em;
    margin-bottom:14px}
  body.mp-master .dkc-chart-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:14px}
  body.mp-master .dkc-chart-tab{
    flex:0 1 auto;
    min-width:0;
    padding:8px 12px;
    font-size:11px;
    line-height:1.2;
    border-radius:999px;
    white-space:nowrap}
  body.mp-master #dkc-canvas-wrap{
    width:100%;
    max-width:100%;
    height:360px;
    min-height:360px;
    max-height:360px;
    overflow:hidden;
    position:relative}
  body.mp-master #dkc-chart{
    display:block;
    width:100%;
    height:300px;
    max-width:100%}
  body.mp-master .dkc-chart-note{
    font-size:12.5px;
    line-height:1.55;
    margin-top:12px;
    padding:12px 13px}
}
@media (max-width: 430px){
  body.mp-master #dkc-canvas-wrap,
  body.mp-master #dkc-chart{height:280px;min-height:280px;max-height:280px}
  body.mp-master .dkc-chart-tab{font-size:10.5px;padding:7px 10px}
  body.mp-master .dkc-chart-tab-compare{margin-left:0}
  body.mp-master .dkc-chart-readout{grid-template-columns:1fr;gap:4px}
}
@media (max-width:768px){
  body.mp-master #sr-canvas{
    width:100%;
    max-width:100%;
    display:block;
    min-height:420px;
    border-radius:10px}
  body.mp-master #sr-canvas + *{max-width:100%}
}


.heatmap-table .hm-plain{
  display:inline;
  padding:0;
  margin:0;
  border:0;
  background:transparent;
  border-radius:0;
  box-shadow:none;
  font-weight:850;
  line-height:1.5;
  white-space:normal}
.heatmap-table .hm-plain.hm-buy{color:#86ffb2}
.heatmap-table .hm-plain.hm-hold{color:#9fdcff}
.heatmap-table .hm-plain.hm-dist{color:#ffd978}
.heatmap-table .hm-plain.hm-exit{color:#ff9d9d}
.heatmap-table .hm-plain.hm-avoid{color:rgba(255,255,255,.72)}
.heatmap-table .hm-action-line{
  color:rgba(255,255,255,.76);
  font-weight:750;
  line-height:1.55}
.heatmap-table .hm-year{font-weight:850;color:rgba(255,255,255,.86)}
.heatmap-table td{background:transparent}


.strategy-notes{
  margin-top:22px;
  display:grid;
  gap:18px}
.strategy-note-block{
  padding:0 0 18px;
  border:0;
  border-bottom:1px solid rgba(255,255,255,.12);
  background:transparent;
  box-shadow:none;
  border-radius:0}
.strategy-note-block:last-child{border-bottom:0;padding-bottom:0}
.strategy-note-block p{
  margin:10px 0 0;
  color:rgba(255,255,255,.82);
  font-size:14.5px;
  line-height:1.75;
  font-weight:650}
.strategy-note-block p strong{color:#fff;font-weight:900}
.strategy-note-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px}
.strategy-note-grid div{
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none}
.strategy-note-grid span{
  display:block;
  margin-bottom:4px;
  color:rgba(255,255,255,.45);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:850}
.strategy-note-grid strong{
  color:rgba(255,255,255,.88);
  font-size:14px;
  line-height:1.55;
  font-weight:850}
@media (max-width:760px){
  .strategy-note-grid{grid-template-columns:1fr;gap:10px}
}


.sector-rotation-card{
  margin:18px auto 10px;
  padding:22px 22px 18px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.014));
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  overflow:hidden}
.sector-rotation-canvas{
  width:100%;
  display:block;
  border-radius:14px;
  background:var(--dkc-bg)}
.sector-rotation-legend{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  margin:0 0 14px;
  color:rgba(255,255,255,.82);
  font-size:12px;
  font-weight:850;
  letter-spacing:.02em}
.sector-rotation-legend span{
  display:inline-flex;
  align-items:center;
  gap:8px}
.sector-rotation-legend i{
  display:inline-block;
  width:34px;
  height:3px;
  border-radius:999px}
.sector-rotation-legend .line-finance{background:#7dd3fc;box-shadow:0 0 12px rgba(125,211,252,.35)}
.sector-rotation-legend .line-economy{background:#b89450;box-shadow:0 0 12px rgba(184,148,80,.28)}
.sector-number-legend{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px 14px;
  margin-top:16px;
  padding-top:15px;
  border-top:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.72);
  font-size:11px;
  line-height:1.35;
  font-weight:750}
.sector-number-legend span{white-space:nowrap}
.sector-number-legend b{
  color:#fff;
  margin-right:5px;
  font-weight:950}
@media(max-width:980px){
  .sector-number-legend{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:560px){
  .sector-rotation-card{padding:16px 12px 14px;border-radius:16px}
  .sector-rotation-legend{justify-content:flex-start;font-size:11px;gap:12px}
  .sector-number-legend{grid-template-columns:1fr;font-size:10.5px}
}


body.mp-master{
  background:
    radial-gradient(ellipse 70% 30% at 50% -8%,rgba(120,255,160,.07),transparent 64%),
    #000}
body.mp-master .hl-hero{
  padding:128px 0 76px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,0) 58%),
    radial-gradient(ellipse 70% 50% at 50% 0%,rgba(215,189,104,.045),transparent 68%),
    #000}
body.mp-master .hl-hero-inner{max-width:1120px}
body.mp-master .hl-hero-kicker{
  color:#fff;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:950;
  margin-bottom:14px}
body.mp-master .hl-hero-title{
  margin:0;
  color:#fff;
  font-size:clamp(3.2rem,8vw,7.2rem);
  line-height:.92;
  letter-spacing:-.075em;
  font-weight:950}
body.mp-master .hl-hero-title span{color:#d7bd68}
body.mp-master .hl-hero-lead{
  max-width:820px;
  margin:24px 0 0;
  color:rgba(255,255,255,.72);
  font-size:clamp(15px,1.35vw,19px);
  line-height:1.78;
  font-weight:650}
body.mp-master .hl-hero-rhythm{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  margin-top:34px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  max-width:940px}
body.mp-master .hl-hero-rhythm div{
  padding:18px 20px;
  background:rgba(0,0,0,.72)}
body.mp-master .hl-hero-rhythm strong{
  display:block;
  color:#fff;
  font-size:13px;
  letter-spacing:.08em;
  font-weight:950}
body.mp-master .hl-hero-rhythm span{
  display:block;
  margin-top:5px;
  color:rgba(215,189,104,.70);
  font-size:13px;
  font-weight:750}
body.mp-master #master{padding-top:66px}
body.mp-master .hl-intro-note{
  margin:0 0 22px;
  padding:0;
  background:transparent;
  border:0;
  color:rgba(255,255,255,.70)}
body.mp-master .hl-intro-note strong,
body.mp-master .dkc-chart-note strong,
body.mp-master .sector-delay-line strong,
body.mp-master .sector-read-line strong{
  color:#fff;
  font-weight:950}


body.mp-master .section-label,
body.mp-master .master-kicker{
  color:#fff;
  font-size:12px;
  letter-spacing:.13em;
  text-transform:uppercase;
  font-weight:950;
  margin-top:34px;
  margin-bottom:14px}
body.mp-master .section-label:first-child{margin-top:0}
body.mp-master .master-kicker{
  margin-top:0;
  margin-bottom:10px}
body.mp-master .section-label::before,
body.mp-master .master-kicker::before{
  content:"";
  display:inline-block;
  width:18px;
  height:2px;
  margin-right:9px;
  border-radius:999px;
  background:rgba(145,255,170,.74);
  vertical-align:middle}


body.mp-master .master-visual,
body.mp-master #dkc-chart-section,
body.mp-master .strategy-master-card,
body.mp-master .sector-rotation-card{
  margin-top:20px;
  margin-bottom:34px}
body.mp-master .htu-wrap,
body.mp-master .heatmap-wrap,
body.mp-master .dkc-table-wrap{
  margin-top:14px;
  margin-bottom:34px}
body.mp-master .strategy-notes{
  margin-top:30px;
  margin-bottom:42px;
  gap:22px}
body.mp-master .strategy-note-block{
  padding-bottom:24px}
body.mp-master .hl-chart-area{margin-top:38px;margin-bottom:42px}


body.mp-master .section-label-sector{margin-top:48px}
body.mp-master .sector-delay-line,
body.mp-master .sector-read-line{
  margin:0 0 10px;
  padding:0;
  background:transparent;
  border:0;
  border-radius:0;
  color:rgba(255,255,255,.76);
  font-size:12px;
  line-height:1.7;
  font-weight:650}
body.mp-master .sector-delay-line{
  font-size:18px;
  color:rgba(255,255,255,.84)}
body.mp-master .sector-delay-line strong{
  color:#a9ffbb;
  margin-right:5px}
body.mp-master .sector-delay-line b{
  color:#fff;
  font-weight:950;
  padding:0 2px}
body.mp-master .sector-read-line strong{
  color:#a9ffbb;
  margin-right:3px}


body.mp-master .sector-rotation-card{
  padding:26px 26px 20px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
  box-shadow:none}
body.mp-master .sector-rotation-canvas{
  min-height:360px;
  background:#040404}
body.mp-master .sector-rotation-legend .line-finance{
  background:#b6c2a3;
  box-shadow:0 0 12px rgba(215,189,104,.28)}
body.mp-master .sector-rotation-legend .line-economy{
  background:#b89450;
  box-shadow:0 0 9px rgba(184,148,80,.24)}
  margin-top:8px;
body.mp-master .sector-number-legend{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:3px 1px;
  color:rgba(255,255,255,.76)}
  margin-top:8px;
@media(max-width:920px){
  body.mp-master .hl-hero{padding:104px 0 58px}
  body.mp-master .hl-hero-rhythm{grid-template-columns:1fr}
  body.mp-master .sector-rotation-canvas{min-height:360px}
  body.mp-master .sector-number-legend{grid-template-columns:1fr}
}
@media(max-width:560px){
  body.mp-master .hl-hero-title{font-size:clamp(2.7rem,17vw,4.2rem)}
  body.mp-master .hl-hero-rhythm div{padding:15px 16px}
  body.mp-master .sector-rotation-card{padding:18px 13px 16px}
}


body.mp-master .hl-hero{
  padding:118px 0 64px;
  min-height:auto;
  border-bottom:1px solid rgba(255,255,255,.07);
  background:
    radial-gradient(ellipse 64% 42% at 50% 0%,rgba(129,196,145,.10),transparent 66%),
    linear-gradient(180deg,rgba(255,255,255,.02),rgba(0,0,0,0) 60%),
    #000}
body.mp-master .hl-hero-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center}
body.mp-master .hl-hero-title{
  margin:0;
  color:#fff;
  font-size:clamp(3.2rem,8vw,6.4rem);
  line-height:.96;
  letter-spacing:-.07em}
body.mp-master .hl-hero-title span,
body.mp-master .hl-hero-kicker,
body.mp-master .hl-hero-lead,
body.mp-master .hl-hero-rhythm{
  display:none}
body.mp-master #master{
  padding-top:72px}
body.mp-master #master > .container > .section-label{
  margin-top:58px;
  padding-top:34px;
  border-top:1px solid rgba(255,255,255,.07)}
body.mp-master #master > .container > .section-label:first-child{
  margin-top:0;
  padding-top:0;
  border-top:0}
body.mp-master .master-visual,
body.mp-master #dkc-chart-section,
body.mp-master .strategy-master-card,
body.mp-master .sector-rotation-card,
body.mp-master .htu-wrap,
body.mp-master .heatmap-wrap,
body.mp-master .dkc-table-wrap{
  background:linear-gradient(180deg,rgba(255,255,255,.032),rgba(255,255,255,.010));
  border-color:rgba(255,255,255,.085);
  border-radius:22px;
  box-shadow:none}
body.mp-master .master-visual,
body.mp-master #dkc-chart-section,
body.mp-master .sector-rotation-card{
  padding:22px}
body.mp-master .syc-card,
body.mp-master .deep-card,
body.mp-master .strategy-note-block{
  background:linear-gradient(180deg,rgba(255,255,255,.026),rgba(255,255,255,.008));
  border-color:rgba(255,255,255,.075)}
body.mp-master .section-label::before,
body.mp-master .master-kicker::before{
  background:rgba(214,187,107,.72)}
@media(max-width:560px){
  body.mp-master .hl-hero{padding:104px 0 48px}
  body.mp-master .hl-hero-title{font-size:clamp(2.8rem,18vw,4.4rem)}
  body.mp-master .master-visual,
  body.mp-master #dkc-chart-section,
  body.mp-master .sector-rotation-card{padding:14px;border-radius:18px}
}


/* === Chiến Lược page clean source of truth === */
body.mp-master .master-visual,
body.mp-master #dkc-chart-section,
body.mp-master .chart-section,
body.mp-master .master-chart-card,
body.mp-master .cycle-chart-card,
body.mp-master .chart-card,
body.mp-master .chart-panel,
body.mp-master .master-chart-wrap,
body.mp-master .cycle-chart-wrap,
body.mp-master .chart-wrap,
body.mp-master .chart-shell,
body.mp-master .chart-canvas-wrap{
  background:#050505;
  border-color:rgba(255,255,255,.075);
  box-shadow:none;
}

body.mp-master .master-chart-svg,
body.mp-master canvas#dkc-chart,
body.mp-master canvas#strategyChart,
body.mp-master canvas#cycleChart{
  background:#050505;
  border-radius:16px;
}
.dkc-ai-nav{color:#fff}
.dkc-footer-unified,
.footer-wrap,
.mp-site-footer{
  padding:44px 22px 26px;
  background:#020202;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.64);
  font-size:12px;
}
.dkc-footer-inner{
  width:min(1120px,100%);
  margin:0 auto;
}
.dkc-footer-brand{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:24px;
  align-items:start;
}
.dkc-footer-logo{
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
  font-weight:950;
}
.dkc-logo-footer{width:34px;height:34px;object-fit:contain;border-radius:9px}
.dkc-footer-brand p{max-width:620px;margin:10px 0 0;color:rgba(255,255,255,.58);line-height:1.7}
.dkc-footer-contact{text-align:right;color:rgba(255,255,255,.68);line-height:1.7}
.dkc-footer-contact span{display:block;color:#fff;font-weight:900}
.dkc-footer-cols{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  margin-top:26px;
}
.dkc-footer-col-title{margin-bottom:10px;color:#fff;font-size:12px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}
.dkc-footer-col a{display:block;margin:6px 0;color:rgba(255,255,255,.70)}
.dkc-footer-col a:hover{color:#fff}
.dkc-footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:18px;
  margin-top:26px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.46);
}
.bc-filter-bar{
  justify-content:center;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
@media(max-width:980px){
  .dkc-footer-brand{grid-template-columns:1fr}
  .dkc-footer-contact{text-align:left}
  .dkc-footer-bottom{display:block}
  .dkc-footer-bottom span{display:block;margin-top:8px}
  .bc-filter-bar{justify-content:center}
}


/* DKC focused cleanup local footer override */
.dkc-footer-contact{display:none}
.dkc-footer-bottom{justify-content:center;text-align:center}
.dkc-footer-bottom span{width:100%;display:block;margin:0}


.dkc-footer-col a.dkc-ai-footer{color:rgba(242,217,130,.96);font-weight:850}

/* Strategy polish: calmer weights for dense investment tables */
body.mp-master .htu-th{font-weight:720}
body.mp-master .htu-year-link{font-weight:780}
body.mp-master .htu-phase-badge,
body.mp-master .htu-conv{font-weight:660}
body.mp-master .htu-main{font-weight:620}
body.mp-master .htu-note{font-weight:430}
body.mp-master .heatmap-table .hm-year{font-weight:720}
body.mp-master .heatmap-table .hm-plain{font-weight:620}
body.mp-master .heatmap-table .hm-focus{display:block;color:rgba(255,255,255,.88);font-weight:680;line-height:1.45}
body.mp-master .heatmap-table .hm-benefit{display:block;color:rgba(214,224,216,.72);font-size:12px;line-height:1.5}
body.mp-master .heatmap-table th{
  padding:11px 13px;
  font-size:11px}
body.mp-master .heatmap-table td{
  padding:11px 13px;
  font-size:12.5px;
  line-height:1.4;
  vertical-align:middle}
body.mp-master .heatmap-table .hm-focus{
  line-height:1.35}
body.mp-master .heatmap-table .hm-benefit{
  font-size:11.5px;
  line-height:1.35}
body.mp-master .heatmap-table .hm-plain{
  line-height:1.35}
.asset-class-key{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  margin:14px 0 8px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  background:rgba(255,255,255,.08)}
.asset-class-key span{
  display:flex;
  gap:8px;
  padding:10px 12px;
  background:#080808;
  color:rgba(255,255,255,.62);
  font-size:11px;
  line-height:1.35}
.asset-class-key strong{
  flex:0 0 auto;
  color:rgba(255,255,255,.88)}
@media(max-width:720px){
  .asset-class-key{grid-template-columns:1fr}
  .asset-class-key span{display:block}
  .asset-class-key strong{display:block;margin-bottom:3px}}
body.mp-master .strategy-note-grid span,
body.mp-master .strategy-note-grid strong{font-weight:680}
body.mp-master .sector-number-legend{font-weight:560}
body.mp-master .sector-number-legend b{font-weight:720}

/* Keep the sector key visually attached to the chart. */
body.mp-master .sector-rotation-card{
  padding-bottom:14px}
body.mp-master .sector-rotation-canvas{
  min-height:0;
  height:520px}
body.mp-master .sector-number-legend{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:6px 18px;
  margin-top:4px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:10.5px;
  line-height:1.25}
body.mp-master .sector-number-legend span{
  overflow:hidden;
  text-overflow:ellipsis}
@media(max-width:920px){
  body.mp-master .sector-rotation-canvas{height:410px}
  body.mp-master .sector-number-legend{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px 12px}}
@media(max-width:560px){
  body.mp-master .sector-number-legend{
    display:flex;
    overflow-x:auto;
    margin-top:2px;
    padding-top:8px;
    gap:6px}
  body.mp-master .sector-number-legend span{
    flex:0 0 auto;
    overflow:visible}}
body.mp-master .cycle-brief-grid strong{font-weight:720}
.dkc-footer-col a.dkc-ai-footer:hover{color:#fff}

body.mp-master .dkc-chart-note{
  font-size:11.5px;
  line-height:1.55;
}

.sector-by-year{
  margin-top:34px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.09);
}
.strategy-asset-label{margin-top:34px}
.strategy-asset-intro{
  margin:8px 0 14px;
  color:rgba(255,255,255,.58);
  font-size:13px;
  line-height:1.6;
}
.strategy-asset-year-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  gap:6px;
  margin:0 0 14px;
  padding:11px 12px;
  border-radius:8px;
  overflow-x:auto;
  scrollbar-width:none;
}
.strategy-asset-year-nav::-webkit-scrollbar{display:none}
.strategy-asset-year-btn{
  flex:0 0 auto;
  min-width:48px;
  min-height:32px;
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:7px;
  color:rgba(255,255,255,.58);
  background:#0a0a0a;
  font:750 11px/1 "Be Vietnam Pro",sans-serif;
  cursor:pointer;
  transition:color .18s ease,border-color .18s ease,background .18s ease,transform .18s ease;
}
.strategy-asset-year-btn:hover,
.strategy-asset-year-btn:focus-visible{
  color:#f0d474;
  border-color:rgba(240,212,116,.28);
}
.strategy-asset-year-btn.is-active{
  color:#080808;
  border-color:#e3c766;
  background:#e3c766;
}
.strategy-asset-table .asset-row[hidden]{display:none !important}
.strategy-asset-table .asset-row.is-flashing{animation:assetRowFlash .9s ease}
@keyframes assetRowFlash{
  0%,100%{box-shadow:none}
  35%{box-shadow:inset 0 0 0 1px rgba(227,199,102,.55),0 0 24px rgba(227,199,102,.08)}
}
.strategy-asset-table{table-layout:fixed}
.strategy-asset-table th:first-child{width:6%}
.strategy-asset-table th:nth-child(2),
.strategy-asset-table th:nth-child(3),
.strategy-asset-table th:nth-child(4){width:31.333%}
.strategy-asset-table td{vertical-align:top}
.strategy-asset-table td:nth-child(2){color:rgba(255,255,255,.78)}
.asset-issues{
  margin:0;
  padding-left:16px;
}
.asset-issues li{
  margin:0 0 5px;
  line-height:1.45;
}
.asset-issues li:last-child{margin-bottom:0}
.asset-points{
  margin:0;
  padding-left:16px;
  font-size:13px;
  font-weight:500;
}
.asset-points li{
  margin:0 0 5px;
  line-height:1.45;
}
.asset-points li:last-child{margin-bottom:0}
.asset-points.hm-buy{color:#86ffb2}
.asset-points.hm-hold{color:#9fdcff}
.asset-points.hm-dist{color:#ffd978}
.asset-points.hm-exit{color:#ff9d9d}
.strategy-asset-table .asset-points{
  display:block;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  padding:0 0 0 16px !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .strategy-asset-year-nav{
    justify-content:flex-start;
    margin-right:-14px;
    padding-right:14px;
  }
  body.mp-master .strategy-asset-table{
    display:block;
    min-width:0;
    border:0;
  }
  body.mp-master .strategy-asset-table thead{display:none}
  body.mp-master .strategy-asset-table tbody{display:block}
  body.mp-master .strategy-asset-table tr{
    display:grid;
    grid-template-columns:58px minmax(0,1fr);
    margin-bottom:12px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.09);
    border-radius:8px;
    background:#080808;
  }
  body.mp-master .strategy-asset-table td{
    display:block;
    width:auto;
    padding:12px 14px;
    border-bottom:1px solid rgba(255,255,255,.07);
    background:transparent;
  }
  body.mp-master .strategy-asset-table td:first-child{
    grid-column:1;
    grid-row:1 / span 3;
    display:flex;
    align-items:flex-start;
    justify-content:center;
    padding:15px 8px;
    border-right:1px solid rgba(255,255,255,.08);
    border-bottom:0;
    color:#e2c45f;
  }
  body.mp-master .strategy-asset-table td:nth-child(n+2){grid-column:2}
  body.mp-master .strategy-asset-table td:last-child{border-bottom:0}
  body.mp-master .strategy-asset-table td:nth-child(n+2)::before{
    display:block;
    margin-bottom:7px;
    color:rgba(255,255,255,.44);
    font-size:10px;
    line-height:1.3;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-weight:650;
  }
  body.mp-master .strategy-asset-table td:nth-child(2)::before{content:'Vấn đề nổi trội'}
  body.mp-master .strategy-asset-table td:nth-child(3)::before{content:'Đáng chú ý'}
  body.mp-master .strategy-asset-table td:nth-child(4)::before{content:'Chịu áp lực'}
  body.mp-master .strategy-asset-table .asset-issues,
  body.mp-master .strategy-asset-table .asset-points{font-size:12.5px}
}
.sector-year[hidden]{display:none !important}
.sector-year.is-active summary{cursor:default;pointer-events:none}
.sector-year.is-active summary::after{display:none !important}
.sector-by-year-intro{
  margin:8px 0 18px;
  color:#9b9b9b;
  font-size:14px;
  line-height:1.65;
}
.sector-year-list{
  border-top:1px solid rgba(255,255,255,.11);
}
.sector-year{
  border-bottom:1px solid rgba(255,255,255,.1);
}
.sector-year summary{
  display:grid;
  grid-template-columns:62px minmax(0,1fr);
  gap:14px;
  align-items:center;
  min-height:62px;
  padding:10px 38px 10px 4px;
  position:relative;
  cursor:pointer;
  list-style:none;
}
.sector-year summary::-webkit-details-marker{display:none}
.sector-year summary::after{
  content:'+';
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  color:#d2b04c;
  font-size:22px;
  font-weight:400;
}
.sector-year[open] summary::after{content:'−'}
.sector-year summary span{
  color:#e5c45d;
  font-weight:850;
  font-size:15px;
}
.sector-year summary strong{
  color:#f2f2f2;
  font-size:15px;
  letter-spacing:0;
}
.sector-year-body{
  padding:0 38px 18px 80px;
  max-width:980px;
}
.sector-year-body p{
  margin:0 0 8px;
  color:#b9b9b9;
  font-size:14px;
  line-height:1.62;
}
.sector-year-body p:last-child{margin-bottom:0}
.sector-year-body b{color:#e8e8e8}
.sector-year summary:hover strong{color:#fff}
@media(max-width:640px){
  .sector-year summary{grid-template-columns:52px minmax(0,1fr);gap:8px;padding-right:32px}
  .sector-year-body{padding:0 12px 16px 60px}
}

/* Strategy typography: one consistent hierarchy across map, chart and tables. */
body.mp-master .hl-hero-title{
  font-size:72px;
  line-height:1;
  letter-spacing:0;
  font-weight:750;
}
body.mp-master .section-label,
body.mp-master .master-kicker{
  font-size:11px;
  line-height:1.4;
  letter-spacing:.08em;
  font-weight:700;
}
body.mp-master .hl-intro-note,
body.mp-master .dkc_inline_hop_luu_002,
body.mp-master .sector-by-year-intro{
  font-size:14px;
  line-height:1.65;
  font-weight:400;
}
body.mp-master .hl-intro-note strong,
body.mp-master .dkc-chart-note strong,
body.mp-master .sector-delay-line strong{
  font-weight:650;
}
body.mp-master .strategy-cycle-year span{
  font-size:13px;
  line-height:1.3;
  letter-spacing:0;
  font-weight:700;
}
body.mp-master .strategy-cycle-year strong{
  font-size:13px;
  line-height:1.45;
  letter-spacing:0;
  font-weight:600;
}
body.mp-master .strategy-cycle-year small{
  font-size:11px;
  line-height:1.5;
  font-weight:400;
}
body.mp-master #dkc-chart-section h3{
  font-size:16px;
  line-height:1.4;
  letter-spacing:0;
  font-weight:700;
}
body.mp-master .dkc-chart-tab{
  font-size:12px;
  font-weight:600;
}
body.mp-master .dkc-chart-readout strong,
body.mp-master .dkc-chart-readout span,
body.mp-master .dkc-chart-note{
  font-size:12px;
  line-height:1.6;
}
body.mp-master .dkc-chart-readout strong{font-weight:650}
body.mp-master .asset-class-key strong{
  font-size:12px;
  letter-spacing:0;
  font-weight:650;
}
body.mp-master .asset-class-key span{
  font-size:12px;
  line-height:1.5;
  font-weight:400;
}
body.mp-master .heatmap-table th{
  font-size:11px;
  line-height:1.35;
  letter-spacing:.04em;
  font-weight:650;
}
body.mp-master .heatmap-table td,
body.mp-master .heatmap-table .hm-plain{
  font-size:13px;
  line-height:1.45;
  font-weight:500;
}
body.mp-master .heatmap-table .hm-year{font-weight:700}
body.mp-master .sector-year summary span{
  font-size:13px;
  letter-spacing:0;
  font-weight:700;
}
body.mp-master .sector-year summary strong{
  font-size:14px;
  line-height:1.45;
  letter-spacing:0;
  font-weight:600;
}
body.mp-master .sector-year-body p{
  font-size:13px;
  line-height:1.65;
  font-weight:400;
}
body.mp-master .sector-year-body b{font-weight:650}
body.mp-master .sector-delay-line{
  margin-top:24px;
  font-size:13px;
  line-height:1.65;
  font-weight:400;
}
@media(max-width:720px){
  body.mp-master .hl-hero-title{font-size:46px}
  body.mp-master .strategy-cycle-year strong{font-size:13px}
}
body.mp-master .dkc-compare-key{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 18px;
}
body.mp-master .dkc-compare-key i{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:rgba(255,255,255,.78);
  font-size:11.5px;
  font-style:normal;
  font-weight:620;
}
body.mp-master .dkc-compare-key i::before{
  content:"";
  width:24px;
  height:3px;
  border-radius:999px;
  background:currentColor;
}
body.mp-master .dkc-compare-key .is-opportunity{color:#78b987}
body.mp-master .dkc-compare-key .is-risk{color:#c8615b}
body.mp-master .dkc-compare-key .is-growth{color:#82a9c2}


/* Generated from inline styles in chien-luoc.html. Keeps original visual output while removing style attributes. */
.dkc_inline_hop_luu_001{margin-bottom:12px;margin-top:32px;}
.dkc_inline_hop_luu_002{font-size:13px;color:var(--muted);margin-bottom:16px;}
.dkc_inline_hop_luu_003{color:#f87171;}
.dkc_inline_hop_luu_004{color:#f59e0b;border-color:#f59e0b40;background:#f59e0b10;}
.dkc_inline_hop_luu_005{color:#7dd3fc;}
.dkc_inline_hop_luu_006{color:#7dd3fc;border-color:#7dd3fc40;background:#7dd3fc10;}
.dkc_inline_hop_luu_007{color:#c4b5fd;}
.dkc_inline_hop_luu_008{color:#c4b5fd;border-color:#c4b5fd40;background:#c4b5fd10;}
.dkc_inline_hop_luu_009{color:#4ade80;}
.dkc_inline_hop_luu_010{color:#4ade80;border-color:#4ade8040;background:#4ade8010;}
.dkc_inline_hop_luu_011{color:#fb923c;}
.dkc_inline_hop_luu_012{color:#fb923c;border-color:#fb923c40;background:#fb923c10;}
.dkc_inline_hop_luu_013{color:#fbbf24;}
.dkc_inline_hop_luu_014{color:#fbbf24;border-color:#fbbf2440;background:#fbbf2410;}
.dkc_inline_hop_luu_015{color:#ef4444;border-color:#ef444440;background:#ef444410;}

/* Annual convergence: conclusion-only timeline. */
body.mp-master .strategy-convergence-timeline{
  position:relative;
  margin:20px 0 34px;
  padding:4px 0 10px;
  overflow-x:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(215,178,78,.42) transparent;
  overscroll-behavior-inline:contain;
}
body.mp-master .strategy-convergence-track{
  position:relative;
  display:grid;
  grid-template-columns:repeat(10,minmax(174px,1fr));
  min-width:1740px;
  padding:0 8px;
}
body.mp-master .strategy-convergence-track::before{
  content:"";
  position:absolute;
  top:42px;
  left:70px;
  right:70px;
  height:1px;
  background:linear-gradient(90deg,rgba(215,178,78,.12),rgba(215,178,78,.52),rgba(215,178,78,.12));
}
body.mp-master .strategy-convergence-item{
  position:relative;
  display:grid;
  grid-template-rows:26px 32px auto auto;
  justify-items:center;
  min-width:0;
  padding:0 12px;
  text-align:center;
}
body.mp-master .strategy-convergence-year{
  color:rgba(255,255,255,.56);
  font-size:12px;
  font-weight:650;
  letter-spacing:.04em;
}
body.mp-master .strategy-convergence-item i{
  position:relative;
  z-index:1;
  width:9px;
  height:9px;
  margin-top:12px;
  border:1px solid rgba(215,178,78,.5);
  border-radius:50%;
  background:#090909;
  box-shadow:0 0 0 5px #090909;
}
body.mp-master .strategy-convergence-item strong{
  max-width:166px;
  color:rgba(255,255,255,.78);
  font-size:12.5px;
  font-weight:650;
  line-height:1.4;
}
body.mp-master .strategy-convergence-item small{
  max-width:168px;
  margin-top:6px;
  color:rgba(255,255,255,.46);
  font-size:10.5px;
  font-weight:470;
  line-height:1.45;
}
body.mp-master .strategy-convergence-item.is-current .strategy-convergence-year,
body.mp-master .strategy-convergence-item.is-current strong{
  color:#e1c465;
}
body.mp-master .strategy-convergence-item.is-current i{
  border-color:#e1c465;
  background:#e1c465;
  box-shadow:0 0 0 5px #090909,0 0 16px rgba(225,196,101,.35);
}
@media(max-width:720px){
  body.mp-master .strategy-convergence-timeline{
    margin-top:16px;
    margin-right:-16px;
    padding-right:16px;
  }
  body.mp-master .strategy-convergence-track{
    grid-template-columns:repeat(10,174px);
    min-width:1740px;
    padding-left:0;
  }
}

/* Compact 2026–2035 cycle map: one-screen replacement for the long timeline. */
body.mp-master .strategy-cycle-map{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:1px;
  margin:18px 0 34px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  background:rgba(255,255,255,.08);
}
body.mp-master .strategy-cycle-year{
  position:relative;
  min-height:126px;
  padding:18px 16px 16px;
  background:linear-gradient(180deg,#0b0b0b,#080808);
}
body.mp-master .strategy-cycle-year::before{
  content:"";
  position:absolute;
  top:0;
  left:16px;
  width:24px;
  height:1px;
  background:rgba(215,178,78,.45);
}
body.mp-master .strategy-cycle-year span{
  display:block;
  margin-bottom:11px;
  color:#d7b24e;
  font-size:13px;
  font-weight:760;
  letter-spacing:.05em;
}
body.mp-master .strategy-cycle-year strong{
  display:block;
  color:rgba(255,255,255,.88);
  font-size:12.5px;
  font-weight:650;
  line-height:1.42;
}
body.mp-master .strategy-cycle-year small{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.48);
  font-size:10.5px;
  font-weight:470;
  line-height:1.45;
}
body.mp-master .strategy-cycle-year.is-current{
  background:linear-gradient(180deg,rgba(215,178,78,.09),#090909 52%);
}
body.mp-master .strategy-cycle-year.is-current::before{
  width:42px;
  background:#e1c465;
  box-shadow:0 0 12px rgba(225,196,101,.25);
}
@media(max-width:900px){
  body.mp-master .strategy-cycle-map{grid-template-columns:repeat(2,minmax(0,1fr))}
  body.mp-master .strategy-cycle-year{min-height:112px}
}
@media(max-width:520px){
  body.mp-master .strategy-cycle-map{grid-template-columns:1fr}
  body.mp-master .strategy-cycle-year{min-height:0;padding:15px 16px}
  body.mp-master .strategy-cycle-year span{margin-bottom:6px}
  body.mp-master .strategy-cycle-year small{margin-top:5px}
}

/* Keep the annual map on the same typography scale as the rest of the page. */
body.mp-master .strategy-cycle-year span{
  font-size:13px;
  line-height:1.3;
  letter-spacing:0;
  font-weight:700;
}
body.mp-master .strategy-cycle-year strong{
  font-size:13px;
  line-height:1.45;
  letter-spacing:0;
  font-weight:600;
}
body.mp-master .strategy-cycle-year small{
  font-size:11px;
  line-height:1.5;
  font-weight:400;
}
