/* =============================================================================
   ADHDity — 12-tool.css
   Sections: 30. Tool Base · 31. Result Cards · 32. Clickable Steps
   ============================================================================= */


/* 30. TOOL PAGE — Base
   ============================================================================= */

.adhdity-tool {
  --bg: #FAFAF7; --surface: #FFFFFF; --surface-alt: #F4F3EF; --border: #E9E7E0;
  --text: #1D1B16; --text-mid: #5C5950; --text-soft: #5C5950;
  --accent: #4A7C59; --accent-light: #E8F0EA; --accent-mid: #3D6A4A;
  --warm: #C4882F; --warm-bg: #FEF6EA; --rose: #C0605B; --rose-bg: #FCEEED;
  --sky: #5B8FA8; --sky-bg: #EBF3F7; --pill-bg: #F0EEE8;
  --tip-bg: #FFF9EE; --tip-border: #F0DFB8; --tip-text: #8A6D2F;
  --shadow-sm: 0 1px 3px rgba(29,27,22,.04), 0 4px 12px rgba(29,27,22,.04);
  --shadow-md: 0 2px 8px rgba(29,27,22,.05), 0 12px 40px rgba(29,27,22,.08);
  --shadow-glow: 0 0 0 4px rgba(74,124,89,.12);
  --r: 20px; --r-pill: 60px;
  --font-body: "DM Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-display: "Fraunces", Georgia, serif;
  --ease: cubic-bezier(.22,.68,0,1);
  font-family: var(--font-body); color: var(--text); line-height: 1.55;
  -webkit-font-smoothing: antialiased; background: transparent;
}

.adhdity-tool, .adhdity-tool * { box-sizing: border-box; }
.adhdity-tool button { font-family: inherit; }

.adhdity-tool .app { max-width: 600px; margin: 0 auto; padding: 10px; position: relative; }
.adhdity-tool .app::before { content: ''; position: absolute; inset: -40px -20px -80px -20px; background: radial-gradient(ellipse at 20% 0%, rgba(74,124,89,.04) 0%, transparent 60%), radial-gradient(ellipse at 80% 100%, rgba(196,136,47,.04) 0%, transparent 60%); pointer-events: none; z-index: -1; }

.adhdity-tool .header { text-align: center; margin-bottom: 44px; }
.adhdity-tool .header-icon { font-size: 56px; display: block; margin-bottom: 8px; filter: drop-shadow(0 4px 12px rgba(0,0,0,.08)); }
.adhdity-tool .header h1 { font-family: var(--font-display); font-size: 2rem; font-weight: 800; color: var(--text); letter-spacing: -.03em; margin-bottom: 6px; line-height: 1.15; }
.adhdity-tool .header p { font-size: 1.1rem; color: var(--text-soft); font-weight: 400; }
.adhdity-tool .section-label { font-size: .85rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--text-soft); margin-bottom: 16px; }

/* Ingredients grid */
.adhdity-tool .ingredients-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-bottom: 28px; }

.adhdity-tool .ing-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 20px 8px 16px; background: var(--surface); border: 2px solid var(--border); border-radius: var(--r); cursor: pointer; transition: all .25s var(--ease); user-select: none; -webkit-tap-highlight-color: transparent; min-height: 110px; position: relative; box-shadow: var(--shadow-sm); }
.adhdity-tool .ing-btn .emoji { font-size: 2.6rem; line-height: 1; transition: transform .3s var(--ease); display: block; }
.adhdity-tool .ing-btn .label { font-size: .95rem; font-weight: 500; color: var(--text-mid); text-align: center; line-height: 1.2; transition: color .25s var(--ease); }
.adhdity-tool .ing-btn:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.adhdity-tool .ing-btn:active { transform: scale(.96); transition-duration: .1s; }
.adhdity-tool .ing-btn.selected { background: var(--accent-light); border-color: var(--accent); box-shadow: var(--shadow-glow); }
.adhdity-tool .ing-btn.selected .emoji { transform: scale(1.15); }
.adhdity-tool .ing-btn.selected .label { color: var(--accent-mid); font-weight: 600; }

.adhdity-tool .ing-btn .check { position: absolute; top: 8px; right: 8px; width: 24px; height: 24px; border-radius: 50%; background: var(--accent); display: flex; align-items: center; justify-content: center; opacity: 0; transform: scale(.5); transition: all .25s var(--ease); }
.adhdity-tool .ing-btn .check svg { width: 14px; height: 14px; stroke: #fff; stroke-width: 2.5; fill: none; }
.adhdity-tool .ing-btn.selected .check { opacity: 1; transform: scale(1); }

.adhdity-tool .selection-info { text-align: center; font-size: 1rem; color: var(--text-soft); margin-bottom: 20px; min-height: 26px; transition: opacity .25s; font-weight: 400; }
.adhdity-tool .selection-info span { font-weight: 700; color: var(--accent); }

.adhdity-tool .cta-btn { display: block; width: 100%; padding: 22px 32px; font-size: 1.2rem; font-weight: 700; color: #fff; background: var(--accent); border: none; border-radius: var(--r-pill); cursor: pointer; transition: all .25s var(--ease); box-shadow: 0 4px 20px rgba(74,124,89,.3); letter-spacing: -.01em; margin-bottom: 12px; }
.adhdity-tool .cta-btn:hover:not(:disabled) { background: var(--accent-mid); transform: translateY(-2px); box-shadow: 0 8px 32px rgba(74,124,89,.35); }
.adhdity-tool .cta-btn:active:not(:disabled) { transform: scale(.98); }
.adhdity-tool .cta-btn:disabled { background: var(--border); color: var(--text-soft); cursor: not-allowed; box-shadow: none; }

.adhdity-tool .clear-btn { display: none; margin: 0 auto 8px; background: none; border: none; font-size: .95rem; color: var(--text-soft); cursor: pointer; padding: 8px 20px; border-radius: var(--r-pill); transition: all .2s; font-weight: 500; }
.adhdity-tool .clear-btn:hover { color: var(--rose); background: var(--rose-bg); }
.adhdity-tool .clear-btn.visible { display: block; }

.adhdity-tool .nothing-btn { display: flex; align-items: center; gap: 14px; width: 100%; padding: 16px 20px; margin-top: 4px; margin-bottom: 24px; background: var(--surface); border: 2px dashed var(--border); border-radius: var(--r); cursor: pointer; transition: all .25s var(--ease); -webkit-tap-highlight-color: transparent; text-align: left; box-shadow: none; }
.adhdity-tool .nothing-btn:hover { border-color: var(--warm); background: var(--warm-bg); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.adhdity-tool .nothing-btn:active { transform: scale(.98); }
.adhdity-tool .nothing-btn .nothing-emoji { font-size: 2rem; flex-shrink: 0; }
.adhdity-tool .nothing-btn .nothing-text { font-size: 1.05rem; font-weight: 700; color: var(--text); display: block; line-height: 1.2; }
.adhdity-tool .nothing-btn .nothing-sub { font-size: .85rem; font-weight: 400; color: var(--text-soft); display: block; line-height: 1.3; }
.adhdity-tool .nothing-btn.active { border-color: var(--warm); border-style: solid; background: var(--warm-bg); }

.adhdity-tool .app-footer { text-align: center; margin-top: 52px; font-size: 1rem; color: var(--text-soft); font-weight: 400; letter-spacing: .01em; }

@media (max-width: 420px) {
  .adhdity-tool .ingredients-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 8px !important; }
  .adhdity-tool .ing-btn { min-height: 92px !important; padding: 14px 6px 12px !important; }
  .adhdity-tool .ing-btn .emoji { font-size: 2rem !important; }
  .adhdity-tool .ing-btn .label { font-size: .78rem !important; line-height: 1.15 !important; }
}


/* 31. TOOL PAGE — Result Cards
   ============================================================================= */

.adhdity-tool .result-area, .adhdity-tool #resultArea { width: 100% !important; max-width: 600px !important; margin: 36px auto 0 !important; display: block !important; }

.adhdity-tool #resultArea > .result-card, .adhdity-tool #resultArea > .grocery-card { width: 100% !important; max-width: 600px !important; min-width: 0 !important; display: block !important; box-sizing: border-box !important; margin: 0 auto !important; background: var(--surface) !important; border-radius: 24px !important; padding: 32px 28px !important; box-shadow: var(--shadow-md) !important; border: 1px solid var(--border) !important; animation: adhdityCardIn .45s var(--ease); }

.adhdity-tool .meal-name { font-family: var(--font-display); font-size: 1.85rem; font-weight: 700; letter-spacing: -.03em; line-height: 1.2; margin: 0 0 8px; color: var(--text); }
.adhdity-tool .meal-vibe { font-size: 1rem; font-style: italic; color: var(--text-soft); margin: 0 0 14px; line-height: 1.55; text-transform: capitalize; }
.adhdity-tool .brain-reason { margin: 0 0 18px; font-size: 1rem; line-height: 1.55; color: var(--accent-mid); font-weight: 600; }
.adhdity-tool .brain-reason strong { color: var(--text); font-weight: 700; }
.adhdity-tool .brain-reason span { text-transform: capitalize; }

.adhdity-tool .meta-row { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 24px; }
.adhdity-tool .meta-pill { display: inline-flex; align-items: center; gap: 6px; font-size: .95rem; font-weight: 600; padding: 8px 16px; border-radius: 999px; background: var(--pill-bg); color: var(--text-mid); white-space: nowrap; }
.adhdity-tool .meta-pill .mi { font-size: 1.15rem; }
.adhdity-tool .meta-pill.mode-shutdown { background: var(--sky-bg); color: var(--sky); }
.adhdity-tool .meta-pill.mode-low { background: var(--warm-bg); color: var(--warm); }
.adhdity-tool .meta-pill.mode-functional { background: var(--accent-light); color: var(--accent-mid); }

.adhdity-tool .card-label, .adhdity-tool .grocery-label { font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; color: var(--text-soft); margin: 0 0 10px; }
.adhdity-tool .card-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 24px; }
.adhdity-tool .card-tag { font-size: 1rem; font-weight: 600; padding: 8px 16px; border-radius: 999px; background: var(--accent-light); color: var(--accent-mid); line-height: 1.2; }

.adhdity-tool .steps-list { list-style: none; margin: 0 0 18px; padding: 0; display: grid; gap: 10px; counter-reset: none; }
.adhdity-tool .steps-list li { margin: 0; padding: 0; border: 0 !important; display: block !important; }
.adhdity-tool .steps-list li::before { content: none !important; display: none !important; }

.adhdity-tool .tip-box { background: var(--tip-bg); border: 1.5px solid var(--tip-border); border-radius: 14px; padding: 14px 16px; margin-bottom: 24px; display: flex; gap: 10px; align-items: flex-start; }
.adhdity-tool .tip-box .tip-icon { font-size: 1.15rem; flex-shrink: 0; line-height: 1.4; }
.adhdity-tool .tip-box .tip-text { font-size: .96rem; line-height: 1.55; color: var(--tip-text); font-weight: 600; }
.adhdity-tool .card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 16px; border-top: 2px dashed var(--border); font-size: .95rem; color: var(--text-soft); font-weight: 500; }

.adhdity-tool .another-btn { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; max-width: 600px; margin: 16px auto 0; padding: 18px 20px; font-size: 1.05rem; font-weight: 600; color: var(--accent-mid); background: var(--accent-light); border: 2px solid transparent; border-radius: var(--r-pill); cursor: pointer; transition: all .25s var(--ease); }
.adhdity-tool .another-btn:hover { border-color: var(--accent); background: #DAE9DC; transform: translateY(-1px); }
.adhdity-tool .another-btn:active { transform: scale(.98); }
.adhdity-tool .another-btn .ri { display: inline-block; transition: transform .4s var(--ease); font-size: 1.25rem; }
.adhdity-tool .another-btn:hover .ri { transform: rotate(180deg); }

.adhdity-tool .no-result { text-align: center; padding: 48px 24px; color: var(--text-soft); font-size: 1.15rem; animation: adhdityCardIn .4s var(--ease); }
.adhdity-tool .no-result .big-emoji { font-size: 3.8rem; display: block; margin-bottom: 14px; }
.adhdity-tool .no-result p { line-height: 1.6; }

.adhdity-tool .grocery-header { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; letter-spacing: -.02em; margin-bottom: 4px; color: var(--text); }
.adhdity-tool .grocery-vibe { font-size: 1rem; font-style: italic; color: var(--text-soft); margin-bottom: 20px; line-height: 1.4; }
.adhdity-tool .grocery-items { list-style: none; margin-bottom: 24px; padding-left: 0; }
.adhdity-tool .grocery-items li { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; font-size: 1.08rem; color: var(--text); border-bottom: 1px solid var(--surface-alt); }
.adhdity-tool .grocery-items li:last-child { border-bottom: none; }
.adhdity-tool .grocery-items .item-name { display: flex; align-items: center; gap: 10px; font-weight: 500; }
.adhdity-tool .grocery-items .item-emoji { font-size: 1.4rem; }
.adhdity-tool .grocery-items .item-price { font-size: .92rem; font-weight: 600; color: var(--text-soft); }
.adhdity-tool .grocery-total { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; margin-bottom: 24px; border-top: 2px solid var(--border); font-size: 1.1rem; font-weight: 700; color: var(--accent-mid); }
.adhdity-tool .grocery-divider { height: 1px; background: var(--border); margin: 4px 0 24px; }

@media (max-width: 640px) {
  .adhdity-tool .result-area, .adhdity-tool #resultArea { max-width: 100% !important; width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; }
  .adhdity-tool #resultArea > .result-card, .adhdity-tool #resultArea > .grocery-card { width: 100% !important; max-width: 100% !important; min-width: 0 !important; border-radius: 20px !important; padding: 24px 18px !important; }
}


/* 32. TOOL PAGE — Clickable Steps
   ============================================================================= */

.adhdity-tool .tool-step-btn { width: 100%; display: flex; align-items: flex-start; gap: 14px; text-align: left; appearance: none; border: 1.5px solid #E7E5E4; background: #FFFFFF; border-radius: 18px; padding: 14px 15px; cursor: pointer; transition: border-color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease; box-shadow: none; }
.adhdity-tool .tool-step-btn:hover { background: #FCFCFD; border-color: #D7DDE5; transform: translateY(-1px); }
.adhdity-tool .tool-step-btn:active { transform: translateY(1px); }

.adhdity-tool .tool-step-btn__num { flex: 0 0 36px; width: 36px; height: 36px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: #F3F4F6; color: #47604C; font-size: 15px; font-weight: 800; line-height: 1; margin-top: 1px; }
.adhdity-tool .tool-step-btn__text { flex: 1 1 auto; min-width: 0; color: var(--text); font-size: 16px; line-height: 1.55; font-weight: 600; }

.adhdity-tool .tool-step-btn.is-start { border-color: #D8E3D8; background: #FCFEFC; }
.adhdity-tool .tool-step-btn.is-start .tool-step-btn__num { background: #E7EEE8; color: #365C3F; }
.adhdity-tool .tool-step-btn.is-active { border-color: #D7E3D9; background: #F9FCF9; box-shadow: 0 0 0 3px rgba(54,92,63,0.05); }
.adhdity-tool .tool-step-btn.is-active .tool-step-btn__num { background: #E3ECE4; color: #2F5E3B; }
.adhdity-tool .tool-step-btn.is-done { background: #F4F7FB; border-color: #D4DCE7; }
.adhdity-tool .tool-step-btn.is-done .tool-step-btn__num { background: #2FA660; color: #FFFFFF; }
.adhdity-tool .tool-step-btn.is-done .tool-step-btn__text { color: #5B6472; text-decoration: line-through; text-decoration-thickness: 1.5px; text-decoration-color: #8B95A5; }

.adhdity-tool .tool-steps-progress { margin-top: 14px; }
.adhdity-tool .tool-steps-progress__row { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.adhdity-tool .tool-steps-progress__text { display: inline-block; font-size: 14px; line-height: 1.3; font-weight: 900; color: #334155; letter-spacing: 0.01em; }
.adhdity-tool .tool-steps-progress__bar { width: 100%; height: 10px; background: #EEF2F6; border-radius: 999px; overflow: hidden; }
.adhdity-tool .tool-steps-progress__fill { display: block; width: 0%; height: 100%; border-radius: 999px; background: #2FA660; transition: width .22s ease; }

.adhdity-tool .tool-steps-reset { appearance: none; border: 1px solid #D8DEE7; background: #FFFFFF; color: #475467; border-radius: 999px; padding: 8px 12px; font-size: 12px; font-weight: 800; line-height: 1; cursor: pointer; transition: background .18s ease, border-color .18s ease, transform .18s ease; }
.adhdity-tool .tool-steps-reset:hover { background: #F8FAFC; border-color: #C9D3E0; }
.adhdity-tool .tool-steps-reset:active { transform: translateY(1px); }

.adhdity-tool .emoji { display: flex; align-items: center; justify-content: center; line-height: 1; }
.adhdity-tool .emoji-img { display: block; width: 36px; height: 36px; }

@media (max-width: 640px) {
  .adhdity-tool .tool-step-btn { gap: 12px; padding: 13px 14px; border-radius: 16px; }
  .adhdity-tool .tool-step-btn__num { width: 34px; height: 34px; flex-basis: 34px; font-size: 14px; }
  .adhdity-tool .tool-step-btn__text { font-size: 15px; line-height: 1.5; }
  .adhdity-tool .tool-steps-progress__text { font-size: 13px; }
  .adhdity-tool .tool-steps-reset { padding: 7px 11px; font-size: 12px; }
}

@media (max-width: 420px) {
  .adhdity-tool .tool-step-btn { padding: 12px 12px; gap: 10px; }
  .adhdity-tool .tool-step-btn__num { width: 32px; height: 32px; flex-basis: 32px; font-size: 13px; }
  .adhdity-tool .tool-step-btn__text { font-size: 14.5px; }
  .adhdity-tool .emoji-img { width: 30px; height: 30px; }
}
