@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;700;800&family=Comic+Neue:wght@400;700&display=swap');

:root{
  --bg:#fff7ef;
  --card:#fffefb;
  --muted:#3d3a34;
  --accent:#d12727; /* more vibrant red */
  --accent-2:#0fb356; /* punchier green */
  --accent-3:#ffdd00; /* brighter comic yellow */
  --accent-4:#ff6b35; /* vibrant orange */
  --accent-5:#8b5cf6; /* purple */
  --accent-6:#0ea5e9; /* sky blue */
  --accent-7:#ec4899; /* pink */
  --shadow: 8px 8px 0 rgba(0,0,0,0.25); /* offset comic shadow */
  --radius:18px;
  --gap:18px;
  font-family: "Baloo 2", "Comic Neue", "Helvetica Neue", Arial, sans-serif;
  color: #221a14;
}

*{box-sizing:border-box}
html,body,#app{height:100%}
body{
  margin:0;
  background:
    radial-gradient(circle at 10% 10%, rgba(255,221,0,0.18), transparent 8%),
    radial-gradient(circle at 90% 90%, rgba(236,72,153,0.15), transparent 10%),
    radial-gradient(circle at 50% 50%, rgba(139,92,246,0.08), transparent 12%),
    radial-gradient(circle at 80% 20%, rgba(14,165,233,0.12), transparent 9%),
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(0,0,0,0.015) 8px 16px),
    linear-gradient(180deg, var(--bg), #fff0e6);
  display:flex;
  align-items:stretch;
  justify-content:center;
  padding:20px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* comic halftone on app */
#app{
  width:100%;
  max-width:1100px;
  height:100%;
  background:transparent;
  display:flex;
  flex-direction:column;
  gap:18px;
  position:relative;
}
#app::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle, rgba(0,0,0,0.12) 1.5px, transparent 1.5px),
    radial-gradient(circle, rgba(0,0,0,0.08) 1px, transparent 1px);
  background-size: 18px 18px, 36px 36px;
  background-position: 0 0, 9px 9px;
  opacity:0.2;
  pointer-events:none;
  mix-blend-mode:multiply;
}

/* Topbar */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:8px 12px;
  background: linear-gradient(135deg, #fff 0%, #fef3ff 30%, #f0f9ff 70%, #fffef0 100%);
  border: 5px solid #000;
  border-radius: 16px;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  transform: rotate(-1deg);
}
.title{
  font-weight:800;
  letter-spacing:0.6px;
  color:var(--accent);
  font-size:20px;
  text-shadow: 
    3px 3px 0 #000,
    4px 4px 0 rgba(255,221,0,0.5);
  -webkit-text-stroke: 1px #000;
}
.controls button{
  border:4px solid #000;
  background:linear-gradient(135deg, var(--accent-6), var(--accent-5));
  box-shadow: 5px 5px 0 rgba(0,0,0,0.4);
  padding:10px 16px;
  border-radius:12px;
  font-size:24px;
  font-weight:900;
  cursor:pointer;
  color:#fff;
  transform:skewX(-8deg);
  transition:transform .12s ease;
  text-shadow: 2px 2px 0 rgba(0,0,0,0.3);
}
.controls button:hover{transform:translateY(-3px) skewX(-8deg); box-shadow: 5px 8px 0 rgba(0,0,0,0.4)}
.controls button:active{transform:translateY(2px) skewX(-8deg); box-shadow: 2px 2px 0 rgba(0,0,0,0.4)}

/* Stage */
.stage{
  flex:1;
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px;
}

/* Slide card */
.slide{
  width:100%;
  height:100%;
  max-height:760px;
  border-radius:var(--radius);
  background:
    repeating-linear-gradient(45deg, transparent 0 4px, rgba(0,0,0,0.02) 4px 8px),
    linear-gradient(180deg, #fffefb, #fff7f0);
  box-shadow: 12px 12px 0 rgba(0,0,0,0.3);
  display:grid;
  grid-template-columns: 1fr 460px;
  gap:calc(var(--gap) + 6px);
  padding:36px;
  align-items:center;
  border:6px solid #000;
  position:relative;
  overflow:hidden;
  transform: rotate(-1deg);
}

/* comic burst behind portrait */
.slide::after{
  content:'';
  position:absolute;
  right:380px;
  top:50%;
  transform: translateY(-50%);
  width:400px;
  height:400px;
  background:
    radial-gradient(circle, transparent 30%, var(--accent-3) 30%, var(--accent-3) 32%, transparent 32%),
    radial-gradient(circle, transparent 45%, var(--accent) 45%, var(--accent) 47%, transparent 47%),
    radial-gradient(circle at 40% 40%, rgba(255,221,0,0.25), transparent 60%);
  pointer-events:none;
  opacity: 0.3;
}

/* left content: large name + lines */
.slide .left{
  padding:8px 6px;
  position:relative;
}
.num{
  position:absolute;
  top:6px;
  right:6px;
  font-size:140px;
  font-weight:900;
  color:rgba(209,39,39,0.1);
  transform:rotate(-18deg) skewX(-8deg);
  pointer-events:none;
  text-shadow: 
    3px 3px 0 rgba(0,0,0,0.05),
    -2px -2px 0 rgba(255,255,255,0.3);
  -webkit-text-stroke: 2px rgba(0,0,0,0.03);
}
.role{
  font-size:48px;
  font-weight:800;
  color:var(--accent);
  margin-bottom:10px;
  letter-spacing:1px;
  text-transform:uppercase;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-3deg);
}
.subtitle{
  display:inline-block;
  background:linear-gradient(90deg, var(--accent-3), #ffee55);
  padding:10px 16px;
  border-radius:999px;
  color:#000;
  font-weight:900;
  font-size:14px;
  margin-bottom:14px;
  transform:skewX(-8deg) rotate(-2deg);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.3);
  border: 3px solid #000;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* speech-bubble style blurb */
.blurb{
  color:var(--muted);
  line-height:1.6;
  font-size:16px;
  background: 
    repeating-linear-gradient(90deg, transparent 0 3px, rgba(0,0,0,0.02) 3px 6px),
    linear-gradient(180deg, #fff, #fffbf0);
  padding:20px;
  border-radius:18px;
  border:5px solid #000;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  position:relative;
  max-width:78%;
  margin-top:8px;
  font-weight:700;
  transform: rotate(1deg);
}
/* speech tail */
.blurb::after{
  content:'';
  position:absolute;
  left:20px;
  bottom:-22px;
  width:30px;
  height:22px;
  background:#fff;
  border-left:5px solid #000;
  border-bottom:5px solid #000;
  transform:skewX(-18deg) rotate(12deg);
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}

/* right column: portrait-style card */
.card{
  height:100%;
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:center;
  justify-content:flex-start;
  padding:20px;
  border-radius:16px;
  background: 
    radial-gradient(circle at 20% 30%, rgba(0,0,0,0.03) 2px, transparent 2px),
    radial-gradient(circle at 80% 70%, rgba(0,0,0,0.03) 2px, transparent 2px),
    linear-gradient(180deg,#fff,#fffaf7);
  background-size: auto, auto, 100%;
  background-position: 0 0, 0 0, 0 0;
  border:5px solid #000;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.3);
  transform:rotate(-6deg);
}
.portrait{
  width:200px;
  height:200px;
  border-radius:16px;
  background: 
    repeating-linear-gradient(135deg, rgba(0,0,0,0.04) 0 8px, transparent 8px 16px),
    linear-gradient(135deg, rgba(236,72,153,0.15), rgba(139,92,246,0.15), rgba(14,165,233,0.15));
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.4);
  border:6px solid var(--accent-4);
  transform:rotate(8deg) translateY(-10px);
}
.portrait::before{
  content: '';
  position: absolute;
  inset: -10%;
  background: radial-gradient(circle at 30% 30%, transparent 40%, rgba(255,255,255,0.3) 40%, rgba(255,255,255,0.3) 42%, transparent 42%);
  pointer-events: none;
  z-index: 1;
}
.portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:10px;
  transform:rotate(-8deg);
  filter: contrast(1.1) saturate(1.2);
}
.portrait-fallback{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:var(--accent);
  font-size:72px;
  text-shadow: 
    -3px -3px 0 #000,
    4px 4px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
}
.meta{
  text-align:center;
  color:var(--muted);
  font-size:14px;
  font-weight:800;
}
.taglist{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:8px;
}
.tag{
  color:#fff;
  padding:8px 14px;
  border-radius:14px;
  font-weight:900;
  font-size:12px;
  border:3px solid #000;
  transform:skewX(-8deg) rotate(-2deg);
  box-shadow: 3px 3px 0 rgba(0,0,0,0.4);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-shadow: 1px 1px 0 rgba(0,0,0,0.3);
}
.tag:nth-child(1){background:linear-gradient(180deg, var(--accent-2), #0a8f45)}
.tag:nth-child(2){background:linear-gradient(180deg, var(--accent-5), #7c3aed)}
.tag:nth-child(3){background:linear-gradient(180deg, var(--accent-4), #f97316)}
.tag:nth-child(4){background:linear-gradient(180deg, var(--accent-6), #0284c7)}
.tag:nth-child(5){background:linear-gradient(180deg, var(--accent-7), #db2777)}

/* Reference Guide */
.reference-guide{
  background: 
    repeating-linear-gradient(0deg, transparent 0 6px, rgba(0,0,0,0.02) 6px 12px),
    linear-gradient(180deg, #fffefb, #fff7f0);
  border: 6px solid #000;
  border-radius: var(--radius);
  padding: 28px;
  margin-top: 18px;
  box-shadow: 10px 10px 0 rgba(0,0,0,0.3);
  position: relative;
  transform: rotate(1deg);
}
.reference-guide::before{
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(0,0,0,0.08) 2px, transparent 2px),
    radial-gradient(circle, rgba(0,0,0,0.05) 1.5px, transparent 1.5px);
  background-size: 28px 28px, 48px 48px;
  background-position: 0 0, 14px 14px;
  opacity: 0.2;
  pointer-events: none;
  border-radius: var(--radius);
}
.guide-title{
  font-size: 28px;
  font-weight: 900;
  color: var(--accent);
  text-align: center;
  margin: 0 0 24px 0;
  letter-spacing: 2px;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
  text-transform: uppercase;
}
.guide-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  position: relative;
  z-index: 1;
}
.guide-item{
  background: 
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 14px 18px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
  transform: skewX(-3deg) rotate(-1deg);
  font-weight: 700;
}
.guide-item:nth-child(odd){
  transform: skewX(-3deg) rotate(1deg);
}
.guide-item strong{
  display: block;
  margin-bottom: 6px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 13px;
}
.guide-item:nth-child(4n+1) strong{color: var(--accent-2)}
.guide-item:nth-child(4n+2) strong{color: var(--accent-5)}
.guide-item:nth-child(4n+3) strong{color: var(--accent-4)}
.guide-item:nth-child(4n) strong{color: var(--accent-6)}

/* footer */
.pager{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 14px;
  background: linear-gradient(135deg, #fff 0%, #fff0f9 30%, #f0f9ff 70%, #fffef0 100%);
  border: 5px solid #000;
  border-radius: 16px;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  transform: rotate(1deg);
}
#progress{
  color:var(--muted); 
  font-weight:900;
  font-size: 16px;
  text-shadow: 2px 2px 0 rgba(255,255,255,0.8);
}
.dots{display:flex;gap:10px}
.dot{
  width:16px;
  height:16px;
  border-radius:999px;
  background:linear-gradient(180deg, #fff, #ffeeee);
  cursor:pointer;
  border:3px solid #000;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
  transition: transform 0.1s ease;
}
.dot:hover{
  transform: scale(1.15);
}
.dot.active{
  background:linear-gradient(180deg, var(--accent), #a01f1f); 
  border-color:#000;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.4), inset 0 2px 4px rgba(0,0,0,0.3);
}

/* small / responsive */
/* Quiz Section */
.quiz-section{
  background: 
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(0,0,0,0.02) 8px 16px),
    linear-gradient(180deg, #fffefb, #fff7f0);
  border: 6px solid #000;
  border-radius: var(--radius);
  padding: 32px;
  margin-top: 18px;
  box-shadow: 10px 10px 0 rgba(0,0,0,0.3);
  position: relative;
  transform: rotate(-1deg);
}
.quiz-title{
  font-size: 32px;
  font-weight: 900;
  color: var(--accent);
  text-align: center;
  margin: 0 0 12px 0;
  letter-spacing: 2px;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
  text-transform: uppercase;
}
.quiz-subtitle{
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 28px 0;
}
.question-card{
  background: 
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 24px;
  border-radius: 16px;
  border: 5px solid #000;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  margin-bottom: 24px;
  transform: rotate(1deg);
}
.question-number{
  display: inline-block;
  background: linear-gradient(90deg, var(--accent), #a01f1f);
  color: #fff;
  padding: 8px 16px;
  border-radius: 12px;
  font-weight: 900;
  font-size: 14px;
  margin-bottom: 14px;
  border: 3px solid #000;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.3);
  transform: skewX(-8deg);
  text-shadow: 2px 2px 0 rgba(0,0,0,0.3);
}
.question-quote{
  background: 
    repeating-linear-gradient(90deg, transparent 0 3px, rgba(0,0,0,0.02) 3px 6px),
    linear-gradient(180deg, #fff, #fffbf0);
  padding: 18px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  font-size: 17px;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 18px;
  font-style: italic;
  position: relative;
  transform: rotate(-1deg);
}
.question-quote::before{
  content: '"';
  font-size: 48px;
  position: absolute;
  left: 8px;
  top: -8px;
  color: var(--accent-3);
  font-weight: 900;
  text-shadow: 2px 2px 0 #000;
  -webkit-text-stroke: 1px #000;
}
.quiz-options{
  display: grid;
  gap: 12px;
}
.quiz-option{
  background: linear-gradient(180deg, #fff, #fffaf0);
  border: 4px solid #000;
  border-radius: 14px;
  padding: 16px 20px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s ease;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  transform: skewX(-2deg);
  text-align: left;
  color: var(--muted);
}
.quiz-option:hover:not(.disabled){
  transform: translateY(-3px) skewX(-2deg);
  box-shadow: 5px 8px 0 rgba(0,0,0,0.3);
  background: linear-gradient(180deg, #fffef0, #fff7e0);
}
.quiz-option:active:not(.disabled){
  transform: translateY(1px) skewX(-2deg);
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
}
.quiz-option.correct{
  background: linear-gradient(180deg, var(--accent-2), #0a8f45);
  color: #fff;
  border-color: #000;
  text-shadow: 1px 1px 0 rgba(0,0,0,0.3);
}
.quiz-option.incorrect{
  background: linear-gradient(180deg, #ffcccc, #ff9999);
  border-color: #000;
}
.quiz-option.disabled{
  cursor: not-allowed;
  opacity: 0.6;
}
.quiz-feedback{
  margin-top: 16px;
  padding: 14px 18px;
  border-radius: 12px;
  font-weight: 900;
  font-size: 15px;
  text-align: center;
  border: 4px solid #000;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.3);
  transform: skewX(-3deg);
}
.quiz-feedback.correct{
  background: linear-gradient(90deg, var(--accent-2), #0fb356);
  color: #fff;
  text-shadow: 1px 1px 0 rgba(0,0,0,0.3);
}
.quiz-feedback.incorrect{
  background: linear-gradient(90deg, var(--accent), #d12727);
  color: #fff;
  text-shadow: 1px 1px 0 rgba(0,0,0,0.3);
}
.quiz-next-btn{
  margin-top: 16px;
  background: linear-gradient(180deg, var(--accent-3), #ffcc00);
  border: 4px solid #000;
  border-radius: 14px;
  padding: 12px 28px;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  transform: skewX(-6deg);
  transition: all 0.12s ease;
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.quiz-next-btn:hover{
  transform: translateY(-3px) skewX(-6deg);
  box-shadow: 5px 8px 0 rgba(0,0,0,0.3);
}
.quiz-next-btn:active{
  transform: translateY(1px) skewX(-6deg);
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
}
.quiz-result{
  background: 
    radial-gradient(circle at 20% 30%, rgba(0,0,0,0.03) 2px, transparent 2px),
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 32px;
  border-radius: 18px;
  border: 6px solid #000;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.3);
  text-align: center;
  transform: rotate(-2deg);
}
.quiz-result h3{
  font-size: 36px;
  font-weight: 900;
  color: var(--accent);
  margin: 0 0 16px 0;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
}
.quiz-result .score{
  font-size: 64px;
  font-weight: 900;
  color: var(--accent-2);
  margin: 16px 0;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
}
.quiz-result .message{
  font-size: 18px;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.6;
  margin: 20px 0;
  background: 
    linear-gradient(180deg, #fffef0, #fff7e0);
  padding: 20px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
}
.quiz-restart-btn{
  margin-top: 20px;
  background: linear-gradient(180deg, var(--accent), #a01f1f);
  color: #fff;
  border: 4px solid #000;
  border-radius: 14px;
  padding: 14px 32px;
  font-size: 18px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  transform: skewX(-6deg);
  transition: all 0.12s ease;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-shadow: 2px 2px 0 rgba(0,0,0,0.3);
}
.quiz-restart-btn:hover{
  transform: translateY(-3px) skewX(-6deg);
  box-shadow: 5px 8px 0 rgba(0,0,0,0.3);
}
.quiz-restart-btn:active{
  transform: translateY(1px) skewX(-6deg);
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
}

/* Personality Quiz Styles */
.personality-quiz-section{
  margin-top: 18px;
}
.personality-option{
  text-align: left;
  padding: 18px 20px;
}
.personality-option strong{
  display: block;
  margin-bottom: 6px;
  color: var(--accent);
  font-size: 15px;
}
.personality-match{
  font-size: 56px;
  font-weight: 900;
  color: var(--accent);
  margin: 24px 0;
  text-shadow: 
    5px 5px 0 #000,
    6px 6px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
}
.personality-description{
  font-size: 20px;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.6;
  margin: 24px 0;
  background: 
    linear-gradient(180deg, #fffef0, #fff7e0);
  padding: 24px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
}
.personality-stats{
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-2);
  margin: 16px 0 24px 0;
  padding: 14px;
  background: linear-gradient(180deg, #fff, #f0fff0);
  border-radius: 12px;
  border: 3px solid #000;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.3);
}

/* Perfect Dinner Form */
.form-section{
  background: 
    repeating-linear-gradient(0deg, transparent 0 2px, rgba(0,0,0,0.015) 2px 4px),
    linear-gradient(180deg, #fffefb, #fffffb);
  border: 6px solid #000;
  border-radius: var(--radius);
  padding: 32px;
  margin-top: 18px;
  box-shadow: 10px 10px 0 rgba(0,0,0,0.3);
  position: relative;
  transform: rotate(0deg);
}
.form-title{
  font-size: 32px;
  font-weight: 900;
  color: var(--accent);
  text-align: center;
  margin: 0 0 12px 0;
  letter-spacing: 2px;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
  text-transform: uppercase;
}
.form-subtitle{
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 32px 0;
}
.dinner-form{
  max-width: 900px;
  margin: 0 auto;
}
.form-section-block{
  background: 
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 28px;
  border-radius: 16px;
  border: 5px solid #000;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  margin-bottom: 24px;
  transform: rotate(-0.5deg);
}
.form-section-block:nth-child(even){
  transform: rotate(0.5deg);
}
.section-heading{
  font-size: 28px;
  font-weight: 900;
  color: var(--accent-2);
  margin: 0 0 20px 0;
  text-shadow: 
    3px 3px 0 #000,
    4px 4px 0 var(--accent-3);
  -webkit-text-stroke: 1.5px #000;
  transform: skewX(-3deg);
}
.form-group{
  margin-bottom: 24px;
}
.form-group:last-child{
  margin-bottom: 0;
}
.form-group > label{
  display: block;
  font-size: 16px;
  font-weight: 900;
  color: var(--muted);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.form-group input[type="text"],
.form-group textarea{
  width: 100%;
  padding: 14px 18px;
  border: 4px solid #000;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  background: linear-gradient(180deg, #fff, #fffef5);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.2);
  color: var(--muted);
  transition: all 0.15s ease;
}
.form-group input[type="text"]:focus,
.form-group textarea:focus{
  outline: none;
  border-color: var(--accent-2);
  box-shadow: 6px 6px 0 rgba(0,0,0,0.3);
  transform: translateY(-2px);
}
.form-group textarea{
  resize: vertical;
  min-height: 80px;
}
.radio-group,
.checkbox-group{
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.radio-label,
.checkbox-label{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: linear-gradient(180deg, #fff, #fffef5);
  border: 4px solid #000;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.15s ease;
  font-weight: 700;
  color: var(--muted);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.2);
  transform: skewX(-1deg);
}
.radio-label:hover,
.checkbox-label:hover{
  background: linear-gradient(180deg, #fffef0, #fff7e0);
  transform: translateY(-2px) skewX(-1deg);
  box-shadow: 4px 6px 0 rgba(0,0,0,0.3);
}
.radio-label input[type="radio"],
.checkbox-label input[type="checkbox"]{
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: var(--accent-2);
}
.radio-label span,
.checkbox-label span{
  flex: 1;
}
.form-submit-btn{
  width: 100%;
  padding: 20px 32px;
  background: linear-gradient(180deg, var(--accent), #a01f1f);
  color: #fff;
  border: 5px solid #000;
  border-radius: 16px;
  font-size: 24px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.4);
  transform: skewX(-3deg);
  transition: all 0.15s ease;
  text-transform: uppercase;
  letter-spacing: 2px;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.3);
  margin-top: 32px;
}
.form-submit-btn:hover{
  transform: translateY(-4px) skewX(-3deg);
  box-shadow: 8px 12px 0 rgba(0,0,0,0.4);
  background: linear-gradient(180deg, #e02828, #8f1b1b);
}
.form-submit-btn:active{
  transform: translateY(2px) skewX(-3deg);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.4);
}
.form-result{
  background: 
    radial-gradient(circle at 20% 30%, rgba(0,0,0,0.03) 2px, transparent 2px),
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 32px;
  border-radius: 18px;
  border: 6px solid #000;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.3);
  text-align: center;
  transform: rotate(-1deg);
}
.form-result h3{
  font-size: 36px;
  font-weight: 900;
  color: var(--accent);
  margin: 0 0 24px 0;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
}
.form-summary{
  background: 
    linear-gradient(180deg, #fffef0, #fff7e0);
  padding: 24px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  text-align: left;
  margin-bottom: 24px;
}
.summary-item{
  font-size: 16px;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 3px dashed rgba(0,0,0,0.15);
}
.summary-item:last-child{
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.summary-item strong{
  color: var(--accent-2);
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: 0.5px;
}
.summary-highlight{
  background: linear-gradient(90deg, var(--accent-3), #ffee55);
  padding: 18px 24px;
  border-radius: 12px;
  border: 4px solid #000;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.3);
  font-size: 18px;
  font-weight: 900;
  font-style: italic;
  color: #000;
  margin-top: 16px;
  transform: skewX(-2deg);
}

/* Glossary Section */
.glossary-section{
  background: 
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(0,0,0,0.02) 8px 16px),
    linear-gradient(180deg, #fffefb, #fff7f0);
  border: 6px solid #000;
  border-radius: var(--radius);
  padding: 32px;
  margin-top: 18px;
  box-shadow: 10px 10px 0 rgba(0,0,0,0.3);
  position: relative;
  transform: rotate(-1deg);
}
.glossary-title{
  font-size: 32px;
  font-weight: 900;
  color: var(--accent-5);
  text-align: center;
  margin: 0 0 12px 0;
  letter-spacing: 2px;
  text-shadow: 
    4px 4px 0 #000,
    5px 5px 0 var(--accent-3);
  -webkit-text-stroke: 2px #000;
  transform: skewX(-4deg);
  text-transform: uppercase;
}
.glossary-subtitle{
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 28px 0;
}
.glossary-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  position: relative;
  z-index: 1;
}
.glossary-term{
  background: 
    linear-gradient(180deg, #fff, #fffdf5);
  padding: 18px 22px;
  border-radius: 14px;
  border: 4px solid #000;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
  transform: skewX(-2deg) rotate(-1deg);
  transition: all 0.15s ease;
}
.glossary-term:nth-child(even){
  transform: skewX(-2deg) rotate(1deg);
}
.glossary-term:hover{
  transform: translateY(-3px) skewX(-2deg) rotate(-1deg);
  box-shadow: 5px 8px 0 rgba(0,0,0,0.3);
}
.term-word{
  display: inline-block;
  background: linear-gradient(90deg, var(--accent-6), var(--accent-5));
  color: #fff;
  padding: 8px 14px;
  border-radius: 10px;
  font-weight: 900;
  font-size: 16px;
  margin-bottom: 10px;
  border: 3px solid #000;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
  text-shadow: 2px 2px 0 rgba(0,0,0,0.3);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.term-definition{
  font-size: 15px;
  line-height: 1.5;
  color: var(--muted);
  font-weight: 700;
}

@media (max-width:820px){
  .slide{grid-template-columns:1fr; padding:20px; border-width:4px; max-height:800px}
  .card{flex-direction:row; gap:14px; padding:16px; align-items:center; transform:rotate(-3deg)}
  .portrait{width:120px;height:120px;font-size:40px;border-radius:14px; transform:rotate(4deg)}
  .role{font-size:32px}
  .blurb{font-size:15px; max-width:100%}
  .topbar .title{font-size:16px}
  .guide-grid{grid-template-columns:1fr}
  .guide-title{font-size:22px}
}

/* Tree banner - composed of character portraits as ornaments */
.tree-banner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
  padding:18px 0 0 0;
  position:relative;
  transform: translateY(-10px);
}
.tree-star{
  font-size:40px;
  color: #ffdd55;
  text-shadow: 3px 3px 0 #000;
  -webkit-text-stroke: 1px #000;
  transform: rotate(-8deg);
}
.tree-row{
  display:flex;
  gap:12px;
  justify-content:center;
  align-items:center;
}
.tree-img{
  width:96px;
  height:96px;
  object-fit:cover;
  border-radius:14px;
  border:5px solid #000;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.28);
  transform: rotate(-6deg);
  background: #fff;
}
.tree-row.row-1 .tree-img{width:120px;height:120px; transform: rotate(-4deg); border-radius:18px}
.tree-row.row-2 .tree-img{width:108px;height:108px}
.tree-row.row-3 .tree-img{width:96px;height:96px}
.tree-row.row-4 .tree-img{width:84px;height:84px}
.tree-row.row-5 .tree-img{width:72px;height:72px}

.tree-trunk{
  width:84px;
  height:40px;
  background:linear-gradient(180deg,#8b4b2a,#5a2e14);
  border-radius:10px;
  margin-top:8px;
  border:5px solid #000;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.32);
  transform: rotate(2deg);
}

/* make banner responsive */
@media (max-width:820px){
  .tree-img{width:72px;height:72px}
  .tree-row.row-1 .tree-img{width:96px;height:96px}
  .tree-row.row-2 .tree-img{width:84px;height:84px}
  .tree-row.row-3 .tree-img{width:72px;height:72px}
  .tree-row.row-4 .tree-img{width:60px;height:60px}
  .tree-row.row-5 .tree-img{width:48px;height:48px}
  .tree-star{font-size:28px}
}

