/* =======================================================================
   Overtime Pay Calculator Ireland – Calculator-Specific Styles
   Shared shell, fields, buttons, breakdowns, etc. are in ic-base.css
   ======================================================================= */

/* ---------- Multiplier/type pills ---------- */
.ic-overtimecalc .ic-rate-group { display: flex; flex-wrap: wrap; gap: 6px; }
.ic-overtimecalc .ic-rate-pill { cursor: pointer; margin: 0; }
.ic-overtimecalc .ic-rate-pill input[type="radio"] { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.ic-overtimecalc .ic-rate-pill span {
    display: inline-block; padding: 8px 14px;
    border: 1.5px solid var(--ic-input-border); border-radius: var(--ic-radius-sm);
    font-family: var(--ic-font); font-size: 13px; font-weight: 500;
    color: var(--ic-text-muted); background: var(--ic-input-bg);
    transition: all .15s ease; line-height: 1; user-select: none;
}
.ic-overtimecalc .ic-rate-pill span:hover { border-color: var(--ic-input-hover-border); color: var(--ic-text); background: var(--ic-input-hover-bg); }
.ic-overtimecalc .ic-rate-pill input[type="radio"]:checked + span {
    background: var(--ic-primary); color: #fff; border-color: var(--ic-primary);
    box-shadow: 0 1px 4px rgba(30,58,138,.18);
}
.ic-overtimecalc .ic-rate-pill input[type="radio"]:focus-visible + span { outline: 2px solid var(--ic-primary); outline-offset: 2px; }

/* ---------- Custom multiplier ---------- */
.ic-overtimecalc .ic-custom-rate-wrap { animation: ic-baseFadeIn .2s ease; }

/* ---------- Break toggle ---------- */
.ic-overtimecalc .ic-toggle-row {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding: 10px 14px; border-radius: var(--ic-radius-sm);
    background: var(--ic-input-bg); border: 1.5px solid var(--ic-input-border);
    cursor: pointer; transition: border-color .15s, background .15s;
}
.ic-overtimecalc .ic-toggle-row:hover { border-color: var(--ic-input-hover-border); background: var(--ic-input-hover-bg); }
.ic-overtimecalc .ic-toggle-row label { font-size: 13px; font-weight: var(--ic-label-weight); color: var(--ic-label-color); cursor: pointer; }
.ic-overtimecalc .ic-switch { position: relative; display: inline-block; width: 36px; height: 20px; flex-shrink: 0; }
.ic-overtimecalc .ic-switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.ic-overtimecalc .ic-switch-slider { position: absolute; inset: 0; background: var(--ic-border); border-radius: 20px; transition: background .2s; cursor: pointer; }
.ic-overtimecalc .ic-switch-slider::before { content: ''; position: absolute; width: 16px; height: 16px; left: 2px; top: 2px; background: #fff; border-radius: 50%; transition: transform .2s; box-shadow: 0 1px 2px rgba(0,0,0,.12); }
.ic-overtimecalc .ic-switch input:checked + .ic-switch-slider { background: var(--ic-primary); }
.ic-overtimecalc .ic-switch input:checked + .ic-switch-slider::before { transform: translateX(16px); }

/* ---------- Break fields ---------- */
.ic-overtimecalc .ic-break-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; animation: ic-baseFadeIn .2s ease; }
.ic-overtimecalc .ic-inline-field { display: flex; flex-direction: column; gap: 4px; }
.ic-overtimecalc .ic-inline-field label { font-size: 12px; font-weight: var(--ic-label-weight); color: var(--ic-label-color); }
.ic-overtimecalc .ic-inline-field input {
    padding: 8px 12px; min-height: 38px;
    border: 1.5px solid var(--ic-input-border); border-radius: var(--ic-radius-sm);
    font-family: var(--ic-font); font-size: 14px; color: var(--ic-text);
    background: var(--ic-input-bg); outline: none;
    transition: border-color .15s, box-shadow .15s, background .15s;
    -moz-appearance: textfield;
}
.ic-overtimecalc .ic-inline-field input::-webkit-inner-spin-button { -webkit-appearance: none; }
.ic-overtimecalc .ic-inline-field input:hover { border-color: var(--ic-input-hover-border); background: var(--ic-input-hover-bg); }
.ic-overtimecalc .ic-inline-field input:focus { border-color: var(--ic-input-focus-border); box-shadow: 0 0 0 3px var(--ic-input-focus-ring); background: var(--ic-surface); }

/* ---------- Result: payable hours pill ---------- */
.ic-overtimecalc .ic-payable-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 600; background: rgba(13,148,136,.08); color: var(--ic-accent); border: 1px solid rgba(13,148,136,.14); border-radius: 20px; padding: 4px 12px; margin-bottom: 14px; }
.ic-overtimecalc .ic-payable-pill svg { flex-shrink: 0; }

/* ---------- Info card ---------- */
.ic-overtimecalc .ic-info-card { background: var(--ic-success-light); border: 1px solid rgba(22,163,74,.12); border-radius: var(--ic-radius-sm); padding: 12px 16px; margin-bottom: 14px; display: flex; align-items: flex-start; gap: 8px; }
.ic-overtimecalc .ic-info-card svg { flex-shrink: 0; color: var(--ic-success); margin-top: 1px; }
.ic-overtimecalc .ic-info-card p { margin: 0; font-size: 12px; color: var(--ic-text-muted); line-height: 1.5; }
.ic-overtimecalc .ic-info-card strong { font-weight: 600; color: var(--ic-text); }

/* ---------- Outdated dimming ---------- */
.ic-overtimecalc .ic-results--outdated .ic-stagger { opacity: .45; pointer-events: none; transition: opacity .2s ease; }

/* ---------- Stagger animation ---------- */
.ic-overtimecalc .ic-stagger > * { opacity: 0; animation: ic-baseFadeIn .3s ease-out forwards; }
.ic-overtimecalc .ic-stagger > *:nth-child(1) { animation-delay: 0ms; }
.ic-overtimecalc .ic-stagger > *:nth-child(2) { animation-delay: 60ms; }
.ic-overtimecalc .ic-stagger > *:nth-child(3) { animation-delay: 120ms; }
.ic-overtimecalc .ic-stagger > *:nth-child(4) { animation-delay: 180ms; }
.ic-overtimecalc .ic-stagger > *:nth-child(5) { animation-delay: 240ms; }
.ic-overtimecalc .ic-stagger > *:nth-child(6) { animation-delay: 300ms; }

/* ---------- Mobile ---------- */
@media (max-width: 700px) {
    .ic-overtimecalc .ic-rate-group { gap: 5px; }
    .ic-overtimecalc .ic-rate-pill span { padding: 7px 10px; font-size: 12px; }
    .ic-overtimecalc .ic-break-fields { grid-template-columns: 1fr; }
}
