/* ========================================================================
   DOMIO IMMOBILIEN — Stylesheet
   Brand colors:
   - Nacht-Navy  #0A0F25  (primary, logo text)
   - Royal Blue  #2D52C4  (accent, CTA)
   - Slate Grey  #7E828D  (subtext, captions)
   - Blue Tint   #E8EDFA  (light backgrounds)
   - Surface     #F0F2F7  (page background panels)
   - Border      #E2E4EA
   ======================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --navy:#0A0F25;
  --navy-2:#162040;
  --navy-3:#1E2E55;
  --royal:#2D52C4;
  --royal-2:#4A72D9;
  --steel:#A8BFED;
  --tint:#E8EDFA;
  --slate:#7E828D;
  --light-grey:#B2B6C0;
  --border:#E2E4EA;
  --surface:#F0F2F7;
  --white:#FFFFFF;
  --text:#1A2238;
  --text-mid:#4A4E5A;
}

html{scroll-behavior:smooth}
body{
  font-family:'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{color:var(--royal);text-decoration:none;transition:color .2s}
a:hover{color:var(--royal-2)}

img{max-width:100%;height:auto;display:block}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ============ TOPBAR ============ */
.topbar{
  background:var(--navy);
  color:rgba(255,255,255,.8);
  font-size:13px;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.topbar-left,.topbar-right{display:flex;gap:24px;flex-wrap:wrap}
.topbar a{color:rgba(255,255,255,.8);font-weight:400}
.topbar a:hover{color:#fff}
.topbar .ico{margin-right:4px}

/* ============ HEADER ============ */
.header{
  background:#fff;
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 1px 2px rgba(10,15,37,.03);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:24px}
.logo-link{display:flex;align-items:center}
.logo{height:48px;width:auto}
.nav{display:flex;gap:28px}
.nav a{
  color:var(--navy);
  font-weight:500;
  font-size:15px;
  padding:6px 0;
  border-bottom:2px solid transparent;
  transition:all .2s;
}
.nav a:hover{color:var(--royal);border-bottom-color:var(--royal)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 22px;
  border-radius:6px;
  font-family:inherit;
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:all .2s;
  white-space:nowrap;
}
.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-primary:hover{background:var(--navy-2);border-color:var(--navy-2);color:#fff;transform:translateY(-1px)}
.btn-accent{background:var(--royal);color:#fff;border-color:var(--royal)}
.btn-accent:hover{background:var(--royal-2);border-color:var(--royal-2);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:var(--surface);color:var(--text-mid);border-color:transparent}
.btn-ghost:hover{background:var(--border)}
.btn-lg{padding:14px 28px;font-size:15px}
.btn-full{width:100%}

/* ============ HERO ============ */
.hero{
  background:linear-gradient(180deg, #fff 0%, var(--surface) 100%);
  padding:70px 0 90px;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  top:-100px;
  right:-100px;
  width:500px;
  height:500px;
  background:radial-gradient(circle,var(--tint) 0%, transparent 70%);
  opacity:.5;
  z-index:0;
}
.hero-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-eyebrow{
  display:inline-block;
  background:var(--tint);
  color:var(--royal);
  padding:6px 14px;
  border-radius:99px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.hero h1{
  font-size:54px;
  font-weight:800;
  line-height:1.05;
  letter-spacing:-1.5px;
  color:var(--navy);
  margin-bottom:20px;
}
.hero h1 .accent{color:var(--royal);position:relative}
.hero h1 .accent::after{
  content:"";
  position:absolute;
  bottom:6px;left:0;right:0;
  height:6px;
  background:var(--tint);
  z-index:-1;
  border-radius:3px;
}
.hero-sub{
  font-size:18px;
  color:var(--text-mid);
  line-height:1.6;
  margin-bottom:32px;
  max-width:540px;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}
.hero-trust{display:flex;gap:36px;flex-wrap:wrap}
.trust-item{display:flex;flex-direction:column}
.trust-num{font-size:28px;font-weight:800;color:var(--navy);line-height:1}
.trust-label{font-size:13px;color:var(--slate);margin-top:4px}

.hero-visual{display:flex;justify-content:center}
.hero-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  padding:32px;
  box-shadow:0 20px 60px rgba(10,15,37,.08);
  width:100%;
  max-width:380px;
}
.hero-card-icon{font-size:32px;margin-bottom:12px}
.hero-card-title{font-size:18px;font-weight:600;color:var(--navy);margin-bottom:20px}
.hero-card-list{list-style:none;counter-reset:hcl}
.hero-card-list li{
  counter-increment:hcl;
  padding:12px 0 12px 48px;
  border-bottom:1px solid var(--border);
  position:relative;
}
.hero-card-list li::before{
  content:counter(hcl);
  position:absolute;left:0;top:14px;
  width:32px;height:32px;
  background:var(--tint);color:var(--royal);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;
}
.hero-card-list li:last-child{border-bottom:none}
.hero-card-list span{display:block;font-weight:600;color:var(--navy);font-size:15px}
.hero-card-list small{display:block;color:var(--slate);font-size:13px;margin-top:2px}

/* ============ TRUSTBAR ============ */
.trustbar{
  background:var(--navy);
  color:#fff;
  padding:32px 0;
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  text-align:center;
}
.trust-block-num{
  font-size:22px;
  font-weight:700;
  color:var(--steel);
  letter-spacing:-.3px;
}
.trust-block-label{
  font-size:13px;
  color:rgba(255,255,255,.7);
  margin-top:4px;
}

/* ============ SECTIONS ============ */
.section{padding:80px 0}
.section-alt{background:var(--surface)}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.eyebrow{
  display:inline-block;
  color:var(--royal);
  font-size:12px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:14px;
}
.eyebrow-light{color:var(--steel)}
.section h2{
  font-size:38px;
  font-weight:700;
  color:var(--navy);
  line-height:1.15;
  letter-spacing:-.8px;
  margin-bottom:16px;
}
.section-sub{
  font-size:17px;
  color:var(--text-mid);
  line-height:1.6;
}

/* ============ SERVICE GRID ============ */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.service-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px;
  text-decoration:none;
  color:inherit;
  transition:all .25s;
  display:block;
}
.service-card:hover{
  border-color:var(--royal);
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(10,15,37,.08);
}
.service-card-alt{background:var(--navy);color:#fff;border-color:var(--navy)}
.service-card-alt h3{color:#fff}
.service-card-alt p{color:rgba(255,255,255,.75)}
.service-card-alt .service-link{color:var(--steel)}
.service-icon{font-size:36px;margin-bottom:16px}
.service-card h3{
  font-size:22px;
  font-weight:600;
  color:var(--navy);
  margin-bottom:10px;
  letter-spacing:-.3px;
}
.service-card p{
  font-size:15px;
  color:var(--text-mid);
  line-height:1.6;
  margin-bottom:18px;
}
.service-link{
  color:var(--royal);
  font-weight:500;
  font-size:14px;
}

/* ============ TWO-COL ============ */
.two-col{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
}
.two-col-text h2{margin-bottom:20px}
.two-col-text p{
  font-size:16px;
  color:var(--text-mid);
  margin-bottom:16px;
  line-height:1.7;
}
.checklist{list-style:none;margin:24px 0 32px}
.checklist li{
  padding:8px 0 8px 32px;
  position:relative;
  font-size:15px;
  color:var(--text-mid);
}
.checklist li::before{
  content:"✓";
  position:absolute;left:0;top:8px;
  color:var(--royal);
  font-weight:700;
  font-size:18px;
}
.stat-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px 24px;
  text-align:center;
}
.stat-num{
  font-size:36px;
  font-weight:800;
  color:var(--royal);
  letter-spacing:-1px;
  line-height:1;
}
.stat-label{
  font-size:14px;
  color:var(--slate);
  margin-top:8px;
  font-weight:500;
}

/* ============ REGION GRID ============ */
.region-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.region-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  padding:24px 16px;
  text-align:center;
  font-weight:500;
  color:var(--navy);
  transition:all .2s;
  cursor:default;
}
.region-card:hover{border-color:var(--royal);color:var(--royal);transform:translateY(-2px)}

/* ============ REVIEWS ============ */
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.review-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px;
}
.review-stars{
  color:#FFC107;
  font-size:18px;
  margin-bottom:14px;
  letter-spacing:2px;
}
.review-card p{
  font-size:15px;
  color:var(--text);
  line-height:1.6;
  margin-bottom:16px;
  font-style:italic;
}
.review-author{
  font-size:13px;
  color:var(--slate);
  font-weight:500;
}

/* ============ CTA SECTION ============ */
.section-cta{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  color:#fff;
}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cta-text h2{color:#fff;margin-bottom:16px}
.cta-text p{font-size:17px;color:rgba(255,255,255,.8);margin-bottom:32px;line-height:1.6}
.contact-info{display:flex;flex-direction:column;gap:8px;font-size:15px;color:rgba(255,255,255,.85)}
.contact-info a{color:var(--steel)}
.contact-info a:hover{color:#fff}

.cta-form{
  background:#fff;
  border-radius:14px;
  padding:32px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.cta-form input,.cta-form select,.cta-form textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:8px;
  font-family:inherit;
  font-size:15px;
  color:var(--text);
  background:#fff;
  transition:border-color .2s;
}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{
  outline:none;
  border-color:var(--royal);
  box-shadow:0 0 0 3px rgba(45,82,196,.1);
}
.cta-form textarea{margin-bottom:14px;resize:vertical}
.form-check{
  display:flex;
  align-items:flex-start;
  gap:8px;
  font-size:13px;
  color:var(--text-mid);
  margin-bottom:18px;
  line-height:1.5;
}
.form-check input{width:auto;margin-top:3px}
.form-check a{color:var(--royal)}

/* ============ FOOTER ============ */
.footer{
  background:var(--navy);
  color:rgba(255,255,255,.7);
  padding:64px 0 24px;
  font-size:14px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:48px;
}
.footer-brand p{margin:14px 0;color:rgba(255,255,255,.7);line-height:1.6}
.footer-logo{
  height:42px;
  width:auto;
  background:#fff;
  padding:8px 14px;
  border-radius:6px;
  margin-bottom:8px;
}
.footer-contact{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.footer-contact a{color:rgba(255,255,255,.85)}
.footer-contact .ico{margin-right:6px;color:var(--steel)}
.footer-col h4{
  color:#fff;
  font-size:15px;
  font-weight:600;
  margin-bottom:16px;
  letter-spacing:.3px;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{
  color:rgba(255,255,255,.7);
  font-size:14px;
  transition:color .2s;
}
.footer-col a:hover{color:#fff}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  color:rgba(255,255,255,.5);
  flex-wrap:wrap;
  gap:16px;
}
.footer-legal{display:flex;gap:24px;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.7);font-size:13px}
.footer-legal a:hover{color:#fff}

/* ============ LEGAL/SUBPAGES ============ */
.page-hero{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  color:#fff;
  padding:60px 0 50px;
  text-align:center;
}
.page-hero h1{
  font-size:42px;
  font-weight:700;
  margin-bottom:12px;
  letter-spacing:-.8px;
}
.page-hero p{font-size:17px;color:rgba(255,255,255,.8);max-width:640px;margin:0 auto}

.content-page{padding:60px 0 80px;max-width:840px;margin:0 auto}
.content-page h2{
  font-size:26px;
  font-weight:600;
  color:var(--navy);
  margin:36px 0 16px;
  letter-spacing:-.3px;
}
.content-page h3{
  font-size:18px;
  font-weight:600;
  color:var(--navy);
  margin:24px 0 10px;
}
.content-page p{
  font-size:16px;
  color:var(--text-mid);
  margin-bottom:14px;
  line-height:1.7;
}
.content-page ul{margin:8px 0 16px 24px;color:var(--text-mid)}
.content-page li{margin-bottom:6px;line-height:1.6}
.content-page a{color:var(--royal)}
.placeholder{
  background:#FFF8E1;
  border-left:3px solid #FFC107;
  padding:14px 18px;
  border-radius:6px;
  margin:14px 0;
  font-size:14px;
  color:#7A5A00;
  font-style:italic;
}

/* ============ KARRIERE / JOBS ============ */
.jobs-grid{display:grid;gap:16px;margin-top:32px}
.job-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:28px 32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  transition:all .2s;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.job-card:hover{
  border-color:var(--royal);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(10,15,37,.06);
}
.job-card-content{flex:1}
.job-tag{
  display:inline-block;
  background:var(--tint);
  color:var(--royal);
  padding:4px 12px;
  border-radius:99px;
  font-size:12px;
  font-weight:600;
  margin-bottom:10px;
}
.job-card h3{
  font-size:20px;
  font-weight:600;
  color:var(--navy);
  margin-bottom:6px;
}
.job-meta{
  display:flex;
  gap:18px;
  font-size:14px;
  color:var(--slate);
  flex-wrap:wrap;
}
.job-meta span{display:flex;align-items:center;gap:4px}
.job-cta{
  color:var(--royal);
  font-weight:500;
  white-space:nowrap;
  font-size:14px;
}

/* Job detail expandable */
.job-detail{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:40px;
  margin-top:32px;
  display:none;
}
.job-detail.open{display:block}
.job-detail h2{font-size:28px;color:var(--navy);margin-bottom:8px}
.job-detail .job-meta{margin-bottom:24px}
.job-detail h3{font-size:18px;color:var(--navy);margin:24px 0 10px;font-weight:600}
.job-detail ul{margin:8px 0 16px 24px;color:var(--text-mid)}
.job-detail li{margin-bottom:6px;line-height:1.6}
.job-detail .btn{margin-top:20px}

.no-jobs-note{
  background:var(--surface);
  border:1px dashed var(--border);
  border-radius:12px;
  padding:32px;
  text-align:center;
  color:var(--slate);
  font-style:italic;
  margin-top:24px;
}

/* ============ SERVICE DETAIL PAGES ============ */
.service-hero{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  color:#fff;
  padding:80px 0 70px;
}
.service-hero-inner{max-width:840px;margin:0 auto;text-align:center}
.service-hero h1{
  font-size:46px;
  font-weight:700;
  margin-bottom:16px;
  letter-spacing:-1px;
}
.service-hero p{font-size:18px;color:rgba(255,255,255,.85);line-height:1.6;margin-bottom:28px}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-top:40px;
}
.feature-item{
  display:flex;
  gap:16px;
  padding:24px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
}
.feature-icon{
  width:44px;height:44px;
  background:var(--tint);
  color:var(--royal);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  flex-shrink:0;
}
.feature-item h4{
  font-size:17px;
  color:var(--navy);
  margin-bottom:6px;
  font-weight:600;
}
.feature-item p{font-size:14px;color:var(--text-mid);line-height:1.6}

/* ============ SCHADENSMELDUNG ============ */
.schadenmeldung-form{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:40px;
  max-width:680px;
  margin:0 auto;
}
.schadenmeldung-form label{
  display:block;
  font-size:14px;
  font-weight:500;
  color:var(--navy);
  margin-bottom:6px;
  margin-top:18px;
}

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  .hero-inner,.two-col,.cta-inner{grid-template-columns:1fr;gap:40px}
  .hero h1{font-size:40px}
  .section h2{font-size:30px}
  .service-grid,.review-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr 1fr}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:1fr}
  .nav{display:none}
}
@media (max-width:600px){
  .topbar .container,.header-inner{flex-direction:column;align-items:flex-start;gap:8px}
  .hero{padding:40px 0 60px}
  .hero h1{font-size:32px}
  .section{padding:50px 0}
  .form-row{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left}
  .job-card{flex-direction:column;align-items:flex-start}
  .service-hero h1,.page-hero h1{font-size:32px}
}

/* ============ REGIONEN DETAIL ============ */
.region-detail-grid{display:flex;flex-direction:column;gap:20px}
.region-detail{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px 36px;
  scroll-margin-top:120px;
}
.region-detail h2{font-size:24px;font-weight:600;color:var(--navy);margin-bottom:12px}
.region-detail p{color:var(--text-mid);line-height:1.7;margin-bottom:20px}

/* ============ JOB CARD ARROW ============ */
.job-card{display:flex;align-items:center;gap:24px;cursor:pointer;transition:all .2s;margin-bottom:16px}
.job-card-arrow{
  font-size:24px;
  color:var(--royal);
  flex-shrink:0;
  transition:transform .2s;
}
.job-card:hover .job-card-arrow{transform:translateX(4px)}
.job-meta{display:flex;gap:8px;flex-wrap:wrap}
