:root{
  --bg:#f5f7f5;
  --surface:#ffffff;
  --surface-soft:#edf5ef;
  --text:#24322c;
  --muted:#5e6d65;
  --brand:#2f7f6f;
  --brand-dark:#245f53;
  --line:#dde7e0;
  --shadow:0 10px 28px rgba(26,46,35,.08);
  --radius:18px;
  --max:1120px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}
html{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  scroll-behavior:smooth;
}

body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  margin:0;
  font-family:'Segoe UI', Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
}

img,
svg,
canvas{
  max-width:100%;
}

img{display:block}
button,
select,
input{
  appearance:none;
  -webkit-appearance:none;
  font:inherit;
}

a{text-decoration:none;color:inherit}

header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}

.nav-wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}

.brand{display:flex; align-items:center; gap:14px;}
.brand img{height:58px; width:auto;}
.brand-name{font-weight:800; color:var(--brand-dark); letter-spacing:.2px;}

nav{display:flex; gap:18px; flex-wrap:wrap;}

nav a{
  font-weight:600;
  color:var(--text);
  font-size:15px;
  padding:8px 0;
}

nav a:hover, nav a.active{color:var(--brand);}

.hero{
  background:linear-gradient(135deg,#e7f3ec 0%, #f8faf8 55%, #edf4ef 100%);
  border-bottom:1px solid var(--line);
}

.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:70px 20px 56px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:34px;
  align-items:center;
}

.badge{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:#dff0e6;
  border:1px solid #cde4d7;
  color:var(--brand-dark);
  font-weight:700;
  font-size:14px;
  margin-bottom:16px;
}

.hero h1{
  margin:0 0 14px;
  font-size:clamp(34px,5vw,56px);
  line-height:1.08;
  color:var(--brand-dark);
}

.hero p{
  margin:0 0 22px;
  font-size:18px;
  color:var(--muted);
  max-width:720px;
}

.actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:18px;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 22px;
  border-radius:12px;
  font-weight:700;
  transition:.2s ease;
}

.button.primary{
  background:var(--brand);
  color:#fff;
}

.button.primary:hover{
  background:var(--brand-dark);
  transform:translateY(-1px);
}

.button.secondary{
  background:#fff;
  color:var(--brand-dark);
  border:1px solid var(--line);
}

.hero-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.hero-card img{
  width:100%;
  height:100%;
  min-height:300px;
  object-fit:cover;
}

main{
  max-width:var(--max);
  margin:0 auto;
  padding:34px 20px 70px;
}

.section{margin-top:34px;}

.panel{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:28px;
}

h1.page-title{
  margin:0 0 10px;
  color:var(--brand-dark);
  font-size:clamp(30px,4vw,44px);
}

h2{
  margin:0 0 14px;
  color:var(--brand-dark);
  font-size:clamp(24px,3vw,32px);
}

h3{margin:0 0 8px; color:var(--brand-dark);}

.lead{
  font-size:18px;
  color:var(--muted);
}

.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:18px;}

.symptom-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.symptom{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:18px;
  transition:.2s ease;
}

.symptom:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(26,46,35,.12);
}

.symptom strong{
  display:block;
  color:var(--brand-dark);
  margin-bottom:8px;
}

/* 🔥 NIEUWE CTA */
.soft-cta{
  margin-top:36px;
  padding:26px 22px;
  text-align:center;
  background:var(--surface-soft);
  border:1px solid #d7e7dc;
  border-radius:20px;
  box-shadow:var(--shadow);
}

.soft-cta p{
  margin:0 0 14px;
  font-size:17px;
  color:var(--text);
  font-weight:500;
}

.soft-cta .button{
  padding:14px 24px;
  border-radius:12px;
}

.soft-cta .button.primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 18px rgba(36,95,83,.18);
}

.about{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:26px;
  align-items:center;
}

.kim-photo{
  width:180px;
  border-radius:18px;
  box-shadow:var(--shadow);
}

.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.review{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:20px;
}

.cta{
  margin-top:28px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:34px 28px;
}

.cta h2{color:#fff;}
.cta p{color:rgba(255,255,255,.9);}

footer{
  margin-top:40px;
  border-top:1px solid var(--line);
  color:var(--muted);
}

.footer-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:28px 20px 40px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
}

@media (max-width: 900px){
  .hero-inner,
  .grid-2,
  .review-grid,
  .symptom-grid,
  .about{
    grid-template-columns:1fr;
  }

  nav{display:none;}
  .hero-card img{min-height:240px;}
  .kim-photo{width:150px;}
}

@media (max-width:700px){
  .soft-cta{
    padding:22px 16px;
  }

  .soft-cta p{
    font-size:16px;
  }
}
/* Beveiligde mailknop op contactpagina */
.secure-mail-wrap{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:18px;
}

.slider-container{
  width:100%;
  max-width:420px;
}

.slider-track{
  position:relative;
  height:54px;
  border-radius:999px;
  background:#e6ece8;
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:inset 0 2px 8px rgba(36,50,44,.06);
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.slider-text{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-size:14px;
  font-weight:700;
  pointer-events:none;
  transition:color .25s ease;
}

.slider-handle{
  position:absolute;
  top:0;
  left:0;
  width:54px;
  height:54px;
  border-radius:50%;
  background:var(--brand);
  box-shadow:0 8px 18px rgba(36,95,83,.22);
  cursor:grab;
  transition:background .2s ease, transform .2s ease, box-shadow .2s ease, left .18s ease;
}

.slider-handle::after{
  content:'→';
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:900;
  font-size:20px;
}

.slider-handle:active{
  cursor:grabbing;
  transform:scale(.96);
}

.slider-handle:focus{
  outline:3px solid rgba(47,127,111,.25);
  outline-offset:3px;
}

.slider-track.success{
  background:#dff5e6;
  border-color:#4caf50;
  box-shadow:0 0 0 4px rgba(76,175,80,.12);
}

.slider-track.success .slider-text{
  color:#2e7d32;
}

.slider-track.success .slider-handle{
  background:#4caf50;
  box-shadow:0 8px 20px rgba(76,175,80,.28);
  animation:checkPulse .55s ease;
}

.slider-track.success .slider-handle::after{
  content:'✓';
  font-size:24px;
}

.button.disabled{
  pointer-events:none;
  opacity:.45;
  filter:grayscale(.15);
}

@keyframes checkPulse{
  0%{transform:scale(1);}
  45%{transform:scale(1.16);}
  100%{transform:scale(1);}
}

@media (max-width:700px){
  .secure-mail-wrap{align-items:stretch;}
  .slider-container,
  .secure-mail-wrap .button{
    width:100%;
    max-width:none;
  }
}
/* Ademhalingsoefeningen */
.ademhaling-page{
  --breath-scale:1;
  --breath-progress:16%;
  --calm-color:#da7b65;
  --calm-color-soft:#f9e5dc;
  --calm-glow:rgba(91,170,132,.14);
  background:#f3f7f4;
}

.breath-hero{
  background:linear-gradient(135deg,#edf6f1 0%,#fbfcfb 58%,#eef5f0 100%);
  border-bottom:1px solid var(--line);
}

.breath-hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:54px 20px 42px;
  display:grid;
  grid-template-columns:1fr 220px;
  gap:28px;
  align-items:center;
}

.breath-hero h1{
  margin:0 0 14px;
  color:var(--brand-dark);
  font-size:clamp(34px,5vw,58px);
  line-height:1.08;
}

.breath-hero p{
  margin:0;
  max-width:760px;
  color:var(--muted);
  font-size:18px;
}

.breath-hero img{
  width:220px;
  justify-self:end;
  filter:drop-shadow(0 16px 22px rgba(26,46,35,.12));
}

.breath-app{
  max-width:var(--max);
  margin:0 auto;
  padding:28px 20px 74px;
}

.age-switcher{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-bottom:20px;
}

.age-card{
  min-height:132px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  color:var(--text);
  padding:18px;
  text-align:left;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.age-card span,
.age-card small{
  display:block;
  color:var(--muted);
  font-weight:700;
}

.age-card strong{
  display:block;
  margin:8px 0 4px;
  color:var(--brand-dark);
  font-size:22px;
}

.age-card:hover,
.age-card.active{
  transform:translateY(-2px);
  border-color:rgba(47,127,111,.42);
  box-shadow:0 16px 34px rgba(26,46,35,.12);
}

.age-card.active{
  background:#eef7f1;
}

.breath-stage{
  min-height:600px;
  border:1px solid var(--line);
  border-radius:8px;
  background:linear-gradient(145deg,#ffffff 0%,#f8fbf8 100%);
  box-shadow:0 14px 34px rgba(26,46,35,.07);
  padding:28px;
  display:grid;
  grid-template-columns:minmax(250px,.82fr) minmax(320px,1.18fr);
  gap:24px;
  align-items:center;
}

.session-copy{
  align-self:stretch;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.mode-label{
  color:var(--brand);
  font-size:14px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.session-copy h2{
  margin:8px 0 10px;
  font-size:clamp(28px,4vw,44px);
}

.session-copy p{
  margin:0 0 20px;
  color:var(--muted);
  font-size:18px;
}

.phase-pill{
  width:100%;
  max-width:360px;
  min-height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#e9f5ee;
  color:var(--brand-dark);
  font-size:24px;
  font-weight:800;
  text-align:center;
}

.visual-wrap{
  min-height:330px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}

.visual{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transform:scale(.98);
  pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
}

[data-breath-mode="klein"] .visual-klein,
[data-breath-mode="midden"] .visual-midden,
[data-breath-mode="tiener"] .visual-tiener{
  opacity:1;
  transform:scale(1);
}

.bear{
  width:min(330px,88vw);
  overflow:visible;
}

.bear-ear,
.bear-head,
.bear-body{
  fill:#c99b72;
  stroke:#7a563f;
  stroke-width:6;
}

.bear-body{
  fill:#da7b65;
  fill:var(--bear-body-color, #da7b65);
  transition:fill .85s cubic-bezier(.22,.61,.36,1);
  filter:none;
}

.bear-belly{
  fill:#fff1df;
  stroke:#7a563f;
  stroke-width:5;
  transform-box:fill-box;
  transform-origin:center;
  transform:scale(var(--breath-scale));
  transition:transform .25s linear;
}

.animal-focus{
  width:min(360px,88vw);
  aspect-ratio:1;
  border-radius:8px;
  background:linear-gradient(145deg,var(--calm-color-soft),#f7fbf8);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:24px;
  border:1px solid #cce2d5;
}

.animal-head{
  width:188px;
  height:160px;
  border-radius:48% 48% 44% 44%;
  background:linear-gradient(145deg,var(--calm-color),#365b4e);
  position:relative;
  transform:scale(var(--breath-scale));
  transition:transform .25s linear;
  box-shadow:0 18px 38px rgba(36,50,44,.18);
}

.animal-ear{
  position:absolute;
  top:-24px;
  width:64px;
  height:74px;
  background:#365b4e;
  border-radius:12px 48px 18px 42px;
}

.animal-ear.left{left:18px;transform:rotate(-28deg);}
.animal-ear.right{right:18px;transform:scaleX(-1) rotate(-28deg);}

.animal-eye{
  position:absolute;
  top:62px;
  width:14px;
  height:14px;
  border-radius:50%;
  background:#b5f2c8;
  box-shadow:0 0 18px rgba(181,242,200,.75);
}

.animal-eye.left{left:58px;}
.animal-eye.right{right:58px;}

.animal-nose{
  position:absolute;
  left:50%;
  top:92px;
  width:28px;
  height:18px;
  border-radius:50%;
  background:#f4d6aa;
  transform:translateX(-50%);
}

.focus-meter{
  width:78%;
  height:18px;
  border-radius:999px;
  background:#d1ded8;
  overflow:hidden;
  border:1px solid rgba(36,95,83,.16);
}

.focus-meter span{
  display:block;
  width:var(--breath-progress);
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#da7b65,#8dc9a5,#5baa84);
  transition:width .35s ease;
}

.visual-tiener{
  background:radial-gradient(circle at center, var(--calm-glow), transparent 52%);
}

.neon-ring{
  width:min(330px,82vw);
  aspect-ratio:1;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#111a18;
  box-shadow:inset 0 0 0 1px rgba(181,242,200,.16), 0 26px 70px rgba(17,26,24,.24);
}

.neon-ring span{
  width:58%;
  aspect-ratio:1;
  border-radius:50%;
  border:3px solid var(--calm-color);
  box-shadow:0 0 28px var(--calm-glow), inset 0 0 28px var(--calm-glow);
  transform:scale(var(--breath-scale));
  transition:transform .25s linear;
}

.session-panel{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.timer-block{
  min-height:92px;
  border-radius:8px;
  background:#f6faf7;
  border:1px solid var(--line);
  padding:16px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.timer-block span{
  color:var(--muted);
  font-weight:700;
}

.timer-block strong{
  color:var(--brand-dark);
  font-size:28px;
  line-height:1.15;
}

.controls{
  grid-column:1 / -1;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.control-button{
  min-height:54px;
  min-width:150px;
  border:0;
  cursor:pointer;
  font:inherit;
}

.support-note{
  grid-column:1 / -1;
  margin:0;
  color:var(--muted);
}

[data-breath-mode="tiener"] .breath-stage{
  background:linear-gradient(145deg,#f8fbf9 0%,#eef6f2 55%,#e6f0ec 100%);
}

[data-breath-mode="tiener"] .phase-pill{
  background:#111a18;
  color:#b5f2c8;
}

@media (max-width:900px){
  .breath-hero-inner,
  .breath-stage{
    grid-template-columns:1fr;
  }

  .breath-hero img{
    justify-self:start;
    width:170px;
  }

  .age-switcher,
  .session-panel{
    grid-template-columns:1fr;
  }

  .breath-stage{
    min-height:auto;
    padding:22px;
  }

  .visual-wrap{
    min-height:300px;
  }

  .controls .button{
    flex:1 1 150px;
  }
}

@media (max-width:560px){
  .breath-hero-inner{
    padding-top:38px;
  }

  .age-card{
    min-height:116px;
  }

  .phase-pill{
    max-width:none;
    font-size:21px;
  }

  .visual-wrap{
    min-height:260px;
  }

  .control-button{
    width:100%;
  }
}

@media (prefers-reduced-motion:reduce){
  .age-card,
  .visual,
  .bear-belly,
  .animal-head,
  .neon-ring span,
  .focus-meter span{
    transition:none;
  }
}


.timer-block-main{
  background:linear-gradient(135deg,#edf8f2,#ffffff);
  border-color:rgba(47,127,111,.28);
}

.timer-block-main strong{
  font-size:clamp(38px,6vw,56px);
  letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
}

.completion-card{
  grid-column:1 / -1;
  border-radius:8px;
  background:linear-gradient(135deg,#e7f6ee,#ffffff);
  border:1px solid rgba(47,127,111,.24);
  padding:20px;
  text-align:center;
  color:var(--brand-dark);
  box-shadow:0 12px 28px rgba(26,46,35,.08);
}

.completion-card strong,
.completion-card span{
  display:block;
}

.completion-card strong{
  font-size:clamp(28px,4vw,42px);
  line-height:1.1;
}

.completion-card span{
  margin-top:6px;
  color:var(--muted);
  font-size:20px;
  font-weight:700;
}

#soundBtn[aria-pressed="true"]{
  background:#e5f6ec;
  border-color:rgba(47,127,111,.34);
  color:var(--brand-dark);
}


/* Rustiger mobiele ademcoach */
.breath-app,
.breath-stage,
.visual-wrap{
  max-width:100%;
}

.bear-belly,
.animal-head,
.neon-ring span{
  will-change:transform;
}

@media (max-width:760px){
  .breath-hero-inner{
    padding:32px 16px 24px;
    gap:18px;
  }

  .breath-hero h1{
    font-size:clamp(30px,9vw,42px);
  }

  .breath-hero p{
    font-size:16px;
  }

  .breath-hero img{
    width:132px;
  }

  .breath-app{
    padding:16px 12px 46px;
  }

  .age-switcher{
    gap:10px;
  }

  .age-card{
    min-height:0;
    padding:14px;
  }

  .age-card strong{
    font-size:clamp(18px,5vw,22px);
  }

  .breath-stage{
    border-radius:8px;
    padding:16px;
    gap:16px;
  }

  .session-copy h2{
    font-size:clamp(25px,7vw,34px);
  }

  .session-copy p{
    font-size:16px;
  }

  .phase-pill{
    min-height:56px;
    font-size:clamp(19px,5.8vw,24px);
  }

  .visual-wrap{
    min-height:250px;
  }

  .bear,
  .animal-focus,
  .neon-ring{
    width:min(280px,82vw);
  }

  .animal-head{
    width:154px;
    height:132px;
  }

  .session-panel{
    grid-template-columns:1.3fr .7fr;
  }

  .timer-block{
    min-height:74px;
    padding:12px;
  }

  .timer-block:nth-child(3){
    grid-column:1 / -1;
  }

  .timer-block span{
    font-size:13px;
  }

  .timer-block strong{
    font-size:24px;
  }

  .timer-block-main strong{
    font-size:clamp(42px,12vw,58px);
  }

  .controls{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }

  .control-button{
    width:100%;
    min-width:0;
    min-height:52px;
    padding:12px 10px;
    font-size:15px;
  }

  .support-note{
    font-size:14px;
  }
}

@media (max-width:380px){
  .breath-stage{
    padding:12px;
  }

  .visual-wrap{
    min-height:215px;
  }

  .timer-block-main strong{
    font-size:40px;
  }

  .control-button{
    font-size:14px;
  }
}

/* Ademhaling mobile hardening v2 */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

*, *::before, *::after{
  box-sizing:border-box;
}

.ademhaling-page{
  min-width:0;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

.ademhaling-page main,
.ademhaling-page section,
.ademhaling-page div,
.ademhaling-page nav,
.ademhaling-page svg{
  min-width:0;
}

.ademhaling-page .nav-wrap,
.ademhaling-page .breath-hero-inner,
.ademhaling-page .breath-app{
  width:100%;
  max-width:var(--max);
}

.ademhaling-page .session-copy,
.ademhaling-page .phase-pill,
.ademhaling-page .support-note,
.ademhaling-page .timer-block,
.ademhaling-page .age-card{
  overflow-wrap:anywhere;
}

.bear{
  display:block;
  max-width:100%;
}

.bear-head{
  fill:#d1a27b;
}

.bear-ear{
  fill:#c99b72;
}

.bear-body,
.animal-head,
.neon-ring span,
.focus-meter span{
  transition:
    fill .9s cubic-bezier(.22,.61,.36,1),
    background .9s cubic-bezier(.22,.61,.36,1),
    border-color .9s cubic-bezier(.22,.61,.36,1),
    box-shadow .9s cubic-bezier(.22,.61,.36,1),
    transform .45s linear,
    width .45s ease;
}

@media (min-width:761px) and (max-width:1024px){
  .ademhaling-page .brand img{
    height:50px;
  }

  .breath-hero-inner{
    grid-template-columns:1fr 160px;
    padding:44px 22px 34px;
  }

  .breath-hero img{
    width:160px;
  }

  .breath-stage{
    grid-template-columns:1fr;
    min-height:auto;
  }

  .visual-wrap{
    min-height:310px;
  }

  .bear,
  .animal-focus,
  .neon-ring{
    width:min(310px,72vw);
  }
}

@media (max-width:760px){
  .ademhaling-page header{
    position:sticky;
    top:0;
  }

  .ademhaling-page .nav-wrap{
    min-height:58px;
    padding:8px 12px;
    gap:10px;
  }

  .ademhaling-page .brand{
    gap:8px;
    min-width:0;
  }

  .ademhaling-page .brand img{
    height:38px;
    flex:0 0 auto;
  }

  .ademhaling-page .brand-name{
    max-width:48vw;
    font-size:15px;
    line-height:1.15;
    white-space:normal;
  }

  .ademhaling-page .menu-toggle{
    margin:0;
    width:44px;
    height:44px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex:0 0 44px;
    border-radius:8px;
    color:var(--brand-dark);
  }

  .ademhaling-page nav{
    max-width:calc(100vw - 24px);
    left:12px;
    right:12px;
    top:58px;
    padding:12px;
    gap:6px;
  }

  .ademhaling-page nav a{
    width:100%;
    padding:10px 8px;
    line-height:1.25;
  }

  .breath-hero-inner{
    grid-template-columns:1fr;
    padding:24px 16px 18px;
  }

  .breath-hero h1{
    font-size:clamp(28px,8.4vw,38px);
    line-height:1.12;
  }

  .breath-hero p,
  .session-copy p{
    line-height:1.55;
  }

  .breath-hero img{
    display:none;
  }

  .breath-app{
    padding:14px 10px 40px;
  }

  .age-switcher{
    grid-template-columns:1fr;
  }

  .breath-stage{
    width:100%;
    max-width:100%;
    overflow:hidden;
    border-radius:8px;
    padding:14px;
  }

  .visual-wrap{
    width:100%;
    max-width:100%;
    min-height:clamp(210px,62vw,270px);
    overflow:hidden;
  }

  .visual{
    overflow:hidden;
  }

  .bear{
    width:min(250px,76vw);
    max-height:250px;
    overflow:visible;
  }

  .animal-focus,
  .neon-ring{
    width:min(250px,76vw);
  }

  .animal-head{
    width:min(150px,48vw);
    height:auto;
    aspect-ratio:188 / 160;
  }

  .session-panel{
    width:100%;
  }

  .timer-block-main strong{
    font-size:clamp(40px,11vw,54px);
  }

  .controls{
    width:100%;
  }

  .control-button{
    touch-action:manipulation;
    border-radius:10px;
  }
}

@media (max-width:430px){
  .controls{
    grid-template-columns:1fr;
  }

  .control-button{
    min-height:54px;
    font-size:15px;
  }

  .session-panel{
    grid-template-columns:1fr;
  }

  .timer-block:nth-child(3){
    grid-column:auto;
  }

  .phase-pill{
    min-height:54px;
    padding:10px;
  }
}

@media (max-width:340px){
  .ademhaling-page .brand-name{
    font-size:13px;
    max-width:42vw;
  }

  .breath-app{
    padding-left:8px;
    padding-right:8px;
  }

  .bear,
  .animal-focus,
  .neon-ring{
    width:min(224px,74vw);
  }

  .timer-block-main strong{
    font-size:36px;
  }
}

/* Age selection UX */
.age-card{
  position:relative;
  outline:0;
}

.age-card::after{
  content:"";
  position:absolute;
  inset:8px;
  border:1px solid transparent;
  border-radius:7px;
  pointer-events:none;
  transition:border-color .35s ease, box-shadow .35s ease, opacity .35s ease;
  opacity:0;
}

.age-card.active{
  background:linear-gradient(145deg,#eef8f2,#ffffff);
  border-color:rgba(47,127,111,.46);
  box-shadow:0 14px 30px rgba(47,127,111,.13);
}

.age-card.active::after{
  border-color:rgba(91,170,132,.38);
  box-shadow:0 0 0 4px rgba(91,170,132,.08);
  opacity:1;
}

.age-card.active span,
.age-card.active strong{
  color:var(--brand-dark);
}

.breath-stage{
  scroll-margin-top:96px;
}

@media (max-width:760px){
  .breath-stage{
    scroll-margin-top:72px;
  }

  .age-card.active{
    transform:none;
  }
}


/* Compact start-ready ademhaling UX */
.breath-stage{
  scroll-margin-top:84px;
}

.controls{
  grid-column:1 / -1;
}

@media (max-width:760px){
  .ademhaling-page .nav-wrap{
    min-height:50px;
    padding:6px 10px;
  }

  .ademhaling-page .brand img{
    height:32px;
  }

  .ademhaling-page .brand-name{
    font-size:14px;
  }

  .ademhaling-page .menu-toggle{
    width:40px;
    height:40px;
    flex-basis:40px;
  }

  .ademhaling-page nav{
    top:50px;
  }

  .breath-hero-inner{
    padding:18px 14px 10px;
  }

  .breath-hero h1{
    font-size:clamp(25px,7.4vw,34px);
    margin-bottom:8px;
  }

  .breath-hero p{
    font-size:15px;
    line-height:1.45;
  }

  .breath-app{
    padding:10px 10px 30px;
  }

  .age-switcher{
    margin-bottom:10px;
    gap:8px;
  }

  .age-card{
    padding:11px 12px;
  }

  .age-card span,
  .age-card small{
    font-size:13px;
  }

  .age-card strong{
    margin:4px 0 2px;
    font-size:18px;
  }

  .breath-stage{
    scroll-margin-top:56px;
    padding:10px;
    gap:9px;
  }

  .session-copy{
    justify-content:start;
  }

  .mode-label{
    font-size:11px;
  }

  .session-copy h2{
    margin:2px 0 5px;
    font-size:clamp(22px,6.4vw,30px);
  }

  .session-copy p{
    display:none;
  }

  .phase-pill{
    min-height:44px;
    padding:8px 10px;
    font-size:clamp(18px,5.4vw,22px);
  }

  .visual-wrap{
    min-height:clamp(168px,45vw,218px);
  }

  .bear,
  .animal-focus,
  .neon-ring{
    width:min(214px,64vw);
  }

  .animal-head{
    width:min(128px,40vw);
  }

  .session-panel{
    grid-template-columns:1.2fr .8fr;
    gap:8px;
  }

  .timer-block{
    min-height:58px;
    padding:9px 10px;
  }

  .timer-block:nth-child(3){
    display:none;
  }

  .timer-block span{
    font-size:12px;
  }

  .timer-block strong{
    font-size:21px;
  }

  .timer-block-main strong{
    font-size:clamp(34px,10vw,46px);
  }

  .controls{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
  }

  .control-button{
    min-height:48px;
    padding:10px 8px;
    font-size:14px;
  }

  .support-note{
    font-size:12px;
    line-height:1.35;
  }
}

@media (max-width:430px){
  .controls{
    grid-template-columns:1fr;
  }

  .control-button{
    min-height:50px;
  }
}

@media (max-height:720px) and (max-width:760px){
  .breath-stage{
    gap:7px;
  }

  .phase-pill{
    min-height:40px;
  }

  .visual-wrap{
    min-height:150px;
  }

  .bear,
  .animal-focus,
  .neon-ring{
    width:min(190px,58vw);
  }

  .timer-block{
    min-height:52px;
  }

  .control-button{
    min-height:44px;
  }
}


/* Focus fruit visual fit */
.visual-midden{
  overflow:visible;
  padding-block:clamp(20px,5vw,34px) clamp(12px,3vw,24px);
}

.visual-midden .animal-focus{
  box-sizing:border-box;
  width:clamp(220px,34vw,360px);
  max-width:100%;
  aspect-ratio:1 / 1;
  padding:clamp(30px,5vw,48px) clamp(18px,4vw,34px) clamp(18px,4vw,34px);
  overflow:visible;
  justify-content:center;
}

.visual-midden .animal-head{
  width:min(58%,188px);
  height:auto;
  aspect-ratio:188 / 160;
  flex:0 0 auto;
  transform:scale(var(--breath-scale));
  transform-origin:center center;
}

.visual-midden .animal-ear{
  width:34%;
  height:auto;
  aspect-ratio:64 / 74;
  top:-18%;
}

.visual-midden .animal-ear.left{
  left:10%;
}

.visual-midden .animal-ear.right{
  right:10%;
}

.visual-midden .animal-eye{
  top:38%;
  width:7.5%;
  height:auto;
  aspect-ratio:1;
}

.visual-midden .animal-eye.left{
  left:31%;
}

.visual-midden .animal-eye.right{
  right:31%;
}

.visual-midden .animal-nose{
  top:57%;
  width:15%;
  height:auto;
  aspect-ratio:28 / 18;
}

@media (max-width:760px){
  [data-breath-mode="midden"] .visual-wrap{
    overflow:visible;
    min-height:auto;
    aspect-ratio:1.08 / 1;
    padding-block:clamp(6px,2vw,12px);
  }

  [data-breath-mode="midden"] .visual{
    overflow:visible;
    position:relative;
    inset:auto;
    min-height:0;
  }

  .visual-midden{
    padding-block:clamp(16px,5vw,26px) clamp(8px,2.5vw,16px);
  }

  .visual-midden .animal-focus{
    width:min(230px,68vw);
    padding:clamp(28px,8vw,38px) clamp(14px,5vw,24px) clamp(14px,5vw,22px);
    gap:clamp(12px,4vw,20px);
  }

  .visual-midden .animal-head{
    width:min(132px,43vw);
    max-width:62%;
  }

  .visual-midden .focus-meter{
    width:82%;
    height:14px;
  }
}

@media (max-width:380px){
  [data-breath-mode="midden"] .visual-wrap{
    aspect-ratio:1.12 / 1;
  }

  .visual-midden .animal-focus{
    width:min(205px,66vw);
    padding-top:30px;
  }

  .visual-midden .animal-head{
    width:min(118px,40vw);
  }
}

@media (min-width:761px) and (max-width:1024px){
  [data-breath-mode="midden"] .visual-wrap{
    overflow:visible;
  }

  .visual-midden .animal-focus{
    width:min(310px,58vw);
  }
}


/* Focus fruit short screens */
@media (max-height:720px) and (max-width:760px){
  [data-breath-mode="midden"] .visual-wrap{
    min-height:auto;
    aspect-ratio:1.18 / 1;
    overflow:visible;
  }

  .visual-midden .animal-focus{
    width:min(190px,62vw);
    padding-top:28px;
  }

  .visual-midden .animal-head{
    width:min(110px,38vw);
  }
}


/* All breathing figures responsive fit */
.visual-wrap{
  --figure-size:clamp(220px,31vw,340px);
}

.visual-klein,
.visual-midden,
.visual-tiener{
  overflow:visible;
}

.visual-klein .bear,
.visual-midden .animal-focus,
.visual-tiener .neon-ring{
  width:var(--figure-size);
  max-width:100%;
  max-height:100%;
  margin-inline:auto;
}

.visual-klein .bear{
  height:auto;
}

.visual-tiener .neon-ring{
  aspect-ratio:1;
}

@media (max-width:760px){
  .visual-wrap{
    --figure-size:clamp(150px,48vw,205px);
    min-height:auto;
    height:auto;
    aspect-ratio:1.22 / 1;
    overflow:visible;
    padding-block:clamp(4px,1.6vw,10px);
  }

  .visual{
    overflow:visible;
    align-items:center;
    justify-content:center;
  }

  [data-breath-mode="klein"] .visual-wrap,
  [data-breath-mode="tiener"] .visual-wrap{
    aspect-ratio:1.18 / 1;
  }

  [data-breath-mode="midden"] .visual-wrap{
    aspect-ratio:1.28 / 1;
    padding-top:clamp(8px,2.4vw,14px);
  }

  .visual-klein .bear{
    width:min(var(--figure-size),54vw);
    max-height:100%;
  }

  .visual-midden .animal-focus{
    width:min(var(--figure-size),58vw);
    padding:clamp(24px,7vw,32px) clamp(12px,4vw,20px) clamp(12px,4vw,18px);
    gap:clamp(9px,3vw,14px);
  }

  .visual-midden .animal-head{
    width:min(112px,35vw);
    transform:scale(var(--breath-scale));
  }

  .visual-midden .focus-meter{
    height:12px;
  }

  .visual-tiener .neon-ring{
    width:min(var(--figure-size),52vw);
  }

  .neon-ring span{
    width:54%;
  }

  .breath-stage{
    gap:7px;
  }

  .session-panel{
    margin-top:0;
  }
}

@media (max-width:430px){
  .visual-wrap{
    --figure-size:clamp(132px,44vw,178px);
    aspect-ratio:1.32 / 1;
  }

  [data-breath-mode="midden"] .visual-wrap{
    aspect-ratio:1.36 / 1;
  }

  .visual-midden .animal-focus{
    width:min(var(--figure-size),54vw);
    padding-top:clamp(22px,6.5vw,28px);
  }

  .visual-midden .animal-head{
    width:min(98px,32vw);
  }
}

@media (max-height:720px) and (max-width:760px){
  .visual-wrap{
    --figure-size:clamp(122px,39vw,165px);
    aspect-ratio:1.45 / 1;
    padding-block:2px;
  }

  [data-breath-mode="midden"] .visual-wrap{
    aspect-ratio:1.48 / 1;
  }

  .visual-midden .animal-focus{
    width:min(var(--figure-size),50vw);
    padding-top:clamp(20px,5.8vw,26px);
    gap:8px;
  }

  .visual-midden .animal-head{
    width:min(88px,29vw);
  }

  .visual-midden .focus-meter{
    height:10px;
  }
}

@media (min-width:761px) and (max-width:1024px){
  .visual-wrap{
    --figure-size:clamp(240px,36vw,320px);
    overflow:visible;
  }
}


/* Prioritize start and gong on mobile */
@media (max-width:430px){
  .controls{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  #startPauseBtn{
    order:1;
  }

  #soundBtn{
    order:2;
  }

  #resetBtn{
    order:3;
    grid-column:1 / -1;
  }
}

@media (max-height:720px) and (max-width:760px){
  .controls{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px;
  }

  #startPauseBtn{
    order:1;
  }

  #soundBtn{
    order:2;
  }

  #resetBtn{
    order:3;
    grid-column:1 / -1;
  }
}


/* Chrome-safe teddybeer colors */
.ademhaling-page{
  --bear-body-color:#da7b65;
}

.visual-klein{
  isolation:isolate;
}

.visual-klein::before{
  content:"";
  position:absolute;
  width:min(230px,56vw);
  aspect-ratio:1;
  border-radius:50%;
  background:var(--calm-glow);
  filter:none;
  opacity:.65;
  transform:translateY(10%);
  pointer-events:none;
  z-index:0;
}

.visual-klein .bear{
  position:relative;
  z-index:1;
  color:#24322c;
  transform:translateZ(0);
  backface-visibility:hidden;
}

.bear-ear,
.bear-head,
.bear-body,
.bear-belly{
  mix-blend-mode:normal;
  opacity:1;
}

.bear-body{
  fill:#da7b65;
  fill:var(--bear-body-color, #da7b65);
}

.bear-belly{
  fill:#fff1df;
}

@media (max-width:760px){
  .visual-klein::before{
    width:min(170px,44vw);
    transform:translateY(8%);
  }
}


/* Premium mobile age picker */
@media (max-width:760px){
  .ademhaling-page header{
    min-height:46px;
  }

  .ademhaling-page .nav-wrap{
    min-height:46px;
    padding:5px 10px;
    align-items:center;
  }

  .ademhaling-page .brand img{
    height:28px;
  }

  .ademhaling-page .brand-name{
    font-size:13px;
    line-height:1.08;
    max-width:50vw;
  }

  .ademhaling-page .menu-toggle{
    width:38px;
    height:38px;
    flex-basis:38px;
    margin-left:auto;
    font-size:22px;
  }

  .ademhaling-page nav{
    top:46px;
    right:10px;
    left:10px;
  }

  .breath-hero-inner{
    padding:14px 14px 8px;
  }

  .breath-hero .badge{
    margin-bottom:8px;
    padding:6px 10px;
    font-size:12px;
  }

  .breath-hero h1{
    font-size:clamp(23px,7vw,32px);
    margin-bottom:6px;
  }

  .breath-hero p{
    font-size:14px;
    line-height:1.42;
  }

  .breath-app{
    padding:8px 12px 30px;
  }

  .age-switcher{
    grid-template-columns:1fr;
    gap:10px;
    margin:0 0 12px;
  }

  .age-card{
    width:100%;
    min-height:86px;
    display:grid;
    grid-template-columns:auto 1fr;
    grid-template-areas:
      "age title"
      "age desc";
    column-gap:14px;
    row-gap:2px;
    align-items:center;
    padding:16px;
    border-radius:12px;
    border:1px solid rgba(36,95,83,.12);
    background:linear-gradient(145deg,#ffffff,#f7fbf8);
    box-shadow:0 8px 22px rgba(26,46,35,.06);
    text-align:left;
  }

  .age-card span{
    grid-area:age;
    min-width:58px;
    min-height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:8px 9px;
    border-radius:10px;
    background:#edf7f1;
    color:var(--brand-dark);
    font-size:12px;
    line-height:1;
    font-weight:800;
    white-space:nowrap;
  }

  .age-card strong{
    grid-area:title;
    margin:0;
    color:var(--brand-dark);
    font-size:clamp(19px,5.2vw,23px);
    line-height:1.1;
    font-weight:800;
  }

  .age-card small{
    grid-area:desc;
    color:var(--muted);
    font-size:14px;
    line-height:1.25;
    font-weight:600;
  }

  .age-card:hover,
  .age-card.active{
    transform:none;
  }

  .age-card.active{
    border-color:rgba(47,127,111,.5);
    background:linear-gradient(145deg,#eff9f3,#ffffff);
    box-shadow:0 12px 28px rgba(47,127,111,.14);
  }

  .age-card.active::after{
    inset:6px;
    border-radius:10px;
    border-color:rgba(91,170,132,.4);
    box-shadow:0 0 0 4px rgba(91,170,132,.08);
  }
}

@media (max-width:360px){
  .age-card{
    min-height:80px;
    padding:13px;
    column-gap:10px;
  }

  .age-card span{
    min-width:52px;
    font-size:11px;
  }

  .age-card strong{
    font-size:18px;
  }

  .age-card small{
    font-size:13px;
  }
}


/* Chrome mobile parity age cards */
@media (max-width:760px){
  .ademhaling-page{
    -webkit-text-size-adjust:100%;
    text-size-adjust:100%;
  }

  .ademhaling-page header{
    min-height:44px;
  }

  .ademhaling-page .nav-wrap{
    min-height:44px;
    height:44px;
    padding:4px 10px;
  }

  .ademhaling-page .brand img{
    height:26px;
    max-height:26px;
  }

  .ademhaling-page .brand-name{
    font-size:13px;
    line-height:1;
  }

  .ademhaling-page .menu-toggle{
    width:36px;
    height:36px;
    flex:0 0 36px;
    margin:0 0 0 auto;
    padding:0;
  }

  .ademhaling-page nav{
    top:44px;
  }

  .age-switcher{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    width:100%;
    gap:10px;
    margin:0 0 12px;
  }

  .age-card{
    -webkit-appearance:none;
    appearance:none;
    width:100%;
    min-width:0;
    min-height:76px;
    display:grid !important;
    grid-template-columns:64px minmax(0,1fr);
    grid-template-rows:auto auto;
    grid-template-areas:
      "age title"
      "age desc";
    align-items:center;
    column-gap:14px;
    row-gap:3px;
    padding:14px 16px;
    border:1px solid rgba(36,95,83,.14);
    border-radius:14px;
    background:#ffffff;
    background:linear-gradient(145deg,#ffffff 0%,#f6fbf8 100%);
    box-shadow:0 8px 20px rgba(26,46,35,.07);
    color:var(--text);
    font:inherit;
    line-height:1.2;
    text-align:left;
    touch-action:manipulation;
    -webkit-tap-highlight-color:rgba(47,127,111,.12);
  }

  .age-card span{
    grid-area:age;
    width:64px;
    min-width:64px;
    min-height:44px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:8px 6px;
    border-radius:11px;
    background:#eaf6ef;
    color:var(--brand-dark);
    font-size:12px;
    line-height:1;
    font-weight:800;
    letter-spacing:0;
    white-space:nowrap;
  }

  .age-card strong{
    grid-area:title;
    min-width:0;
    margin:0;
    color:var(--brand-dark);
    font-size:21px;
    line-height:1.08;
    font-weight:800;
    letter-spacing:0;
  }

  .age-card small{
    grid-area:desc;
    min-width:0;
    color:var(--muted);
    font-size:14px;
    line-height:1.25;
    font-weight:600;
    letter-spacing:0;
  }

  .age-card.active{
    border-color:rgba(47,127,111,.55);
    background:linear-gradient(145deg,#eef9f3 0%,#ffffff 100%);
    box-shadow:0 12px 26px rgba(47,127,111,.14);
  }

  .age-card.active::after{
    inset:6px;
    border-radius:12px;
    border-color:rgba(91,170,132,.42);
    box-shadow:0 0 0 4px rgba(91,170,132,.08);
  }

  .breath-stage{
    scroll-margin-top:50px;
  }
}

@media (max-width:360px){
  .age-card{
    min-height:72px;
    grid-template-columns:58px minmax(0,1fr);
    column-gap:11px;
    padding:12px 13px;
  }

  .age-card span{
    width:58px;
    min-width:58px;
    min-height:40px;
    font-size:11px;
  }

  .age-card strong{
    font-size:19px;
  }

  .age-card small{
    font-size:13px;
  }
}


/* Chrome-safe rebuilt age picker */
@media (max-width:760px){
  .age-switcher{
    display:block;
    width:100%;
    margin:0 0 12px;
    padding:0;
  }

  .age-card{
    appearance:none;
    -webkit-appearance:none;
    display:block !important;
    width:100%;
    min-height:72px;
    margin:0 0 12px;
    padding:16px;
    border:1px solid rgba(47,127,111,.16);
    border-radius:18px;
    background:#f8fcf9;
    color:var(--text);
    box-shadow:0 6px 18px rgba(26,46,35,.06);
    text-align:left;
    font:inherit;
    line-height:1.3;
    transform:none !important;
    transition:border-color .25s ease, background-color .25s ease, box-shadow .25s ease;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
  }

  .age-card:last-child{
    margin-bottom:0;
  }

  .age-card::after{
    display:none !important;
    content:none;
  }

  .age-card span,
  .age-card strong,
  .age-card small{
    display:block;
    width:auto;
    min-width:0;
    min-height:0;
    margin:0;
    padding:0;
    background:transparent;
    border-radius:0;
    line-height:1.25;
    white-space:normal;
  }

  .age-card span{
    margin-bottom:4px;
    color:var(--brand);
    font-size:13px;
    font-weight:800;
  }

  .age-card strong{
    margin-bottom:4px;
    color:var(--brand-dark);
    font-size:22px;
    font-weight:800;
  }

  .age-card small{
    color:var(--muted);
    font-size:14px;
    font-weight:600;
  }

  .age-card.active{
    border-color:rgba(47,127,111,.58);
    background:#eff8f3;
    box-shadow:0 8px 22px rgba(47,127,111,.14);
  }

  .breath-stage{
    position:static;
    scroll-margin-top:0;
  }

  .breath-app,
  .breath-stage,
  .visual-wrap{
    overflow:visible;
  }
}

@media (max-width:360px){
  .age-card{
    min-height:72px;
    padding:15px;
  }

  .age-card strong{
    font-size:20px;
  }
}


/* Chrome mobile debug stable */
@media (max-width:760px){
  .ademhaling-page header{
    position:relative !important;
    top:auto !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  .ademhaling-page .breath-app,
  .ademhaling-page .breath-stage,
  .ademhaling-page .visual-wrap,
  .ademhaling-page .session-copy,
  .ademhaling-page .session-panel,
  .ademhaling-page .controls{
    overflow:visible !important;
    transform:none !important;
    height:auto !important;
    min-height:0;
  }

  .ademhaling-page .visual-wrap{
    min-height:150px;
  }

  .ademhaling-page .age-switcher,
  .ademhaling-page .age-card{
    max-width:100%;
    transform:none !important;
  }

  .ademhaling-page .age-card{
    display:block !important;
    width:100%;
    min-height:72px;
  }
}


/* Robust Chrome exercise switching */
.exercise{
  display:none;
}

#exercise-klein{
  display:flex;
}

@media (max-width:760px){
  .age-card{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-height:84px !important;
    padding:18px !important;
    margin:0 0 12px !important;
    border-radius:18px !important;
    font-size:18px !important;
    line-height:1.3 !important;
    transform:none !important;
  }

  .age-card span,
  .age-card strong,
  .age-card small{
    display:block !important;
    width:auto !important;
    min-width:0 !important;
    min-height:0 !important;
    padding:0 !important;
    background:transparent !important;
    text-align:left !important;
  }

  .age-card span{
    margin:0 0 5px !important;
    font-size:14px !important;
    font-weight:800 !important;
  }

  .age-card strong{
    margin:0 0 5px !important;
    font-size:24px !important;
    line-height:1.12 !important;
  }

  .age-card small{
    margin:0 !important;
    font-size:15px !important;
    line-height:1.3 !important;
  }

  .age-card.active{
    border-color:rgba(47,127,111,.62) !important;
    background:#eef8f3 !important;
    box-shadow:0 10px 24px rgba(47,127,111,.16) !important;
  }

  .age-card::after{
    display:none !important;
  }
}

/* Robust mobile rebuild for Ademhaling */
.ademhaling-page .exercise[hidden]{
  display:none !important;
}

.ademhaling-page .exercise:not([hidden]){
  display:grid !important;
}

.ademhaling-page .breathing-visual{
  width:min(72vw, 260px);
  max-width:100%;
  height:auto;
  min-height:180px;
  margin:18px auto;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:visible;
}

.ademhaling-page .breathing-visual .bear,
.ademhaling-page .breathing-visual .animal-focus,
.ademhaling-page .breathing-visual .neon-ring{
  width:100%;
  max-width:260px;
  height:auto;
  max-height:260px;
  margin:0 auto;
  transform:scale(var(--breath-scale, 1));
  transform-origin:center center;
}

.ademhaling-page .breathing-visual .animal-focus,
.ademhaling-page .breathing-visual .neon-ring{
  aspect-ratio:1 / 1;
}

@media (max-width:760px){
  .ademhaling-page header{
    position:relative !important;
    top:auto !important;
    min-height:44px !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  .ademhaling-page .nav-wrap{
    min-height:44px !important;
    height:44px !important;
    padding:4px 10px !important;
  }

  .ademhaling-page .brand img{
    height:26px !important;
    max-height:26px !important;
    width:auto !important;
  }

  .ademhaling-page .brand-name{
    font-size:13px !important;
    line-height:1 !important;
  }

  .ademhaling-page .menu-toggle{
    width:36px !important;
    height:36px !important;
    flex:0 0 36px !important;
    margin-left:auto !important;
    padding:0 !important;
  }

  .ademhaling-page .breath-app,
  .ademhaling-page .breath-stage,
  .ademhaling-page .session-copy,
  .ademhaling-page .session-panel,
  .ademhaling-page .controls{
    overflow:visible !important;
    transform:none !important;
    height:auto !important;
    min-height:0;
    max-width:100%;
  }

  .ademhaling-page .breath-app{
    padding:8px 12px 30px !important;
  }

  .ademhaling-page .age-switcher{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    margin:0 0 14px !important;
    padding:0 !important;
  }

  .ademhaling-page .age-card{
    appearance:none !important;
    -webkit-appearance:none !important;
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-height:82px !important;
    margin:0 0 12px !important;
    padding:16px 18px !important;
    border:1px solid rgba(47,127,111,.18) !important;
    border-radius:18px !important;
    background:#f8fcf9 !important;
    color:var(--text) !important;
    box-shadow:0 8px 22px rgba(26,46,35,.07) !important;
    text-align:left !important;
    font:inherit !important;
    font-size:18px !important;
    line-height:1.35 !important;
    transform:none !important;
    touch-action:manipulation;
    -webkit-tap-highlight-color:rgba(47,127,111,.12);
  }

  .ademhaling-page .age-card:last-child{
    margin-bottom:0 !important;
  }

  .ademhaling-page .age-card::after{
    display:none !important;
    content:none !important;
  }

  .ademhaling-page .age-card span,
  .ademhaling-page .age-card strong,
  .ademhaling-page .age-card small{
    display:block !important;
    width:auto !important;
    min-width:0 !important;
    min-height:0 !important;
    margin:0 !important;
    padding:0 !important;
    background:transparent !important;
    border-radius:0 !important;
    text-align:left !important;
    white-space:normal !important;
    letter-spacing:0 !important;
  }

  .ademhaling-page .age-card span{
    margin-bottom:5px !important;
    color:var(--brand) !important;
    font-size:14px !important;
    line-height:1.1 !important;
    font-weight:800 !important;
  }

  .ademhaling-page .age-card strong{
    margin-bottom:5px !important;
    color:var(--brand-dark) !important;
    font-size:24px !important;
    line-height:1.12 !important;
    font-weight:800 !important;
  }

  .ademhaling-page .age-card small{
    color:var(--muted) !important;
    font-size:15px !important;
    line-height:1.3 !important;
    font-weight:600 !important;
  }

  .ademhaling-page .age-card.active{
    border-color:rgba(47,127,111,.62) !important;
    background:#eef8f3 !important;
    box-shadow:0 10px 24px rgba(47,127,111,.16) !important;
  }

  .ademhaling-page .breathing-visual{
    width:min(72vw, 260px) !important;
    height:auto !important;
    min-height:180px !important;
    margin:18px auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:visible !important;
  }

  .ademhaling-page .breathing-visual .bear,
  .ademhaling-page .breathing-visual .animal-focus,
  .ademhaling-page .breathing-visual .neon-ring{
    width:100% !important;
    max-width:240px !important;
    max-height:240px !important;
  }

  .ademhaling-page .controls{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .ademhaling-page .controls button{
    min-height:56px !important;
    padding:14px 18px !important;
    font-size:18px !important;
  }
}

@media (max-width:380px){
  .ademhaling-page .age-card{
    min-height:82px !important;
    padding:16px !important;
  }

  .ademhaling-page .age-card strong{
    font-size:22px !important;
  }

  .ademhaling-page .breathing-visual{
    width:min(68vw, 230px) !important;
    min-height:165px !important;
    margin:14px auto !important;
  }

  .ademhaling-page .breathing-visual .bear,
  .ademhaling-page .breathing-visual .animal-focus,
  .ademhaling-page .breathing-visual .neon-ring{
    max-width:220px !important;
    max-height:220px !important;
  }
}
