/* ====== RepairNStore – Website Theme (clean) + Stepper/Search (merged) ====== */
:root{
  --bg:#f6fbf8;
  --bg2:#eef7f1;
  --panel:#ffffff;
  --muted:#5b6b66;
  --text:#0f1b17;

  --brand:#10b981;
  --ring:rgba(2,44,34,.08);
  --bd:1px solid var(--ring);

  --radius:18px;
  --shadow:0 10px 30px rgba(4,60,40,.06);
  --shadow-strong:0 30px 60px rgba(4,60,40,.10);

  --primary:#0b62ff;

  /* Added / merged */
  --card:#ffffff;
  --border:#e6edf6;
  --primary-weak:#e9f2ff;

  /* keep separate so it won't change your header shadow */
  --shadow-soft: 0 10px 30px rgba(16,42,67,.08);
}

/* Base */
*{ box-sizing:border-box; }

html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  /* background: linear-gradient(180deg, var(--bg), var(--bg2)); */
  background: #fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;

  /* font merged from first css */
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

/* =========================================
   MEGA DROPDOWN FIX (nur Header)
   ========================================= */

/* wichtig: Dropdown darf nicht abgeschnitten werden */
.topbar,
.topbar-row--nav,
.topnav {
  overflow: visible !important;
}

/* Referenz für absolute Positionierung */
.topbar-row--nav { 
  position: relative; 
  z-index: 2000;
}
.topnav { 
  position: relative; 
}

/* .topnav-dd nicht mehr "relative" */
.topnav-dd { 
  position: static !important; 
}

/* Mega Menü: volle Breite unter der Nav-Zeile */
.topnav-dd .mega{
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 10px) !important;

  width: auto !important;
  max-width: none !important;

  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(0,0,0,.12);
  padding: 18px;

  z-index: 9999;

  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
  transition: all .16s ease;
}

/* Standort-Dropdown ist kompakter */
.topnav-dd--standorte .mega {
  left: auto !important;
  right: auto !important;
  width: 240px !important;
  min-width: 220px !important;
  max-width: 280px !important;
  padding: 12px !important;
}

.topnav-dd.is-open > .mega{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Grid */
.topnav-dd .mega-grid{
  display: grid;
  grid-template-columns: repeat(5, minmax(160px, 1fr));
  gap: 22px;
}

.topnav-dd .mega-title{
  display:block;
  font-weight: 800;
  margin: 4px 0 10px;
  text-decoration: none;
  font-size: 14px;
  color: #0b62ff;
}

.topnav-dd .mega-link{
  display:block;
  padding: 7px 8px;
  border-radius: 10px;
  text-decoration: none;
  color: #111;
  font-size: 14px;
}

.topnav-dd .mega-link:hover{
  background: rgba(0,0,0,.04);
}

.topnav-dd .mega-all{
  display:block;
  margin-top: 10px;
  padding: 7px 8px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 700;
  font-size: 13px;
  color: #0b62ff;
}

.topnav-dd .mega-all:hover{
  background: rgba(11,98,255,.08);
}

/* Responsive */
@media (max-width:1100px){
  .topnav-dd .mega-grid{ grid-template-columns: repeat(2, minmax(160px, 1fr)); }
}
@media (max-width:760px){
  .topnav-dd .mega-grid{ grid-template-columns: 1fr; }
}

/* ===== Hover Dropdown ===== */
.topnav-dd:hover > .mega {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.topnav-dd:hover > .topnav-item {
  background: rgba(2,44,34,.04);
}

/* Container (dein bestehender wrap bleibt!) */
.wrap{
  width:100%;
  margin:0;
  padding:0;
}
.fullwidth{
  width:100%;
  margin:0;
}

/* ===== Topbar (2 rows) ===== */
.topbar{
  padding:14px 16px;
  background:#fff;
  border-bottom: var(--bd);
  box-shadow: var(--shadow);
  position: relative;
  z-index: 50;
}

.topbar-row{display:flex; align-items:center;}
.topbar-row--top{justify-content:space-between; gap:16px;}
.topbar-row--nav{
  margin-top:12px;
  padding-top:10px;
  border-top:1px solid rgba(2,44,34,.08);
}

/* Brand */
.brand{display:inline-flex; align-items:center; gap:12px; text-decoration:none}
.brand img{height:34px}
.brand .appname{font-weight:700; letter-spacing:.2px; color:var(--text)}

/* Actions right */
.topbar-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

.menu-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  width:46px;
  height:46px;
  padding:0;
  border:0;
  border-radius:14px;
  background:transparent;
  color:var(--primary);
  cursor:pointer;
}

.menu-toggle span{
  display:block;
  width:24px;
  height:3px;
  border-radius:999px;
  background:currentColor;
  transition:transform .18s ease, opacity .18s ease;
}

.menu-toggle.is-active span:nth-child(1){
  transform:translateY(8px) rotate(45deg);
}

.menu-toggle.is-active span:nth-child(2){
  opacity:0;
}

.menu-toggle.is-active span:nth-child(3){
  transform:translateY(-8px) rotate(-45deg);
}

/* Standorte Button */
.btn-location{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 14px;
  border-radius:12px;
  background:var(--primary);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  box-shadow:0 8px 18px rgba(11,98,255,.18);
  white-space:nowrap;
}
.btn-location:hover{
  background:#094fd1;
  box-shadow:0 10px 22px rgba(11,98,255,.25);
}

/* Language (dein header-style bleibt; nur ergänzende Teile) */
.lang{display:flex; align-items:center;}
.lang label{position:absolute; left:-9999px}
.lang select{
  appearance:none;
  background:#fff;
  border:var(--bd);
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
  min-width:170px;
  font-weight:700;
  cursor:pointer;
}
/* optional from first css */
.flag{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid #dde6f4;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:#fff;
}

.lang--mobile{
  display:none;
}

/* ===== Main card ===== */
.card{
  background:#fff;
  border:var(--bd);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
}

/* ===== Location Public Page Overrides ===== */
.location-page,
.location-page .container {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
  margin: 0 auto !important;
}

.location-page .section-card,
.location-page .hero-card,
.location-page .split-panel,
.location-page .review-strip,
.location-page .repair-grid,
.location-page .faq-box,
.location-page .section-card.p-4.mt-4 {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.location-page .hero-card,
.location-page .split-panel,
.location-page .review-strip,
.location-page .repair-grid,
.location-page .faq-box {
  margin-bottom: 1.25rem !important;
}

.location-page .panel-head,
.location-page .section-title,
.location-page .hero-title {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  text-align: left;
}

.location-page .section-card.p-4.mt-4{
  padding: 0 !important;
  margin-top: 1.25rem !important;
}
{
  background:#fff;
  border:var(--bd);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
}

/* ===== Nav ===== */
.topnav{
  display:flex;
  align-items:center;
  gap:18px;
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.topnav::-webkit-scrollbar{ height: 6px; }

.topnav-item{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:14px;
  text-decoration:none;
  color:var(--text);
  font-weight:600;
  white-space:nowrap;
}
.topnav-item:hover{ background: rgba(2,44,34,.04); }

/* ===== Reparatur per Post Page Styles ===== */
.mailin-page {
  --rns-primary: #1e66ff;
  --rns-dark: #0f172a;
  --rns-text: #0b1220;
  --rns-muted: #5b6b85;
  --rns-border: #e6ecf7;
  --rns-bg: #f8fbff;
  --rns-card: #ffffff;
  width: 100%;
  max-width: 1188px;
  margin: 0 auto;
  padding: 32px 16px 44px;
}

.mailin-page.container-fluid,
.mailin-page.container {
  max-width: 1188px;
  width: 100%;
  padding-left: 16px;
  padding-right: 16px;
}

.mailin-wide {
  width: 100%;
  max-width: 1110px;
  margin: 0 auto;
}

.mailin-form-shell {
  width: 100%;
  max-width: 100%;
  background: #fff;
  border: 1px solid var(--rns-border);
  border-radius: 24px;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .12);
  padding: 2rem;
  font-size: 1.14rem;
  line-height: 1.62;
}

.mailin-form-shell input,
.mailin-form-shell select,
.mailin-form-shell textarea,
.mailin-form-shell label,
.mailin-label {
  font-size: 1.25rem;
}

.mailin-label {
  display: inline-block;
  margin-bottom: 0.35rem;
  font-weight: 700;
  color: var(--rns-text);
}

.mailin-form-shell .form-control {
  min-height: 52px;
  font-size: 1.06rem;
  padding: 0.75rem 0.85rem;
}

.mailin-step-panel {
  display: none;
}

.mailin-step-panel.active {
  display: block;
}

.mailin-progress {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 1.5rem;
  padding: 0.75rem 0;
}

.mailin-step-indicator,
.mailin-progress .mailin-step-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.6rem 0.9rem;
  border-radius: 999px;
  cursor: pointer;
  color: #334155;
  font-weight: 700;
  font-size: 1.4rem;
  background: #f3f7ff;
  border: 1px solid #e2eaf9;
}

.mailin-step-indicator.active,
.mailin-progress .mailin-step-indicator.active {
  background: #fff;
  border-color: #1e66ff;
  color: #0f172a;
  box-shadow: 0 6px 20px rgba(30, 102, 255, 0.15);
}

.mailin-step-indicator .step-badge,
.step-badge {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #dde9ff;
  color: #1e66ff;
  font-size: 1rem;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mailin-step-indicator.active .step-badge,
.step-badge.active {
  background: #1e66ff;
  color: #fff;
  box-shadow: 0 6px 14px rgba(30, 102, 255, 0.38);
}

.mailin-step-indicator.active .step-badge,
.step-badge.active {
  background: #1e66ff;
  color: #fff;
}

.mailin-actions,
.mailin-actions-between {
  margin-top: 1.25rem;
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
}

.mailin-actions-between {
  justify-content: space-between;
}

.mailin-inline-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 42px;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  border: 1.5px solid var(--rns-border);
  background: #fff;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
  text-decoration: none;
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.mailin-inline-btn:hover {
  transform: translateY(-1px);
}

.mailin-inline-btn-add {
  color: #45658f;
  border-color: #9fb6d8;
  box-shadow: 0 2px 8px rgba(69, 101, 143, 0.08);
}

.mailin-inline-btn-add::before {
  content: "+";
  font-size: 1rem;
  font-weight: 500;
}

.mailin-inline-btn-add:hover {
  background: #f7fbff;
  border-color: #6f93c3;
  color: #2f4f78;
}

.mailin-inline-btn-remove {
  color: #ef4444;
  border-color: #fca5a5;
}

.mailin-inline-btn-remove:hover {
  background: #fff5f5;
  border-color: #f87171;
  color: #dc2626;
}

.mailin-additional-repairs-wrap {
  margin-top: 0.25rem;
}

.mailin-additional-repair-row {
  margin-left: 0;
  margin-right: 0;
}

.mailin-additional-repair-actions {
  display: flex;
  align-items: flex-end;
}

.mailin-additional-repair-actions .mailin-inline-btn-remove {
  margin-top: 1.9rem;
}

.mailin-progress {
  margin-bottom: 1.5rem;
}

.mailin-progress .step-indicator,
.mailin-step-indicator {
  cursor: pointer;
}

@media (max-width: 767.98px) {
  .mailin-form-shell {
    padding: 1rem;
  }

  .mailin-actions-between {
    flex-direction: column;
    align-items: stretch;
  }
}

.mailin-section {
  background: var(--rns-bg);
  border: 1px solid var(--rns-border);
  border-radius: 20px;
  padding: 2rem;
}

.mailin-hero {
  background:
    radial-gradient(1000px 500px at 0% 0%, #eef4ff 0, transparent 60%),
    radial-gradient(800px 400px at 100% 100%, #e8fbff 0, transparent 60%),
    var(--rns-bg);
}

.mailin-eyebrow {
  color: var(--rns-primary);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  font-size: .85rem;
  margin-bottom: .5rem;
}

.mailin-title {
  color: var(--rns-dark);
  font-weight: 800;
  line-height: 1.15;
}

.mailin-lead {
  color: var(--rns-muted);
  font-size: 1.05rem;
}

.mailin-pill {
  display: inline-flex;
  align-items: center;
  padding: .45rem .8rem;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--rns-border);
  font-size: .92rem;
  font-weight: 600;
  color: #334155;
}

.mailin-card,
.mailin-info-card,
.mailin-form-card,
.mailin-device-card {
  background: #fff;
  border: 1px solid var(--rns-border);
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .05);
}

.mailin-card {
  padding: 1.4rem;
  height: 100%;
  transition: .25s ease;
}

.mailin-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 36px rgba(15, 23, 42, .08);
}

.mailin-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin-bottom: 1rem;
  font-size: 1.4rem;
  font-weight: 700;
}

.mailin-icon.primary { background: linear-gradient(135deg, #1e66ff, #5aa0ff); }
.mailin-icon.blue { background: linear-gradient(135deg, #2563eb, #60a5fa); }
.mailin-icon.cyan { background: linear-gradient(135deg, #0ea5e9, #22d3ee); }
.mailin-icon.green { background: linear-gradient(135deg, #10b981, #34d399); }

.mailin-card h3,
.mailin-info-card h3,
.mailin-device-card h3 {
  color: var(--rns-dark);
  font-weight: 700;
}

.mailin-card p,
.mailin-info-card p,
.mailin-device-card p,
.mailin-note,
.mailin-muted {
  color: #475569;
}

.mailin-form-card {
  padding: 1.75rem;
}

.mailin-progress .step {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  margin-bottom: 28px;
}

.mailin-step-indicator {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #64748b;
  font-size: 17px;
  font-weight: 500;
}

.mailin-progress .step-number {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e9eefb;
  color: #64748b;
  font-weight: 700;
  margin-bottom: .5rem;
}

.mailin-progress .step.active .step-number {
  background: #232f3e;
  color: #fff;
}

.mailin-progress .step-title {
  font-size: .9rem;
  font-weight: 600;
  color: #475569;
}

.mailin-progress .step.active .step-title {
  color: #0f172a;
}

.mailin-note-box {
  background: #f3fcf8;
  border: 1px solid #c6f0dc;
  color: #0b7a4b;
  border-radius: 14px;
  padding: .9rem 1rem;
  font-weight: 600;
}

.mailin-info-card {
  padding: 1.5rem;
  height: 100%;
}

.mailin-list {
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
}

.mailin-list li {
  position: relative;
  padding-left: 1.6rem;
  margin-bottom: .7rem;
  color: #334155;
}

.mailin-list li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--rns-primary);
  font-weight: 700;
}

.mailin-badge {
  display: inline-block;
  background: #f1f5ff;
  border: 1px solid #d9e5ff;
  color: #1e3a8a;
  border-radius: 999px;
  padding: .35rem .75rem;
  font-size: .88rem;
  font-weight: 600;
  margin: 0 .35rem .35rem 0;
}

.mailin-payment {
  border: 1px solid var(--rns-border);
  border-radius: 12px;
  padding: .75rem 1rem;
  text-align: center;
  font-weight: 600;
  background: #fff;
  color: #0f172a;
  height: 100%;
}

.mailin-device-card {
  padding: 1.4rem;
  height: 100%;
}

.mailin-chip {
  display: inline-block;
  padding: .42rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--rns-border);
  background: #fff;
  color: #334155;
  margin: 0 .4rem .4rem 0;
  font-size: .9rem;
}

.mailin-hero-image {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--rns-border);
  box-shadow: 0 14px 40px rgba(15, 23, 42, .08);
  background: #fff;
}

.mailin-hero-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

@media (max-width: 767.98px) {
  .mailin-section {
    padding: 1.25rem;
  }

  .mailin-form-card {
    padding: 1.25rem;
  }

  .mailin-progress {
    gap: 1rem !important;
  }

  .mailin-progress .step-title {
    font-size: .8rem;
  }
}


.topnav-ico{
  width:18px; height:18px; display:inline-flex;
  color: var(--primary);
}
.topnav-ico svg{ width:18px; height:18px; }
.topnav-caret{ font-size:.85rem; opacity:.6; margin-left:2px; }

.topnav-item.is-active{
  background: rgba(2,44,34,.04);
  box-shadow: inset 0 0 0 1px rgba(2,44,34,.06);
}

.topnav-dd{ position:relative; }
.topnav-trigger{
  appearance:none;
  background:transparent;
  border:0;
  margin:0;
  font:inherit;
  color:inherit;
  line-height:inherit;
  cursor:pointer;
  padding:0;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:14px;
  text-decoration:none;
  color:var(--text);
  font-weight:600;
  white-space:nowrap;
}

/* ===== Mega Dropdown ===== */
/* .mega{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);

  background:#fff;
  border:1px solid rgba(2,44,34,.10);
  border-radius:18px;
  box-shadow: 0 18px 45px rgba(4,60,40,.14);
  padding:18px;
  z-index: 9999;

  opacity:0;
  transform: translateY(6px);
  pointer-events:none;
  transition: all .16s ease;
} */
.mega{
  opacity:0;
  transform: translateY(6px);
  pointer-events:none;
  transition: all .16s ease;
}
/* .topnav-dd.is-open > .mega{
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
} */

.mega-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(160px, 1fr));
  gap:22px;
}

.mega-col{min-width:0;}

.mega-title{
  display:block;
  font-weight:800;
  margin: 4px 0 10px;
  color: var(--primary);
  text-decoration:none;
  font-size:14px;
}

.mega-link{
  display:block;
  padding:7px 8px;
  border-radius:10px;
  text-decoration:none;
  color: var(--text);
  font-size:14px;
}

.mega-link:hover{ background: rgba(2,44,34,.04); }

.mega-all{
  display:block;
  margin-top:10px;
  padding:7px 8px;
  border-radius:10px;
  text-decoration:none;
  color: var(--primary);
  font-weight:700;
  font-size:13px;
}
.mega-all:hover{ background: rgba(11,98,255,.08); }

/* ===== Footer ===== */
.site-footer{
  margin-top:18px;
  background:#fff;
  border:var(--bd);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:28px 28px;
}

.footer-grid{
  display:grid;
  grid-template-columns: 1.35fr 1fr 1fr 1fr 1.1fr;
  gap:28px;
  align-items:start;
}

.footer-brand{display:flex; gap:14px; align-items:flex-start;}
.footer-brand img{ height:34px; width:auto; margin-top:2px; }

.footer-brand-text p{
  margin:0;
  color:var(--muted);
  line-height:1.45;
  font-size:14px;
}

.footer-col h3{
  margin:0 0 10px 0;
  font-size:15px;
  font-weight:800;
  color:var(--text);
}

.footer-links{ list-style:none; padding:0; margin:0; }
.footer-links li{ margin: 7px 0; }
.footer-links a{
  color: var(--primary);
  text-decoration:none;
  font-size:14px;
}
.footer-links a:hover{ text-decoration:underline; }

/* ===== Responsive ===== */
@media (max-width:1100px){
  .mega-grid{ grid-template-columns: repeat(2, minmax(160px, 1fr)); }
  .footer-grid{ grid-template-columns: 1.2fr 1fr 1fr; }
}
@media (max-width:760px){
  .lang select{min-width:unset; width:100%}
  .footer-grid{ grid-template-columns:1fr; gap:18px; }
  .mega-grid{ grid-template-columns: 1fr; }

  .topbar{
    padding:12px 14px;
  }

  .topbar-row--top{
    display:grid;
    grid-template-columns:minmax(0, 1fr) auto auto;
    align-items:center;
    gap:10px;
  }

  .topbar-actions{
    display:contents;
  }

  .brand{
    min-width:0;
    gap:8px;
  }

  .brand img{
    height:30px;
    width:auto;
    max-width:160px;
    object-fit:contain;
  }

  .brand .appname{
    font-size:15px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .btn-location{
    justify-content:center;
    height:46px;
    padding:0 18px;
    border-radius:16px;
    font-size:15px;
    box-shadow:0 10px 24px rgba(11,98,255,.22);
  }

  .menu-toggle{
    display:inline-flex;
  }

  .topbar > .topbar-row--top .lang{
    display:none;
  }

  .topbar-row--nav{
    display:none;
    margin-top:14px;
    padding-top:14px;
    border-top:1px solid rgba(2,44,34,.08);
  }

  .topbar-row--nav.is-mobile-open{
    display:block;
  }

  .topnav{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    overflow:visible;
  }

  .topnav-item{
    width:100%;
    justify-content:flex-start;
    padding:14px 16px;
    border:1px solid rgba(2,44,34,.08);
    border-radius:16px;
    background:#fff;
  }

  .topnav-caret{
    margin-left:auto;
  }

  .topnav-dd{
    width:100%;
  }

  .topnav-dd.is-empty > .mega{
    display:none !important;
  }

  .topnav-dd.is-empty .topnav-caret{
    display:none;
  }

  .topnav-dd .mega,
  .topnav-dd--standorte .mega{
    display:none;
    position:static !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    width:100% !important;
    min-width:0 !important;
    max-width:none !important;
    margin-top:8px;
    padding:14px !important;
    border-radius:16px;
    box-shadow:none;
  }

  .topnav-dd:hover > .mega{
    opacity:0;
    transform:translateY(6px);
    pointer-events:none;
  }

  .topnav-dd.is-open > .mega{
    display:block;
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
  }

  .lang--mobile{
    display:block;
    width:100%;
    margin-top:6px;
  }

  .lang--mobile select{
    min-width:0;
    width:100%;
    border-radius:14px;
    min-height:48px;
  }
}

/* ==========================================================
   STEPPER / SEARCH UI (GLOBAL, no .startpage)
   (keine body/wrap overrides!)
   ========================================================== */

/* main "frame" like the first design */
.frame{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-soft);
  padding: 26px;
  position: relative;
  overflow:hidden;
}

.top-accent{
  width: 52px;
  height: 4px;
  border-radius: 999px;
  background: var(--primary);
  margin: 0 auto 18px;
  opacity:.95;
}

/* Stepper */
.stepper{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 14px;
  margin-bottom: 24px;
  user-select:none;
}
.step{
  display:flex;
  flex-direction:column;
  align-items:center;
  min-width: 120px;
  gap: 6px;
}
.bubble{
  width: 34px;
  height: 34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-weight:700;
  font-size:14px;
  background:#dfe7f3;
  color:#64748b;
  border:1px solid var(--border);
}
.step.active .bubble{
  background: var(--primary);
  border-color: var(--primary);
  color:#fff;
}
.label{
  font-size: 12px;
  color:#8aa0b8;
  font-weight:600;
  text-align:center;
  white-space:nowrap;
}
.step.active .label{ color:#0f172a; }

.line{
  flex: 1 1 140px;
  height: 4px;
  border-radius:999px;
  background:#d9e3f1;
  max-width: 180px;
  position: relative;
  top: -10px;
}
.line.active{ background: var(--primary); }

/* Header row */
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  margin-top: 8px;
  margin-bottom: 18px;
}
.h-left{
  display:flex;
  align-items:center;
  gap: 12px;
}
.badge{
  width: 36px;
  height: 28px;
  border-radius: 8px;
  background: #cfe7ff;
}
.header-row h1{
  margin:0;
  font-size: 28px;
  letter-spacing: .1px;
  font-weight: 800;
}
.header-row h1 span{ font-weight:900; }

/* Search block */
.search-card{
  background: #f8fbff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
}
.search-grid{
  display:grid;
  grid-template-columns: 1fr 170px;
  gap: 18px;
  align-items:stretch;
}
.hint{
  display:flex;
  align-items:center;
  gap: 10px;
  color:#1f3b57;
  font-weight: 650;
  margin-bottom: 10px;
  font-size: 1.38em;
}
.dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--primary);
}

.searchbox{
  display:flex;
  gap: 10px;
  align-items:center;
  background:#fff;
  border: 2px solid #b9d6ff;
  border-radius: 14px;
  padding: 10px 12px;
  max-width: 520px;
}
.searchbox input{
  border:none;
  outline:none;
  font-size: 16px;
  width: 100%;
  padding: 6px 2px;
  color:#0f172a;
}
.search-btn{
  width: 44px;
  height: 38px;
  border: none;
  border-radius: 12px;
  background: var(--primary-weak);
  cursor:pointer;
  display:grid;
  place-items:center;
}
.search-btn svg{ stroke: var(--primary); }

.find-card{
  border: 1px solid var(--border);
  border-radius: 16px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap: 10px;
  padding: 14px;
  text-align:center;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .08s ease;
}
.find-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(16,42,67,.08);
}
.find-card small{
  color: var(--muted);
  font-weight: 700;
}

/* Type section */
.types{ margin-top: 18px; }
.types .hint{ margin-bottom: 14px; font-size: 1.38em}

.cards{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.type-card{
  background:#fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 22px 14px;
  min-height: 120px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap: 14px;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .08s ease, border-color .08s ease;
  text-align:center;
}
.type-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(16,42,67,.08);
  border-color:#cfe0f7;
}
.type-card span{
  font-size: 12px;
  letter-spacing: .9px;
  color:#0f172a;
  font-weight:800;
}
.icon svg{
  width: 60px;
  height: 60px;
  stroke: #3b556f;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: .9;
}

/* Mega Grid als Spalten (Brand-Spalten) */
.mega-grid--brands{
  display: grid;
  grid-template-columns: repeat(5, minmax(180px, 1fr));
  gap: 22px;
  align-items: start;
}

.mega-col{
  min-width: 0;
}

.mega-title{
  display:block;
  font-weight: 800;
  color:#0b62ff;
  text-decoration:none;
  padding: 6px 6px;
  margin-bottom: 8px;
  border-radius: 10px;
}

.mega-title:hover{
  background: rgba(2,44,34,.04);
}

.mega-links{
  display:flex;
  flex-direction: column;
  gap: 4px;
}

.mega-link{
  display:block;
  padding: 6px 6px;
  border-radius: 10px;
  text-decoration:none;
  color: var(--text);
  font-size: 14px;
}

.mega-link:hover{
  background: rgba(2,44,34,.04);
}

.mega-all{
  display:block;
  margin-top: 10px;
  padding: 6px 6px;
  border-radius: 10px;
  text-decoration:none;
  color:#0b62ff;
  font-weight: 700;
  font-size: 13px;
}


/* Responsive */
@media (max-width:1100px){
  .mega-grid--brands{ grid-template-columns: repeat(2, minmax(180px, 1fr)); }
}

@media (max-width:760px){
  .mega-grid--brands{ grid-template-columns: 1fr; }
}

/* Responsive (Stepper/Search UI) */
@media (max-width: 980px){
  .search-grid{ grid-template-columns: 1fr; }
  .searchbox{ max-width: 100%; }
  .find-card{ flex-direction:row; justify-content:flex-start; text-align:left; }
  .cards{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px){
  .header-row h1{ font-size: 22px; }
  .step{ min-width: 92px; }
  .line{ max-width: 110px; }
  .cards{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px){
  .frame{ padding: 18px; }
  .cards{ grid-template-columns: 1fr; }
  .label{ white-space:normal; }
  .line{ display:none; }
}

/* Product grid */
.products-grid{  display:grid;  grid-template-columns: repeat(4, minmax(220px, 1fr));  gap: 22px;}

@media (max-width: 1100px){  .products-grid{ grid-template-columns: repeat(3, minmax(220px, 1fr)); }}
@media (max-width: 860px){  .products-grid{ grid-template-columns: repeat(2, minmax(220px, 1fr)); }}
@media (max-width: 520px){  .products-grid{ grid-template-columns: 1fr; }}

.product-card{  border: 1px solid #bdbdbd;  background:#fff;  padding: 18px;  min-height: 220px;  display:flex;  flex-direction:column;  justify-content:space-between;  text-decoration:none;  color: inherit;}

.product-card:hover{  box-shadow: 0 10px 24px rgba(0,0,0,.08);  transform: translateY(-1px);}

.product-img{ height: 135px;  display:flex;  align-items:center;  justify-content:center;}

.product-img img{  max-height: 135px;  max-width: 100%;  object-fit: contain;}

.product-title{  text-align:center;  margin-top: 14px;  font-size: 16px;  font-weight: 500;}
/* Layout 2-Spalten + Sticky */
.model-layout{  display:flex;  gap:18px;  align-items:flex-start;  justify-content:center;  flex-wrap:wrap;}

.model-left{  flex: 1 1 420px;  max-width: 520px;}

.model-right{  flex: 0 1 520px;  min-width: 320px;  display:flex;  justify-content:center;}

/* Sticky Box */
.price-sticky{  position: sticky;  top: 16px;  align-self: flex-start;  width:100%;  max-width:520px;}

/* Tabelle kompakter & schmaler */
.price-box{  width:100%;  max-width: 520px;  margin:0 auto;  border:1px solid #d7dee7;  border-radius:10px;  overflow:hidden;  background:#fff;}

.price-title{  text-align:center;  font-weight:800;  padding:10px 12px;  border-bottom:1px solid #e6edf6;}

.price-table{  width:100%;  border-collapse:collapse;  font-size:14px;}

.price-table th{  text-align:left;  padding:10px 12px;  background:#f6f8fb;  border-bottom:1px solid #d7dee7;  font-weight:700;}

.price-table td{  padding:10px 12px;  border-bottom:1px solid #e6edf6;  vertical-align:middle;}

/* CTA Button in Tabelle */
.btn-row{  display:inline-flex;  align-items:center;  gap:8px;  padding:7px 10px;  border-radius:10px;  background:#10b981;  color:#fff;  text-decoration:none;  font-weight:700;  font-size:13px;  white-space:nowrap;}

.btn-row:hover{ filter: brightness(.95); }

.price-right{  text-align:right;  white-space:nowrap;  width: 210px; /* Preis + Button Spalte */}

/* Mobile: Sticky deaktivieren (sonst nervig) */
@media (max-width: 980px){  .price-sticky{ position: static; max-width: 100%; }  .model-right{ flex: 1 1 100%; }  .price-box{ max-width: 100%; }  .price-right{ width:auto; }}

.btn-plus, .btn-minus{  width:34px;  height:34px;  border-radius:10px;  border:1px solid #d7dee7;  font-weight:900;  cursor:pointer;  display:grid;  place-items:center;  background:#fff;}
.btn-plus{ color:#10b981; }
.btn-minus{ color:#ef4444; }
.btn-plus:hover{ background: rgba(16,185,129,.08); }
.btn-minus:hover{ background: rgba(239,68,68,.08); }

/* ===== Stepper ===== */
.repair-steps{display:flex;align-items:center;gap:12px;margin:0 0 18px}
.step{display:flex;align-items:center;gap:10px}
.step-number{width:38px;height:38px;border-radius:50%;background:#e5e5e5;color:#333;display:flex;align-items:center;justify-content:center;font-weight:700}
.step-title{font-weight:700;color:#333}
.step.active .step-number{background:#3c8dbc;color:#fff}
.step-line{flex:1;height:2px;background:#e5e5e5;border-radius:999px}

/* ===== Summary Sticky ===== */
.summary-box{position:sticky;top:90px}
.service-line{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px solid #f2f2f2}
.total-line{display:flex;justify-content:space-between;font-size:18px;margin-top:10px}
.checkout-summary-service-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;text-align:right}
.checkout-remove-service-form{display:inline-flex;margin:0}
.checkout-remove-service-btn{border:1px solid #fecaca;border-radius:10px;background:#fff5f5;color:#b91c1c;font-size:12px;font-weight:800;line-height:1;padding:7px 9px}
.checkout-remove-service-btn:hover{background:#fee2e2;color:#991b1b}

/* ===== Badges ===== */
.selected-services{margin-top:10px}
.service-badge{font-size:13px;margin:4px 4px 0 0;padding:8px 10px;display:inline-block;border-radius:3px;background:#3c8dbc;color:#fff}
.service-badge .price{margin-left:6px;font-weight:700;opacity:.95}

/* ===== Tabs disabled ===== */
.nav-tabs>li.disabled>a{pointer-events:none;opacity:.55}

/* ===== Error ===== */
.has-error .form-control{border-color:#dd4b39}
.help-hint{color:#777;font-size:12px}

/* ===== Repair checkout customer data ===== */
.checkout-customer-note,
.checkout-address-block{
  border:1px solid #d9e7fb;
  border-radius:18px;
  background:#f6faff;
  padding:14px 16px;
  margin-bottom:16px;
}
.checkout-customer-note strong,
.checkout-address-block__head strong{
  display:block;
  color:#102a43;
  font-size:15px;
  font-weight:800;
}
.checkout-customer-note span,
.checkout-address-block__head span{
  display:block;
  margin-top:4px;
  color:#5f6f85;
  font-size:13px;
  line-height:1.45;
}
.checkout-address-block{
  margin-top:10px;
  background:#fbfdff;
}
.checkout-address-block__head{
  margin-bottom:12px;
}
.checkout-fulfillment-block{
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#fff;
  padding:14px;
  margin-bottom:16px;
}
.checkout-fulfillment-block>label{
  display:block;
  margin-bottom:10px;
  color:#102a43;
  font-size:15px;
  font-weight:800;
}
.checkout-fulfillment-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.checkout-fulfillment-option{
  min-height:96px;
  cursor:pointer;
  border:1px solid #d9e2ef;
  border-radius:16px;
  background:#f8fafc;
  padding:12px;
}
.checkout-fulfillment-option input{
  margin:0 0 8px;
}
.checkout-fulfillment-option:has(input:checked){
  border-color:#3c8dbc;
  background:#eef8ff;
  box-shadow:0 10px 26px rgba(60,141,188,.12);
}
.checkout-fulfillment-option strong,
.checkout-fulfillment-option span{
  display:block;
}
.checkout-fulfillment-option strong{
  color:#102a43;
  font-size:15px;
}
.checkout-fulfillment-option span{
  margin-top:4px;
  color:#667085;
  font-size:13px;
  line-height:1.4;
}
.checkout-mail-in-info{
  border:1px solid #bfdbfe;
  border-radius:16px;
  background:#eff6ff;
  color:#0b3b76;
  font-size:13px;
  font-weight:700;
  line-height:1.45;
  margin:0 0 16px;
  padding:12px 14px;
}
.box.box-primary .form-control{
  min-height:42px;
  border-color:#d9e2ef;
  border-radius:10px;
  box-shadow:none;
}
.box.box-primary .form-control:focus{
  border-color:#3c8dbc;
  box-shadow:0 0 0 3px rgba(60,141,188,.12);
}
@media (max-width:767.98px){
  .checkout-fulfillment-options{grid-template-columns:1fr}
}


.location-page {
        --rn-primary: #0d3b73;
        --rn-accent: #0d6efd;
        --rn-text: #22324a;
        --rn-muted: #667085;
        --rn-border: #d9dee7;
        --rn-bg: #f7f8fa;
        --rn-card: #ffffff;
        --rn-radius: 18px;
        --rn-shadow: 0 10px 30px rgba(16, 24, 40, 0.06);
    }

    .location-page {
        color: var(--rn-text);
    }

    .location-page .section-card {
        background: var(--rn-card);
        border: 1px solid var(--rn-border);
        border-radius: var(--rn-radius);
        box-shadow: var(--rn-shadow);
    }

    .location-page .hero-card {
        padding: 28px;
    }

    .location-page .hero-title {
        color: var(--rn-primary);
        font-size: clamp(2rem, 3.2vw, 3rem);
        font-weight: 800;
        margin-bottom: 1.75rem;
        text-align: center;
    }

    .location-page .hero-image {
        width: 100%;
        height: 100%;
        min-height: 320px;
        object-fit: cover;
        border-radius: 16px;
        display: block;
    }

    .location-page .info-title,
    .location-page .section-title {
        color: var(--rn-primary);
        font-weight: 800;
    }

    .location-page .section-title {
        font-size: clamp(1.65rem, 2vw, 2.2rem);
        margin-bottom: 1rem;
    }

    .location-page .address-box p,
    .location-page .address-box a,
    .location-page .address-box li {
        font-size: 1.05rem;
    }

    .location-page .meta-link {
        color: var(--rn-accent);
        text-decoration: underline;
    }

    .location-page .action-stack {
        display: grid;
        gap: 14px;
        margin-top: 1.75rem;
    }

    .location-page .action-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        min-height: 56px;
        padding: 0 18px;
        border: 1px solid var(--rn-border);
        border-radius: 12px;
        background: #fff;
        color: var(--rn-text);
        text-decoration: none;
        font-weight: 600;
        transition: .2s ease;
    }

    .location-page .action-btn:hover {
        transform: translateY(-1px);
        box-shadow: 0 8px 20px rgba(16,24,40,.08);
        color: var(--rn-primary);
    }

    .location-page .hours-list {
        margin: 0;
        padding-left: 1.25rem;
    }

    .location-page .hours-list li {
        margin-bottom: .45rem;
        font-size: 1.05rem;
    }

    .location-page .split-panels {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 24px;
        margin-top: 2rem;
    }

    .location-page .split-panel {
        padding: 24px;
    }

    .location-page .panel-head {
        border: 1px solid var(--rn-border);
        border-radius: 8px;
        text-align: center;
        padding: 10px 16px;
        font-weight: 600;
        margin-bottom: 24px;
        background: #fff;
    }

    .location-page .contact-form label {
        font-weight: 700;
        margin-bottom: .35rem;
    }

    .location-page .contact-form .form-control {
        border-radius: 0;
        border: 1px solid #cfd4dc;
        min-height: 44px;
    }

    .location-page .contact-form textarea.form-control {
        min-height: 140px;
    }

    .location-page .submit-btn {
        min-width: 130px;
        border-radius: 0;
        font-weight: 600;
    }

    .location-page .info-block {
        text-align: center;
    }

    .location-page .info-icon {
        font-size: 70px;
        line-height: 1;
        margin-bottom: 10px;
    }

    .location-page .review-strip,
    .location-page .faq-box,
    .location-page .repair-card {
        background: #fff;
        border: 1px solid var(--rn-border);
        border-radius: var(--rn-radius);
        box-shadow: var(--rn-shadow);
    }

    .location-page .review-strip {
        padding: 24px;
        margin-top: 2rem;
    }

    .location-page .review-grid {
        display: grid;
        grid-template-columns: 280px repeat(4, 1fr);
        gap: 18px;
        align-items: stretch;
    }

    .location-page .rating-summary {
        display: flex;
        flex-direction: column;
        justify-content: center;
        height: 100%;
    }

    .location-page .review-card {
        border: 1px solid #eceff3;
        border-radius: 14px;
        background: #fafafa;
        padding: 18px;
        min-height: 190px;
    }

    .location-page .repair-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 28px;
        margin-top: 2rem;
    }

    .location-page .repair-card {
        padding: 28px 20px;
        text-align: center;
    }

    .location-page .repair-card h3 a {
        color: #0d6efd;
        text-decoration: underline;
        font-size: 14px;
        font-weight: 800;
    }

    .location-page .repair-card img {
        max-width: 210px;
        max-height: 260px;
        width: auto;
        height: auto;
        object-fit: contain;
        margin: 16px auto 18px;
        display: block;
    }

    .location-page .repair-card p {
        text-align: left;
        line-height: 1.75;
        font-size: 14px;
    }

    .location-page .repair-card .repair-btn {
        margin-top: 10px;
        border: 1px solid #cfd4dc;
        border-radius: 6px;
        background: #fff;
        padding: 10px 26px;
        color: var(--rn-text);
        text-decoration: none;
        display: inline-block;
    }

    .location-page .faq-box {
        margin-top: 2rem;
        padding: 38px 28px;
        text-align: center;
    }

    .location-page .faq-title {
        color: #0d6efd;
        font-size: clamp(1.8rem, 2.5vw, 2.8rem);
        font-weight: 800;
        margin-bottom: 1.5rem;
    }

    .location-page .faq-item {
        margin-bottom: 1.8rem;
    }

    .location-page .faq-item h4 {
        color: #0d6efd;
        font-size: 1.35rem;
        font-weight: 800;
        margin-bottom: .5rem;
    }

    .location-page .faq-item p {
        max-width: 900px;
        margin: 0 auto;
        font-size: 1.1rem;
        line-height: 1.8;
    }

    .location-page .divider-line {
        margin: 2.5rem 0;
        border-top: 1px solid var(--rn-border);
    }

    @media (max-width: 991.98px) {
        .location-page .split-panels,
        .location-page .repair-grid,
        .location-page .review-grid {
            grid-template-columns: 1fr;
        }

        .location-page .hero-card {
            padding: 18px;
        }

        .location-page .hero-image {
            min-height: 240px;
        }
    }

    .rns-hero { width: 100%; }
    .rns-hero__bg{
      position: relative;
      min-height: 520px;
      display: flex;
      align-items: center;
      padding: 64px 0;
      background-image: image-set(
        url("{{ asset('/uploads/website_foto/home_foto_reparatur-1024.webp') }}") type("image/webp"),
        url("{{ asset('/uploads/website_foto/home_foto_reparatur.png') }}") type("image/png")
      );
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      overflow: hidden;
    }

    .rns-hero__overlay{
      position:absolute; inset:0;
      /* Left-weighted overlay to keep text readable */
      background: linear-gradient(
        90deg,
        rgba(8, 16, 28, 0.78) 0%,
        rgba(8, 16, 28, 0.62) 42%,
        rgba(8, 16, 28, 0.20) 68%,
        rgba(8, 16, 28, 0.00) 100%
      );
      pointer-events:none;
    }

    .rns-hero__container{
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .rns-hero__content{
      max-width: 620px;
      color: #fff;
    }

    .rns-hero__badge{
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.20);
      font-size: 13px;
      line-height: 1;
      letter-spacing: 0.3px;
      margin-bottom: 16px;
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
    }

    .rns-hero__title{
      margin: 0 0 14px 0;
      font-weight: 800;
      font-size: clamp(30px, 4vw, 46px);
      line-height: 1.08;
      color: rgba(255,255,255,0.88); 
      letter-spacing: -0.6px;
    }

    .rns-hero__subtitle{
      margin: 0 0 22px 0;
      font-size: clamp(15px, 1.4vw, 18px);
      line-height: 1.55;
      color: rgba(255,255,255,0.88);
      max-width: 560px;
    }

    .rns-hero__ctas{
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin: 0 0 18px 0;
    }

    .rns-btn{
      display: inline-flex;
      flex-direction: column;
      align-items: flex-start;
      justify-content: center;
      gap: 6px;
      padding: 14px 16px;
      border-radius: 14px;
      text-decoration: none !important;
      font-weight: 700;
      font-size: 16px;
      line-height: 1.2;
      transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease, border-color 140ms ease;
      min-height: 58px;
      box-shadow: 0 10px 24px rgba(0,0,0,0.25);
      user-select: none;
    }

    .rns-btn__sub{
      display:block;
      font-weight: 600;
      font-size: 12.5px;
      line-height: 1.2;
      opacity: 0.9;
    }

    .rns-btn--primary{
      background: #0B5FFF;
      color: #fff !important;
      border: 1px solid rgba(255,255,255,0.14);
    }

    .rns-btn--primary:hover{
      transform: translateY(-1px);
      box-shadow: 0 14px 32px rgba(0,0,0,0.32);
      background: #0A56E6;
    }

    .rns-btn--secondary{
      background: rgba(255,255,255,0.12);
      color: #fff !important;
      border: 1px solid rgba(255,255,255,0.28);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
    }

    .rns-btn--secondary:hover{
      transform: translateY(-1px);
      box-shadow: 0 14px 32px rgba(0,0,0,0.32);
      background: rgba(255,255,255,0.16);
      border-color: rgba(255,255,255,0.38);
    }

    .rns-hero__proof{
      margin: 10px 0 0 0;
      padding: 0;
      list-style: none;
      display: grid;
      gap: 8px;
      color: rgba(255,255,255,0.90);
      font-size: 14px;
      line-height: 1.35;
    }

    .rns-hero__proof li{
      position: relative;
      padding-left: 24px;
    }

    .rns-hero__proof li:before{
      content: "✓";
      position: absolute;
      left: 0;
      top: 0;
      color: rgba(255,255,255,0.92);
      font-weight: 900;
    }

    @media (max-width: 860px){
      .rns-hero__bg{ min-height: 520px; padding: 52px 0; background-position: 70% center; }
      .rns-hero__content{ max-width: 680px; }
      .rns-hero__ctas{ grid-template-columns: 1fr; }
      .rns-btn{ align-items: center; text-align: center; }
      .rns-btn__sub{ text-align: center; width: 100%; }
      .rns-hero__overlay{
        background: linear-gradient(
          180deg,
          rgba(8, 16, 28, 0.74) 0%,
          rgba(8, 16, 28, 0.58) 45%,
          rgba(8, 16, 28, 0.30) 75%,
          rgba(8, 16, 28, 0.18) 100%
        );
      }
    }

    /* Optional: hide line breaks on desktop if not needed */
    .rns-hero__br{ display: none; }
    @media (max-width: 520px){
      .rns-hero__br{ display: inline; }
    }

/* =========================================================
   Public Website 2026 UI polish
   Scope: public website layout only, no ERP/admin tables.
   ========================================================= */
:root{
  --rns-page:#f6f8fb;
  --rns-surface:#ffffff;
  --rns-surface-soft:#f8fbff;
  --rns-text:#101828;
  --rns-subtle:#475467;
  --rns-line:#e4e7ec;
  --rns-blue:#0b62ff;
  --rns-blue-dark:#084cc9;
  --rns-green:#10b981;
  --rns-radius-sm:8px;
  --rns-radius:12px;
  --rns-radius-lg:16px;
  --rns-shadow:0 16px 40px rgba(16,24,40,.08);
  --rns-shadow-soft:0 8px 24px rgba(16,24,40,.06);
}

html{
  scroll-behavior:smooth;
  text-size-adjust:100%;
}

body{
  background:var(--rns-page);
  color:var(--rns-text);
  font-family:"Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
}

body,
button,
input,
select,
textarea{
  letter-spacing:0 !important;
}

a{
  color:var(--rns-blue);
  text-underline-offset:3px;
}

a:hover{
  color:var(--rns-blue-dark);
}

img,
svg,
video{
  max-width:100%;
  height:auto;
}

.site-main{
  width:100%;
  margin:0;
  padding:0;
  background:var(--rns-page);
}

.site-main > *{
  width:100%;
}

.topbar{
  position:sticky;
  top:0;
  z-index:1050;
  padding:12px clamp(14px, 2vw, 28px);
  border-bottom:1px solid rgba(16,24,40,.08);
  box-shadow:0 10px 26px rgba(16,24,40,.08);
}

.brand img{
  height:40px;
  width:auto;
}

.topbar-row--nav{
  border-top:1px solid rgba(16,24,40,.08);
}

.topnav{
  gap:8px;
  scrollbar-width:none;
}

.topnav::-webkit-scrollbar{
  display:none;
}

.topnav-item{
  min-height:44px;
  border-radius:var(--rns-radius-sm);
  color:#182230;
  font-weight:700;
  font-size:14px;
  transition:background-color .16s ease, color .16s ease, box-shadow .16s ease;
}

.topnav-item:hover,
.topnav-dd.is-open > .topnav-item{
  background:#eef4ff;
  color:var(--rns-blue-dark);
}

.btn-location{
  min-height:44px;
  border-radius:var(--rns-radius-sm);
  background:var(--rns-blue);
  box-shadow:0 10px 22px rgba(11,98,255,.22);
}

.lang select{
  min-height:44px;
  border-radius:var(--rns-radius-sm);
  border:1px solid var(--rns-line);
}

.topnav-dd .mega{
  border-radius:var(--rns-radius-lg);
  border:1px solid rgba(16,24,40,.10);
  box-shadow:0 24px 56px rgba(16,24,40,.18);
}

.topnav-dd .mega-title,
.topnav-dd .mega-all{
  color:var(--rns-blue);
}

.topnav-dd .mega-link{
  color:#344054;
}

.topnav-dd .mega-link:hover,
.topnav-dd .mega-all:hover{
  background:#f2f4f7;
  color:var(--rns-blue-dark);
}

.site-main h1,
.site-main h2,
.site-main h3,
.site-main h4{
  color:var(--rns-text);
  font-weight:800;
  line-height:1.14;
  letter-spacing:0 !important;
}

.site-main h1{
  font-size:clamp(2.25rem, 5vw, 4.75rem);
}

.site-main h2{
  font-size:clamp(1.8rem, 3.2vw, 3rem);
}

.site-main h3{
  font-size:clamp(1.25rem, 2vw, 1.75rem);
}

.site-main p,
.site-main li{
  color:var(--rns-subtle);
}

.site-main .container,
.site-main .container-fluid,
.rns-section,
.mailin-page,
.location-page .container{
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  padding-left:clamp(16px, 3vw, 32px);
  padding-right:clamp(16px, 3vw, 32px);
}

.rns-hero__bg{
  min-height:clamp(560px, 72vh, 760px);
  padding:clamp(72px, 9vw, 120px) 0;
}

.rns-hero__title{
  color:#fff;
  font-weight:900;
  letter-spacing:0 !important;
  font-size:clamp(2.3rem, 5.4vw, 5.25rem);
  line-height:1.02;
}

.rns-hero__subtitle{
  max-width:640px;
  font-size:clamp(1.02rem, 1.4vw, 1.25rem);
}

.rns-hero__badge{
  border-radius:999px;
  font-weight:800;
  letter-spacing:0 !important;
}

.rns-hero__ctas{
  max-width:620px;
}

.rns-btn,
.site-main .btn,
.device-repair-btn-secondary,
.meta-link,
.mailin-inline-btn{
  border-radius:var(--rns-radius-sm) !important;
  min-height:46px;
  font-weight:800;
  letter-spacing:0 !important;
}

.rns-btn{
  align-items:flex-start;
  box-shadow:0 16px 34px rgba(0,0,0,.22);
}

.rns-btn--primary,
.site-main .btn-primary{
  background:var(--rns-blue) !important;
  border-color:var(--rns-blue) !important;
}

.rns-btn--primary:hover,
.site-main .btn-primary:hover{
  background:var(--rns-blue-dark) !important;
  border-color:var(--rns-blue-dark) !important;
}

.site-main .card,
.site-main .section-card,
.site-main .hero-card,
.site-main .mailin-form-shell,
.site-main .mailin-section,
.site-main .faq-box,
.site-main .split-panel,
.site-main .review-strip,
.site-main .type-card,
.site-main .brand-card{
  border-radius:var(--rns-radius-lg) !important;
  border:1px solid var(--rns-line) !important;
  box-shadow:var(--rns-shadow-soft) !important;
}

.site-main .card .card,
.site-main .section-card .card,
.site-main .hero-card .card{
  box-shadow:none !important;
}

.site-main input:not([type="checkbox"]):not([type="radio"]),
.site-main select,
.site-main textarea,
.site-main .form-control{
  min-height:48px;
  border-radius:var(--rns-radius-sm) !important;
  border:1px solid #d0d5dd !important;
  color:var(--rns-text);
  box-shadow:none !important;
}

.site-main textarea{
  min-height:120px;
}

.site-main input:focus,
.site-main select:focus,
.site-main textarea:focus,
.site-main .form-control:focus{
  border-color:var(--rns-blue) !important;
  box-shadow:0 0 0 4px rgba(11,98,255,.14) !important;
}

.site-footer{
  margin-top:0;
  background:#0b1220;
  color:#d0d5dd;
  padding:clamp(38px, 5vw, 72px) clamp(16px, 3vw, 32px);
}

.footer-grid{
  max-width:1200px;
  margin:0 auto;
  gap:clamp(24px, 4vw, 48px);
}

.footer-col h3{
  color:#fff;
  font-size:1rem;
  letter-spacing:0 !important;
}

.footer-links a{
  color:#d0d5dd;
  min-height:30px;
  display:inline-flex;
  align-items:center;
}

.footer-links a:hover{
  color:#fff;
}

@media (max-width: 991.98px){
  .topbar{
    padding:10px 14px;
  }

  .menu-toggle{
    display:inline-flex;
  }

  .topbar-row--nav{
    display:none;
    margin-top:10px;
    padding-top:10px;
  }

  .topbar-row--nav.is-mobile-open{
    display:block;
  }

  .topnav{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    overflow:visible;
  }

  .topnav-item{
    width:100%;
    justify-content:space-between;
    min-height:48px;
    background:#f8fafc;
  }

  .topnav-dd{
    position:relative !important;
  }

  .topnav-dd .mega,
  .topnav-dd--standorte .mega{
    position:static !important;
    width:100% !important;
    min-width:0 !important;
    max-width:none !important;
    margin-top:8px;
    padding:12px !important;
    border-radius:var(--rns-radius) !important;
    opacity:1;
    transform:none;
    display:none;
    pointer-events:auto;
    box-shadow:none;
  }

  .topnav-dd.is-open .mega{
    display:block;
  }

  .topnav-dd .mega-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .topbar-actions .lang{
    display:none;
  }

  .lang--mobile{
    display:flex;
    margin-top:8px;
  }

  .lang--mobile select{
    width:100%;
  }
}

@media (max-width: 767.98px){
  body{
    font-size:15px;
  }

  .brand img{
    height:34px;
  }

  .btn-location{
    padding:9px 10px;
    font-size:13px;
  }

  .rns-hero__bg{
    min-height:620px;
    padding:68px 0 56px;
    background-position:70% center;
  }

  .rns-hero__ctas{
    grid-template-columns:1fr;
  }

  .rns-btn{
    width:100%;
    align-items:center;
    text-align:center;
  }

  .site-main .container,
  .site-main .container-fluid,
  .rns-section,
  .mailin-page,
  .location-page .container{
    padding-left:16px !important;
    padding-right:16px !important;
  }
}

/* Premium web-app direction: calm surfaces, sharper hierarchy, conversion CTAs. */
:root{
  --rns-page:#f7f9fc;
  --rns-surface:#ffffff;
  --rns-surface-alt:#fbfcff;
  --rns-ink:#0b1220;
  --rns-copy:#475467;
  --rns-muted-2:#667085;
  --rns-accent:#0b62ff;
  --rns-accent-2:#0f766e;
  --rns-border-strong:#d9e1ec;
  --rns-premium-shadow:0 18px 44px rgba(16,24,40,.10);
}

.site-main{
  background:
    linear-gradient(180deg, #fff 0, var(--rns-page) 420px),
    var(--rns-page);
}

.topbar{
  backdrop-filter:saturate(1.1) blur(14px);
  -webkit-backdrop-filter:saturate(1.1) blur(14px);
  background:rgba(255,255,255,.94);
}

.topnav-item,
.btn-location,
.lang select,
.menu-toggle{
  border-radius:8px !important;
}

.btn-location{
  background:linear-gradient(135deg, var(--rns-accent), #084cc9);
  border:1px solid rgba(255,255,255,.16);
}

.rns-hero__bg{
  isolation:isolate;
}

.rns-hero__overlay{
  background:
    linear-gradient(90deg, rgba(5,12,24,.88) 0%, rgba(5,12,24,.72) 43%, rgba(5,12,24,.30) 72%, rgba(5,12,24,.08) 100%),
    linear-gradient(180deg, rgba(11,98,255,.18), rgba(15,118,110,.14));
}

.rns-hero__badge{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.26);
  color:#fff;
}

.rns-hero__title{
  max-width:760px;
  text-wrap:balance;
}

.rns-hero__subtitle{
  color:rgba(255,255,255,.88);
}

.rns-hero__proof{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
  max-width:760px;
  margin-top:18px;
}

.rns-hero__proof li{
  min-height:42px;
  display:flex;
  align-items:center;
  padding:10px 12px 10px 36px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  background:rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.rns-hero__proof li:before{
  left:13px;
  top:50%;
  transform:translateY(-50%);
  color:#8cffd2;
}

.rns-btn{
  border-radius:8px !important;
  min-height:64px;
  padding:16px 18px;
  box-shadow:0 18px 40px rgba(0,0,0,.24);
}

.rns-btn--primary{
  background:linear-gradient(135deg, #0b62ff, #0645b8) !important;
}

.rns-btn--secondary{
  background:rgba(255,255,255,.12);
}

.rns-device-picker,
.rns-faq,
.mailin-page,
.location-page{
  background:var(--rns-page) !important;
}

.rns-device-picker{
  padding:clamp(48px, 7vw, 96px) 0 clamp(34px, 5vw, 70px) !important;
}

.rns-device-picker__intro{
  max-width:820px !important;
  margin-bottom:34px !important;
}

.rns-device-picker__eyebrow,
.rns-hero__badge,
.mailin-step-indicator{
  letter-spacing:0 !important;
}

.rns-device-picker__intro h2{
  color:var(--rns-ink) !important;
  font-weight:900 !important;
  text-wrap:balance;
}

.rns-device-picker__intro p{
  color:var(--rns-copy) !important;
  font-size:1.05rem !important;
}

.rns-device-grid{
  max-width:1200px;
  margin:0 auto;
  gap:18px !important;
}

.rns-device-card{
  min-height:360px !important;
  border:1px solid var(--rns-border-strong) !important;
  border-radius:8px !important;
  box-shadow:0 10px 28px rgba(16,24,40,.06) !important;
  background:linear-gradient(180deg, #fff, #fbfcff) !important;
}

a.rns-device-card:hover,
a.rns-device-card:focus-visible{
  transform:translateY(-3px) !important;
  border-color:var(--rns-accent) !important;
  box-shadow:var(--rns-premium-shadow) !important;
}

.rns-device-icon{
  min-height:230px !important;
}

.rns-device-icon img{
  width:min(252px, 100%) !important;
  height:auto !important;
  aspect-ratio:1 / 1;
  border-radius:8px !important;
  box-shadow:0 14px 34px rgba(16,24,40,.10);
}

.rns-device-label{
  color:var(--rns-ink);
  font-weight:800 !important;
}

.rns-faq{
  border:0 !important;
  padding:clamp(52px, 7vw, 96px) clamp(16px, 4vw, 40px) !important;
}

.rns-faq h2{
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
  font-weight:900 !important;
  text-wrap:balance;
}

.rns-faq .faq-list{
  max-width:980px !important;
}

.rns-faq details{
  border:1px solid var(--rns-border-strong) !important;
  border-radius:8px !important;
  box-shadow:0 10px 26px rgba(16,24,40,.06) !important;
  padding:18px 20px !important;
}

.rns-faq summary{
  color:var(--rns-ink) !important;
  font-size:1.05rem !important;
  gap:16px;
}

.rns-faq summary::after{
  color:var(--rns-accent) !important;
}

.rns-faq p{
  color:var(--rns-copy) !important;
  font-size:1rem !important;
}

.site-main .mailin-form-shell,
.site-main .mailin-section,
.site-main .section-card,
.site-main .hero-card,
.site-main .split-panel,
.site-main .review-strip,
.site-main .type-card,
.site-main .brand-card,
.site-main .faq-box{
  border-radius:8px !important;
  border-color:var(--rns-border-strong) !important;
  box-shadow:0 10px 30px rgba(16,24,40,.07) !important;
}

.site-main .btn,
.site-main .form-control,
.site-main input:not([type="checkbox"]):not([type="radio"]),
.site-main select,
.site-main textarea{
  border-radius:8px !important;
}

.site-footer{
  background:linear-gradient(180deg, #111827 0%, #07101f 100%);
}

@media (max-width: 991.98px){
  .rns-hero__proof{
    grid-template-columns:1fr;
  }
}

@media (max-width: 767.98px){
  .rns-hero__bg{
    min-height:640px;
  }

  .rns-hero__proof li{
    min-height:40px;
  }

  .rns-device-card{
    min-height:280px !important;
  }
}

/* repairNstore premium start page */
.rns-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  padding:8px 12px;
  border:1px solid rgba(11,98,255,.14);
  border-radius:999px;
  background:#eef5ff;
  color:#0b62ff !important;
  font-size:13px;
  font-weight:800;
  line-height:1.2;
}

.rns-home-hero{
  padding:clamp(54px, 7vw, 92px) clamp(16px, 4vw, 40px) clamp(42px, 6vw, 76px);
  background:
    radial-gradient(circle at 78% 18%, rgba(11,98,255,.14), transparent 28%),
    radial-gradient(circle at 12% 84%, rgba(15,118,110,.10), transparent 24%),
    linear-gradient(180deg, #fff 0%, #f7f9fc 100%);
}

.rns-home-hero__inner{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) minmax(340px, .78fr);
  gap:clamp(32px, 5vw, 72px);
  align-items:center;
}

.rns-home-hero h1{
  max-width:820px;
  margin:0;
  color:#0b1220;
  font-size:clamp(2.6rem, 6vw, 5.7rem);
  font-weight:900;
  line-height:.98;
  text-wrap:balance;
}

.rns-home-hero__lead{
  max-width:720px;
  margin:24px 0 0;
  color:#475467 !important;
  font-size:clamp(1.08rem, 1.6vw, 1.32rem);
  line-height:1.68;
}

.rns-home-hero__actions{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin-top:30px;
}

.rns-home-btn{
  display:flex;
  min-height:68px;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  padding:15px 17px;
  border-radius:8px;
  border:1px solid #d9e1ec;
  text-decoration:none;
  font-weight:900;
  line-height:1.15;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.rns-home-btn span{
  color:inherit;
  opacity:.78;
  font-size:12px;
  font-weight:700;
  line-height:1.35;
}

.rns-home-btn:hover,
.rns-home-btn:focus-visible{
  transform:translateY(-2px);
  text-decoration:none;
  box-shadow:0 16px 34px rgba(16,24,40,.12);
}

.rns-home-btn--primary{
  border-color:#0b62ff;
  background:linear-gradient(135deg, #0b62ff, #0645b8);
  color:#fff !important;
}

.rns-home-btn--light{
  background:#fff;
  color:#0b1220 !important;
}

.rns-home-btn--dark{
  border-color:#101828;
  background:#101828;
  color:#fff !important;
}

.rns-home-hero__proof{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
  padding:0;
  margin:24px 0 0;
  list-style:none;
}

.rns-home-hero__proof li{
  min-height:68px;
  padding:13px 14px;
  border:1px solid #d9e1ec;
  border-radius:8px;
  background:rgba(255,255,255,.78);
  color:#344054 !important;
  font-size:13px;
  font-weight:750;
  line-height:1.45;
}

.rns-home-hero__visual{
  position:relative;
  min-height:560px;
}

.rns-home-device{
  position:absolute;
  overflow:hidden;
  border:1px solid rgba(16,24,40,.10);
  border-radius:8px;
  background:#fff;
  box-shadow:0 24px 70px rgba(16,24,40,.15);
}

.rns-home-device img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.rns-home-device--phone{
  inset:0 auto auto 0;
  width:68%;
  height:76%;
}

.rns-home-device--laptop{
  right:0;
  bottom:38px;
  width:68%;
  height:46%;
}

.rns-home-trust-card{
  position:absolute;
  left:24px;
  bottom:0;
  max-width:260px;
  padding:18px;
  border:1px solid rgba(255,255,255,.70);
  border-radius:8px;
  background:rgba(255,255,255,.90);
  box-shadow:0 18px 44px rgba(16,24,40,.14);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.rns-home-trust-card strong,
.rns-home-trust-card span{
  display:block;
}

.rns-home-trust-card strong{
  color:#0b1220;
  font-size:18px;
  font-weight:900;
}

.rns-home-trust-card span{
  margin-top:6px;
  color:#475467;
  font-size:13px;
  line-height:1.45;
}

.rns-home-section{
  max-width:1200px;
  margin:0 auto;
  padding:clamp(54px, 7vw, 92px) clamp(16px, 4vw, 40px);
}

.rns-home-section__head{
  max-width:760px;
  margin:0 auto 30px;
  text-align:center;
}

.rns-home-section__head h2,
.rns-home-status h2,
.rns-home-claims h2{
  margin:0;
  color:#0b1220;
  font-size:clamp(2rem, 4vw, 3.8rem);
  font-weight:900;
  line-height:1.02;
  text-wrap:balance;
}

.rns-home-section__head p,
.rns-home-status p,
.rns-home-claims p{
  margin:16px 0 0;
  color:#475467 !important;
  font-size:1.04rem;
  line-height:1.72;
}

.rns-home-device-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}

.rns-home-service-card{
  display:flex;
  min-height:410px;
  flex-direction:column;
  overflow:hidden;
  border:1px solid #d9e1ec;
  border-radius:8px;
  background:#fff;
  color:#0b1220 !important;
  text-decoration:none;
  box-shadow:0 12px 30px rgba(16,24,40,.07);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.rns-home-service-card:hover,
.rns-home-service-card:focus-visible{
  transform:translateY(-4px);
  border-color:#0b62ff;
  box-shadow:0 22px 48px rgba(16,24,40,.13);
  text-decoration:none;
}

.rns-home-service-card__media{
  display:block;
  aspect-ratio:1.08 / 1;
  background:#f2f5f9;
}

.rns-home-service-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.rns-home-service-card__body{
  display:flex;
  flex:1;
  flex-direction:column;
  gap:10px;
  padding:18px;
}

.rns-home-service-card strong{
  color:#0b1220;
  font-size:1.2rem;
  font-weight:900;
}

.rns-home-service-card span span{
  color:#475467;
  font-size:14px;
  line-height:1.55;
}

.rns-home-service-card em{
  margin-top:auto;
  color:#0b62ff;
  font-style:normal;
  font-size:14px;
  font-weight:900;
}

.rns-home-brand-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}

.rns-home-brand-card{
  min-height:132px;
  padding:20px;
  border:1px solid #d9e1ec;
  border-radius:8px;
  background:#fff;
  color:#0b1220 !important;
  text-decoration:none;
  box-shadow:0 10px 26px rgba(16,24,40,.05);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.rns-home-brand-card:hover,
.rns-home-brand-card:focus-visible{
  transform:translateY(-3px);
  border-color:#0b62ff;
  box-shadow:0 18px 38px rgba(16,24,40,.11);
  text-decoration:none;
}

.rns-home-brand-card strong,
.rns-home-brand-card span{
  display:block;
}

.rns-home-brand-card strong{
  font-size:1.18rem;
  font-weight:900;
}

.rns-home-brand-card span{
  margin-top:8px;
  color:#667085;
  font-size:13px;
  line-height:1.45;
}

.rns-home-status,
.rns-home-claims{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:28px;
  align-items:center;
  margin-top:18px;
  border:1px solid #d9e1ec;
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 44px rgba(16,24,40,.08);
}

.rns-home-status .rns-home-btn,
.rns-home-claims .rns-home-btn{
  min-width:230px;
}

.rns-home-claims{
  grid-template-columns:minmax(0, 1fr) minmax(260px, 360px);
  background:
    linear-gradient(135deg, rgba(11,98,255,.08), transparent 34%),
    #fff;
}

.rns-home-claims__badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:20px;
}

.rns-home-claims__badges span{
  display:inline-flex;
  min-height:34px;
  align-items:center;
  padding:7px 11px;
  border:1px solid #d9e1ec;
  border-radius:999px;
  background:#f8fafc;
  color:#344054;
  font-size:13px;
  font-weight:800;
}

.rns-home-claims__actions{
  display:grid;
  gap:12px;
}

@media (max-width: 1099px){
  .rns-home-hero__inner{
    grid-template-columns:1fr;
  }

  .rns-home-hero__visual{
    min-height:460px;
  }

  .rns-home-device-grid,
  .rns-home-brand-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px){
  .rns-home-hero{
    padding-top:38px;
  }

  .rns-home-hero__actions,
  .rns-home-hero__proof,
  .rns-home-device-grid,
  .rns-home-brand-grid,
  .rns-home-status,
  .rns-home-claims{
    grid-template-columns:1fr;
  }

  .rns-home-hero h1{
    font-size:clamp(2.2rem, 13vw, 3.8rem);
  }

  .rns-home-hero__visual{
    min-height:390px;
  }

  .rns-home-device--phone{
    width:72%;
    height:74%;
  }

  .rns-home-device--laptop{
    width:72%;
    height:42%;
    bottom:40px;
  }

  .rns-home-trust-card{
    left:12px;
    right:12px;
    max-width:none;
  }

  .rns-home-section{
    padding-top:48px;
    padding-bottom:48px;
  }

  .rns-home-service-card{
    min-height:0;
  }

  .rns-home-status .rns-home-btn,
  .rns-home-claims .rns-home-btn{
    min-width:0;
    width:100%;
  }
}

/* repairNstore premium homepage */
.rns-eyebrow{
  margin:0 0 16px;
  color:#0b63ce;
  font-size:13px;
  font-weight:800;
  letter-spacing:0;
  text-transform:uppercase;
}

.rns-home-hero,
.rns-home-section{
  color:#101828;
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.rns-home-hero{
  position:relative;
  overflow:hidden;
  padding:92px 20px 74px;
  background:
    linear-gradient(135deg, rgba(240, 247, 255, .98), rgba(255, 255, 255, .96) 54%, rgba(245, 248, 252, .98)),
    linear-gradient(90deg, rgba(13, 110, 253, .08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(13, 110, 253, .06) 1px, transparent 1px);
  background-size:auto, 74px 74px, 74px 74px;
}

.rns-home-hero::after{
  content:"";
  position:absolute;
  inset:auto 8% 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(13, 110, 253, .22), transparent);
}

.rns-home-hero__inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) minmax(360px, .98fr);
  gap:56px;
  align-items:center;
  width:min(1220px, 100%);
  margin:0 auto;
}

.rns-home-hero h1{
  max-width:820px;
  margin:0;
  color:#0b1220;
  font-size:clamp(48px, 6vw, 86px);
  line-height:.96;
  font-weight:900;
  letter-spacing:0;
}

.rns-home-hero__lead{
  max-width:720px;
  margin:24px 0 0;
  color:#475467;
  font-size:clamp(18px, 2vw, 22px);
  line-height:1.6;
}

.rns-home-hero__actions{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
  margin-top:34px;
}

.rns-home-btn{
  display:flex;
  min-height:64px;
  padding:14px 18px;
  border:1px solid rgba(16, 24, 40, .1);
  border-radius:20px;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:4px;
  color:#101828;
  background:#fff;
  box-shadow:0 16px 34px rgba(16, 24, 40, .08);
  font-weight:850;
  line-height:1.15;
  text-align:center;
  text-decoration:none;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.rns-home-btn span{
  color:inherit;
  font-size:12px;
  font-weight:650;
  opacity:.78;
}

.rns-home-btn:hover,
.rns-home-btn:focus{
  color:inherit;
  text-decoration:none;
  transform:translateY(-3px);
  box-shadow:0 22px 48px rgba(16, 24, 40, .13);
}

.rns-home-btn--primary{
  border-color:#0b63ce;
  color:#fff;
  background:linear-gradient(135deg, #0b63ce, #0d8aff);
}

.rns-home-btn--light{
  color:#0b1220;
  background:rgba(255, 255, 255, .9);
  backdrop-filter:blur(14px);
}

.rns-home-btn--dark{
  border-color:#101828;
  color:#fff;
  background:#101828;
}

.rns-home-hero__proof{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
  padding:0;
  margin:28px 0 0;
  list-style:none;
}

.rns-home-hero__proof li{
  min-height:92px;
  padding:16px;
  border:1px solid rgba(13, 110, 253, .12);
  border-radius:20px;
  color:#344054;
  background:rgba(255, 255, 255, .72);
  box-shadow:0 14px 32px rgba(16, 24, 40, .06);
  font-size:14px;
  font-weight:750;
}

.rns-home-hero__proof span{
  display:block;
  margin-bottom:12px;
  color:#0b63ce;
  font-size:12px;
  font-weight:900;
}

.rns-home-hero__visual{
  position:relative;
  min-height:610px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:34px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.86), rgba(246,249,253,.94)),
    radial-gradient(circle at 78% 16%, rgba(13, 110, 253, .16), transparent 34%);
  box-shadow:0 28px 70px rgba(16, 24, 40, .13);
}

.rns-home-device{
  position:absolute;
  overflow:hidden;
  margin:0;
  border:1px solid rgba(255, 255, 255, .84);
  border-radius:28px;
  background:#fff;
  box-shadow:0 24px 56px rgba(16, 24, 40, .2);
}

.rns-home-device img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.rns-home-device--phone{
  top:44px;
  left:48px;
  width:42%;
  height:70%;
}

.rns-home-device--laptop{
  right:34px;
  bottom:54px;
  width:62%;
  height:42%;
}

.rns-home-device--watch{
  top:66px;
  right:44px;
  width:26%;
  height:26%;
  border-radius:999px;
}

.rns-home-trust-card,
.rns-home-metric-card{
  position:absolute;
  z-index:2;
  padding:18px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:22px;
  background:rgba(255, 255, 255, .92);
  box-shadow:0 20px 46px rgba(16, 24, 40, .14);
  backdrop-filter:blur(16px);
}

.rns-home-trust-card{
  left:32px;
  right:32px;
  bottom:26px;
}

.rns-home-trust-card strong,
.rns-home-metric-card strong{
  display:block;
  color:#101828;
  font-size:18px;
  font-weight:900;
}

.rns-home-trust-card span,
.rns-home-metric-card span{
  display:block;
  margin-top:6px;
  color:#667085;
  font-size:14px;
  line-height:1.5;
}

.rns-home-trust-card a{
  display:inline-flex;
  margin-top:12px;
  color:#0b63ce;
  font-weight:800;
  text-decoration:none;
}

.rns-home-metric-card{
  top:28px;
  left:45%;
  width:190px;
}

.rns-home-section{
  width:min(1220px, calc(100% - 40px));
  margin:0 auto;
  padding:76px 0;
}

.rns-home-section__head{
  max-width:760px;
  margin:0 auto 34px;
  text-align:center;
}

.rns-home-section__head h2,
.rns-home-status h2,
.rns-home-claims h2,
.rns-home-final-cta h2{
  margin:0;
  color:#101828;
  font-size:clamp(32px, 4vw, 56px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:0;
}

.rns-home-section__head p,
.rns-home-status p,
.rns-home-claims p,
.rns-home-final-cta p{
  margin:16px 0 0;
  color:#667085;
  font-size:17px;
  line-height:1.7;
}

.rns-home-device-grid,
.rns-home-brand-grid,
.rns-home-benefit-grid{
  display:grid;
  gap:18px;
}

.rns-home-device-grid{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.rns-home-service-card,
.rns-home-brand-card,
.rns-home-benefit-card{
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:28px;
  color:#101828;
  background:#fff;
  box-shadow:0 18px 46px rgba(16, 24, 40, .08);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.rns-home-service-card{
  display:flex;
  min-height:100%;
  overflow:hidden;
  flex-direction:column;
  text-decoration:none;
}

.rns-home-service-card:hover,
.rns-home-service-card:focus,
.rns-home-brand-card:hover,
.rns-home-brand-card:focus,
.rns-home-benefit-card:hover{
  color:#101828;
  text-decoration:none;
  transform:translateY(-5px);
  border-color:rgba(13, 110, 253, .28);
  box-shadow:0 28px 64px rgba(16, 24, 40, .14);
}

.rns-home-service-card__media{
  position:relative;
  display:block;
  aspect-ratio:1.18 / 1;
  overflow:hidden;
  background:#eef4ff;
}

.rns-home-service-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .32s ease;
}

.rns-home-service-card:hover img{
  transform:scale(1.05);
}

.rns-home-icon{
  position:absolute;
  right:16px;
  bottom:16px;
  display:grid;
  width:52px;
  height:52px;
  border-radius:18px;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg, #0b63ce, #0d8aff);
  box-shadow:0 16px 32px rgba(11, 99, 206, .24);
}

.rns-home-icon::before{
  content:"";
  width:24px;
  height:24px;
  border:2px solid currentColor;
}

.rns-home-icon--phone::before{border-radius:7px;}
.rns-home-icon--tablet::before{width:28px;height:22px;border-radius:7px;}
.rns-home-icon--computer::before{width:30px;height:20px;border-radius:5px;box-shadow:0 10px 0 -6px currentColor;}
.rns-home-icon--watch::before{width:20px;height:24px;border-radius:10px;box-shadow:0 -10px 0 -7px currentColor, 0 10px 0 -7px currentColor;}

.rns-home-service-card__body{
  display:flex;
  padding:22px;
  flex:1;
  flex-direction:column;
}

.rns-home-service-card strong,
.rns-home-brand-card strong{
  display:block;
  color:#101828;
  font-size:21px;
  font-weight:900;
}

.rns-home-service-card__body > span,
.rns-home-brand-card > span:last-child{
  display:block;
  margin-top:10px;
  color:#667085;
  font-size:14px;
  line-height:1.6;
}

.rns-home-service-card em{
  margin-top:auto;
  padding-top:18px;
  color:#0b63ce;
  font-style:normal;
  font-weight:850;
}

.rns-home-section--brands{
  width:min(1280px, calc(100% - 40px));
  padding:76px 24px;
  border-radius:38px;
  background:linear-gradient(135deg, #f8fbff, #fff);
  border:1px solid rgba(16, 24, 40, .06);
}

.rns-home-brand-grid{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.rns-home-brand-card{
  display:block;
  min-height:178px;
  padding:24px;
  text-decoration:none;
}

.rns-home-brand-card__mark{
  display:grid;
  width:58px;
  height:58px;
  margin-bottom:20px;
  border-radius:20px;
  place-items:center;
  color:#0b63ce;
  background:#eef5ff;
  font-size:18px;
  font-weight:900;
}

.rns-home-status,
.rns-home-claims,
.rns-home-final-cta{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(270px, 360px);
  gap:28px;
  align-items:center;
  padding:42px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:34px;
  background:linear-gradient(135deg, #101828, #163c70);
  box-shadow:0 24px 70px rgba(16, 24, 40, .16);
}

.rns-home-status .rns-eyebrow,
.rns-home-claims .rns-eyebrow,
.rns-home-final-cta .rns-eyebrow{
  color:#9ed0ff;
}

.rns-home-status h2,
.rns-home-status p,
.rns-home-claims h2,
.rns-home-claims p,
.rns-home-final-cta h2,
.rns-home-final-cta p{
  color:#fff;
}

.rns-home-status p,
.rns-home-claims p,
.rns-home-final-cta p{
  opacity:.82;
}

.rns-home-claims{
  background:linear-gradient(135deg, #0b1220, #0b63ce);
}

.rns-home-claims__badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}

.rns-home-claims__badges span{
  padding:9px 12px;
  border:1px solid rgba(255, 255, 255, .22);
  border-radius:999px;
  color:#fff;
  background:rgba(255, 255, 255, .1);
  font-size:13px;
  font-weight:800;
}

.rns-home-claims__actions{
  display:grid;
  gap:12px;
}

.rns-home-benefit-grid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.rns-home-benefit-card{
  padding:26px;
}

.rns-home-benefit-card > span{
  display:block;
  width:42px;
  height:6px;
  margin-bottom:22px;
  border-radius:999px;
  background:linear-gradient(90deg, #0b63ce, #58b8ff);
}

.rns-home-benefit-card h3{
  margin:0;
  color:#101828;
  font-size:20px;
  font-weight:900;
}

.rns-home-benefit-card p{
  margin:10px 0 0;
  color:#667085;
  font-size:15px;
  line-height:1.65;
}

.rns-home-final-cta{
  margin-bottom:72px;
  background:linear-gradient(135deg, #f7fbff, #ffffff);
}

.rns-home-final-cta .rns-eyebrow{
  color:#0b63ce;
}

.rns-home-final-cta h2{
  color:#101828;
}

.rns-home-final-cta p{
  color:#667085;
}

.rns-animate{
  animation:rnsFadeUp .7s ease both;
}

@keyframes rnsFadeUp{
  from{opacity:0;transform:translateY(18px);}
  to{opacity:1;transform:translateY(0);}
}

@media (prefers-reduced-motion: reduce){
  .rns-animate,
  .rns-home-service-card,
  .rns-home-brand-card,
  .rns-home-benefit-card,
  .rns-home-btn,
  .rns-home-service-card__media img{
    animation:none;
    transition:none;
  }
}

@media (max-width:1199.98px){
  .rns-home-hero__inner{
    grid-template-columns:1fr;
  }

  .rns-home-hero__visual{
    max-width:760px;
    width:100%;
    margin:0 auto;
  }

  .rns-home-device-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:991.98px){
  .rns-home-hero__actions,
  .rns-home-hero__proof,
  .rns-home-brand-grid,
  .rns-home-benefit-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .rns-home-status,
  .rns-home-claims,
  .rns-home-final-cta{
    grid-template-columns:1fr;
  }
}

@media (max-width:767.98px){
  .rns-home-hero{
    padding:58px 16px 46px;
  }

  .rns-home-hero h1{
    font-size:clamp(40px, 12vw, 58px);
  }

  .rns-home-hero__lead{
    font-size:17px;
  }

  .rns-home-hero__actions,
  .rns-home-hero__proof,
  .rns-home-device-grid,
  .rns-home-brand-grid,
  .rns-home-benefit-grid{
    grid-template-columns:1fr;
  }

  .rns-home-hero__visual{
    min-height:420px;
    border-radius:28px;
  }

  .rns-home-device--phone{
    top:26px;
    left:22px;
    width:48%;
    height:58%;
  }

  .rns-home-device--watch{
    top:38px;
    right:20px;
    width:30%;
    height:23%;
  }

  .rns-home-device--laptop{
    right:18px;
    bottom:74px;
    width:72%;
    height:34%;
  }

  .rns-home-trust-card{
    left:16px;
    right:16px;
    bottom:16px;
  }

  .rns-home-metric-card{
    display:none;
  }

  .rns-home-section,
  .rns-home-section--brands{
    width:min(100% - 28px, 1220px);
    padding-top:54px;
    padding-bottom:54px;
  }

  .rns-home-section--brands,
  .rns-home-status,
  .rns-home-claims,
  .rns-home-final-cta{
    border-radius:28px;
  }

  .rns-home-status,
  .rns-home-claims,
  .rns-home-final-cta{
    padding:28px;
  }

  .rns-home-btn{
    min-height:58px;
  }
}

/* repairNstore store locator */
.rns-locator-page{
  overflow:hidden;
  color:#101828;
  background:#fff;
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.rns-locator-eyebrow{
  margin:0 0 14px;
  color:#0b63ce;
  font-size:13px;
  font-weight:850;
  letter-spacing:0;
  text-transform:uppercase;
}

.rns-locator-hero,
.rns-locator-map-section,
.rns-location-list{
  width:min(1220px, calc(100% - 40px));
  margin:0 auto;
}

.rns-locator-hero{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 420px);
  gap:34px;
  align-items:center;
  padding:86px 0 44px;
}

.rns-locator-hero h1{
  max-width:840px;
  margin:0;
  color:#0b1220;
  font-size:clamp(42px, 5vw, 76px);
  line-height:.98;
  font-weight:900;
  letter-spacing:0;
}

.rns-locator-hero p{
  max-width:760px;
  margin:22px 0 0;
  color:#667085;
  font-size:19px;
  line-height:1.7;
}

.rns-locator-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}

.rns-locator-btn{
  display:inline-flex;
  min-height:52px;
  padding:12px 18px;
  border:1px solid rgba(16, 24, 40, .1);
  border-radius:16px;
  align-items:center;
  justify-content:center;
  color:#101828;
  background:#fff;
  box-shadow:0 14px 30px rgba(16, 24, 40, .08);
  font-size:14px;
  font-weight:850;
  line-height:1.2;
  text-align:center;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.rns-locator-btn:hover,
.rns-locator-btn:focus{
  color:#101828;
  text-decoration:none;
  transform:translateY(-2px);
  box-shadow:0 20px 46px rgba(16, 24, 40, .13);
}

.rns-locator-btn--primary{
  border-color:#0b63ce;
  color:#fff;
  background:linear-gradient(135deg, #0b63ce, #0d8aff);
}

.rns-locator-btn--primary:hover,
.rns-locator-btn--primary:focus{
  color:#fff;
}

.rns-locator-btn--light{
  color:#0b1220;
  background:#fff;
}

.rns-locator-hero__panel{
  display:grid;
  gap:14px;
  padding:22px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:30px;
  background:linear-gradient(135deg, #f7fbff, #fff);
  box-shadow:0 24px 70px rgba(16, 24, 40, .12);
}

.rns-locator-hero__panel div{
  padding:18px;
  border:1px solid rgba(13, 110, 253, .12);
  border-radius:20px;
  background:#fff;
}

.rns-locator-hero__panel strong{
  display:block;
  color:#101828;
  font-size:28px;
  font-weight:900;
}

.rns-locator-hero__panel span{
  display:block;
  margin-top:4px;
  color:#667085;
  font-size:14px;
  font-weight:700;
}

.rns-locator-map-section{
  padding:26px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:36px;
  background:linear-gradient(135deg, #f8fbff, #fff);
  box-shadow:0 24px 70px rgba(16, 24, 40, .1);
}

.rns-locator-shell{
  display:grid;
  grid-template-columns:minmax(320px, 420px) minmax(0, 1fr);
  gap:22px;
  align-items:stretch;
}

.rns-locator-search{
  display:flex;
  min-height:620px;
  padding:26px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:28px;
  flex-direction:column;
  background:#fff;
}

.rns-locator-search h1,
.rns-locator-search h2{
  margin:0;
  color:#101828;
  font-size:30px;
  line-height:1.12;
  font-weight:900;
}

.rns-locator-search p{
  margin:14px 0 0;
  color:#667085;
  font-size:15px;
  line-height:1.65;
}

.rns-locator-searchbox{
  display:flex;
  min-height:58px;
  margin-top:22px;
  padding:6px 8px 6px 16px;
  border:1px solid rgba(16, 24, 40, .12);
  border-radius:18px;
  align-items:center;
  gap:12px;
  background:#f9fafb;
}

.rns-locator-searchbox span{
  position:relative;
  display:block;
  width:18px;
  height:18px;
  border:2px solid #0b63ce;
  border-radius:999px;
}

.rns-locator-searchbox span::after{
  content:"";
  position:absolute;
  right:-6px;
  bottom:-4px;
  width:8px;
  height:2px;
  border-radius:999px;
  background:#0b63ce;
  transform:rotate(45deg);
}

.rns-locator-searchbox input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  color:#101828;
  background:transparent;
  font-size:16px;
  font-weight:700;
}

.rns-locator-search__actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}

.rns-locator-status{
  min-height:22px;
  margin-top:16px;
  color:#667085;
  font-size:13px;
  font-weight:750;
}

.rns-locator-results{
  display:grid;
  max-height:330px;
  margin-top:8px;
  overflow:auto;
  gap:10px;
  padding-right:4px;
}

.rns-locator-result{
  display:block;
  padding:14px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:16px;
  color:#101828;
  background:#fff;
  text-decoration:none;
  transition:border-color .2s ease, background .2s ease, transform .2s ease;
}

.rns-locator-result:hover,
.rns-locator-result:focus{
  color:#101828;
  border-color:rgba(13, 110, 253, .26);
  background:#f7fbff;
  text-decoration:none;
  transform:translateY(-1px);
}

.rns-locator-result strong,
.rns-locator-result span{
  display:block;
}

.rns-locator-result strong{
  font-size:14px;
  font-weight:900;
}

.rns-locator-result span{
  margin-top:5px;
  color:#667085;
  font-size:13px;
  line-height:1.45;
}

.rns-locator-map-card{
  min-height:620px;
  overflow:hidden;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:28px;
  background:#eef4ff;
}

.rns-locator-map{
  width:100%;
  height:100%;
  min-height:620px;
}

.rns-locator-seo{
  width:min(1220px, calc(100% - 40px));
  margin:28px auto 0;
  padding:34px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:34px;
  background:linear-gradient(135deg, #ffffff, #f7fbff);
  box-shadow:0 18px 52px rgba(16, 24, 40, .08);
}

.rns-locator-seo__intro{
  max-width:860px;
}

.rns-locator-seo__intro h2{
  margin:0;
  color:#101828;
  font-size:clamp(30px, 3.4vw, 48px);
  line-height:1.08;
  font-weight:900;
  letter-spacing:0;
}

.rns-locator-seo__intro p{
  margin:16px 0 0;
  color:#475467;
  font-size:17px;
  line-height:1.75;
}

.rns-locator-seo__grid{
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(0, 1.1fr);
  gap:18px;
  margin-top:26px;
}

.rns-locator-seo-card{
  padding:24px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:24px;
  background:#fff;
}

.rns-locator-seo-card h3{
  margin:0 0 14px;
  color:#101828;
  font-size:21px;
  font-weight:900;
}

.rns-locator-seo-card p{
  margin:0;
  color:#667085;
  font-size:15px;
  line-height:1.65;
}

.rns-locator-seo-card ul{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0;
  margin:0;
  list-style:none;
}

.rns-locator-seo-card li,
.rns-locator-seo__cities span{
  display:inline-flex;
  min-height:34px;
  align-items:center;
  border:1px solid #dbeafe;
  border-radius:999px;
  background:#eff6ff;
  padding:7px 11px;
  color:#0b63ce;
  font-size:13px;
  font-weight:850;
}

.rns-locator-seo__locations{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin-top:18px;
}

.rns-locator-seo__locations a{
  display:block;
  padding:12px 14px;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:16px;
  color:#101828;
  background:#f9fafb;
  font-size:14px;
  font-weight:850;
  text-decoration:none;
}

.rns-locator-seo__locations a:hover,
.rns-locator-seo__locations a:focus{
  border-color:#bfdbfe;
  color:#0b63ce;
  background:#fff;
  text-decoration:none;
}

.rns-locator-seo__cities{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}

.rns-location-list{
  padding:76px 0 88px;
}

.rns-location-list__head{
  display:flex;
  gap:20px;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:28px;
}

.rns-location-list__head h2{
  margin:0;
  color:#101828;
  font-size:clamp(32px, 4vw, 54px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:0;
}

.rns-location-list__head p{
  margin:12px 0 0;
  color:#667085;
  font-size:16px;
  font-weight:750;
}

.rns-locator-print{
  display:inline-flex;
  min-height:48px;
  padding:12px 16px;
  border:1px solid rgba(16, 24, 40, .1);
  border-radius:16px;
  align-items:center;
  gap:8px;
  color:#101828;
  background:#fff;
  box-shadow:0 14px 30px rgba(16, 24, 40, .08);
  font-weight:850;
  text-decoration:none;
}

.rns-locator-print:hover,
.rns-locator-print:focus{
  color:#101828;
  text-decoration:none;
}

.rns-location-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}

.rns-location-card{
  display:flex;
  min-height:100%;
  overflow:hidden;
  border:1px solid rgba(16, 24, 40, .08);
  border-radius:28px;
  flex-direction:column;
  background:#fff;
  box-shadow:0 18px 46px rgba(16, 24, 40, .08);
}

.rns-location-card__media{
  position:relative;
  aspect-ratio:1.45 / 1;
  overflow:hidden;
  background:#eef4ff;
}

.rns-location-card__media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.rns-location-card__media span{
  position:absolute;
  left:16px;
  bottom:16px;
  padding:8px 12px;
  border-radius:999px;
  color:#fff;
  background:rgba(11, 18, 32, .76);
  font-size:13px;
  font-weight:850;
  backdrop-filter:blur(12px);
}

.rns-location-card__body{
  display:flex;
  padding:24px;
  flex:1;
  flex-direction:column;
}

.rns-location-card__title h3{
  margin:0;
  color:#101828;
  font-size:22px;
  font-weight:900;
}

.rns-location-card__title p{
  margin:8px 0 0;
  color:#667085;
  font-size:14px;
  line-height:1.55;
}

.rns-location-address{
  margin:18px 0 0;
  color:#475467;
  font-style:normal;
  line-height:1.55;
}

.rns-location-address strong,
.rns-location-address span{
  display:block;
}

.rns-location-contact{
  display:grid;
  gap:8px;
  margin-top:18px;
}

.rns-location-contact a{
  display:flex;
  min-width:0;
  align-items:center;
  gap:9px;
  color:#0b63ce;
  font-size:14px;
  font-weight:800;
  text-decoration:none;
  overflow-wrap:anywhere;
}

.rns-location-contact span{
  display:grid;
  width:26px;
  height:26px;
  border-radius:9px;
  flex:0 0 26px;
  place-items:center;
  color:#fff;
  background:#0b63ce;
  font-size:12px;
  font-weight:900;
}

.rns-location-hours{
  margin-top:22px;
  padding:16px;
  border-radius:18px;
  background:#f9fafb;
}

.rns-location-hours h4{
  margin:0 0 12px;
  color:#101828;
  font-size:15px;
  font-weight:900;
}

.rns-location-hours ul{
  display:grid;
  gap:7px;
  padding:0;
  margin:0;
  list-style:none;
}

.rns-location-hours li{
  display:flex;
  gap:10px;
  justify-content:space-between;
  color:#475467;
  font-size:13px;
  line-height:1.45;
}

.rns-location-hours li.is-closed{
  color:#98a2b3;
}

.rns-location-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:auto;
  padding-top:22px;
}

@media (max-width:1099.98px){
  .rns-locator-hero,
  .rns-locator-shell{
    grid-template-columns:1fr;
  }

  .rns-locator-search,
  .rns-locator-map-card,
  .rns-locator-map{
    min-height:460px;
  }

  .rns-location-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .rns-locator-seo__grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:767.98px){
  .rns-locator-hero,
  .rns-locator-map-section,
  .rns-locator-seo,
  .rns-location-list{
    width:min(100% - 28px, 1220px);
  }

  .rns-locator-hero{
    padding:54px 0 30px;
  }

  .rns-locator-hero h1{
    font-size:clamp(38px, 11vw, 56px);
  }

  .rns-locator-hero p{
    font-size:17px;
  }

  .rns-locator-map-section{
    padding:14px;
    border-radius:28px;
  }

  .rns-locator-seo{
    padding:22px;
    border-radius:28px;
  }

  .rns-locator-seo__locations{
    grid-template-columns:1fr;
  }

  .rns-locator-search,
  .rns-locator-map-card{
    border-radius:22px;
  }

  .rns-locator-search{
    min-height:auto;
    padding:20px;
  }

  .rns-locator-search__actions,
  .rns-location-actions,
  .rns-location-grid{
    grid-template-columns:1fr;
  }

  .rns-locator-map-card,
  .rns-locator-map{
    min-height:380px;
  }

  .rns-location-list__head{
    align-items:flex-start;
    flex-direction:column;
  }

  .rns-location-list{
    padding:54px 0 64px;
  }
}