/*
Theme Name: WeCare Berlin
Theme URI: https://wecare-berlin.de/
Author: WeCare Berlin
Author URI: https://wecare-berlin.de/
Description: One-page WordPress theme converted from the WeCare Berlin flat HTML landing page. Includes bilingual DE/EN layout, service sections, booking and inquiry modals, responsive styling, and theme-ready WordPress hooks.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wecare-berlin
Tags: one-page, landing-page, responsive, custom-logo, business
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#0d1410;
  --ink2:#1e2b22;
  --ac:#1e7a48;       /* accent — one green, used sparingly */
  --ac-light:#e8f5ee;
  --ac-mid:#2a9058;
  --off:#f5f4f1;
  --warm:#faf9f7;
  --stone:#e0dbd3;
  --muted:#7a8680;
  --white:#ffffff;
  --gold:#b8882a;
  --nav:70px;
  --r:10px;
}
html{scroll-behavior:smooth}
body{font-family:'Bricolage Grotesque',sans-serif;background:var(--warm);color:var(--ink);overflow-x:hidden;font-weight:400;line-height:1.6;font-size:16px}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--off)}
::-webkit-scrollbar-thumb{background:var(--stone);border-radius:2px}

/* DE/EN */
[lang="de"] .en{display:none}[lang="en"] .de{display:none}
[lang="de"] .en-i{display:none}[lang="en"] .de-i{display:none}
[lang="de"] .en-b{display:none}[lang="en"] .de-b{display:none}

/* ── WHATSAPP FLOAT ── */
.wa-btn{
  position:fixed;bottom:90px;right:28px;z-index:990;
  width:52px;height:52px;border-radius:50%;
  background:#25d366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.35);
  text-decoration:none;transition:all 0.2s;
}
.wa-btn:hover{transform:scale(1.1)}
.wa-btn svg{width:26px;height:26px;fill:#fff}
/* ── SCROLL UP ── */
.scroll-up{
  position:fixed;bottom:28px;right:28px;z-index:990;
  width:44px;height:44px;border-radius:50%;
  background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;cursor:pointer;
  box-shadow:0 4px 14px rgba(13,20,16,0.25);
  transition:all 0.2s;text-decoration:none;
  opacity:0;pointer-events:none;
}
.scroll-up.visible{opacity:1;pointer-events:all}
.scroll-up:hover{background:var(--ac);transform:translateY(-2px)}

/* ── LANG TOGGLE ── */
.lang-toggle{display:flex;border:1px solid var(--stone);border-radius:100px;overflow:hidden}
.lt-btn{
  padding:4px 11px;border:none;background:transparent;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:0.72rem;font-weight:700;color:var(--muted);cursor:pointer;transition:all 0.15s;
}
.lt-btn.on{background:var(--ink);color:#fff}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:var(--nav);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 max(28px,4vw);
  background:rgba(250,249,247,0.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(224,219,211,0.8);
}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-box{
  width:36px;height:36px;border-radius:9px;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
}
.logo-box svg{width:20px;height:20px}
.logo-text{font-size:1.15rem;font-weight:700;color:var(--ink);letter-spacing:-0.4px}
.logo-text span{color:var(--ac)}
/* Nav right side */
.nav-right{display:flex;align-items:center;gap:1.5rem}
.nav-menu{display:flex;gap:1.75rem;list-style:none}
.nav-menu a{font-size:0.82rem;font-weight:500;color:var(--muted);text-decoration:none;transition:color 0.15s;white-space:nowrap}
.nav-menu a:hover{color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:0.75rem}
.nav-cta{
  background:var(--ink);color:#fff;
  font-size:0.8rem;font-weight:700;letter-spacing:0.2px;
  padding:0.55rem 1.25rem;border-radius:100px;
  text-decoration:none;white-space:nowrap;transition:all 0.18s;
}
.nav-cta:hover{background:var(--ac)}

/* ── STICKY PAGE-NAV ── */
.pg-nav{
  position:sticky;top:var(--nav);z-index:90;
  background:var(--off);border-bottom:1px solid var(--stone);
  display:flex;overflow-x:auto;scrollbar-width:none;
  padding:0 max(28px,4vw);
}
.pg-nav::-webkit-scrollbar{display:none}
.pg-nav a{
  display:block;padding:0.8rem 1.1rem;white-space:nowrap;
  font-size:0.76rem;font-weight:600;color:var(--muted);
  text-decoration:none;border-bottom:2px solid transparent;transition:all 0.15s;
}
.pg-nav a:hover,.pg-nav a.on{color:var(--ink);border-bottom-color:var(--ink)}

/* ── SHARED ── */
.sec{padding:clamp(56px,7vw,96px) max(28px,4vw)}
.sec-off{background:var(--off)}
.sec-dark{background:var(--ink)}

.eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.67rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:0.85rem;
}
.eyebrow::before{content:'';width:14px;height:2px;background:var(--stone);border-radius:2px;flex-shrink:0}
.eyebrow-ac{color:var(--ac)}
.eyebrow-ac::before{background:var(--ac)}
.eyebrow-light{color:rgba(255,255,255,0.35)}
.eyebrow-light::before{background:rgba(255,255,255,0.2)}

.sh{
  font-family:'Lora',serif;
  font-size:clamp(1.8rem,3vw,2.9rem);
  font-weight:500;line-height:1.18;
  letter-spacing:-0.4px;color:var(--ink);margin-bottom:0.75rem;
}
.sh em{font-style:italic;color:var(--ac)}
.sh-light{color:#fff}.sh-light em{color:rgba(255,255,255,0.6)}
.body-txt{font-size:0.9rem;color:var(--muted);line-height:1.8;font-weight:400;max-width:540px}
.body-txt-light{color:rgba(255,255,255,0.5)}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center .eyebrow::before{display:none}
.center .body-txt{margin:0 auto}

.btn-dark{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--ink);color:#fff;
  font-size:0.875rem;font-weight:700;padding:0.82rem 1.75rem;
  border-radius:100px;text-decoration:none;transition:all 0.18s;
}
.btn-dark:hover{background:var(--ac);transform:translateY(-1px)}
.btn-outline{
  display:inline-flex;align-items:center;gap:7px;
  background:transparent;color:var(--ink);
  font-size:0.875rem;font-weight:600;padding:0.82rem 1.75rem;
  border-radius:100px;text-decoration:none;
  border:1.5px solid var(--stone);transition:all 0.18s;
}
.btn-outline:hover{border-color:var(--ink);color:var(--ink)}

/* ── HERO ── */
.hero{
  min-height:100vh;padding-top:var(--nav);
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--warm);
}
.hero-left{
  padding:clamp(40px,6vw,80px) clamp(20px,3vw,48px) clamp(40px,6vw,80px) max(28px,4vw);
  display:flex;flex-direction:column;justify-content:center;
}
.hero-kicker{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.75rem;
}
.hero-kicker::before{content:'';width:22px;height:1.5px;background:var(--stone);border-radius:2px}
.hero h1{
  font-family:'Lora',serif;
  font-size:clamp(2.8rem,5vw,5rem);
  font-weight:500;line-height:1.05;
  letter-spacing:-1.5px;color:var(--ink);margin-bottom:1.5rem;
}
.hero h1 em{font-style:italic;color:var(--ac)}
.hero-sub{
  font-size:1rem;line-height:1.78;color:var(--muted);
  max-width:420px;margin-bottom:2.5rem;
}
.hero-btns{display:flex;gap:0.75rem;flex-wrap:wrap}
.hero-trust{
  display:flex;gap:2.5rem;margin-top:3rem;
  padding-top:2rem;border-top:1px solid var(--stone);
}
.ht-num{font-family:'Lora',serif;font-size:2rem;font-weight:500;color:var(--ink);line-height:1}
.ht-lbl{font-size:0.7rem;color:var(--muted);margin-top:3px}
.hero-right{
  background:var(--off);
  display:flex;flex-direction:column;gap:0.75rem;
  justify-content:center;padding:clamp(40px,6vw,80px) max(28px,4vw) clamp(40px,6vw,80px) clamp(20px,3vw,48px);
}
.hero-mosaic{
  display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:200px 150px;gap:0.75rem;border-radius:16px;overflow:hidden;
}
.hm{background:var(--stone);overflow:hidden;position:relative}
.hm:first-child{grid-row:span 2}
.hm img{width:100%;height:100%;object-fit:cover}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--ink);border-radius:14px;padding:1rem 0;
}
.hs-item{text-align:center;padding:0.6rem 0.5rem}
.hs-num{font-family:'Lora',serif;font-size:1.4rem;font-weight:500;color:#fff;line-height:1}
.hs-lbl{font-size:0.6rem;color:rgba(255,255,255,0.4);margin-top:3px;letter-spacing:0.2px}
.hs-div{width:1px;background:rgba(255,255,255,0.08)}

/* ── TRUST BAR ── */
.trust-bar{
  background:var(--off);border-top:1px solid var(--stone);border-bottom:1px solid var(--stone);
  padding:0.9rem max(28px,4vw);
  display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;
}
.tb-item{display:flex;align-items:center;gap:6px;padding:0.3rem 1.75rem;font-size:0.77rem;color:var(--muted)}
.tb-item strong{color:var(--ink2);font-weight:600}
.tb-div{width:1px;height:16px;background:var(--stone)}

/* ── SERVICES GRID ── */
#leistungen .svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-top:3.5rem;
}
.svc-card{
  border-radius:14px;overflow:hidden;
  border:1px solid var(--stone);background:var(--white);
  transition:all 0.22s;display:flex;flex-direction:column;
  cursor:pointer;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,0.09);border-color:var(--ink)}
.svc-img{height:190px;overflow:hidden;position:relative;background:var(--stone);flex-shrink:0}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.svc-card:hover .svc-img img{transform:scale(1.05)}
.svc-badge{
  position:absolute;top:12px;left:12px;
  width:34px;height:34px;border-radius:50%;
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:'Lora',serif;font-size:0.88rem;font-weight:500;
  color:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.25);
}
.svc-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.svc-name{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:0.4rem;line-height:1.25}
.svc-desc{font-size:0.8rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:1rem}
.svc-chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:1rem}
.chip{font-size:0.64rem;font-weight:600;padding:2px 8px;border-radius:100px;background:var(--off);color:var(--ink2);border:1px solid var(--stone)}
.svc-action{
  display:flex;gap:8px;flex-wrap:wrap;
}
.svc-book-btn{
  font-size:0.75rem;font-weight:700;
  padding:7px 14px;border-radius:100px;
  background:var(--ink);color:#fff;
  border:none;cursor:pointer;transition:all 0.15s;
  font-family:'Bricolage Grotesque',sans-serif;
}
.svc-book-btn:hover{background:var(--ac)}
.svc-req-btn{
  font-size:0.75rem;font-weight:600;
  padding:7px 14px;border-radius:100px;
  background:transparent;color:var(--muted);
  border:1px solid var(--stone);cursor:pointer;transition:all 0.15s;
  font-family:'Bricolage Grotesque',sans-serif;
}
.svc-req-btn:hover{border-color:var(--ink);color:var(--ink)}
/* featured svc card */
.svc-card.feat{background:var(--ink);border-color:var(--ink)}
.svc-card.feat .svc-badge{background:var(--white);color:var(--ink)}
.svc-card.feat .svc-name{color:#fff}
.svc-card.feat .svc-desc{color:rgba(255,255,255,0.6)}
.svc-card.feat .chip{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.75);border-color:rgba(255,255,255,0.1)}
.svc-card.feat .svc-book-btn{background:rgba(255,255,255,0.15);color:#fff}
.svc-card.feat .svc-book-btn:hover{background:var(--ac)}
.svc-card.feat .svc-req-btn{border-color:rgba(255,255,255,0.2);color:rgba(255,255,255,0.6)}

/* ── BOOKING MODAL ── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(13,20,16,0.5);
  align-items:center;justify-content:center;
  padding:1rem;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--white);border-radius:20px;
  width:100%;max-width:620px;
  max-height:90vh;overflow-y:auto;
  padding:2.25rem;position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,0.18);
}
.modal-close{
  position:absolute;top:1.25rem;right:1.25rem;
  width:32px;height:32px;border-radius:50%;
  background:var(--off);border:1px solid var(--stone);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;cursor:pointer;transition:all 0.15s;color:var(--muted);
}
.modal-close:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.modal-title{
  font-family:'Lora',serif;font-size:1.5rem;font-weight:500;
  color:var(--ink);margin-bottom:0.25rem;letter-spacing:-0.3px;
}
.modal-sub{font-size:0.82rem;color:var(--muted);margin-bottom:1.75rem}

/* STEPS */
.step-bar{
  display:flex;gap:0;margin-bottom:2rem;
  border:1px solid var(--stone);border-radius:100px;overflow:hidden;
}
.step-dot{
  flex:1;padding:7px;text-align:center;
  font-size:0.68rem;font-weight:700;color:var(--muted);
  border-right:1px solid var(--stone);transition:all 0.2s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.step-dot:last-child{border-right:none}
.step-dot.done{background:var(--off);color:var(--ink)}
.step-dot.active{background:var(--ink);color:#fff}

/* STEP CONTENT */
.step-content{display:none}
.step-content.active{display:block}

.option-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0.75rem;margin-bottom:1.5rem;
}
.opt-btn{
  padding:1rem;border:1.5px solid var(--stone);border-radius:12px;
  background:var(--warm);cursor:pointer;text-align:left;
  transition:all 0.15s;font-family:'Bricolage Grotesque',sans-serif;
}
.opt-btn:hover{border-color:var(--ink);background:var(--off)}
.opt-btn.selected{border-color:var(--ink);background:var(--ink)}
.opt-btn.selected .opt-name{color:#fff}
.opt-btn.selected .opt-sub{color:rgba(255,255,255,0.5)}
.opt-icon{font-size:1.5rem;margin-bottom:0.5rem;display:block}
.opt-name{font-size:0.85rem;font-weight:700;color:var(--ink);line-height:1.2}
.opt-sub{font-size:0.72rem;color:var(--muted);margin-top:2px}

.fg{display:flex;flex-direction:column;gap:4px;margin-bottom:0.85rem}
.fl{font-size:0.7rem;font-weight:700;color:var(--ink2);letter-spacing:0.2px}
.fi,.fs,.ft{
  padding:0.65rem 0.85rem;border:1.5px solid var(--stone);border-radius:9px;
  font-family:'Bricolage Grotesque',sans-serif;font-size:0.85rem;
  font-weight:400;color:var(--ink);background:var(--warm);outline:none;width:100%;
  transition:border-color 0.15s,box-shadow 0.15s;
}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(13,20,16,0.08)}
.fi::placeholder,.ft::placeholder{color:var(--stone)}
.ft{resize:none;height:80px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:0.85rem}

/* PAKETE */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem;margin-bottom:1.5rem}
.pkg{
  border:1.5px solid var(--stone);border-radius:12px;
  padding:1.1rem;cursor:pointer;transition:all 0.15s;
  background:var(--warm);text-align:center;
}
.pkg:hover{border-color:var(--ink)}
.pkg.sel{border-color:var(--ink);background:var(--ink)}
.pkg.sel .pkg-name,.pkg.sel .pkg-price,.pkg.sel .pkg-desc{color:#fff}
.pkg.sel .pkg-desc{color:rgba(255,255,255,0.5)}
.pkg-name{font-size:0.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.pkg-price{font-family:'Lora',serif;font-size:1.5rem;font-weight:500;color:var(--ink);line-height:1;margin-bottom:4px}
.pkg-desc{font-size:0.7rem;color:var(--muted)}

/* CALENDAR */
.cal-wrap{margin-bottom:1.5rem}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-nav-btn{
  width:32px;height:32px;border-radius:50%;background:var(--off);
  border:1px solid var(--stone);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:0.9rem;
  transition:all 0.15s;
}
.cal-nav-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cal-month{font-size:0.9rem;font-weight:700;color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-head{font-size:0.65rem;font-weight:700;color:var(--muted);text-align:center;padding:4px 0}
.cal-day{
  aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:0.78rem;font-weight:500;cursor:pointer;
  border:1px solid transparent;transition:all 0.15s;color:var(--ink);
}
.cal-day:hover:not(.empty):not(.past){background:var(--off);border-color:var(--stone)}
.cal-day.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.cal-day.today{border-color:var(--ink);color:var(--ink)}
.cal-day.empty,.cal-day.past{opacity:0.25;cursor:default;pointer-events:none}

/* CONFIRM */
.confirm-box{
  background:var(--off);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;
}
.confirm-row{
  display:flex;justify-content:space-between;
  font-size:0.82rem;padding:0.4rem 0;
  border-bottom:1px solid var(--stone);
}
.confirm-row:last-child{border-bottom:none}
.cr-label{color:var(--muted)}
.cr-val{font-weight:600;color:var(--ink)}
.success-box{
  text-align:center;padding:2rem 1rem;display:none;
}
.success-icon{font-size:3rem;margin-bottom:1rem;display:block}
.success-title{font-family:'Lora',serif;font-size:1.5rem;font-weight:500;color:var(--ink);margin-bottom:0.5rem}
.success-sub{font-size:0.85rem;color:var(--muted);line-height:1.65}

/* INQUIRY MODAL */
.inq-modal{
  background:var(--white);border-radius:20px;
  width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  padding:2.25rem;position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,0.18);
}

.modal-btns{display:flex;gap:0.75rem;justify-content:flex-end;margin-top:1rem}
.m-btn-next{
  background:var(--ink);color:#fff;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:0.82rem;font-weight:700;
  padding:0.7rem 1.5rem;border-radius:100px;
  border:none;cursor:pointer;transition:all 0.15s;
}
.m-btn-next:hover{background:var(--ac)}
.m-btn-prev{
  background:transparent;color:var(--muted);
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:0.82rem;font-weight:600;
  padding:0.7rem 1.25rem;border-radius:100px;
  border:1px solid var(--stone);cursor:pointer;transition:all 0.15s;
}
.m-btn-prev:hover{border-color:var(--ink);color:var(--ink)}
.m-btn-submit{
  background:var(--ac);color:#fff;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:0.85rem;font-weight:700;
  padding:0.85rem 2rem;border-radius:100px;
  border:none;cursor:pointer;width:100%;margin-top:1rem;
  display:flex;align-items:center;justify-content:center;gap:6px;transition:all 0.15s;
}
.m-btn-submit:hover{background:var(--ink)}

/* ── HOW ── */
.how-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;border:1px solid var(--stone);border-radius:16px;overflow:hidden;
  margin-top:3.5rem;
}
.how-cell{
  padding:2rem 1.5rem;border-right:1px solid var(--stone);
  transition:background 0.2s;
}
.how-cell:last-child{border-right:none}
.how-cell:hover{background:var(--off)}
.how-cell.hi{background:var(--ink);border-color:var(--ink)}
.how-n{
  font-family:'Lora',serif;font-size:3.5rem;
  font-weight:500;color:var(--stone);line-height:1;margin-bottom:1.1rem;
  letter-spacing:-2px;
}
.how-cell.hi .how-n{color:rgba(255,255,255,0.12)}
.how-icon{font-size:1.4rem;margin-bottom:0.75rem;display:block}
.how-t{font-size:0.88rem;font-weight:700;color:var(--ink);margin-bottom:0.4rem}
.how-cell.hi .how-t{color:#fff}
.how-d{font-size:0.77rem;color:var(--muted);line-height:1.65}
.how-cell.hi .how-d{color:rgba(255,255,255,0.5)}

/* ── PRICING ── */
.p-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-top:3.5rem;align-items:start;
}
.pc{
  border-radius:18px;padding:2rem;
  border:1px solid var(--stone);background:var(--white);
  display:flex;flex-direction:column;transition:all 0.2s;
}
.pc:hover:not(.pc-f){transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,0.07)}
.pc-f{
  background:var(--ink);border-color:var(--ink);
  transform:scale(1.03);box-shadow:0 20px 48px rgba(13,20,16,0.2);
}
.pc-flag{
  font-size:0.62rem;font-weight:700;letter-spacing:0.5px;
  background:var(--gold);color:#fff;
  padding:3px 9px;border-radius:100px;display:inline-block;margin-bottom:1rem;width:fit-content;
}
.pc-tier{font-size:0.67rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:0.6rem}
.pc-f .pc-tier{color:rgba(255,255,255,0.3)}
.pc-price{font-family:'Lora',serif;font-size:3rem;font-weight:500;color:var(--ink);line-height:1;margin-bottom:0.25rem;letter-spacing:-1px}
.pc-f .pc-price{color:#fff}
.pc-per{font-size:0.75rem;color:var(--muted);margin-bottom:1.5rem}
.pc-f .pc-per{color:rgba(255,255,255,0.3)}
.pc-hr{height:1px;background:var(--stone);margin-bottom:1.35rem}
.pc-f .pc-hr{background:rgba(255,255,255,0.08)}
.pc-list{list-style:none;display:flex;flex-direction:column;gap:0.6rem;flex:1;margin-bottom:1.75rem}
.pc-list li{display:flex;align-items:flex-start;gap:0.55rem;font-size:0.8rem;color:var(--ink2);line-height:1.4}
.pc-f .pc-list li{color:rgba(255,255,255,0.7)}
.pc-ck{
  width:17px;height:17px;border-radius:4px;flex-shrink:0;
  background:var(--off);border:1px solid var(--stone);
  display:flex;align-items:center;justify-content:center;font-size:8px;color:var(--ac);margin-top:1px;
}
.pc-f .pc-ck{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.1);color:rgba(255,255,255,0.6)}
.pc-btn{
  display:block;text-align:center;padding:0.8rem;border-radius:10px;
  font-size:0.8rem;font-weight:700;text-decoration:none;transition:all 0.15s;
  border:1.5px solid var(--ink);color:var(--ink);
}
.pc-btn:hover{background:var(--ink);color:#fff}
.pc-f .pc-btn{background:rgba(255,255,255,0.12);color:#fff;border-color:rgba(255,255,255,0.2)}
.pc-f .pc-btn:hover{background:rgba(255,255,255,0.22)}

/* ── PROJECTS ── */
.proj-grid{display:flex;flex-direction:column;gap:2.5rem;margin-top:3.5rem}
.proj-item{
  display:grid;grid-template-columns:1fr auto 1fr;
  border-radius:18px;overflow:hidden;border:1px solid var(--stone);
  background:var(--white);
}
.proj-side{position:relative;overflow:hidden}
.proj-side img{width:100%;height:260px;object-fit:cover;display:block;transition:transform 0.4s}
.proj-item:hover .proj-side img{transform:scale(1.03)}
.proj-lbl{
  position:absolute;top:12px;left:12px;
  font-size:0.62rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.lbl-b{background:rgba(13,20,16,0.7);color:#fff}
.lbl-a{background:var(--ac);color:#fff}
.proj-mid{
  width:3px;background:var(--white);
  display:flex;align-items:center;justify-content:center;z-index:2;
}
.proj-mid-icon{
  width:30px;height:30px;border-radius:50%;
  background:var(--white);border:1px solid var(--stone);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--muted);box-shadow:0 2px 8px rgba(0,0,0,0.1);
  flex-shrink:0;
}
.proj-info{
  grid-column:1/-1;padding:1.1rem 1.5rem;
  border-top:1px solid var(--stone);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.pi-cat{font-size:0.62rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.pi-name{font-size:0.9rem;font-weight:700;color:var(--ink)}
.pi-loc{font-size:0.73rem;color:var(--muted);margin-top:1px}
.pi-tag{
  font-size:0.65rem;font-weight:600;white-space:nowrap;
  background:var(--off);color:var(--ink2);
  border:1px solid var(--stone);padding:4px 10px;border-radius:100px;
}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-img-area{position:relative}
.about-img{
  width:100%;aspect-ratio:4/5;border-radius:18px;
  background:url('https://images.unsplash.com/photo-1600880292203-757bb62b4baf?w=700&q=80') center/cover;
  display:block;
}
.about-badge{
  position:absolute;bottom:-18px;right:-18px;
  background:var(--ink);color:#fff;
  border-radius:14px;padding:1rem 1.25rem;
  border:3px solid var(--warm);text-align:center;
}
.ab-num{font-family:'Lora',serif;font-size:1.85rem;font-weight:500;line-height:1}
.ab-lbl{font-size:0.62rem;opacity:0.5;margin-top:2px;letter-spacing:0.3px}
.about-body{font-size:0.9rem;color:var(--muted);line-height:1.85;margin-top:0.75rem;margin-bottom:2rem}
.vr{
  display:flex;align-items:flex-start;gap:0.9rem;
  padding:0.9rem 1rem;border-radius:10px;
  background:var(--off);border:1px solid var(--stone);margin-bottom:0.65rem;
}
.vr-icon{
  width:34px;height:34px;border-radius:8px;
  background:var(--white);border:1px solid var(--stone);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;
}
.vr-t{font-size:0.85rem;font-weight:700;color:var(--ink);margin-bottom:2px}
.vr-d{font-size:0.73rem;color:var(--muted);line-height:1.5}

/* ── TEAM ── */
.team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.25rem;margin-top:3.5rem;
}
.team-card{
  border-radius:14px;overflow:hidden;
  border:1px solid var(--stone);background:var(--white);transition:all 0.2s;
}
.team-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,0.07)}
.tc-img{height:210px;overflow:hidden;position:relative;background:var(--stone)}
.tc-img img{width:100%;height:100%;object-fit:cover;object-position:top}
.tc-role-tag{
  position:absolute;bottom:10px;left:10px;
  background:var(--ink);color:#fff;
  font-size:0.6rem;font-weight:700;letter-spacing:0.5px;
  padding:3px 9px;border-radius:100px;
}
.tc-body{padding:1.1rem}
.tc-name{font-size:0.92rem;font-weight:700;color:var(--ink);margin-bottom:1px}
.tc-role{font-size:0.72rem;color:var(--ac);font-weight:600;margin-bottom:0.45rem}
.tc-bio{font-size:0.73rem;color:var(--muted);line-height:1.55}
.tc-soc{display:flex;gap:5px;margin-top:0.75rem}
.tc-soc a{
  width:26px;height:26px;border-radius:6px;
  border:1px solid var(--stone);display:flex;align-items:center;justify-content:center;
  text-decoration:none;font-size:11px;color:var(--muted);transition:all 0.15s;
}
.tc-soc a:hover{background:var(--ink);border-color:var(--ink);color:#fff}

/* ── TESTIMONIALS ── */
.testi-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:1.25rem;margin-top:3.5rem;
}
.tes{
  border-radius:16px;padding:1.75rem;
  border:1px solid var(--stone);background:var(--white);
  display:flex;flex-direction:column;transition:all 0.2s;
}
.tes:hover{border-color:var(--stone);transform:translateY(-2px)}
.tes.tes-big{grid-column:span 2;background:var(--off);border-color:var(--stone)}
.tes-stars{display:flex;gap:2px;margin-bottom:1rem}
.star{width:12px;height:12px;background:var(--gold);border-radius:2px}
.tes-text{
  font-family:'Lora',serif;font-size:0.98rem;font-style:italic;
  color:var(--ink2);line-height:1.6;margin-bottom:1.35rem;flex:1;
}
.tes.tes-big .tes-text{font-size:1.1rem}
.tes-author{display:flex;align-items:center;gap:0.7rem;margin-top:auto}
.tes-av{
  width:36px;height:36px;border-radius:50%;
  background:var(--ink);display:flex;align-items:center;justify-content:center;
  font-size:0.68rem;font-weight:700;color:#fff;flex-shrink:0;
}
.tes-name{font-size:0.82rem;font-weight:700;color:var(--ink)}
.tes-role{font-size:0.7rem;color:var(--muted);margin-top:1px}

/* ── CONTACT ── */
.ct-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:start}
.ct-left{}
.ct-body{font-size:0.9rem;color:rgba(255,255,255,0.5);line-height:1.8;margin-top:0.75rem;margin-bottom:2rem}
.ct-links{display:flex;flex-direction:column;gap:0.65rem}
.ct-link{
  display:flex;align-items:center;gap:0.8rem;
  padding:0.9rem 1rem;border-radius:12px;
  border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);
  text-decoration:none;transition:all 0.15s;
}
.ct-link:hover{background:rgba(255,255,255,0.09)}
.ct-link-icon{
  width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,0.07);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;
}
.ct-link-label{font-size:0.63rem;color:rgba(255,255,255,0.3);margin-bottom:1px}
.ct-link-val{font-size:0.83rem;font-weight:600;color:#fff}
.wa-link{
  display:flex;align-items:center;gap:0.8rem;
  padding:0.9rem 1rem;border-radius:12px;
  border:1px solid rgba(37,211,102,0.25);background:rgba(37,211,102,0.08);
  text-decoration:none;transition:all 0.15s;
}
.wa-link:hover{background:rgba(37,211,102,0.15)}
.wa-link-icon{
  width:34px;height:34px;border-radius:8px;background:#25d366;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.wa-link-icon svg{width:18px;height:18px;fill:#fff}
.wa-link-label{font-size:0.63rem;color:rgba(255,255,255,0.3);margin-bottom:1px}
.wa-link-val{font-size:0.83rem;font-weight:600;color:#25d366}
.pm-list{display:flex;flex-direction:column;gap:0.45rem;margin-top:1.4rem}
.pm{display:flex;align-items:center;gap:0.55rem;font-size:0.77rem;color:rgba(255,255,255,0.4)}
.pm::before{content:'';width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.2);flex-shrink:0}
.form-box{
  background:var(--white);border:1px solid var(--stone);border-radius:18px;padding:2.25rem;
}
.form-box .modal-title{font-size:1.35rem;margin-bottom:0.25rem}
.form-box .modal-sub{margin-bottom:1.5rem}
.form-box .m-btn-submit{font-size:0.875rem;padding:0.9rem 2rem;border-radius:12px}

/* ── FOOTER ── */
footer{background:var(--ink);padding:clamp(48px,6vw,72px) max(28px,4vw) 2rem}
.ft-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;
  padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,0.07);margin-bottom:2rem;
}
.ft-logo{display:flex;align-items:center;gap:8px;text-decoration:none;margin-bottom:0.8rem}
.ft-lm{width:30px;height:30px;border-radius:7px;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center}
.ft-lm svg{width:16px;height:16px}
.ft-lw{font-size:1.05rem;font-weight:700;color:#fff;letter-spacing:-0.3px}
.ft-lw span{color:rgba(255,255,255,0.4)}
.ft-tag{font-size:0.76rem;color:rgba(255,255,255,0.28);line-height:1.7;max-width:220px;margin-bottom:1.25rem}
.soc-row{display:flex;gap:7px;flex-wrap:wrap}
.si{
  width:32px;height:32px;border-radius:7px;
  border:1px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:rgba(255,255,255,0.4);transition:all 0.15s;
}
.si:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2);color:#fff}
.si svg{width:14px;height:14px;fill:currentColor}
.fc-title{font-size:0.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.2);margin-bottom:1rem}
.fc a{display:block;font-size:0.77rem;color:rgba(255,255,255,0.42);text-decoration:none;margin-bottom:0.5rem;transition:color 0.15s}
.fc a:hover{color:rgba(255,255,255,0.85)}
.ft-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.75rem}
.ft-copy{font-size:0.68rem;color:rgba(255,255,255,0.17)}
.ft-legal{display:flex;gap:1.5rem}
.ft-legal a{font-size:0.68rem;color:rgba(255,255,255,0.2);text-decoration:none;transition:color 0.15s}
.ft-legal a:hover{color:rgba(255,255,255,0.6)}

/* ── ANIMATIONS ── */
@keyframes up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-left>*{animation:up 0.6s ease both}
.hero-kicker{animation-delay:.05s}.hero h1{animation-delay:.15s}
.hero-sub{animation-delay:.25s}.hero-btns{animation-delay:.35s}.hero-trust{animation-delay:.45s}
.hero-right{animation:up 0.7s 0.2s ease both}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.team-grid{grid-template-columns:1fr 1fr}.ft-top{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:900px){
  .nav-menu{display:none}
  .hero{grid-template-columns:1fr}.hero-right{padding-top:0}
  .about-grid,.ct-wrap{grid-template-columns:1fr;gap:3rem}
  #leistungen .svc-grid{grid-template-columns:1fr 1fr}
  .how-grid{grid-template-columns:1fr 1fr}
  .p-grid,.testi-grid{grid-template-columns:1fr}
  .pc-f{transform:none}
  .tes.tes-big{grid-column:span 1}
  .proj-item{grid-template-columns:1fr}
  .proj-mid{display:none}
  .proj-side:last-of-type{display:none}
  .proj-info{grid-column:span 1}
  .sec{padding:clamp(44px,6vw,72px) max(20px,4vw)}
  .option-grid{grid-template-columns:1fr 1fr}
  .pkg-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  #leistungen .svc-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .f-row,.frow{grid-template-columns:1fr}
  .option-grid{grid-template-columns:1fr}
  .pkg-grid{grid-template-columns:1fr}
  .pg-nav{display:none}
}
