/* 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; }
