@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;900&family=Barlow:wght@400;600;700&display=swap');

/* ════════════════════════════════════════════
   Softball Lineup Generator v3 — Plugin CSS
   Aesthetic: Bold sports dashboard
════════════════════════════════════════════ */
.slg-wrap{
  --g: #1e6b35; --gd: #155228; --gl: #e8f5ed;
  --gd2: #d4edda;
  --gold: #d4890a; --goldd: #f5c842;
  --blue: #1a5f8e; --red: #c0392b;
  --ink: #1a1a1a; --mid: #555; --pale: #f7f4ef;
  --border: #e0dcd5; --r: 8px;
  font-family: 'Barlow', Georgia, sans-serif;
  color: var(--ink);
  max-width: 960px;
  margin: 0 auto;
  padding: 0 12px 48px;
}

/* ── Tabs ──────────────────────────────────── */
.slg-tabs{
  display: flex; gap: 2px; flex-wrap: wrap;
  border-bottom: 3px solid var(--g);
}
.slg-tab{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase;
  padding: 10px 20px;
  border: none; border-radius: 6px 6px 0 0;
  background: #ede9e3; color: var(--mid);
  cursor: pointer; transition: .15s;
  white-space: nowrap;
}
.slg-tab:hover{ background: #ddd; }
.slg-tab.active{ background: var(--g); color: #fff; }

/* ── Panels ────────────────────────────────── */
.slg-panel{
  display: none;
  background: #fff;
  border: 2px solid var(--g);
  border-top: none;
  border-radius: 0 0 var(--r) var(--r);
  padding: 24px;
}
.slg-panel.active{ display: block; }

/* ── Section heading ───────────────────────── */
.slg-sec{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 17px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--g);
  border-left: 5px solid var(--gold);
  padding-left: 10px;
  margin: 0 0 14px;
}
.slg-badge{
  font-family: 'Barlow', sans-serif;
  font-size: 12px; font-weight: 700;
  background: var(--g); color: #fff;
  padding: 2px 9px; border-radius: 20px;
  margin-left: 8px; vertical-align: middle;
}
.slg-hint-text{
  color: var(--mid); font-size: 13px;
  margin: -8px 0 14px; line-height: 1.5;
}

/* ── 2-column layout ───────────────────────── */
.slg-row-2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
@media(max-width:700px){ .slg-row-2{ grid-template-columns:1fr; } }

/* ── Form grid ─────────────────────────────── */
.slg-grid2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.slg-field{ display: flex; flex-direction: column; gap: 4px; }
.slg-field label, .slg-field-lbl{
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--mid);
}
.slg-field input, .slg-field select,
.slg-add-row input, .slg-add-row select{
  padding: 9px 12px;
  border: 2px solid var(--border);
  border-radius: var(--r);
  font-family: 'Barlow', sans-serif;
  font-size: 15px; color: var(--ink);
  transition: border-color .2s;
  background: #fff;
}
.slg-field input:focus, .slg-field select:focus,
.slg-add-row input:focus, .slg-add-row select:focus{
  outline: none; border-color: var(--g);
}
.slg-span2{ grid-column: 1/-1; }

/* ── Branding section ──────────────────────── */
.slg-branding{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media(max-width:500px){ .slg-branding{ grid-template-columns:1fr; } }

.slg-logo-box{
  border: 2px dashed var(--border);
  border-radius: var(--r);
  padding: 16px;
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  background: var(--pale);
  transition: border-color .2s;
  cursor: pointer;
}
.slg-logo-box:hover, .slg-logo-box.has-logo{ border-color: var(--g); border-style: solid; }
.slg-logo-inner{
  display: flex; flex-direction: column;
  align-items: center; gap: 4px; text-align: center;
}
.slg-logo-label{ font-size: 14px; font-weight: 600; }
.slg-logo-hint{ font-size: 11px; color: #aaa; }
.slg-logo-inner img{ max-width: 90px; max-height: 90px; object-fit: contain; border-radius: 8px; }
.slg-logo-btns{ display: flex; gap: 8px; }

.slg-color-box{
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 14px;
  background: var(--pale);
}
.slg-swatches{ display: flex; gap: 7px; flex-wrap: wrap; margin: 8px 0 4px; }
.slg-sw{
  width: 30px; height: 30px; border-radius: 50%;
  border: 3px solid transparent; cursor: pointer;
  transition: transform .15s, border-color .15s;
}
.slg-sw:hover{ transform: scale(1.18); }
.slg-sw.active{ border-color: #fff; box-shadow: 0 0 0 2px var(--ink); }

/* ── Add player row ────────────────────────── */
.slg-add-row{
  display: flex; gap: 8px; flex-wrap: wrap;
  align-items: center;
  background: var(--gl);
  border: 2px dashed var(--g);
  border-radius: var(--r);
  padding: 12px 14px;
  margin-bottom: 12px;
}
.slg-add-row input, .slg-add-row select{
  flex: 1; min-width: 100px;
}

/* ── Player list ───────────────────────────── */
.slg-plist{
  min-height: 70px;
  display: flex; flex-direction: column; gap: 5px;
  margin-bottom: 14px;
}
.slg-empty{
  text-align: center; color: #bbb;
  font-style: italic; padding: 22px 0;
  font-size: 14px;
}

/* ── Player row ────────────────────────────── */
.slg-prow{
  display: flex; align-items: center; gap: 8px;
  background: var(--pale);
  border: 1px solid var(--border);
  border-left: 5px solid var(--g);
  border-radius: var(--r);
  padding: 9px 11px;
  cursor: grab; user-select: none;
  transition: box-shadow .15s;
}
.slg-prow:hover{ box-shadow: 0 3px 12px rgba(0,0,0,.1); }
.slg-prow.dragging{ opacity: .45; border-left-color: var(--gold); }
.slg-drag{ color: #ccc; font-size: 18px; cursor: grab; }
.slg-onum{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 900;
  color: var(--g); min-width: 28px; text-align: center;
}
.slg-iinput{
  border: none; border-bottom: 2px solid var(--border);
  background: transparent;
  font-family: 'Barlow', sans-serif;
  font-size: 15px; padding: 2px 4px;
  transition: border-color .2s;
}
.slg-iinput:focus{ outline: none; border-bottom-color: var(--g); }
.slg-iinput.name{ flex: 1; font-weight: 700; }
.slg-iinput.num{ width: 46px; text-align: center; font-weight: 700; }
.slg-ipos{
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 13px;
}
.slg-ibtn{
  background: none; border: none; cursor: pointer;
  font-size: 15px; padding: 3px 5px;
  border-radius: 4px; transition: background .15s; line-height: 1;
}
.slg-ibtn:hover{ background: #eee; }
.slg-ibtn.del:hover{ background: #fde; color: var(--red); }

/* ── DP/FLEX info ──────────────────────────── */
.slg-dpflex-info{
  background: #fff8e1; border: 1px solid #f5c842;
  border-left: 4px solid var(--gold);
  border-radius: 6px; padding: 10px 14px;
  font-size: 13px; color: #6b4c00;
  margin-bottom: 12px;
}

/* ── Fair rotation box ─────────────────────── */
.slg-fair-box{
  background: var(--pale); border: 1px solid var(--border);
  border-left: 4px solid var(--gold);
  border-radius: var(--r); padding: 14px;
  margin-top: 4px;
}
.slg-fair-title{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px;
  color: var(--gold); margin-bottom: 8px;
}
.slg-fair-output{
  font-size: 13px; color: var(--mid); line-height: 1.6;
}
.slg-fair-output .fair-warn{
  color: var(--red); font-weight: 600;
}
.slg-fair-output .fair-ok{
  color: var(--g); font-weight: 600;
}

/* ── Buttons ───────────────────────────────── */
.slg-btn{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase;
  padding: 10px 20px; border: none;
  border-radius: var(--r); cursor: pointer;
  transition: filter .15s, transform .1s;
  white-space: nowrap;
}
.slg-btn:hover{ filter: brightness(1.1); }
.slg-btn:active{ transform: scale(.97); }
.slg-green { background: var(--g);    color: #fff; }
.slg-gold  { background: var(--gold); color: #fff; }
.slg-blue  { background: var(--blue); color: #fff; }
.slg-red   { background: var(--red);  color: #fff; }
.slg-purple{ background: #6c3483;     color: #fff; }
.slg-outline{
  background: transparent;
  border: 2px solid var(--g); color: var(--g);
  font-size: 13px; padding: 7px 14px;
}
.slg-outline:hover{ background: var(--g); color: #fff; }
.slg-ghost{
  background: transparent;
  border: 2px solid var(--border); color: var(--mid);
  font-size: 13px; padding: 7px 12px;
}
.slg-ghost:hover{ border-color: var(--red); color: var(--red); }

/* ── Action bar ────────────────────────────── */
.slg-action-bar{
  display: flex; gap: 8px; flex-wrap: wrap;
  padding-top: 12px; border-top: 2px solid var(--border);
  margin-top: 8px;
}

/* ── Messages ──────────────────────────────── */
.slg-msg{
  margin-top: 12px; padding: 11px 16px;
  border-radius: var(--r); font-weight: 600; font-size: 14px;
}
.slg-msg.ok  { background: #d4edda; color: #155724; border:1px solid #c3e6cb; }
.slg-msg.err { background: #f8d7da; color: #721c24; border:1px solid #f5c6cb; }

/* ── Share box ─────────────────────────────── */
.slg-share-box{
  margin-top: 14px;
  background: #f0f7ff;
  border: 2px solid #1a5f8e;
  border-radius: var(--r);
  padding: 14px;
}
.slg-share-url-row{
  display: flex; gap: 8px; margin: 8px 0 6px;
}
.slg-share-url-row input{
  flex: 1; padding: 8px 12px;
  border: 2px solid #ddd; border-radius: 6px;
  font-size: 13px; background: #fff; color: #333;
}

/* ── Defense grid ──────────────────────────── */
.slg-grid-controls{
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 14px; flex-wrap: wrap;
}
.slg-grid-controls label{
  font-size: 14px; font-weight: 600; color: var(--mid);
}
.slg-grid-wrap{ overflow-x: auto; }
.slg-def-table{
  border-collapse: collapse;
  min-width: 100%; font-size: 14px;
}
.slg-def-table th{
  background: var(--g); color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase;
  padding: 9px 12px; white-space: nowrap;
  -webkit-print-color-adjust: exact; print-color-adjust: exact;
}
.slg-def-table td{
  border: 1px solid var(--border);
  padding: 6px 8px; min-width: 80px;
}
.slg-def-table td:first-child{
  background: var(--gl); font-weight: 700; font-size: 13px;
  min-width: 110px; white-space: nowrap;
}
.slg-def-select{
  width: 100%; border: 1px solid #ddd;
  border-radius: 4px; font-size: 13px;
  padding: 4px 6px; background: #fff;
}
.slg-def-select:focus{ outline: none; border-color: var(--g); }

/* ── Preview ───────────────────────────────── */
.slg-print-bar{
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-bottom: 18px;
}
#slg-preview-card{
  background: #f7f4ef;
  border-radius: 10px; padding: 20px;
}

/* ── History / Stats ───────────────────────── */
.slg-stats-row{
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.slg-stat-card{
  flex: 1; min-width: 100px;
  background: var(--pale); border: 1px solid var(--border);
  border-radius: var(--r); padding: 14px 18px; text-align: center;
}
.slg-stat-num{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 32px; font-weight: 900; color: var(--g);
}
.slg-stat-lbl{ font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--mid); margin-top: 2px; }

.slg-hist-card{
  display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--border);
  border-left: 5px solid var(--gold);
  border-radius: var(--r);
  padding: 12px 16px; margin-bottom: 8px;
  background: var(--pale); flex-wrap: wrap;
}
.slg-hist-info{ flex: 1; }
.slg-hist-info strong{ font-size: 15px; display: block; }
.slg-hist-info span  { font-size: 12px; color: var(--mid); }
.slg-result-badge{
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700;
  padding: 4px 10px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: .5px;
}
.slg-result-badge.win { background: var(--gd2); color: var(--gd); }
.slg-result-badge.loss{ background: #fde; color: var(--red); }
.slg-result-badge.tie { background: #fff3cd; color: #856404; }
.slg-hist-actions{ display: flex; gap: 6px; flex-wrap: wrap; }

/* ── Result logger ─────────────────────────── */
.slg-result-row{
  display: flex; gap: 8px; align-items: center;
  flex-wrap: wrap; margin-top: 8px;
  padding: 10px; background: var(--pale);
  border-radius: var(--r); border: 1px solid var(--border);
}
.slg-result-row label{ font-size: 12px; font-weight: 600; color: var(--mid); text-transform: uppercase; }
.slg-result-row input[type=number]{
  width: 60px; padding: 6px 8px;
  border: 2px solid var(--border); border-radius: 6px;
  font-size: 15px; font-weight: 700; text-align: center;
}
.slg-result-row select{
  padding: 6px 10px; border: 2px solid var(--border);
  border-radius: 6px; font-size: 14px; font-weight: 600;
}

/* ── Mobile optimizations ──────────────────── */
@media (max-width: 580px) {
  .slg-grid2{ grid-template-columns: 1fr; }
  .slg-span2{ grid-column: 1; }
  .slg-prow{ flex-wrap: wrap; }
  .slg-action-bar .slg-btn{ flex: 1; min-width: 100px; text-align: center; }
  .slg-tab{ padding: 9px 12px; font-size: 12px; }
  .slg-panel{ padding: 16px; }
  .slg-onum{ font-size: 18px; }
}

/* ── Touch-friendly on small screens ──────── */
@media (max-width: 480px) {
  .slg-iinput.name{ font-size: 14px; }
  .slg-add-row{ flex-direction: column; }
  .slg-add-row input, .slg-add-row select{ width: 100%; min-width: unset; }
  .slg-add-row .slg-btn{ width: 100%; }
}
