/* Inflation + Overtime Calculator Shared Styles — inf__ / ot__ prefixes */

/* --- Shared two-col container (reused for both tools) --- */
.inf__container, .ot__container {
  display:grid; grid-template-columns:1fr;
  background:var(--surface-1); border:1px solid var(--border-1);
  border-radius:var(--r-lg); overflow:hidden;
}
@media(min-width:768px){.inf__container,.ot__container{grid-template-columns:1fr 1fr;}}

.inf__inputs,.ot__inputs{
  padding:var(--sp-5); display:flex; flex-direction:column; gap:var(--sp-4);
  background:var(--bg); border-bottom:1px solid var(--border-1);
}
@media(min-width:768px){
  .inf__inputs,.ot__inputs{padding:var(--sp-6);gap:var(--sp-5);border-bottom:none;border-right:1px solid var(--border-1);}
}
.inf__results,.ot__results{
  padding:var(--sp-5); display:flex; flex-direction:column; gap:var(--sp-3); background:var(--surface-1);
}
@media(min-width:768px){.inf__results,.ot__results{padding:var(--sp-6);gap:var(--sp-4);}}

/* Fields */
.inf__field,.ot__field{display:flex;flex-direction:column;gap:var(--sp-2);}
.inf__row,.ot__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);}
.inf__label,.ot__label{font-size:var(--text-sm);font-weight:700;color:var(--text-2);}
.inf__label-hint,.ot__label-hint{font-size:11px;font-weight:500;color:var(--text-3);display:block;margin-top:2px;}
.inf__section-label,.ot__section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);}
.inf__divider,.ot__divider{height:1px;background:var(--border-1);}

/* Inputs */
.inf__input-wrap,.ot__input-wrap{position:relative;display:flex;align-items:center;}
.inf__icon-prefix,.ot__icon-prefix,.inf__suffix,.ot__suffix{
  position:absolute;color:var(--text-3);font-weight:700;pointer-events:none;display:flex;align-items:center;
}
.inf__icon-prefix,.ot__icon-prefix{left:14px;opacity:.6;}
.inf__suffix,.ot__suffix{right:14px;font-size:var(--text-sm);}
.inf__input,.ot__input,.inf__select,.ot__select{
  width:100%;padding:11px 16px;font-size:var(--text-lg);font-weight:700;
  color:var(--text-1);background:var(--surface-1);border:1px solid var(--border-1);
  border-radius:var(--r-md);outline:none;transition:all .3s cubic-bezier(.4,0,.2,1);
  -moz-appearance:textfield;
}
.inf__input::-webkit-inner-spin-button,.ot__input::-webkit-inner-spin-button,
.inf__input::-webkit-outer-spin-button,.ot__input::-webkit-outer-spin-button{-webkit-appearance:none;}
.inf__input-wrap:has(.inf__icon-prefix) .inf__input,
.ot__input-wrap:has(.ot__icon-prefix) .ot__input{padding-left:42px;}
.inf__input-wrap:has(.inf__suffix) .inf__input,
.ot__input-wrap:has(.ot__suffix) .ot__input{padding-right:44px;}
.inf__input:focus,.ot__input:focus,.inf__select:focus,.ot__select:focus{
  border-color:var(--accent,var(--green));
  box-shadow:0 0 0 4px rgba(0,93,72,.1);background:var(--bg);
}
.inf__select,.ot__select{
  padding:11px 40px 11px 16px;font-size:var(--text-base);
  -webkit-appearance:none;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}

/* Segmented control */
.inf__segmented-control,.ot__segmented-control{
  display:flex;background:var(--surface-2);padding:5px;border-radius:var(--r-lg);gap:4px;border:1px solid var(--border-1);
}
.inf__seg-btn,.ot__seg-btn{
  flex:1 1 auto;padding:7px 8px;font-size:var(--text-sm);font-weight:700;color:var(--text-2);
  background:transparent;border:none;border-radius:var(--r-md);cursor:pointer;
  white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);
}
.inf__seg-btn--active,.ot__seg-btn--active{
  background:#fff;color:var(--accent,var(--green));
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}

/* Hero result */
.inf__hero,.ot__hero{
  background:linear-gradient(135deg,rgba(0,93,72,.08) 0%,rgba(0,93,72,.02) 100%);
  border:1.5px solid rgba(0,93,72,.2);border-radius:var(--r-md);
  padding:var(--sp-5);text-align:center;position:relative;overflow:hidden;
}
.inf__hero-label,.ot__hero-label{
  display:block;font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text-3);margin-bottom:6px;
}
.inf__hero-value,.ot__hero-value{
  display:block;font-size:clamp(1.8rem,7vw,2.6rem);font-weight:900;
  letter-spacing:-.03em;color:var(--accent,var(--green));word-break:break-all;
}
.inf__hero-sub,.ot__hero-sub{font-size:var(--text-sm);color:var(--text-3);margin-top:4px;}

/* Stat grid */
.inf__stat-grid,.ot__stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);}
@media(min-width:768px){.inf__stat-grid,.ot__stat-grid{gap:var(--sp-3);}}
.inf__stat-card,.ot__stat-card{
  background:var(--bg);border:1px solid var(--border-1);
  border-radius:var(--r-md);padding:var(--sp-3);text-align:center;min-width:0;overflow:hidden;
}
.inf__stat-label,.ot__stat-label{display:block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:4px;}
.inf__stat-value,.ot__stat-value{display:block;font-size:clamp(.95rem,4vw,var(--text-xl));font-weight:800;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.inf__stat-value--green,.ot__stat-value--green{color:var(--accent,var(--green));}
.inf__stat-value--red,.ot__stat-value--red{color:#dc2626;}
.inf__stat-value--amber,.ot__stat-value--amber{color:var(--warning);}
.inf__stat-value--blue,.ot__stat-value--blue{color:#1565C0;}

/* Breakdown rows */
.inf__breakdown,.ot__breakdown{background:var(--bg);border:1px solid var(--border-1);border-radius:var(--r-md);overflow:hidden;}
.inf__breakdown-header,.ot__breakdown-header{padding:9px 14px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);background:var(--surface-2);border-bottom:1px solid var(--border-1);}
.inf__breakdown-row,.ot__breakdown-row{display:flex;justify-content:space-between;align-items:baseline;padding:9px 14px;font-size:var(--text-sm);font-weight:600;border-bottom:1px solid var(--border-1);gap:var(--sp-2);}
.inf__breakdown-row:last-child,.ot__breakdown-row:last-child{border-bottom:none;}
.inf__breakdown-row span:first-child,.ot__breakdown-row span:first-child{color:var(--text-2);flex:1 1 auto;min-width:0;}
.inf__breakdown-row span:last-child,.ot__breakdown-row span:last-child{font-weight:800;flex:0 0 auto;text-align:right;white-space:nowrap;}
.inf__breakdown-row--net,.ot__breakdown-row--net{background:rgba(0,93,72,.04);}
.inf__breakdown-row--net span:first-child,.ot__breakdown-row--net span:first-child{color:var(--text-1);font-weight:800;}
.inf__breakdown-row--net span:last-child,.ot__breakdown-row--net span:last-child{color:var(--accent,var(--green));}
.ot__breakdown-row--ot span:last-child{color:#d97706;}
.ot__breakdown-row--dt span:last-child{color:#dc2626;}

/* AI Insight */
.inf__ai-insight,.ot__ai-insight{
  background:linear-gradient(145deg,#f0fdf4 0%,#e6f6ec 100%);
  border:1px solid rgba(0,168,107,.2);border-radius:var(--r-md);
  padding:var(--sp-4);box-shadow:0 2px 8px rgba(0,168,107,.05);
}
.inf__ai-header,.ot__ai-header{display:flex;align-items:center;gap:8px;font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--accent,var(--green));margin-bottom:8px;}
.inf__ai-text,.ot__ai-text{font-size:var(--text-sm);color:var(--text-1);line-height:1.65;font-weight:500;margin:0;}

/* Chart section */
.inf__chart-section,.ot__chart-section{
  margin-top:var(--sp-8);background:var(--surface-1);border:1px solid var(--border-1);
  border-radius:var(--r-lg);padding:var(--sp-5);
}
.inf__chart-title,.ot__chart-title{font-size:var(--text-lg);font-weight:800;color:var(--text-1);margin:0 0 var(--sp-4) 0;}
.inf__chart-wrap,.ot__chart-wrap{position:relative;height:280px;}

/* Year-by-year table */
.inf__table,.ot__table{width:100%;border-collapse:collapse;font-size:var(--text-sm);overflow:auto;}
.inf__table th,.ot__table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);background:var(--surface-2);border-bottom:2px solid var(--border-1);white-space:nowrap;}
.inf__table td,.ot__table td{padding:9px 14px;border-bottom:1px solid var(--border-1);font-weight:600;color:var(--text-1);}
.inf__table tr:hover td,.ot__table tr:hover td{background:var(--surface-2);}
.inf__table .td-green,.ot__table .td-green{color:var(--accent,var(--green));font-weight:800;}

/* Info banner (state-specific note) */
.inf__info-banner,.ot__info-banner{
  background:rgba(0,93,72,.05);border:1px solid rgba(0,93,72,.15);
  border-radius:var(--r-md);padding:10px 14px;font-size:var(--text-sm);color:var(--text-2);font-weight:500;
}
.inf__info-banner strong,.ot__info-banner strong{color:var(--text-1);}

/* CA daily hours grid */
.ot__daily-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
@media(max-width:600px){.ot__daily-grid{grid-template-columns:repeat(4,1fr);}}
.ot__daily-cell{display:flex;flex-direction:column;gap:4px;}
.ot__daily-label{font-size:10px;font-weight:800;text-align:center;color:var(--text-3);text-transform:uppercase;}
.ot__daily-input{width:100%;padding:8px 6px;text-align:center;font-size:var(--text-base);font-weight:700;color:var(--text-1);background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--r-md);outline:none;transition:border .3s;}
.ot__daily-input:focus{border-color:var(--accent,var(--green));}

/* Disclaimer */
.inf__disclaimer,.ot__disclaimer{
  margin-top:var(--sp-8);padding:var(--sp-4);background:var(--surface-2);
  border-left:3px solid var(--border-2);border-radius:0 var(--r-md) var(--r-md) 0;
  font-size:var(--text-xs);color:var(--text-3);line-height:1.6;
}

/* Dark mode overrides */
[data-theme="dark"] .inf__seg-btn--active,[data-theme="dark"] .ot__seg-btn--active{background:var(--surface-3,#333);color:#fff;}
[data-theme="dark"] .inf__ai-insight,[data-theme="dark"] .ot__ai-insight{background:linear-gradient(145deg,rgba(0,168,107,.1) 0%,rgba(0,93,72,.15) 100%);}
