/*
Theme Name: FS
Description: Orthopädie Onepager Theme (Customizer-ready, flexible)
Version: 1.3.2
Author: FS
Text Domain: orthopadie-fix
*/

* { margin:0; padding:0; box-sizing:border-box; }
:root { --primary:#2c5530; --accent:#d4af37; --text:#333; --bg:#f8f9fa; --white:#fff; }
body { font-family:'Segoe UI', Arial, sans-serif !important; line-height:1.6; color:var(--text); background:var(--white); }
.container { max-width:1200px; margin:0 auto; padding:0 20px; }

.main-header { background:linear-gradient(135deg, var(--primary), #1e3a21); color:#fff; padding:15px 0; position:fixed; top:0; left:0; right:0; z-index:1000; box-shadow:0 2px 10px rgba(0,0,0,.1); }
.header-content { display:flex; justify-content:space-between; align-items:center; }
.logo { font-size:24px; font-weight:700; color:var(--accent); }
.main-nav ul { list-style:none; display:flex; gap:30px; }
.main-nav a { color:#fff; text-decoration:none; font-weight:500; transition:color .3s; }
.main-nav a:hover { color:var(--accent); }

.hero-section { min-height:100vh; background:linear-gradient(rgba(44,85,48,.8), rgba(30,58,33,.8)), #2c5530; display:flex; align-items:center; justify-content:center; text-align:center; color:#fff; }
.hero-content h1 { font-size:48px; margin-bottom:20px; font-weight:700; }
.hero-content .subtitle { font-size:20px; margin-bottom:20px; opacity:.9; }
.hero-notices { display:grid; gap:12px; margin:10px auto 20px; max-width:760px; text-align:left; }
.hero-notice { background:rgba(255,255,255,.10); border-left:4px solid var(--accent); padding:12px 16px; border-radius:10px; color:#fff; }
.hero-notice h4 { margin:0 0 6px; color:var(--accent); font-size:18px; }
.hero-notice .hn-body p { margin:0 0 8px; }
.hero-notice a { color:#fff; text-decoration:underline; }

.cta-btn { background:var(--accent); color:var(--text); padding:15px 30px; text-decoration:none; border-radius:25px; font-weight:700; font-size:18px; display:inline-block; transition:transform .3s; cursor:pointer; }
.cta-btn:hover { transform:translateY(-2px); }

.content-section { padding:80px 0; }
.section-title { text-align:center; font-size:40px; margin-bottom:50px; color:var(--primary); position:relative; }
.section-title:after { content:''; width:60px; height:4px; background:var(--accent); display:block; margin:20px auto 0; }

.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-text { font-size:18px; line-height:1.8; }
.about-text h3 { color:var(--primary); margin-bottom:20px; font-size:24px; }
.about-image { height:400px; background:linear-gradient(45deg, #8b4513, var(--primary)); border-radius:20px; display:flex; align-items:center; justify-content:center; font-size:60px; color:#fff; background-size:cover; background-position:center; background-repeat:no-repeat; position:relative; }
.about-image span { opacity:.3; }

.services-section { background:var(--bg); }
.services-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:30px; }
.service-card { background:#fff; padding:40px 30px; border-radius:15px; text-align:center; box-shadow:0 10px 30px rgba(0,0,0,.1); transition:transform .3s; }
.service-card:hover { transform:translateY(-5px); }
.service-icon { font-size:50px; color:var(--accent); margin-bottom:20px; }
.service-card h3 { color:var(--primary); margin-bottom:15px; font-size:22px; }

.process-section { background:var(--bg); }
.process-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:30px; }
.process-step { background:#fff; padding:30px 25px 25px; border-radius:15px; box-shadow:0 10px 30px rgba(0,0,0,.08); position:relative; }
.process-step .step-badge { width:42px; height:42px; line-height:42px; border-radius:50%; background:var(--accent); color:var(--text); font-weight:700; text-align:center; position:absolute; top:-21px; left:20px; box-shadow:0 4px 14px rgba(0,0,0,.15); }
.process-step h3 { color:var(--primary); margin:10px 0 8px; font-size:20px; }

.contact-section { background:var(--primary); color:#fff; }
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:40px; margin-top:40px; }
.contact-item { text-align:center; }
.contact-icon { font-size:40px; color:var(--accent); margin-bottom:20px; display:block; }
.contact-item strong { color:var(--accent); display:block; margin-bottom:10px; font-size:18px; }
.contact-section a { color:inherit; }

.main-footer { background:#1a1a1a; color:#fff; padding:30px 0; text-align:center; }

.anchor-section { scroll-margin-top: 90px; }

.impressum-section .imp-block { max-width:900px; margin:0 auto 28px; background:var(--bg); padding:22px; border-radius:12px; box-shadow:0 6px 16px rgba(0,0,0,.06); }
.impressum-section .imp-block h3 { margin:0 0 10px; color:var(--primary); font-size:22px; }
.impressum-section .imp-body p { margin:0 0 10px; }
.impressum-section .imp-note { max-width:900px; margin:10px auto 0; text-align:center; opacity:.8; }

@media (max-width:768px) { .header-content{flex-direction:column; gap:15px;} .main-nav ul{gap:20px;} .hero-content h1{font-size:32px;} .about-grid{grid-template-columns:1fr; gap:30px;} .content-section{padding:50px 0;} .hero-section{padding-top:30px;} }

.fa, .fas, .far { font-family:'Font Awesome 6 Free' !important; }
