.ztn-wg-wrap{--ztn-accent:#e50914;--ztn-gold:#d4af37;font-family:Inter,Arial,sans-serif;border-radius:0;padding:0;margin:0 auto;max-width:1280px;overflow:hidden;box-shadow:0 24px 90px rgba(0,0,0,.45)}
.ztn-wg-dark{background:#050505;color:#fff}.ztn-wg-light{background:#111;color:#fff}.ztn-netflix-ui{position:relative;background:radial-gradient(circle at 80% 0%,rgba(229,9,20,.24),transparent 34%),linear-gradient(180deg,#111 0%,#050505 58%,#000 100%)}
.ztn-games-hero{min-height:390px;padding:54px 42px 34px;display:flex;justify-content:space-between;gap:28px;align-items:flex-end;position:relative;background:linear-gradient(90deg,rgba(0,0,0,.98) 0%,rgba(0,0,0,.78) 45%,rgba(0,0,0,.18) 100%),radial-gradient(circle at 88% 24%,rgba(212,175,55,.35),transparent 0 18%,rgba(229,9,20,.22) 19%,transparent 42%)}
.ztn-games-hero:after{content:"";position:absolute;inset:auto 0 0;height:135px;background:linear-gradient(180deg,transparent,#050505)}.ztn-hero-copy{position:relative;z-index:2;max-width:720px}.ztn-wg-kicker{text-transform:uppercase;letter-spacing:.18em;color:var(--ztn-accent);font-size:12px;font-weight:900}.ztn-hero-copy h2{font-family:Arial Black,Impact,Arial,sans-serif;text-transform:uppercase;font-size:clamp(40px,7vw,78px);line-height:.9;margin:10px 0 12px;letter-spacing:-.05em;text-shadow:0 10px 30px rgba(0,0,0,.9)}.ztn-hero-meta{font-weight:800;color:#f3f3f3;margin:0 0 10px}.ztn-hero-sub{font-size:18px;line-height:1.45;color:#d8d8d8;max-width:600px;margin:0 0 22px}.ztn-hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.ztn-play-now,.ztn-wg-tabs button,.ztn-clues button,.ztn-hive-submit,.ztn-shuffle-check{cursor:pointer;border:0}.ztn-play-now{background:#fff;color:#000;border-radius:5px;padding:13px 24px;font-weight:900;font-size:16px}.ztn-play-now:hover{background:var(--ztn-accent);color:#fff}.ztn-rating-pill{border:1px solid rgba(255,255,255,.25);border-radius:4px;padding:8px 10px;background:rgba(255,255,255,.08);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.ztn-wg-score{position:relative;z-index:2;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:16px 24px;text-align:center;min-width:105px;backdrop-filter:blur(10px)}.ztn-wg-score strong{display:block;font-size:38px;color:var(--ztn-accent);line-height:1}.ztn-wg-score span{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:#bbb}
.ztn-game-rail-label{font-size:22px;font-weight:900;margin:0 42px 12px;position:relative;z-index:3}.ztn-card-rail{display:flex;gap:14px;overflow-x:auto;padding:0 42px 28px;scroll-snap-type:x mandatory}.ztn-wg-tabs button.ztn-game-card{min-width:220px;height:118px;border-radius:8px;background:linear-gradient(145deg,#282828,#111);border:1px solid rgba(255,255,255,.09);color:#fff;text-align:left;padding:18px;scroll-snap-align:start;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.ztn-game-card span{display:block;font-size:22px;font-weight:900;margin-bottom:8px}.ztn-game-card small{color:#cfcfcf;font-weight:700}.ztn-wg-tabs button.active,.ztn-wg-tabs button.ztn-game-card:hover{transform:scale(1.05);background:linear-gradient(145deg,var(--ztn-accent),#6d050b);box-shadow:0 18px 40px rgba(229,9,20,.28)}
.ztn-wg-panel{display:none;margin:0 42px 42px;background:linear-gradient(180deg,#171717,#0a0a0a);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:26px;box-shadow:0 18px 50px rgba(0,0,0,.35)}.ztn-wg-panel.active{display:block}.ztn-panel-title{margin-bottom:18px}.ztn-panel-title span{color:var(--ztn-accent);font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:900}.ztn-panel-title h3{margin:5px 0 0;font-size:34px;line-height:1;color:#fff}.ztn-wg-game-layout{display:grid;grid-template-columns:minmax(320px,560px) 1fr;gap:28px}.ztn-crossword{display:grid;grid-template-columns:repeat(11,1fr);gap:2px;background:#000;border:4px solid #000;max-width:560px;border-radius:8px;overflow:hidden}.ztn-cell{aspect-ratio:1/1;width:100%;text-align:center;text-transform:uppercase;font-size:23px;font-weight:900;background:#f5f5f5;color:#111;border:0}.ztn-cell.black{background:#000}.ztn-cell.correct{background:#d8f5d1}.ztn-cell.wrong{background:#ffd7d7}.ztn-clues{font-family:Inter,Arial,sans-serif}.ztn-clues h3{color:var(--ztn-accent);font-size:22px;margin:0 0 8px}.ztn-clues p{line-height:1.45;border-bottom:1px solid rgba(255,255,255,.09);padding-bottom:8px;color:#e8e8e8}.ztn-clues button,.ztn-hive-submit,.ztn-shuffle-check{background:#fff;color:#000;border-radius:5px;padding:11px 16px;font-weight:900;margin:8px 8px 0 0}.ztn-clues button:hover,.ztn-hive-submit:hover,.ztn-shuffle-check:hover{background:var(--ztn-accent);color:#fff}.ztn-wordgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:5px;max-width:660px}.ztn-wordgrid button{aspect-ratio:1/1;border:1px solid rgba(255,255,255,.12);background:#f2f2f2;color:#111;border-radius:6px;font-weight:900;cursor:pointer}.ztn-wordgrid button.active{background:var(--ztn-accent);color:#fff}.ztn-wordlist{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.ztn-wordlist h3{width:100%;margin-bottom:4px}.ztn-wordlist span{border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:8px 12px;background:#202020}.ztn-hive{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;max-width:540px;margin:10px auto}.ztn-hive button,.ztn-hive-center{width:78px;height:78px;clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);border:0;font-size:28px;font-weight:900;background:#f4f4f4;color:#111}.ztn-hive-center{display:grid;place-items:center;background:var(--ztn-accent);color:#fff}.ztn-hive-input,.ztn-shuffle-input{width:100%;max-width:430px;margin:14px auto;display:block;padding:14px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#111;color:#fff;font-size:18px}.ztn-found{text-align:center}.ztn-found span{display:inline-block;margin:5px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12)}.ztn-scrambled{font-size:clamp(36px,7vw,64px);letter-spacing:.22em;text-align:center;color:var(--ztn-accent);font-weight:900;margin:28px 0}.ztn-shuffle-result{text-align:center;font-size:20px;font-weight:bold}
@media(max-width:800px){.ztn-games-hero{min-height:330px;padding:38px 20px 26px;align-items:flex-start;flex-direction:column}.ztn-game-rail-label{margin:0 20px 12px}.ztn-card-rail{padding:0 20px 24px}.ztn-wg-panel{margin:0 20px 28px;padding:18px}.ztn-wg-game-layout{grid-template-columns:1fr}.ztn-cell{font-size:16px}.ztn-wordgrid{grid-template-columns:repeat(12,1fr);gap:2px}.ztn-wordgrid button{font-size:11px}.ztn-hive button,.ztn-hive-center{width:58px;height:58px;font-size:21px}}

/* Desktop expansion: larger game window for computer viewing */
@media (min-width:1024px){
  .ztn-wg-wrap{
    max-width:1680px;
    width:96vw;
  }
  .ztn-games-hero{
    min-height:430px;
    padding-left:60px;
    padding-right:60px;
  }
  .ztn-game-rail-label{
    margin-left:60px;
    margin-right:60px;
  }
  .ztn-card-rail{
    padding-left:60px;
    padding-right:60px;
  }
  .ztn-wg-tabs button.ztn-game-card{
    min-width:270px;
    height:142px;
  }
  .ztn-wg-panel{
    margin-left:60px;
    margin-right:60px;
    padding:36px;
    min-height:680px;
  }
  .ztn-wg-game-layout{
    grid-template-columns:minmax(620px,760px) minmax(380px,1fr);
    gap:42px;
    align-items:start;
  }
  .ztn-crossword{
    max-width:760px;
  }
  .ztn-cell{
    font-size:30px;
  }
  .ztn-wordgrid{
    max-width:900px;
    gap:7px;
  }
  .ztn-wordgrid button{
    font-size:20px;
  }
  .ztn-hive{
    max-width:760px;
    min-height:390px;
  }
  .ztn-hive button,
  .ztn-hive-center{
    width:104px;
    height:104px;
    font-size:36px;
  }
  .ztn-hive-input,
  .ztn-shuffle-input{
    max-width:620px;
    padding:18px;
    font-size:22px;
  }
  .ztn-scrambled{
    font-size:82px;
  }
}

@media (min-width:1400px){
  .ztn-wg-panel{
    min-height:760px;
  }
  .ztn-crossword{
    max-width:820px;
  }
  .ztn-cell{
    font-size:34px;
  }
}

/* v1.3.0 desktop clipping fixes + richer word games */
.ztn-wg-wrap{
  overflow:visible;
  box-sizing:border-box;
}
.ztn-wg-wrap *{box-sizing:border-box}
.ztn-wg-panel{
  overflow:visible;
}
.ztn-wg-game-layout{
  overflow-x:auto;
  padding-bottom:8px;
}
.ztn-crossword{
  flex:0 0 auto;
  min-width:520px;
}
.ztn-wordgame-layout{
  display:grid;
  grid-template-columns:minmax(520px,820px) minmax(240px,1fr);
  gap:28px;
  align-items:start;
  overflow-x:auto;
  padding-bottom:8px;
}
.ztn-wordgrid{
  grid-template-columns:repeat(var(--ztn-grid-size,16),1fr);
  width:min(100%,820px);
  min-width:640px;
  max-width:820px;
}
.ztn-word-actions,.ztn-hive-controls{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.ztn-word-actions button,.ztn-hive-check,.ztn-hive-solve,.ztn-hive-clear{
  border:0;
  cursor:pointer;
  background:#fff;
  color:#000;
  border-radius:5px;
  padding:11px 16px;
  font-weight:900;
}
.ztn-word-actions button:hover,.ztn-hive-check:hover,.ztn-hive-solve:hover,.ztn-hive-clear:hover{
  background:var(--ztn-accent);
  color:#fff;
}
.ztn-selected-word{color:var(--ztn-accent);font-weight:900;letter-spacing:.08em;min-width:90px;display:inline-block}
.ztn-wordgrid button.found{background:#19a35b;color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.16) inset}
.ztn-wordlist span.found{text-decoration:line-through;background:#145c38;color:#d8ffe9;border-color:#32d17d}
.ztn-hive-result{text-align:center;font-weight:900;color:var(--ztn-accent);min-height:24px}
.ztn-hive-controls .ztn-hive-input{margin:0;max-width:520px;flex:1 1 320px}

@media (min-width:1024px){
  .ztn-wg-wrap{
    width:min(98vw,1900px);
    max-width:1900px;
  }
  .ztn-wg-panel{
    margin-left:32px;
    margin-right:32px;
  }
  .ztn-wg-game-layout{
    grid-template-columns:minmax(820px,920px) minmax(420px,1fr);
  }
  .ztn-crossword{
    max-width:920px;
    min-width:820px;
  }
  .ztn-wordgame-layout{
    grid-template-columns:minmax(760px,980px) minmax(300px,1fr);
  }
  .ztn-wordgrid{
    width:920px;
    max-width:920px;
    min-width:760px;
  }
}
@media (min-width:1500px){
  .ztn-wg-panel{margin-left:56px;margin-right:56px}
  .ztn-crossword{max-width:980px;min-width:900px}
  .ztn-wordgrid{width:980px;max-width:980px}
}
@media(max-width:800px){
  .ztn-crossword{min-width:0}
  .ztn-wordgame-layout{display:block;overflow-x:auto}
  .ztn-wordgrid{min-width:560px;width:560px;max-width:none}
  .ztn-word-actions,.ztn-hive-controls{justify-content:flex-start}
}

/* v2.0 production crossword engine UI fixes */
.ztn-crossword{
  grid-template-columns:repeat(var(--ztn-cw-size,15),1fr) !important;
  width:min(100%,900px);
  max-width:900px;
  min-width:720px;
}
.ztn-crossword .ztn-cell{
  min-width:0;
}
@media (min-width:1024px){
  .ztn-wg-game-layout{
    grid-template-columns:minmax(740px,940px) minmax(420px,1fr) !important;
  }
  .ztn-crossword{
    width:900px;
    max-width:900px;
    min-width:820px;
  }
  .ztn-cell{font-size:24px !important;}
}
@media (min-width:1500px){
  .ztn-crossword{width:960px;max-width:960px;min-width:900px;}
  .ztn-cell{font-size:26px !important;}
}
@media(max-width:800px){
  .ztn-crossword{min-width:620px;width:620px;max-width:none;}
  .ztn-wg-game-layout{overflow-x:auto;}
}

/* v2.1 centered production board layout with wording below boards */
.ztn-wg-wrap{
  margin-left:auto !important;
  margin-right:auto !important;
}
.ztn-wg-panel{
  max-width:1720px;
  margin-left:auto !important;
  margin-right:auto !important;
}
.ztn-crossword-stack,
.ztn-wordgame-stack{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:22px !important;
  overflow-x:visible !important;
}
.ztn-crossword-board-wrap,
.ztn-wordgrid-board-wrap{
  width:100%;
  display:flex;
  justify-content:center;
  overflow-x:auto;
  padding:4px 0 12px;
}
.ztn-crossword{
  margin:0 auto !important;
  width:min(88vw,840px) !important;
  min-width:0 !important;
  max-width:840px !important;
}
.ztn-wordgrid{
  margin:0 auto !important;
  width:min(88vw,900px) !important;
  min-width:0 !important;
  max-width:900px !important;
}
.ztn-below-board-copy{
  width:min(100%,1180px);
  margin:0 auto;
  text-align:left;
}
.ztn-game-help{
  color:#d9d9d9;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  padding:14px 16px;
  margin-bottom:16px;
  line-height:1.45;
  font-weight:700;
}
.ztn-clue-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.ztn-board-actions{
  text-align:center;
  margin-top:10px;
}
.ztn-wordlist.ztn-below-board-copy{
  justify-content:center;
  text-align:center;
}
.ztn-wordlist.ztn-below-board-copy .ztn-game-help,
.ztn-wordlist.ztn-below-board-copy h3{
  width:100%;
  text-align:left;
}
@media (min-width:1024px){
  .ztn-wg-wrap{width:min(98vw,1900px) !important;}
  .ztn-wg-panel{width:calc(100% - 84px);}
  .ztn-crossword{width:min(72vw,860px) !important;max-width:860px !important;}
  .ztn-wordgrid{width:min(76vw,940px) !important;max-width:940px !important;}
  .ztn-cell{font-size:22px !important;}
}
@media (min-width:1500px){
  .ztn-crossword{width:900px !important;max-width:900px !important;}
  .ztn-wordgrid{width:980px !important;max-width:980px !important;}
  .ztn-wg-panel{width:calc(100% - 112px);}
}
@media(max-width:800px){
  .ztn-crossword-board-wrap,
  .ztn-wordgrid-board-wrap{justify-content:flex-start;}
  .ztn-crossword{width:620px !important;max-width:none !important;min-width:620px !important;}
  .ztn-wordgrid{width:560px !important;max-width:none !important;min-width:560px !important;}
  .ztn-clue-columns{grid-template-columns:1fr;}
  .ztn-below-board-copy{text-align:left;}
}


/* v2.2 premium responsive engine: viewport-fit boards, no clipping, centered 100% width */
.ztn-wg-wrap.ztn-netflix-ui{
  width:100% !important;
  max-width:100% !important;
  margin-inline:auto !important;
  overflow:hidden !important;
  border-radius:0;
  container-type:inline-size;
}
.ztn-wg-wrap, .ztn-wg-wrap *{box-sizing:border-box}
.ztn-games-hero,.ztn-card-rail,.ztn-game-rail-label{
  max-width:1600px;
  margin-left:auto !important;
  margin-right:auto !important;
}
.ztn-wg-panel{
  width:min(100%,1600px) !important;
  max-width:calc(100vw - 24px) !important;
  margin:0 auto 32px !important;
  padding:clamp(14px,2.2vw,30px) !important;
  min-height:0 !important;
  overflow:hidden !important;
}
.ztn-panel-title{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.ztn-panel-title span{width:100%}
.ztn-fullscreen-toggle{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
}
.ztn-fullscreen-toggle:hover{background:var(--ztn-accent);border-color:var(--ztn-accent)}
.ztn-crossword-stack,.ztn-wordgame-stack{
  width:100% !important;
  max-width:100% !important;
  overflow:hidden !important;
}
.ztn-crossword-board-wrap,.ztn-wordgrid-board-wrap{
  width:100% !important;
  max-width:100% !important;
  overflow:hidden !important;
  display:flex !important;
  justify-content:center !important;
  align-items:flex-start !important;
  padding:0 0 14px !important;
}
.ztn-crossword{
  --ztn-board-fit:min(94vw, 74vh, 860px);
  display:grid !important;
  grid-template-columns:repeat(var(--ztn-cw-size,15), minmax(0,1fr)) !important;
  width:var(--ztn-board-fit) !important;
  max-width:100% !important;
  min-width:0 !important;
  aspect-ratio:1/1 !important;
  gap:clamp(1px,.22vw,2px) !important;
  border-width:clamp(2px,.45vw,4px) !important;
  overflow:hidden !important;
}
.ztn-crossword .ztn-cell{
  width:100% !important;
  min-width:0 !important;
  height:auto !important;
  aspect-ratio:1/1 !important;
  font-size:clamp(10px, calc(66vw / var(--ztn-cw-size,15)), 24px) !important;
  line-height:1 !important;
  padding:0 !important;
  border-radius:0 !important;
}
.ztn-wordgrid{
  --ztn-word-fit:min(94vw, 70vh, 900px);
  display:grid !important;
  grid-template-columns:repeat(var(--ztn-grid-size,16), minmax(0,1fr)) !important;
  width:var(--ztn-word-fit) !important;
  max-width:100% !important;
  min-width:0 !important;
  aspect-ratio:1/1 !important;
  gap:clamp(2px,.32vw,6px) !important;
  overflow:hidden !important;
}
.ztn-wordgrid button{
  width:100% !important;
  min-width:0 !important;
  height:auto !important;
  aspect-ratio:1/1 !important;
  font-size:clamp(10px, calc(60vw / var(--ztn-grid-size,16)), 20px) !important;
  padding:0 !important;
  display:grid;
  place-items:center;
}
.ztn-below-board-copy{
  width:min(100%,1120px) !important;
  max-width:100% !important;
}
.ztn-clue-columns{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.ztn-word-actions,.ztn-board-actions,.ztn-hive-controls{
  width:100%;
  max-width:100%;
}
.ztn-wg-panel.ztn-game-fullscreen{
  position:fixed !important;
  inset:0 !important;
  z-index:999999 !important;
  width:100vw !important;
  max-width:100vw !important;
  height:100dvh !important;
  max-height:100dvh !important;
  margin:0 !important;
  border-radius:0 !important;
  overflow:auto !important;
  background:#050505 !important;
}
.ztn-wg-panel.ztn-game-fullscreen .ztn-crossword{
  --ztn-board-fit:min(96vw, 78vh, 940px);
}
.ztn-wg-panel.ztn-game-fullscreen .ztn-wordgrid{
  --ztn-word-fit:min(96vw, 76vh, 980px);
}
.ztn-wg-panel.ztn-game-fullscreen .ztn-fullscreen-toggle::after{content:' Mode'}
@media (max-width:900px){
  .ztn-games-hero{padding:34px 18px 24px !important;min-height:300px !important;}
  .ztn-card-rail{padding-left:18px !important;padding-right:18px !important;}
  .ztn-game-rail-label{margin-left:18px !important;margin-right:18px !important;}
  .ztn-wg-panel{max-width:calc(100vw - 12px) !important;margin-bottom:20px !important;}
  .ztn-crossword{--ztn-board-fit:min(94vw, 68vh, 680px);}
  .ztn-wordgrid{--ztn-word-fit:min(94vw, 66vh, 680px);}
  .ztn-clue-columns{grid-template-columns:1fr;gap:10px;}
  .ztn-panel-title h3{font-size:clamp(26px,8vw,34px)}
}
@media (max-width:520px){
  .ztn-wg-panel{max-width:100vw !important;border-left:0;border-right:0;padding:12px !important;}
  .ztn-crossword{--ztn-board-fit:min(96vw, 62vh, 480px);}
  .ztn-wordgrid{--ztn-word-fit:min(96vw, 60vh, 480px);gap:2px !important;}
  .ztn-word-actions button,.ztn-board-actions button{padding:9px 11px;font-size:12px;}
}

/* v2.4 numbered-cell crossword fixes */
.ztn-crossword .ztn-cell.playable{
  position:relative !important;
  display:block !important;
  background:#f5f5f5 !important;
  color:#111 !important;
  overflow:hidden !important;
}
.ztn-crossword .ztn-cell.playable input{
  width:100% !important;
  height:100% !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  color:#111 !important;
  text-align:center !important;
  text-transform:uppercase !important;
  font-weight:900 !important;
  font-size:clamp(12px, calc(66vw / var(--ztn-cw-size,15)), 24px) !important;
  line-height:1 !important;
  padding:18% 2% 2% !important;
  box-sizing:border-box !important;
}
.ztn-crossword .ztn-cell.playable:has(input.correct){background:#d8f5d1 !important;}
.ztn-crossword .ztn-cell.playable:has(input.wrong){background:#ffd7d7 !important;}
.ztn-crossword .ztn-cell-number{
  position:absolute !important;
  top:2px !important;
  left:3px !important;
  z-index:2 !important;
  color:#111 !important;
  font-size:clamp(7px, calc(24vw / var(--ztn-cw-size,15)), 12px) !important;
  line-height:1 !important;
  font-weight:900 !important;
  pointer-events:none !important;
}
.ztn-crossword .ztn-cell.black{background:#050505 !important;}
@media(max-width:700px){
  .ztn-crossword .ztn-cell.playable input{padding-top:22% !important;}
  .ztn-crossword .ztn-cell-number{top:1px;left:2px;}
}

/* v2.5 premium crossword interactions */
.ztn-panel-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.ztn-panel-tools{
  display:flex;
  align-items:center;
  gap:10px;
}
.ztn-crossword-timer{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-weight:900;
  font-variant-numeric:tabular-nums;
}
.ztn-crossword{
  background:#343434 !important;
  border-color:#343434 !important;
  gap:2px !important;
  box-shadow:0 20px 60px rgba(0,0,0,.32), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.ztn-crossword-board-wrap{
  background:#242424 !important;
  border-radius:16px !important;
  padding:14px !important;
}
.ztn-crossword .ztn-cell.playable{
  background:#f1f1f1 !important;
  transition:background .12s ease, box-shadow .12s ease, transform .12s ease;
}
.ztn-crossword .ztn-cell.playable.active-word{
  background:#fff0ba !important;
}
.ztn-crossword .ztn-cell.playable.active-cell{
  background:#ffd85a !important;
  box-shadow:inset 0 0 0 3px #111;
  z-index:4;
}
.ztn-crossword .ztn-cell.playable:has(input.correct){background:#d9f7d5 !important;}
.ztn-crossword .ztn-cell.playable:has(input.wrong){background:#ffd6d6 !important;}
.ztn-clues p{
  cursor:pointer;
  border-radius:10px;
  padding:8px 10px !important;
  transition:background .14s ease, color .14s ease;
}
.ztn-clues p.active-clue{
  background:rgba(212,175,55,.18);
  border-color:rgba(212,175,55,.45) !important;
  color:#fff !important;
}
.ztn-crossword-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:14px;
}
.ztn-dir-toggle{
  display:inline-flex;
  gap:6px;
  padding:4px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.ztn-dir-toggle button,
.ztn-reset-crossword{
  border:0;
  border-radius:999px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
}
.ztn-dir-toggle button{
  background:transparent;
  color:#ddd;
}
.ztn-dir-toggle button.active{
  background:var(--ztn-accent);
  color:#111;
}
.ztn-crossword-status{
  min-height:24px;
  margin:10px 0 0;
  color:var(--ztn-accent);
  font-weight:800;
}
.ztn-puzzle-complete .ztn-crossword-board-wrap{
  box-shadow:0 0 0 2px rgba(212,175,55,.4), 0 24px 80px rgba(212,175,55,.14);
}
@media(max-width:700px){
  .ztn-panel-title{align-items:flex-start;}
  .ztn-panel-tools{width:100%;justify-content:space-between;}
  .ztn-crossword-toolbar{align-items:flex-start;}
  .ztn-board-actions{display:flex;gap:8px;flex-wrap:wrap;}
  .ztn-board-actions button{margin-right:0 !important;}
}

/* v2.6 NYT-accurate crossword interaction layer */
.ztn-crossword .ztn-cell.playable.active-word{
  background:#ffec99 !important; /* NYT-style active word yellow */
}
.ztn-crossword .ztn-cell.playable.active-cell{
  background:#ffd54f !important;
  box-shadow:inset 0 0 0 3px #c99a00, 0 0 0 1px rgba(0,0,0,.28) !important; /* gold active-cell border */
  z-index:5;
}
.ztn-crossword .ztn-cell.playable:has(input.correct),
.ztn-crossword .ztn-cell.playable.cell-correct{
  background:#8bd88b !important;
}
.ztn-crossword .ztn-cell.playable:has(input.wrong),
.ztn-crossword .ztn-cell.playable.cell-wrong{
  background:#ef6b6b !important;
}
.ztn-crossword .ztn-cell.playable:has(input.correct) input,
.ztn-crossword .ztn-cell.playable:has(input.wrong) input{color:#071107 !important;}
.ztn-pencil-on .ztn-crossword .ztn-cell.playable input,
.ztn-crossword .ztn-cell.playable input.pencil-letter{
  font-style:italic !important;
  font-weight:700 !important;
  color:#444 !important;
}
.ztn-clue-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
@media(min-width:900px){
  .ztn-clue-columns>div{
    max-height:65vh;
    overflow-y:auto;
    padding-right:8px;
    scrollbar-width:thin;
    scrollbar-color:var(--ztn-accent) rgba(255,255,255,.10);
  }
  .ztn-clue-columns>div::-webkit-scrollbar{width:9px;}
  .ztn-clue-columns>div::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px;}
  .ztn-clue-columns>div::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--ztn-accent),#8b6d16);border-radius:999px;border:2px solid #151515;}
}
.ztn-crossword-toolbar{
  align-items:stretch !important;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding:10px;
}
.ztn-toolbar-group{
  display:flex;
  align-items:center;
  gap:7px;
  flex-wrap:wrap;
  padding:8px;
  border-radius:13px;
  background:rgba(0,0,0,.26);
  border:1px solid rgba(255,255,255,.08);
}
.ztn-toolbar-label{
  width:100%;
  color:#bdbdbd;
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:900;
}
.ztn-toolbar-group button,
.ztn-pencil-mode{
  border:0;
  border-radius:999px;
  padding:9px 12px;
  font-weight:900;
  cursor:pointer;
  background:#fff;
  color:#111;
  margin:0 !important;
}
.ztn-toolbar-group button:hover,
.ztn-toolbar-group button.active,
.ztn-pencil-mode[aria-pressed="true"]{
  background:var(--ztn-accent) !important;
  color:#111 !important;
}
.ztn-toolbar-tools .ztn-dir-toggle{margin:0;}
.ztn-shortcut-tipbar{
  margin:10px 0 0;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(212,175,55,.12);
  border:1px solid rgba(212,175,55,.25);
  color:#f1e6bd;
  font-size:12px;
  font-weight:800;
  line-height:1.35;
}
.ztn-crossword-context-menu{
  position:absolute;
  z-index:9999;
  display:none;
  min-width:180px;
  padding:8px;
  border-radius:12px;
  background:#111;
  border:1px solid rgba(212,175,55,.5);
  box-shadow:0 18px 55px rgba(0,0,0,.55);
}
.ztn-crossword-context-menu.open{display:block;}
.ztn-crossword-context-menu button{
  display:block;
  width:100%;
  text-align:left;
  border:0;
  background:transparent;
  color:#fff;
  padding:10px 12px;
  border-radius:9px;
  font-weight:800;
  cursor:pointer;
}
.ztn-crossword-context-menu button:hover{background:rgba(212,175,55,.18);color:#fff;}
.ztn-confetti-burst{
  pointer-events:none;
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:30;
}
.ztn-confetti-burst i{
  position:absolute;
  top:-24px;
  width:9px;
  height:14px;
  border-radius:2px;
  background:var(--ztn-accent);
  animation:ztnConfettiFall 2.25s cubic-bezier(.2,.8,.2,1) forwards;
}
.ztn-confetti-burst i:nth-child(3n){background:#e50914;}
.ztn-confetti-burst i:nth-child(3n+1){background:#fff;}
@keyframes ztnConfettiFall{
  0%{transform:translate3d(0,-20px,0) rotate(0deg);opacity:1;}
  70%{opacity:1;}
  100%{transform:translate3d(var(--x),78vh,0) rotate(var(--r));opacity:0;}
}
@media(max-width:899px){
  .ztn-clue-columns{grid-template-columns:1fr;}
  .ztn-toolbar-group{width:100%;}
  .ztn-toolbar-group button{font-size:12px;padding:8px 10px;}
}


/* v2.7 reset/new-words engine + exact letter centering */
.ztn-crossword .ztn-cell.playable{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.ztn-crossword .ztn-cell.playable input{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  padding:0 !important;
  line-height:1 !important;
  height:100% !important;
  width:100% !important;
  transform:none !important;
}
.ztn-wordgrid button{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  line-height:1 !important;
  padding:0 !important;
}
.ztn-word-status{
  color:var(--ztn-accent);
  font-weight:900;
  min-width:220px;
  text-align:center;
}
.ztn-word-new{
  background:var(--ztn-accent) !important;
  color:#050505 !important;
}
.ztn-word-new:hover{
  filter:brightness(1.08);
}
@media(max-width:700px){
  .ztn-crossword .ztn-cell.playable input{padding:0 !important;}
  .ztn-word-status{width:100%;font-size:12px;}
}
