/* ========== FONTS (lokal, kein Google Fonts CDN) ========== */
@font-face{
  font-family:'Inter';font-style:normal;font-display:swap;
  font-weight:400 800;
  src:url('/assets/fonts/inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';font-style:normal;font-display:swap;
  font-weight:400 800;
  src:url('/assets/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* ========== BASE ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f4f5f7;
  --bg-2:#ffffff;
  --bg-3:#eceef2;
  --line:rgba(15,20,30,.09);
  --line-2:rgba(15,20,30,.18);
  --text:#0a0a0c;
  --muted:#4d5159;
  --dim:#85898f;
  --brand:#c8102e;
  --brand-2:#a00d24;
  --brand-soft:rgba(200,16,46,.08);
  --accent:#1f2a44;
  --green:#1f8a32;
  --radius:10px;
  --radius-s:6px;
  --max:1200px;
  --pad:clamp(20px,4vw,48px);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
a{color:inherit;text-decoration:none;transition:color .2s}
a:hover{color:var(--brand)}
img,svg{display:block;max-width:100%}
em{font-style:normal;color:var(--brand);font-weight:700}
strong{font-weight:600;color:var(--text)}

/* ========== AURORA BACKGROUND ========== */
.aurora{display:none}

/* ========== NAV ========== */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
  padding:16px var(--pad);
  background:rgba(244,245,247,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav__logo{
  display:flex;align-items:center;gap:10px;
  line-height:0;
}
.nav__logo img{
  height:36px;width:auto;
  transition:opacity .2s;
}
.nav__logo:hover img{opacity:.8}
@media (max-width:560px){
  .nav__logo img{height:28px}
}
.nav__links{display:flex;gap:32px;font-size:14.5px}
.nav__links a,
.nav__links a:link,
.nav__links a:visited{position:relative;color:var(--muted);outline:none}
.nav__links a:hover,
.nav__links a:focus,
.nav__links a:focus-visible,
.nav__links a:active,
.nav__links a.is-active{color:var(--text);background:transparent}
.nav__links a.is-active::after{transform:scaleX(1);transform-origin:left}
.nav__links a:focus-visible{box-shadow:0 0 0 2px var(--brand-soft);border-radius:4px}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;
  height:2px;background:var(--brand);transform:scaleX(0);
  transform-origin:right;transition:transform .3s;
}
.nav__links a:hover::after,
.nav__links a:focus::after{transform:scaleX(1);transform-origin:left}
.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:8px;
  background:#fff;
  border:1px solid var(--line-2);
  font-size:14px;font-weight:600;color:var(--text);
  transition:transform .2s, border-color .2s, box-shadow .2s;
  box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.nav__cta:hover{transform:translateY(-1px);border-color:var(--brand);color:var(--brand);box-shadow:0 6px 16px rgba(200,16,46,.12)}
.pulse{
  width:8px;height:8px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(31,138,50,.5);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(31,138,50,.5)}
  70%{box-shadow:0 0 0 8px rgba(31,138,50,0)}
  100%{box-shadow:0 0 0 0 rgba(31,138,50,0)}
}
@media (max-width:780px){
  .nav__links{display:none}
}

/* ========== HERO ========== */
.hero{position:relative;padding:clamp(60px,9vw,120px) var(--pad) 0}
.hero__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;border:1px solid var(--line-2);border-radius:6px;
  font-size:13px;color:var(--muted);
  background:#fff;
  font-weight:500;
}
.dot{width:6px;height:6px;border-radius:50%;background:var(--dim)}
.dot--open{background:var(--green);box-shadow:0 0 8px rgba(31,138,50,.5)}
.dot--closed{background:var(--dim)}
.hero__title{
  font-weight:700;
  font-size:clamp(38px,5.4vw,68px);
  line-height:1.06;letter-spacing:-.03em;
  margin:24px 0 24px;
  color:var(--text);
}
.hero__lead{
  font-size:clamp(16px,1.4vw,19px);color:var(--muted);
  max-width:520px;
}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin:36px 0 48px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:8px;
  font-size:15px;font-weight:600;letter-spacing:-.005em;
  transition:transform .2s, box-shadow .2s, background .2s, color .2s;
  white-space:nowrap;cursor:pointer;border:1px solid transparent;
}
.btn--primary{
  background:var(--brand);
  color:#fff;
  box-shadow:0 10px 28px rgba(200,16,46,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover{transform:translateY(-2px);background:var(--brand-2);color:#fff;box-shadow:0 14px 36px rgba(200,16,46,.38)}
.btn--ghost{
  background:#fff;
  border-color:var(--line-2);
  color:var(--text);
}
.btn--ghost:hover{background:#fff;border-color:var(--brand);color:var(--brand)}
.btn--gold{
  background:transparent;border-color:var(--brand);color:var(--brand);
}
.btn--gold:hover{background:var(--brand);color:#fff}
.hero__stats{
  display:flex;gap:48px;flex-wrap:wrap;
  padding-top:32px;border-top:1px solid var(--line);
}
.hero__stats div{display:flex;flex-direction:column}
.hero__stats-num{
  font-size:28px;font-weight:700;
  color:var(--text);letter-spacing:-.025em;
}
.hero__stats span{font-size:13px;color:var(--muted);margin-top:2px}

/* ========== 3D PHONE (Diagnose-Mockup) ========== */
.hero__device{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:560px;perspective:1600px;
}
.device{
  position:relative;
  width:260px;height:540px;
  transform-style:preserve-3d;
  transform:rotateY(-18deg) rotateX(6deg);
  transition:transform .15s ease-out;
  animation:floatPhone 6s ease-in-out infinite;
}
@keyframes floatPhone{
  0%,100%{translate:0 0}
  50%{translate:0 -10px}
}
.device__glow{
  position:absolute;inset:-50px;
  background:radial-gradient(closest-side,rgba(200,16,46,.20),transparent 70%);
  filter:blur(28px);z-index:-1;
}

/* Side-Buttons (Titanium look) */
.device__side{
  position:absolute;background:linear-gradient(180deg,#3a3a40,#1a1a1f);
  border-radius:1px;z-index:3;
}
.device__side--power{
  right:-2px;top:120px;width:3px;height:60px;
  box-shadow:inset -1px 0 0 rgba(255,255,255,.08);
}
.device__side--vol-up{
  left:-2px;top:110px;width:3px;height:40px;
  box-shadow:inset 1px 0 0 rgba(255,255,255,.08);
}
.device__side--vol-down{
  left:-2px;top:160px;width:3px;height:40px;
  box-shadow:inset 1px 0 0 rgba(255,255,255,.08);
}

/* Titanium-Frame mit feinen Antenna-Lines (echte iPhones haben die als
   Funk-Trennlinien an Top und Bottom des Frames) */
.device__frame{
  position:absolute;inset:0;
  border-radius:46px;
  background:
    linear-gradient(135deg,#3a3a40 0%,#2a2a30 15%,#1a1a1f 50%,#252529 85%,#3a3a40 100%);
  border:1px solid rgba(255,255,255,.04);
  box-shadow:
    0 40px 80px -25px rgba(0,0,0,.45),
    0 20px 35px -15px rgba(0,0,0,.30),
    inset 0 0 0 5px #0a0a0c,
    inset 0 0 0 6px rgba(255,255,255,.04);
  overflow:hidden;
}
.device__frame::before,
.device__frame::after{
  content:"";position:absolute;left:0;right:0;height:1px;z-index:4;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.10) 10%,
    rgba(0,0,0,.40) 50%,
    rgba(255,255,255,.10) 90%,
    transparent 100%);
}
.device__frame::before{top:54px}
.device__frame::after{bottom:54px}

/* Dynamic Island */
.device__island{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:105px;height:32px;
  background:#000;border-radius:18px;z-index:2;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}
.device__island::before{
  content:"";position:absolute;top:50%;left:14px;
  transform:translateY(-50%);
  width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#1a3a6a,#000 70%);
}
.device__island::after{
  content:"";position:absolute;top:50%;right:14px;
  transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#2a2a30,#000 70%);
}

/* Display */
.device__screen{
  position:absolute;inset:13px;border-radius:34px;
  background:
    radial-gradient(120% 80% at 50% 0%,rgba(200,16,46,.10),transparent 50%),
    linear-gradient(170deg,#0a0a0c 0%,#16161a 100%);
  overflow:hidden;
}

/* Status-Bar bleibt fix oben, Slides darunter */
.screen__top{
  position:absolute;top:18px;left:24px;right:24px;z-index:3;
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;font-weight:600;color:rgba(255,255,255,.7);
}
.screen__diag{
  position:absolute;inset:0;
  padding:60px 22px 22px;
  display:flex;flex-direction:column;
  color:#f4f4f6;
  opacity:0;visibility:hidden;
  transition:opacity .6s ease;
}
.screen__diag.is-active{
  opacity:1;visibility:visible;
}
.screen__time{font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.screen__signal{
  display:inline-block;width:16px;height:11px;
  background:
    linear-gradient(to top,#fff 25%,transparent 25%) 0 100% / 3px 25% no-repeat,
    linear-gradient(to top,#fff 50%,transparent 50%) 4px 100% / 3px 50% no-repeat,
    linear-gradient(to top,#fff 75%,transparent 75%) 8px 100% / 3px 75% no-repeat,
    linear-gradient(to top,#fff 100%,transparent 100%) 12px 100% / 3px 100% no-repeat;
}

.screen__kicker{
  font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:#c8102e;margin-top:6px;
}
.screen__value{
  font-size:62px;font-weight:800;letter-spacing:-.04em;
  line-height:1;margin-top:6px;
  background:linear-gradient(180deg,#fff,#a8a8b0);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.screen__value small{font-size:28px;font-weight:600;margin-left:2px}
.screen__sub{
  font-size:12px;color:rgba(255,255,255,.55);margin-top:4px;
}

.screen__checks{
  list-style:none;
  margin:22px 0 0;padding:0;
  display:flex;flex-direction:column;gap:9px;
}
.screen__checks li{
  font-size:13px;font-weight:500;color:rgba(255,255,255,.85);
  padding-left:22px;position:relative;
  opacity:0;
}
.screen__diag.is-active .screen__checks li{
  animation:checkIn .4s ease forwards;
  animation-delay:var(--d);
}
.screen__checks li::before{
  content:"";position:absolute;left:0;top:50%;
  width:14px;height:14px;border-radius:50%;
  background:#1f8a32;
  transform:translateY(-50%);
}
.screen__checks li::after{
  content:"";position:absolute;left:3px;top:50%;
  width:8px;height:5px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:translateY(-75%) rotate(-45deg);
}
@keyframes checkIn{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:translateX(0)}
}

.screen__progress{
  position:absolute;bottom:38px;left:24px;right:24px;
  height:3px;border-radius:2px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}
.screen__progress::before{
  content:"";position:absolute;inset:0;width:0;
  background:linear-gradient(90deg,#c8102e,#e83a55);
  border-radius:inherit;
}
.screen__diag.is-active .screen__progress::before{
  animation:progressFill 1.8s ease-out forwards;
}
@keyframes progressFill{
  from{width:0}
  to{width:100%}
}

/* Home indicator */
.device__screen::after{
  content:"";position:absolute;bottom:10px;left:50%;
  transform:translateX(-50%);
  width:110px;height:4px;border-radius:2px;
  background:rgba(255,255,255,.45);
}

.device__shine{display:none}
.device__reflect{
  position:absolute;top:100%;left:0;right:0;height:120px;
  background:linear-gradient(180deg,rgba(0,0,0,.10),transparent);
  filter:blur(10px);
  transform:scaleY(-1);
  transform-origin:top;
  opacity:.5;
}
.hero__hint{
  position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);
  font-size:11.5px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;
  font-weight:600;
  padding:6px 12px;
  background:rgba(244,245,247,.85);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border-radius:6px;
  white-space:nowrap;
  pointer-events:none;
}
@media (pointer:coarse){
  /* Touch-Geräte: kein Hinweis nötig, Phone-Animation startet automatisch */
  .hero__hint{display:none}
}

/* ========== MARQUEE ========== */
.marquee{
  margin-top:80px;padding:24px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.marquee__track{
  display:flex;gap:32px;
  animation:marquee 40s linear infinite;
  width:max-content;
  font-size:22px;font-weight:600;
  color:var(--dim);letter-spacing:-.015em;
  text-transform:uppercase;
}
.marquee__track span{flex-shrink:0}
@keyframes marquee{to{transform:translateX(-50%)}}

@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__device{min-height:460px}
  .device{width:220px;height:460px;transform:rotateY(-10deg) rotateX(4deg)}
  .device__island{width:90px;height:28px}
  .screen__value{font-size:52px}
  .hero__stats{gap:24px}
  .hero__stats-num{font-size:24px}
}

/* ========== SECTIONS ========== */
.section{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,12vw,140px) var(--pad);
}
.section--alt{
  max-width:none;
  background:var(--bg-3);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.section--alt > *{max-width:var(--max);margin-left:auto;margin-right:auto}
.section__head{text-align:center;max-width:680px;margin:0 auto 64px}
.section__kicker{
  display:inline-block;
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brand);margin-bottom:18px;
}
.section__title{
  font-weight:800;
  font-size:clamp(30px,4vw,52px);line-height:1.08;letter-spacing:-.025em;
  margin-bottom:18px;color:var(--text);
}
.section__sub{color:var(--muted);font-size:17px;max-width:560px;margin:0 auto}

/* ========== CARDS ========== */
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.card{
  position:relative;
  padding:32px 28px;border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line);
  transition:transform .25s, border-color .25s, box-shadow .25s;
  overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(200,16,46,.06),transparent 40%);
  opacity:0;transition:opacity .3s;
}
.card:hover{transform:translateY(-4px);border-color:var(--brand);box-shadow:0 14px 30px rgba(0,0,0,.06)}
.card:hover::before{opacity:1}
.card__icon{
  width:44px;height:44px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  background:var(--brand-soft);
  color:var(--brand);margin-bottom:24px;
}
.card__icon svg{width:24px;height:24px}
.card h3{
  font-weight:700;font-size:19px;
  letter-spacing:-.015em;margin-bottom:10px;color:var(--text);
}
.card p{color:var(--muted);font-size:15px}
.card__arrow{
  position:absolute;top:32px;right:28px;
  color:var(--dim);transition:transform .2s, color .2s;
}
.card:hover .card__arrow{transform:translateX(4px);color:var(--brand)}
.card--gold{
  background:linear-gradient(145deg,#fff,#fdf1f3);
  border-color:rgba(200,16,46,.25);
}
.card--gold .card__icon{
  background:var(--brand);
  color:#fff;
}
@media (max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cards{grid-template-columns:1fr}}

/* ========== SPLIT SECTIONS ========== */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.section--reverse .split{direction:rtl}
.section--reverse .split > *{direction:ltr}
.split__copy h2{margin-top:18px;margin-bottom:24px;text-align:left}
.split__copy p{color:var(--muted);font-size:17px;margin-bottom:24px}
.checklist{list-style:none;display:flex;flex-direction:column;gap:12px}
.checklist li{
  padding-left:32px;position:relative;color:var(--muted);
}
.checklist li::before{
  content:"";position:absolute;left:0;top:8px;width:20px;height:12px;
  border-left:2px solid var(--brand);border-bottom:2px solid var(--brand);
  transform:rotate(-45deg);
}
.grid-list{
  display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;
  margin-top:8px;color:var(--muted);
}
.grid-list div{
  padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;
}

/* repair pills */
.repair-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  padding:24px;
}
.repair-pill{
  display:flex;align-items:center;gap:12px;
  padding:16px 20px;
  background:#fff;
  border:1px solid var(--line);border-radius:8px;
  font-size:15px;font-weight:600;color:var(--text);
  transition:transform .2s, border-color .2s, box-shadow .2s;
  animation:popIn .6s ease both;animation-delay:var(--d);
  box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.repair-pill:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:0 8px 18px rgba(0,0,0,.05)}
.repair-pill span{font-size:22px}
@keyframes popIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* laptop */
.laptop{
  perspective:1200px;display:flex;flex-direction:column;align-items:center;
}
.laptop__lid{
  width:100%;max-width:440px;aspect-ratio:16/10;
  background:linear-gradient(145deg,#cfcfd6,#a8a8b0);
  border-radius:10px 10px 4px 4px;
  padding:14px;
  border:1px solid var(--line-2);
  box-shadow:0 20px 40px -10px rgba(0,0,0,.18);
  transform:rotateX(-3deg);
  transform-origin:bottom;
}
.laptop__screen{
  width:100%;height:100%;border-radius:4px;
  background:#0a0a0c;overflow:hidden;
  border:1px solid rgba(0,0,0,.2);
}
.laptop__base{
  width:108%;height:14px;
  background:linear-gradient(180deg,#bcbcc4,#90909a);
  border-radius:0 0 12px 12px;
  border:1px solid var(--line-2);border-top:none;
}
.terminal{height:100%;display:flex;flex-direction:column;font-family:ui-monospace,'SF Mono',monospace}
.terminal__bar{display:flex;gap:6px;padding:10px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06)}
.terminal__bar span{width:10px;height:10px;border-radius:50%;background:#3a3a40}
.terminal__bar span:nth-child(1){background:#ff5f57}
.terminal__bar span:nth-child(2){background:#febc2e}
.terminal__bar span:nth-child(3){background:#28c840}
.terminal__body{padding:14px 18px;font-size:13px;color:#a8e5a8;flex:1}
.terminal__body p{margin-bottom:6px}
.prompt{color:#e8a13c;margin-right:6px}
.muted{color:#5a8a5a}
.ok{color:#56d364}
.caret{display:inline-block;width:7px;height:14px;background:#a8e5a8;animation:blink 1s infinite;vertical-align:middle;margin-left:2px}
@keyframes blink{50%{opacity:0}}

@media (max-width:900px){
  .split{grid-template-columns:1fr;gap:40px}
  .section--reverse .split{direction:ltr}
  .grid-list{grid-template-columns:1fr}
}

/* ========== DATA STRIP ========== */
.data-strip{
  display:grid;grid-template-columns:repeat(6,1fr);gap:12px;
  padding:32px;border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.data-strip__item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:20px 12px;text-align:center;
}
.data-strip__num{
  font-size:22px;font-weight:700;
  color:var(--brand);letter-spacing:-.02em;
}
.data-strip__item span{font-size:13px;color:var(--muted)}
@media (max-width:800px){.data-strip{grid-template-columns:repeat(3,1fr)}}
@media (max-width:480px){.data-strip{grid-template-columns:repeat(2,1fr)}}

/* ========== BRAND GRID ========== */
.brand-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;
}
.brand-card{
  padding:32px;border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line);
  transition:transform .25s,border-color .25s,box-shadow .25s;
  box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.brand-card:hover{transform:translateY(-4px);border-color:var(--brand);box-shadow:0 14px 30px rgba(0,0,0,.06)}
.brand-card__logo{
  width:48px;height:48px;border-radius:8px;
  background:linear-gradient(135deg,#cfcfd6,#90909a);
  margin-bottom:20px;
  position:relative;
}
.brand-card__logo::before{
  content:"";position:absolute;inset:14px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,#888);
}
.brand-card__logo--samsung{background:linear-gradient(135deg,#1428a0,#0a1660)}
.brand-card__logo--samsung::before{background:#fff;inset:8px;border-radius:50%;}
.brand-card__logo--other{background:linear-gradient(135deg,#c8102e,#8a0e22)}
.brand-card__logo--other::before{background:none;border:3px solid #fff;border-radius:8px;inset:10px}
.brand-card__name{font-weight:700;font-size:19px;margin-bottom:8px;color:var(--text);letter-spacing:-.015em;display:block}
.brand-card p{color:var(--muted);font-size:15px}
.note{text-align:center;color:var(--muted);font-size:15px}
.note a{color:var(--brand);border-bottom:1px dashed var(--brand)}
@media (max-width:900px){.brand-grid{grid-template-columns:1fr}}

/* ========== TRANSFER ========== */
.section--transfer{
  max-width:none;
  background:var(--bg-3);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.transfer{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;
}
.transfer__copy h2{text-align:left;margin:18px 0 24px}
.transfer__copy p{color:var(--muted);font-size:17px;margin-bottom:24px}
.transfer__copy .checklist{margin-bottom:32px}
.transfer__badges{display:flex;flex-direction:column;gap:16px}
.badge{
  display:flex;align-items:center;gap:18px;
  padding:24px;border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line-2);
  transition:transform .2s, border-color .2s, box-shadow .2s;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.badge:hover{transform:translateX(6px);border-color:var(--brand);box-shadow:0 8px 22px rgba(0,0,0,.07)}
.badge__mark{
  flex-shrink:0;
  width:64px;height:64px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:20px;letter-spacing:-.02em;
}
.badge--wu .badge__mark{background:linear-gradient(135deg,#ffdd00,#d4a300);color:#000}
.badge--ria .badge__mark{background:linear-gradient(135deg,#ff6a3d,#c43a16);color:#fff}
.badge__name{display:block;font-size:17px;margin-bottom:2px;color:var(--text);font-weight:600}
.badge span{font-size:14px;color:var(--muted)}
@media (max-width:900px){.transfer{grid-template-columns:1fr;gap:40px}}

/* ========== CONTACT ========== */
.contact{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.contact__card,.contact__hours{
  padding:32px;border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.contact__row{
  display:flex;gap:18px;
  padding:18px 0;border-bottom:1px solid var(--line);
}
.contact__row:last-child{border-bottom:none}
.contact__icon{
  flex-shrink:0;width:40px;height:40px;border-radius:6px;
  background:var(--brand-soft);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.contact__row-label{display:block;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-weight:600}
.contact__row p{font-size:17px;color:var(--text)}
.contact__row a{color:var(--brand);font-size:14px;display:inline-block;margin-top:6px}
.contact__row a:hover{color:var(--brand-2)}
.contact__hours-title{font-weight:700;font-size:19px;margin-bottom:18px;color:var(--text);letter-spacing:-.015em;display:block}
.hours{display:flex;flex-direction:column}
.hours > div{
  display:flex;justify-content:space-between;
  padding:12px 0;border-bottom:1px solid var(--line);
  font-size:15px;
}
.hours > div:last-child{border-bottom:none}
.hours span{color:var(--muted)}
.hours__time{color:var(--text);font-weight:500}
.hours__closed .hours__time{color:var(--dim);font-weight:400}
.status{
  margin-top:16px;padding:12px 16px;border-radius:10px;
  font-size:14px;display:flex;align-items:center;gap:8px;
}
.status.open{background:rgba(31,138,50,.1);color:var(--green)}
.status.closed{background:rgba(0,0,0,.04);color:var(--muted)}
.status::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:currentColor;box-shadow:0 0 8px currentColor;
}
@media (max-width:800px){.contact{grid-template-columns:1fr}}

/* ========== FAQ ========== */
.faq{
  max-width:760px;margin:0 auto;
  display:flex;flex-direction:column;gap:8px;
}
.faq__item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.faq__item:hover{border-color:var(--line-2)}
.faq__item[open]{border-color:var(--brand);box-shadow:0 6px 18px rgba(0,0,0,.04)}
.faq__item summary{
  cursor:pointer;list-style:none;
  padding:18px 22px;
  font-weight:600;font-size:15.5px;color:var(--text);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  user-select:none;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:'+';
  color:var(--brand);font-size:24px;font-weight:300;line-height:1;
  flex-shrink:0;
  transition:transform .2s;
}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item .faq__answer{
  padding:0 22px 20px;
  color:var(--muted);font-size:15px;line-height:1.65;
}
.faq__item .faq__answer p{margin:0}
.faq__item .faq__answer a{color:var(--brand);font-weight:500}

/* ========== FOOTER ========== */
.footer{
  border-top:1px solid var(--line);
  padding:64px var(--pad) 24px;
  margin-top:60px;
  background:var(--bg-3);
}
.footer__inner{max-width:var(--max);margin:0 auto}
.footer__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:40px;
  border-bottom:1px solid var(--line);
}
.footer__col__title{
  font-size:12px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text);
  margin-bottom:18px;
}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer__col li{color:var(--muted);font-size:14.5px;line-height:1.45}
.footer__col a{color:var(--muted);transition:color .2s}
.footer__col a:hover{color:var(--brand)}
.footer__col--brand .footer__logo{height:42px;width:auto;margin-bottom:18px}
.footer__col--brand p{color:var(--muted);font-size:14.5px;max-width:300px;line-height:1.55}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;
  gap:16px;flex-wrap:wrap;
}
.footer__copy{font-size:13px;color:var(--dim);margin:0}
.footer__legal{display:flex;gap:24px;font-size:13px;color:var(--dim)}
.footer__legal a{color:var(--dim);transition:color .2s}
.footer__legal a:hover{color:var(--brand)}
@media (max-width:840px){
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer__col--brand{grid-column:1 / -1}
}
@media (max-width:520px){
  .footer__grid{grid-template-columns:1fr;gap:32px}
  .footer__bottom{justify-content:center;text-align:center}
}

/* ========== REVEAL ON SCROLL ========== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* ========== PRINT / REDUCED MOTION ========== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
