/* ========================================
   PRAXIS HEIKE VÖLKER — v6.0
   1:1 Original-Design-Rebuild
   ======================================== */

:root{
  --teal-50:#effef9;
  --teal-100:#d3f7ed;
  --teal-200:#a9edd8;
  --teal-300:#6fdbbf;
  --teal-400:#2ec29d;
  --teal-500:#14b8a0;
  --teal-600:#0d9488;
  --teal-700:#0f766e;
  --teal-800:#115e59;
  --teal-900:#134e4a;

  --coral-400:#fb923c;
  --coral-500:#f97316;
  --coral-600:#ea580c;

  --ink-900:#0f172a;
  --ink-800:#1e293b;
  --ink-700:#334155;
  --ink-600:#475569;
  --ink-500:#64748b;
  --ink-400:#94a3b8;
  --ink-300:#cbd5e1;

  --surface:#ffffff;
  --surface-soft:#f8fafc;
  --surface-muted:#f1f5f9;
  --border:#e2e8f0;

  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:24px;
  --radius-xl:32px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(15,23,42,0.04);
  --shadow-md:0 8px 24px rgba(15,23,42,0.08);
  --shadow-lg:0 16px 40px rgba(15,23,42,0.12);
  --shadow-xl:0 24px 60px rgba(15,23,42,0.16);

  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-smooth:cubic-bezier(0.4,0,0.2,1);

  --font-display:ui-serif,Georgia,Cambria,"Times New Roman",Times,serif;
  --font-sans:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;

  --container:1200px;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  scroll-padding-top:100px;
}

body{
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  color:var(--ink-700);
  background:var(--surface);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

button{
  font-family:inherit;
  cursor:pointer;
  border:none;
  background:none;
}

ul{
  list-style:none;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

.section{
  padding:110px 0;
}

.section-header{
  margin-bottom:60px;
}

.section-header.center{
  text-align:center;
  max-width:680px;
  margin-left:auto;
  margin-right:auto;
}

.section-header.left{
  text-align:left;
  max-width:640px;
}

.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--teal-600);
  margin-bottom:16px;
}

.kicker::before{
  content:"";
  width:24px;
  height:2px;
  background:var(--teal-500);
}

.section-title{
  font-family:var(--font-display);
  font-size:2.8rem;
  font-weight:600;
  line-height:1.15;
  color:var(--ink-900);
  letter-spacing:-0.02em;
}

.section-title .highlight{
  background:linear-gradient(90deg,var(--teal-600) 0%,var(--coral-500) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.section-subtitle{
  font-size:1.1rem;
  color:var(--ink-600);
  margin-top:18px;
  line-height:1.7;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 28px;
  border-radius:var(--radius-pill);
  font-size:15px;
  font-weight:700;
  transition:all 200ms var(--ease-out);
  position:relative;
  overflow:hidden;
}

.btn-primary{
  background:var(--ink-900);
  color:#fff;
  box-shadow:0 4px 14px rgba(15,23,42,0.18);
}

.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(15,23,42,0.22);
}

.btn-ghost{
  background:transparent;
  color:var(--ink-900);
  border:1.5px solid var(--border);
}

.btn-ghost:hover{
  border-color:var(--teal-400);
  color:var(--teal-700);
}

.btn-outline{
  background:transparent;
  color:var(--ink-900);
  border:1.5px solid var(--ink-900);
}

.btn-outline:hover{
  background:var(--ink-900);
  color:#fff;
}

.btn-dark{
  background:var(--ink-900);
  color:#fff;
}

.btn-sm{
  padding:10px 20px;
  font-size:13px;
}

.btn-block{
  width:100%;
}

/* Header */
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:10000;
  padding:18px 0;
  transition:all 300ms var(--ease-out);
  background:transparent;
}

.nav.scrolled{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(226,232,240,0.8);
  padding:12px 0;
}

.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.logo{
  display:flex;
  align-items:center;
  gap:12px;
}

.logo-mark{
  width:40px;
  height:40px;
  border-radius:var(--radius-md);
  background:var(--teal-700);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:14px;
  letter-spacing:0.04em;
}

.logo-text{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:600;
  color:var(--ink-900);
}

.nav-links{
  display:flex;
  align-items:center;
  gap:32px;
}

.nav-links a{
  font-size:14px;
  font-weight:600;
  color:var(--ink-700);
  position:relative;
  transition:color 200ms;
}

.nav-links a:hover{
  color:var(--teal-700);
}

.nav-links a::after{
  content:"";
  position:absolute;
  bottom:-4px;
  left:0;
  width:0;
  height:2px;
  background:var(--teal-500);
  transition:width 200ms var(--ease-out);
}

.nav-links a:hover::after{
  width:100%;
}

.nav-cta{
  padding:12px 22px;
  font-size:14px;
}

.burger{
  display:none;
  flex-direction:column;
  gap:5px;
  width:32px;
  height:32px;
  justify-content:center;
  align-items:center;
  z-index:10001;
  position:relative;
}

.burger span{
  width:22px;
  height:2px;
  background:var(--ink-900);
  border-radius:2px;
  transition:all 250ms var(--ease-out);
}

.burger.open span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.burger.open span:nth-child(2){
  opacity:0;
}

.burger.open span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

.mobile-menu{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:#fff;
  z-index:9998;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
  padding:100px 24px 40px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform 350ms var(--ease-out);
  -webkit-overflow-scrolling:touch;
  isolation:isolate;
}

.mobile-menu.open{
  transform:translateX(0);
}

.mobile-menu a{
  font-size:1.25rem;
  font-weight:600;
  color:var(--ink-900);
}

.mobile-menu .btn-primary{
  color:#fff;
  font-size:1rem;
  margin-top:12px;
}

/* Hero */
.hero{
  position:relative;
  padding:160px 0 0;
  background:linear-gradient(135deg,#ffffff 0%,var(--teal-50) 50%,#f0fdfa 100%);
  overflow:hidden;
}

.hero-bg{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 70% 30%,rgba(45,194,157,0.08) 0%,transparent 50%);
  pointer-events:none;
}

.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:60px;
  align-items:center;
}

.hero-content{
  padding-bottom:80px;
}

.hero-tag{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 18px;
  background:rgba(255,255,255,0.8);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--teal-700);
  margin-bottom:28px;
  backdrop-filter:blur(8px);
}

.hero-tag .dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--teal-500);
}

.hero-title{
  font-family:var(--font-display);
  font-size:3.6rem;
  font-weight:600;
  line-height:1.1;
  color:var(--ink-900);
  letter-spacing:-0.03em;
  margin-bottom:24px;
}

.hero-title .highlight{
  background:linear-gradient(90deg,var(--teal-600) 0%,var(--coral-500) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-subtitle{
  font-size:1.15rem;
  color:var(--ink-600);
  line-height:1.75;
  margin-bottom:34px;
  max-width:520px;
}

.hero-actions{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:48px;
}

.hero-stats{
  display:flex;
  align-items:center;
  gap:40px;
}

.stat-number{
  font-family:var(--font-display);
  font-size:2rem;
  font-weight:700;
  color:var(--teal-700);
  line-height:1;
}

.stat-label{
  font-size:13px;
  color:var(--ink-600);
  margin-top:6px;
}

.hero-visual{
  position:relative;
  padding-bottom:80px;
}

.hero-image-wrap{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:visible;
}

.hero-image{
  width:100%;
  height:560px;
  object-fit:cover;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xl);
}

.hero-float-card{
  position:absolute;
  background:#fff;
  border-radius:var(--radius-md);
  padding:18px 22px;
  box-shadow:var(--shadow-lg);
}

.hero-float-top{
  top:-20px;
  right:20px;
}

.hero-float-left{
  left:-30px;
  bottom:60px;
  display:flex;
  align-items:center;
  gap:14px;
}

.hfc-icon{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.hfc-title{
  font-weight:800;
  color:var(--ink-900);
  font-size:15px;
}

.hfc-sub{
  font-size:13px;
  color:var(--ink-500);
}





/* Trust Bar */
.trust-bar{
  background:var(--surface-soft);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:28px 0;
}

.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}

.trust-item{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:15px;
  font-weight:700;
  color:var(--ink-800);
}

.trust-icon{
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.trust-icon svg{
  width:18px;
  height:18px;
}

/* Praxis / About */
.praxis{
  background:var(--surface);
}

.praxis-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:70px;
  align-items:center;
}

.praxis-image{
  position:relative;
}

.praxis-image img{
  width:100%;
  height:500px;
  object-fit:cover;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
}

.praxis-badge{
  position:absolute;
  right:-20px;
  bottom:40px;
  background:#fff;
  border-radius:var(--radius-md);
  padding:22px 28px;
  box-shadow:var(--shadow-lg);
  text-align:center;
}

.pb-number{
  font-family:var(--font-display);
  font-size:2.6rem;
  font-weight:700;
  color:var(--teal-600);
  line-height:1;
}

.pb-label{
  font-size:13px;
  font-weight:700;
  color:var(--ink-800);
  margin-top:4px;
}

.praxis-content .kicker{
  margin-bottom:16px;
}

.praxis-lead{
  font-family:var(--font-display);
  font-size:1.35rem;
  color:var(--ink-800);
  line-height:1.6;
  margin:24px 0 18px;
}

.praxis-text{
  font-size:16px;
  color:var(--ink-600);
  line-height:1.75;
  margin-bottom:14px;
}

.praxis-features{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin:32px 0 36px;
}

.pf-item{
  display:flex;
  align-items:center;
  gap:18px;
  padding:18px 22px;
  background:var(--surface-soft);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
}

.pf-number{
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:700;
  color:var(--teal-400);
  line-height:1;
}

.pf-title{
  font-weight:800;
  color:var(--ink-900);
  font-size:15px;
}

.pf-sub{
  font-size:13px;
  color:var(--ink-500);
  margin-top:2px;
}

/* Services */
.services{
  background:var(--surface-soft);
}

.service-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.service-row{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:box-shadow 200ms var(--ease-out), border-color 200ms;
}

.service-row:hover{
  box-shadow:var(--shadow-md);
  border-color:var(--teal-200);
}

.service-row.open{
  border-color:var(--teal-300);
}

.sr-header{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:22px;
  align-items:center;
  padding:26px 32px;
  cursor:pointer;
}

.sr-num{
  font-family:var(--font-display);
  font-size:1.5rem;
  font-weight:700;
  color:var(--teal-400);
  line-height:1;
}

.sr-title{
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:600;
  color:var(--ink-900);
}

.sr-summary{
  font-size:15px;
  color:var(--ink-500);
  margin-top:4px;
  line-height:1.5;
}

.sr-toggle{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--surface-soft);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all 200ms var(--ease-out);
  flex-shrink:0;
}

.service-row:hover .sr-toggle,
.service-row.open .sr-toggle{
  background:var(--teal-600);
  border-color:var(--teal-600);
}

.sr-icon{
  width:14px;
  height:14px;
  position:relative;
}

.sr-icon::before,
.sr-icon::after{
  content:"";
  position:absolute;
  background:var(--ink-700);
  transition:background 200ms, transform 200ms;
}

.sr-icon::before{
  width:14px;
  height:2px;
  top:50%;
  left:0;
  transform:translateY(-50%);
}

.sr-icon::after{
  width:2px;
  height:14px;
  top:0;
  left:50%;
  transform:translateX(-50%);
}

.service-row:hover .sr-icon::before,
.service-row:hover .sr-icon::after,
.service-row.open .sr-icon::before,
.service-row.open .sr-icon::after{
  background:#fff;
}

.service-row.open .sr-icon::after{
  transform:translateX(-50%) scaleY(0);
}

.sr-content{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows 350ms var(--ease-out);
}

.service-row.open .sr-content{
  grid-template-rows:1fr;
}

.sr-inner{
  overflow:hidden;
}

.sr-inner p{
  padding:0 32px 28px 96px;
  font-size:16px;
  color:var(--ink-600);
  line-height:1.75;
  max-width:760px;
}

/* Team */
.team{
  background:var(--surface);
}

.team-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:40px;
  align-items:stretch;
}

.team-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms var(--ease-out), box-shadow 300ms var(--ease-out);
  display:flex;
  flex-direction:column;
}

.team-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}

.team-image{
  height:360px;
  overflow:hidden;
  flex-shrink:0;
}

.team-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  transition:transform 500ms var(--ease-out);
}

.team-card:hover .team-image img{
  transform:scale(1.03);
}

.team-body{
  padding:32px;
  flex:1;
  display:flex;
  flex-direction:column;
}

.team-body h3{
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:600;
  color:var(--ink-900);
  margin-bottom:6px;
}

.team-role{
  font-size:14px;
  font-weight:700;
  color:var(--teal-600);
  margin-bottom:16px;
}

.team-body > p{
  font-size:15px;
  color:var(--ink-600);
  line-height:1.7;
  margin-bottom:24px;
  flex:1;
  min-height:52px;
}

.team-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:auto;
}

.team-meta span{
  padding:7px 14px;
  border-radius:var(--radius-pill);
  background:var(--teal-50);
  color:var(--teal-800);
  font-size:13px;
  font-weight:700;
}

/* Conditions */
.conditions{
  background:var(--surface-soft);
}

.conditions-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:70px;
  align-items:center;
}

.conditions-lead{
  font-size:1.1rem;
  color:var(--ink-600);
  line-height:1.75;
  margin:22px 0 30px;
}

.conditions-list{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-bottom:36px;
}

.conditions-list li{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 22px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
}

.cond-icon{
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.cond-icon svg{
  width:16px;
  height:16px;
}

.cond-body{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.cond-body strong{
  font-weight:800;
  color:var(--ink-900);
  font-size:15px;
}

.cond-body span{
  font-size:13px;
  color:var(--ink-500);
}

.conditions-image{
  position:relative;
}

.conditions-image img{
  width:100%;
  height:520px;
  object-fit:cover;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
}

.conditions-badge{
  position:absolute;
  left:-20px;
  bottom:40px;
  background:#fff;
  border-radius:var(--radius-md);
  padding:18px 24px;
  box-shadow:var(--shadow-lg);
}

.cb-title{
  font-weight:800;
  color:var(--ink-900);
  font-size:15px;
}

.cb-sub{
  font-size:13px;
  color:var(--ink-500);
  margin-top:2px;
}

/* Process */
.process{
  background:var(--surface-soft);
}

.process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}

.process-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:50px 28px 32px;
  position:relative;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms var(--ease-out), box-shadow 300ms var(--ease-out);
}

.process-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
}

.process-badge{
  position:absolute;
  top:-20px;
  left:28px;
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--teal-600);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
  box-shadow:0 6px 16px rgba(13,148,136,0.25);
}

.process-icon{
  width:46px;
  height:46px;
  border-radius:12px;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:20px;
}

.process-icon svg{
  width:22px;
  height:22px;
}

.process-title{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:600;
  color:var(--ink-900);
  margin-bottom:12px;
  line-height:1.3;
}

.process-card > p{
  font-size:15px;
  color:var(--ink-600);
  line-height:1.7;
}

/* Testimonials */
.testimonials{
  background:var(--surface);
}

.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  align-items:stretch;
}

.testimonial-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:36px 30px;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms var(--ease-out), box-shadow 300ms var(--ease-out);
  display:flex;
  flex-direction:column;
}

.testimonial-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}

.testimonial-card.featured{
  background:var(--teal-900);
  border-color:var(--teal-900);
  color:#fff;
  transform:scale(1.02);
  box-shadow:var(--shadow-lg);
}

.quote-mark{
  font-family:var(--font-display);
  font-size:3.5rem;
  line-height:1;
  color:var(--teal-400);
  margin-bottom:10px;
}

.testimonial-card.featured .quote-mark{
  color:var(--teal-300);
}

.testimonial-card p{
  font-size:16px;
  line-height:1.75;
  color:var(--ink-700);
  flex:1;
}

.testimonial-card.featured p{
  color:rgba(255,255,255,0.92);
}

.testimonial-source{
  font-size:13px;
  font-weight:700;
  color:var(--ink-500);
  margin-top:24px;
}

.testimonial-card.featured .testimonial-source{
  color:var(--teal-200);
}

/* Pricing */
.pricing{
  background:var(--surface-soft);
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  align-items:stretch;
}

.price-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:40px 32px;
  position:relative;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms var(--ease-out), box-shadow 300ms var(--ease-out);
  display:flex;
  flex-direction:column;
  min-height:520px;
}

.price-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
}

.price-card.featured{
  border-color:var(--teal-300);
  box-shadow:var(--shadow-lg);
  background:linear-gradient(180deg,#fff 0%,var(--teal-50) 100%);
  transform:scale(1.02);
  z-index:2;
}

.pc-badge{
  position:absolute;
  top:-12px;
  right:24px;
  padding:6px 14px;
  border-radius:var(--radius-pill);
  background:var(--teal-700);
  color:#fff;
  font-size:11px;
  font-weight:800;
  letter-spacing:0.04em;
}

.price-card h3{
  font-family:var(--font-display);
  font-size:1.5rem;
  font-weight:600;
  color:var(--ink-900);
  margin-bottom:10px;
}

.price-card > p{
  font-size:15px;
  color:var(--ink-600);
  line-height:1.6;
  margin-bottom:20px;
  flex-shrink:0;
  min-height:50px;
}

.price-card .price{
  font-size:2.6rem;
  font-weight:800;
  color:var(--ink-900);
  margin-bottom:22px;
  line-height:1;
}

.price-card .price .currency{
  font-size:1rem;
  font-weight:600;
  color:var(--ink-500);
  margin-right:6px;
  vertical-align:middle;
}

.price-card ul{
  list-style:none;
  margin-bottom:28px;
  flex:1;
}

.price-card ul li{
  padding:12px 0;
  border-bottom:1px solid var(--border);
  font-size:15px;
  color:var(--ink-600);
  display:flex;
  align-items:center;
  gap:10px;
}

.price-card ul li::before{
  content:"✓";
  color:var(--teal-600);
  font-weight:800;
}

.price-card .btn{
  margin-top:auto;
  width:100%;
  flex-shrink:0;
}

.pricing-note{
  font-size:15px;
  color:var(--ink-500);
  margin-top:40px;
  text-align:center;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}

/* FAQ */
.faq{
  background:#fff;
}

.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.faq-col{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:border-color 200ms, box-shadow 200ms;
}

.faq-item:hover{
  border-color:var(--teal-200);
}

.faq-item.open{
  border-color:var(--teal-300);
  box-shadow:var(--shadow-md);
}

.faq-q{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  width:100%;
  padding:22px 26px;
  font-size:16px;
  font-weight:700;
  color:var(--ink-900);
  text-align:left;
}

.faq-icon{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--surface-soft);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:500;
  color:var(--ink-700);
  transition:all 200ms var(--ease-out);
  flex-shrink:0;
}

.faq-item.open .faq-icon{
  background:var(--teal-600);
  border-color:var(--teal-600);
  color:#fff;
}

.faq-a{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows 350ms var(--ease-out);
}

.faq-item.open .faq-a{
  grid-template-rows:1fr;
}

.faq-a-inner{
  overflow:hidden;
}

.faq-a-inner p{
  padding:0 26px 22px;
  font-size:15px;
  color:var(--ink-600);
  line-height:1.7;
}

/* Contact */
.contact{
  background:var(--surface-soft);
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:60px;
  align-items:start;
}

.contact-lead{
  font-size:1.1rem;
  color:var(--ink-600);
  line-height:1.75;
  margin:20px 0 32px;
}

.contact-cards{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-bottom:32px;
}

.contact-card{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 22px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  transition:all 200ms var(--ease-out);
}

.contact-card:hover{
  border-color:var(--teal-300);
  transform:translateX(4px);
}

.cc-icon{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.cc-icon svg{
  width:18px;
  height:18px;
}

.cc-body{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.cc-label{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.04em;
  color:var(--ink-500);
}

.cc-value{
  font-weight:700;
  color:var(--ink-900);
  font-size:15px;
  line-height:1.4;
}

.opening-hours{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:20px 24px;
}

.oh-row{
  display:flex;
  justify-content:space-between;
  padding:12px 0;
  border-bottom:1px solid var(--border);
  font-size:15px;
  color:var(--ink-600);
}

.oh-row:last-child{
  border-bottom:none;
}

.contact-form-wrap{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:40px;
  box-shadow:var(--shadow-md);
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.form-group{
  margin-bottom:22px;
}

.form-group label{
  display:block;
  font-size:12px;
  font-weight:800;
  color:var(--ink-700);
  margin-bottom:8px;
  text-transform:uppercase;
  letter-spacing:0.04em;
}

.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  padding:14px 18px;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  background:var(--surface-soft);
  font-family:var(--font-sans);
  font-size:15px;
  color:var(--ink-900);
  transition:border-color 200ms, box-shadow 200ms;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--teal-400);
  box-shadow:0 0 0 3px rgba(45,194,157,0.12);
}

.form-group textarea{
  min-height:120px;
  resize:vertical;
}

.form-privacy{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:22px;
  font-size:13px;
  color:var(--ink-600);
  line-height:1.6;
}

.form-privacy input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--teal-600);
  flex-shrink:0;
}

.form-privacy a{
  color:var(--teal-700);
  text-decoration:underline;
  font-weight:600;
}

.form-success,
.form-error{
  display:none;
  padding:14px 18px;
  border-radius:var(--radius-md);
  margin-bottom:20px;
  font-size:14px;
  font-weight:600;
}

.form-success{
  background:var(--teal-50);
  color:var(--teal-800);
  border:1px solid var(--teal-200);
}

.form-error{
  background:#fef2f2;
  color:#991b1b;
  border:1px solid #fecaca;
}

.form-success.show,
.form-error.show{
  display:block;
}

/* Location */
.location{
  background:#fff;
}

.location-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:70px;
  align-items:center;
}

.location-map{
  background:linear-gradient(135deg,var(--teal-700) 0%,var(--teal-500) 100%);
  border-radius:var(--radius-xl);
  padding:60px;
  min-height:460px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.map-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:40px;
  text-align:center;
  box-shadow:var(--shadow-xl);
  width:100%;
  max-width:340px;
}

.map-pin{
  width:56px;
  height:56px;
  border-radius:50%;
  background:var(--teal-50);
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 20px;
}

.map-pin svg{
  width:26px;
  height:26px;
}

.map-address{
  font-family:var(--font-display);
  font-size:1.5rem;
  font-weight:600;
  color:var(--ink-900);
  margin-bottom:4px;
}

.map-city{
  font-size:15px;
  color:var(--ink-600);
  margin-bottom:24px;
}

.location-info .kicker{
  margin-bottom:16px;
}

.location-info .section-title{
  margin-bottom:32px;
}

.location-cards{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.loc-card{
  display:flex;
  gap:18px;
  padding:22px;
  background:var(--surface-soft);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
}

.loc-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:#fff;
  color:var(--teal-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  box-shadow:var(--shadow-sm);
}

.loc-icon svg{
  width:20px;
  height:20px;
}

.loc-title{
  font-weight:800;
  color:var(--ink-900);
  font-size:16px;
  margin-bottom:4px;
}

.loc-text{
  font-size:14px;
  color:var(--ink-600);
  line-height:1.6;
}

/* Footer */
.footer{
  background:var(--teal-900);
  color:#fff;
  padding:70px 0 0;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:50px;
  margin-bottom:60px;
}

.footer-brand .footer-logo{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:18px;
}

.footer-brand .logo-mark{
  background:var(--teal-500);
}

.footer-brand .logo-text{
  color:#fff;
}

.footer-tagline{
  font-size:15px;
  color:var(--teal-200);
  line-height:1.7;
  margin-bottom:24px;
}

.footer-contact{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:14px;
  color:var(--teal-100);
}

.footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.footer-heading{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--teal-300);
  margin-bottom:8px;
}

.footer-col a{
  font-size:14px;
  color:var(--teal-100);
  transition:color 200ms;
}

.footer-col a:hover{
  color:#fff;
}

.footer-bottom{
  border-top:1px solid rgba(94,196,180,0.2);
  padding:24px 0;
}

.fb-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  color:var(--teal-300);
}

/* Sticky CTA */
.sticky-cta{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:998;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  background:var(--teal-600);
  color:#fff;
  border-radius:var(--radius-pill);
  font-size:14px;
  font-weight:700;
  box-shadow:0 8px 24px rgba(13,148,136,0.3);
  transition:transform 200ms var(--ease-out), box-shadow 200ms;
}

.sticky-cta:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(13,148,136,0.4);
}

.sticky-cta svg{
  width:18px;
  height:18px;
}

/* Cookie Banner */
.cookie-banner{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:997;
  background:var(--ink-900);
  color:#fff;
  padding:18px 0;
  transform:translateY(100%);
  transition:transform 350ms var(--ease-out);
}

.cookie-banner.show{
  transform:translateY(0);
}

.cookie-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.cookie-inner p{
  font-size:14px;
  color:var(--teal-100);
}

.cookie-inner a{
  color:var(--teal-300);
  text-decoration:underline;
  font-weight:600;
}

/* Reveal Animations */
.js [data-reveal]{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
}

.js [data-reveal].in{
  opacity:1;
  transform:translateY(0);
}

.js [data-delay="1"]{transition-delay:100ms}
.js [data-delay="2"]{transition-delay:200ms}
.js [data-delay="3"]{transition-delay:300ms}
.js [data-delay="4"]{transition-delay:400ms}
.js [data-delay="5"]{transition-delay:500ms}

/* Mobile */
@media(max-width:1100px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav-cta{display:none}
}

@media(max-width:1024px){
  .hero-grid,
  .praxis-grid,
  .conditions-grid,
  .location-grid{
    grid-template-columns:1fr;
    gap:50px;
  }

  .hero-visual{order:-1}
  .hero-image{height:420px}
  .hero-content{padding-bottom:40px; text-align:center}
  .hero-subtitle{margin-left:auto; margin-right:auto}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  
  .hero-float-left{left:20px}

  .trust-grid{grid-template-columns:repeat(2,1fr); gap:20px}

  .process-grid{grid-template-columns:repeat(2,1fr)}
  .testimonial-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr; max-width:520px; margin:0 auto}
  .faq-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr; gap:40px}
}

@media(max-width:640px){
  .section{padding:70px 0}
  .section-title{font-size:2rem}
  .hero-title{font-size:2.6rem}
  .hero-stats{flex-direction:column; gap:20px}
  .hero-actions{flex-direction:column; width:100%}
  .hero-actions .btn{width:100%}
  .trust-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr}
  .praxis-features{gap:12px}
  .sr-header{grid-template-columns:auto 1fr auto; gap:14px; padding:20px}
  .sr-inner p{padding:0 20px 20px 68px}
  .form-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:28px}
  .footer-grid{grid-template-columns:1fr}
  .fb-inner{flex-direction:column; gap:8px; text-align:center}
  .cookie-inner{flex-direction:column; text-align:center}
  .sticky-cta{right:16px; bottom:16px; padding:12px 18px}
}


/* ========================================
   ANIMATIONS
   ======================================== */

/* Hero load animation */
.js .hero-content{
  opacity:0;
  transform:translateY(40px);
  animation:heroIn 900ms var(--ease-out) 200ms forwards;
}

.js .hero-visual{
  opacity:0;
  transform:translateY(50px);
  animation:heroIn 900ms var(--ease-out) 400ms forwards;
}

@keyframes heroIn{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* Floating badges gentle float */
.hero-float-top,
.hero-float-left{
  animation:float 6s ease-in-out infinite;
}

.hero-float-left{
  animation-delay:1.5s;
}

@keyframes float{
  0%, 100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* Button fill effect */
.btn{
  z-index:1;
}

.btn::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--teal-600);
  z-index:-1;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 400ms var(--ease-out);
  border-radius:inherit;
}

.btn-primary:hover::before{
  transform:scaleX(1);
}

.btn-primary:hover{
  background:transparent;
}

.btn-outline:hover::before,
.btn-ghost:hover::before{
  transform:scaleX(1);
}

.btn-outline:hover,
.btn-ghost:hover{
  color:#fff;
  border-color:var(--teal-600);
}

/* Trust items */
.trust-item{
  transition:transform 250ms var(--ease-out);
}

.trust-item:hover{
  transform:translateY(-4px);
}

.trust-icon{
  transition:transform 300ms var(--ease-out), background 300ms;
}

.trust-item:hover .trust-icon{
  transform:scale(1.1) rotate(-8deg);
  background:var(--teal-100);
}

/* Praxis feature items */
.pf-item{
  transition:transform 250ms var(--ease-out), border-color 250ms, box-shadow 250ms;
}

.pf-item:hover{
  transform:translateX(8px);
  border-color:var(--teal-300);
  box-shadow:var(--shadow-md);
}

/* Service rows */
.service-row{
  transition:transform 250ms var(--ease-out), box-shadow 250ms, border-color 250ms;
}

.service-row:hover{
  transform:translateX(6px);
}

/* Team cards */
.team-card{
  transition:transform 350ms var(--ease-out), box-shadow 350ms;
}

.team-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-lg);
}

.team-meta span{
  transition:background 250ms, color 250ms;
}

.team-card:hover .team-meta span{
  background:var(--teal-600);
  color:#fff;
}

/* Conditions list */
.conditions-list li{
  transition:transform 250ms var(--ease-out), border-color 250ms;
}

.conditions-list li:hover{
  transform:translateX(8px);
  border-color:var(--teal-300);
}

/* Process cards */
.process-card{
  transition:transform 350ms var(--ease-out), box-shadow 350ms;
}

.process-card:hover{
  transform:translateY(-12px);
  box-shadow:var(--shadow-lg);
}

.process-badge{
  transition:transform 300ms var(--ease-out), box-shadow 300ms;
}

.process-card:hover .process-badge{
  transform:scale(1.1);
  box-shadow:0 8px 24px rgba(13,148,136,0.35);
}

.process-icon{
  transition:transform 300ms, background 300ms;
}

.process-card:hover .process-icon{
  transform:scale(1.1);
  background:var(--teal-100);
}

/* Testimonials */
.testimonial-card{
  transition:transform 350ms var(--ease-out), box-shadow 350ms;
}

.testimonial-card:hover{
  transform:translateY(-8px) scale(1.01);
  box-shadow:var(--shadow-md);
}

.testimonial-card.featured:hover{
  transform:translateY(-8px) scale(1.03);
}

/* Pricing cards */
.price-card{
  transition:transform 350ms var(--ease-out), box-shadow 350ms, border-color 350ms;
}

.price-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-lg);
}

.price-card.featured:hover{
  transform:translateY(-10px) scale(1.03);
}

/* FAQ items */
.faq-item{
  transition:transform 250ms var(--ease-out), border-color 250ms, box-shadow 250ms;
}

.faq-item:hover{
  transform:translateY(-3px);
}

/* Contact cards */
.contact-card{
  transition:transform 250ms var(--ease-out), border-color 250ms, box-shadow 250ms;
}

.contact-card:hover{
  transform:translateX(8px);
  border-color:var(--teal-300);
  box-shadow:var(--shadow-md);
}

/* Location cards */
.loc-card{
  transition:transform 250ms var(--ease-out), border-color 250ms;
}

.loc-card:hover{
  transform:translateX(8px);
  border-color:var(--teal-300);
}

/* Map card */
.map-card{
  animation:mapFloat 5s ease-in-out infinite;
}

@keyframes mapFloat{
  0%, 100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

/* Cursor glow */
.cursor-glow{
  position:fixed;
  top:0;
  left:0;
  width:260px;
  height:260px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(45,194,157,0.12) 0%, transparent 70%);
  pointer-events:none;
  z-index:9999;
  opacity:0;
  transition:opacity 300ms;
}

body:hover .cursor-glow{
  opacity:1;
}

/* Sticky CTA pulse */
/* Underline animation for footer links */
.footer-col a{
  position:relative;
  display:inline-block;
}

.footer-col a::after{
  content:"";
  position:absolute;
  bottom:-2px;
  left:0;
  width:0;
  height:1px;
  background:#fff;
  transition:width 250ms var(--ease-out);
}

.footer-col a:hover::after{
  width:100%;
}

/* Focus states for accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid var(--teal-500);
  outline-offset:2px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .cursor-glow{display:none !important}
}


/* ========================================
   REFINEMENTS
   ======================================== */

/* Softer shadows */
.hero-image,
.hero-float-card,
.praxis-image img,
.conditions-image img,
.contact-form-wrap,
.map-card,
.team-card,
.price-card,
.testimonial-card,
.process-card{
  box-shadow:0 10px 30px rgba(15,23,42,0.08);
}

.hero-image:hover,
.praxis-image img:hover,
.conditions-image img:hover{
  box-shadow:0 18px 44px rgba(15,23,42,0.12);
}

.team-card:hover,
.price-card:hover,
.testimonial-card:hover,
.process-card:hover{
  box-shadow:0 20px 50px rgba(15,23,42,0.14);
}

/* Sticky CTA refined */
.sticky-cta{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:998;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 18px;
  background:var(--teal-600);
  color:#fff;
  border-radius:var(--radius-pill);
  font-size:13px;
  font-weight:700;
  box-shadow:0 6px 20px rgba(13,148,136,0.25);
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
  transition:opacity 350ms var(--ease-out), transform 350ms var(--ease-out), box-shadow 250ms;
}

.sticky-cta.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
  box-shadow:0 8px 22px rgba(13,148,136,0.35);
}

.sticky-cta:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(13,148,136,0.45);
}

.sticky-cta svg{
  width:18px;
  height:18px;
}

/* Contact grid vertical center */
.contact-grid{
  align-items:center;
}

.contact-info{
  display:flex;
  flex-direction:column;
  justify-content:center;
  height:100%;
}

.contact-form-wrap{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-self:stretch;
}

.contact-form-wrap form{
  width:100%;
}

@media(min-width:1025px){
  .contact-info{
    padding-right:30px;
  }
  .contact-form-wrap{
    min-height:680px;
  }
}

/* Equal team cards */
.team-grid{
  align-items:stretch;
}

.team-card{
  min-height:620px;
}

.team-body > p{
  min-height:54px;
}

/* Equal pricing cards */
.pricing-grid{
  align-items:stretch;
}

.price-card{
  min-height:540px;
}

.price-card > p{
  min-height:54px;
}

.price-card ul{
  min-height:140px;
}

/* Process title single line */
.process-title{
  white-space:nowrap;
  font-size:1.1rem;
}

/* Trust bar spacing */
.trust-grid{
  align-items:center;
}

.trust-item{
  min-height:44px;
}

/* Nav CTA shadow softer */
.nav-cta,
.hero-actions .btn-primary{
  box-shadow:0 4px 12px rgba(15,23,42,0.12);
}

.nav-cta:hover,
.hero-actions .btn-primary:hover{
  box-shadow:0 6px 18px rgba(15,23,42,0.18);
}

/* Better section spacing consistency */
.section{
  padding:100px 0;
}

.hero{
  padding:150px 0 0;
}

/* Mobile: sticky cta smaller */
@media(max-width:640px){
  .sticky-cta span{
    display:none;
  }
  .sticky-cta{
    padding:12px;
    border-radius:50%;
  }
  .process-title{
    white-space:normal;
  }
}

@media(max-width:1024px){
  .contact-grid{
    align-items:start;
  }
  .contact-form-wrap{
    align-self:auto;
  }
  .team-card,
  .price-card{
    min-height:auto;
  }
  .process-title{
    white-space:normal;
  }
}


/* Form thank you message */
.form-thank-you{
  display:none;
  align-items:center;
  gap:12px;
  margin-top:16px;
  padding:14px 18px;
  background:var(--teal-50);
  border:1px solid var(--teal-200);
  border-radius:var(--radius-lg);
  color:var(--teal-900);
  font-size:15px;
  line-height:1.4;
  opacity:0;
  transform:translateY(10px);
  transition:opacity 300ms var(--ease-out), transform 300ms var(--ease-out);
}

.form-thank-you.show{
  opacity:1;
  transform:translateY(0);
}

.form-thank-you strong{
  display:block;
  font-weight:700;
}

.form-thank-you span{
  display:block;
  color:var(--teal-800);
  font-size:14px;
}

.thank-you-icon{
  flex-shrink:0;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--teal-600);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:700;
}
