/* TaxQuill — page widgets
   tables (deadline calendar, deduction-by-year, software compare),
   refund calculator, forms accordion, FAQ, review cards.
   kept separate from styles.css so the masthead/footer file stays small. */

/* ---- generic data table ---- */
.tbl-wrap { border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
table.data { width: 100%; border-collapse: collapse; font-size: .95rem; }
table.data caption { text-align: left; padding: 14px 18px; font-family: var(--serif); font-size: 1.15rem; background: var(--paper-2); border-bottom: 1px solid var(--line); }
table.data th, table.data td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--line); }
table.data thead th { font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); background: var(--paper); }
table.data tbody tr:last-child td { border-bottom: none; }
table.data tbody tr:hover { background: var(--paper-2); }
table.data td.num, table.data th.num { text-align: right; font-variant-numeric: tabular-nums; }
.tbl-note { font-size: .78rem; color: var(--ink-faint); margin-top: 10px; }

/* ---- deadline calendar (date-led rows) ---- */
.cal-list { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.cal-row { display: grid; grid-template-columns: 96px 1fr auto; gap: 16px; align-items: center; padding: 16px 18px; border-bottom: 1px solid var(--line); background: var(--paper); }
.cal-row:last-child { border-bottom: none; }
.cal-row:hover { background: var(--paper-2); }
.cal-row.is-past { opacity: .5; }
.cal-date { text-align: center; border-right: 1px solid var(--line); padding-right: 14px; }
.cal-date .d { font-family: var(--serif); font-size: 1.7rem; line-height: 1; color: var(--ink); }
.cal-date .m { font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--marigold); font-weight: 700; }
.cal-body h3 { font-size: 1.08rem; margin: 0 0 3px; }
.cal-body p { font-size: .88rem; color: var(--ink-soft); margin: 0; }
.cal-tags { display: flex; gap: 6px; align-items: center; }

/* month grouping header inside calendar */
.cal-month { padding: 10px 18px; background: var(--ink); color: var(--paper); font-family: var(--ui); font-weight: 700; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; }

/* ---- refund calculator ---- */
.calc { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); }
.calc-form { padding: 28px 26px; background: var(--paper); }
.calc-out { padding: 28px 26px; background: var(--ink); color: var(--paper); display: flex; flex-direction: column; }
.field { margin-bottom: 18px; }
.field > label { display: block; font-weight: 700; font-size: .86rem; margin-bottom: 7px; color: var(--ink); }
.field .hint { font-weight: 400; color: var(--ink-faint); font-size: .8rem; }
.field input[type=number], .field select { width: 100%; font: inherit; font-size: 1.05rem; padding: 12px 13px; border: 1.5px solid var(--line-strong); border-radius: var(--radius); background: #fff; font-variant-numeric: tabular-nums; }
.field input:focus, .field select:focus { outline: none; border-color: var(--pine); }
.input-money { position: relative; }
.input-money::before { content: "$"; position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--ink-faint); font-weight: 700; }
.input-money input { padding-left: 26px; }
.seg-toggle { display: flex; border: 1.5px solid var(--line-strong); border-radius: var(--radius); overflow: hidden; }
.seg-toggle button { flex: 1; font: inherit; font-weight: 600; font-size: .9rem; padding: 11px 6px; background: #fff; border: none; cursor: pointer; color: var(--ink-soft); border-right: 1px solid var(--line); }
.seg-toggle button:last-child { border-right: none; }
.seg-toggle button.on { background: var(--pine); color: #fff; }

/* calc output panel */
.calc-out .co-label { font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); font-weight: 700; }
.calc-out .co-figure { font-family: var(--serif); font-size: clamp(2.6rem, 2rem + 3vw, 3.8rem); line-height: 1; margin: 8px 0 4px; font-variant-numeric: tabular-nums; }
.calc-out .co-figure.refund { color: #6fe0b0; }
.calc-out .co-figure.owe { color: #ff9b8a; }
.calc-out .co-sub { color: rgba(255,255,255,.7); font-size: .92rem; margin-bottom: 20px; }
.co-breakdown { margin-top: auto; border-top: 1px solid rgba(255,255,255,.12); padding-top: 16px; }
.co-breakdown .br { display: flex; justify-content: space-between; padding: 6px 0; font-size: .9rem; color: rgba(255,255,255,.78); }
.co-breakdown .br b { color: #fff; font-variant-numeric: tabular-nums; }
.co-bar { height: 8px; border-radius: 5px; background: rgba(255,255,255,.12); overflow: hidden; margin: 4px 0 16px; }
.co-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--marigold), #6fe0b0); transition: width .5s cubic-bezier(.16,1,.3,1); }

/* ---- forms accordion (W-2, 1099, 1040 ...) ---- */
.forms-acc { display: flex; flex-direction: column; gap: 12px; }
details.fitem { border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--paper); overflow: hidden; }
details.fitem[open] { border-color: var(--line-strong); }
details.fitem summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 16px; padding: 18px 20px; }
details.fitem summary::-webkit-details-marker { display: none; }
.fitem .fcode { font-family: var(--serif); font-weight: 600; font-size: 1.15rem; color: var(--pine-deep); background: var(--pine-wash); border-radius: var(--radius); padding: 8px 12px; min-width: 74px; text-align: center; flex-shrink: 0; }
.fitem .ftitle { flex: 1; }
.fitem .ftitle b { display: block; font-size: 1.05rem; }
.fitem .ftitle span { font-size: .85rem; color: var(--ink-faint); }
.fitem .fchev { width: 20px; height: 20px; color: var(--ink-faint); transition: transform .2s ease; flex-shrink: 0; }
.fitem[open] .fchev { transform: rotate(180deg); }
.fitem .fbody { padding: 2px 20px 20px; border-top: 1px solid var(--line); }
.fitem .fbody p { font-size: .94rem; color: var(--ink-soft); margin-top: 14px; }
.fitem .fbody ul { font-size: .92rem; color: var(--ink-soft); }

/* ---- FAQ ---- */
.faq-list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--line); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { list-style: none; cursor: pointer; padding: 18px 2px; font-family: var(--serif); font-size: 1.15rem; display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { content: "+"; font-size: 1.5rem; color: var(--pine); line-height: 1; }
.faq-list details[open] summary::after { content: "–"; }
.faq-list .ans { padding: 0 2px 20px; color: var(--ink-soft); max-width: 74ch; }

/* ---- software review cards ---- */
.review-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 20px; }
.rev-card { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 24px 22px; background: var(--paper); display: flex; flex-direction: column; position: relative; }
.rev-card.pick { border-color: var(--pine); border-width: 2px; box-shadow: var(--shadow); }
.rev-card .pick-flag { position: absolute; top: -11px; left: 22px; background: var(--pine); color: #fff; font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 10px; border-radius: 30px; }
.rev-card .rev-name { font-family: var(--serif); font-size: 1.5rem; margin: 0; }
.rev-card .rev-score { display: flex; align-items: baseline; gap: 8px; margin: 8px 0 4px; }
.rev-card .rev-score b { font-size: 2rem; font-family: var(--serif); color: var(--pine-deep); font-variant-numeric: tabular-nums; }
.rev-card .stars { color: var(--marigold); letter-spacing: 1px; font-size: .95rem; }
.rev-card .rev-price { font-size: .88rem; color: var(--ink-faint); margin-bottom: 14px; }
.rev-card ul.pc { list-style: none; padding: 0; margin: 0 0 18px; font-size: .9rem; }
.rev-card ul.pc li { padding: 5px 0 5px 24px; position: relative; color: var(--ink-soft); }
.rev-card ul.pc li.pro::before { content: "✓"; position: absolute; left: 0; color: var(--pos); font-weight: 700; }
.rev-card ul.pc li.con::before { content: "✕"; position: absolute; left: 0; color: var(--oxblood); font-weight: 700; }
.rev-card .rev-cta { margin-top: auto; }
.rev-card .rev-cta .btn { width: 100%; justify-content: center; }
.aff-tag { font-size: .72rem; color: var(--ink-faint); text-align: center; margin-top: 8px; }

/* affiliate disclosure ribbon */
.aff-disclose { background: var(--marigold-wash); border: 1px solid #ecd6a0; border-radius: var(--radius); padding: 13px 18px; font-size: .85rem; color: #7a5206; margin-bottom: 28px; }
.aff-disclose b { color: #5e3f04; }

/* responsive */
@media (max-width: 760px) {
  .calc { grid-template-columns: 1fr; }
  .cal-row { grid-template-columns: 72px 1fr; }
  .cal-tags { grid-column: 2; }
  /* let wide tables scroll instead of squashing — quick fix, revisit */
  .tbl-wrap { overflow-x: auto; }
  table.data { min-width: 540px; }
}
