/* TCEA Digital Breakouts — shared structural styles.
   Palette variables (--navy, --red, --gold, --c1..c5, etc.) are set per suite
   by a small inline :root in each page, so one stylesheet serves every theme.
   Load AFTER the inline palette:  <link rel="stylesheet" href="../../assets/breakout.css"> */

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Nunito',sans-serif;color:var(--ink);background:
  radial-gradient(ellipse 60% 50% at 80% 0%,var(--bg-a,rgba(178,30,40,.10))0%,transparent 60%),
  radial-gradient(ellipse 50% 40% at 0% 100%,var(--bg-b,rgba(11,107,58,.10))0%,transparent 60%),var(--paper);
  min-height:100vh;line-height:1.55}
.wrap{max-width:880px;margin:0 auto;padding:20px 18px 80px}
.langbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:8px}
.langbar .globe{font-size:1.1rem}
.breakout-i18n-switcher,#i18nSwitcher{font-family:'Nunito',sans-serif;font-weight:700;font-size:.9rem;
  padding:7px 12px;border:2px solid var(--line);border-radius:9px;background:#fff;color:var(--navy);cursor:pointer}
.crumb{font-size:.82rem;font-weight:700;margin-bottom:10px}
.crumb a{color:var(--c3);text-decoration:none}
header.top{text-align:center;padding:8px 0 4px}
.eyebrow{display:inline-block;background:var(--navy);color:#fff;font-family:'Fredoka',sans-serif;
  font-weight:600;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;padding:6px 16px;border-radius:100px;margin-bottom:12px}
h1{font-family:'Fredoka',sans-serif;font-weight:700;font-size:clamp(1.9rem,6vw,3rem);color:var(--navy);line-height:1.04}
.sub{color:var(--ink-soft);font-weight:600;margin-top:8px;max-width:640px;margin-left:auto;margin-right:auto}
.progress-wrap{display:flex;align-items:center;gap:12px;justify-content:center;flex-wrap:wrap;position:sticky;top:8px;z-index:30;margin:12px 0 6px;padding:10px 14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;box-shadow:0 4px 14px rgba(10,36,99,.07)}
.lockdots{display:flex;gap:8px}
.ld{width:30px;height:30px;border-radius:9px;background:#d8deea;display:flex;align-items:center;justify-content:center;
  font-size:1rem;transition:.3s;border:2px solid transparent}
.ld.open{background:var(--good);color:#fff;border-color:#1f7a31}
.pcount{font-family:'Fredoka',sans-serif;font-weight:600;color:var(--navy)}
.resetbtn{background:#fff;border:2px solid var(--line);border-radius:9px;padding:7px 14px;font-family:'Fredoka',sans-serif;
  font-weight:600;color:var(--ink-soft);cursor:pointer;font-size:.85rem}
.resetbtn:hover{border-color:var(--bad);color:var(--bad)}

.brief{background:#fffdf6;border:2px dashed var(--gold-d);border-radius:14px;padding:16px 20px;margin:18px 0}
.brief h2{font-family:'Fredoka',sans-serif;font-size:1.15rem;color:var(--navy);margin-bottom:6px}
.brief .tag{font-family:'Fredoka',sans-serif;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-d);font-weight:600}

.section-title{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.2rem;color:var(--navy);margin:24px 0 4px}
.hint{color:var(--ink-soft);font-weight:600;font-size:.92rem;margin-bottom:12px}

.clue-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.clue{background:var(--card);border:2px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;
  transition:.18s;text-align:center;font-family:inherit}
.clue:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 8px 20px rgba(10,36,99,.1)}
.clue .ico{font-size:2rem;line-height:1}
.clue .nm{font-weight:700;margin-top:6px;color:var(--navy);font-size:.92rem}
.clue.opened{border-color:var(--c5);background:#eefbfd}
.clue.opened .nm::after{content:' ✓';color:var(--good)}

.locks{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}
@media(max-width:640px){.locks{grid-template-columns:1fr}.clue-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}
.lock{background:var(--card);border:2px solid var(--line);border-radius:16px;padding:18px;position:relative}
.lock.solved{border-color:var(--good);background:#f3fbf975}
.lock .lk-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.lk-badge{width:38px;height:38px;border-radius:10px;color:#fff;font-family:'Fredoka',sans-serif;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}
.lk-title{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.05rem;color:var(--navy);line-height:1.1}
.lk-q{font-size:.9rem;color:var(--ink-soft);font-weight:600;margin:8px 0 12px}
.lk-solved-msg{display:none;color:var(--good);font-weight:800;font-family:'Fredoka',sans-serif;margin-top:6px}
.lock.solved .lk-solved-msg{display:block}
.lock.solved .lk-body{display:none}

.digits{display:flex;gap:8px;margin-bottom:10px}
.digit{width:46px;height:54px;border:2px solid var(--line);border-radius:10px;text-align:center;font-size:1.5rem;
  font-weight:800;font-family:'Fredoka',sans-serif;color:var(--navy)}
.digit:focus{outline:none;border-color:var(--c3)}

.wordin{width:100%;border:2px solid var(--line);border-radius:10px;padding:11px 13px;font-size:1.05rem;
  font-weight:700;font-family:inherit;color:var(--navy)}
.wordin:focus{outline:none;border-color:var(--c3)}

.mc{display:flex;flex-direction:column;gap:8px}
.mc button{text-align:left;background:#fff;border:2px solid var(--line);border-radius:10px;padding:10px 13px;
  font-family:inherit;font-weight:600;cursor:pointer;font-size:.92rem;transition:.15s}
.mc button:hover{border-color:var(--navy);background:#f7f9ff}

.seq-pads{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.seqpad{min-width:46px;height:46px;padding:0 6px;border-radius:10px;border:3px solid rgba(0,0,0,.12);cursor:pointer;font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
.seq-current{min-height:30px;font-family:'Fredoka',sans-serif;font-weight:700;color:var(--navy);letter-spacing:1px;font-size:1.1rem;
  background:#f0f3fa;border-radius:8px;padding:4px 10px;display:inline-block;margin-bottom:8px;min-width:120px}
.seq-clear{background:none;border:none;color:var(--ink-soft);font-weight:700;cursor:pointer;text-decoration:underline;font-size:.82rem;margin-left:8px}

.lk-submit{background:var(--navy);color:#fff;border:none;border-radius:9px;padding:10px 20px;font-family:'Fredoka',sans-serif;
  font-weight:600;cursor:pointer;font-size:.92rem;margin-top:4px}
.lk-submit:hover{background:var(--navy-d)}
.lk-feedback{margin-top:10px;font-weight:700;font-size:.88rem;min-height:20px}
.lk-feedback.bad{color:var(--bad)}
.lk-feedback.good{color:var(--good)}

.multi{display:flex;flex-direction:column;gap:8px}
.multi-opt{display:flex;gap:10px;align-items:flex-start;text-align:left;background:#fff;border:2px solid var(--line);border-radius:10px;padding:10px 13px;font-family:inherit;font-weight:600;cursor:pointer;font-size:.92rem;transition:.15s}
.multi-opt:hover{border-color:var(--navy);background:#f7f9ff}
.multi-opt .mbox{width:22px;height:22px;border-radius:6px;border:2px solid var(--line);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff}
.multi-opt.picked{border-color:var(--c3);background:#eef4ff}
.multi-opt.picked .mbox{background:var(--c3);border-color:var(--c3)}
.multi-opt.picked .mbox::after{content:'✓'}

.modal-bg{position:fixed;inset:0;background:rgba(10,29,61,.55);display:none;align-items:center;justify-content:center;z-index:40;padding:20px}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:18px;padding:26px 24px;max-width:460px;width:100%;animation:pop .25s ease}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.modal .mico{font-size:2.6rem;text-align:center}
.modal h3{font-family:'Fredoka',sans-serif;color:var(--navy);text-align:center;margin:6px 0 12px;font-size:1.3rem}
.modal p{font-weight:600;color:var(--ink);margin:8px 0}
.modal .closebtn{display:block;margin:16px auto 0;background:var(--gold);color:var(--navy-d);border:none;border-radius:9px;
  padding:10px 24px;font-family:'Fredoka',sans-serif;font-weight:600;cursor:pointer}
.reasoning{background:#fff4f4;border-left:4px solid var(--red);border-radius:8px;padding:10px 13px;font-size:.88rem;color:#6b2330;font-weight:600;margin-top:10px}

.win{position:fixed;inset:0;background:rgba(10,29,61,.7);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.win.show{display:flex}
.win-card{background:#fff;border-radius:22px;padding:34px 30px;max-width:480px;text-align:center;animation:pop .3s ease}
.win-card .stamp{display:inline-block;font-family:'Fredoka',sans-serif;font-weight:700;font-size:1.3rem;color:var(--red);
  border:4px solid var(--red);border-radius:12px;padding:8px 20px;transform:rotate(-6deg);margin-bottom:16px}
.win-card h2{font-family:'Fredoka',sans-serif;color:var(--navy);font-size:1.6rem;margin-bottom:8px}
.win-card p{font-weight:600;color:var(--ink-soft);margin-bottom:18px}
.win-card button{background:var(--navy);color:#fff;border:none;border-radius:10px;padding:12px 26px;font-family:'Fredoka',sans-serif;
  font-weight:600;cursor:pointer;font-size:1rem}
#confetti{position:fixed;inset:0;pointer-events:none;z-index:60}
footer{text-align:center;margin-top:30px;font-size:.8rem;color:var(--ink-soft);font-weight:600;line-height:1.7}
footer a{color:var(--c3);font-weight:700}

/* keep numeric date entry left-to-right even in RTL languages */
[dir="rtl"] .digits{direction:ltr}
[dir="rtl"] .mc button,[dir="rtl"] .multi-opt{text-align:right}
[dir="rtl"] .seq-clear{margin-left:0;margin-right:8px}
