:root{
  /* Väripaletti (pyydetty) */
  --orange:#E36414; --gold:#FB8B24; --cream:#FFFFFA; --mint:#FCD757;
  --black:#000000; --dark-gray:#121212; --medium-gray:#1f1f1f; --light-gray:#2a2a2a;
}

/* Perus */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
html{background:#000}
body{
  font-family:'Inter',sans-serif;
  background:var(--black);
  min-height:100vh; color:var(--cream); line-height:1.6
}
.container{max-width:1200px;margin:0 auto;padding:20px}

/* Yläpalkki */
.nav{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  background:var(--dark-gray);
  border-radius:20px;
  padding:26px 30px;
  margin-bottom:40px;
  border:1px solid var(--light-gray);
  gap:18px;
}
.logo{
  font-family:'Fredoka',sans-serif;
  font-weight:700;
  font-size:2.4em;
  color:var(--orange);
  letter-spacing:.04em;
}
.logo a{color:var(--orange);text-decoration:none}
.logo a:hover{color:var(--gold)}
.nav-groups{
  display:flex;
  flex-direction:column;
  gap:20px;
  width:100%;
}
.nav-menu{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  padding:28px 24px 18px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--light-gray);
  border-radius:18px;
  position:relative;
}
.nav-menu::before{
  content:'';
  position:absolute;
  top:-15px;
  left:50%;
  transform:translateX(-50%);
  padding:4px 14px;
  background:var(--black);
  border:1px solid var(--gold);
  border-radius:999px;
  font-family:'Fredoka',sans-serif;
  font-size:.78em;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--gold);
}
.nav-menu.nav-primary::before{content:'Core Tools'}
.nav-menu.nav-dnd{
  background:rgba(227,100,20,.1);
  border-color:rgba(227,100,20,.5);
}
.nav-menu.nav-dnd::before{
  content:'D&D Suite';
  border-color:rgba(227,100,20,.8);
  color:var(--cream);
  background:#1b0c05;
}
.nav-menu.nav-dnd .nav-label{display:none}
.nav-item{
  font-family:'Fredoka',sans-serif;
  font-weight:500;
  color:var(--cream);
  text-decoration:none;
  padding:10px 16px;
  border-radius:12px;
  transition:all .2s ease;
  border:1px solid transparent;
}
.nav-item:hover{
  background:var(--light-gray);
  color:var(--gold);
  border-color:rgba(255,255,255,.1);
}
.nav-item.active{
  background:var(--orange);
  color:var(--cream);
  border-color:var(--orange);
}

/* Hero + kortit */
.hero{text-align:center;margin-bottom:60px}
.hero h1{font-family:'Fredoka',sans-serif;font-weight:600;font-size:3.0em;margin-bottom:18px;color:var(--gold)}
.hero p{font-size:1.05em;opacity:.9;max-width:760px;margin:0 auto}
.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:24px}
.game-card{
  background:var(--dark-gray);border-radius:16px;padding:30px;text-align:center;border:1px solid var(--light-gray);
  transition:all .3s ease;cursor:pointer;text-decoration:none;color:inherit;display:block
}
.game-card:hover{transform:translateY(-4px);border-color:var(--gold);background:var(--medium-gray)}
.game-icon{font-size:3.5em;margin-bottom:16px;display:flex;align-items:center;justify-content:center;height:56px}
.game-title{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.35em;margin-bottom:12px;color:var(--gold)}
.game-description{opacity:.85}

.home-sections{display:flex;flex-direction:column;gap:36px}
.card-section{
  border:1px solid var(--light-gray);
  border-radius:20px;
  background:rgba(255,255,255,.02);
  padding:28px;
}
.card-section.dnd-section{
  border-color:rgba(227,100,20,.45);
  background:linear-gradient(145deg,rgba(227,100,20,.08),rgba(0,0,0,.65));
}
.section-heading{
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:6px;
  border-bottom:1px solid rgba(255,255,255,.08);
  padding-bottom:16px;
}
.section-heading h2{
  font-family:'Fredoka',sans-serif;
  font-size:1.8em;
  color:var(--gold);
}
.section-heading p{
  opacity:.8;
  max-width:720px;
}

/* Otsikot & sisällöt */
.game-header{background:var(--dark-gray);border-radius:16px;padding:26px;margin-bottom:12px;text-align:center;border:1px solid var(--light-gray)}
.game-header h2{font-family:'Fredoka',sans-serif;font-weight:600;font-size:2em;color:var(--gold);margin-bottom:6px}
.game-header p{opacity:.9}
.hint{margin-top:6px;font-size:.95em;opacity:.85}
.game-content{background:var(--dark-gray);border-radius:16px;padding:20px 26px;border:1px solid var(--light-gray)}

/* Lomake & napit */
.input-group{margin-bottom:16px}
label{display:block;margin-bottom:8px;font-weight:600;color:var(--gold)}
input,select{
  width:100%;padding:12px 16px;border:1px solid var(--light-gray);border-radius:10px;font-size:16px;
  background:var(--medium-gray);color:var(--cream);transition:all .2s ease
}
input:focus,select:focus{outline:none;border-color:var(--gold);background:#2e2e2e}
input::placeholder{color:rgba(255,255,250,.45)}
.btn{
  font-family:'Fredoka',sans-serif;font-weight:600;color:var(--cream);background:var(--gold);border:none;
  padding:14px 24px;border-radius:12px;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block
}
.btn:hover{background:var(--orange);transform:translateY(-1px);box-shadow:0 4px 12px rgba(251,139,36,.3)}
.btn.secondary{background:transparent;border:2px solid var(--mint);color:var(--mint)}
.btn.secondary:hover{background:transparent;border:2px solid var(--mint);color:var(--mint)}
.btn.danger{background:#000;border:2px solid var(--orange);color:var(--cream)}
.btn.danger:hover{background:transparent;color:var(--orange)}
.btn.fs{background:transparent;border:1px dashed var(--orange);color:var(--orange);padding:12px 14px}

/* Layoutit */
.flex-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap}
.flex-row>div{flex:1 1 auto}
.page{display:block}

/* Wheel inputs grid (vain tämä ei ristiriidassa) */
#wheelInputs{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#wheelInputs .memory-item{margin:0}

/* Animaatiot */
@keyframes pop-in{0%{opacity:0;transform:scale(.7)}60%{opacity:1;transform:scale(1.08)}100%{transform:scale(1)}}
@keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-6px)}40%,60%{transform:translateX(6px)}}
@keyframes flip-card{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}100%{transform:rotateY(0)}}

/* Coin poistettu animaatio */
.coin-display{animation:none !important}

/* Etusivun kortit: 2x2 desktop, 1x4 mobiili */
.games-grid{grid-template-columns:repeat(2,1fr)}
@media(max-width:768px){
  .games-grid{grid-template-columns:1fr}
  .nav{padding:20px}
}

/* Mobiili */
@media(max-width:560px){
  .nav{padding:18px}
  .nav-menu{padding:24px 16px 16px}
  .hero h1{font-size:2.4em}
  .hero p{font-size:1.0em}
  .games-grid{grid-template-columns:1fr;gap:16px}
  .game-card{padding:24px}
  .flex-row{flex-direction:column;gap:8px}
}

/* Mobiili fullscreen optimointi */
@media(max-width:768px){
  .overlay{
    padding:5px !important;
  }
  .overlay .inner{
    max-width:100vw !important;
    max-height:100vh !important;
    padding:5px !important;
    gap:8px !important;
  }
  .overlay .controls{
    margin-top:8px !important;
    gap:12px !important;
  }
}

/* SEO-lohkojen tyylit */
.seo-block {
  background: var(--dark-gray);
  border: 1px solid var(--light-gray);
  border-radius: 16px;
  padding: 24px;
  margin: 32px auto;
  max-width: 800px;
  color: var(--cream);
}

.seo-block h2 {
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  font-size: 1.6em;
  color: var(--gold);
  margin-bottom: 16px;
}

.seo-block h3 {
  font-family: 'Fredoka', sans-serif;
  font-weight: 500;
  font-size: 1.2em;
  color: var(--mint);
  margin: 16px 0 8px 0;
}

.seo-block p {
  margin-bottom: 12px;
  line-height: 1.6;
  opacity: 0.9;
}

.seo-block ul {
  margin: 12px 0;
  padding-left: 20px;
}

.seo-block li {
  margin-bottom: 8px;
  opacity: 0.9;
}

.seo-block details {
  margin: 16px 0;
  border: 1px solid var(--light-gray);
  border-radius: 8px;
  overflow: hidden;
}

.seo-block summary {
  background: var(--medium-gray);
  padding: 12px 16px;
  cursor: pointer;
  font-weight: 500;
  border-bottom: 1px solid var(--light-gray);
  transition: background 0.2s ease;
}

.seo-block summary:hover {
  background: var(--light-gray);
}

.seo-block details[open] summary {
  background: var(--light-gray);
}

.seo-block details > *:not(summary) {
  padding: 16px;
  background: var(--dark-gray);
}

.seo-block kbd {
  background: var(--medium-gray);
  border: 1px solid var(--light-gray);
  border-radius: 4px;
  padding: 2px 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.9em;
  color: var(--gold);
}

.seo-block a {
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s ease;
}

.seo-block a:hover {
  border-bottom-color: var(--gold);
}

.seo-block .meta {
  font-size: 0.9em;
  color: var(--cream);
  opacity: 0.7;
  margin-top: 20px;
  text-align: center;
  border-top: 1px solid var(--light-gray);
  padding-top: 16px;
}

/* Mobiili-tyylit SEO-lohkoille */
@media(max-width:560px){
  .seo-block {
    padding: 20px;
    margin: 24px 16px;
  }
  
  .seo-block h2 {
    font-size: 1.4em;
  }
  
  .seo-block details > *:not(summary) {
    padding: 12px;
  }
}

.related-tools{
  background:var(--dark-gray);
  border:1px solid var(--light-gray);
  border-radius:16px;
  padding:24px;
  margin:32px 0 0;
  line-height:1.6;
}

.related-tools h2{
  font-family:'Fredoka',sans-serif;
  font-weight:600;
  color:var(--gold);
  margin-bottom:16px;
}

.related-tools ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.related-tools li{
  border:1px solid var(--light-gray);
  border-radius:12px;
  padding:12px 16px;
  background:#1c1c1c;
}

.related-tools a{
  color:var(--mint);
  font-weight:600;
  text-decoration:none;
}

.related-tools a:hover{
  text-decoration:underline;
}

/* Footer */
.footer{
  margin-top:40px;
  background:var(--dark-gray);
  border:1px solid var(--light-gray);
  border-radius:16px;
  padding:20px 24px;
}
.footer-inner{
  display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between
}
.footer .links{display:flex;flex-wrap:wrap;gap:10px}
.footer a{color:var(--cream);text-decoration:none;padding:6px 10px;border-radius:8px}
.footer a:hover{background:var(--light-gray);color:var(--gold)}
.footer .copy{opacity:.7;font-size:.95em}

@media(max-width:560px){
  .footer-inner{flex-direction:column;gap:10px;align-items:flex-start}
}
