/* Global shared styles for 38 Arena Products */
:root {
  --brand-orange:#ff6a1c;
  --brand-orange-dark:#e35811;
  --border-color:#d1d9e2;
  --bg-soft:#f1f5f9;
  --bg-muted:#f6f8fa;
  --radius-sm:6px;
  --radius:8px;
  --radius-lg:14px;
  --focus-ring:#ffbf99;
  --text-muted:#555;
}
html,body {margin:0;padding:0;font-family:system-ui,Arial,sans-serif;background:var(--bg-muted);color:#111;line-height:1.35}
img {max-width:100%;height:auto}

/* Layout */
main{max-width:1220px;margin:20px auto;padding:0 16px}
header{background:#fff;color:var(--brand-orange);padding:12px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;border-bottom:2px solid var(--brand-orange)}
header a{color:var(--brand-orange);text-decoration:none;font-size:13px;font-weight:600}
header a:hover{text-decoration:underline}

/* Tabs */
.nav-tabs{display:flex;gap:6px;list-style:none;padding:0;margin:0 0 14px;border-bottom:1px solid var(--border-color)}
.nav-tabs a{padding:6px 12px;border:1px solid var(--border-color);border-bottom:none;border-radius:10px 10px 0 0;background:var(--bg-soft);text-decoration:none;color:#111;font-size:14px}
.nav-tabs a.active{background:var(--brand-orange);color:#fff;border-color:var(--brand-orange)}

/* Cards */
.card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:18px}
.card-header{padding:10px 14px;font-weight:600;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card-body{padding:14px}

/* Buttons */
.btn{background:var(--brand-orange);color:#fff;border:none;padding:6px 12px;font-size:14px;border-radius:var(--radius);cursor:pointer}
.btn:hover{background:var(--brand-orange-dark)}
.btn-soft{background:#eef2f7;color:#111;border:1px solid var(--border-color);border-radius:var(--radius);padding:6px 10px;display:inline-block;text-decoration:none}
.btn-soft.active{background:var(--brand-orange);color:#fff;border-color:var(--brand-orange)}
.btn-danger{background:#fff;color:#b91c1c;border:1px solid #f5c2c7}
.btn[disabled],.btn-soft[disabled]{opacity:.55;cursor:not-allowed}
.btn-secondary{background:#374151;color:#fff;border:1px solid #374151}
.btn-secondary:hover{background:#1f2937}
.btn-outline{background:#fff;color:#374151;border:1px solid var(--border-color)}
.btn-outline:hover{border-color:var(--brand-orange);color:#9a3412;background:#fff7ed}

/* Tables */
.table{border-collapse:collapse;width:100%}
.table th,.table td{padding:6px 8px;border-bottom:1px solid #e4e8ec;font-size:13px;text-align:left;vertical-align:middle}
.table thead th{background:var(--bg-soft)}
.drag-row{background:#fff7ed;font-weight:600;color:#9a3412;text-align:center}

/* Table embedded form controls */
.table input[type=text],
.table input[type=number],
.table input[type=email],
.table input[type=search],
.table input[type=time],
.table input[type=date],
.table select,
.table textarea { border-radius:var(--radius); }
/* Explicit rounding for run time / cost preview numeric entries */
.table input.time { border-radius:var(--radius); padding:6px 8px; height:30px; }
/* Fallback: any inline numeric input with width constraint */
input[placeholder='0.00'] { border-radius:var(--radius) !important; }
/* Barrel run table specific inputs */
.table .raw-input { border:1px solid #d1d5db; border-radius:var(--radius); padding:6px 8px; height:30px; font:inherit; background:#fff; }
.table .raw-input:focus { outline:2px solid var(--brand-orange); outline-offset:0; }
.table .barrels-select { border:1px solid #d1d5db; border-radius:var(--radius); padding:4px 6px; height:30px; font:inherit; background:#fff; }
.table .dq-check { width:20px; height:20px; }

/* Forms */
input[type=text],input[type=number],input[type=email],input[type=password],input[type=search],input[type=decimal],input[type=date],input[type=time],input:not([type]),select,textarea{
  font-family:inherit;font-size:13px;border:1px solid var(--border-color);border-radius:var(--radius);padding:6px 8px;background:#fff;box-sizing:border-box
}
input:focus,select:focus,textarea:focus{outline:2px solid var(--focus-ring);outline-offset:1px}
textarea{resize:vertical}
label{font-size:12px}
.badge{display:inline-block;background:var(--bg-soft);color:#444;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}
.small{font-size:12px}
.muted{color:#6b7280}

/* Rounded custom checkboxes */
input[type=checkbox]{
  appearance:none;-webkit-appearance:none; width:16px;height:16px;display:inline-block;vertical-align:middle;cursor:pointer;
  border:1px solid var(--border-color);border-radius:6px;background:#fff;position:relative;transition:.15s background, .15s border-color;
}
input[type=checkbox]:hover{border-color:var(--brand-orange)}
input[type=checkbox]:focus{outline:2px solid var(--focus-ring);outline-offset:2px}
input[type=checkbox]:checked{background:var(--brand-orange);border-color:var(--brand-orange)}
input[type=checkbox]:checked::after{content:"";position:absolute;left:4px;top:2px;width:6px;height:10px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}
input[type=checkbox][disabled]{opacity:.5;cursor:not-allowed}

/* Grid helpers */
.grid{display:grid;gap:12px}
.grid.auto{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}

/* Rider Search Widget */
.rider-search-root{position:relative;font-size:13px}
.rider-search-input{width:100%;padding:6px 8px;border:1px solid var(--border-color);border-radius:var(--radius);background:#fff;font-size:13px}
.rider-search-actions{display:flex;gap:6px;margin-top:4px}
.rider-search-actions button{font-size:12px;padding:4px 8px;border-radius:var(--radius-sm);background:var(--brand-orange);color:#fff;border:none;cursor:pointer}
.rider-search-actions button.clear-btn{background:#374151}
.rider-search-actions button:disabled{opacity:.5;cursor:not-allowed}
.suggest ul{position:absolute;z-index:40;list-style:none;margin:0;padding:0;max-height:200px;overflow:auto;background:#fff;border:1px solid var(--border-color);border-radius:8px;width:300px;box-shadow:0 4px 14px rgba(0,0,0,.09)}
.suggest li{padding:6px 8px;cursor:pointer}
.suggest li:hover{background:var(--bg-soft)}

/* Pick Rows (Team Roping) */
.tr-row{display:flex;gap:8px;align-items:flex-start;position:relative}
.tr-row .tr-pick-widget{flex:0 0 260px;min-width:260px}
.tr-row select.tr-horse{flex:0 0 230px;min-width:210px;margin-left:4px}

/* Utility */
.flex{display:flex}
.flex-wrap{flex-wrap:wrap}
.gap-8{gap:8px}
.text-right{text-align:right}

/* Print handling placeholder (pages may override) */
@media print {
  .no-print{display:none!important}
  .print-only{display:block!important}
}

/* Alerts */
.alert{padding:10px 14px;border:1px solid transparent;border-radius:var(--radius-lg);font-size:14px;margin:0 0 16px;background:#fff}
.alert-danger{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}
.alert-warn{background:#fffbea;border-color:#fde68a;color:#92400e}
.alert-success{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}

/* Fieldsets / forms */
fieldset{border:1px solid var(--border-color);border-radius:10px;padding:10px 12px;min-width:220px;background:#fff}
legend{padding:0 6px;font-size:12px;color:#444}
.form-label{display:block;font-size:12px;margin:8px 0 4px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
.check{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:12px}

/* Link tiles (homepage) */
.links{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:10px}
a.tile{display:block;border:1px solid #e5e7eb;border-radius:10px;padding:14px 16px;background:#f8fafc;color:#1f2937;text-decoration:none;transition:.15s background,.15s color,.15s border-color}
a.tile:hover{border-color:var(--brand-orange);background:#fff7ed;color:#9a3412}

/* Small variant buttons */
.btn-soft.sm{padding:4px 8px;font-size:12px}

/* Legacy open-link button mapping */
.open-link-btn{display:inline-block;padding:4px 10px;border:1px solid var(--border-color);border-radius:var(--radius);text-decoration:none;font-size:12px;background:#f8fafc;color:#1f2937;cursor:pointer}
.open-link-btn:hover{background:#fff7ed;color:#9a3412;border-color:var(--brand-orange)}

/* Badge variants */
.badge-finalized{background:#eafbea;color:#065f46;border:1px solid #bbf7d0}
.badge-not-finalized{background:#fffbea;color:#92400e;border:1px solid #fde68a}

/* Inline utility */
form.inline{display:inline}

/* Rider profile & search utilities */
.kv{display:grid;grid-template-columns:160px 1fr;gap:6px;font-size:14px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width: 860px){ .two-col{grid-template-columns:1fr} }
.avatar{position:relative;padding-left:68px;min-height:56px}
.avatar img,.avatar .placeholder{position:absolute;left:0;top:0;width:56px;height:56px;border-radius:50%;object-fit:cover;border:1px solid #e5e7eb;background:#fff}
.avatar .placeholder{display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#6b7280;font-weight:600}
.tabs{display:flex;gap:8px;margin:8px 0}
.tab-btn{background:#eef2f7;border:1px solid var(--border-color);color:#111;padding:6px 10px;border-radius:var(--radius);cursor:pointer;font:inherit}
.tab-btn.active{background:var(--brand-orange);border-color:var(--brand-orange);color:#fff}
.form-grid{display:grid;gap:10px;max-width:460px}

/* Badge open/closed (entries) */
.badge-open{color:#15803d;font-weight:600}
.badge-closed{color:#b91c1c;font-weight:600}

/* Metric / stats layout helpers */
.metric-row{display:flex;justify-content:space-between;align-items:center;margin:0 0 6px}
.metric-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:12px}

/* Spacing utilities (selective) */
.p-16{padding:16px!important}
.mt-14{margin-top:14px!important}
.mb-8{margin-bottom:8px!important}
.m-0{margin:0!important}

/* Modal panels */
.modal-panel{background:#fff;border:1px solid var(--border-color);border-radius:12px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.2);max-width:96vw}
.modal-panel.sm{min-width:320px}
.modal-panel.md{min-width:340px}

/* Modal overlay */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:40}
.modal-overlay.show{display:flex}

/* Test / utility extras */
.note{font-size:12px;color:#475569;line-height:1.5;margin-top:10px}
.grid-cards{display:grid;gap:18px;margin-top:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.pre-block{background:#0f172a;color:#e2e8f0;padding:14px;border-radius:10px;font-size:12px;line-height:1.45;overflow:auto;margin:0}
.label-upper{text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.ok{background:#ecfdf5;color:#065f46;border:1px solid #34d399;padding:6px 10px;border-radius:8px;font-size:12px;margin-top:12px}
.warn{background:#fff8e1;color:#854d0e;border:1px solid #facc15;padding:6px 10px;border-radius:8px;font-size:12px;margin-top:12px}

/* Rider search avatar */
.rider-avatar{width:46px;height:46px;border-radius:50%;background:#f1f5f9;border:1px solid var(--border-color);flex:0 0 46px;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:12px;font-weight:600;color:#475569}
.rider-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.rider-avatar.initials{background:#fff7ed;color:#9a3412}
.rider-search-item.with-avatar{display:flex;align-items:center;gap:10px}
.rider-search-item.with-avatar .rs-main{flex:1;display:flex;justify-content:space-between;gap:8px}

/* Rider search widget (migrated from inline <style>) */
.rider-search-wrap{position:relative;max-width:340px;font:13px/1.3 system-ui,Arial,sans-serif}
.rider-search-input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}
.rider-search-results{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid #cbd5e1;border-radius:6px;margin-top:4px;z-index:50;max-height:260px;overflow:auto;box-shadow:0 4px 12px rgba(0,0,0,0.08)}
.rider-search-item{padding:6px 8px;cursor:pointer;font-size:13px;display:flex;justify-content:space-between;gap:8px}
.rider-search-item:hover{background:#f1f5f9}
.rider-search-empty{padding:8px;color:#64748b;font-size:12px}
.rider-search-actions{display:flex;gap:6px;margin-top:6px}
.rider-search-btn{background:var(--brand-orange,#ff6a1c);color:#fff;border:0;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer}
.rider-search-btn.secondary{background:#475569}

/* Table / listing avatars */
.avatar-circle{width:56px;height:56px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;background:#fff;object-fit:cover;line-height:1}
.avatar-circle img{width:100%;height:100%;display:block;object-fit:cover}
.avatar-circle.sm{width:40px;height:40px}
.avatar-circle.placeholder{background:#f3f4f6;color:#64748b;font-weight:600;font-size:14px;letter-spacing:.5px}

/* Location picker enhancements */
.location-wide{min-width:340px;width:480px;max-width:100%}
.location-modal-results{max-height:360px;overflow:auto;border:1px solid var(--border-color);border-radius:10px;margin-top:10px;background:#fff}
.location-modal-results div{padding:8px 10px;border-bottom:1px solid #eef2f7;cursor:pointer}
.location-modal-results div:last-child{border-bottom:none}
.location-modal-results div:hover{background:#fff7ed}

/* Event search widget */
.event-search-wrap{border:1px solid var(--border-color);border-radius:12px;padding:16px;background:#fff;max-width:760px;box-sizing:border-box}
.event-search-wrap .es-row{display:flex;gap:8px;margin-bottom:8px}
.event-search-wrap .es-controls{margin-bottom:4px}
.event-search-wrap .es-row:first-child{margin-top:2px}
.event-search-wrap .es-row:last-child{margin-bottom:0}
.event-search-wrap .es-row.gap{align-items:center}
.event-search-wrap .es-origin{flex:1;padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius)}
.event-search-wrap .es-filter{flex:1;padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius)}
.event-search-wrap select.es-radius{padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius);background:#fff}
.event-search-wrap .es-results{display:grid;grid-template-columns:1fr;gap:10px;max-height:480px;overflow:auto;margin-top:8px;padding-bottom:4px}
.event-search-wrap .es-item{display:flex;gap:12px;padding:12px;border:1px solid #e2e8f0;border-radius:10px;position:relative;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.event-search-wrap .es-item:hover{background:#fff7ed;border-color:#f0ad72}
.event-search-wrap .es-flyer-thumb{width:60px;height:60px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f8fafc;font-size:11px;font-weight:600;color:#475569;flex:0 0 60px}
.event-search-wrap .es-flyer-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.event-search-wrap .es-flyer-thumb.empty{color:#94a3b8;font-weight:500}
.event-search-wrap .es-main{flex:1;display:flex;flex-direction:column;gap:4px}
.event-search-wrap .es-title{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#111}
.event-search-wrap .es-title a{text-decoration:none;color:#111}
.event-search-wrap .es-distance{background:#111;color:#fff;border-radius:20px;padding:2px 8px;font-size:11px;line-height:1;font-weight:500}
.event-search-wrap .es-meta{color:#475569;font-size:13px;line-height:1.5}
.event-search-wrap .es-actions{display:flex;gap:6px;margin-top:4px}
.event-search-wrap .es-empty{padding:18px;text-align:center;color:#64748b}
.event-search-wrap .es-status{color:#475569}
.event-search-wrap .es-my-loc{border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;cursor:pointer;background:#f8fafc}
.event-search-wrap .es-my-loc:hover{background:#f1f5f9}
.es-flyer-preview{position:absolute;z-index:60;background:#fff;border:1px solid var(--border-color);padding:8px;border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.2);max-width:420px}
.es-flyer-preview img{max-width:400px;height:auto;display:block;border-radius:6px}

/* Spacing utilities used on homepage */
.p-20{padding:20px!important}
.px-20{padding-left:20px!important;padding-right:20px!important}
.mt-20{margin-top:20px!important}
.mt-40{margin-top:40px!important}
.mb-40{margin-bottom:40px!important}

/* Auth (login) pages: layout + spacing */
/* Scope by inline max-width used on login pages to avoid broad impact */
main[style*="max-width:420px"] .card{padding:16px}
main[style*="max-width:420px"] .card .form-label{
  display:grid;grid-template-columns:150px 1fr;align-items:center;gap:10px;
  margin:10px 0
}
main[style*="max-width:420px"] .card .form-label input,
main[style*="max-width:420px"] .card .form-label select,
main[style*="max-width:420px"] .card .form-label textarea{width:100%}
/* Align the remember-me row under the input column */
main[style*="max-width:420px"] .card .check{margin:10px 0 14px 0;padding-left:160px}
/* Align submit button with input column */
main[style*="max-width:420px"] .card form > .btn{margin-left:160px}

/* Responsive fallback: stack on small screens */
@media (max-width: 520px){
  main[style*="max-width:420px"] .card .form-label{grid-template-columns:1fr}
  main[style*="max-width:420px"] .card .check{padding-left:0}
  main[style*="max-width:420px"] .card form > .btn{margin-left:0}
}

/* Auth (signup) pages: rider (520px) and producer (480px) */
/* Rider signup: max-width 520px */
main[style*="max-width:520px"] .card{padding:16px}
main[style*="max-width:520px"] .card .form-label{
  display:grid;grid-template-columns:150px 1fr;align-items:center;gap:10px;margin:10px 0
}
main[style*="max-width:520px"] .card .form-label input,
main[style*="max-width:520px"] .card .form-label select,
main[style*="max-width:520px"] .card .form-label textarea{width:100%}
main[style*="max-width:520px"] .card form > .btn{margin-left:160px}
/* ensure helper text aligns under input column */
main[style*="max-width:520px"] .card .text-xs.text-muted{margin-left:160px}

/* Producer signup: max-width 480px */
main[style*="max-width:480px"] .card{padding:16px}
main[style*="max-width:480px"] .card .form-label{
  display:grid;grid-template-columns:150px 1fr;align-items:center;gap:10px;margin:10px 0
}
main[style*="max-width:480px"] .card .form-label input,
main[style*="max-width:480px"] .card .form-label select,
main[style*="max-width:480px"] .card .form-label textarea{width:100%}
main[style*="max-width:480px"] .card form > .btn{margin-left:160px}
/* ensure helper text aligns under input column */
main[style*="max-width:480px"] .card .text-xs.text-muted{margin-left:160px}

@media (max-width: 560px){
  main[style*="max-width:520px"] .card .form-label,
  main[style*="max-width:480px"] .card .form-label{grid-template-columns:1fr}
  main[style*="max-width:520px"] .card form > .btn,
  main[style*="max-width:480px"] .card form > .btn{margin-left:0}
  main[style*="max-width:520px"] .card .text-xs.text-muted,
  main[style*="max-width:480px"] .card .text-xs.text-muted{margin-left:0}
}
