/* ============================================================
   Markisenwelt24 — main.css
   Frontpage + Kunden-Dashboard
   Keine externen Abhängigkeiten — alles lokal
   ============================================================ */

/* ── VARIABLEN ───────────────────────────────────────────────── */
:root {
    --orange:     #f15b26;
    --orange-dk:  #d44d1e;
    --orange-glow:rgba(241,91,38,.15);
    --teal:       #4cc2c0;
    --teal-dk:    #3aada9;
    --dark:       #1a1a2e;
    --dark2:      #16213e;
    --text:       #1a1a2e;
    --text2:      #4a5568;
    --muted:      #718096;
    --bg:         #f8f9fc;
    --white:      #ffffff;
    --border:     #e2e8f0;
    --border2:    #cbd5e0;
    --green:      #38a169;
    --green-bg:   rgba(56,161,105,.08);
    --red:        #e53e3e;
    --red-bg:     rgba(229,62,62,.08);
    --radius:     10px;
    --radius-lg:  16px;
    --shadow:     0 4px 24px rgba(0,0,0,.08);
    --shadow-lg:  0 8px 40px rgba(0,0,0,.12);
    --t:          .2s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--orange);text-decoration:none;transition:color var(--t);}
a:hover{color:var(--orange-dk);}
ul{list-style:none;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ── HEADER ──────────────────────────────────────────────────── */
.site-header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:var(--white);
    border-bottom:1px solid var(--border);
    box-shadow:0 2px 12px rgba(0,0,0,.06);
    height:70px;
}
.header-spacer{height:70px;}
.header-inner{
    max-width:1200px;margin:0 auto;
    padding:0 24px;height:70px;
    display:flex;align-items:center;justify-content:space-between;
    gap:16px;
}
.header-logo img{height:42px;object-fit:contain;width:auto;}

/* ── NAVIGATION ──────────────────────────────────────────────── */
.main-nav ul{display:flex;align-items:center;gap:4px;}
.main-nav li{}
.main-nav a{
    display:block;padding:8px 14px;
    font-size:15px;font-weight:500;color:var(--text2);
    border-radius:8px;transition:all var(--t);
}
.main-nav a:hover{background:var(--bg);color:var(--text);}
.main-nav li.active a{color:var(--orange);font-weight:600;}
.nav-btn{padding:9px 20px !important;border-radius:8px !important;font-weight:600 !important;}
.nav-btn-primary{background:var(--orange) !important;color:#fff !important;}
.nav-btn-primary:hover{background:var(--orange-dk) !important;box-shadow:0 4px 14px var(--orange-glow);}
.nav-btn-outline{border:1px solid var(--border) !important;color:var(--text2) !important;}
.nav-btn-outline:hover{border-color:var(--red) !important;color:var(--red) !important;}
.nav-company{font-size:13px;color:var(--muted);padding:0 8px;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:all var(--t);}

/* ── COOKIE BANNER ───────────────────────────────────────────── */
#cookie-banner{
    position:fixed;bottom:0;left:0;right:0;z-index:9999;
    background:rgba(26,26,46,.97);backdrop-filter:blur(8px);
    border-top:1px solid rgba(255,255,255,.1);
    padding:16px 24px;
}
.cookie-inner{
    max-width:1200px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;
    gap:16px;flex-wrap:wrap;
}
.cookie-inner p{font-size:14px;color:#cbd5e0;flex:1;}
.cookie-inner a{color:var(--teal);}
.cookie-btns{display:flex;gap:8px;flex-shrink:0;}
.cookie-accept,.cookie-reject{
    padding:8px 18px;border-radius:7px;border:none;
    font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;
}
.cookie-accept{background:var(--orange);color:#fff;}
.cookie-accept:hover{background:var(--orange-dk);}
.cookie-reject{background:rgba(255,255,255,.1);color:#cbd5e0;border:1px solid rgba(255,255,255,.15);}
.cookie-reject:hover{background:rgba(255,255,255,.15);}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:12px 24px;border-radius:var(--radius);border:none;
    font-size:15px;font-weight:600;cursor:pointer;
    font-family:inherit;text-decoration:none;
    transition:all var(--t);white-space:nowrap;
}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 4px 14px var(--orange-glow);}
.btn-primary:hover{background:var(--orange-dk);box-shadow:0 6px 20px var(--orange-glow);transform:translateY(-1px);color:#fff;}
.btn-teal{background:var(--teal);color:#fff;}
.btn-teal:hover{background:var(--teal-dk);transform:translateY(-1px);color:#fff;}
.btn-outline{background:transparent;color:var(--orange);border:2px solid var(--orange);}
.btn-outline:hover{background:var(--orange);color:#fff;}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark:hover{background:var(--dark2);color:#fff;transform:translateY(-1px);}
.btn-lg{padding:15px 32px;font-size:17px;border-radius:12px;}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:7px;}
.btn-full{width:100%;}

/* ── HERO ────────────────────────────────────────────────────── */
.hero{
    background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 50%,#0f3460 100%);
    padding:72px 24px 60px;
    position:relative;overflow:hidden;
}
.hero::before{
    content:'';position:absolute;inset:0;
    background:url('/assets/img/spring-276014_1920.jpg') center/cover no-repeat;
    opacity:.15;
}
.hero-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1;}
.hero-content{max-width:600px;}
.hero-tag{
    display:inline-flex;align-items:center;gap:6px;
    background:rgba(241,91,38,.15);color:var(--orange);
    border:1px solid rgba(241,91,38,.3);
    border-radius:999px;padding:5px 14px;
    font-size:13px;font-weight:600;margin-bottom:20px;
    text-transform:uppercase;letter-spacing:.06em;
}
.hero h1{
    font-size:clamp(28px,4vw,52px);
    font-weight:800;color:#fff;
    line-height:1.15;letter-spacing:-.5px;
    margin-bottom:20px;
}
.hero h1 span{color:var(--orange);}
.hero p{
    font-size:18px;color:rgba(255,255,255,.75);
    margin-bottom:32px;line-height:1.65;
    max-width:520px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px;}
.hero-trust{
    display:flex;align-items:center;gap:20px;
    flex-wrap:wrap;
}
.trust-item{
    display:flex;align-items:center;gap:8px;
    font-size:13px;color:rgba(255,255,255,.65);font-weight:500;
}
.trust-item .dot{
    width:8px;height:8px;border-radius:50%;
    background:var(--teal);flex-shrink:0;
}

/* ── FORMULAR-BEREICH ────────────────────────────────────────── */
.lead-form-section{
    background:var(--bg);
    padding:64px 24px;
}
.lead-form-section .section-inner{
    max-width:900px;margin:0 auto;
}
.lead-form-card{
    background:var(--white);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);
    overflow:hidden;
}
.form-card-header{
    background:linear-gradient(135deg,var(--orange),var(--orange-dk));
    padding:24px 32px;color:#fff;
}
.form-card-header h2{font-size:22px;font-weight:700;margin-bottom:4px;}
.form-card-header p{font-size:14px;opacity:.85;}

/* Schritt-Indikatoren */
.steps{display:flex;gap:0;border-bottom:1px solid var(--border);}
.step{
    flex:1;padding:14px 16px;text-align:center;
    font-size:13px;font-weight:600;color:var(--muted);
    border-bottom:3px solid transparent;
    transition:all var(--t);cursor:default;
    display:flex;align-items:center;justify-content:center;gap:8px;
}
.step.active{color:var(--orange);border-bottom-color:var(--orange);}
.step.done{color:var(--green);border-bottom-color:var(--green);}
.step-num{
    width:24px;height:24px;border-radius:50%;
    background:var(--bg);
    display:flex;align-items:center;justify-content:center;
    font-size:12px;font-weight:700;flex-shrink:0;
}
.step.active .step-num{background:var(--orange);color:#fff;}
.step.done .step-num{background:var(--green);color:#fff;}

/* Formular Tabs */
.form-tab{display:none;padding:32px;}
.form-tab.active{display:block;}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{margin-bottom:18px;}
.form-group label{
    display:block;font-size:12px;font-weight:600;
    color:var(--text2);text-transform:uppercase;
    letter-spacing:.07em;margin-bottom:6px;
}
.form-group input,
.form-group select,
.form-group textarea{
    width:100%;background:var(--bg);
    border:1.5px solid var(--border);border-radius:8px;
    padding:11px 14px;font-size:15px;color:var(--text);
    font-family:inherit;outline:none;
    transition:border-color var(--t),box-shadow var(--t);
    appearance:none;-webkit-appearance:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
    border-color:var(--orange);
    box-shadow:0 0 0 3px var(--orange-glow);
    background:var(--white);
}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23718096' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;}
.form-group textarea{min-height:100px;resize:vertical;}
.form-group .error-text{font-size:12px;color:var(--red);margin-top:4px;display:none;}
.form-group.has-error input,.form-group.has-error select{border-color:var(--red);}
.form-group.has-error .error-text{display:block;}

.agb-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:20px;}
.agb-row input[type="checkbox"]{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:var(--orange);}
.agb-row label{font-size:14px;color:var(--text2);cursor:pointer;}
.agb-row a{color:var(--orange);}

.form-nav{
    display:flex;justify-content:space-between;align-items:center;
    padding:16px 32px;border-top:1px solid var(--border);
    background:var(--bg);
}
.progress-wrap{flex:1;margin:0 20px;}
.progress-bar-outer{background:var(--border);border-radius:999px;height:6px;overflow:hidden;}
.progress-bar-inner{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-dk));border-radius:999px;transition:width .4s ease;}
.progress-text{font-size:12px;color:var(--muted);text-align:center;margin-top:4px;}

/* ── SECTIONS ────────────────────────────────────────────────── */
section{padding:72px 24px;}
.container{max-width:1200px;margin:0 auto;}
.section-title{
    font-size:clamp(24px,3vw,38px);font-weight:800;
    color:var(--text);letter-spacing:-.5px;
    margin-bottom:12px;
}
.section-sub{font-size:18px;color:var(--muted);margin-bottom:48px;line-height:1.6;}
.text-center{text-align:center;}
.heading-line{
    display:flex;align-items:center;justify-content:center;gap:8px;
    margin-bottom:48px;
}
.heading-line .line{height:3px;border-radius:2px;}
.heading-line .line-short{width:32px;background:var(--orange);}
.heading-line .line-long{width:80px;background:var(--teal);}

/* Benefits-Grid */
.benefits-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:24px;
}
.benefit-card{
    background:var(--white);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:28px 24px;
    position:relative;overflow:hidden;
    transition:all var(--t);
}
.benefit-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,var(--orange),var(--teal));
    opacity:0;transition:opacity var(--t);
}
.benefit-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:transparent;}
.benefit-card:hover::before{opacity:1;}
.benefit-icon{
    width:52px;height:52px;border-radius:12px;
    background:linear-gradient(135deg,var(--orange),var(--orange-dk));
    display:flex;align-items:center;justify-content:center;
    font-size:24px;color:#fff;margin-bottom:16px;
    box-shadow:0 4px 14px var(--orange-glow);
}
.benefit-card h3{font-size:17px;font-weight:700;margin-bottom:8px;}
.benefit-card p{font-size:14px;color:var(--muted);line-height:1.65;}

/* Produkte-Grid */
.products-section{background:var(--bg);}
.products-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:16px;
}
.product-card{
    background:var(--white);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:24px 20px;text-align:center;
    transition:all var(--t);cursor:pointer;
}
.product-card:hover{border-color:var(--orange);box-shadow:0 4px 20px var(--orange-glow);transform:translateY(-2px);}
.product-card .product-icon{font-size:36px;margin-bottom:12px;}
.product-card h3{font-size:15px;font-weight:600;color:var(--text);}
.product-card p{font-size:13px;color:var(--muted);margin-top:4px;}

/* So funktioniert es */
.how-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:32px;
    counter-reset:step-counter;
}
.how-item{text-align:center;counter-increment:step-counter;}
.how-num{
    width:56px;height:56px;border-radius:50%;
    background:linear-gradient(135deg,var(--orange),var(--orange-dk));
    display:flex;align-items:center;justify-content:center;
    font-size:22px;font-weight:800;color:#fff;
    margin:0 auto 16px;
    box-shadow:0 4px 16px var(--orange-glow);
}
.how-item h3{font-size:17px;font-weight:700;margin-bottom:8px;}
.how-item p{font-size:14px;color:var(--muted);line-height:1.65;}
.how-connector{
    display:none;
}

/* Stats-Leiste */
.stats-bar{
    background:linear-gradient(135deg,var(--dark),var(--dark2));
    padding:48px 24px;
}
.stats-inner{
    max-width:1000px;margin:0 auto;
    display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:32px;
}
.stat-item{text-align:center;color:#fff;}
.stat-number{font-size:clamp(32px,4vw,48px);font-weight:800;color:var(--orange);}
.stat-label{font-size:14px;color:rgba(255,255,255,.65);margin-top:4px;}

/* CTA-Section */
.cta-section{
    background:linear-gradient(135deg,var(--orange),var(--orange-dk));
    padding:64px 24px;text-align:center;color:#fff;
}
.cta-section h2{font-size:clamp(24px,3vw,38px);font-weight:800;margin-bottom:12px;}
.cta-section p{font-size:18px;opacity:.9;margin-bottom:32px;}
.cta-section .btn-dark{background:#fff;color:var(--orange);}
.cta-section .btn-dark:hover{background:var(--bg);color:var(--orange-dk);}

/* ── FOOTER ──────────────────────────────────────────────────── */
.site-footer{background:var(--dark);color:rgba(255,255,255,.8);}
.footer-inner{
    max-width:1200px;margin:0 auto;
    padding:56px 24px 40px;
    display:grid;grid-template-columns:1fr 2fr;gap:64px;
}
.footer-logo img{height:36px;object-fit:contain;filter:brightness(1.2);margin-bottom:12px;}
.footer-logo p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.6;}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.footer-col h4{font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;}
.footer-col ul li{margin-bottom:9px;}
.footer-col a{font-size:14px;color:rgba(255,255,255,.6);transition:color var(--t);}
.footer-col a:hover{color:var(--orange);}
.footer-bottom{
    background:rgba(0,0,0,.3);
    text-align:center;padding:16px 24px;
    font-size:13px;color:rgba(255,255,255,.4);
}

/* ── DASHBOARD ───────────────────────────────────────────────── */
.dash-layout{display:flex;min-height:calc(100vh - 70px);}
.dash-sidebar{
    width:240px;flex-shrink:0;
    background:var(--white);border-right:1px solid var(--border);
    padding:24px 12px;
    position:sticky;top:70px;height:calc(100vh - 70px);
    overflow-y:auto;
}
.dash-nav a{
    display:flex;align-items:center;gap:10px;
    padding:10px 14px;border-radius:var(--radius);
    font-size:14px;font-weight:500;color:var(--text2);
    margin-bottom:2px;transition:all var(--t);
}
.dash-nav a:hover{background:var(--bg);color:var(--text);}
.dash-nav a.active{background:var(--orange);color:#fff;}
.dash-nav .nav-section{
    font-size:10px;font-weight:700;color:var(--muted);
    text-transform:uppercase;letter-spacing:.1em;
    padding:12px 14px 5px;
}
.dash-main{flex:1;padding:28px;background:var(--bg);}
.dash-topbar{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:24px;
}
.dash-topbar h1{font-size:22px;font-weight:700;}
.credits-chip{
    background:var(--white);border:1px solid var(--border);
    border-radius:999px;padding:7px 16px;
    font-size:14px;font-weight:600;
    display:flex;align-items:center;gap:6px;
}
.credits-chip .amount{color:var(--green);}

/* Leads-Tabelle */
.leads-table-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.leads-table-head{
    padding:14px 20px;border-bottom:1px solid var(--border);
    display:flex;align-items:center;justify-content:space-between;
}
.leads-table-head h3{font-size:15px;font-weight:600;}
.tab-nav{display:flex;gap:2px;background:var(--bg);border-radius:8px;padding:3px;}
.tab-nav a{
    padding:6px 14px;border-radius:6px;
    font-size:13px;font-weight:500;color:var(--muted);
    transition:all var(--t);
}
.tab-nav a.active{background:var(--white);color:var(--text);box-shadow:var(--shadow);}
.leads-table table{width:100%;border-collapse:collapse;}
.leads-table th{
    font-size:11px;text-transform:uppercase;letter-spacing:.08em;
    color:var(--muted);padding:10px 16px;border-bottom:1px solid var(--border);
    text-align:left;background:var(--bg);font-weight:600;
}
.leads-table td{
    padding:12px 16px;font-size:14px;color:var(--text);
    border-bottom:1px solid var(--border);vertical-align:middle;
}
.leads-table tr:last-child td{border-bottom:none;}
.leads-table tr:hover td{background:var(--bg);}
.badge{
    display:inline-flex;align-items:center;
    padding:3px 9px;border-radius:999px;
    font-size:12px;font-weight:600;
}
.badge-new{background:rgba(76,194,192,.1);color:var(--teal);border:1px solid rgba(76,194,192,.2);}
.badge-bought{background:var(--green-bg);color:var(--green);border:1px solid rgba(56,161,105,.2);}
.badge-ignored{background:rgba(113,128,150,.1);color:var(--muted);border:1px solid var(--border);}
.badge-complained{background:var(--red-bg);color:var(--red);border:1px solid rgba(229,62,62,.2);}
.btn-buy{
    background:var(--orange);color:#fff;
    border:none;border-radius:7px;padding:7px 14px;
    font-size:13px;font-weight:600;cursor:pointer;
    font-family:inherit;transition:all var(--t);
}
.btn-buy:hover{background:var(--orange-dk);}
.btn-view{
    background:var(--bg);color:var(--text2);
    border:1px solid var(--border);border-radius:7px;padding:7px 14px;
    font-size:13px;font-weight:600;cursor:pointer;
    font-family:inherit;transition:all var(--t);
}
.btn-view:hover{border-color:var(--border2);color:var(--text);}

/* ── ALERTS ──────────────────────────────────────────────────── */
.alert{padding:13px 18px;border-radius:var(--radius);font-size:14px;margin-bottom:18px;display:flex;align-items:center;gap:10px;font-weight:500;}
.alert-error{background:var(--red-bg);border:1px solid rgba(229,62,62,.2);color:var(--red);}
.alert-success{background:var(--green-bg);border:1px solid rgba(56,161,105,.2);color:var(--green);}
.alert-info{background:rgba(76,194,192,.08);border:1px solid rgba(76,194,192,.2);color:var(--teal-dk);}

/* ── MODALS ──────────────────────────────────────────────────── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:2000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);}
.modal-bg.open{display:flex;}
.modal{background:var(--white);border-radius:var(--radius-lg);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;padding:32px;position:relative;box-shadow:var(--shadow-lg);}
.modal-close{position:absolute;top:16px;right:16px;background:var(--bg);border:1px solid var(--border);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--muted);transition:all var(--t);}
.modal-close:hover{background:var(--red-bg);border-color:var(--red);color:var(--red);}
.modal h3{font-size:19px;font-weight:700;margin-bottom:20px;}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;}
.modal-field label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:3px;font-weight:600;}
.modal-field p{font-size:14px;color:var(--text);}
.modal-field.full{grid-column:1/-1;}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
    .footer-inner{grid-template-columns:1fr;gap:40px;}
    .footer-links{grid-template-columns:repeat(3,1fr);}
    .dash-sidebar{width:200px;}
}
@media(max-width:768px){
    .main-nav{
        display:none;position:fixed;top:70px;left:0;right:0;
        background:var(--white);border-bottom:1px solid var(--border);
        padding:16px;flex-direction:column;
        box-shadow:var(--shadow-lg);
    }
    .main-nav.open{display:flex;}
    .main-nav ul{flex-direction:column;width:100%;}
    .main-nav a{width:100%;padding:12px 16px;}
    .nav-toggle{display:flex;}
    .hero-actions{flex-direction:column;}
    .hero-actions .btn{width:100%;justify-content:center;}
    .form-row-2{grid-template-columns:1fr;}
    .form-tab{padding:20px 16px;}
    .form-nav{padding:12px 16px;}
    .footer-links{grid-template-columns:1fr 1fr;}
    .stats-inner{grid-template-columns:1fr 1fr;}
    .dash-layout{flex-direction:column;}
    .dash-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--border);}
    .dash-nav ul{display:flex;flex-wrap:wrap;gap:4px;}
    .dash-main{padding:16px;}
}
@media(max-width:480px){
    .cookie-inner{flex-direction:column;}
    .footer-links{grid-template-columns:1fr;}
    .modal-grid{grid-template-columns:1fr;}
    .steps{overflow-x:auto;}
    .step span:not(.step-num){display:none;}
}

/* ── Formular-Fehlerklassen ─────────────────────────────────────────────── */
.error-text{display:none;font-size:12px;color:#dc2626;margin-top:4px;font-weight:500;}
.form-group.has-error input,
.form-group.has-error select,
.form-group.has-error textarea{border-color:#dc2626!important;background:rgba(220,38,38,.04);}
.form-group.has-error .error-text{display:block;}
