:root{
  --kudi-blue:#314d39;
  --kudi-blue-dark:#1d2f23;
  --kudi-orange:#7fbf5b;
  --kudi-orange-dark:#5e9e3f;
  --kudi-orange-soft:#a8d98b;
  --kudi-light:#f6faf4;
  --kudi-light-2:#fbfdf9;
  --kudi-text:#2f3b2f;
  --kudi-muted:#6f7d70;
  --kudi-border:#e6efe3;
  --kudi-white:#ffffff;

  --shadow-soft:0 6px 18px rgba(32,51,39,0.05);
  --shadow-medium:0 10px 26px rgba(32,51,39,0.08);
  --shadow-strong:0 18px 40px rgba(32,51,39,0.12);

  --radius-s:12px;
  --radius-m:18px;
  --radius-l:24px;
  --radius-xl:28px;

  --transition:all .28s ease;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:"Inter", Arial, Helvetica, sans-serif;
  color:var(--kudi-text);
  background:var(--kudi-white);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;display:block}

a{
  text-decoration:none;
  transition:var(--transition);
}

p{
  margin:0 0 18px;
  color:var(--kudi-text);
}

h1,h2,h3,h4,h5,h6{
  margin:0 0 14px;
  color:var(--kudi-blue-dark);
  font-weight:800;
  line-height:1.14;
  letter-spacing:-0.03em;
  font-family:"Manrope","Inter",Arial,sans-serif;
}

.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 20px;
}

.row{
  display:flex;
  flex-wrap:wrap;
  margin-left:-15px;
  margin-right:-15px;
}

.col-lg-12,.col-lg-7,.col-lg-6,.col-lg-5,.col-lg-4,.col-lg-3,.col-md-6,.col-md-4,.col-6,.col-md-12{
  width:100%;
  padding-left:15px;
  padding-right:15px;
  box-sizing:border-box;
}

@media(min-width:768px){
  .col-md-4{width:33.3333%}
  .col-md-6{width:50%}
  .col-md-12{width:100%}
  .col-6{width:50%}
}

@media(min-width:992px){
  .col-lg-3{width:25%}
  .col-lg-4{width:33.3333%}
  .col-lg-5{width:41.6666%}
  .col-lg-6{width:50%}
  .col-lg-7{width:58.3333%}
  .col-lg-12{width:100%}
}

.mb-4{margin-bottom:1.5rem}
.mt-4{margin-top:1.5rem}
.text-center{text-align:center}
.text-left{text-align:left}
.align-items-stretch{align-items:stretch}
.align-items-center{align-items:center}
.no-gutters{margin-left:0;margin-right:0}
.no-gutters > [class*="col-"]{padding-left:0;padding-right:0}

.section-padding{
  padding:120px 0;
}

/* ========================= */
/* NAVBAR */
/* ========================= */

.navbar{
  background:rgba(29,47,35,0.78);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:12px 0;
  position:fixed;
  top:0;
  left:0;
  width:100%;
  z-index:9999;
  box-shadow:0 8px 24px rgba(0,0,0,0.06);
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.kudi-nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:relative;
  min-height:56px;
}

.navbar-brand{
  display:flex;
  align-items:center;
  color:#fff !important;
  text-decoration:none !important;
  position:relative;
  z-index:10001;
  min-width:0;
}

.brand-logo-wrap{
  width:60px;
  height:60px;
  border-radius:16px;
  background:rgba(255,255,255,0.96);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-right:14px;
  box-shadow:0 12px 26px rgba(127,191,91,0.14);
  overflow:hidden;
  flex:0 0 60px;
}

.brand-logo-img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:6px;
}

.brand-text{
  line-height:1.08;
  color:#fff;
  font-weight:800;
  font-size:1.06rem;
  font-family:"Manrope","Inter",sans-serif;
}

.brand-text small{
  display:block;
  font-size:.72rem;
  font-weight:600;
  color:rgba(255,255,255,0.72);
  letter-spacing:.02em;
  margin-top:4px;
}

.nav-toggle-input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.kudi-nav{
  display:flex;
  align-items:center;
  gap:4px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.kudi-nav a{
  color:#fff;
  font-weight:600;
  font-size:.95rem;
  padding:10px 12px;
  display:block;
  border-radius:12px;
}

.kudi-nav a:hover,
.kudi-nav a.active{
  color:#fff !important;
  background:rgba(255,255,255,0.08);
}

.kudi-nav-toggle{
  display:none;
  width:48px;
  height:48px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.06);
  border-radius:14px;
  cursor:pointer;
  position:relative;
  z-index:10002;
  align-items:center;
  justify-content:center;
  padding:0;
}

.kudi-nav-toggle:hover{
  background:rgba(255,255,255,0.10);
}

.kudi-nav-toggle-line{
  display:block;
  width:20px;
  height:2px;
  background:#fff;
  border-radius:2px;
  margin:4px auto;
  transition:var(--transition);
}

.nav-toggle-input:checked + .kudi-nav-toggle .kudi-nav-toggle-line:nth-child(1){
  transform:translateY(6px) rotate(45deg);
}
.nav-toggle-input:checked + .kudi-nav-toggle .kudi-nav-toggle-line:nth-child(2){
  opacity:0;
}
.nav-toggle-input:checked + .kudi-nav-toggle .kudi-nav-toggle-line:nth-child(3){
  transform:translateY(-6px) rotate(-45deg);
}

/* ========================= */
/* HERO */
/* ========================= */

.hero-area-bg{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:
    linear-gradient(135deg, rgba(29,47,35,0.88), rgba(127,191,91,0.24)),
    url('../img/hero-meinelesung.jpg') center center / cover no-repeat;
}

.hero-area-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,0.10), transparent 30%),
    radial-gradient(circle at 82% 26%, rgba(219,238,205,0.18), transparent 26%),
    linear-gradient(to bottom, rgba(29,47,35,0.16), rgba(29,47,35,0.30));
  pointer-events:none;
}

.hero-area-bg::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:140px;
  background:linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,0.05));
  pointer-events:none;
}

.hero-area-bg .contents{
  position:relative;
  z-index:2;
  padding:182px 0 112px;
}

.hero-logo{
  width:96px;
  margin:0 auto 22px;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,0.10));
}

.hero-kicker{
  display:inline-block;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.08);
  color:#fff;
  font-size:.88rem;
  margin-bottom:24px;
  letter-spacing:.05em;
  box-shadow:0 10px 24px rgba(0,0,0,0.08);
}

.hero-title{
  color:#fff;
  font-size:clamp(2.45rem, 5.6vw, 4.45rem);
  line-height:1.01;
  font-weight:800;
  margin-bottom:24px;
  max-width:980px;
  margin-left:auto;
  margin-right:auto;
  letter-spacing:-0.05em;
  text-shadow:0 8px 22px rgba(0,0,0,0.14);
}

.hero-title span{
  color:#cfe6bf;
}

.hero-text{
  color:rgba(255,255,255,0.94);
  max-width:820px;
  margin:0 auto 40px;
  font-size:1.08rem;
  line-height:1.85;
}

.hero-text strong{
  color:#fff;
}

.hero-buttons{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:14px;
  margin-bottom:8px;
}

.hero-buttons .btn-kudi,
.hero-buttons .btn-kudi-outline{
  margin:0;
}

.hero-info-row{
  margin-top:56px;
}

.hero-info-box{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  color:#fff;
  border-radius:20px;
  padding:24px 22px;
  margin-bottom:20px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  min-height:126px;
  box-shadow:0 14px 34px rgba(0,0,0,0.10);
  transition:var(--transition);
}

.hero-info-box:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,0.11);
}

.hero-info-box strong{
  display:block;
  color:#d8ebcb;
  margin-bottom:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.76rem;
}

.hero-info-box a{
  color:#fff;
  font-weight:700;
}

/* ========================= */
/* QUICK CONTACT */
/* ========================= */

.quick-contact{
  margin-top:-58px;
  position:relative;
  z-index:5;
}

.quick-contact-wrap{
  background:#fff;
  border:1px solid var(--kudi-border);
  border-radius:28px;
  box-shadow:var(--shadow-medium);
  overflow:hidden;
}

.quick-contact-item{
  padding:34px 30px;
  height:100%;
  border-right:1px solid var(--kudi-border);
  background:#fff;
}

.quick-contact-item:last-child{
  border-right:0;
}

.quick-contact-item i{
  font-size:1.45rem;
  color:var(--kudi-orange);
  margin-bottom:14px;
  display:block;
  font-style:normal;
}

.quick-contact-item h3{
  font-size:1.08rem;
  margin-bottom:8px;
}

.quick-contact-item p,
.quick-contact-item a{
  margin:0;
  color:var(--kudi-muted);
  font-weight:600;
}

.quick-contact-item a:hover{
  color:var(--kudi-orange-dark);
}

/* ========================= */
/* TITLES / BUTTONS */
/* ========================= */

.section-title{
  font-size:clamp(1.85rem, 3.4vw, 2.6rem);
  text-align:center;
  margin-bottom:16px;
  color:var(--kudi-blue-dark);
  letter-spacing:-0.04em;
}

.section-title:after{
  content:"";
  display:block;
  width:92px;
  height:4px;
  border-radius:50px;
  background:linear-gradient(90deg, var(--kudi-orange), #cfe6bf);
  margin:18px auto 0;
}

.section-subtitle{
  text-align:center;
  max-width:760px;
  margin:0 auto 56px;
  color:var(--kudi-muted);
  font-size:1.08rem;
  line-height:1.8;
}

.btn-kudi{
  background:linear-gradient(135deg, var(--kudi-orange), var(--kudi-orange-soft));
  color:#fff !important;
  border:0;
  padding:14px 30px;
  font-weight:800;
  border-radius:14px;
  letter-spacing:.02em;
  box-shadow:0 12px 28px rgba(32,51,39,0.08);
  display:inline-block;
}

.btn-kudi:hover{
  background:linear-gradient(135deg, var(--kudi-orange-dark), var(--kudi-orange));
  color:#fff !important;
  transform:translateY(-2px);
  box-shadow:0 18px 36px rgba(32,51,39,0.12);
}

.btn-kudi-outline{
  background:rgba(255,255,255,0.06);
  color:#fff !important;
  border:1px solid rgba(255,255,255,0.26);
  padding:13px 28px;
  font-weight:700;
  border-radius:14px;
  display:inline-block;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}

.btn-kudi-outline:hover{
  background:#fff;
  border-color:#fff;
  color:var(--kudi-blue-dark) !important;
}

/* ========================= */
/* ABOUT */
/* ========================= */

.about-section{
  background:#fff;
}

.about-card{
  background:linear-gradient(180deg, var(--kudi-light) 0%, #fbfdf9 100%);
  border:1px solid var(--kudi-border);
  border-radius:26px;
  padding:42px;
  height:100%;
  box-shadow:var(--shadow-soft);
}

.about-card p{
  color:var(--kudi-muted);
}

.about-list{
  padding-left:18px;
  margin-top:18px;
  color:var(--kudi-text);
}

.about-list li{
  margin-bottom:8px;
}

.highlight-grid{
  margin-top:12px;
}

.highlight-box{
  background:#fff;
  border:1px solid var(--kudi-border);
  border-radius:20px;
  padding:24px;
  text-align:center;
  height:100%;
  box-shadow:0 6px 16px rgba(32,51,39,0.04);
}

.highlight-box strong{
  display:block;
  font-size:1.55rem;
  color:var(--kudi-orange);
  line-height:1.1;
}

.highlight-box span{
  display:block;
  color:var(--kudi-muted);
  margin-top:8px;
  font-size:.95rem;
}

/* ========================= */
/* SERVICES / CARDS */
/* ========================= */

.services-section{
  background:linear-gradient(180deg, var(--kudi-light) 0%, var(--kudi-light-2) 100%);
}

.service-link{
  display:block;
  color:inherit;
  height:100%;
}

.service-card{
  background:#fff;
  border:1px solid var(--kudi-border);
  border-radius:24px;
  padding:34px 28px;
  height:100%;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}

.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-medium);
  border-color:#d8e8d2;
}

.service-card:before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--kudi-orange), #cfe6bf);
}

.service-icon,
.icon{
  width:64px;
  height:64px;
  border-radius:18px;
  background:rgba(127,191,91,0.12);
  color:var(--kudi-orange-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.45rem;
  margin-bottom:20px;
  font-style:normal;
}

.service-card h3{
  font-size:1.2rem;
  margin-bottom:12px;
}

.service-card p,
.card p,
.process-card p,
.contact-card p,
.contact-info-card p{
  color:var(--kudi-muted);
  margin-bottom:16px;
}

.service-more{
  color:var(--kudi-blue);
  font-weight:700;
  font-size:.95rem;
}

.card{
  background:#fff;
  border:1px solid #edf3ea;
  border-radius:22px;
  padding:36px 30px;
  height:100%;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}

.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-medium);
}

.accent{
  background:linear-gradient(180deg, var(--kudi-light) 0%, var(--kudi-light-2) 100%);
}

/* ========================= */
/* PROCESS */
/* ========================= */

.process-section{
  background:#fff;
}

.process-card{
  background:#fff;
  border:1px solid var(--kudi-border);
  border-left:4px solid var(--kudi-orange);
  border-radius:0 20px 20px 0;
  padding:34px 28px;
  height:100%;
  box-shadow:var(--shadow-soft);
}

.process-step{
  display:block;
  color:var(--kudi-orange);
  font-weight:700;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
}

/* ========================= */
/* CTA */
/* ========================= */

.cta-section{
  background:linear-gradient(135deg, #314d39, #5e9e3f);
  color:#fff;
  position:relative;
  overflow:hidden;
}

.cta-section::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,0.07), transparent 22%),
    radial-gradient(circle at 85% 30%, rgba(255,255,255,0.07), transparent 20%);
  pointer-events:none;
}

.cta-section .container{
  position:relative;
  z-index:2;
}

.cta-section .section-title,
.cta-section h3{
  color:#fff;
}

.cta-section .section-subtitle{
  color:rgba(255,255,255,0.84);
}

.cta-card{
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:24px;
  padding:34px 28px;
  height:100%;
  backdrop-filter:blur(5px);
  box-shadow:0 14px 32px rgba(0,0,0,0.10);
}

.cta-card i{
  color:#d8ebcb;
  font-size:1.8rem;
  margin-bottom:14px;
  display:block;
  font-style:normal;
}

.cta-card p{
  color:rgba(255,255,255,0.88);
  margin-bottom:0;
}

/* ========================= */
/* CONTACT */
/* ========================= */

.contact-section{
  background:linear-gradient(180deg, var(--kudi-light) 0%, var(--kudi-light-2) 100%);
}

.contact-card,
.contact-info-card{
  background:#fff;
  border:1px solid #edf3ea;
  border-radius:24px;
  padding:40px;
  height:100%;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}

.contact-card:hover,
.contact-info-card:hover{
  box-shadow:var(--shadow-medium);
}

.contact-info-item{
  padding:16px 0;
  border-bottom:1px solid var(--kudi-border);
}

.contact-info-item:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.contact-info-item strong{
  display:block;
  margin-bottom:6px;
  color:var(--kudi-blue-dark);
}

.contact-info-item a,
.legal-box a{
  color:var(--kudi-orange-dark);
  font-weight:700;
}

.contact-info-item a:hover{
  color:var(--kudi-orange);
}

.contact-form-kudi{
  margin-top:24px;
}

.form-group-kudi{
  margin-bottom:18px;
}

.form-group-kudi label{
  display:block;
  margin-bottom:8px;
  font-weight:700;
  color:var(--kudi-blue-dark);
  font-size:.95rem;
}

.form-control-kudi{
  width:100%;
  border:1px solid var(--kudi-border);
  background:#fcfefb;
  border-radius:14px;
  padding:14px 15px;
  color:var(--kudi-text);
  transition:var(--transition);
  outline:none;
  box-sizing:border-box;
  font-family:inherit;
  font-size:1rem;
}

.form-control-kudi:focus{
  border-color:var(--kudi-orange);
  box-shadow:0 0 0 4px rgba(127,191,91,0.14);
  background:#fff;
}

.form-control-kudi-textarea{
  min-height:180px;
  resize:vertical;
}

/* ========================= */
/* SUBHERO / BAND */
/* ========================= */

.subhero{
  position:relative;
  padding:172px 0 112px;
  color:#fff;
  text-align:center;
  background:
    linear-gradient(135deg, rgba(29,47,35,0.90), rgba(127,191,91,0.40)),
    url('../img/hero-meinelesung.jpg') center center / cover no-repeat;
  overflow:hidden;
}

.subhero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.08), transparent 28%),
    radial-gradient(circle at 80% 28%, rgba(255,255,255,0.08), transparent 24%);
  pointer-events:none;
}

.subhero .container{
  position:relative;
  z-index:2;
}

.subhero-kicker{
  display:inline-block;
  padding:8px 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.22);
  background:rgba(255,255,255,0.08);
  color:#fff;
  font-size:.9rem;
  margin-bottom:20px;
}

.subhero h1{
  color:#fff;
  font-size:clamp(2.15rem, 5vw, 3.6rem);
  line-height:1.05;
  margin-bottom:18px;
  font-weight:800;
}

.subhero h1 span{
  color:#cfe6bf;
}

.subhero p{
  color:rgba(255,255,255,0.92);
  max-width:860px;
  margin:0 auto 30px;
  font-size:1.08rem;
}

.band{
  background:linear-gradient(135deg, #314d39, #5e9e3f);
  border-radius:28px;
  padding:38px;
  color:#fff;
  box-shadow:var(--shadow-medium);
}

.band h2,
.band h3,
.band p{
  color:#fff;
}

.band-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

/* ========================= */
/* LEGAL */
/* ========================= */

.legal-card{
  background:#fff;
  border:1px solid #edf3ea;
  border-radius:26px;
  padding:40px;
  box-shadow:var(--shadow-soft);
}

.legal-box{
  background:linear-gradient(180deg, var(--kudi-light) 0%, var(--kudi-light-2) 100%);
  border:1px solid var(--kudi-border);
  border-radius:20px;
  padding:24px;
  color:var(--kudi-text);
}

/* ========================= */
/* PRICING */
/* ========================= */

.pricing-note{
  background:#fff7ef;
  border:1px solid #f0d7bc;
  border-left:5px solid #f0a45a;
  border-radius:18px;
  padding:20px 22px;
  color:#7b5732;
  box-shadow:var(--shadow-soft);
  margin-bottom:30px;
}

.pricing-headline{
  font-size:1.65rem;
  text-align:center;
  margin:10px 0 26px;
}

.pricing-intro-extended{
  max-width:720px;
  margin:0 auto 30px;
  text-align:center;
  color:var(--kudi-muted);
  font-size:1.02rem;
  line-height:1.8;
}

.pricing-intro-extended p{
  margin-bottom:14px;
}

.pricing-intro-extended strong{
  color:var(--kudi-blue-dark);
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
  margin-bottom:28px;
}

.pricing-card{
  position:relative;
  background:#fff;
  border:1px solid #edf3ea;
  border-radius:24px;
  padding:30px 24px;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}

.pricing-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-medium);
}

.pricing-card-featured{
  border-color:#d8e8d2;
  box-shadow:var(--shadow-medium);
}

.pricing-badge{
  position:absolute;
  top:-12px;
  right:18px;
  background:linear-gradient(135deg, var(--kudi-orange), var(--kudi-orange-soft));
  color:#fff;
  padding:7px 12px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:700;
  box-shadow:0 10px 20px rgba(127,191,91,0.20);
}

.pricing-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:16px;
}

.pricing-card-head h4{
  margin:0;
  font-size:1.15rem;
}

.pricing-price{
  font-size:1.5rem;
  font-weight:800;
  color:var(--kudi-orange-dark);
  white-space:nowrap;
}

.pricing-list{
  margin:0;
  padding-left:18px;
  color:var(--kudi-text);
}

.pricing-list li{
  margin-bottom:8px;
}

/* ========================= */
/* FOOTER / BACK TO TOP */
/* ========================= */

.footer-mini{
  background:var(--kudi-blue-dark);
  color:rgba(255,255,255,0.82);
  text-align:center;
  padding:28px 0;
  font-size:.95rem;
}

.footer-mini a{
  color:#fff;
  margin-right:16px;
}

.footer-mini a:hover{
  color:#d8ebcb;
}

.back-to-top{
  position:fixed;
  right:20px;
  bottom:20px;
  width:48px;
  height:48px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--kudi-orange), var(--kudi-orange-soft));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  font-weight:700;
  box-shadow:0 14px 28px rgba(127,191,91,0.22);
  z-index:9998;
}

.back-to-top:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 34px rgba(127,191,91,0.26);
}

/* ========================= */
/* REVEAL */
/* ========================= */

.reveal,
.reveal-up,
.reveal-left,
.reveal-right,
.reveal-hero{
  opacity:1;
  transform:none;
}

.js-ready .reveal{
  opacity:0;
  transition:opacity 1s ease, transform 1s ease;
  will-change:opacity, transform;
}

.js-ready .reveal-up{transform:translateY(34px)}
.js-ready .reveal-left{transform:translateX(-34px)}
.js-ready .reveal-right{transform:translateX(34px)}
.js-ready .reveal-hero{transform:translateY(18px)}
.js-ready .reveal.is-visible{opacity:1;transform:translate(0,0)}

.delay-1{transition-delay:.08s}
.delay-2{transition-delay:.16s}
.delay-3{transition-delay:.24s}

/* ========================= */
/* PODCAST PAGE */
/* ========================= */

.podcast-platform-card{
  min-height:100%;
}

.podcast-episode-card{
  position:relative;
}

.podcast-episode-label{
  display:inline-block;
  margin-bottom:14px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(127,191,91,0.12);
  color:var(--kudi-orange-dark);
  font-size:.82rem;
  font-weight:700;
}

.podcast-episode-meta{
  color:var(--kudi-muted);
  font-weight:700;
  margin-bottom:14px;
}

.podcast-episode-actions{
  margin-top:20px;
}

.podcast-embed-wrap{
  margin-top:18px;
}

.podcast-embed-wrap iframe{
  display:block;
  width:100%;
  max-width:100%;
  box-shadow:var(--shadow-soft);
}

/* ========================= */
/* COOKIE BANNER */
/* ========================= */

.cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:10050;
}

.cookie-banner-inner{
  max-width:1180px;
  margin:0 auto;
  background:rgba(29,47,35,0.95);
  color:#fff;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:24px;
  box-shadow:0 20px 50px rgba(0,0,0,0.20);
  padding:24px;
  display:flex;
  justify-content:space-between;
  gap:22px;
  align-items:center;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.cookie-banner h3{
  color:#fff;
  margin-bottom:8px;
}

.cookie-banner p{
  color:rgba(255,255,255,0.88);
  margin:0;
}

.cookie-banner a{
  color:#d8ebcb;
  font-weight:700;
}

.cookie-banner a:hover{
  color:#fff;
}

.cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
  min-width:280px;
}

.cookie-banner .btn-kudi-outline{
  border-color:rgba(255,255,255,0.22);
  background:rgba(255,255,255,0.04);
}

.cookie-banner .btn-kudi-outline:hover{
  background:#fff;
  color:var(--kudi-blue-dark) !important;
}

.cookie-modal{
  position:fixed;
  inset:0;
  background:rgba(21,33,24,0.54);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:10060;
  padding:20px;
}

.cookie-modal.is-open{
  display:flex;
}

.cookie-modal-dialog{
  width:100%;
  max-width:620px;
}

.cookie-modal-card{
  background:#fff;
  border:1px solid var(--kudi-border);
  border-radius:24px;
  padding:30px;
  box-shadow:var(--shadow-strong);
}

.cookie-modal-card h3{
  margin-bottom:10px;
}

.cookie-option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:18px 0;
  border-bottom:1px solid var(--kudi-border);
}

.cookie-option:last-of-type{
  border-bottom:0;
}

.cookie-option p{
  margin:6px 0 0;
  color:var(--kudi-muted);
}

.cookie-option-status{
  font-weight:700;
  color:var(--kudi-muted);
  white-space:nowrap;
}

.cookie-option input[type="checkbox"]{
  width:20px;
  height:20px;
  accent-color:var(--kudi-orange);
}

.cookie-modal-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
  margin-top:24px;
}

/* ========================= */
/* EMBED CONSENT */
/* ========================= */

.embed-consent-placeholder{
  background:linear-gradient(180deg, var(--kudi-light) 0%, var(--kudi-light-2) 100%);
  border:1px solid var(--kudi-border);
  border-radius:20px;
  padding:28px 24px;
  text-align:center;
  box-shadow:var(--shadow-soft);
}

.embed-consent-placeholder h4{
  margin-bottom:10px;
}

.embed-consent-placeholder p{
  color:var(--kudi-muted);
  margin-bottom:18px;
}

/* ========================= */
/* RESPONSIVE */
/* ========================= */

@media (max-width:991px){
  .section-padding{padding:88px 0}
  .quick-contact{margin-top:30px}
  .quick-contact-item{border-right:0;border-bottom:1px solid var(--kudi-border)}
  .quick-contact-item:last-child{border-bottom:0}

  .kudi-nav-toggle{
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .kudi-nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    margin-top:12px;
    background:rgba(29,47,35,0.98);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:18px;
    box-shadow:0 18px 36px rgba(0,0,0,0.18);
    padding:14px 16px;
    flex-direction:column;
    align-items:stretch;
    gap:0;
  }

  .nav-toggle-input:checked + .kudi-nav-toggle + .kudi-nav{display:flex}
  .kudi-nav a{width:100%;padding:14px 12px;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:4px}
  .kudi-nav a:last-child{border-bottom:0;margin-bottom:0}
  .hero-area-bg .contents{padding:158px 0 92px}
  .hero-info-row{margin-top:40px}
  .band-row{flex-direction:column;align-items:flex-start}
  .pricing-grid{grid-template-columns:1fr}
  .back-to-top{right:16px;bottom:16px;width:44px;height:44px}
}

@media (max-width:767px){
  .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .cookie-banner-inner{
    padding:20px;
    border-radius:18px;
    flex-direction:column;
    align-items:flex-start;
  }

  .cookie-banner-actions{
    width:100%;
    min-width:0;
    justify-content:stretch;
  }

  .cookie-banner-actions .btn-kudi,
  .cookie-banner-actions .btn-kudi-outline{
    flex:1 1 100%;
    text-align:center;
    justify-content:center;
  }

  .cookie-modal-card{
    padding:24px 20px;
    border-radius:18px;
  }

  .cookie-option{
    align-items:flex-start;
  }

  .cookie-modal-actions{
    flex-direction:column;
  }

  .cookie-modal-actions .btn-kudi,
  .cookie-modal-actions .btn-kudi-outline{
    width:100%;
    justify-content:center;
  }
}

@media (max-width:575px){
  .section-title{font-size:1.75rem}
  .hero-title{font-size:2.15rem;line-height:1.05}
  .hero-text,.subhero p{font-size:1rem}
  .hero-kicker{font-size:.82rem;padding:8px 14px}
  .hero-info-box{min-height:auto;padding:20px 18px}
  .hero-buttons{flex-direction:column;align-items:stretch}
  .hero-buttons .btn-kudi,.hero-buttons .btn-kudi-outline{width:100%;text-align:center}
  .about-card,.contact-card,.contact-info-card,.cta-card,.card,.band,.legal-card,.pricing-card{padding:26px 22px}
  .legal-box,.pricing-note{padding:20px}
  .pricing-card-head{flex-direction:column;align-items:flex-start}
  .brand-text{font-size:1rem}
  .brand-text small{font-size:.66rem}
  .brand-logo-wrap{width:48px;height:48px;flex:0 0 48px}
  .hero-logo{width:82px;margin-bottom:18px}
  .podcast-episode-actions .btn-kudi{width:100%;text-align:center}
}




.kudi-honeypot{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}

.form-alert{
  padding:14px 16px;
  border-radius:14px;
  margin-bottom:20px;
  font-weight:600;
}

.form-alert-success{
  background:#eef8e8;
  border:1px solid #cfe3c4;
  color:#2f5a2a;
}

.form-alert-error{
  background:#fff1f1;
  border:1px solid #efcaca;
  color:#8a2f2f;
}


.field-meta{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-top:8px;
}

.field-error{
  min-height:20px;
  font-size:.92rem;
  color:#8a2f2f;
  line-height:1.45;
}

.field-counter{
  font-size:.85rem;
  color:var(--kudi-muted);
  white-space:nowrap;
}

.field-optional{
  color:var(--kudi-muted);
  font-weight:600;
  font-size:.88rem;
}

.form-control-kudi.is-valid{
  border-color:#9fce89;
  box-shadow:0 0 0 3px rgba(127,191,91,0.10);
}

.form-control-kudi.is-invalid{
  border-color:#d88f8f;
  box-shadow:0 0 0 3px rgba(216,143,143,0.10);
}

.form-check-kudi input[type="checkbox"]{
  margin-right:8px;
  accent-color:var(--kudi-orange);
}

.form-check-kudi .field-error{
  margin-top:8px;
}

.form-submit-wrap{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:10px;
}

.form-submit-hint{
  font-size:.92rem;
  color:var(--kudi-muted);
}

.js-submit-btn{
  position:relative;
  min-width:220px;
}

.js-submit-btn.is-loading{
  pointer-events:none;
  opacity:.92;
}

.js-submit-btn .btn-loading{
  display:none;
}

.js-submit-btn.is-loading .btn-label{
  opacity:0;
}

.js-submit-btn.is-loading .btn-loading{
  display:block;
  position:absolute;
  top:50%;
  left:50%;
  width:18px;
  height:18px;
  margin:-9px 0 0 -9px;
  border:2px solid rgba(255,255,255,0.35);
  border-top-color:#fff;
  border-radius:50%;
  animation:kudi-spin .8s linear infinite;
}

@keyframes kudi-spin{
  to{transform:rotate(360deg);}
}

.form-alert{
  padding:14px 16px;
  border-radius:14px;
  margin-bottom:20px;
  font-weight:600;
  scroll-margin-top:110px;
}

.form-alert-success{
  background:#eef8e8;
  border:1px solid #cfe3c4;
  color:#2f5a2a;
}

.form-alert-error{
  background:#fff1f1;
  border:1px solid #efcaca;
  color:#8a2f2f;
}

@media (max-width:575px){
  .field-meta{
    flex-direction:column;
    gap:6px;
  }

  .js-submit-btn{
    width:100%;
  }
}