body {
  margin:0;
  min-height:100vh;
  background: radial-gradient(circle, #3a3a3a 0%, #1b1b1b 70%);
  color:#f4ecd8;
  font-family:'Cormorant Garamond', serif;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:0 16px;
  box-sizing:border-box;
}

h1 {
  font-family:'Cinzel', serif;
  margin:40px 0 10px;
  letter-spacing:2px;
  text-align:center;
}

.campaign {
  margin:20px 0 30px;
  text-align:center;
  font-family:'Cinzel', serif;
  font-size:32px;
  letter-spacing:3px;
  color:#c9a24d;
  text-shadow:0 0 15px rgba(201,162,77,0.6);
}

.campaign span { font-size:40px; }
.campaign small { display:block; margin-top:8px; font-size:18px; letter-spacing:2px; color:#f4ecd8; text-shadow:none; }

.subtitle { opacity:0.8; margin-bottom:24px; font-style:italic; text-align:center; padding:0 20px; }

.page-links {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:40px;
  justify-content:center;
}

.page-links a {
  color:#f4ecd8;
  border:1px solid #c9a24d;
  padding:10px 18px;
  border-radius:6px;
  text-decoration:none;
  font-family:'Cinzel', serif;
  letter-spacing:1px;
  background:rgba(43,29,14,0.7);
  transition:all 0.2s ease;
  box-sizing:border-box;
}

.page-links a:hover,
.page-links a:focus {
  color:#2b1d0e;
  background:#c9a24d;
  box-shadow:0 0 14px rgba(201,162,77,0.55);
}

.lang-link {
  background:#c9a24d;
  color:#f4ecd8 !important;
}

.lang-link:hover,
.lang-link:focus {
  background:#c9a24d !important;
  color:#f4ecd8 !important;
}

.hall {
  display:grid;
  grid-template-columns:repeat(4,140px);
  gap:25px;
  padding-bottom:60px;
  justify-content:center;
}

.seal {
  height:140px;
  background:linear-gradient(145deg,#2b1d0e,#3a2a16);
  border:2px solid #5a4322;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Cinzel', serif;
  font-size:24px;
  cursor:pointer;
  position:relative;
  transition:all 0.3s ease;
  user-select:none;
}

.seal.locked { opacity:0.4; cursor:not-allowed; }
.seal.today { box-shadow:0 0 15px #c9a24d; animation:pulse 2s infinite; }
.seal.opened { background:linear-gradient(145deg,#f4ecd8,#e6dbc3); color:#2b1d0e; border-color:#c9a24d; }
.seal.opened::after { content:"✓"; position:absolute; top:5px; right:8px; font-size:20px; color:greenyellow; font-weight:bold; }

@keyframes pulse {
  0% { box-shadow:0 0 10px #c9a24d; }
  50% { box-shadow:0 0 20px #ffd777; }
  100% { box-shadow:0 0 10px #c9a24d; }
}

.modal {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.75);
  display:none;
  align-items:center;
  justify-content:center;
}

.modal-content {
  background:linear-gradient(145deg,#f4ecd8,#e6dbc3);
  color:#2b1d0e;
  width:min(620px, calc(100% - 40px));
  max-height:80vh;
  overflow:auto;
  padding:34px;
  border:2px solid #c9a24d;
  border-radius:8px;
  font-size:20px;
  line-height:1.65;
  box-shadow:0 0 25px rgba(0,0,0,0.6);
  box-sizing:border-box;
}

.modal-content #modalText {
  white-space:pre-line;
}

.modal-content #modalText::first-line {
  color:#6c4a14;
  font-family:'Cinzel', serif;
  font-size:24px;
  font-weight:700;
}

.close { margin-top:20px; text-align:right; font-weight:bold; cursor:pointer; }

.riddle-box {
  width:min(720px, 100%);
  background:linear-gradient(145deg,#2b1d0e,#3a2a16);
  border:2px solid #5a4322;
  border-radius:8px;
  padding:28px;
  box-shadow:0 8px 20px rgba(0,0,0,0.25);
  box-sizing:border-box;
  margin-bottom:60px;
}

.riddle-box p,
.riddle-box a,
.riddle-box label {
  font-size:20px;
  line-height:1.6;
}

.riddle-box input,
.riddle-box button {
  width:100%;
  box-sizing:border-box;
  border-radius:6px;
  border:1px solid #c9a24d;
  font-family:'Cormorant Garamond', serif;
  font-size:20px;
}

.riddle-box input {
  padding:12px 14px;
  background:#f4ecd8;
  color:#2b1d0e;
}

.riddle-box button {
  padding:12px 16px;
  background:#c9a24d;
  color:#2b1d0e;
  font-family:'Cinzel', serif;
  cursor:pointer;
}

.riddle-box a {
  color:#f4ecd8;
}

.board-page {
  width:min(1100px, calc(100% - 32px));
  padding-bottom:60px;
}

.board-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:18px;
}

.board-card {
  min-height:260px;
  background:linear-gradient(145deg,#2b1d0e,#3a2a16);
  border:2px solid #5a4322;
  border-radius:8px;
  padding:22px;
  box-shadow:0 8px 20px rgba(0,0,0,0.25);
  text-align:center;
}

.board-photo {
  width:120px;
  height:120px;
  margin:0 auto 18px;
  border:1px dashed rgba(201,162,77,0.75);
  border-radius:50%;
  background:rgba(244,236,216,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  color:#c9a24d;
  font-family:'Cinzel', serif;
  letter-spacing:1px;
}

.board-photo img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:none;
}

.board-photo img[src]:not([src=""]) {
  display:block;
}

.board-photo img[src]:not([src=""]) + span {
  display:none;
}

.photo-nathan {
  object-position:35% 38%;
}

.board-card h2 {
  min-height:44px;
  margin:0 0 10px;
  color:#c9a24d;
  font-family:'Cinzel', serif;
  font-size:18px;
  line-height:1.2;
  letter-spacing:1px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow-wrap:anywhere;
}

.board-name {
  min-height:24px;
  margin:0 auto 14px;
  padding:6px 10px;
  border:1px solid rgba(201,162,77,0.55);
  border-radius:6px;
  background:rgba(244,236,216,0.08);
  color:#f4ecd8;
  font-family:'Cinzel', serif;
  font-size:15px;
  letter-spacing:1px;
}

.board-card p {
  margin:0;
  font-size:18px;
  line-height:1.45;
}

.plans-page {
  width:min(980px, calc(100% - 32px));
  padding-bottom:60px;
}

.plans-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
  gap:18px;
}

.plan-card {
  background:linear-gradient(145deg,#2b1d0e,#3a2a16);
  border:2px solid #5a4322;
  border-radius:8px;
  padding:24px;
  box-shadow:0 8px 20px rgba(0,0,0,0.25);
}

.plan-card h2 {
  margin:0 0 16px;
  color:#c9a24d;
  font-family:'Cinzel', serif;
  font-size:20px;
  line-height:1.2;
  letter-spacing:1px;
  text-align:center;
}

.plan-card ul {
  margin:0;
  padding-left:22px;
  font-size:20px;
  line-height:1.55;
}

.plan-card li::marker {
  color:#c9a24d;
}

.motivation-page {
  width:min(900px, calc(100% - 32px));
  padding-bottom:70px;
}

.motivation-card {
  background:linear-gradient(145deg,#2b1d0e,#3a2a16);
  border:2px solid #5a4322;
  border-radius:8px;
  padding:34px;
  box-shadow:0 8px 20px rgba(0,0,0,0.25);
}

.motivation-card h2 {
  margin:34px 0 12px;
  color:#c9a24d;
  font-family:'Cinzel', serif;
  font-size:22px;
  line-height:1.2;
  letter-spacing:1px;
}

.motivation-card p,
.motivation-card li {
  font-size:20px;
  line-height:1.6;
}

.motivation-card p {
  margin:0 0 18px;
}

.motivation-card ul {
  margin:0 0 22px;
  padding-left:24px;
}

.motivation-card li {
  margin-bottom:14px;
}

.motivation-card li::marker {
  color:#c9a24d;
}

.motivation-signoff {
  color:#c9a24d;
  font-family:'Cinzel', serif;
  letter-spacing:1px;
}

.motivation-signature {
  margin-bottom:0;
  font-family:'Cinzel', serif;
  color:#f4ecd8;
}

@media (max-width: 680px) {
  h1 {
    font-size:28px;
    text-align:center;
  }

  .campaign {
    font-size:26px;
    margin:16px 0 24px;
  }

  .campaign span {
    font-size:32px;
  }

  .campaign small {
    font-size:16px;
  }

  .page-links {
    width:100%;
    gap:10px;
    margin-bottom:28px;
  }

  .page-links a {
    flex:1 1 calc(50% - 10px);
    text-align:center;
    padding:12px 14px;
    font-size:14px;
  }

  .lang-link {
    flex-basis:100%;
  }

  .hall {
    width:100%;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
  }

  .seal {
    height:120px;
    width:100%;
    font-size:22px;
  }

  .modal {
    padding:16px;
    box-sizing:border-box;
  }

  .modal-content {
    width:100%;
    max-height:85vh;
    padding:22px;
    font-size:18px;
    line-height:1.55;
  }

  .modal-content #modalText::first-line {
    font-size:21px;
  }

  .board-page,
  .plans-page,
  .motivation-page {
    width:100%;
  }

  .board-grid,
  .plans-grid {
    grid-template-columns:1fr;
  }

  .board-card,
  .plan-card,
  .motivation-card,
  .riddle-box {
    padding:20px;
  }

  .motivation-card {
    padding:24px;
  }

  .motivation-card p,
  .motivation-card li {
    font-size:18px;
  }

  .plan-card ul,
  .board-card p,
  .riddle-box p,
  .riddle-box a {
    font-size:18px;
  }

  .riddle-box input,
  .riddle-box button {
    font-size:18px;
  }
}
