/* ========================================
   Physio Landingpage (Orange/Grau)
   ======================================== */

:root{
  --bg:#f7f4ef;
  --bg-2:#efebe4;
  --card:#ffffff;
  --text:#1f2328;
  --muted:#636a73;
  --line:#dfd6ca;
  --brand:#b7581d;
  --brand-2:#e28a2e;
  --brand-3:#f5b56d;
  --brand-deep:#35261f;
  --dark:#2f3135;
  --success:#1f7a4d;
  --warning:#9a6700;
  --error:#b42318;
  --shadow:0 18px 60px rgba(23,28,35,.10);
  --radius-xl:24px;
  --radius-lg:18px;
  --radius-md:14px;
  --container:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#faf7f2 0%, #f4f1ea 50%, #f6f3ee 100%);
  line-height:1.45;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}
.container{width:min(var(--container), calc(100% - 32px)); margin-inline:auto}
.section{padding:72px 0}
.center-title{text-align:center;font-size:clamp(1.8rem,3vw,2.5rem);margin:0 0 26px}
.center-title span,
.section-head h2 span,
.about-copy h2 span,
.process-head h2 span{color:var(--brand)}
.warm-img{filter:saturate(1.02) contrast(1.02)}
.site-bg-decor{
  position:fixed; inset:0; pointer-events:none; z-index:-1;
  background:
    radial-gradient(600px 320px at 90% 8%, rgba(226,138,46,.08), transparent 70%),
    radial-gradient(420px 240px at 8% 28%, rgba(183,88,29,.06), transparent 72%),
    radial-gradient(500px 300px at 80% 70%, rgba(255,202,133,.10), transparent 75%);
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:40;
  background:rgba(250,247,242,.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(223,214,202,.7);
}
.topbar-inner{
  min-height:72px;
  display:grid;
  grid-template-columns: 56px 1fr auto;
  align-items:center;
  gap:12px;
}
.brand{justify-self:center}
.brand img{height:44px; width:auto}
.top-actions{display:flex; align-items:center; gap:10px}
.icon-btn{
  width:42px; height:42px; border-radius:12px; border:1px solid var(--line); background:#fff;
  display:grid; place-items:center; cursor:pointer; color:var(--dark);
  transition:.2s ease;
}
.icon-btn:hover{transform:translateY(-1px); box-shadow:0 8px 20px rgba(0,0,0,.08)}
.icon-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon-btn.whatsapp{
  border-color:rgba(183,88,29,.24);
  color:var(--brand);
  background:linear-gradient(180deg, #fff, #fff7ef);
}
.icon-btn.whatsapp svg{width:18px;height:18px;fill:none;stroke:none}
.call-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:0 14px; height:42px; border-radius:12px;
  background:linear-gradient(180deg,var(--brand-2),var(--brand));
  color:#fff; font-weight:700; box-shadow:0 12px 30px rgba(183,88,29,.24);
}
.call-btn:hover{filter:brightness(1.02)}
.phone-icon{display:grid; place-items:center; width:18px; height:18px}
.phone-icon svg{width:18px;height:18px;fill:#fff}

/* Drawer */
.mobile-drawer{position:fixed; inset:0; z-index:60; pointer-events:none}
.mobile-drawer.is-open{pointer-events:auto}
.drawer-overlay{
  position:absolute; inset:0; background:rgba(17,17,19,.38);
  opacity:0; transition:.25s ease;
}
.drawer-panel{
  position:absolute; inset:0 auto 0 0; width:min(340px, 92vw);
  background:#fff; border-right:1px solid var(--line);
  transform:translateX(-105%); transition:.28s ease;
  display:flex; flex-direction:column; padding:14px;
  box-shadow:0 20px 60px rgba(0,0,0,.16);
}
.mobile-drawer.is-open .drawer-overlay{opacity:1}
.mobile-drawer.is-open .drawer-panel{transform:translateX(0)}
.drawer-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:8px}
.drawer-nav{display:grid; gap:4px; margin-top:6px}
.drawer-nav a{
  padding:12px 10px; border-radius:12px; font-weight:600;
  border:1px solid transparent;
}
.drawer-nav a:hover{background:var(--bg); border-color:var(--line)}
.drawer-contact{
  margin-top:auto; padding:12px; border:1px solid var(--line); border-radius:14px; background:var(--bg);
}
.drawer-contact p{margin:0 0 6px}
.drawer-contact p:last-child{margin-bottom:0}
.drawer-contact a{color:var(--brand); font-weight:700}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border-radius:12px; border:1px solid transparent; font-weight:700; cursor:pointer;
  transition:.2s ease; text-align:center;
}
.btn-primary{
  background:linear-gradient(180deg,var(--brand-2),var(--brand));
  color:#fff; box-shadow:0 12px 30px rgba(183,88,29,.20);
}
.btn-primary:hover{transform:translateY(-1px)}
.btn-outline{
  background:#fff; color:var(--dark); border-color:var(--line);
}
.btn-outline:hover{border-color:#cbbca8; color:var(--brand)}
.btn-sm{height:38px; padding:0 14px; font-size:.94rem}
.btn-block{width:100%; height:44px; padding:0 16px}

/* Hero */
.hero{padding:18px 0 36px}
.hero-wrap{
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(223,214,202,.9);
  background:linear-gradient(180deg, #fff 0%, #fcfbf8 100%);
  box-shadow:var(--shadow);
}
.hero-top{
  display:grid;
  grid-template-columns: 1fr 1.25fr;
  gap:22px;
  align-items:stretch;
  background:
    radial-gradient(240px 140px at 85% 38%, rgba(226,138,46,.10), transparent 70%),
    linear-gradient(135deg, #2b2724 0%, #3a2c24 28%, #4a331f 70%, #5f3c1a 100%);
  color:#fff;
  padding:22px 22px 150px;
  position:relative;
}
.hero-top::after{
  content:"";
  position:absolute; inset:auto 18px 12px auto; width:150px; height:110px;
  opacity:.12; border:2px solid #fff; border-radius:24px;
  transform:skew(-15deg);
}
.hero-copy-small{
  max-width:360px;
  font-size:.92rem;
  color:rgba(255,255,255,.86);
}
.hero-copy-small p{margin:10px 0 0}
.hero-headline h1{
  margin:4px 0 0;
  font-size:clamp(2rem, 4.2vw, 3.35rem);
  line-height:1.03;
  letter-spacing:-.03em;
}
.hero-media{
  position:relative;
  display:grid;
  grid-template-columns: 360px 1fr;
  gap:18px;
  margin-top:-122px;
  padding:0 22px 22px;
}
.hero-image-card{
  grid-column:2;
  position:relative;
  min-height:380px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#eee;
}
.hero-image-card img{
  width:100%; height:100%; object-fit:cover;
}
.trust-badge{
  position:absolute;
  right:14px; bottom:14px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(223,214,202,.9);
  border-radius:14px;
  padding:10px 12px;
  display:flex; align-items:center; gap:10px;
  box-shadow:0 12px 30px rgba(0,0,0,.12);
  max-width:260px;
}
.badge-avatars{display:flex; align-items:center}
.badge-avatars span{
  width:24px; height:24px; border-radius:50%;
  border:2px solid #fff;
  margin-left:-7px;
  background:
    radial-gradient(circle at 35% 35%, #fff 0 18%, transparent 20%),
    linear-gradient(180deg, #ffc78a, #d97926);
}
.badge-avatars span:first-child{margin-left:0}
.badge-avatars span:nth-child(2){background:linear-gradient(180deg, #ddd, #999)}
.badge-avatars span:nth-child(3){background:linear-gradient(180deg, #fad0e4, #e98ba0)}
.trust-badge p{margin:0; font-size:.78rem; line-height:1.3; color:var(--muted)}
.trust-badge strong{color:var(--text)}

.hero-form-card{
  grid-column:1;
  position:relative;
  z-index:2;
  background:rgba(255,255,255,.96);
  border-radius:18px;
  border:1px solid var(--line);
  padding:14px;
  box-shadow:0 18px 45px rgba(25,26,30,.14);
  align-self:start;
}

.alert{
  border-radius:12px;
  padding:10px 12px;
  margin-bottom:10px;
  font-size:.92rem;
  border:1px solid transparent;
}
.alert-success{background:#edf9f1; color:#0f6f3d; border-color:#bce7cb}
.alert-warning{background:#fff7e7; color:#8d5a00; border-color:#f2d28a}
.alert-error{background:#fff0ef; color:#b42318; border-color:#f1c0bc}

.contact-form .field{display:grid; gap:5px; margin-bottom:10px}
.contact-form label{font-weight:600; font-size:.88rem; color:#3d434a}
.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fbfbfa;
  padding:10px 12px;
  color:var(--text);
  outline:none;
  transition:.2s ease;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color:#e0a16a;
  box-shadow:0 0 0 4px rgba(226,138,46,.14);
  background:#fff;
}
.contact-form textarea{resize:vertical; min-height:90px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.form-note{margin:8px 0 0; color:var(--muted); font-size:.78rem}
.honeypot{position:absolute !important; left:-9999px; opacity:0; pointer-events:none}

/* Section common */
.section-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:18px;
}
.section-head h2{
  margin:0;
  font-size:clamp(1.7rem, 3vw, 2.5rem);
  letter-spacing:-.02em;
}

/* Services */
.services-section .container{
  background:#f1eee7;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px 18px 22px;
  box-shadow:var(--shadow);
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.service-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  box-shadow:0 10px 30px rgba(22,24,28,.05);
}
.service-card h3{
  margin:0 0 10px;
  font-size:1.1rem;
  letter-spacing:-.02em;
}
.service-card img{
  width:100%;
  aspect-ratio: 16 / 10;
  object-fit:cover;
  border-radius:10px;
  border:1px solid #ece6dd;
}
.service-card p{
  margin:10px 0 0;
  font-size:.9rem;
  color:var(--muted);
  min-height:52px;
}
.card-arrow{
  position:absolute;
  right:12px; top:62px;
  width:30px; height:30px; border-radius:10px;
  display:grid; place-items:center; font-weight:700;
  background:linear-gradient(180deg, #fbe7cb, #f3cd9f);
  border:1px solid #e4b27b;
  color:#6a3c12;
}
.slider-dots{display:flex; justify-content:center; gap:6px; margin-top:14px}
.slider-dots span{
  width:8px; height:8px; border-radius:999px; background:#d7cfc3;
}
.slider-dots span.active{width:24px; background:linear-gradient(90deg,var(--brand),var(--brand-2))}

/* Statement band */
.statement-band{
  overflow:hidden;
  padding:18px 0 8px;
}
.statement-track{
  display:flex; gap:20px; align-items:center;
  white-space:nowrap;
  font-size:clamp(2rem, 7vw, 4.8rem);
  line-height:.95;
  color:rgba(183,88,29,.52);
  letter-spacing:-.03em;
  animation:marquee 32s linear infinite;
}
.statement-track span:nth-child(2n){opacity:.45}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-35%)}
}

/* About */
.about-section{padding-top:30px}
.about-grid{
  display:grid;
  grid-template-columns: 1fr 1.15fr;
  gap:22px;
  align-items:center;
}
.about-image-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.about-image-card img{
  width:100%; aspect-ratio: 4 / 3; object-fit:cover;
}
.experience-badge{
  position:absolute;
  left:14px; bottom:14px;
  background:rgba(36,37,39,.9);
  color:#fff;
  border-radius:14px;
  padding:10px 12px;
  min-width:116px;
  border:1px solid rgba(255,255,255,.12);
}
.experience-badge strong{display:block; font-size:2rem; line-height:1}
.experience-badge span{font-size:.8rem; color:rgba(255,255,255,.86)}
.about-copy h2{
  margin:0 0 12px;
  font-size:clamp(1.7rem, 3.4vw, 2.75rem);
  line-height:1.05;
  letter-spacing:-.03em;
}
.about-copy p{
  margin:0 0 12px;
  color:var(--muted);
  max-width:62ch;
}

/* Process */
.process-section .container{
  background:linear-gradient(180deg,#efebe3,#ece8de);
  border:1px solid var(--line);
  border-radius:26px;
  padding:22px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.process-section .container::before,
.process-section .container::after{
  content:"";
  position:absolute;
  width:220px;height:220px; border-radius:44px;
  background:radial-gradient(circle at 35% 35%, rgba(226,138,46,.10), rgba(183,88,29,.05) 60%, transparent 62%);
  opacity:.8;
  z-index:0;
}
.process-section .container::before{right:-30px; bottom:20px}
.process-section .container::after{left:-40px; top:80px}
.process-head{
  position:relative; z-index:1;
  display:flex; gap:18px; justify-content:space-between; align-items:flex-end;
  margin-bottom:18px;
}
.process-head h2{
  margin:0 0 10px;
  font-size:clamp(1.7rem,3vw,2.4rem);
  letter-spacing:-.03em;
}
.process-head p{margin:0; color:var(--muted); max-width:62ch}
.process-grid{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
  align-items:start;
}
.process-card{
  background:rgba(255,255,255,.7);
  border:1px solid rgba(223,214,202,.9);
  border-radius:18px;
  padding:12px;
  backdrop-filter: blur(3px);
  box-shadow:0 8px 24px rgba(25,26,30,.05);
}
.process-card .step-no{
  display:inline-block; min-width:34px;
  padding:4px 8px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  color:#737b84; font-weight:700; font-size:.85rem;
  margin-bottom:8px;
}
.process-content h3{
  margin:0 0 8px; font-size:1.12rem; letter-spacing:-.02em;
}
.process-content img{
  width:100%; aspect-ratio: 16/10; object-fit:cover;
  border-radius:10px; border:1px solid #ece4d8;
}
.process-content p{
  margin:8px 0 0; color:var(--muted); font-size:.88rem;
}
.p1{grid-column:8 / -1}
.p2{grid-column:5 / 10; margin-top:62px}
.p3{grid-column:1 / 6; margin-top:126px}

/* Testimonials */
.testimonial-section{padding-top:54px}
.testimonial-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:16px 54px;
  box-shadow:var(--shadow);
}
.slider-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:34px; height:34px; border-radius:10px;
  border:1px solid var(--line); background:#fff;
  color:#66707b; cursor:pointer; font-size:1.2rem;
}
.slider-nav.prev{left:12px}
.slider-nav.next{right:12px}
.testimonial-inner{
  display:grid;
  grid-template-columns: 120px 1fr auto;
  gap:16px;
  align-items:center;
}
.testimonial-avatar{
  width:120px; height:120px; border-radius:999px;
  overflow:hidden; border:1px solid var(--line);
  background:#f0eee9;
}
.testimonial-avatar img{width:100%; height:100%; object-fit:cover}
.testimonial-text h3{margin:0; font-size:1.15rem}
.testimonial-text small{display:block; color:var(--muted); margin:2px 0 8px}
.testimonial-text p{margin:0; color:var(--muted)}
.quote-mark{
  font-size:4.4rem; color:rgba(183,88,29,.18); line-height:.7;
  font-weight:800; align-self:start;
}

.logo-strip{
  margin-top:20px;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
}
.logo-strip img{
  width:100%; height:48px; object-fit:contain;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:6px;
}

/* Footer */
.site-footer{padding:18px 0 26px}
.footer-cta{
  border-radius:20px;
  padding:12px 14px;
  border:1px solid rgba(95,60,26,.25);
  background:linear-gradient(135deg,#2d241f 0%, #563617 45%, #7c4a17 100%);
  color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  box-shadow:0 20px 50px rgba(73,39,12,.22);
}
.footer-cta-left img{
  height:46px; width:auto;
  filter:brightness(0) invert(1) contrast(1.02);
}
.footer-cta-right{display:flex; align-items:center; gap:10px}
.footer-call{
  height:40px; padding:0 14px; border-radius:12px;
  display:inline-flex; align-items:center;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18);
  font-weight:700;
}
.footer-grid{
  margin-top:16px;
  background:#f1eee7;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  display:grid;
  grid-template-columns:1.15fr .8fr .8fr 1fr;
  gap:18px;
}
.footer-grid h3{
  margin:0 0 10px; font-size:1rem;
}
.muted{color:var(--muted); margin:0; font-size:.92rem}
.social-row{display:flex; gap:8px; margin-bottom:10px}
.social-row a{
  width:34px; height:34px; border-radius:10px; display:grid; place-items:center;
  border:1px solid var(--line); background:#fff; color:#5e6670; font-weight:700; font-size:.78rem;
}
.footer-links{list-style:none; padding:0; margin:0; display:grid; gap:6px}
.footer-links a{color:var(--muted)}
.footer-links a:hover{color:var(--brand)}
.newsletter-form{
  display:grid; gap:8px; max-width:320px;
}
.newsletter-form input{
  width:100%; height:42px; padding:0 12px;
  border-radius:12px; border:1px solid var(--line); background:#fff;
}
.footer-bottom{
  display:flex; justify-content:space-between; gap:12px;
  padding:14px 4px 0;
  color:var(--muted);
  font-size:.85rem;
}
.footer-bottom a{color:inherit}
.footer-bottom a:hover{color:var(--brand)}

/* Responsive */
@media (max-width: 1080px){
  .hero-media{grid-template-columns: 330px 1fr}
  .hero-top{grid-template-columns:1fr 1.1fr}
  .logo-strip{grid-template-columns:repeat(3,1fr)}
}

@media (max-width: 900px){
  .topbar-inner{grid-template-columns:56px 1fr auto}
  .call-btn{padding:0 10px}
  .call-btn .phone-icon{display:none}
  .call-btn{font-size:.88rem}
  .hero-top{
    grid-template-columns:1fr;
    padding-bottom:18px;
    gap:8px;
  }
  .hero-media{
    margin-top:0;
    padding-top:0;
    grid-template-columns:1fr;
  }
  .hero-form-card,.hero-image-card{grid-column:auto}
  .hero-image-card{min-height:260px}
  .grid-2{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .service-card p{min-height:0}
  .about-grid{grid-template-columns:1fr}
  .process-head{flex-direction:column; align-items:flex-start}
  .process-grid{grid-template-columns:1fr}
  .p1,.p2,.p3{grid-column:auto; margin-top:0}
  .testimonial-card{padding:16px}
  .slider-nav{display:none}
  .testimonial-inner{
    grid-template-columns:1fr;
    text-align:center;
  }
  .testimonial-avatar{margin-inline:auto}
  .quote-mark{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 620px){
  .topbar-inner{gap:8px}
  .brand img{height:38px}
  .top-actions{gap:8px}
  .call-btn{
    width:42px; padding:0; justify-content:center;
    font-size:0; gap:0;
  }
  .call-btn::before{
    content:"";
    width:18px; height:18px;
    background:currentColor;
    mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox=\"0 0 24 24\"><path fill=\"black\" d=\"M6.6 10.8a15.7 15.7 0 0 0 6.6 6.6l2.2-2.2c.3-.3.7-.4 1.1-.3 1.2.4 2.4.6 3.7.6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1C10.5 21 3 13.5 3 4c0-.6.4-1 1-1h3.5c.6 0 1 .4 1 1 0 1.3.2 2.5.6 3.7.1.4 0 .8-.3 1.1l-2.2 2Z\"/></svg>') center / contain no-repeat;
    color:#fff;
  }
  .phone-icon{display:none}
  .hero{padding-top:10px}
  .hero-wrap{border-radius:22px}
  .services-section .container,
  .process-section .container{border-radius:20px}
  .section{padding:54px 0}
  .statement-track{font-size:clamp(1.6rem, 11vw, 3rem)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
}
