/* === Subpage hero (different from homepage hero slider) === */
.sub-hero{position:relative;background:var(--rolutec-blue-deep);color:#fff;padding:120px 40px 100px;overflow:hidden;}
.sub-hero::before{content:none;}
.sub-hero::after{content:none;}
.sub-hero-inner{position:relative;max-width:var(--page-w);margin:0 auto;}
.crumbs{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--rolutec-orange);margin-bottom:20px;}
.crumbs a{color:rgba(255,255,255,.7);text-decoration:none;}
.crumbs a:hover{color:#fff;}
.crumbs .sep{color:rgba(255,255,255,.4);}
.sub-hero h1{font-family:var(--font-display);font-weight:800;font-size:64px;line-height:1.05;letter-spacing:-0.02em;color:#fff;margin:0 0 22px;max-width:880px;}
.sub-hero p{font-family:var(--font-body);font-size:20px;font-weight:500;line-height:1.6;color:rgba(255,255,255,.92);max-width:680px;margin:0;}

/* === Content blocks for subpages === */
.prose{max-width:760px;}
.prose h2{font-family:var(--font-display);font-weight:800;font-size:36px;line-height:1.15;letter-spacing:-0.01em;color:var(--fg-1);margin:48px 0 18px;}
.prose h2:first-child{margin-top:0;}
.prose h3{font-family:var(--font-display);font-weight:700;font-size:22px;line-height:1.3;color:var(--fg-1);margin:32px 0 12px;}
.prose p{font-family:var(--font-body);font-size:18px;font-weight:500;line-height:1.7;color:var(--fg-2);margin:0 0 18px;}
.prose ul{padding-left:0;list-style:none;margin:0 0 24px;}
.prose ul li{font-family:var(--font-body);font-size:18px;font-weight:500;line-height:1.65;color:var(--fg-2);padding:8px 0 8px 32px;position:relative;}
.prose ul li::before{content:"";position:absolute;left:0;top:18px;width:18px;height:2px;background:var(--rolutec-orange);}
.prose strong{color:var(--fg-1);font-weight:600;}

.two-col{display:grid;grid-template-columns:1fr 380px;gap:80px;align-items:start;}
.aside-card{background:var(--bg-warm-white-2);border:1px solid var(--border-1);border-radius:var(--r-md);padding:32px;position:sticky;top:32px;}
.aside-card h4{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--fg-1);margin:0 0 14px;}
.aside-card p{font-family:var(--font-body);font-size:16px;font-weight:500;line-height:1.6;color:var(--fg-2);margin:0 0 18px;}
.aside-card .row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-2);font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--fg-1);}
.aside-card .row:last-child{border-bottom:0;}
.aside-card .row svg{color:var(--rolutec-blue);}
.aside-card a.btn{display:inline-flex;align-items:center;gap:10px;background:var(--rolutec-blue);color:#fff;padding:0 18px;height:46px;border-radius:var(--r-md);font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;margin-top:18px;}
.aside-card a.btn:hover{background:var(--rolutec-blue-deep);}

/* Service feature grid */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:32px 0;}
.feat{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);padding:24px;}
.feat .ic{width:44px;height:44px;border-radius:var(--r-sm);background:var(--rolutec-blue-faint);color:var(--rolutec-blue);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;}
.feat h4{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--fg-1);margin:0 0 8px;}
.feat p{font-family:var(--font-body);font-size:16px;font-weight:500;line-height:1.6;color:var(--fg-2);margin:0;}

/* Service related cards (links to other services) */
.related{margin-top:80px;border-top:1px solid var(--border-1);padding-top:60px;}
.related h3{font-family:var(--font-display);font-weight:800;font-size:28px;color:var(--fg-1);margin:0 0 28px;}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.related-card{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);padding:24px;text-decoration:none;display:block;transition:border-color .2s;}
.related-card:hover{border-color:var(--rolutec-blue);}
.related-card .ic{width:40px;height:40px;border-radius:var(--r-sm);background:var(--rolutec-orange-faint);color:var(--rolutec-orange);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;}
.related-card h4{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--fg-1);margin:0 0 8px;}
.related-card p{font-family:var(--font-body);font-size:15px;font-weight:500;line-height:1.55;color:var(--fg-3);margin:0;}

/* Team / referenzen / karriere grids */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.team-card{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);overflow:hidden;}
.team-card .ph{aspect-ratio:4/5;background:linear-gradient(135deg, var(--rolutec-blue-faint), var(--rolutec-orange-faint));display:flex;align-items:center;justify-content:center;color:var(--neutral-400);font-family:var(--font-display);font-size:14px;letter-spacing:.18em;text-transform:uppercase;}
.team-card .meta{padding:20px 22px;}
.team-card .role{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--rolutec-orange);margin-bottom:6px;}
.team-card h4{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--fg-1);margin:0 0 4px;}
.team-card .sub{font-family:var(--font-body);font-size:13px;color:var(--fg-3);}

.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.ref-card{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);overflow:hidden;}
.ref-card .ph{aspect-ratio:16/10;background:linear-gradient(135deg, var(--neutral-200), var(--neutral-100));display:flex;align-items:center;justify-content:center;color:var(--neutral-400);font-family:var(--font-display);font-size:14px;letter-spacing:.18em;text-transform:uppercase;}
.ref-card .meta{padding:24px 28px;}
.ref-card .tag{display:inline-block;font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--rolutec-blue);background:var(--rolutec-blue-faint);padding:5px 10px;border-radius:var(--r-sm);margin-bottom:10px;}
.ref-card h4{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--fg-1);margin:0 0 8px;}
.ref-card p{font-family:var(--font-body);font-size:16px;font-weight:500;line-height:1.6;color:var(--fg-2);margin:0;}

.job-list{display:flex;flex-direction:column;gap:12px;}
.job{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);padding:24px 28px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;text-decoration:none;transition:border-color .2s;}
.job:hover{border-color:var(--rolutec-blue);}
.job .meta{display:flex;gap:14px;align-items:center;font-family:var(--font-body);font-size:13px;color:var(--fg-3);margin-bottom:6px;}
.job .meta .dot{width:4px;height:4px;border-radius:50%;background:var(--neutral-300);}
.job h4{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--fg-1);margin:0;}
.job .arr{width:48px;height:48px;border-radius:var(--r-pill);background:var(--bg-warm-white-2);color:var(--rolutec-blue);display:inline-flex;align-items:center;justify-content:center;}

/* Kontakt form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;}
.contact-info .row{display:flex;gap:18px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--border-1);}
.contact-info .row:last-child{border-bottom:0;}
.contact-info .ic{width:48px;height:48px;border-radius:var(--r-sm);background:var(--rolutec-blue-faint);color:var(--rolutec-blue);display:inline-flex;align-items:center;justify-content:center;flex:none;}
.contact-info .lbl{font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);margin-bottom:4px;}
.contact-info a, .contact-info p{font-family:var(--font-body);font-size:18px;font-weight:500;color:var(--fg-1);text-decoration:none;margin:0;line-height:1.5;}
.contact-info a:hover{color:var(--rolutec-blue);}

.form-card{background:#fff;border:1px solid var(--border-1);border-radius:var(--r-md);padding:36px;}
.form-card h3{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--fg-1);margin:0 0 8px;}
.form-card .sub{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--fg-3);margin:0 0 24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.form-card label{display:block;font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:6px;}
.form-card input, .form-card textarea, .form-card select{width:100%;font-family:var(--font-body);font-size:15px;padding:12px 14px;border:1px solid var(--border-1);border-radius:var(--r-sm);background:#fff;color:var(--fg-1);}
.form-card input:focus, .form-card textarea:focus{outline:0;border-color:var(--rolutec-blue);}
.form-card textarea{resize:vertical;min-height:120px;}
.form-card button{margin-top:18px;display:inline-flex;align-items:center;gap:10px;background:var(--rolutec-blue);color:#fff;padding:0 22px;height:50px;border:0;border-radius:var(--r-md);font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background 160ms ease;}
.form-card button:hover{background:var(--rolutec-blue-deep);}
.form-card button:disabled{background:var(--neutral-300);cursor:not-allowed;}

.kf-privacy{display:flex !important;gap:10px;align-items:flex-start;margin:8px 0 6px;text-transform:none !important;letter-spacing:0 !important;font-size:14px !important;font-weight:400 !important;color:var(--fg-2) !important;line-height:1.5;}
.kf-privacy input[type=checkbox]{width:18px;height:18px;flex:0 0 18px;margin-top:2px;cursor:pointer;accent-color:var(--rolutec-blue);}
.kf-privacy a{color:var(--rolutec-blue);text-decoration:underline;}
.kf-privacy a:hover{color:var(--rolutec-blue-deep);}

.kf-status{margin-top:14px;padding:0;font-family:var(--font-body);font-size:14px;line-height:1.5;min-height:0;}
.kf-status.error{padding:12px 14px;background:#fff1ec;border:1px solid var(--rolutec-orange);border-radius:var(--r-sm);color:var(--rolutec-orange-deep);}
.kf-status.success{padding:14px 16px;background:var(--rolutec-blue-faint);border:1px solid var(--rolutec-blue-soft);border-radius:var(--r-sm);color:var(--rolutec-blue-deep);}

/* Responsive subpage */
@media (max-width: 1024px){
  .sub-hero{padding:80px 24px 64px;}
  .sub-hero h1{font-size:42px;}
  .sub-hero p{font-size:16px;}
  .two-col{grid-template-columns:1fr;gap:32px;}
  .aside-card{position:static;}
  .feat-grid, .team-grid, .ref-grid, .related-grid, .contact-grid{grid-template-columns:1fr !important;}
  .prose h2{font-size:28px;}
}

@media (max-width: 640px){
  /* Sub-Hero */
  .sub-hero{padding:48px 20px 36px;}
  .sub-hero h1{font-size:30px;line-height:1.1;margin-bottom:14px;}
  .sub-hero p{font-size:15px;line-height:1.55;}
  .crumbs{font-size:11px;letter-spacing:.12em;margin-bottom:14px;gap:6px;}

  /* Two-col + Prose */
  .two-col{gap:32px;}
  .prose h2{font-size:23px;line-height:1.2;margin:32px 0 14px;}
  .prose h3{font-size:18px;margin:24px 0 10px;}
  .prose p{font-size:15.5px;line-height:1.65;margin-bottom:14px;}
  .prose ul{margin-bottom:18px;}
  .prose ul li{font-size:15.5px;padding:6px 0 6px 26px;line-height:1.55;}
  .prose ul li::before{top:14px;width:14px;}

  /* Feature-Grid */
  .feat-grid{gap:12px;margin:24px 0;}
  .feat{padding:20px;}
  .feat .ic{width:42px;height:42px;margin-bottom:12px;}
  .feat h4{font-size:16px;margin-bottom:6px;}
  .feat p{font-size:14.5px;line-height:1.55;}

  /* Aside-Card */
  .aside-card{padding:24px 22px;}
  .aside-card h4{font-size:17px;margin-bottom:12px;}
  .aside-card p{font-size:14.5px;line-height:1.55;margin-bottom:14px;}
  .aside-card .row{font-size:14.5px;padding:9px 0;gap:10px;}
  .aside-card a.btn{height:44px;padding:0 16px;font-size:11.5px;letter-spacing:.1em;margin-top:14px;}

  /* Related */
  .related{margin-top:48px;padding-top:36px;}
  .related h3{font-size:22px;margin-bottom:20px;}
  .related-grid{gap:12px;}
  .related-card{padding:20px;}
  .related-card h4{font-size:16px;}
  .related-card p{font-size:14px;}

  /* Team */
  .team-grid{gap:18px;}
  .team-card .meta{padding:18px 20px;}
  .team-card h4{font-size:18px;}
  .team-card .role{font-size:11px;letter-spacing:.14em;}

  /* Referenzen */
  .ref-grid{gap:18px;}
  .ref-card .meta{padding:20px 22px;}
  .ref-card h4{font-size:19px;}
  .ref-card p{font-size:14.5px;line-height:1.55;}
  .ref-card .tag{font-size:10.5px;padding:4px 8px;}

  /* Karriere-Jobs */
  .job{padding:18px 20px;gap:14px;}
  .job h4{font-size:16px;line-height:1.25;}
  .job .meta{font-size:11.5px;gap:10px;flex-wrap:wrap;margin-bottom:5px;}
  .job .arr{width:40px;height:40px;}

  /* Kontakt-Info */
  .contact-grid{gap:32px;}
  .contact-info .row{padding:14px 0;gap:14px;}
  .contact-info .ic{width:42px;height:42px;}
  .contact-info .lbl{font-size:10.5px;letter-spacing:.14em;}
  .contact-info a, .contact-info p{font-size:16px;}

  /* Form-Card — wichtig: 16px Input-Font verhindert iOS-Auto-Zoom beim Fokus */
  .form-card{padding:24px 20px;}
  .form-card h3{font-size:21px;margin-bottom:6px;}
  .form-card .sub{font-size:14px;margin-bottom:18px;}
  .form-row{grid-template-columns:1fr;gap:0;margin-bottom:0;}
  .form-row > div{margin-bottom:14px;}
  .form-card label{font-size:10.5px;letter-spacing:.1em;margin-bottom:5px;}
  .form-card input, .form-card textarea, .form-card select{font-size:16px;padding:11px 12px;}
  .form-card textarea{min-height:96px;}
  .form-card button{height:48px;padding:0 18px;font-size:12.5px;letter-spacing:.05em;width:100%;justify-content:center;}

  .kf-privacy{font-size:13.5px !important;gap:9px;line-height:1.45;}
  .kf-privacy input[type=checkbox]{width:20px;height:20px;flex:0 0 20px;margin-top:1px;}

  .kf-status{font-size:13.5px;}
  .kf-status.error, .kf-status.success{padding:11px 13px;}
}

@media (max-width: 380px){
  .sub-hero{padding:40px 16px 30px;}
  .sub-hero h1{font-size:26px;}
  .form-card, .aside-card{padding:20px 18px;}
  .feat{padding:18px;}
  .ref-card .meta, .team-card .meta{padding:16px 18px;}
}
