.cw-articles-seo-app,
.cw-articles-seo-app *,
.cw-articles-seo-app *::before,
.cw-articles-seo-app *::after{
  box-sizing:border-box;
}

.cw-articles-seo-app{
  --cw-article-bg:#f3eee7;
  --cw-article-card:#fffaf3;
  --cw-article-card-2:#f8f2e9;
  --cw-article-border:#d8c7b4;
  --cw-article-text:#2f1b0e;
  --cw-article-muted:#6f5947;
  --cw-article-brown:#7b4a25;
  --cw-article-brown-2:#5f3519;
  --cw-article-gold:#d9b277;
  --cw-article-gold-2:#f6e7cd;
  --cw-article-shadow:0 14px 30px rgba(64,36,18,.16);
  width:min(100%,1080px);
  margin:0 auto;
  padding:22px;
  color:var(--cw-article-text);
  font-family:Georgia,"Times New Roman",serif;
  line-height:1.72;
}

.cw-articles-seo-app button,
.cw-articles-seo-app input,
.cw-articles-seo-app textarea,
.cw-articles-seo-app select{
  font-family:Georgia,"Times New Roman",serif;
}

.cw-articles-seo-shell{
  background:linear-gradient(180deg,#fbf7f0 0%,#f0e7dc 100%);
  border:1px solid var(--cw-article-border);
  border-radius:28px;
  box-shadow:0 18px 44px rgba(71,43,20,.14);
  overflow:hidden;
}

.cw-articles-seo-header{
  padding:0;
  background:linear-gradient(180deg,#f7f0e6 0%,#efe4d6 100%);
}

.cw-articles-seo-header-card{
  margin:0 auto;
  padding:18px 18px 20px;
  border-radius:27px;
  background:linear-gradient(180deg,rgba(255,252,246,.82) 0%,rgba(246,238,228,.86) 100%);
}

.cw-articles-seo-nav{
  display:grid;
  grid-template-columns:repeat(9,minmax(0,1fr));
  gap:6px;
  align-items:center;
  margin-bottom:14px;
}

.cw-articles-seo-nav-pill,
.cw-articles-seo-tool-button,
.cw-articles-seo-lang-link{
  color:#332012;
  text-decoration:none;
  border:1px solid rgba(131,82,38,.25);
  background:
    radial-gradient(circle at 30% 18%,rgba(255,255,255,.58) 0,rgba(255,255,255,0) 36%),
    linear-gradient(180deg,#fff2dc 0%,#e4c393 52%,#cda66c 100%);
  box-shadow:0 4px 10px rgba(117,73,33,.18),inset 0 1px 0 rgba(255,255,255,.72);
  transition:transform .16s ease,box-shadow .16s ease,filter .16s ease,border-color .16s ease;
}

.cw-articles-seo-nav-pill{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 8px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  line-height:1.1;
  text-align:center;
  cursor:pointer;
}

.cw-articles-seo-nav-share{
  width:100%;
}

.cw-articles-seo-nav-pill:hover,
.cw-articles-seo-tool-button:hover,
.cw-articles-seo-lang-link:hover{
  transform:translateY(-1px);
  filter:saturate(1.03);
  box-shadow:0 7px 14px rgba(117,73,33,.22),inset 0 1px 0 rgba(255,255,255,.76);
}

.cw-articles-seo-share-icon{
  width:18px;
  height:18px;
  display:block;
  fill:none;
  stroke:currentColor;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.cw-articles-seo-brand-banner{
  width:min(780px,calc(100% - 160px));
  min-height:130px;
  margin:0 auto 18px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:16px 22px 20px;
  border-radius:19px;
  border:1px solid rgba(80,45,21,.42);
  background:
    radial-gradient(circle at 34% 10%,rgba(255,235,199,.42) 0,rgba(255,235,199,0) 42%),
    linear-gradient(180deg,#d6ac7a 0%,#a56a3a 49%,#744522 100%);
  box-shadow:0 12px 25px rgba(64,38,20,.30),inset 0 1px 0 rgba(255,255,255,.45),inset 0 -2px 0 rgba(48,25,11,.24);
  text-align:center;
}

.cw-articles-seo-brand-link{
  color:#130b06;
  text-decoration:none;
  font-weight:800;
  font-size:clamp(34px,5.1vw,54px);
  line-height:1;
  letter-spacing:.2px;
  text-shadow:0 1px 0 rgba(255,255,255,.18);
}

.cw-articles-seo-brand-subtitle{
  margin-top:8px;
  color:#150b05;
  font-size:clamp(24px,3.1vw,36px);
  font-weight:800;
  line-height:1.05;
}

.cw-articles-seo-header-bottom{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:16px;
  padding:0 1px;
}

.cw-articles-seo-description{
  margin:0 0 0 76px;
  color:#1b0f07;
  font-size:19px;
  line-height:1.45;
}

.cw-articles-seo-tools{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  min-width:0;
}

.cw-articles-seo-tool-button{
  width:50px;
  min-width:50px;
  height:50px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:16px;
  cursor:pointer;
  background:linear-gradient(180deg,#fffdf8 0%,#fbf1e2 100%);
}

.cw-articles-seo-language-switcher{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px;
  border-radius:999px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(216,199,180,.9);
  box-shadow:0 5px 14px rgba(88,54,27,.10);
}

.cw-articles-seo-lang-link{
  min-height:28px;
  min-width:50px;
  padding:5px 8px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  font-size:10px;
  font-weight:800;
  line-height:1;
  background:transparent;
  box-shadow:none;
}

.cw-articles-seo-lang-link.is-active{
  border-color:#c29b75;
  background:linear-gradient(180deg,#f5e5cf 0%,#e6c9a5 100%);
  color:#6a3819;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62);
}

.cw-articles-seo-menu-panel{
  margin-top:12px;
  display:block;
}

.cw-articles-seo-menu-panel[hidden]{
  display:none;
}

.cw-articles-seo-menu-panel-inner{
  margin-left:auto;
  width:min(330px,100%);
  padding:14px;
  border:1px solid var(--cw-article-border);
  border-radius:18px;
  background:rgba(255,251,244,.94);
  box-shadow:0 12px 24px rgba(72,45,23,.14);
}

.cw-articles-seo-menu-panel-inner strong{
  display:block;
  margin-bottom:9px;
  color:var(--cw-article-brown-2);
}

.cw-articles-seo-menu-links{
  display:grid;
  gap:7px;
}

.cw-articles-seo-menu-links a{
  color:#4a2b17;
  text-decoration:none;
  border:1px solid rgba(216,199,180,.9);
  border-radius:12px;
  background:#fffaf3;
  padding:8px 10px;
  font-weight:700;
}

.cw-articles-seo-body{
  padding:18px;
  background:linear-gradient(180deg,#fbf8f3 0%,#f1e8dc 100%);
}

.cw-articles-seo-content{
  display:grid;
  gap:18px;
}

.cw-articles-seo-hero-card,
.cw-articles-seo-section,
.cw-articles-seo-faq,
.cw-articles-seo-footer{
  border:1px solid var(--cw-article-border);
  border-radius:22px;
  background:rgba(255,253,249,.72);
  box-shadow:0 5px 18px rgba(103,77,48,.08);
}

.cw-articles-seo-hero-card{
  padding:28px;
}

.cw-articles-seo-kicker{
  display:inline-flex;
  margin-bottom:14px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid #b8cfbd;
  background:#e2eee5;
  color:#185d40;
  font-weight:800;
  font-size:14px;
}

.cw-articles-seo-title{
  margin:0 0 12px;
  color:var(--cw-article-brown-2);
  font-size:clamp(31px,4.8vw,48px);
  line-height:1.08;
}

.cw-articles-seo-lead{
  margin:0;
  max-width:850px;
  color:var(--cw-article-muted);
  font-size:19px;
  line-height:1.72;
}

.cw-articles-seo-section{
  overflow:hidden;
}

.cw-articles-seo-section h2,
.cw-articles-seo-faq h2{
  margin:0;
  padding:18px 22px;
  border-bottom:1px solid var(--cw-article-border);
  background:linear-gradient(180deg,rgba(255,255,255,.68) 0%,rgba(245,236,225,.66) 100%);
  color:var(--cw-article-brown-2);
  font-size:28px;
  line-height:1.2;
}

.cw-articles-seo-section-body,
.cw-articles-seo-faq-body{
  padding:20px 22px;
  color:var(--cw-article-muted);
  font-size:17px;
}

.cw-articles-seo-section-body p,
.cw-articles-seo-faq-body p{
  margin:0 0 12px;
}

.cw-articles-seo-section-body p:last-child,
.cw-articles-seo-faq-body p:last-child{
  margin-bottom:0;
}

.cw-articles-seo-section-body ul{
  margin:0 0 14px;
  padding-left:24px;
}

.cw-articles-seo-section-body li{
  margin-bottom:7px;
}

.cw-articles-seo-section-body a,
.cw-articles-seo-faq-body a{
  color:#7a4b1b;
  text-underline-offset:3px;
}

.cw-articles-seo-note{
  margin-top:14px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--cw-article-border);
  background:#f6efe5;
  color:#715d4c;
}

.cw-articles-seo-footer{
  margin-top:18px;
  padding:14px;
  text-align:center;
  color:#7b6755;
  font-size:14px;
}

.cw-articles-seo-visually-hidden{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}

.cw-articles-seo-app.is-font-large .cw-articles-seo-section-body,
.cw-articles-seo-app.is-font-large .cw-articles-seo-faq-body,
.cw-articles-seo-app.is-font-large .cw-articles-seo-lead{
  font-size:1.08em;
}

@media (max-width:920px){
  .cw-articles-seo-nav{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }

  .cw-articles-seo-brand-banner{
    width:100%;
  }

  .cw-articles-seo-description{
    margin-left:0;
  }
}

@media (max-width:680px){
  .cw-articles-seo-app{
    padding:8px;
  }

  .cw-articles-seo-shell{
    border-radius:22px;
  }

  .cw-articles-seo-header-card{
    padding:12px;
    border-radius:21px;
  }

  .cw-articles-seo-nav{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:6px;
  }

  .cw-articles-seo-nav-pill{
    min-height:31px;
    padding:5px 6px;
    font-size:11px;
  }

  .cw-articles-seo-brand-banner{
    min-height:98px;
    padding:12px 14px 15px;
    border-radius:17px;
    margin-bottom:13px;
  }

  .cw-articles-seo-brand-link{
    font-size:clamp(31px,10vw,42px);
  }

  .cw-articles-seo-brand-subtitle{
    font-size:clamp(22px,7vw,30px);
  }

  .cw-articles-seo-header-bottom{
    grid-template-columns:1fr;
    text-align:center;
    gap:12px;
  }

  .cw-articles-seo-description{
    font-size:16px;
  }

  .cw-articles-seo-tools{
    justify-content:center;
    flex-wrap:wrap;
  }

  .cw-articles-seo-tool-button{
    width:43px;
    min-width:43px;
    height:43px;
  }

  .cw-articles-seo-language-switcher{
    padding:3px;
  }

  .cw-articles-seo-lang-link{
    min-width:45px;
    min-height:25px;
    padding:4px 6px;
    font-size:9px;
  }

  .cw-articles-seo-body{
    padding:12px;
  }

  .cw-articles-seo-hero-card{
    padding:20px 16px;
  }

  .cw-articles-seo-section h2,
  .cw-articles-seo-faq h2{
    padding:15px 16px;
    font-size:23px;
  }

  .cw-articles-seo-section-body,
  .cw-articles-seo-faq-body{
    padding:16px;
    font-size:16px;
  }
}

@media (max-width:430px){
  .cw-articles-seo-nav{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .cw-articles-seo-nav-pill{
    font-size:12px;
  }
}


/* Etap 1A header correction: floating utility panels, no header reflow */
.cw-articles-seo-shell{
  overflow:visible;
}

.cw-articles-seo-header{
  position:relative;
  z-index:30;
}

.cw-articles-seo-header-card{
  position:relative;
  z-index:31;
}

.cw-articles-seo-body{
  position:relative;
  z-index:1;
}

.cw-articles-seo-tools{
  position:relative;
}

.cw-articles-seo-tool-wrap{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}

.cw-articles-seo-menu-icon{
  width:22px;
  height:22px;
  display:block;
  fill:none;
  stroke:currentColor;
  stroke-width:2.35;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.cw-articles-seo-tool-button.is-open{
  border-color:rgba(126,87,49,.34);
  box-shadow:0 7px 16px rgba(103,77,48,.18),inset 0 1px 0 rgba(255,255,255,.75);
}

.cw-articles-seo-popover{
  position:absolute;
  top:calc(100% + 10px);
  z-index:120;
  padding:10px;
  border:1px solid var(--cw-article-border);
  border-radius:18px;
  background:linear-gradient(180deg,#fffaf4 0%,#f4ede4 100%);
  box-shadow:0 18px 36px rgba(73,45,22,.18),0 3px 10px rgba(73,45,22,.08);
  display:grid;
  gap:8px;
  text-align:left;
}

.cw-articles-seo-popover[hidden]{
  display:none!important;
}

.cw-articles-seo-font-panel{
  left:50%;
  transform:translateX(-50%);
  min-width:235px;
}

.cw-articles-seo-portal-panel{
  right:0;
  width:min(318px,calc(100vw - 36px));
  max-height:min(68vh,560px);
  overflow:auto;
  align-content:start;
}

.cw-articles-seo-font-option,
.cw-articles-seo-menu-link,
.cw-articles-seo-menu-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  min-height:44px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid rgba(113,67,31,.16);
  background:rgba(255,255,255,.72);
  color:var(--cw-article-brown-2);
  font-size:14px;
  font-weight:700;
  text-decoration:none;
  appearance:none;
  -webkit-appearance:none;
  text-align:left;
  cursor:pointer;
  box-shadow:none;
  line-height:1.18;
}

.cw-articles-seo-font-option:hover,
.cw-articles-seo-menu-link:hover,
.cw-articles-seo-menu-summary:hover,
.cw-articles-seo-menu-subitem:hover{
  background:linear-gradient(180deg,#fffdf8 0%,#f6efe5 100%);
  box-shadow:0 6px 14px rgba(103,77,48,.08);
}

.cw-articles-seo-font-option.is-current,
.cw-articles-seo-menu-link.is-current{
  border-color:#c9ab8c;
  background:#ead8c4;
  color:#6b4529;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42),0 8px 16px rgba(103,77,48,.10);
}

.cw-articles-seo-font-option-size{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:52px;
  font-size:15px;
  font-weight:800;
  color:inherit;
}

.cw-articles-seo-menu-status{
  font-size:12px;
  font-weight:700;
  color:#6f5b4c;
  flex:0 0 auto;
}

.cw-articles-seo-menu-link.is-current .cw-articles-seo-menu-status{
  color:inherit;
}

.cw-articles-seo-menu-group{
  display:grid;
  gap:7px;
  margin:0;
}

.cw-articles-seo-menu-summary{
  position:relative;
  padding-right:38px;
  list-style:none;
  user-select:none;
}

.cw-articles-seo-menu-summary::-webkit-details-marker{
  display:none;
}

.cw-articles-seo-menu-summary::after{
  content:"▾";
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  font-size:13px;
  line-height:1;
  color:#7a5639;
  transition:transform .16s ease;
}

.cw-articles-seo-menu-group[open] .cw-articles-seo-menu-summary::after{
  transform:translateY(-50%) rotate(180deg);
}

.cw-articles-seo-menu-subgrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;
  padding:0 2px 2px 10px;
}

.cw-articles-seo-menu-subitem{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 9px;
  border-radius:12px;
  border:1px solid rgba(113,67,31,.12);
  background:rgba(255,255,255,.54);
  color:var(--cw-article-brown-2);
  font-size:12px;
  font-weight:700;
  line-height:1.1;
  text-align:center;
  text-decoration:none;
  overflow-wrap:anywhere;
}

.cw-articles-seo-menu-subitem--overview{
  grid-column:1/-1;
  min-height:36px;
  font-weight:800;
}

.cw-articles-seo-app.is-font-larger .cw-articles-seo-section-body,
.cw-articles-seo-app.is-font-larger .cw-articles-seo-faq-body,
.cw-articles-seo-app.is-font-larger .cw-articles-seo-lead{
  font-size:1.08em;
}

.cw-articles-seo-app.is-font-largest .cw-articles-seo-section-body,
.cw-articles-seo-app.is-font-largest .cw-articles-seo-faq-body,
.cw-articles-seo-app.is-font-largest .cw-articles-seo-lead{
  font-size:1.16em;
}

@media (max-width:760px){
  .cw-articles-seo-font-panel{
    left:auto;
    right:0;
    transform:none;
    min-width:220px;
  }

  .cw-articles-seo-portal-panel{
    right:0;
    width:min(300px,calc(100vw - 28px));
  }

  .cw-articles-seo-menu-subgrid{
    grid-template-columns:1fr;
    padding-left:8px;
  }
}

@media (max-width:430px){
  .cw-articles-seo-popover{
    top:calc(100% + 8px);
  }

  .cw-articles-seo-font-panel,
  .cw-articles-seo-portal-panel{
    right:50%;
    transform:translateX(50%);
    width:min(300px,calc(100vw - 24px));
  }
}


/* Etap 1A header desktop visual cleanup: one clean header card, smaller lower row */
.cw-articles-seo-shell{
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
}

.cw-articles-seo-header{
  margin:0 auto;
  padding:0;
  background:transparent;
  border:0;
  position:relative;
  z-index:40;
}

.cw-articles-seo-header-card{
  width:100%;
  margin:0 auto;
  padding:18px 18px 16px;
  border:1px solid rgba(216,199,180,.85);
  border-radius:23px;
  background:linear-gradient(180deg,#fffbf5 0%,#f6eee3 100%);
  box-shadow:0 18px 38px rgba(73,45,22,.11);
  overflow:visible;
}

.cw-articles-seo-nav{
  margin-bottom:14px;
}

.cw-articles-seo-brand-banner{
  margin-bottom:14px;
}

.cw-articles-seo-header-bottom{
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  padding:0 34px 0 76px;
  min-height:42px;
}

.cw-articles-seo-description{
  margin:0;
  max-width:660px;
  font-size:15px;
  line-height:1.45;
}

.cw-articles-seo-tools{
  gap:6px;
}

.cw-articles-seo-tool-button{
  width:40px;
  min-width:40px;
  height:40px;
  font-size:13px;
  box-shadow:0 4px 10px rgba(117,73,33,.13),inset 0 1px 0 rgba(255,255,255,.72);
}

.cw-articles-seo-menu-icon{
  width:18px;
  height:18px;
  stroke-width:2.25;
}

.cw-articles-seo-language-switcher{
  gap:3px;
  padding:3px;
  box-shadow:0 4px 10px rgba(88,54,27,.08);
}

.cw-articles-seo-lang-link{
  min-width:40px;
  min-height:22px;
  padding:4px 6px;
  gap:3px;
  font-size:8px;
}

.cw-articles-seo-body{
  margin-top:20px;
  padding:18px;
  border:1px solid rgba(216,199,180,.85);
  border-radius:26px;
  background:linear-gradient(180deg,#fbf8f3 0%,#f1e8dc 100%);
  box-shadow:0 14px 30px rgba(64,36,18,.08);
  overflow:hidden;
}

@media (max-width:920px){
  .cw-articles-seo-header-bottom{
    padding:0 18px;
  }

  .cw-articles-seo-description{
    max-width:none;
  }
}

@media (max-width:680px){
  .cw-articles-seo-header-card{
    padding:12px;
    border-radius:21px;
  }

  .cw-articles-seo-header-bottom{
    grid-template-columns:1fr;
    justify-items:center;
    text-align:center;
    gap:10px;
    padding:0 4px;
    min-height:0;
  }

  .cw-articles-seo-description{
    font-size:15px;
    line-height:1.42;
  }

  .cw-articles-seo-tools{
    justify-content:center;
    gap:6px;
  }

  .cw-articles-seo-tool-button{
    width:38px;
    min-width:38px;
    height:38px;
    font-size:12px;
  }

  .cw-articles-seo-lang-link{
    min-width:38px;
    min-height:22px;
    font-size:8px;
  }

  .cw-articles-seo-body{
    margin-top:14px;
    padding:12px;
    border-radius:22px;
  }
}

/* Etap 1A mobile header menu fix */
.cw-articles-seo-nav-mobile-wrap{
  display:none;
  position:relative;
}

.cw-articles-seo-nav-mobile-toggle{
  gap:6px;
}

.cw-articles-seo-nav-mobile-icon{
  font-size:12px;
  line-height:1;
}

.cw-articles-seo-mobile-nav-panel{
  right:0;
  width:min(250px,calc(100vw - 24px));
}

.cw-articles-seo-mobile-nav-links{
  display:grid;
  gap:8px;
}

.cw-articles-seo-mobile-nav-link{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  min-height:40px;
  padding:9px 12px;
  border-radius:13px;
  border:1px solid rgba(113,67,31,.16);
  background:rgba(255,255,255,.72);
  color:var(--cw-article-brown-2);
  font-size:13px;
  font-weight:700;
  text-decoration:none;
  text-align:center;
  appearance:none;
  -webkit-appearance:none;
  box-shadow:none;
  cursor:pointer;
}

.cw-articles-seo-mobile-nav-link:hover{
  background:linear-gradient(180deg,#fffdf8 0%,#f6efe5 100%);
  box-shadow:0 6px 14px rgba(103,77,48,.08);
}

@media (max-width:680px){
  .cw-articles-seo-nav{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:8px;
  }

  .cw-articles-seo-nav-mobile-wrap{
    display:block;
  }

  .cw-articles-seo-nav-mobile-hidden{
    display:none;
  }

  .cw-articles-seo-nav-pill{
    min-height:34px;
    padding:6px 8px;
    font-size:12px;
  }

  .cw-articles-seo-brand-banner{
    min-height:88px;
    padding:12px 12px 14px;
  }

  .cw-articles-seo-brand-link{
    font-size:clamp(22px,8.6vw,30px);
    line-height:1.02;
  }

  .cw-articles-seo-brand-subtitle{
    margin-top:5px;
    font-size:clamp(16px,5.8vw,22px);
    line-height:1.04;
  }

  .cw-articles-seo-header-bottom{
    grid-template-columns:1fr;
    justify-items:center;
    gap:8px;
    padding:0;
  }

  .cw-articles-seo-description{
    display:none;
  }

  .cw-articles-seo-tools{
    justify-content:center;
    gap:6px;
  }

  .cw-articles-seo-tool-button{
    width:36px;
    min-width:36px;
    height:36px;
    font-size:12px;
  }

  .cw-articles-seo-menu-icon{
    width:16px;
    height:16px;
  }

  .cw-articles-seo-language-switcher{
    padding:2px;
    gap:2px;
  }

  .cw-articles-seo-lang-link{
    min-width:34px;
    min-height:20px;
    padding:3px 5px;
    font-size:8px;
  }
}

@media (max-width:430px){
  .cw-articles-seo-nav{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:6px;
  }

  .cw-articles-seo-nav-pill{
    min-height:32px;
    padding:5px 6px;
    font-size:11px;
  }

  .cw-articles-seo-mobile-nav-panel{
    right:0;
    width:min(220px,calc(100vw - 20px));
    transform:none;
  }

  .cw-articles-seo-brand-link{
    font-size:26px;
  }

  .cw-articles-seo-brand-subtitle{
    font-size:18px;
  }

  .cw-articles-seo-tool-button{
    width:35px;
    min-width:35px;
    height:35px;
  }

  .cw-articles-seo-lang-link{
    min-width:33px;
    font-size:7px;
  }
}

@media (max-width:680px){
  .cw-articles-seo-nav > .cw-articles-seo-nav-pill,
  .cw-articles-seo-nav-mobile-toggle{
    width:100%;
    justify-content:center;
  }
}

/* Etap 1A final hamburger correction
   Cel: większe i czytelniejsze kreski hamburgera bez powiększania okrągłego przycisku.
   Ten blok ma zostać na końcu pliku, żeby nadpisać wcześniejsze próby poprawek. */
.cw-articles-seo-tool-button .cw-articles-seo-menu-icon{
  width:22px !important;
  height:22px !important;
  display:block !important;
  overflow:visible !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2.85 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
  flex:0 0 auto !important;
}

.cw-articles-seo-tool-button .cw-articles-seo-menu-icon path,
.cw-articles-seo-tool-button .cw-articles-seo-menu-icon line,
.cw-articles-seo-tool-button .cw-articles-seo-menu-icon polyline{
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2.85 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}

.cw-articles-seo-nav-mobile-toggle .cw-articles-seo-nav-mobile-icon{
  font-size:17px !important;
  font-weight:800 !important;
  line-height:1 !important;
  transform:translateY(-.5px) !important;
}

@media (max-width:680px){
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon{
    width:21px !important;
    height:21px !important;
    stroke-width:3 !important;
  }

  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon path,
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon line,
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon polyline{
    stroke-width:3 !important;
  }

  .cw-articles-seo-nav-mobile-toggle .cw-articles-seo-nav-mobile-icon{
    font-size:17px !important;
  }
}

@media (max-width:430px){
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon{
    width:21px !important;
    height:21px !important;
    stroke-width:3.05 !important;
  }

  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon path,
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon line,
  .cw-articles-seo-tool-button .cw-articles-seo-menu-icon polyline{
    stroke-width:3.05 !important;
  }

  .cw-articles-seo-nav-mobile-toggle .cw-articles-seo-nav-mobile-icon{
    font-size:17px !important;
  }
}

/* Stage 2: full Why play chess article layout */
.cw-article-content{
  --cw-bg:#ffffff;
  --cw-panel:#f7f4ef;
  --cw-panel-2:#f3eee7;
  --cw-line:#dfd6ca;
  --cw-text:#5a4636;
  --cw-text-strong:#6b441d;
  --cw-green-bg:#ead8c4;
  --cw-green-bd:#c9ab8c;
  --cw-green-tx:#6b441d;
  color:var(--cw-text);
  font-family:Georgia,"Times New Roman",serif;
  line-height:1.75;
}
.cw-article-content *,
.cw-article-content *::before,
.cw-article-content *::after{box-sizing:border-box;font-family:Georgia,"Times New Roman",serif!important;}
.cw-article-hero{display:grid;grid-template-columns:1.35fr .85fr;gap:18px;margin-bottom:18px;}
.cw-card,.cw-side-card,.cw-section,.cw-cta-box,.cw-sidebar,.cw-links-grid,.cw-footer-links{background:rgba(255,255,255,.52);border:1px solid var(--cw-line);border-radius:22px;box-shadow:0 5px 18px rgba(103,77,48,.08);}
.cw-card{padding:26px 24px;min-width:0;}
.cw-kicker{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(180deg,#f3dfc4 0%,#e1ba83 55%,#c59052 100%);color:#4b2812;border:1px solid #b8844d;border-radius:999px;padding:10px 16px;font-size:14px;font-weight:700;margin-bottom:16px;box-shadow:0 5px 12px rgba(124,79,35,.14), inset 0 1px 0 rgba(255,255,255,.42);text-shadow:0 1px 0 rgba(255,255,255,.28);}
.cw-title{margin:0 0 10px;color:var(--cw-text-strong);font-size:40px;line-height:1.08;overflow-wrap:anywhere;hyphens:auto;}
.cw-lead{margin:0;font-size:18px;line-height:1.65;color:#6f5b4c;max-width:760px;}
.cw-hero-side{display:flex;flex-direction:column;gap:14px;justify-content:center;}
.cw-side-card{padding:16px;background:linear-gradient(180deg,#fbf8f4 0%,#f2ebe3 100%);min-width:0;}
.cw-side-card strong{display:block;color:var(--cw-text-strong);font-size:17px;margin-bottom:6px;}
.cw-side-card span{display:block;font-size:15px;line-height:1.55;color:#6d5b4a;}
.cw-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:18px;align-items:start;}
.cw-sidebar{padding:18px;position:sticky;top:20px;min-width:0;}
.cw-sidebar h2{margin:0 0 14px;font-size:16px;color:var(--cw-text-strong);text-align:center;font-weight:700;}
.cw-sidebar-nav{display:flex;flex-direction:column;gap:12px;}
.cw-sidebar-nav a,.cw-btn,.cw-link-card,.cw-footer-links__card{display:flex;align-items:center;justify-content:center;min-height:64px;min-width:0;max-width:100%;padding:10px 14px;border-radius:18px;text-decoration:none;color:#442817;font-weight:700;font-size:17px;line-height:1.25;text-align:center;white-space:normal;overflow-wrap:anywhere;word-break:normal;hyphens:auto;background:radial-gradient(circle at 22% 18%, rgba(255,255,255,.34) 0, rgba(255,255,255,0) 30%),repeating-linear-gradient(0deg, rgba(255,255,255,.035) 0 2px, rgba(0,0,0,.018) 2px 4px),linear-gradient(180deg, #e6bc81 0%, #c88d47 55%, #a66b35 100%);border:1px solid rgba(113,67,31,.28);box-shadow:0 8px 16px rgba(124,79,35,.18), inset 0 1px 0 rgba(255,255,255,.3);transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;}
.cw-sidebar-nav a:hover,.cw-btn:hover,.cw-link-card:hover,.cw-footer-links__card:hover{transform:translateY(-1px);filter:saturate(1.02);box-shadow:0 10px 20px rgba(124,79,35,.22), inset 0 1px 0 rgba(255,255,255,.35);}
.cw-content{display:flex;flex-direction:column;gap:18px;min-width:0;}
.cw-section,.cw-side-card,.cw-sidebar,.cw-links-grid,.cw-footer-links{min-width:0;}
.cw-section{overflow:hidden;}
.cw-section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 22px;border-bottom:1px solid var(--cw-line);background:linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(245,239,232,.6) 100%);}
.cw-section-head h2{margin:0;min-width:0;font-size:29px;color:var(--cw-text-strong);line-height:1.15;overflow-wrap:anywhere;word-break:normal;hyphens:auto;}
.cw-badge{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:110px;padding:10px 14px;border-radius:999px;background:linear-gradient(180deg,#f3dfc4 0%,#e1ba83 55%,#c59052 100%);border:1px solid #b8844d;color:#4b2812;font-size:14px;font-weight:700;text-align:center;box-shadow:0 5px 12px rgba(124,79,35,.14), inset 0 1px 0 rgba(255,255,255,.42);text-shadow:0 1px 0 rgba(255,255,255,.28);}
.cw-section-body{padding:22px;font-size:17px;color:#6d5a49;}
.cw-section-body p{margin:0 0 14px;}.cw-section-body p:last-child{margin-bottom:0;}.cw-section-body ul{margin:0 0 14px;padding-left:24px;}.cw-section-body li{margin:0 0 8px;}.cw-section-body a{color:#7a4b1b;text-decoration:underline;text-underline-offset:3px;}.cw-section-body a:hover{opacity:.92;}
.cw-note{margin-top:8px;padding:12px 14px;border-radius:16px;background:#f3eee7;border:1px solid var(--cw-line);color:#7a6857;font-size:15px;}
.cw-figure{margin:0 0 18px;border:1px solid var(--cw-line);border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 5px 18px rgba(103,77,48,.08);}
.cw-figure img{display:block;width:100%;height:auto;}
.cw-figure figcaption{padding:11px 14px;font-size:.94rem;line-height:1.55;color:#3f3126;background:#f7f0e7;border-top:1px solid var(--cw-line);font-weight:500;}
.cw-links-grid{padding:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px;}
.cw-link-card{min-height:120px;flex-direction:column;gap:8px;padding:18px 16px;line-height:1.35;}
.cw-link-card small{display:block;font-size:14px;font-weight:400;color:#4e3a2a;}
.cw-cta-box{margin-top:18px;padding:24px;text-align:center;background:linear-gradient(180deg,rgba(255,255,255,.58) 0%,rgba(243,236,227,.85) 100%);}
.cw-cta-box h3{margin:0 0 10px;font-size:28px;color:var(--cw-text-strong);}
.cw-cta-box p{margin:0 auto 18px;max-width:760px;font-size:17px;line-height:1.7;color:#6d5a49;}.cw-cta-buttons{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
.cw-footer-links{margin-top:18px;padding:20px 18px;}.cw-footer-links h3{margin:0 0 14px;font-size:26px;color:var(--cw-text-strong);text-align:center;overflow-wrap:anywhere;hyphens:auto;}.cw-footer-links__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}.cw-article-footnote{padding:18px 0 6px;text-align:center;color:#7a6857;font-size:15px;}
@media (max-width:980px){.cw-article-hero,.cw-layout,.cw-links-grid,.cw-footer-links__grid{grid-template-columns:1fr}.cw-sidebar{position:static}}
@media (max-width:760px){.cw-card{padding:20px 16px}.cw-title{font-size:31px}.cw-lead{font-size:17px}.cw-sidebar-nav a{font-size:14px;min-height:56px;padding:10px 12px}.cw-section-head{padding:16px;flex-direction:column;align-items:flex-start}.cw-section-head h2{font-size:23px;max-width:100%}.cw-badge{min-width:0;max-width:100%}.cw-section-body{padding:16px;font-size:16px}.cw-cta-box{padding:20px 16px}.cw-cta-box h3{font-size:24px}.cw-btn{width:100%;min-width:0}}


/* 0.1.0.32: clickable board with fuller right-side copy in Play now article hero */
.cw-article-hero--play-now{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);align-items:stretch;}
.cw-play-now-card{display:flex;flex-direction:column;gap:14px;}
.cw-board-game-link{display:block;margin-top:4px;border-radius:20px;overflow:hidden;text-decoration:none;color:#442817;background:linear-gradient(180deg,#fffaf4 0%,#f2e5d3 100%);border:1px solid var(--cw-line);box-shadow:0 10px 24px rgba(103,77,48,.14);transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;}
.cw-board-game-link:hover{transform:translateY(-2px);filter:saturate(1.03);box-shadow:0 14px 30px rgba(103,77,48,.2);}
.cw-board-game-link__media{display:block;background:#fff;}
.cw-board-game-link__media img{display:block;width:100%;height:auto;}
.cw-board-game-link__caption{display:flex;align-items:center;justify-content:center;min-height:50px;padding:10px 14px;font-weight:700;font-size:17px;text-align:center;background:linear-gradient(180deg,#f3dfc4 0%,#e1ba83 55%,#c59052 100%);border-top:1px solid rgba(113,67,31,.2);text-shadow:0 1px 0 rgba(255,255,255,.3);}
.cw-play-now-buttons{display:none;}
.cw-hero-side--play-now-copy{align-content:start;gap:14px;}
.cw-side-card--text{padding:18px 20px;}
.cw-side-card--text span{font-size:16px;line-height:1.65;}
@media (max-width:980px){.cw-article-hero--play-now{grid-template-columns:1fr}.cw-article-hero--play-now .cw-hero-side{display:grid;grid-template-columns:1fr 1fr;}}
@media (max-width:760px){.cw-article-hero--play-now .cw-hero-side{grid-template-columns:1fr}.cw-board-game-link__caption{font-size:16px;min-height:46px}.cw-play-now-card{gap:12px}}


/* 0.1.0.33: restore visible flags in language switcher */
.cw-articles-seo-lang-link span[aria-hidden="true"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  line-height:1;
  transform:translateY(-.5px);
}
.cw-articles-seo-lang-link span:not([aria-hidden="true"]){
  display:inline-flex;
  align-items:center;
  line-height:1;
}
.cw-articles-seo-lang-link{
  min-width:48px;
  gap:4px;
}
@media (max-width:760px){
  .cw-articles-seo-lang-link{
    min-width:46px;
    padding:4px 6px;
  }
  .cw-articles-seo-lang-link span[aria-hidden="true"]{
    font-size:12px;
  }
}

/* 0.1.0.34: real CSS flag icons in language switcher (no emoji dependency) */
.cw-articles-seo-flag{
  display:inline-block;
  flex:0 0 auto;
  width:16px;
  height:11px;
  border-radius:2px;
  border:1px solid rgba(92,56,28,.24);
  box-shadow:0 1px 2px rgba(74,43,19,.12);
  overflow:hidden;
}
.cw-articles-seo-flag--pl{
  background:linear-gradient(to bottom,#ffffff 0 50%,#dc143c 50% 100%);
}
.cw-articles-seo-flag--en{
  position:relative;
  background:#012169;
}
.cw-articles-seo-flag--en::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom,transparent 0 38%,#fff 38% 45%,#c8102e 45% 55%,#fff 55% 62%,transparent 62% 100%),
    linear-gradient(to right,transparent 0 38%,#fff 38% 45%,#c8102e 45% 55%,#fff 55% 62%,transparent 62% 100%);
}
.cw-articles-seo-flag--nl{
  background:linear-gradient(to bottom,#ae1c28 0 33.333%,#ffffff 33.333% 66.666%,#21468b 66.666% 100%);
}
.cw-articles-seo-lang-label{
  display:inline-flex;
  align-items:center;
  line-height:1;
}
.cw-articles-seo-lang-link{
  min-width:56px;
  gap:5px;
}
@media (max-width:760px){
  .cw-articles-seo-flag{width:14px;height:10px;}
  .cw-articles-seo-lang-link{min-width:52px;gap:4px;}
}
@media (max-width:430px){
  .cw-articles-seo-lang-link{min-width:48px;}
}

/* 0.1.0.36: play now hero - board on left, headline copy on right */
.cw-play-now-card--board-only{justify-content:center;}
.cw-side-card--hero-title{gap:12px;padding:22px 20px;background:linear-gradient(180deg,rgba(255,255,255,.82) 0%,rgba(247,239,229,.94) 100%);}
.cw-side-card--hero-title .cw-kicker{display:inline-flex;width:100%;margin:0 0 2px;padding:9px 14px;font-size:14px;line-height:1.25;}
.cw-side-card--hero-title strong{font-size:30px;line-height:1.08;color:var(--cw-text-strong);}
.cw-side-card--hero-title span:last-child{font-size:17px;line-height:1.62;color:#5f4a37;}
@media (max-width:760px){.cw-side-card--hero-title strong{font-size:25px}.cw-side-card--hero-title .cw-kicker{font-size:13px}}

/* 0.1.0.37: separate Play now board CTA into a rounded standalone tube */
.cw-board-game-link{
  margin-top:4px;
  border:0;
  border-radius:0;
  overflow:visible;
  background:transparent;
  box-shadow:none;
}
.cw-board-game-link:hover{
  transform:none;
  filter:none;
  box-shadow:none;
}
.cw-board-game-link__media{
  display:block;
  overflow:hidden;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--cw-line);
  box-shadow:0 10px 24px rgba(103,77,48,.14);
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.cw-board-game-link:hover .cw-board-game-link__media{
  transform:translateY(-1px);
  filter:saturate(1.03);
  box-shadow:0 14px 30px rgba(103,77,48,.19);
}
.cw-board-game-link__caption{
  width:min(360px,86%);
  min-height:46px;
  margin:14px auto 0;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid rgba(113,67,31,.24);
  box-shadow:0 8px 16px rgba(124,79,35,.18), inset 0 1px 0 rgba(255,255,255,.36);
}
.cw-board-game-link:hover .cw-board-game-link__caption{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(124,79,35,.22), inset 0 1px 0 rgba(255,255,255,.42);
}
@media (max-width:760px){
  .cw-board-game-link__caption{width:min(320px,90%);margin-top:12px;min-height:44px;}
}

/* Hotfix 0.1.0.39 - mobile header full-width refinement for all article pages
   Cel: na mobile wykorzystac pelna szerokosc ekranu, utrzymac 4 przyciski w jednej linii
   oraz zmniejszyc gorna tube i podtytul marki. */
@media (max-width:680px){
  .cw-articles-seo-app{
    width:100vw;
    max-width:none;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding-left:0;
    padding-right:0;
  }

  .cw-articles-seo-shell,
  .cw-articles-seo-header,
  .cw-articles-seo-header-card{
    width:100%;
    max-width:none;
  }

  .cw-articles-seo-header-card{
    border-left:0;
    border-right:0;
    border-radius:0 0 22px 22px;
    padding:12px 10px 14px;
  }

  .cw-articles-seo-nav{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:5px;
    margin-bottom:10px;
  }

  .cw-articles-seo-nav-pill,
  .cw-articles-seo-nav-mobile-toggle{
    white-space:nowrap;
    min-height:31px;
    padding:5px 5px;
    font-size:10.5px;
    line-height:1;
  }

  .cw-articles-seo-brand-banner{
    width:calc(100% - 48px);
    max-width:340px;
    min-height:76px;
    margin:0 auto 11px;
    padding:9px 12px 11px;
    border-radius:14px;
  }

  .cw-articles-seo-brand-link{
    font-size:clamp(25px,8.2vw,31px);
    line-height:1;
  }

  .cw-articles-seo-brand-subtitle{
    margin-top:4px;
    font-size:clamp(15px,5.1vw,18px);
    line-height:1.03;
  }
}

@media (max-width:360px){
  .cw-articles-seo-nav{
    gap:4px;
  }

  .cw-articles-seo-nav-pill,
  .cw-articles-seo-nav-mobile-toggle{
    font-size:10px;
    padding-left:4px;
    padding-right:4px;
  }

  .cw-articles-seo-brand-banner{
    width:calc(100% - 42px);
    min-height:72px;
  }

  .cw-articles-seo-brand-link{
    font-size:26px;
  }

  .cw-articles-seo-brand-subtitle{
    font-size:15px;
  }
}

/* Hotfix 0.1.0.40 - mobile header rounded shell margin
   Cel: zostawic mobile header prawie full-width, ale pokazac 6px tla po bokach,
   zeby gorna karta wygladala jak jedna zaokraglona tuba. Dol artykulu bez zmian. */
@media (max-width:680px){
  .cw-articles-seo-header-card{
    width:calc(100% - 12px);
    max-width:none;
    margin-left:auto;
    margin-right:auto;
    border-left:1px solid var(--cw-line);
    border-right:1px solid var(--cw-line);
    border-top:1px solid var(--cw-line);
    border-radius:20px;
  }
}

@media (max-width:360px){
  .cw-articles-seo-header-card{
    width:calc(100% - 10px);
    border-radius:18px;
  }
}


/* Hotfix 0.1.0.44 - centered mobile utility popovers
   Cel: panele po kliknieciu A i hamburgera maja otwierac sie na srodku ekranu,
   nie przy lewej krawedzi ani poza widocznym obszarem naglowka. */
@media (max-width:680px){
  .cw-articles-seo-font-panel,
  .cw-articles-seo-portal-panel,
  .cw-articles-seo-tool-wrap .cw-articles-seo-font-panel,
  .cw-articles-seo-tool-wrap .cw-articles-seo-portal-panel{
    position:fixed;
    left:50%;
    right:auto;
    top:var(--cw-articles-popover-top, 206px);
    transform:translateX(-50%);
    width:min(320px,calc(100vw - 32px));
    min-width:0;
    max-width:calc(100vw - 32px);
    max-height:calc(100vh - var(--cw-articles-popover-top, 206px) - 14px);
    overflow:auto;
    z-index:9999;
  }

  .cw-articles-seo-font-panel{
    align-content:start;
  }

  .cw-articles-seo-portal-panel{
    align-content:start;
  }
}

/* Hotfix 0.1.0.50.4 - training image CTA glass overlay
   Cel: lekki przycisk typu glass w obrebie samego zdjecia, bez nachodzenia na podpis; responsywny na mobile. */
.cw-figure--training-overlay{
  overflow:hidden;
}

.cw-figure--training-overlay .cw-figure__media{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:inherit;
}

.cw-figure--training-overlay .cw-figure__media img{
  display:block;
  width:100%;
  height:auto;
}

.cw-figure--training-overlay .cw-figure__cta{
  position:absolute;
  right:clamp(14px,3.2vw,30px);
  bottom:clamp(14px,2.6vw,26px);
  z-index:2;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 18px;
  border:1px solid rgba(255,255,255,.62);
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.78),rgba(210,150,80,.56));
  color:#6b3508;
  font-weight:800;
  font-size:clamp(13px,1.45vw,16px);
  line-height:1.15;
  text-align:center;
  text-decoration:none;
  white-space:nowrap;
  max-width:calc(100% - 28px);
  box-shadow:0 10px 24px rgba(45,28,12,.18), inset 0 1px 0 rgba(255,255,255,.78);
  backdrop-filter:blur(8px) saturate(1.08);
  -webkit-backdrop-filter:blur(8px) saturate(1.08);
  transform:translateZ(0);
}

.cw-figure--training-overlay .cw-figure__cta:hover,
.cw-figure--training-overlay .cw-figure__cta:focus{
  background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(222,164,92,.70));
  color:#552800;
  text-decoration:none;
  box-shadow:0 12px 28px rgba(45,28,12,.23), inset 0 1px 0 rgba(255,255,255,.88);
}

.cw-figure--training-overlay figcaption{
  position:relative;
  z-index:1;
}

@media (max-width:680px){
  .cw-figure--training-overlay .cw-figure__cta{
    right:10px;
    bottom:10px;
    min-height:34px;
    padding:7px 12px;
    font-size:12px;
    max-width:calc(100% - 20px);
  }
}

@media (max-width:420px){
  .cw-figure--training-overlay .cw-figure__cta{
    right:8px;
    bottom:8px;
    min-height:32px;
    padding:6px 10px;
    font-size:11px;
    max-width:calc(100% - 16px);
    box-shadow:0 7px 16px rgba(45,28,12,.16), inset 0 1px 0 rgba(255,255,255,.72);
  }
}
