/* 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;
}
/* Display font: Bronco (replaces test Western Bang Bang) */
@font-face {
  font-family: 'Bronco';
  src: url('../fonts/BroncoPersonalUse.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap; /* ensure fast text rendering */
}
/* Utility class for event title test */
.bronco-display { font-family: 'Bronco', system-ui, Arial, sans-serif; letter-spacing:1px; }
html,body {margin:0;padding:0;font-family:system-ui,Arial,sans-serif;color:#111;line-height:1.35}
/* Default page background (muted) */
body{background:var(--bg-muted)}
/* Arena photo background applied site-wide except on program pages that opt-out with .no-arena-bg */
body:not(.no-arena-bg){
  background:
    linear-gradient(rgba(255,255,255,.30), rgba(255,255,255,.30)),
    #000 url('../img/arena-bg-test.jpg') center center / cover no-repeat fixed;
  background-blend-mode: normal;
}
img {max-width:100%;height:auto}
/* Global display heading classes */
.h1,.h2,.h3 {font-family:'Bronco',system-ui,Arial,sans-serif;letter-spacing:1px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* 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);font-family:'Bronco',system-ui,Arial,sans-serif;letter-spacing:1px}
header a{color:var(--brand-orange);text-decoration:none;font-size:18px;font-weight:600;line-height:1}
header a:hover{text-decoration:underline}

/* Tabs - Orange underline style */
.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)}
/* Modern tab style with orange underline */
.em-tabs{display:flex;gap:0;margin:-24px -24px 20px -24px;padding:0 24px;border-bottom:2px solid #e5e7eb;background:#fff}
.em-tab-btn{padding:14px 20px;font-size:14px;font-weight:500;border:none;background:transparent;border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;color:#64748b;transition:all 0.2s;text-decoration:none!important;display:inline-block}
.em-tab-btn:hover{color:#ff6a1c;background:#fff5f0;text-decoration:none!important}
.em-tab-btn.active{background:transparent;color:#ff6a1c;border-bottom-color:#ff6a1c;font-weight:600;text-decoration:none!important}
/* Tabs inside .card (after .card-header) */
.card > .em-tabs{margin:-24px 0 20px 0;padding:0 24px;border-top:none}
.em-panel{display:none}
.em-panel.active{display:block}

/* Cards - Modern Orange Border Theme */
.card{background:#fff;border:2px solid #ff6a1c;border-radius:8px;margin-bottom:20px;box-shadow:0 1px 3px 0 rgba(0,0,0,0.1);overflow:hidden;padding:0}
/* Override parchment for cleaner look */
body:not(.program-page):not(.no-parchment) .card{background:#fff;border:2px solid #ff6a1c}
/* Nested cards maintain orange theme */
body:not(.program-page):not(.no-parchment) .grid .card,
body:not(.program-page):not(.no-parchment) #pendingTeamsCard,
body:not(.program-page):not(.no-parchment) #myTeamsCard,
body:not(.program-page):not(.no-parchment) #trDueCard,
body:not(.program-page):not(.no-parchment) #signupSponsorBanner{background:#fff;border:2px solid #ff6a1c}
/* Card headers - Orange background */
.card-header{background:#ff6a1c;color:#fff;padding:20px 24px;margin:0;display:flex;justify-content:space-between;align-items:center;border-bottom:none;font-family:'Bronco',system-ui,Arial,sans-serif;letter-spacing:1px}
.card-header h1,.card-header h2,.card-header h3,.card-header .h1,.card-header .h2,.card-header .h3{color:#fff !important;margin:0;font-size:20px;font-weight:600}
.card-header .small{color:rgba(255,255,255,0.9)}
/* Producer logo styling inside card-header */
.card-header .producer-logo-header{background:#fff;border:1px solid rgba(255,255,255,0.3);border-radius:8px;padding:6px 10px;margin:0;max-width:200px}
/* Buttons in card-header - white background with orange text */
.card-header .btn-soft{background:#fff;color:#ff6a1c;border:1px solid #fff;font-weight:600}
.card-header .btn-soft:hover{background:#fff7ed;color:#e55a0c;border-color:#fff7ed}
.card-body{padding:24px}
/* Provide default inner spacing when cards don't use .card-header/.card-body sections */
.card > :not(.card-header):not(.card-body){padding:14px}
/* Auto-styled orange headers for cards with direct h2/h3 headings */
.card.p-20 > h2.h2:first-child,
.card.p-16 > h2.h2:first-child,
.card.p-20 > h3.h3:first-child,
.card.p-16 > h3.h3:first-child {
  background: linear-gradient(135deg, #ff6a1c 0%, #ff8c3c 100%);
  color: #fff !important;
  margin: -20px -20px 20px -20px;
  padding: 20px 24px;
  font-family: 'Bronco', system-ui, Arial, sans-serif;
  letter-spacing: 1px;
  font-size: 20px;
  font-weight: 600;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  text-transform: uppercase;
}
.card.p-16 > h2.h2:first-child,
.card.p-16 > h3.h3:first-child {
  margin: -16px -16px 16px -16px;
  padding: 20px 24px;
}
/* Headings placed directly in a padded card (non-first-child pattern) */
.card > h1.h1,.card > h2.h2,.card > h3.h3 {font-family:'Bronco',system-ui,Arial,sans-serif;letter-spacing:1px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
/* Slight size bump for Bronco display without redefining base .h2 etc globally */
.card > h2.h2.bronco-display-size,.card > h3.h3.bronco-display-size {font-size:1.9rem}
/* Avoid double-padding when utility padding is applied directly on .card */
.card.p-16 > :not(.card-header):not(.card-body){padding:0}
.card.p-20 > :not(.card-header):not(.card-body){padding:0}
.card.px-20 > :not(.card-header):not(.card-body){padding-left:0;padding-right:0}
/* Avoid double-padding when .card-body is applied on the same element as .card */
.card.card-body > :not(.card-header):not(.card-body){padding:0}
/* Card links (dashboard cards) */
a.card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,0.15)}

/* Buttons - Unified Modern System */
.btn{background:#ff6a1c;color:#fff;border:1px solid #ff6a1c;padding:8px 16px;font-size:14px;border-radius:8px;cursor:pointer;font-weight:500;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px}
.btn:hover{background:#e55a0c;border-color:#e55a0c}
.btn-soft{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;border-radius:8px;padding:8px 16px;display:inline-flex;align-items:center;gap:6px;text-decoration:none;font-size:14px;font-weight:500;transition:all 0.15s;cursor:pointer}
.btn-soft:hover{background:#e2e8f0;color:#1e293b}
.btn-soft.active{background:#ff6a1c;color:#fff;border-color:#ff6a1c}
.btn-danger{background:#ef4444;color:#fff;border:1px solid #ef4444}
.btn-danger:hover{background:#dc2626;border-color:#dc2626}
.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:#ff6a1c;color:#9a3412;background:#fff7ed}
/* Additional button variants */
.btn-yellow{background:#fbbf24;color:#78350f;border:1px solid #fbbf24;padding:8px 16px;font-size:14px;border-radius:8px;cursor:pointer;font-weight:500;transition:all 0.15s}
.btn-yellow:hover{background:#f59e0b;border-color:#f59e0b}
.btn-blue{background:#3b82f6;color:#fff;border:1px solid #3b82f6;padding:8px 16px;font-size:14px;border-radius:8px;cursor:pointer;font-weight:500;transition:all 0.15s}
.btn-blue:hover{background:#2563eb;border-color:#2563eb}
.btn-green{background:#10b981;color:#fff;border:1px solid #10b981;padding:8px 16px;font-size:14px;border-radius:8px;cursor:pointer;font-weight:500;transition:all 0.15s}
.btn-green:hover{background:#059669;border-color:#059669}
.btn-red{background:#ef4444;color:#fff;border:1px solid #ef4444;padding:8px 16px;font-size:14px;border-radius:8px;cursor:pointer;font-weight:500;transition:all 0.15s}
.btn-red:hover{background:#dc2626;border-color:#dc2626}

/* 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}
/* Badges */
.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}
.badge-finalized{background:#dcfce7;color:#166534;border:1px solid #86efac}
.badge-not-finalized{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.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: base page box (orientation auto so ticket rules can override to portrait) */
@page { size: auto; margin: 10mm; }
@media print {
  html, body { background:#fff !important; color:#111 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .no-print{display:none!important}
  .print-only{display:block!important}
  /* Hide interactive UI in print if present */
  .btn, .btn-soft, .tab-btn, .tabs, header, .nav-tabs { display:none !important; }
  /* Use on-screen table styling to keep print identical */
  /* Constrain width and tighten spacing to prevent wrapping on Letter */
  main { max-width: 980px !important; margin: 0 auto !important; padding: 0 10px !important; }
  .card-header { padding: 8px 12px !important; }
  .card-body { padding: 10px 12px !important; }
  .table th, .table td { font-size: 12px !important; padding: 4px 6px !important; }
}

/* Alerts */
.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}
.alert-success{background:#ecfdf5;border:1px solid #10b981;color:#065f46}
.alert-danger{background:#fef2f2;border:1px solid #ef4444;color:#991b1b}
.alert-warn{background:#fffbea;border:1px solid #fde68a;color:#92400e}

/* 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}
/* --- Ticket Layout ------------------------------------------------------- */
.ticket-wrapper{display:flex;flex-direction:column;gap:18px}
/* Simplified new layout uses existing .ticket from later section; add admit side panels variant */
.ticket.admit{display:grid;grid-template-columns:60px 1fr 60px;min-height:170px;border:1px solid rgba(120,84,40,0.4);background:#fdfbf5;}
@media (max-width:760px){.ticket.admit{grid-template-columns:1fr;}}
.ticket-admit-panel{background:#4b2f23;color:#fff;writing-mode:vertical-rl;text-orientation:mixed;font-size:13px;letter-spacing:4px;display:flex;align-items:center;justify-content:center;font-weight:600;font-family:'Bronco',system-ui,Arial,sans-serif;}
.ticket-admit-panel span{transform:rotate(180deg);}
.ticket-core-grid{display:grid;grid-template-columns:1fr 200px;gap:18px;padding:16px 20px;align-items:flex-start;}
@media (max-width:960px){.ticket-core-grid{grid-template-columns:1fr 160px;padding:14px}}
@media (max-width:640px){.ticket-core-grid{grid-template-columns:1fr}}
.ticket-info h2{font-family:'Bronco',system-ui,Arial,sans-serif;margin:0 0 4px;font-size:30px;letter-spacing:1px;line-height:1.05}
@media (max-width:960px){.ticket-info h2{font-size:26px}}
.ticket-price{font-family:'Bronco',system-ui,Arial,sans-serif;font-size:32px;font-weight:600;letter-spacing:2px;margin:0 0 6px;color:#111}
.ticket-code-block{margin-top:2px;font-family:monospace;font-size:12px;letter-spacing:2px;background:#fff;border:1px dashed #7b6a52;padding:6px 8px;border-radius:6px;display:inline-block;color:#111}
.ticket-barcode-box{background:#e8f1fa;border:1px solid #334155;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;margin-top:8px;min-height:60px;min-width:140px}
.ticket-barcode-box img{max-width:100%;height:auto;display:block}

/* Unified Event Ticket (info left, flyer right) */
/* Base ticket uses Bronco everywhere (fallback system fonts) */
.event-ticket{--et-pady:18px;display:grid;grid-template-columns:1fr 190px;gap:26px;position:relative;background:#fdfbf5;border:1px solid rgba(120,84,40,0.35);border-radius:12px;padding:var(--et-pady) 70px;font-family:'Bronco',system-ui,Arial,sans-serif;overflow:hidden;min-height:160px;box-sizing:border-box;aspect-ratio:2.857/1}
/* Variant with flyer on the left */
.event-ticket.flyer-left{grid-template-columns:190px 1fr}
@media (max-width:820px){
  .event-ticket{grid-template-columns:1fr 160px;gap:18px;--et-pady:16px;padding:var(--et-pady) 18px}
  .event-ticket.flyer-left{grid-template-columns:160px 1fr}
}
@media (max-width:600px){
  .event-ticket{grid-template-columns:1fr;--et-pady:14px;padding:var(--et-pady) 16px}
  .event-ticket.flyer-left{grid-template-columns:1fr}
}
/* Add configurable admit bar background variable (site orange) */
.event-ticket.admit{--admit-bar-w:44px;--admit-bar-bg:#d97706}
/* Structural admit bars */
.event-ticket.admit .admit-bar{position:absolute;top:0;bottom:0;width:var(--admit-bar-w);background:var(--admit-bar-bg);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Bronco',system-ui,Arial,sans-serif;letter-spacing:2px;font-size:11px;font-weight:600}
.event-ticket.admit .admit-bar.admit-left{left:0;border-top-left-radius:12px;border-bottom-left-radius:12px}
.event-ticket.admit .admit-bar.admit-right{right:0;border-top-right-radius:12px;border-bottom-right-radius:12px}
.event-ticket.admit .admit-bar .admit-inner{display:flex;flex-direction:column;align-items:center;justify-content:space-between;height:100%;padding:7px 0;box-sizing:border-box;gap:6px}
.event-ticket.admit .admit-bar .adm-label{font-size:11px;font-weight:600;letter-spacing:2px;writing-mode:vertical-rl;text-orientation:mixed}
.event-ticket.admit .admit-bar .adm-price{font-family:system-ui,Arial,sans-serif;font-size:9px;font-weight:600;letter-spacing:1px;writing-mode:vertical-rl;text-orientation:mixed}
/* Adjust for very narrow screens: hide bars */
@media (max-width:900px){.event-ticket{padding:16px 20px}.event-ticket.admit .admit-bar{display:none}}
.et-info{display:flex;flex-direction:column;gap:8px;z-index:1;min-width:0;overflow:hidden}
.et-header{display:flex;align-items:flex-start;flex-wrap:wrap;gap:14px;min-width:0}
.et-title{font-size:30px;line-height:1.05;margin:0;letter-spacing:1px;color:#23160f;flex:1 1 auto;min-width:0;word-break:break-word}
@media (max-width:820px){.et-title{font-size:26px}}
.et-price{margin-left:auto;font-size:32px;letter-spacing:2px;color:#23160f}
.et-meta{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#2d241f;margin-top:4px}
.et-meta .et-line{display:flex;flex-wrap:wrap;gap:14px}
.et-meta-label{font-weight:700;letter-spacing:.5px;font-size:12px;color:#3a2a1c;text-transform:uppercase;margin-bottom:2px}
.et-meta span.label{font-weight:600;color:#111;margin-right:4px}
.et-row-inline{display:flex;align-items:center;flex-wrap:wrap;gap:16px;margin-top:4px}
.et-code{font-family:monospace;font-size:12px;letter-spacing:2px;background:#fff;border:1px dashed #7b6a52;padding:6px 8px;border-radius:6px;display:inline-block;color:#111;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.et-barcode{background:#e8f1fa;border:1px solid #334155;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;margin-top:0;min-height:52px;min-width:120px}
.et-barcode img{max-width:100%;height:auto;display:block}
.et-sponsors{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.et-sponsors img{height:36px;max-width:110px;object-fit:contain;background:#fff;border:1px solid #e2e2e2;border-radius:6px;padding:4px 6px}
.et-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.et-note{font-size:11px;color:#5f4b39;line-height:1.35;margin-top:6px;max-width:520px}
.et-flyer{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.18);background:#fff;min-height:180px;height:100%}
.et-flyer img{width:100%;height:100%;object-fit:cover;display:block}
/* Letter ratio variant (fits full 8.5x11 flyer without side crop). Uses width-dominant scaling inside ticket column */
.et-flyer.letter-full{aspect-ratio:17/22;height:auto;align-self:stretch;display:flex}
.et-flyer.letter-full img{object-fit:contain;background:#000}
/* When used with flush-flyer, maintain negative bleed but respect intrinsic aspect ratio */
.event-ticket.layout-3.flush-flyer .et-flyer.letter-full{margin-top:calc(var(--et-pady) * -1);margin-bottom:calc(var(--et-pady) * -1);height:auto}
@media print {.et-flyer.letter-full{aspect-ratio:17/22}}
@media (max-width:600px){.et-flyer{max-width:280px;justify-self:center}}
/* 3-column layout variant (flyer, info, aside) */
.event-ticket.layout-3{grid-template-columns:150px 1fr 210px}
/* Ticket-default specific tightening for 7in x 2.5in physical target */
.ticket-default.event-ticket.layout-3{grid-template-columns:110px 1fr 190px;padding:var(--et-pady) 44px;gap:18px}
/* Perforated multi-zone layout */
.ticket-default.perf-layout{--perf-gap:22px;display:grid;grid-template-columns:180px minmax(0,1fr) 190px;gap:var(--perf-gap);padding:18px 44px 18px 50px;align-items:start;position:relative;height:2.5in;min-height:unset;overflow:hidden}
.ticket-default.perf-layout .t-zone{min-width:0}
.ticket-default.perf-layout .t-flyer{display:flex;align-items:flex-start}
.ticket-default.perf-layout .flyer-img{width:100%;height:auto;max-height:225px;object-fit:contain;border:1px solid #1d150f;border-radius:2px;background:#fff;margin-top:-4px}
.ticket-default.perf-layout .flyer-placeholder{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;font-size:12px;border:1px dashed #cbd5e1;background:#fff;color:#555}
.ticket-default.perf-layout .t-main{display:flex;flex-direction:column;gap:10px;min-width:0;--ticket-title-fs:24px}
.ticket-default.perf-layout .t-main .et-title{margin:0;font-size:var(--ticket-title-fs);line-height:1.02;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ticket-default.perf-layout .t-main .et-title.fit-one-line{transition:font-size .12s ease}
.ticket-default.perf-layout .t-type{font-size:14px;font-weight:600;letter-spacing:.5px}
.ticket-default.perf-layout .t-meta{font-size:12px;display:flex;flex-direction:column;gap:4px;line-height:1.25}
.ticket-default.perf-layout .t-meta .m-label{font-weight:700;font-size:11px;letter-spacing:.5px;margin-bottom:2px}
.ticket-default.perf-layout .logos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px;max-width:380px}
.ticket-default.perf-layout .logo-box{height:48px;border:1px dashed #9ca3af;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:10px;letter-spacing:1px;background:#fff;color:#64748b}
.ticket-default.perf-layout .t-perf{display:none}
.ticket-default.perf-layout .t-aside{position:relative}
.ticket-default.perf-layout .t-aside .t-perf-inline{position:absolute;top:0;bottom:0;left:0;width:2px;display:flex;align-items:center;justify-content:center}
.ticket-default.perf-layout .t-aside .t-perf-inline::before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:2px;background:repeating-linear-gradient(180deg,#222 0 6px,transparent 6px 12px);opacity:.6}
.ticket-default.perf-layout .t-aside .t-perf-inline .cut-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);writing-mode:vertical-rl;text-orientation:mixed;font-size:11px;letter-spacing:4px;font-weight:600;color:#1d150f}
.ticket-default.perf-layout .cut-text{writing-mode:vertical-rl;text-orientation:mixed;font-size:11px;letter-spacing:4px;font-weight:600;color:#1d150f}
.ticket-default.perf-layout .t-aside{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.ticket-default.perf-layout .price-row .et-price-block{font-size:30px;margin:0}
.ticket-default.perf-layout .code-row .et-code{margin-top:0}
.ticket-default.perf-layout .qr-box{width:150px;max-width:150px;aspect-ratio:1/1;background:#e8f0fa;border:2px solid #1d2a38;border-radius:8px;display:flex;align-items:center;justify-content:center}
.ticket-default.perf-layout .qr-box.blank::after{content:"";width:40%;height:40%;border:3px solid #a7b2bd;border-radius:4px}
.ticket-default.perf-layout .qr-box img.qr{max-width:86%;max-height:86%;display:block}
@media (max-width:1200px){
  .ticket-default.perf-layout{grid-template-columns:175px 1fr 180px;padding:24px 50px;--perf-gap:22px}
  .ticket-default.perf-layout .t-main .et-title{font-size:var(--ticket-title-fs)}
  .ticket-default.perf-layout .price-row .et-price-block{font-size:26px}
}
@media (max-width:980px){
  .ticket-default.perf-layout{grid-template-columns:165px 1fr 170px;padding:22px 38px;--perf-gap:20px}
}
/* Print multi-up adjustments */
@media print {
  body,html{background:#fff !important}
  /* Hide nav and non-ticket cards */
  nav,header,footer,.card:not(.tickets-print-card){display:none !important}
  /* Ensure the tickets card body flex wraps with no gaps */
  .tickets-print-card .ticket-wrapper{display:flex !important;flex-direction:column;gap:0 !important;margin:0 !important;padding:0 !important}
  .tickets-print-card .ticket-wrapper .ticket-default{margin:0 0 0 0 !important;page-break-inside:avoid;break-inside:avoid;transform:none !important;box-shadow:none !important}
  .ticket-default.event-ticket.perf-layout{width:7.5in !important;height:2.5in !important}
  @page { margin:0.25in }
}
@media (max-width:860px){
  .ticket-default.perf-layout{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;}
  .ticket-default.perf-layout .t-perf{order:4;height:40px}
  .ticket-default.perf-layout .t-perf::before{left:0;right:0;top:50%;bottom:auto;width:100%;height:2px;transform:translateY(-50%);background:repeating-linear-gradient(90deg,#222 0 6px,transparent 6px 12px)}
  .ticket-default.perf-layout .cut-text{writing-mode:horizontal-tb;letter-spacing:8px}
  .ticket-default.perf-layout .t-aside{flex-direction:row;flex-wrap:wrap}
  .ticket-default.perf-layout .qr-box{flex:none}
}
@media print{
  .ticket-default.perf-layout{grid-template-columns:170px 1fr 160px;padding:16px 32px;--perf-gap:14px}
  .ticket-default.perf-layout .t-main .et-title{font-size:24px}
  .ticket-default.perf-layout .price-row .et-price-block{font-size:22px}
  .ticket-default.perf-layout .logo-box{height:48px;font-size:10px}
  .ticket-default.perf-layout .qr-box{border-width:1px}
  /* Force admit bars visible even if browser disables background printing */
  .event-ticket.admit .admit-bar{display:flex !important;background:var(--admit-bar-bg) !important;color:#fff !important;-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:inset 0 0 0 1px #a45300}
  /* Provide fallback outline if background is suppressed */
  @supports (-webkit-print-color-adjust: exact){ .event-ticket.admit .admit-bar{box-shadow:none} }
}
@media (max-width:1100px){.ticket-default.event-ticket.layout-3{grid-template-columns:120px 1fr 180px}}
@media (max-width:900px){.ticket-default.event-ticket.layout-3{grid-template-columns:160px 1fr}}
@media (max-width:600px){.ticket-default.event-ticket.layout-3{grid-template-columns:1fr}}
.ticket-default .et-title{font-size:24px}
@media print {.ticket-default .et-title{font-size:20px !important}}
.ticket-default .et-type-line{font-size:12px;margin-top:0}
.ticket-default .et-meta{font-size:12px}
.ticket-default .et-meta-label{font-size:11px}
.ticket-default .et-price-block{font-size:20px;letter-spacing:1px;margin-bottom:2px}
@media print {.ticket-default .et-price-block{font-size:18px}}
.ticket-default .et-code{font-size:11px;padding:4px 6px}
.ticket-default .et-sponsors img{height:28px;max-width:90px;padding:3px 4px}
.ticket-default .et-note{font-size:10px;max-width:420px}
.ticket-default .et-flyer{min-height:160px;overflow:hidden}
.ticket-default .et-info{padding-left:12px}
.ticket-default .et-flyer.letter-full{aspect-ratio:17/22}
.ticket-default .et-flyer img{object-fit:cover}
.ticket-default .et-barcode{padding:4px 6px;min-width:100px}
.ticket-default .et-barcode img.qr{width:120px;max-width:120px}
.ticket-default.event-ticket.admit::before,.ticket-default.event-ticket.admit::after{width:44px;font-size:11px}
@media print {.ticket-default.event-ticket.admit::before,.ticket-default.event-ticket.admit::after{width:40px;font-size:10px}}
/* Flush flyer variant: removes visual top/bottom bars by bleeding flyer into vertical padding space */
/* Flush-flyer disabled for standard layout; keep rule for backward compatibility but inactive unless class present */
.event-ticket.layout-3.flush-flyer .et-flyer{margin-top:0;margin-bottom:0;height:100%;border-radius:6px}
@media (max-width:900px){.event-ticket.layout-3.flush-flyer .et-flyer{margin-top:0;margin-bottom:0;height:100%;border-radius:6px}}
@media (max-width:1100px){.event-ticket.layout-3{grid-template-columns:160px 1fr 190px}}
@media (max-width:900px){.event-ticket.layout-3{grid-template-columns:180px 1fr}}
@media (max-width:900px){.event-ticket.layout-3 .et-aside{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;margin-top:10px}}
@media (max-width:600px){.event-ticket.layout-3{grid-template-columns:1fr}.event-ticket.layout-3 .et-flyer{max-width:260px;justify-self:start}}
.et-aside{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.et-aside-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.et-type-line{font-size:14px;font-weight:600;letter-spacing:.5px;color:#2d241f;margin-top:2px}
.et-aside .et-code{margin-top:0}
.et-aside .et-barcode{margin-top:0}
.et-price-block{font-size:24px;letter-spacing:2px;font-family:'Bronco',system-ui,Arial,sans-serif;color:#23160f;margin:0 0 4px}
@media (max-width:900px){.et-price-block{font-size:22px}}
@media print {.et-price-block{font-size:20px;margin-bottom:2px}}
/* Print layout adjustments (scoped strictly to tickets-print-root) */
@media print {
  /* Force portrait Letter for ticket pages (placed after base @page so it wins in most browsers) */
  @page { size: letter; margin:10mm; }
  body,html{background:#fff !important;margin:0;padding:0}
  /* Hide everything by default */
  body *{visibility:hidden !important}
  /* Show ticket root + children */
  .tickets-print-root, .tickets-print-root *{visibility:visible !important}
  nav, header, footer, .site-nav{display:none !important}
  /* Remove container/card constraints so ticket spans full printable width */
  .tickets-print-root{max-width:none !important;width:100% !important;margin:0 !important;padding:0 !important;display:block !important}
  .tickets-print-root .card{border:none !important;box-shadow:none !important;padding:0 !important;margin:0 !important;background:transparent !important}
  .tickets-print-root .card-body{padding:0 !important}
  /* Preserve ticket layout exactly; remove aspect-ratio so height fits content */
  .event-ticket{page-break-inside:avoid;box-shadow:none !important;width:100% !important;aspect-ratio:auto !important;}
  /* Fixed height so exactly 4 tickets fit per Letter page (accounting for margins & 12px gaps).
    Letter printable height ~= 980px after margins; (980 - 3*12) / 4 ≈ 236px => choose 235px for buffer */
  .event-ticket{height:235px;overflow:hidden;}
  /* Compact sizing to fit 4-5 tickets per sheet (Letter portrait) */
  .event-ticket{--et-pady:12px;padding:var(--et-pady) 50px;gap:16px;}
  .event-ticket.layout-3.flush-flyer .et-flyer{margin-top:calc(var(--et-pady) * -1);margin-bottom:calc(var(--et-pady) * -1);height:calc(100% + (var(--et-pady) * 2));border-radius:0}
  .event-ticket.layout-3{grid-template-columns:150px 1fr 180px}
  .ticket-default.event-ticket.layout-3{grid-template-columns:110px 1fr 170px;padding:var(--et-pady) 38px;gap:14px}
  .ticket-default .et-barcode img.qr{width:110px;max-width:110px}
  .ticket-default .et-flyer{min-height:150px}
  .et-title{font-size:22px !important;}
  .et-price{font-size:24px !important;}
  .et-meta{font-size:12px !important;gap:2px}
  .et-meta-label{font-size:11px !important;margin-bottom:0}
  .et-sponsors{gap:6px;margin-top:6px}
  .et-sponsors img{height:26px;max-width:80px;padding:2px 4px}
  /* Clamp sponsor zone to prevent vertical growth pushing ticket to next page */
  .et-sponsors{max-height:56px;overflow:hidden}
  .et-barcode{padding:4px 8px;min-width:110px}
  .et-code{font-size:11px;padding:4px 6px}
  .et-note{font-size:10px;max-width:480px;margin-top:4px}
  /* Ensure admit bars always visible in print (override mobile hide breakpoint) */
  .event-ticket.admit::before,.event-ticket.admit::after{display:flex !important;width:44px !important;font-size:10px !important;letter-spacing:2px !important}
  /* Maintain spacing between tickets */
  .event-ticket + .event-ticket{margin-top:12px !important}
  /* Keep QR block from pushing downward by disallowing unintended scaling */
  .et-aside{align-self:flex-start}
  .et-barcode{min-height:0 !important}
  /* Page break every 5 tickets for cleaner splits on Letter */
  /* Page break every 4 tickets for Letter portrait */
  .tickets-print-root .event-ticket:nth-of-type(4n){page-break-after:always;}
  /* Remove top spacing that could cause blank first page */
  .tickets-print-root .mt-40, .tickets-print-root .mt-20 { margin-top:0 !important; }
  /* Eliminate blank first page: remove flow dependence of hidden preceding nodes */
  .tickets-print-root{position:absolute;top:0;left:0;right:0}
}
.ticket-code{font-family:monospace;font-size:12px;background:#fff;border:1px dashed #cbd5e1;padding:4px 8px;border-radius:8px;letter-spacing:1px;color:#334155;align-self:flex-start;margin-top:auto}
.ticket-actions{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.ticket-barcode{margin-top:10px;align-self:flex-start;border:1px dashed #999;padding:6px 10px;background:#fff;font-family:monospace;font-size:12px;letter-spacing:3px;border-radius:8px}
/* Perforation effect */
.ticket:before{content:"";position:absolute;top:0;bottom:0;left:180px;width:18px;background:repeating-linear-gradient(180deg,#fdfbf5 0 6px,#e2e8f0 6px 7px);}
.ticket.no-image:before{display:none}
.ticket:after{content:"";position:absolute;top:0;bottom:0;left:180px;width:1px;background:linear-gradient(#d1d9e2 60%,rgba(0,0,0,0) 0);background-size:1px 10px}
.ticket.no-image:after{display:none}
@media (max-width: 640px){
  .ticket{flex-direction:column}
  .ticket:before,.ticket:after{left:0;top:180px;width:100%;height:18px}
  .ticket-media{flex:0 0 180px;max-width:none;height:180px}
}
/* Unified 7in x 2.5in ticket sizing */
.ticket-default{--ticket-width:7.5in;--ticket-height:2.5in;width:var(--ticket-width);height:var(--ticket-height);max-width:none;box-sizing:border-box;}
@media screen{
  .ticket-default{width:7.5in;height:2.5in;}
}
@media print{
  .ticket-default{width:7.5in;min-height:2.5in;height:2.5in;}
  /* Minimize vertical spacing specifically for unified template stack */
  .tickets-print-root .ticket-default{margin-bottom:6mm;}
}
.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:fixed;background:#fff;border:1px solid #cbd5e1;border-radius:6px;margin-top:4px;z-index:9999;max-height:320px;overflow:auto;box-shadow:0 4px 12px rgba(0,0,0,0.15);min-width:300px}
.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}

/* Facility search widget */
.facility-search-wrap{position:relative;max-width:340px;font:13px/1.3 system-ui,Arial,sans-serif}
.facility-search-input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}
.facility-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)}
.facility-search-item{padding:8px 10px;cursor:pointer;font-size:13px;border-bottom:1px solid #f1f5f9}
.facility-search-item:last-child{border-bottom:0}
.facility-search-item:hover{background:#f1f5f9}
.facility-search-item.with-icon{display:flex;align-items:center;gap:10px}
.facility-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.facility-search-item .fs-main{flex:1;display:flex;flex-direction:column;gap:2px}
.facility-search-item .fs-name{font-weight:500;color:#111827}
.facility-search-item .fs-meta{font-size:12px;color:#6b7280}
.facility-search-empty{padding:8px;color:#64748b;font-size:12px}
.facility-search-actions{display:flex;gap:6px;margin-top:6px}
.facility-search-btn{background:var(--brand-orange,#ff6a1c);color:#fff;border:0;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer}
.facility-search-btn.secondary{background:#475569}

/* Producer search widget - reuses facility search styles */
.producer-search-wrap{position:relative;max-width:340px;font:13px/1.3 system-ui,Arial,sans-serif}
.producer-search-input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}
.producer-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)}
.producer-search-item{padding:8px 10px;cursor:pointer;font-size:13px;border-bottom:1px solid #f1f5f9}
.producer-search-item:last-child{border-bottom:0}
.producer-search-item:hover{background:#f1f5f9}
.producer-search-item.with-icon{display:flex;align-items:center;gap:10px}
.producer-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.producer-search-item .ps-main{flex:1;display:flex;flex-direction:column;gap:2px}
.producer-search-item .ps-name{font-weight:500;color:#111827}
.producer-search-item .ps-meta{font-size:12px;color:#6b7280}
.producer-search-empty{padding:8px;color:#64748b;font-size:12px}
.producer-search-actions{display:flex;gap:6px;margin-top:6px}
.producer-search-btn{background:var(--brand-orange,#ff6a1c);color:#fff;border:0;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer}
.producer-search-btn.secondary{background:#475569}

/* Stock Contractor search widget */
.stock-contractor-search-wrap{position:relative;max-width:340px;font:13px/1.3 system-ui,Arial,sans-serif}
.stock-contractor-search-input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}
.stock-contractor-search-results{position:fixed;background:#fff;border:1px solid #cbd5e1;border-radius:6px;margin-top:4px;z-index:9999;max-height:320px;overflow:auto;box-shadow:0 4px 12px rgba(0,0,0,0.15);min-width:300px}
.stock-contractor-search-item{padding:8px 10px;cursor:pointer;font-size:13px;border-bottom:1px solid #f1f5f9}
.stock-contractor-search-item:last-child{border-bottom:0}
.stock-contractor-search-item:hover{background:#f1f5f9}
.stock-contractor-search-item.with-icon{display:flex;align-items:center;gap:10px}
.contractor-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.stock-contractor-search-item .sc-main{flex:1;display:flex;flex-direction:column;gap:2px}
.stock-contractor-search-item .sc-name{font-weight:500;color:#111827}
.stock-contractor-search-item .sc-meta{font-size:12px;color:#6b7280}
.stock-contractor-search-empty{padding:8px;color:#64748b;font-size:12px}
.stock-contractor-search-actions{display:flex;gap:6px;margin-top:6px}
.stock-contractor-search-btn{background:var(--brand-orange,#ff6a1c);color:#fff;border:0;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer}
.stock-contractor-search-btn.secondary{background:#475569}

/* Calendar Modal */
.calendar-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;font-family:system-ui,-apple-system,sans-serif}
.calendar-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px)}
.calendar-modal-content{position:relative;max-width:min(90vw,780px);margin:40px auto;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);max-height:calc(100vh - 80px);display:flex;flex-direction:column}
.calendar-modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}
.calendar-modal-title{margin:0;font-size:18px;font-weight:600;color:#111827}
.calendar-modal-close{background:none;border:0;font-size:28px;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}
.calendar-modal-close:hover{background:#f3f4f6;color:#111827}
.calendar-modal-nav{padding:12px 24px;border-bottom:1px solid #e5e7eb;display:flex;gap:8px;justify-content:center;background:#f9fafb}
.calendar-nav-btn{padding:8px 16px;border:1px solid #cbd5e1;background:#fff;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all 0.15s}
.calendar-nav-btn:hover{background:#f1f5f9;border-color:#94a3b8}
.calendar-nav-btn:active{background:#e2e8f0}
.calendar-modal-body{padding:24px;overflow-y:auto;flex:1}
.calendar-selected-count{text-align:center;margin-top:16px;font-size:14px;font-weight:500}
.calendar-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}
.calendar-day-cell{border:1px solid #cbd5e1;background:#fff;padding:8px 4px;font-size:12px;cursor:pointer;border-radius:6px;text-align:center;min-height:36px;position:relative;transition:all 0.15s;font-weight:500;color:#374151}
.calendar-day-cell:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}
.calendar-day-cell.selected{background:#2563eb;color:#fff;border-color:#1d4ed8;font-weight:600}
.calendar-day-cell.selected:hover{background:#1d4ed8}
.calendar-day-cell.disabled{opacity:0.4;cursor:not-allowed;background:#f9fafb;color:#9ca3af}
.calendar-day-cell .event-indicator{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:currentColor;opacity:0.6}
.calendar-day-cell.selected .event-indicator{background:#fff;opacity:1}

/* Time Modal */
.time-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;align-items:center;justify-content:center}
.time-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px)}
.time-modal-content{position:relative;max-width:min(90vw,480px);width:100%;margin:40px auto;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);max-height:calc(100vh - 80px);display:flex;flex-direction:column}
.time-modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}
.time-modal-title{margin:0;font-size:18px;font-weight:600;color:#111827}
.time-modal-close{background:none;border:0;font-size:28px;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}
.time-modal-close:hover{background:#f3f4f6;color:#111827}
.time-modal-body{padding:24px;overflow-y:auto;flex:1}
.time-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}
.time-input-section{margin-bottom:24px}
.time-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}
.time-text-input{width:100%;padding:12px 16px;border:2px solid #cbd5e1;border-radius:8px;font-size:16px;transition:all 0.15s}
.time-text-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
.time-help-text{margin-top:8px;font-size:13px;color:#6b7280;line-height:1.5}
.time-help-text span{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:12px}
.time-picker-section{background:#f9fafb;border-radius:8px;padding:20px;margin-bottom:20px}
.time-display{text-align:center;font-size:48px;font-weight:700;color:#111827;margin-bottom:20px;font-variant-numeric:tabular-nums}
.time-controls{display:flex;gap:16px;justify-content:center;align-items:flex-end}
.time-control-group{text-align:center}
.time-control-group label{display:block;font-size:12px;font-weight:600;color:#6b7280;margin-bottom:8px;text-transform:uppercase;letter-spacing:0.5px}
.time-stepper{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:4px}
.time-btn{background:#fff;border:1px solid #cbd5e1;width:36px;height:36px;border-radius:6px;font-size:18px;font-weight:600;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;justify-content:center;color:#374151}
.time-btn:hover{background:#f1f5f9;border-color:#94a3b8}
.time-btn:active{background:#e2e8f0}
.time-hour-display,.time-minute-display{min-width:40px;font-size:24px;font-weight:700;color:#111827;text-align:center;font-variant-numeric:tabular-nums}
.time-period-toggle{display:flex;gap:4px;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:4px}
.time-period-btn{background:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.15s;color:#6b7280}
.time-period-btn:hover{background:#f1f5f9}
.time-period-btn.active{background:#2563eb;color:#fff}
.time-presets{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.time-preset-btn{background:#fff;border:1px solid #cbd5e1;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.15s;color:#374151}
.time-preset-btn:hover{background:#f1f5f9;border-color:#94a3b8}
.time-preset-btn:active{background:#dbeafe;border-color:#2563eb;color:#1e40af}

/* Image Upload Modal */
.image-upload-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;align-items:center;justify-content:center}
.image-upload-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px)}
.image-upload-modal-content{position:relative;max-width:min(90vw,600px);width:100%;margin:40px auto;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);max-height:calc(100vh - 80px);display:flex;flex-direction:column}
.image-upload-modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}
.image-upload-modal-title{margin:0;font-size:18px;font-weight:600;color:#111827}
.image-upload-modal-close{background:none;border:0;font-size:28px;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}
.image-upload-modal-close:hover{background:#f3f4f6;color:#111827}
.image-upload-modal-body{padding:24px;overflow-y:auto;flex:1}
.image-upload-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}
.image-upload-dropzone{border:2px dashed #cbd5e1;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all 0.2s;background:#f9fafb}
.image-upload-dropzone:hover{border-color:#94a3b8;background:#f1f5f9}
.image-upload-dropzone.dragover{border-color:#2563eb;background:#dbeafe;border-style:solid}
.image-upload-icon{font-size:64px;margin-bottom:16px}
.image-upload-text{font-size:16px;color:#374151;margin-bottom:8px}
.image-upload-text strong{color:#111827}
.image-upload-hint{font-size:13px;color:#6b7280}
.image-upload-preview{text-align:center}
.image-upload-preview-container{background:#f9fafb;border-radius:12px;padding:16px;margin-bottom:16px;border:1px solid #e5e7eb}
.image-upload-preview-img{max-width:100%;max-height:400px;display:block;margin:0 auto;border-radius:8px;box-shadow:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06)}
.image-upload-info{text-align:center}
.image-upload-filename{font-size:14px;font-weight:600;color:#111827;margin-bottom:4px;word-break:break-all}
.image-upload-filesize{font-size:13px;color:#6b7280}
.image-upload-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:8px;margin-top:16px;font-size:14px}

/* Select Modal */
.select-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;align-items:center;justify-content:center}
.select-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px)}
.select-modal-content{position:relative;max-width:min(90vw,540px);width:100%;margin:40px auto;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);max-height:calc(100vh - 80px);display:flex;flex-direction:column}
.select-modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}
.select-modal-title{margin:0;font-size:18px;font-weight:600;color:#111827}
.select-modal-close{background:none;border:0;font-size:28px;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}
.select-modal-close:hover{background:#f3f4f6;color:#111827}
.select-modal-search{padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}
.select-search-input{width:100%;padding:10px 16px;border:2px solid #cbd5e1;border-radius:8px;font-size:15px;transition:all 0.15s}
.select-search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
.select-modal-body{padding:12px;overflow-y:auto;flex:1;max-height:400px}
.select-options-list{display:flex;flex-direction:column;gap:4px}
.select-option-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all 0.15s;border:1px solid transparent}
.select-option-item:hover{background:#f1f5f9;border-color:#e2e8f0}
.select-option-item.selected{background:#dbeafe;border-color:#93c5fd}
.select-option-icon{font-size:24px;flex-shrink:0;width:32px;text-align:center}
.select-option-content{flex:1;min-width:0}
.select-option-label{font-size:15px;font-weight:500;color:#111827}
.select-option-description{font-size:13px;color:#6b7280;margin-top:2px}
.select-option-check{font-size:18px;font-weight:700;color:#2563eb;flex-shrink:0}
.select-empty-state{text-align:center;padding:48px 20px;color:#9ca3af;font-size:15px}
.select-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}

/* Select Modal Trigger Button */
.select-modal-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 16px;
  background:#fff;
  border:1px solid #cbd5e1;
  border-radius:6px;
  font-size:15px;
  color:#374151;
  cursor:pointer;
  transition:all 0.15s;
  text-align:left;
}
.select-modal-trigger:hover{
  border-color:#94a3b8;
  background:#f9fafb;
}
.select-modal-trigger:focus{
  outline:none;
  border-color:#ff6a1c;
  box-shadow:0 0 0 3px rgba(255,106,28,0.1);
}
.select-arrow{
  color:#6b7280;
  font-size:12px;
  transition:transform 0.2s;
}
.select-modal-trigger:hover .select-arrow{
  color:#374151;
}

/* Toggle Button Group */
.toggle-button-group{
  display:flex;
  gap:8px;
  margin-top:6px;
}
.toggle-option{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 16px;
  background:#fff;
  border:2px solid #cbd5e1;
  border-radius:8px;
  font-size:15px;
  font-weight:500;
  color:#6b7280;
  cursor:pointer;
  transition:all 0.15s;
}
.toggle-option:hover{
  border-color:#94a3b8;
  background:#f9fafb;
}
.toggle-option.active{
  background:#dbeafe;
  border-color:#2563eb;
  color:#1e40af;
}
.toggle-check{
  font-size:16px;
  font-weight:700;
  opacity:0;
  transition:opacity 0.15s;
}
.toggle-option.active .toggle-check{
  opacity:1;
}




/* 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{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 card layout - shared with producer pages */
.em-event-layout{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:16px 20px}
.em-event-header{grid-column:1;grid-row:1;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.em-event-footer{grid-column:1;grid-row:2;display:flex;gap:8px;padding-top:16px;border-top:1px solid #e5e7eb;flex-wrap:wrap}
.em-event-flyer{grid-column:2;grid-row:1 / 3;width:140px;height:100%;min-height:180px;border-radius:10px;overflow:hidden;border:1px solid #e5e7eb;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f9fafb}
.em-event-flyer img{width:100%;height:100%;object-fit:cover}
.em-event-flyer.no-flyer{font-size:11px;font-weight:600;color:#94a3b8}
.em-event-main{flex:1;min-width:300px}
.em-event-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.em-event-title{font-family:'Bronco',system-ui,Arial,sans-serif;font-size:20px;font-weight:600;letter-spacing:0.5px;color:#111827;margin:0}
.em-event-title a{color:#111827;text-decoration:none}
.em-event-title a:hover{text-decoration:underline}
.em-event-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:14px;color:#6b7280}
.em-event-date{color:#374151;font-weight:500}
.em-event-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex-shrink:0}

/* Legacy flyer thumb for compatibility */
.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}

/* Responsive event cards */
@media (max-width:900px){
  .em-event-layout{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .em-event-header{grid-column:1;grid-row:1;flex-direction:column}
  .em-event-footer{grid-column:1;grid-row:3}
  .em-event-flyer{grid-column:1;grid-row:2;width:100%;max-width:200px;height:260px;justify-self:center}
  .em-event-main{min-width:100%}
}
.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}
}

/* Event Manager outline shells (scroll functionality removed) */
.em-outline{border:2px solid #ff6a1c;border-radius:8px;padding:0;background:#fff;position:relative;margin-bottom:26px;overflow:hidden}
.shows-list{position:relative}
body:not(.program-page):not(.no-parchment) .em-outline{background:#fff;border:2px solid #ff6a1c;background-image:none}
.em-outline h2{margin:0}
.em-outline-inner{margin-top:10px}
/* Orange gradient header for .em-outline cards */
.em-outline > .flex:first-child {
  background: linear-gradient(135deg, #ff6a1c 0%, #ff8c3c 100%);
  color: #fff;
  padding: 20px;
  margin: 0;
}
.em-outline > .flex:first-child h2 {
  color: #fff !important;
  margin: 0;
}
.em-outline > .flex:first-child .small {
  color: rgba(255, 255, 255, 0.9);
}
.em-outline > .flex:first-child .btn {
  background: #fff;
  color: #ff6a1c;
  border: 1px solid #fff;
  font-weight: 600;
}
.em-outline > .flex:first-child .btn:hover {
  background: #fff7ed;
  color: #e55a0c;
  border-color: #fff7ed;
}
/* Content area padding for .em-outline */
.em-outline > .em-tabs {
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 16px;
}
.em-outline > .small {
  padding-left: 20px;
  padding-right: 20px;
  display: block;
}
/* Lists - edge-to-edge */
.em-outline > .shows-list,
.em-outline > .events-list {
  padding-left: 0;
  padding-right: 0;
}
/* Show cards (individual show items) */
.em-show-item{border:1px solid var(--border-color);border-radius:12px;background:#fff;padding:12px 14px;margin-top:12px}
body:not(.program-page):not(.no-parchment) .em-show-item{background:rgba(255,255,255,0.75)}
.em-show-item:first-child{margin-top:0}
.em-show-item .flex{flex-wrap:wrap}
.em-show-item .table-wrap{margin-top:8px}
.em-show-actions a.btn-soft,.em-show-actions button.btn-soft{margin-left:6px}
/* Events tables header (no sticky positioning now to avoid scroll artifacts) */
.em-events-table thead th{background:#fff}
/* Reintroduced unified scroll area (opt-in) */
.em-scroll-area{overflow:visible;position:relative;padding-right:4px;--em-scroll-max:620px}
@media (min-height:900px){ .em-scroll-area{--em-scroll-max:760px} }
@media (max-width:780px){ .em-scroll-area{--em-scroll-max:500px} }
/* When activated via JS by adding .is-scroll */
.em-scroll-area.is-scroll{overflow:auto;max-height:var(--em-scroll-max);scrollbar-width:thin}
.em-scroll-area.is-scroll::-webkit-scrollbar{width:10px}
.em-scroll-area.is-scroll::-webkit-scrollbar-track{background:rgba(0,0,0,0.05);border-radius:8px}
.em-scroll-area.is-scroll::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.25);border-radius:8px}
.em-scroll-area.scrolled{box-shadow:inset 0 6px 6px -6px rgba(0,0,0,0.3)}
/* Table headers remain visible at top within scroll */
.em-scroll-area.is-scroll .em-events-table thead th{position:sticky;top:0;z-index:5}

