:root{
  --color-bg-light:#f4f4f5;
  --color-bg-dark:#020617;
  --color-surface-light:#ffffff;
  --color-surface-dark:#0b1224;
  --color-primary:#2563eb;
  --color-primary-soft:#dbeafe;
  --color-accent:#a3e635;

  --color-text:#111827;
  --color-text-soft:#4b5563;

  --color-text-dark:#e5e7eb;
  --color-text-soft-dark:#9ca3af;

  --color-border:#e5e7eb;
  --shadow-soft:0 10px 30px rgba(15,23,42,0.15);

  --transition-fast:150ms ease-out;
  --radius-lg:18px;
  --radius-full:999px;

  --font-body:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-heading:"Poppins",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --base-font-size:16px;
}

html{
  font-size:var(--base-font-size);
  scroll-behavior:smooth;
}

html.large-text{
  font-size:18px;
}

html[data-theme="light"]{
  color-scheme:light;
}

html[data-theme="dark"]{
  color-scheme:dark;
}

html.high-contrast[data-theme="light"]{
  --color-bg-light:#ffffff;
  --color-surface-light:#ffffff;
  --color-text:#000000;
  --color-text-soft:#0b0b0b;
  --color-border:#000000;
}

html.high-contrast[data-theme="dark"]{
  --color-bg-dark:#000000;
  --color-surface-dark:#000000;
  --color-text-dark:#ffffff;
  --color-text-soft-dark:#e5e5e5;
  --color-border:#ffffff;
}

*{
  box-sizing:border-box;
}

body{
  margin:0;
  font-family:var(--font-body);
  background:var(--color-bg-light);
  color:var(--color-text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

html[data-theme="dark"] body{
  background:radial-gradient(circle at top,#020617 0,#020617 45%,#020617 100%);
  color:var(--color-text-dark);
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:2px solid var(--color-accent);
  outline-offset:2px;
}

h1,h2,h3,h4{
  font-family:var(--font-heading);
  margin:0;
  letter-spacing:-.03em;
}

h1{
  font-size:2rem;
  line-height:1.1;
  margin-bottom:.75rem;
}

h2{
  font-size:1.7rem;
}

h3{
  font-size:1.25rem;
}

@media (min-width:768px){
  h1{font-size:2.6rem;}
  h2{font-size:2rem;}
}

p{
  margin:0;
  color:var(--color-text-soft);
}

html[data-theme="dark"] p{
  color:var(--color-text-soft-dark);
}

.container{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:0 1.25rem;
}

.section{
  padding:4rem 0;
}

@media (min-width:768px){
  .section{
    padding:5rem 0;
  }
}

.section-header{
  max-width:760px;
  margin:0 auto 2.5rem;
  text-align:center;
}

.section-label,
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.15rem .85rem;
  border-radius:var(--radius-full);
  font-size:.75rem;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.section-label{
  background:var(--color-primary-soft);
  color:#1d4ed8;
}

html[data-theme="dark"] .section-label{
  background:rgba(37,99,235,.18);
  color:#bfdbfe;
}

.btn-row{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.btn-row-center{
  justify-content:center;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  padding:.7rem 1.35rem;
  border-radius:var(--radius-full);
  border:1px solid transparent;
  font-size:.9rem;
  font-weight:500;
  cursor:pointer;
  background:#111827;
  color:#f9fafb;
  transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);
  white-space:nowrap;
  min-height:44px;
}

@media (max-width:560px){
  .btn{
    width:100%;
  }

  .btn-row > .btn,
  .btn-row > a.btn,
  .btn-row > button.btn{
    width:100%;
  }
}

.btn-primary{
  background:linear-gradient(135deg,#2563eb,#1d4ed8);
  box-shadow:0 10px 20px rgba(37,99,235,.4);
}

.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(37,99,235,.45);
}

.btn-secondary{
  background:transparent;
  color:var(--color-text);
  border-color:var(--color-border);
}

html[data-theme="dark"] .btn-secondary{
  color:var(--color-text-dark);
  border-color:rgba(148,163,184,.6);
  background:rgba(15,23,42,.8);
}

.btn-secondary:hover{
  background:rgba(15,23,42,.03);
}

html[data-theme="dark"] .btn-secondary:hover{
  background:rgba(15,23,42,.9);
}

.btn-small{
  padding:.55rem 1rem;
  font-size:.85rem;
}

.lang-switcher{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.25rem .55rem;
  border-radius:999px;
  border:1px solid rgba(148,163,184,0.65);
  background:rgba(255,255,255,0.6);
}

html[data-theme="dark"] .lang-switcher{
  background:rgba(15,23,42,0.9);
  border-color:rgba(75,85,99,0.9);
}

.lang-pill{
  padding:.2rem .5rem;
  border-radius:999px;
  font-size:.75rem;
  opacity:.85;
}

.lang-pill.active{
  opacity:1;
  background:rgba(37,99,235,0.18);
}

.lang-pill.disabled{
  opacity:.45;
  cursor:not-allowed;
  user-select:none;
}

.top-bar{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter:blur(16px);
  background:rgba(244,244,245,.92);
  border-bottom:1px solid rgba(148,163,184,.25);
}

html[data-theme="dark"] .top-bar{
  background:rgba(2,6,23,.9);
  border-bottom-color:rgba(30,64,175,.4);
}

.top-bar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.7rem 1.25rem;
  max-width:1120px;
  margin:0 auto;
}

.logo-wrap{
  display:flex;
  align-items:center;
  gap:.6rem;
  min-width:0;
}

.logo-icon{
  width:34px;
  height:34px;
  border-radius:1rem;
  background:radial-gradient(circle at 20% 0%,#a3e635 0,#22c55e 26%,#2563eb 90%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-weight:700;
  font-size:1.05rem;
  box-shadow:0 8px 20px rgba(15,23,42,.35);
  flex:0 0 auto;
}

.logo-copy{
  min-width:0;
}

.logo-text-main{
  font-family:var(--font-heading);
  font-weight:600;
  font-size:1.05rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.logo-text-sub{
  font-size:.75rem;
  color:var(--color-text-soft);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

html[data-theme="dark"] .logo-text-sub{
  color:var(--color-text-soft-dark);
}

.nav-right{
  display:flex;
  align-items:center;
  gap:.75rem;
}

.main-nav{
  display:none;
  gap:.4rem;
  align-items:center;
}

.main-nav a{
  padding:.4rem .6rem;
  border-radius:10px;
  font-size:.9rem;
  color:var(--color-text);
  transition:background .2s ease;
}

.main-nav a.is-active{
  background:rgba(37,99,235,0.12);
}

html[data-theme="dark"] .main-nav a{
  color:var(--color-text-dark);
}

.main-nav a:hover{
  background:rgba(37,99,235,.1);
}

html[data-theme="dark"] .main-nav a:hover{
  background:rgba(255,255,255,.08);
}

.menu-btn{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.35rem .65rem;
  border-radius:var(--radius-full);
  border:1px solid rgba(148,163,184,.65);
  background:rgba(255,255,255,.7);
  cursor:pointer;
  font-size:.8rem;
  min-height:44px;
}

html[data-theme="dark"] .menu-btn{
  background:rgba(15,23,42,.9);
  color:var(--color-text-dark);
  border-color:rgba(75,85,99,.9);
}

.header-controls{
  display:flex;
  align-items:center;
  gap:.35rem;
}

.icon-btn{
  border-radius:999px;
  border:1px solid rgba(148,163,184,.65);
  background:rgba(255,255,255,.7);
  padding:.25rem .6rem;
  font-size:.75rem;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  white-space:nowrap;
  min-height:44px;
}

html[data-theme="dark"] .icon-btn{
  background:rgba(15,23,42,.9);
  color:var(--color-text-dark);
  border-color:rgba(75,85,99,.9);
}

.mobile-nav{
  border-top:1px solid rgba(148,163,184,.25);
  background:rgba(244,244,245,.96);
}

html[data-theme="dark"] .mobile-nav{
  background:rgba(2,6,23,.96);
  border-top-color:rgba(30,64,175,.35);
}

.mobile-nav[hidden]{
  display:none !important;
}

.mobile-nav-inner{
  max-width:1120px;
  margin:0 auto;
  padding:.75rem 1.25rem 1rem;
  display:grid;
  gap:.5rem;
}

.mobile-nav a{
  padding:.7rem .85rem;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.7);
  font-size:.95rem;
  min-height:44px;
}

html[data-theme="dark"] .mobile-nav a{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.65);
}

@media (min-width:900px){
  .main-nav{display:flex;}
  .menu-btn{display:none;}
  .mobile-nav{display:none !important;}
}

@media (max-width:899px){
  .lang-switcher{
    display:none;
  }

  .header-controls{
    gap:.25rem;
  }

  .icon-btn span:last-child{
    display:none;
  }

  .icon-btn{
    padding:.25rem .5rem;
    min-width:44px;
    justify-content:center;
  }
}

@media (max-width:560px){
  .top-bar-inner{
    gap:.75rem;
    padding:.65rem 1rem;
  }

  .logo-text-main{
    font-size:.95rem;
  }

  .logo-text-sub{
    font-size:.7rem;
  }

  .nav-right{
    gap:.5rem;
  }
}

.hero{
  padding-top:1.5rem;
  padding-bottom:3.5rem;
}

@media (min-width:768px){
  .hero{
    padding-top:2.5rem;
    padding-bottom:4.5rem;
  }
}

.hero-inner{
  display:grid;
  gap:2rem;
}

@media (min-width:768px){
  .hero-inner{
    grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
    align-items:center;
    gap:3rem;
  }
}

.hero-kicker{
  background:var(--color-primary-soft);
  color:#1d4ed8;
  margin-bottom:1rem;
}

html[data-theme="dark"] .hero-kicker{
  background:rgba(15,23,42,.9);
  border:1px solid rgba(37,99,235,.4);
  color:#bfdbfe;
}

.hero-highlight{
  background:linear-gradient(90deg,#22c55e,#a3e635,#22c55e);
  background-clip:text;
  -webkit-background-clip:text;
  color:transparent;
}

.hero-subtitle{
  margin-bottom:1.4rem;
  max-width:34rem;
}

.hero-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  margin-top:1.4rem;
}

.hero-meta-item{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-size:.85rem;
  padding:.4rem .75rem;
  border-radius:var(--radius-full);
  background:rgba(15,23,42,.035);
  color:var(--color-text-soft);
}

html[data-theme="dark"] .hero-meta-item{
  background:rgba(15,23,42,.9);
  color:var(--color-text-soft-dark);
  border:1px solid rgba(31,41,55,.9);
}

.hero-badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  margin-top:1.75rem;
  align-items:center;
}

.hero-rating{
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.9rem;
}

.hero-rating-stars{
  color:#facc15;
  font-size:1.05rem;
}

.hero-rating-text strong{
  font-weight:600;
}

.hero-warranty-note{
  font-size:.8rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .hero-warranty-note{
  color:var(--color-text-soft-dark);
}

.hero-card{
  position:relative;
  background:var(--color-surface-light);
  border-radius:1.4rem;
  box-shadow:var(--shadow-soft);
  padding:1.25rem 1.2rem;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.35);
}

html[data-theme="dark"] .hero-card{
  background:radial-gradient(circle at 0% 0%,rgba(59,130,246,.14),rgba(15,23,42,1));
  border-color:rgba(37,99,235,.45);
  box-shadow:0 18px 40px rgba(15,23,42,.95);
}

.hero-card-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  margin-bottom:1.1rem;
}

.hero-card-title{
  font-size:.95rem;
  font-weight:600;
}

.hero-card-intro{
  font-size:.78rem;
}

.hero-chip{
  padding:.25rem .7rem;
  border-radius:var(--radius-full);
  background:rgba(22,163,74,.1);
  color:#166534;
  font-size:.75rem;
  font-weight:500;
  white-space:nowrap;
}

html[data-theme="dark"] .hero-chip{
  background:rgba(22,163,74,.35);
  color:#bbf7d0;
}

.hero-card-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.8rem;
  margin-bottom:1rem;
  font-size:.78rem;
}

.hero-info-block{
  min-width:0;
}

.hero-info-label{
  font-size:.75rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .hero-info-label{
  color:var(--color-text-soft-dark);
}

.hero-info-title{
  font-weight:600;
  margin-top:.25rem;
}

.hero-info-text{
  font-size:.78rem;
  color:var(--color-text-soft);
  margin-top:.25rem;
}

html[data-theme="dark"] .hero-info-text{
  color:var(--color-text-soft-dark);
}

.hero-card-note{
  font-size:.78rem;
  color:var(--color-text-soft);
  margin-bottom:.4rem;
}

html[data-theme="dark"] .hero-card-note{
  color:var(--color-text-soft-dark);
}

@media (max-width:560px){
  .hero{
    padding-top:1rem;
    padding-bottom:3rem;
  }

  .hero-inner{
    gap:1.5rem;
  }

  .hero-card{
    padding:1rem;
    border-radius:1.1rem;
  }

  .hero-card-header{
    flex-direction:column;
    align-items:flex-start;
  }

  .hero-card-grid{
    grid-template-columns:1fr;
  }

  .hero-meta-item{
    width:100%;
    border-radius:14px;
  }

  .hero-badge-row{
    align-items:flex-start;
    flex-direction:column;
  }
}

.grid{
  display:grid;
  gap:1.25rem;
}

@media (min-width:640px){
  .grid-2{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (min-width:900px){
  .grid-3{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

.card{
  background:var(--color-surface-light);
  border-radius:var(--radius-lg);
  padding:1.15rem 1.1rem;
  border:1px solid var(--color-border);
  box-shadow:0 10px 24px rgba(15,23,42,.05);
  transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast);
}

html[data-theme="dark"] .card{
  background:rgba(15,23,42,.95);
  border-color:rgba(31,41,55,.95);
  box-shadow:0 18px 40px rgba(15,23,42,.9);
}

.card:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(15,23,42,.09);
  border-color:rgba(148,163,184,.9);
}

html[data-theme="dark"] .card:hover{
  box-shadow:0 20px 50px rgba(15,23,42,1);
}

.card-title{
  font-size:1rem;
  margin-bottom:.3rem;
}

.card-body{
  font-size:.9rem;
  margin-bottom:.6rem;
}

.card-meta{
  font-size:.78rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .card-meta{
  color:var(--color-text-soft-dark);
}

.card-tag{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-size:.75rem;
  margin-bottom:.4rem;
  color:#16a34a;
}

html[data-theme="dark"] .card-tag{
  color:#bbf7d0;
}

.table-scroll{
  overflow-x:auto;
}

.repairs-table{
  width:100%;
  border-collapse:collapse;
  font-size:.9rem;
  overflow:hidden;
  border-radius:1rem;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
  min-width:720px;
}

.repairs-table thead{
  background:#eff6ff;
}

html[data-theme="dark"] .repairs-table thead{
  background:rgba(15,23,42,.9);
}

.repairs-table th,
.repairs-table td{
  padding:.8rem .85rem;
  text-align:left;
  border-bottom:1px solid #e5e7eb;
  vertical-align:top;
}

html[data-theme="dark"] .repairs-table th,
html[data-theme="dark"] .repairs-table td{
  border-bottom-color:rgba(31,41,55,.9);
}

.repairs-table th{
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:#1d4ed8;
}

html[data-theme="dark"] .repairs-table th{
  color:#bfdbfe;
}

.repairs-table tr:last-child td{
  border-bottom:none;
}

.note{
  margin-top:1rem;
  font-size:.88rem;
  color:var(--color-text-soft);
  text-align:center;
}

html[data-theme="dark"] .note{
  color:var(--color-text-soft-dark);
}

.review-grid{
  display:grid;
  gap:1rem;
}

@media (min-width:768px){
  .review-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

.review-stars{
  color:#eab308;
  font-size:.9rem;
  margin-bottom:.35rem;
}

.review-name{
  font-weight:600;
  margin-top:.55rem;
}

.review-meta{
  font-size:.8rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .review-meta{
  color:var(--color-text-soft-dark);
}

.review-button-row{
  margin-bottom:1.25rem;
}

.brand-strip{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  justify-content:center;
  font-size:.85rem;
}

.brand-pill{
  padding:.35rem .9rem;
  border-radius:999px;
  border:1px dashed rgba(148,163,184,.9);
  background:rgba(255,255,255,.8);
}

html[data-theme="dark"] .brand-pill{
  background:rgba(15,23,42,.95);
  border-style:solid;
}

.contact-layout{
  display:grid;
  gap:1.5rem;
}

@media (min-width:768px){
  .contact-layout{
    grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  }
}

.field-group{
  margin-bottom:.9rem;
}

.field-label{
  display:block;
  font-size:.85rem;
  font-weight:600;
  margin-bottom:.3rem;
}

.field-hint{
  font-size:.75rem;
  color:var(--color-text-soft);
  margin-bottom:.35rem;
}

html[data-theme="dark"] .field-hint{
  color:var(--color-text-soft-dark);
}

.input,
.textarea,
.select{
  width:100%;
  padding:.6rem .7rem;
  border-radius:.75rem;
  border:1px solid rgba(148,163,184,.8);
  background:rgba(255,255,255,.95);
  font-family:inherit;
  font-size:.9rem;
  color:inherit;
  min-height:44px;
}

html[data-theme="dark"] .input,
html[data-theme="dark"] .textarea,
html[data-theme="dark"] .select{
  background:rgba(15,23,42,.95);
  border-color:rgba(55,65,81,.95);
}

.textarea{
  min-height:120px;
  resize:vertical;
}

.map-embed{
  border-radius:1rem;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.6);
  box-shadow:0 10px 24px rgba(15,23,42,.06);
  background:#e5e7eb;
  height:260px;
}

.map-embed iframe{
  border:0;
  width:100%;
  height:100%;
}

.footer{
  border-top:1px solid rgba(148,163,184,.35);
  padding:1.5rem 0;
  font-size:.85rem;
}

html[data-theme="dark"] .footer{
  border-top-color:rgba(31,41,55,.9);
}

.footer-inner{
  display:flex;
  flex-direction:column;
  gap:.75rem;
}

@media (min-width:768px){
  .footer-inner{
    flex-direction:row;
    justify-content:space-between;
    align-items:center;
  }
}

.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  align-items:center;
}

.footer a{
  opacity:.95;
}

.footer a:hover{
  opacity:1;
  text-decoration:underline;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity 400ms ease-out,transform 400ms ease-out;
}

.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

.cookie-banner{
  position:fixed;
  left:1rem;
  right:1rem;
  bottom:1rem;
  z-index:999;
  max-width:1120px;
  margin:0 auto;
  border-radius:1rem;
  border:1px solid rgba(148,163,184,.45);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 18px 50px rgba(15,23,42,.25);
  padding:1rem;
  display:none;
}

html[data-theme="dark"] .cookie-banner{
  background:rgba(2,6,23,.92);
  border-color:rgba(37,99,235,.35);
  box-shadow:0 20px 60px rgba(0,0,0,.55);
}

.cookie-row{
  display:flex;
  flex-direction:column;
  gap:.85rem;
}

@media (min-width:768px){
  .cookie-row{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
  }
}

.cookie-text{
  font-size:.9rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .cookie-text{
  color:var(--color-text-soft-dark);
}

.cookie-learn-more{
  display:inline-block;
  margin-left:.35rem;
}

.cookie-learn-more a{
  text-decoration:underline;
}

.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}

.hidden-field{
  display:none;
}

.form-heading{
  margin-bottom:.75rem;
}

.form-intro{
  margin-bottom:1rem;
}

.contact-inline-note{
  margin-top:.75rem;
  font-size:.85rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .contact-inline-note{
  color:var(--color-text-soft-dark);
}

.shop-details-card{
  margin-bottom:1rem;
}

.shop-details-title{
  margin-bottom:.5rem;
}

.contact-details-list{
  margin-top:.75rem;
  font-size:.95rem;
}

.contact-details-list > div + div{
  margin-top:.2rem;
}

.opening-hours{
  margin-top:.9rem;
  font-size:.95rem;
}

.serving-note{
  margin-top:.8rem;
  font-size:.85rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .serving-note{
  color:var(--color-text-soft-dark);
}

.mt-16{
  margin-top:1rem;
}

.mt-24{
  margin-top:1.5rem;
}

.mt-32{
  margin-top:2rem;
}
.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

.skip-link:focus{
  left:1rem;
  top:1rem;
  width:auto;
  height:auto;
  padding:.6rem .9rem;
  border-radius:999px;
  background:rgba(15,23,42,.95);
  color:#fff;
  z-index:9999;
  border:1px solid rgba(163,230,53,.6);
}

.mobile-call-btn{
  display:none;
}

.nav-group-title{
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--color-text-soft);
  padding:.35rem .25rem .15rem;
}

html[data-theme="dark"] .nav-group-title{
  color:var(--color-text-soft-dark);
}

.mobile-nav-note{
  padding:.55rem .9rem;
  border-radius:14px;
  display:inline-flex;
  border:1px solid rgba(148,163,184,.35);
  background:transparent;
}

.mobile-sticky{
  position:sticky;
  top:0;
  z-index:39;
  display:none;
  border-bottom:1px solid rgba(148,163,184,.25);
  background:rgba(244,244,245,.92);
  backdrop-filter:blur(16px);
}

html[data-theme="dark"] .mobile-sticky{
  background:rgba(2,6,23,.88);
  border-bottom-color:rgba(30,64,175,.25);
}

.mobile-sticky-inner{
  max-width:1120px;
  margin:0 auto;
  padding:.55rem 1.25rem;
  display:flex;
  gap:.6rem;
  justify-content:flex-end;
  align-items:center;
}

.repairs-hero-note{
  margin-top:.9rem;
  font-size:.98rem;
}

.jump-card{
  max-width:980px;
  margin:0 auto;
}

.jump-card-title{
  margin-bottom:.4rem;
}

.jump-card-body{
  margin-bottom:.8rem;
}

.btn-row-start{
  justify-content:flex-start;
}

.inline-link{
  text-decoration:underline;
}

.section-anchor{
  scroll-margin-top:110px;
}

@media (max-width:899px){
  .logo-text-sub{
    display:none;
  }

  .header-controls{
    display:none;
  }

  .lang-switcher{
    display:none;
  }

  .mobile-call-btn{
    display:inline-flex;
  }

  .mobile-sticky{
    display:block;
  }
}
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:.6rem;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.25rem .6rem;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.55);
  background:rgba(255,255,255,.55);
  font-size:.82rem;
}

html[data-theme="dark"] .badge{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.8);
}

.shop-address-note{
  margin-top:.9rem;
  font-size:.9rem;
}

.shop-address-note strong{
  color:inherit;
}

.card-meta-spaced{
  margin-top:.8rem;
}

.shop-setup-card{
  max-width:980px;
  margin:1.5rem auto 0;
}

.shop-repairs-note{
  margin-top:.9rem;
}
.stat-grid{
  display:grid;
  gap:.9rem;
  max-width:980px;
  margin:0 auto 1.5rem;
}

@media (min-width:780px){
  .stat-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

.stat{
  padding:1rem 1rem;
  border-radius:16px;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.6);
}

html[data-theme="dark"] .stat{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.65);
}

.stat strong{
  display:block;
  font-size:1.25rem;
  font-family:var(--font-heading);
  letter-spacing:-.02em;
}

.stat span{
  font-size:.9rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .stat span{
  color:var(--color-text-soft-dark);
}

.about-card-note{
  margin-top:.7rem;
}

.about-promise-card{
  max-width:980px;
  margin:1.5rem auto 0;
}
.call-btn{
  display:none;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.65);
  background:rgba(255,255,255,.7);
  padding:.35rem .7rem;
  font-size:.8rem;
  font-weight:600;
  white-space:nowrap;
  min-height:44px;
}

html[data-theme="dark"] .call-btn{
  background:rgba(15,23,42,.9);
  color:var(--color-text-dark);
  border-color:rgba(75,85,99,.9);
}

@media (min-width:900px){
  .call-btn{
    display:inline-flex;
    align-items:center;
    gap:.35rem;
  }
}

.reviews-help-note{
  margin-top:.9rem;
  font-size:.9rem;
  color:var(--color-text-soft-dark);
}

html[data-theme="light"] .reviews-help-note{
  color:var(--color-text-soft);
}

.ticker{
  border-radius:var(--radius-lg);
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.55);
  overflow:hidden;
  position:relative;
}

html[data-theme="dark"] .ticker{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.65);
}

.ticker::before,
.ticker::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:48px;
  z-index:2;
  pointer-events:none;
}

.ticker::before{
  left:0;
  background:linear-gradient(90deg, rgba(244,244,245,1), rgba(244,244,245,0));
}

.ticker::after{
  right:0;
  background:linear-gradient(270deg, rgba(244,244,245,1), rgba(244,244,245,0));
}

html[data-theme="dark"] .ticker::before{
  background:linear-gradient(90deg, rgba(2,6,23,1), rgba(2,6,23,0));
}

html[data-theme="dark"] .ticker::after{
  background:linear-gradient(270deg, rgba(2,6,23,1), rgba(2,6,23,0));
}

.ticker-track{
  display:flex;
  gap:.9rem;
  padding:1rem 1rem;
  width:max-content;
  animation:tickerMove 38s linear infinite;
}

.ticker:hover .ticker-track,
.ticker:focus-within .ticker-track{
  animation-play-state:paused;
}

@keyframes tickerMove{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

@media (prefers-reduced-motion: reduce){
  .ticker-track{
    animation:none;
  }
}

.review-card{
  width:min(340px, 78vw);
  flex:0 0 auto;
  border-radius:16px;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.7);
  padding:.95rem .95rem;
}

html[data-theme="dark"] .review-card{
  background:rgba(15,23,42,.95);
  border-color:rgba(75,85,99,.65);
}

.stars{
  letter-spacing:.12em;
  font-size:.95rem;
  color:#facc15;
}

.quote{
  margin-top:.55rem;
  font-size:.92rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .quote{
  color:var(--color-text-soft-dark);
}

.meta{
  margin-top:.75rem;
  font-size:.78rem;
  color:var(--color-text-soft);
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  align-items:center;
}

html[data-theme="dark"] .meta{
  color:var(--color-text-soft-dark);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.18rem .55rem;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.55);
  font-size:.72rem;
}

html[data-theme="dark"] .pill{
  background:rgba(2,6,23,.6);
  border-color:rgba(75,85,99,.65);
}
.faq-wrap{
  max-width:980px;
  margin:0 auto;
  display:grid;
  gap:.9rem;
}

.faq-item{
  border-radius:var(--radius-lg);
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.6);
  overflow:hidden;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
  transition:transform var(--transition-fast), border-color var(--transition-fast);
}

html[data-theme="dark"] .faq-item{
  background:rgba(15,23,42,.95);
  border-color:rgba(31,41,55,.95);
  box-shadow:0 18px 40px rgba(15,23,42,.9);
}

.faq-item:hover{
  transform:translateY(-1px);
  border-color:rgba(148,163,184,.85);
}

.faq-item details{
  padding:0;
}

.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1rem 1.05rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  font-family:var(--font-heading);
  font-weight:600;
  letter-spacing:-.01em;
  user-select:none;
}

.faq-item summary::-webkit-details-marker{
  display:none;
}

.faq-q{
  font-size:1rem;
}

.faq-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.55);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
  flex:0 0 auto;
  background:rgba(255,255,255,.6);
  transition:transform 150ms ease-out;
}

html[data-theme="dark"] .faq-icon{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.75);
}

.faq-item details[open] .faq-icon{
  transform:rotate(45deg);
}

.faq-a{
  padding:0 1.05rem 1rem;
  color:var(--color-text-soft);
  font-size:.95rem;
}

html[data-theme="dark"] .faq-a{
  color:var(--color-text-soft-dark);
}

.faq-a p{
  margin-top:.65rem;
}

.faq-a ul{
  margin:.65rem 0 0;
  padding-left:1.1rem;
}

.faq-a li{
  margin:.25rem 0;
}

.mini-callout{
  max-width:980px;
  margin:1.25rem auto 0;
  border-radius:var(--radius-lg);
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.55);
  padding:1.15rem 1.1rem;
}

html[data-theme="dark"] .mini-callout{
  background:rgba(15,23,42,.9);
  border-color:rgba(75,85,99,.65);
}

.mini-callout-title{
  font-family:var(--font-heading);
  margin:0 0 .4rem;
  font-size:1.35rem;
}
.contact-help-note{
  text-align:center;
  margin-top:.8rem;
}

.contact-form-title{
  margin-bottom:.4rem;
}

.contact-form-intro{
  margin-bottom:1rem;
}

.contact-form-note{
  margin-top:.75rem;
}

.contact-details-card{
  margin-bottom:1rem;
}

.contact-details-title{
  margin-bottom:.5rem;
}

.contact-address-line{
  opacity:.9;
}

.contact-info-list{
  margin-top:.9rem;
  font-size:.95rem;
}

.contact-info-list > div + div{
  margin-top:.3rem;
}

.opening-hours-block{
  margin-top:1rem;
  font-size:.95rem;
}

.contact-map-note{
  margin-top:.8rem;
}

.contact-quote-card{
  max-width:900px;
  margin:1.5rem auto 0;
}
.privacy-last-updated{
  margin-top:.8rem;
  font-size:.9rem;
}

.privacy-layout{
  display:grid;
  gap:1.25rem;
}

@media (min-width:900px){
  .privacy-layout{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

.privacy-card{
  height:100%;
}

.privacy-list{
  margin:.2rem 0 0;
  padding-left:1.1rem;
  color:var(--color-text-soft);
}

html[data-theme="dark"] .privacy-list{
  color:var(--color-text-soft-dark);
}

.privacy-list li{
  margin:.3rem 0;
}

.privacy-footer-card{
  max-width:980px;
  margin:1.5rem auto 0;
}