/* Start custom CSS for html, class: .elementor-element-f12ffe1 *//* ===== PRACOMF Full Width Hero ===== */
.pc-hero{
  position: relative;
  width: 100vw;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin-left: calc(-50vw + 50%);
}

/* Hintergrundbild */
.pc-hero__bg{
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(
      to right,
      rgba(0,0,0,.45) 0%,
      rgba(0,0,0,.25) 40%,
      rgba(0,0,0,.15) 100%
    ),
    url("https://pracomf.de/wp-content/uploads/2026/01/Sonnenschutz_header.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(1.05);
  z-index: 0;
}

/* Inhalt */
.pc-hero__content{
  position: relative;
  z-index: 1;
  max-width: 1200px;
  width: 100%;
  padding: 60px 24px;
}

/* Headline */
.pc-hero__content h1{
  margin: 0 0 10px 0;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.15;
  font-weight: 800;
  color: #fff;
}

/* Subline */
.pc-hero__content p{
  margin: 0;
  font-size: clamp(16px, 1.6vw, 20px);
  line-height: 1.6;
  color: rgba(255,255,255,.92);
  max-width: 620px;
}

/* Mobile Feinschliff */
@media (max-width: 768px){
  .pc-hero{
    min-height: 360px;
  }

  .pc-hero__content{
    padding: 48px 20px;
  }
}

.elementor-column-gap-default>.elementor-column>.elementor-element-populated{padding: 0px;}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-56fab8d *//* ===== Modern Soft-Blue Info Card ===== */
.pc-dim-card{
    
    margin-top: 30px;
  --brand: #0A5F72;                 /* dein Petrol/Blau */
  --blue-50: #F3F8FF;               /* sehr helles Blau */
  --blue-100: #E6F1FF;              /* helles Blau */
  --border: rgba(10,95,114,.18);
  --muted: #777;

  display: flex;
  gap: 14px;
  align-items: flex-start;

  width: 100%;
  box-sizing: border-box;

  /* moderner Look */
  background: linear-gradient(180deg, var(--blue-50), #ffffff);
  border: 1px solid rgba(10,95,114,.16);
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .06);
  padding: 18px 20px;
}

/* Icon modern (gefüllt, weich, mit Ring) */
.pc-dim-icon{
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 999px;

  background: radial-gradient(circle at 30% 30%, rgba(10,95,114,.25), rgba(10,95,114,.10));
  color: var(--brand);

  display: grid;
  place-items: center;

  font-weight: 900;
  font-size: 14px;
  line-height: 1;

  border: 1px solid rgba(10,95,114,.22);
  box-shadow: 0 6px 16px rgba(10,95,114,.12);
}

/* Typo: klare Hierarchie */
.pc-dim-text{
  font-size: 14px;
  line-height: 1.55;
  color: #0f172a;
}

.pc-dim-text strong{
  font-weight: 800;
}

.pc-dim-muted{
  display: block;                   /* wirkt moderner als Inline */
  margin-top: 6px;
  color: #64748b;                   /* moderner als #777 */
  font-size: 13px;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2fdf129 *//* ===== PRACOMF Intro Section (Text + Bild) ===== */
.pc-intro{
  --brand: #0A5F72;              /* ggf. wie vorher feinjustieren */
  --muted: #777;                  /* kleiner Text */
  --text: #0f172a;

  padding: 10px 0;               /* passt sich an deine Sektionen an */
}

.pc-intro__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: start;
  width: 100%;
}

@media (min-width: 900px){
  .pc-intro__grid{
    grid-template-columns: 1.05fr .95fr;
    gap: 28px;
    align-items: start;    /* ✅ Text startet ganz oben */
  }
}

.pc-intro__title{
  margin: 0 0 10px 0;
  font-size: 26px;
  line-height: 1.2;
  font-weight: 800;
  color: #0b0b0b;                /* wie in deinem Screenshot */
}

.pc-intro__p{
  margin: 0 0 14px 0;
  font-size: 15px;
  line-height: 1.75;
  color: #444;                   /* gut lesbar, aber weich */
}

.pc-intro__p:last-child{
  margin-bottom: 0;
}

/* Bild-Card wie deine UI */
.pc-intro__media{
  margin: 0;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(10,95,114,.18);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}

.pc-intro__media img{
  width: 100%;
  height: auto;
  display: block;
}

/* Optional: auf Mobile Bild nach oben */
@media (max-width: 899px){
  .pc-intro__media{
    order: -1;                   /* Bild zuerst, dann Text */
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-37d657e *//* ===== PRACOMF Swatches – Style wie B2B Card ===== */
.pc-swatches{
  /* Stell hier deinen Brand-Blau Ton ein */
  --brand: #0A5F72;        /* <- ggf. minimal anpassen */
  --brand-soft: rgba(10,95,114,.10);
  --border: rgba(10,95,114,.18);
  --text: #0f172a;
  --muted: #777;           /* wie gewünscht */
  --bg: #fff;
  --shadow: 0 10px 30px rgba(0,0,0,.06);
  --radius: 16px;
}

.pc-card{
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
  margin: 0 auto;
}

.pc-head h3{
  margin: 0 0 6px 0;
  font-size: 22px;
  line-height: 1.2;
  color: var(--brand);
  font-weight: 700;
}

.pc-sub{
  margin: 0 0 18px 0;
  font-size: 14px;
  color: var(--muted);
}

.pc-swatch-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 768px){
  .pc-swatch-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (min-width: 1024px){
  .pc-swatch-grid{ grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

.pc-swatch{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 14px 12px;
  display: grid;
  justify-items: start;
  gap: 6px;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}

.pc-swatch:hover{
  border-color: var(--border);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
  transform: translateY(-1px);
}

.pc-dot{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--c);
  border: 1px solid rgba(0,0,0,.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.35);
  position: relative;
}

.pc-dot::after{
  content:"";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--texture, transparent);
  opacity: .55;
}

.pc-code{
  font-weight: 700;
  font-size: 12px;
  color: var(--text);
  line-height: 1.2;
}

.pc-name{
  font-size: 12px;
  color: var(--muted);
  line-height: 1.2;
}

.pc-note{
  margin: 14px 0 0 0;
  font-size: 12px;
  color: var(--muted);
  border-top: 1px solid rgba(10,95,114,.12);
  padding-top: 12px;
}/* End custom CSS */