/* APP PAGE */
.fz-app { max-width: 620px; margin: 0 auto; padding: 40px 24px; }
.fz-app-title { font-size: 36px; font-weight: 900; color: #e8855a; text-align: center; margin-bottom: 6px; }
.fz-app-sub { font-size: 16px; color: #a0613a; font-weight: 500; text-align: center; margin-bottom: 32px; line-height: 1.6; }

/* FORM */
.fz-form { background: #fff8f4; border: 2.5px solid #f4b183; border-radius: 20px; padding: 28px; }
.fz-field { margin-bottom: 24px; }
.fz-label { font-size: 18px; font-weight: 900; color: #c47a55; display: block; margin-bottom: 10px; }
.fz-label-hint { font-size: 13px; font-weight: 600; color: #e8a070; }
.fz-input { width: 100%; padding: 12px 16px; border: 2px solid #f4b183; border-radius: 12px; font-family: 'Nunito', sans-serif; font-size: 16px; background: #fef6ef; color: #6b3a1f; outline: none; transition: border-color 0.15s; }
.fz-input:focus { border-color: #e8855a; }
.fz-options { display: flex; flex-wrap: wrap; gap: 8px; }
.fz-opt { padding: 9px 18px; border: 2px solid #f4b183; border-radius: 50px; font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700; color: #c47a55; background: #fef6ef; cursor: pointer; transition: all 0.15s; user-select: none; }
.fz-opt:hover { background: #fde8d5; }
.fz-opt.selected { background: #e8855a; color: #fff; border-color: #e8855a; }
.fz-opt.teal { border-color: #7ecdc4; color: #3a9e96; }
.fz-opt.teal:hover { background: #e8f5f5; }
.fz-opt.teal.selected { background: #7ecdc4; color: #fff; border-color: #7ecdc4; }
.fz-go { width: 100%; padding: 16px; background: #e8855a; color: #fff; border: none; border-radius: 50px; font-family: 'Nunito', sans-serif; font-size: 22px; font-weight: 900; cursor: pointer; margin-top: 8px; transition: background 0.15s, transform 0.1s; letter-spacing: 0.5px; }
.fz-go:hover { background: #d4704a; transform: scale(1.02); }
.fz-error { background: #fff0ee; border: 2px solid #e8855a; border-radius: 12px; padding: 12px 16px; color: #c47a55; font-size: 14px; font-weight: 700; text-align: center; margin-top: 12px; display: none; }
.fz-error.show { display: block; }

/* LOADING */
.fz-loading { text-align: center; padding: 60px 32px; display: none; }
.fz-loading.show { display: block; }
.fz-bubble-anim { font-size: 48px; animation: bounce 0.8s infinite alternate; display: inline-block; margin-bottom: 16px; }
@keyframes bounce { from { transform: translateY(0); } to { transform: translateY(-10px); } }
.fz-loading-text { font-size: 24px; font-weight: 900; color: #e8855a; }

/* RESULTS */
.fz-results { display: none; }
.fz-results.show { display: block; }
.fz-results-title { font-size: 32px; font-weight: 900; color: #e8855a; text-align: center; margin-bottom: 4px; }
.fz-results-sub { font-size: 16px; color: #a0613a; font-weight: 600; text-align: center; margin-bottom: 28px; }

/* ACTIVITY CARDS */
.fz-card { background: #fff8f4; border: 3px solid #f4b183; border-radius: 20px; padding: 24px; margin-bottom: 20px; page-break-inside: avoid; }
.fz-card:nth-child(even) { border-color: #7ecdc4; }
.fz-card-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.fz-card-num { width: 36px; height: 36px; border-radius: 50%; background: #e8855a; color: #fff; font-size: 18px; font-weight: 900; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.fz-card:nth-child(even) .fz-card-num { background: #7ecdc4; }
.fz-card-title { font-size: 22px; font-weight: 900; color: #e8855a; }
.fz-card:nth-child(even) .fz-card-title { color: #3a9e96; }
.fz-card-desc { font-size: 15px; color: #a0613a; font-weight: 500; line-height: 1.7; margin-bottom: 14px; }
.fz-card-steps { padding: 14px 16px; background: #fef6ef; border-radius: 12px; margin-bottom: 12px; }
.fz-card-steps-title { font-size: 13px; font-weight: 900; color: #c47a55; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.fz-card-steps ol { padding-left: 20px; }
.fz-card-steps li { font-size: 14px; color: #6b3a1f; font-weight: 600; line-height: 1.6; margin-bottom: 4px; }
.fz-card-tip { background: #fff8f0; border-left: 4px solid #e8855a; border-radius: 0 12px 12px 0; padding: 10px 14px; font-size: 14px; color: #a0613a; font-weight: 600; }
.fz-card-tip strong { color: #e8855a; }
.fz-card:nth-child(even) .fz-card-tip { border-left-color: #7ecdc4; }
.fz-card:nth-child(even) .fz-card-tip strong { color: #3a9e96; }

/* RESULT ACTIONS */
.fz-result-actions { display: flex; gap: 12px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.fz-print-btn { background: #e8855a; color: #fff; border: none; border-radius: 50px; padding: 12px 28px; font-family: 'Nunito', sans-serif; font-size: 16px; font-weight: 800; cursor: pointer; transition: background 0.15s; }
.fz-print-btn:hover { background: #d4704a; }
.fz-reset { background: #fef6ef; color: #e8855a; border: 3px solid #e8855a; border-radius: 50px; padding: 12px 28px; font-family: 'Nunito', sans-serif; font-size: 16px; font-weight: 800; cursor: pointer; transition: background 0.15s; }
.fz-reset:hover { background: #fde8d5; }

/* PRINT STYLES */
@media print {
  .fz-nav, .fz-result-actions, .fz-footer, .fz-form-wrap, .fz-loading, .fz-app-title, .fz-app-sub, .fz-results-sub { display: none !important; }
  body { background: #fff; }
  .fz-app { padding: 0; max-width: 100%; }
  .fz-results { display: block !important; }
  .fz-results-title { font-size: 28px; color: #e8855a; text-align: center; margin-bottom: 6px; }

  .fz-print-header { display: block !important; text-align: center; margin-bottom: 20px; border-bottom: 3px solid #e8855a; padding-bottom: 16px; }
  .fz-print-logo { font-size: 32px; font-weight: 900; color: #e8855a; letter-spacing: -1px; }
  .fz-print-tag { font-size: 13px; color: #c47a55; font-weight: 700; }

  .fz-card { border: 2px solid #f4b183 !important; border-radius: 12px; padding: 16px; margin-bottom: 16px; break-inside: avoid; }
  .fz-card:nth-child(even) { border-color: #7ecdc4 !important; }
  .fz-card-title { font-size: 18px; }
  .fz-card-desc { font-size: 13px; }
  .fz-card-steps li { font-size: 13px; }
  .fz-card-tip { font-size: 12px; }

  .fz-print-footer { display: block !important; text-align: center; margin-top: 20px; border-top: 2px dashed #f4b183; padding-top: 12px; font-size: 11px; color: #c47a55; font-weight: 600; }
}

.fz-print-header, .fz-print-footer { display: none; }

/* ACCESS CODE */
.fz-access-note { font-size:13px; color:#a0613a; text-align:center; margin-top:12px; }
.fz-access-note a { color:#e8855a; }
.fz-code-input { font-size:18px!important; font-weight:900!important; text-align:center; letter-spacing:2px; }

/* ROLE CARDS */
.fz-toggle-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fz-role-card { background:#fff8f4; border:2.5px solid #f4b183; border-radius:16px; padding:24px 16px; text-align:center; cursor:pointer; transition:all 0.15s; }
.fz-role-card:hover { border-color:#e8855a; transform:translateY(-2px); }
.fz-role-card.active { background:#e8855a; border-color:#e8855a; }
.fz-role-card.active .fz-role-title { color:#fff; }
.fz-role-card.active .fz-role-desc { color:#fde8d5; }
.fz-role-icon { font-size:36px; margin-bottom:8px; }
.fz-role-title { font-size:20px; font-weight:900; color:#e8855a; margin-bottom:4px; }
.fz-role-desc { font-size:13px; color:#a0613a; font-weight:500; }

/* DISABLED YEAR GROUPS */
.fz-opt.disabled { opacity:0.3; text-decoration:line-through; cursor:not-allowed; }

/* SUPERVISION WARNING */
.fz-supervision-warning { background:#fff8f0; border:2px solid #e8855a; border-radius:12px; padding:12px 14px; font-size:13px; color:#a0613a; line-height:1.6; margin-top:10px; }

/* CHILD-LED BUTTON */
.fz-child-led-btn { background:#f0fafa; color:#3a9e96; border:2px solid #7ecdc4; border-radius:50px; padding:8px 18px; font-family:'Nunito',sans-serif; font-size:13px; font-weight:800; cursor:pointer; margin-top:10px; transition:background 0.15s; }
.fz-child-led-btn:hover { background:#e0f4f4; }
.fz-child-led-btn:disabled { opacity:0.5; cursor:not-allowed; }

/* EMAIL SECTION */
.fz-email-section { margin:20px 0; }
.fz-email-box { background:#fff8f4; border:2.5px solid #f4b183; border-radius:16px; padding:20px; }
.fz-email-title { font-size:16px; font-weight:900; color:#e8855a; margin-bottom:6px; }
.fz-email-note { font-size:13px; color:#a0613a; margin-bottom:10px; line-height:1.5; }
.fz-email-btn { width:100%; padding:12px; background:#e8855a; color:#fff; border:none; border-radius:50px; font-family:'Nunito',sans-serif; font-size:16px; font-weight:800; cursor:pointer; margin-top:10px; transition:background 0.15s; }
.fz-email-btn:hover { background:#d4704a; }
.fz-email-btn:disabled { background:#f4b183; cursor:not-allowed; }
.fz-email-success { background:#e8f5f0; border:2px solid #7ecdc4; border-radius:10px; padding:10px 14px; font-size:14px; font-weight:700; color:#3a9e96; text-align:center; margin-top:10px; }

/* AI DISCLAIMER */
.fz-ai-disclaimer { background:#f0fafa; border:1.5px solid #7ecdc4; border-radius:12px; padding:12px 14px; font-size:12px; color:#3a9e96; line-height:1.6; margin:16px 0; }

/* BACK BUTTON */
.fz-back-btn { display:block; width:100%; padding:10px; background:none; border:2px solid #f4b183; border-radius:50px; font-family:'Nunito',sans-serif; font-size:15px; font-weight:800; color:#c47a55; cursor:pointer; margin-top:10px; transition:background 0.15s; }
.fz-back-btn:hover { background:#fde8d5; }
