/*
Theme Name: Neve Child
Template: neve
Version: 1.0
*/

.builder-item--nav-icon, .nav-menu-primary  
{
display: none !Important;
}

.hfg_footer, .hfg_footer p
{
font-size:.9rem !Important;
}

@font-face {
    font-family: 'ProximaNova';
    src: url('../fonts/Proxima_Nova_Regular.otf') format('otf');
}


.neve-main
{
flex: 1 1 0 !important;
}

 

html {
  font-size: 16px;
}


/* CF7 Layout */

/* ==============================
   WRAPPER = 2 SPALTEN LAYOUT
   ============================== */
   
   textarea, .wpcf7-textarea, input, select
   {
   width:100% !Important;
   }
   
.cf7-wrapper {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 40px;
	margin-top:1rem !important;
}

@media (max-width: 768px) {
    .cf7-wrapper {
        grid-template-columns: 1fr;
    }
    .cf7-right { order: 1; }
    .cf7-left { order: 2; }
}

/* ==============================
   LINKER BEREICH = FORMULAR
   ============================== */
.cf7-row {
    display: grid;
    gap: 20px;
	width:100%;
    
}

.cf7-2col {
    grid-template-columns: 1fr 1fr;
}

@media (max-width: 768px) {
    .cf7-2col {
        grid-template-columns: 1fr;
    }
}

/* Pflichtstern */
.required {
    color: red;
    margin-left: 4px;
}

/* ==============================
   RECHTE BEREICH = OPTIONEN
   ============================== */
.cf7-right {
    position: static; /* kein sticky mehr */
}

.wpcf7-list-item
{
width: 100% !important;
  margin: .5rem 0 !important;
}

.wpcf7 label
{
color:#333 !important
}


.radio-cards .wpcf7-list-item-label {
    display: flex;
    flex-direction: row;   /* Radio links, Text rechts */
    align-items: center;   /* Vertikal zentriert */
    padding: 12px 16px;
    border: 2px solid #ddd;
    border-radius: 10px;
    cursor: pointer;
    gap: 12px;
    transition: all 0.2s;
}

.radio-cards .wpcf7-list-item-label input[type="radio"] {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    margin: 0;
}

.radio-cards .card-content {
    display: flex;
    flex-direction: column;
}

.radio-cards .option-label {
    font-weight: 900;
	font-size:1.3rem !Important;
}

.radio-cards .option-subtext {
    font-size: 0.85em;
    color: #666;
	font-weight: normal;
}

/* Hover + Checked */
.radio-cards .wpcf7-list-item-label:hover,
.wpcf7-list-item-label .radio-cards .wpcf7-list-item-label input[type="radio"]:checked + .card-content {
    border-color: #000;
    background: #ebebeb  !important;
    box-shadow: 0 3px 8px rgba(0,0,0,0.08);
}





/* =========================================
   🌴 IBIZA TYPOGRAPHY SYSTEM
   Proxima Nova Base + Serif Accent
   ========================================= */

/* ========== FONTS ========== */
:root {
  --font-sans: "ProximaNova", "Inter", system-ui, -apple-system, sans-serif;
  --font-serif: "Canela", "Editorial New", "Georgia", serif;
}

/* ========== BASE ========== */
html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-sans)  !important;
  font-weight: 300;
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: #111;
  background-color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.site-logo a
{
border:0 !Important;
}


/* =========================================
   HEADINGS
   ========================================= */

/* HERO / H1 */
h1 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(2.8rem, 5vw, 5rem);
  line-height: 1.05;
  letter-spacing: -0.05em;
  margin: 0 0 1.5rem 0;
}

/* SECTION HEADLINES / H2 */
h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 1.15;
  letter-spacing: -0.05em;
  margin: 0 0 1.25rem 0;
}

/* SUB SECTIONS / H3 */
h3 {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.3;
  letter-spacing: -0.05em;
  margin: 0 0 1rem 0;
}

/* SMALL SECTIONS / H4 */
h4 {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.4;
  margin: 0 0 0.75rem 0;
}

/* UI LABELS / H5 */
h5 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 0.5rem 0;
}

/* MICRO LABELS / H6 */
h6 {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.6;
  margin: 0 0 0.5rem 0;
}

/* =========================================
   BODY TEXT
   ========================================= */

p {
  font-size: 1rem;
  line-height: 1.7;
  font-weight: 300;
  margin: 0 0 1rem 0;
}

/* LARGE INTRO TEXT */
.lead {
  font-size: 1.25rem;
  line-height: 1.6;
  font-weight: 300;
  max-width: 60ch;
}

/* SMALL UI TEXT */
.small {
  font-size: 0.875rem;
  line-height: 1.6;
  opacity: 0.75;
}

/* =========================================
   LINKS
   ========================================= */

a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.2);
  transition: opacity 0.2s ease;
}

a:hover {
  opacity: 0.7;
}

/* =========================================
   TEXT UTILITIES
   ========================================= */

/* Uppercase spacing label */
.label {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.7;
}

/* Centered text */
.text-center {
  text-align: center;
}

/* Muted text */
.muted {
  opacity: 0.6;
}

/* =========================================
   TYPOGRAPHY RULES (GLOBAL FEEL)
   ========================================= */

/*
  DESIGN PRINCIPLES:
  - Serif nur für Emotion (H1/H2)
  - Sans für alles Funktionale
  - Viel Luft statt Gewicht
  - Tracking für Premium Feel
  - Keine harten Kontraste
*/

p {
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 2rem;
}

/* Layout */
section {
  padding: 7.5rem 1.25rem;
}

.container {
  max-width: 68.75rem;
  margin: 0 auto;
}

/* Buttons */
.so-widget-button a,
button {
  background-color: #296D98;
  color: #fff;
  padding: 0.875rem 1.75rem;
  border-radius: 0.5rem;
  text-decoration: none;
}

.so-widget-button a:hover,
button:hover {
  background-color: #245a7d;
}

/* Cards */
.card {
  background: #ffffff;
  padding: 2rem;
  border-radius: 0.625rem;
}