.section.tool-hero { padding-top: 40px; }
.tool-breadcrumb { font: 400 var(--fs-meta)/1.4 var(--font-body); color: var(--mid); margin: 0 0 12px; }
.tool-breadcrumb a { color: var(--mid); }
.tool-breadcrumb a:hover { color: var(--navy); }
.tool-intro { font-size: var(--fs-body-lg); color: var(--mid); max-width: 60ch; margin-bottom: 32px; }
.tool-updated { font: 400 var(--fs-meta)/1.4 var(--font-body); color: var(--mid); margin: -16px 0 28px; }
.tool-related { margin: 32px 0 0; }
.tool-related h2 { font-family: var(--font-display); font-size: var(--fs-heading-sm); color: var(--navy); margin: 0 0 12px; }
.tool-related ul { margin: 0; padding-left: 18px; display: grid; gap: 6px; }
.tool-related a { color: var(--navy); }

/* ===== Two-column layout: controls left, sticky live result right ===== */
.csg-layout { display: grid; gap: 32px; align-items: start; }
@media (min-width: 920px) {
  .csg-layout { grid-template-columns: minmax(300px, 360px) 1fr; }
  .csg-output { position: sticky; top: 88px; }
}

.csg-controls { display: grid; gap: 28px; margin: 0; border: 0; padding: 0; min-width: 0; }
.csg-group { display: grid; gap: 14px; border: 0; padding: 0; margin: 0; }
.csg-group-title { font-family: var(--font-display); font-size: var(--fs-heading-sm); color: var(--navy); margin: 0; }

.tool-field { display: grid; gap: 6px; border: 0; padding: 0; margin: 0; min-width: 0; }
.tool-label { font: 600 var(--fs-label)/1.3 var(--font-body); color: var(--charcoal); }
.tool-input { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 10px 14px; font: 400 var(--fs-body)/1.4 var(--font-body); color: var(--charcoal); width: 100%; }
.tool-input:focus-visible { outline: none; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(37,75,90,.08); }
.csg-fields-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px) { .csg-fields-2 { grid-template-columns: 1fr; } }
.csg-radio-row { display: flex; gap: 16px; flex-wrap: wrap; }
.csg-radio { display: inline-flex; align-items: center; gap: 6px; font: 400 var(--fs-body)/1.3 var(--font-body); color: var(--charcoal); }
.csg-hint { font: 400 var(--fs-body-sm)/1.5 var(--font-body); color: var(--mid); margin: 0; }

.pattern-grid { display: grid; gap: 10px; border: 0; padding: 0; margin: 0; }
.pattern-opt { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--radius-md); cursor: pointer; background: var(--white); transition: border-color var(--duration-short) var(--ease-move), background var(--duration-short) var(--ease-move); }
.pattern-opt:hover { border-color: var(--mist); }
.pattern-opt:has(input:checked) { border-color: var(--navy); background: var(--blue-light); }
.pattern-opt input { margin-top: 3px; flex: 0 0 auto; }
.pattern-opt-body { display: grid; gap: 2px; }
.pattern-opt-name { font: 600 var(--fs-body)/1.3 var(--font-body); color: var(--charcoal); }
.pattern-opt-desc { font: 400 var(--fs-meta)/1.4 var(--font-body); color: var(--mid); }

.holiday-controls { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px 12px; }
.holiday-ctl { display: flex; align-items: center; gap: 8px; font: 400 var(--fs-body-sm)/1.3 var(--font-body); color: var(--charcoal); cursor: pointer; }

/* ===== Output ===== */
.tool-result-heading { font-family: var(--font-display); font-size: var(--fs-heading-md); color: var(--navy); margin: 0 0 16px; }
.csg-output-inner { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.tool-result { display: grid; gap: 20px; }

.tool-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; margin: 0; }
.tool-summary .stat { background: var(--blue-light); border-radius: var(--radius-md); padding: 12px 14px; display: grid; gap: 3px; }
.tool-summary .stat-label { font: 600 var(--fs-micro)/1.2 var(--font-body); color: var(--mid); text-transform: uppercase; letter-spacing: .04em; }
.tool-summary .stat-value { font: 600 var(--fs-heading-sm)/1.1 var(--font-display); color: var(--navy); }

.tool-calendar { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-cell { border: 1px solid var(--border); border-radius: var(--radius-xs); padding: 8px 6px; min-height: 56px; font: 500 var(--fs-meta)/1.2 var(--font-body); }
.cal-cell[data-parent="A"] { background: var(--navy); color: var(--white); }
.cal-cell[data-parent="B"] { background: var(--cal-parent-b); color: var(--charcoal); }
.cal-cell .cal-tag { font-weight: 700; }
.cal-cell .cal-name { display: block; margin-top: 2px; opacity: .9; }
.cal-dow { font: 600 var(--fs-micro)/1 var(--font-body); color: var(--mid); text-transform: uppercase; text-align: center; padding: 4px 0; }

.csg-print-row { display: flex; }
.tool-holiday-table { overflow-x: auto; margin: 0; }
.tool-holiday-table h3 { font-family: var(--font-display); font-size: var(--fs-heading-sm); color: var(--navy); margin: 0 0 12px; }
.holiday-table { width: 100%; border-collapse: collapse; font: 400 var(--fs-body-sm)/1.4 var(--font-body); }
.holiday-table th, .holiday-table td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--border); }
.holiday-table th { color: var(--mid); font-weight: 600; }
.holiday-flip { font: 600 var(--fs-meta)/1 var(--font-body); color: var(--navy); background: none; border: 1px solid var(--border); border-radius: var(--radius-full); padding: 4px 12px; cursor: pointer; }
.holiday-flip:hover { background: var(--blue-light); border-color: var(--navy); }

/* Calendar Parent-B cell uses a lighter olive than brand --secondary so charcoal text clears WCAG AA (#8A9E6B vs #082434 = 5.47:1). */
:root { --cal-parent-b: #8A9E6B; }

.tool-disclaimer { font-size: var(--fs-body-sm); color: var(--mid); background: var(--stone); border-radius: var(--radius-md); padding: 16px 20px; margin: 32px 0 0; }
.tool-email-card { background: var(--stone); border-radius: var(--radius-lg); padding: 24px; margin: 32px 0 0; max-width: 720px; }
.tool-email-card h2 { margin: 0 0 8px; font-family: var(--font-display); color: var(--navy); font-size: var(--fs-heading-sm); }
.tool-email-card p { color: var(--mid); margin: 0 0 16px; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

@media (max-width: 480px) {
  .tool-calendar { gap: 2px; }
  .cal-cell { min-height: 44px; padding: 4px 2px; font-size: var(--fs-micro); }
  .cal-cell .cal-name { display: none; }
  .csg-output-inner { padding: 16px; }
}

@media print {
  .pp-header, .pp-banner, .site-footer, #cookie-banner, .nav-mobile-backdrop, .nav-mobile-panel, .skip-link,
  .csg-controls, .tool-disclaimer, .csg-print-row, #print-btn, .holiday-flip, .tool-email-card { display: none !important; }
  .csg-layout { display: block; }
  .csg-output { position: static; }
  .csg-output-inner { border: 0; box-shadow: none; padding: 0; }
  body { background: #fff; color: var(--charcoal); }
  .tool-calendar .cal-cell { box-shadow: none; border: 1px solid var(--border) !important; print-color-adjust: exact; -webkit-print-color-adjust: exact; }
  .cal-cell[data-parent="A"] { background: var(--navy) !important; color: #fff !important; }
  .cal-cell[data-parent="B"] { background: var(--cal-parent-b) !important; color: var(--charcoal) !important; }
  .container { max-width: none; }
  @page { margin: 12mm; }
  .tool-result::after { content: "Generated with Parenting Path · parentingpath.net"; display: block; margin-top: 16px; font: 400 12px/1.4 var(--font-body); color: var(--mid); }
}
