/* =========================================================
   Reparaturauftrag · Rokamat
   Reuses index_contact.css conventions (ct-*) wherever possible.
   All borders strictly cubic (border-radius:0) to match the
   site-wide design language — only animated dots / focus rings
   remain circular.
   ========================================================= */

/* --- HERO: matches Unternehmens-Header (pg-hero). The header markup
   uses pg-hero / pg-h1 / pg-lead directly (see index_page.css); only the
   inline "so läuft's" flow list is repair-specific. --- */

/* Numbered "so läuft's" flow inline (light background, sits inside pg-hero) */
.rp-flow{
  list-style:none;margin:0 0 26px;padding:0;counter-reset:rpf;
  display:flex;flex-direction:column;gap:8px;max-width:620px;
}
.rp-flow li{
  counter-increment:rpf;
  display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:baseline;
  font-size:15px;line-height:1.55;color:var(--rok-fg-muted,#3a3a3a);font-weight:400;
}
.rp-flow li::before{
  content:counter(rpf, decimal-leading-zero);
  font-family:'Roboto',system-ui,sans-serif;
  font-weight:900;font-style:italic;color:#ea5b0a;font-size:14px;
  letter-spacing:.02em;align-self:baseline;
}
.rp-flow li strong{color:var(--rok-ink,#0b0b0c);font-weight:700;}

/* --- PRIMARY GRID: form (left) + sticky summary (right) --- */
.rp-primary{padding:56px 0 96px;background:#fff;}
.rp-primary-grid{
  display:grid;grid-template-columns: minmax(0,1fr) 380px;gap:64px;align-items:start;
}

/* Section group inside the form */
.rp-section{
  margin:0 0 40px;padding:0 0 32px;border-bottom:1px solid #ece9e3;
}
.rp-section:last-child{border-bottom:0;}
.rp-section-head{display:flex;align-items:baseline;gap:14px;margin:0 0 22px;}
.rp-section-head .num{
  font-family:'Roboto',system-ui,sans-serif;font-weight:900;font-style:italic;
  color:#ea5b0a;font-size:42px;line-height:1;letter-spacing:-.02em;
}
.rp-section-head h2{
  margin:0;font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;
  text-transform:uppercase;font-size:22px;letter-spacing:-.01em;color:#0b0b0c;
}
.rp-section-head .h-meta{margin-left:auto;font-size:13px;color:var(--rok-text-muted-accessible);}

/* Field row layout */
.rp-row{display:grid;gap:14px;margin:0 0 14px;}
.rp-row.two{grid-template-columns:1fr 1fr;}
.rp-row.three{grid-template-columns:1fr 1fr 1fr;}
.rp-row.zip-city{grid-template-columns:140px 1fr;}
@media (max-width:760px){
  .rp-row.two,.rp-row.three,.rp-row.zip-city{grid-template-columns:1fr;}
}

.rp-field{display:flex;flex-direction:column;gap:6px;}
.rp-field > label{
  font-size:13px;font-weight:600;color:#0b0b0c;letter-spacing:.01em;
}
.rp-field > label em{color:#ea5b0a;font-style:normal;}
.rp-field > .hint{font-size:12px;color:var(--rok-text-muted-accessible);line-height:1.4;}
.rp-field input,.rp-field textarea,.rp-field select{
  width:100%;font-family:inherit;font-size:15px;padding:12px 14px;
  border:1px solid #d8d4cc;background:#fff;color:#0b0b0c;
  transition:border-color .15s, box-shadow .15s;
}
.rp-field textarea{resize:vertical;min-height:120px;}
.rp-field input:focus,.rp-field textarea:focus,.rp-field select:focus{
  outline:0;border-color:#ea5b0a;box-shadow:0 0 0 2px rgba(234,91,10,.18);
}
.rp-field .error{font-size:12px;color:#c93434;}
.rp-field.invalid input,.rp-field.invalid textarea{border-color:#c93434;}

/* Kind chips (the 4 PDF checkboxes, modernized — cubic) */
.rp-kinds{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0;
}
@media (max-width:560px){.rp-kinds{grid-template-columns:1fr;}}
.rp-kind{
  position:relative;display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;border:1px solid #d8d4cc;cursor:pointer;
  background:#fff;transition:border-color .15s, background .15s;
}
.rp-kind:hover{border-color:#0b0b0c;}
.rp-kind input{position:absolute;opacity:0;pointer-events:none;}
.rp-kind .box{
  width:18px;height:18px;border:1.5px solid #b6b1a6;flex:none;
  margin-top:1px;display:flex;align-items:center;justify-content:center;
  transition:background .15s, border-color .15s;
}
.rp-kind .box::after{
  content:"";width:10px;height:10px;background:#ea5b0a;
  transform:scale(0);transition:transform .12s;
}
.rp-kind input:checked ~ .box{border-color:#ea5b0a;}
.rp-kind input:checked ~ .box::after{transform:scale(1);}
.rp-kind input:checked ~ .meta .title{color:#ea5b0a;}
.rp-kind:has(input:checked){border-color:#ea5b0a;background:#fff8f2;}
.rp-kind .meta .title{font-weight:700;font-size:14px;color:#0b0b0c;display:block;margin-bottom:2px;}
.rp-kind .meta .sub{font-size:12px;color:#666;line-height:1.4;display:block;}

/* Battery gate */
.rp-battery{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;
}
@media (max-width:760px){.rp-battery{grid-template-columns:1fr;}}
.rp-bat-opt{
  position:relative;display:block;padding:14px 16px;border:1px solid #d8d4cc;
  cursor:pointer;background:#fff;text-align:left;
  transition:border-color .15s, background .15s;
}
.rp-bat-opt:hover{border-color:#0b0b0c;}
.rp-bat-opt input{position:absolute;opacity:0;pointer-events:none;}
.rp-bat-opt:has(input:checked){border-color:#ea5b0a;background:#fff8f2;}
.rp-bat-opt .title{font-weight:700;font-size:14px;color:#0b0b0c;display:block;margin-bottom:2px;}
.rp-bat-opt .sub{font-size:12px;color:#666;display:block;line-height:1.4;}

.rp-bat-notice{
  margin-top:14px;padding:14px 16px;font-size:14px;line-height:1.5;
  border:1px solid;display:flex;gap:12px;align-items:flex-start;
}
.rp-bat-notice .ic{font-size:18px;line-height:1;flex:none;display:flex;align-items:center;}
.rp-bat-notice.info{background:#fff8f2;border-color:#f3d9bf;color:#7a3a05;}
.rp-bat-notice.warn{background:#fdecec;border-color:#f4b4b4;color:#7a1a1a;}
.rp-bat-notice a{color:inherit;text-decoration:underline;font-weight:600;}

/* Submit row — uses .v2-btn class on the button itself for site-wide CTA parity. */
.rp-submit-row{display:flex;align-items:center;gap:18px;margin-top:8px;flex-wrap:wrap;}
.rp-submit-row .v2-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;}
.rp-submit-row .v2-btn:disabled:hover{background:var(--rok-orange,#ea5b0a);transform:none;}
.rp-required{font-size:12px;color:var(--rok-text-muted-accessible);letter-spacing:.04em;}

/* Form-level error / success banners */
.rp-banner{
  margin:0 0 22px;padding:14px 18px;font-size:14px;line-height:1.5;
  display:flex;gap:12px;align-items:flex-start;border:1px solid;
}
.rp-banner.err{background:#fdecec;border-color:#f4b4b4;color:#7a1a1a;}
.rp-banner .ic{display:flex;align-items:center;flex:none;line-height:1;}
.rp-banner.ok{background:#fff;border-left:4px solid #ea5b0a;border-color:#e9e6e1;color:#0b0b0c;}
.rp-banner.ok strong{color:#ea5b0a;margin-right:4px;}

/* Consent line */
.rp-consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#3a3a3a;line-height:1.5;}
.rp-consent input{margin-top:3px;}
.rp-consent a{color:#ea5b0a;font-weight:600;}

/* --- STICKY SIDEBAR (right column) — reuses .ct-card from contact CSS,
       adds a single variant for the dark "recipient" card. --- */
.rp-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:16px;}
.ct-card.dark{
  background:#0b0b0c;color:#fff;border-color:#0b0b0c;
}
.ct-card.dark .ct-card-eyebrow{color:#ea5b0a;}
.ct-card.dark h3{color:#fff;}
.ct-card.dark address{
  font-style:normal;font-size:15px;line-height:1.6;color:rgba(255,255,255,.85);
  margin:0;font-family:'Roboto',system-ui,sans-serif;
}
.ct-card .ct-quick.bare{border-top:0;margin-top:6px;}

/* Summary dl inside a ct-card */
.rp-summary-dl{
  margin:0;font-size:13px;line-height:1.55;
  display:grid;grid-template-columns:auto 1fr;gap:8px 14px;
}
.rp-summary-dl dt{color:var(--rok-text-muted-accessible);font-weight:600;}
.rp-summary-dl dd{margin:0;color:#0b0b0c;font-weight:500;word-break:break-word;}
.rp-summary-dl dd.pending{color:var(--rok-text-muted-accessible);font-weight:400;font-style:italic;}

/* Mobile: drop sticky, single column */
@media (max-width:1000px){
  .rp-primary-grid{grid-template-columns:1fr;gap:32px;}
  .rp-side{position:static;}
}

/* Honeypot */
.rp-hp{position:absolute;left:-9999px;height:0;width:0;overflow:hidden;}

/* =========================================================
   Success card — replaces the form after a successful submit.
   No separate confirmation page; the card lives in the same
   layout slot as the form.
   ========================================================= */
.rp-success{
  border:1px solid #e9e6e1;background:#fff;padding:48px 48px 40px;
  max-width:680px;
}
.rp-success-mark{
  display:flex;align-items:center;justify-content:center;
  width:56px;height:56px;background:#ea5b0a;color:#fff;
  font-size:30px;font-weight:800;line-height:1;margin-bottom:22px;
}
.rp-success h2{
  margin:0 0 14px;
  font-family:'Roboto',system-ui,sans-serif;font-weight:900;font-style:italic;
  text-transform:uppercase;font-size:38px;letter-spacing:-.02em;color:#0b0b0c;
}
.rp-success p{
  margin:0 0 22px;font-size:16px;line-height:1.6;color:#3a3a3a;
  font-weight:300;max-width:560px;
}
.rp-success-actions{
  display:flex;gap:14px;flex-wrap:wrap;margin:0 0 24px;
}
.rp-success-foot{
  margin:0;padding-top:18px;border-top:1px solid #ece9e3;
  font-size:13px;line-height:1.55;color:var(--rok-text-muted-accessible);
}
.rp-success-foot a{color:var(--rok-orange-text);font-weight:600;}
@media (max-width:600px){
  .rp-success{padding:32px 28px 28px;}
  .rp-success h2{font-size:30px;}
}

/* =========================================================
   Ticket confirmation page (printable)
   ========================================================= */
.rp-ticket{padding:48px 0 80px;background:#fff;}
.rp-ticket .v2-container{max-width:880px;}
.rp-ticket-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  border-bottom:2px solid #0b0b0c;padding-bottom:18px;margin-bottom:28px;gap:24px;flex-wrap:wrap;
}
.rp-ticket-head h1{
  margin:0;font-family:'Roboto',sans-serif;font-weight:900;
  font-style:italic;text-transform:uppercase;font-size:42px;letter-spacing:-.02em;
}
.rp-ticket-head .brand{font-weight:900;font-style:italic;letter-spacing:.02em;color:#ea5b0a;}
.rp-ticket-head .brand small{display:block;font-style:normal;font-size:11px;color:#666;letter-spacing:.2em;font-weight:600;}
.rp-ticket-no{
  font-family:var(--rok-font-body);background:#0b0b0c;color:#fff;
  padding:6px 12px;font-size:14px;font-weight:700;letter-spacing:.05em;
}
.rp-ticket-grid{display:grid;grid-template-columns:160px 1fr;gap:10px 22px;font-size:14px;line-height:1.55;}
.rp-ticket-grid dt{color:#666;font-weight:600;}
.rp-ticket-grid dd{margin:0;color:#0b0b0c;}
.rp-ticket-section{margin-top:32px;}
.rp-ticket-section h2{
  margin:0 0 14px;font-size:14px;font-weight:700;text-transform:uppercase;
  letter-spacing:.18em;color:#ea5b0a;border-bottom:1px solid #e9e6e1;padding-bottom:8px;
}
.rp-ticket-box{
  margin-top:18px;padding:14px 16px;border:1px solid #f3d9bf;background:#fff8f2;
  font-size:13px;line-height:1.55;color:#7a3a05;
}
.rp-ticket-actions{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;}

/* Print: hide chrome, simplify to PDF-look */
@media print{
  .v2-topbar,.v2-nav,.v2-footer,.pdp-crumb,.rp-ticket-actions,
  .rp-ticket-back,.v2-cart-bar,header,nav{display:none !important;}
  body{background:#fff;}
  .rp-ticket{padding:0;}
  .rp-ticket .v2-container{max-width:none;padding:0;}
  .rp-ticket-head{border-bottom:2px solid #000;}
  .rp-ticket-no{background:#000;}
  .rp-ticket-box{border:1px solid #ccc;background:#fafafa;color:#333;}
  @page{margin:18mm;}
}
