@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* Slider spec overrides and cleanups */
.slider-row::before { display: none !important; } /* disable old overlay tint */

/* Subtle themed tracks to match each row color */
.slider-row[data-field="distance"] .field-slider { background: rgba(59,130,246,0.25) !important; }  /* blue */
.slider-row[data-field="time"] .field-slider     { background: rgba(245,158,11,0.25) !important; }   /* orange */
.slider-row[data-field="height"] .field-slider   { background: rgba(139,92,246,0.25) !important; }   /* purple */
/* This was a duplicate import statement, now removed. */

:root {
    --primary-blue: #0A84FF;
    --primary-blue-dark: #0066CC;
    --success-green: #22C55E;
    --error-red: #EF4444;
    --white: #FFFFFF;
    --gray-50: #F9FAFB;
    --gray-100: #F3F4F6;
    --gray-200: #E5E7EB;
    --gray-300: #D1D5DB;
    --gray-400: #9CA3AF;
    --gray-500: #6B7280;
    --gray-600: #4B5563;
    --gray-700: #374151;
    --gray-800: #1F2937;
    --gray-900: #111827;
    --space-xs: 0.125rem;
    --space-sm: 0.25rem;
    --space-md: 0.5rem;
    --space-lg: 0.75rem;
    --space-xl: 1rem;
    --space-2xl: 1.5rem;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-md: 0 2px 6px rgba(0,0,0,0.08);
    --shadow-lg: 0 8px 16px rgba(0,0,0,0.08);
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-size-xs: 0.6875rem;
    --font-size-sm: 0.75rem;
    --font-size-base: 0.875rem;
    --font-size-lg: 1rem;
    --font-size-xl: 1.125rem;
    --transition-fast: 0.15s ease-out;
    --transition-base: 0.2s ease-out;
    --transition-slow: 0.3s ease-out;
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: 1.4;
    color: var(--gray-800);
    background: var(--gray-50);
}

#map {
    height: 100vh;
    width: 100%;
    position: relative;
    z-index: 1;
}

#loading-spinner {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 40px;
    border: 3px solid var(--gray-200);
    border-top: 3px solid var(--primary-blue);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    z-index: 9999;
    background: var(--white);
    box-shadow: var(--shadow-lg);
}

@keyframes spin {
  to { transform: translate(-50%, -50%) rotate(360deg); }
}

.controls-toggle {
    position: fixed;
    bottom: var(--space-xl);
    right: var(--space-xl);
    width: 48px;
    height: 48px;
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: 50%;
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    cursor: pointer;
    z-index: 1001;
    transition: all var(--transition-base);
    backdrop-filter: blur(8px);
    /* Ensure it's always visible and accessible */
    min-width: 48px;
    min-height: 48px;
}
.controls-toggle:hover { transform: scale(1.05); }
.controls-toggle:active { transform: scale(0.97); }

.controls-panel {
    position: fixed;
    background: var(--white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    z-index: 1000;
    overflow: hidden;
    transition: all var(--transition-slow);
    display: flex; /* Use flexbox for layout */
    flex-direction: column; /* Stack children vertically */
    /* Removed touch-action: pan-y; to let the browser handle scrolling. */
}

.controls-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-lg) var(--space-xl);
    border-bottom: 1px solid var(--gray-200);
    background: var(--white);
}
.controls-title {
    margin: 0;
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--gray-800);
    flex-grow: 1;
}
.language-switcher {
    display: flex;
    gap: var(--space-md);
    margin-right: var(--space-lg);
}
.lang-flag {
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all var(--transition-base);
    opacity: 0.6;
    border: 2px solid transparent;
}
.lang-flag.active {
    opacity: 1;
    transform: scale(1.1);
    box-shadow: var(--shadow-md);
    border-color: var(--primary-blue);
}
.lang-flag:hover {
    opacity: 1;
}
.controls-close {
    display: none;
    width: 32px; /* Slightly larger for better touch access */
    height: 32px;
    border: none;
    background: var(--gray-100);
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition-fast);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234B5563' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
    background-size: 16px 16px;
    background-position: center;
    background-repeat: no-repeat;
}
.controls-close:hover { background: var(--gray-100); color: var(--gray-800); }

.controls-content {
    flex: 1; /* Allow this element to grow and fill available space */
    overflow-y: auto; /* Enable scrolling only when content overflows */
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    padding-bottom: calc(var(--space-2xl) + 20px); /* Add extra padding for better scroll */
    flex-grow: 1; /* Ensure it takes up available space */
}

.control-card {
    padding: var(--space-lg) var(--space-xl);
    border-bottom: 1px solid var(--gray-100);
}
.control-card:last-child { border-bottom: 0; }
.control-card h3 {
    margin: 0 0 var(--space-lg) 0;
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.mode-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}
.mode-btn {
    padding: var(--space-lg);
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-base);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
    color: var(--gray-700);
}
.mode-btn input { display: none; }
.mode-btn.active {
    background: var(--primary-blue);
    color: var(--white);
    border-color: var(--primary-blue);
    box-shadow: var(--shadow-md);
}
.mode-icon { font-size: 1.1rem; }
.mode-label { font-weight: 600; font-size: var(--font-size-sm); }
.mode-btn small { font-size: var(--font-size-xs); opacity: 0.85; }

.input-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}
#address-input {
    width: 100%;
    padding: var(--space-lg);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    font-size: 16px; /* Prevent zoom on iOS by using 16px or larger */
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    background: var(--white);
}
#address-input:focus {
    outline: none;
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(10,132,255,0.12);
}

.locate-btn {
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-lg);
    font-weight: 600;
    font-size: var(--font-size-xs);
    cursor: pointer;
    transition: all var(--transition-base);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    border: 1px solid var(--primary-blue);
    background: var(--primary-blue);
    color: var(--white);
}
.locate-btn.secondary {
    background: var(--white);
    color: var(--primary-blue);
}
.locate-btn.tertiary {
    background: var(--white);
    color: var(--gray-700);
    border-color: var(--gray-300);
}
.locate-btn:hover { box-shadow: var(--shadow-md); }
.locate-btn:active { transform: translateY(0); }

.toggle-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--gray-50);
    border-radius: var(--radius-lg);
    transition: background-color var(--transition-fast);
    min-height: 44px;
    margin-bottom: var(--space-md);
}
.toggle-item:hover { background: var(--gray-100); }
.toggle-icon { font-size: 1rem; min-width: 20px; text-align: center; flex-shrink: 0; }
.toggle-label { font-weight: 600; color: var(--gray-800); font-size: var(--font-size-sm); }
.toggle-sublabel { flex: 1; font-weight: 400; color: var(--gray-600); font-size: var(--font-size-xs); margin-left: var(--space-sm); }
.ios-toggle { position: relative; display: inline-block; width: 44px; height: 26px; flex-shrink: 0; }
.ios-toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute; cursor: pointer; inset: 0;
    background-color: var(--gray-300);
    transition: var(--transition-base);
    border-radius: 26px;
}
.toggle-slider:before {
    content: ""; position: absolute; height: 20px; width: 20px; left: 3px; bottom: 3px;
    background-color: var(--white); transition: var(--transition-base);
    border-radius: 50%; box-shadow: var(--shadow-sm);
}
.ios-toggle input:checked + .toggle-slider { background-color: var(--primary-blue); }
.ios-toggle input:checked + .toggle-slider:before { transform: translateX(18px); }

.slider-row {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    padding: var(--space-lg);
    background: var(--white);
    border-radius: var(--radius-xl);
    border: 1px solid var(--gray-200);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    min-height: 56px;
}
.slider-row:hover { box-shadow: var(--shadow-md); }
.field-icon { font-size: 1rem; min-width: 20px; text-align: center; flex-shrink: 0; }
.field-label { font-weight: 600; color: var(--gray-800); font-size: var(--font-size-sm); flex: 1; min-width: 0; }
.field-slider {
    flex: 2;
    height: 6px;
    border-radius: 3px;
    background: var(--gray-200);
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}
.field-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--primary-blue);
    cursor: pointer; box-shadow: var(--shadow-md); transition: transform var(--transition-fast);
}
.field-slider::-moz-range-thumb {
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--primary-blue);
    cursor: pointer; border: none; box-shadow: var(--shadow-md); transition: transform var(--transition-fast);
}
.field-slider:hover::-webkit-slider-thumb { transform: scale(1.08); }
.field-slider:hover::-moz-range-thumb { transform: scale(1.08); }
.field-output { font-weight: 700; font-size: var(--font-size-sm); min-width: 54px; text-align: right; margin: 0; color: var(--gray-700); }

.lock-btn {
    background: var(--gray-100);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-md);
    width: 32px; height: 32px;
    cursor: pointer; font-size: var(--font-size-sm); color: var(--gray-600);
    display: inline-flex; align-items: center; justify-content: center;
    transition: all var(--transition-fast);
    flex-shrink: 0;
}
.lock-btn.locked { background: var(--primary-blue); color: var(--white); border-color: var(--primary-blue); }
.lock-btn:hover { transform: scale(1.05); }

.preference-buttons { margin-top: var(--space-md); }
.button-row { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-bottom: var(--space-md); }
.button-row:last-child { margin-bottom: 0; }
.pref-btn {
    display: inline-flex; align-items: center; gap: var(--space-sm);
    padding: 8px 12px;
    border: 1px solid var(--gray-300);
    border-radius: 999px;
    background: var(--white);
    color: var(--gray-700);
    cursor: pointer;
    transition: all var(--transition-base);
    user-select: none;
}
.pref-btn input { display: none; }
.pref-btn.active {
    background: var(--primary-blue);
    border-color: var(--primary-blue);
    color: var(--white);
    box-shadow: var(--shadow-md);
}
.btn-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}
.btn-label { font-size: var(--font-size-sm); line-height: 1.2; }

.action-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    gap: var(--space-md);
}
.action-btn {
    padding: var(--space-xl);
    border-radius: var(--radius-xl);
    cursor: pointer;
    font-weight: 700;
    font-size: var(--font-size-sm);
    transition: all var(--transition-base);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    text-align: center;
    position: relative;
    overflow: hidden;
    min-height: 80px;
    border: 1px solid transparent;
}

.action-btn .btn-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 20px;
    height: 20px;
}

.action-btn .btn-label {
    line-height: 1.2;
    text-align: center;
    word-wrap: break-word;
    hyphens: auto;
    max-width: 100%;
}
.action-btn.random {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: var(--white);
    border: none;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(102, 126, 234, 0.4);
}

.action-btn.random::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #764ba2 0%, #667eea 100%);
    transition: left 0.5s ease;
    z-index: -1;
}

.action-btn.random:hover::before {
    left: 0;
}

.action-btn.random:hover {
    box-shadow: 0 6px 20px rgba(102, 126, 234, 0.6);
    transform: none; /* Prevent button movement */
}

.action-btn.refine { background: var(--white); color: var(--primary-blue); border-color: var(--primary-blue); }
.action-btn.save { background: var(--white); color: var(--gray-800); border-color: var(--gray-300); }
.action-btn.share { background: #4285F4; color: var(--white); border-color: #4285F4; }
.action-btn:hover { box-shadow: var(--shadow-md); }
.action-btn:active { transform: translateY(0); }

/* Ensure other buttons don't have the transform: none override */
.action-btn.refine:hover,
.action-btn.save:hover,
.action-btn.share:hover {
    transform: none;
}

.saved-list {
    max-height: 150px;
    overflow-y: auto;
    padding: var(--space-sm) 0;
}
.saved-route, .location-item {
    background: var(--white);
    padding: var(--space-md);
    margin-bottom: var(--space-sm);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-base);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--gray-800);
    border: 1px solid var(--gray-200);
    min-height: 36px;
}
.saved-route:hover, .location-item:hover { box-shadow: var(--shadow-md); border-color: var(--primary-blue); }
.saved-route:last-child, .location-item:last-child { margin-bottom: 0; }

.delete-btn, .delete-location-btn {
    background: var(--gray-100);
    border: none;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    cursor: pointer;
    transition: all var(--transition-fast);
    flex-shrink: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234B5563' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
    background-size: 12px 12px;
    background-position: center;
    background-repeat: no-repeat;
}
.delete-btn:hover, .delete-location-btn:hover {
    background-color: var(--error-red);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
}

.load-location-btn {
    background: var(--white);
    border: 1px solid var(--primary-blue);
    border-radius: var(--radius-sm);
    padding: var(--space-xs) var(--space-sm);
    color: var(--primary-blue);
    font-size: var(--font-size-xs);
    cursor: pointer;
    transition: all var(--transition-fast);
    margin-right: var(--space-sm);
}
.load-location-btn:hover { background: var(--primary-blue); color: var(--white); }

@media (max-width: 768px) {
  .controls-panel {
    bottom: 0; left: 0; right: 0;
    max-height: 65dvh; /* Use dynamic viewport height for better mobile compatibility */
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    transform: translateY(100%);
    transition: transform var(--transition-slow);
  }
  .controls-panel.active { transform: translateY(0); }
  .controls-close { display: flex; }
  .controls-toggle { display: flex; }
  .input-group { display: grid; grid-template-columns: 1fr; gap: var(--space-sm); }
  .action-buttons {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .controls-panel {
    top: var(--space-xl); right: var(--space-xl);
    width: 320px;
    max-height: calc(100vh - 2 * var(--space-xl));
    border-radius: var(--radius-xl);
  }
  .controls-toggle { display: none; }
  .input-group { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm); }
  .input-group #address-input { grid-column: 1 / -1; }
  .action-buttons {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
  }
}

@media (min-width: 1025px) {
  .controls-panel {
    top: var(--space-xl); right: var(--space-xl);
    width: 340px;
    max-height: calc(100vh - 2 * var(--space-xl));
    border-radius: var(--radius-xl);
  }
  .controls-toggle { display: none; }
  .control-card { padding: var(--space-md) var(--space-xl); }
  .input-group {
    display: grid; grid-template-columns: 1fr auto auto;
    gap: var(--space-sm); align-items: end;
  }
  .input-group #address-input { grid-column: 1 / -1; margin-bottom: var(--space-sm); }
  .action-buttons {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
  }
  .slider-row { margin-bottom: var(--space-md); padding: var(--space-md) var(--space-lg); min-height: 50px; }
  .saved-list { max-height: 120px; }
}

.controls-content::-webkit-scrollbar { width: 4px; }
.controls-content::-webkit-scrollbar-track { background: var(--gray-100); border-radius: 2px; }
.controls-content::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 2px; }
.controls-content::-webkit-scrollbar-thumb:hover { background: var(--gray-400); }

.controls-toggle:focus,
.controls-close:focus,
.locate-btn:focus,
.action-btn:focus,
.ios-toggle:focus-within {
    outline: 2px solid var(--primary-blue);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}
/* === Spec sliders (Distance, Estimated Time, Height) — pastel gradient rows with inline number and lock === */
:root {
  --distance-grad: linear-gradient(135deg, #BFD9FF 0%, #9EC5FF 100%);
  --time-grad: linear-gradient(135deg, #FFE0B2 0%, #FFCC80 100%);
  --height-grad: linear-gradient(135deg, #E3D5FF 0%, #C8B5FF 100%);
  --distance-color: #3B82F6; /* blue */
  --time-color: #F59E0B;     /* orange */
  --height-color: #8B5CF6;   /* purple */
}

/* Turn slider-row into a compact 5-column grid matching the reference */
.slider-row {
  display: grid !important;
  grid-template-columns: 24px max-content minmax(0,1fr) max-content 32px; /* icon | label | slider | value | lock */
  column-gap: var(--space-md);
  align-items: center;
  padding: var(--space-lg);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: var(--shadow-md);
  min-height: 56px; /* stays compact; does not increase overall height */
}

/* Pastel gradients per field */
.slider-row[data-field="distance"] { background: var(--distance-grad) !important; }
.slider-row[data-field="time"]     { background: var(--time-grad) !important; }
.slider-row[data-field="height"]   { background: var(--height-grad) !important; }

/* Tidy content inside the row */
.slider-row .field-icon { font-size: 1rem; min-width: 20px; text-align: center; }
.slider-row .field-label { font-weight: 700; color: #1F2937; opacity: 0.95; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Thin neutral track line like the mock */
.slider-row .field-slider {
  align-self: center;
  height: 6px !important;
  border-radius: 999px !important;
  background: rgba(0,0,0,0.14) !important;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}

/* Color the thumb to match each row’s theme */
.slider-row[data-field="distance"] .field-slider::-webkit-slider-thumb { background: var(--distance-color) !important; }
.slider-row[data-field="distance"] .field-slider::-moz-range-thumb    { background: var(--distance-color) !important; }

.slider-row[data-field="time"] .field-slider::-webkit-slider-thumb { background: var(--time-color) !important; }
.slider-row[data-field="time"] .field-slider::-moz-range-thumb    { background: var(--time-color) !important; }

.slider-row[data-field="height"] .field-slider::-webkit-slider-thumb { background: var(--height-color) !important; }
.slider-row[data-field="height"] .field-slider::-moz-range-thumb    { background: var(--height-color) !important; }

/* Value text inline, right-aligned; units added via CSS so JS can keep setting numbers only */
.slider-row .field-output {
  font-weight: 700;
  font-size: var(--font-size-sm);
  min-width: 64px;
  text-align: right;
  margin: 0;
  color: #1F2937;
}

/* Append units to match the requested display */
.slider-row[data-field="distance"] .field-output::after { content: " km"; }
.slider-row[data-field="height"] .field-output::after   { content: " m"; }

/* Lock button styled like the mock: soft pill with icon centered */
.lock-btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,0.78) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  color: var(--gray-700) !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.lock-btn.locked {
  background: rgba(55,65,81,0.92) !important; /* gray-700 */
  color: #fff !important;
  border-color: rgba(0,0,0,0.12) !important;
}
.lock-btn:hover { transform: scale(1.05); box-shadow: var(--shadow-md); }

/* Slightly reduce desktop min-height to ensure we don’t grow overall height */
@media (min-width: 1025px) {
  .slider-row { min-height: 50px; }
}