/* euro-desk.at v9 - 20250503 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:       #0c2461;
  --navy-dark:  #091840;
  --navy-mid:   #1a3a7a;
  --gold:       #d97706;
  --gold-dark:  #b45309;
  --blue-light: #dbeafe;
  --blue-pale:  #eff6ff;
  --white:      #ffffff;
  --gray-50:    #f8fafc;
  --gray-100:   #f1f5f9;
  --gray-200:   #e2e8f0;
  --gray-400:   #94a3b8;
  --gray-600:   #475569;
  --gray-700:   #334155;
  --gray-800:   #1e293b;
  --text:       #1e293b;
  --radius:     14px;
  --sh:         0 1px 12px rgba(12,36,97,.07);
  --sh-md:      0 4px 24px rgba(12,36,97,.12);
  --sh-lg:      0 8px 40px rgba(12,36,97,.18);
  --t:          .22s ease;
}

html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--text);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4{line-height:1.12;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,5vw,3.4rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:1rem;font-weight:700}
p{line-height:1.65}

.container{max-width:1680px;margin:0 auto;padding:0 48px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:0 1px 8px rgba(12,36,97,.06);transition:box-shadow var(--t)}
.site-header.scrolled{box-shadow:0 4px 20px rgba(12,36,97,.13)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.site-logo img{height:48px;width:auto}
.site-nav{display:flex;align-items:center;gap:4px}
.site-nav a{font-size:.94rem;font-weight:500;color:var(--gray-700);padding:8px 18px;border-radius:8px;transition:background var(--t),opacity var(--t)}
.site-nav a:hover{color:var(--navy);background:var(--blue-pale);opacity:.9}
.site-nav a.nav-cta{background:var(--navy);color:#fff;padding:10px 24px;font-weight:600;border-radius:9px}
.site-nav a.nav-cta:hover{background:var(--navy-mid);box-shadow:0 4px 16px rgba(12,36,97,.3)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:var(--t)}

/* ── HERO ── */
.hero{border-bottom:1px solid var(--blue-light);background:#fff;overflow:hidden}
.hero-inner{display:flex;align-items:flex-start;height:460px;position:relative;overflow:hidden}
.hero-content{padding:32px 0 0 24px;width:50%;min-width:360px;position:relative;z-index:2}
.hero-bg-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  z-index:1;
}

.hero-content h1{color:var(--navy);font-size:clamp(1.9rem,3.5vw,2.6rem);font-weight:900;letter-spacing:-.03em;margin-bottom:14px;line-height:1.1}
.hero-subtitle{font-size:1.05rem;color:var(--gray-800);margin-bottom:14px;max-width:480px;line-height:1.6;font-weight:500}
.hero-badges{display:flex;flex-wrap:nowrap;gap:10px;padding-left:5px}
.hero-badge{display:flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600;color:var(--navy)}
.hero-badge svg{width:22px;height:22px;color:var(--gold);flex-shrink:0}
.hero-visual{display:none}
.hero-visual picture{display:block;height:460px}
.hero-img{width:100%;height:460px;object-fit:cover;object-position:left center;display:block}

/* ── WHY + SERVICES ── */
.why-services-section{padding:32px 0 32px;background:var(--gray-50)}

.combined-row{display:flex;flex-direction:row;gap:16px;align-items:stretch}

/* LEFT: heading + 2 stacked why-cards */
.why-block{flex:0 0 510px;display:flex;flex-direction:column;gap:10px}
.why-heading-text{
  color:var(--navy);
  font-size:1.65rem;
  font-weight:900;
  line-height:1.15;
  letter-spacing:-.02em;
  margin-bottom:6px;
}
.why-cards-grid{display:flex;flex-direction:column;gap:10px;flex:1}
.why-card{
  background:#fff;
  border:1.5px solid var(--gray-200);
  border-radius:var(--radius);
  padding:16px 14px;
  display:flex;gap:12px;align-items:flex-start;
  box-shadow:var(--sh);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  flex:1;
}
.why-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--blue-light)}
.why-icon-inline{width:40px;height:40px;min-width:40px;background:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px}
.why-icon-inline img{width:22px;height:22px}
.why-card h3{color:var(--navy);font-size:.9rem;font-weight:700;margin-bottom:6px;line-height:1.3}
.why-card p{color:var(--gray-600);font-size:.82rem;line-height:1.55}

/* RIGHT: 3 service cards */
.services-block{flex:1;display:flex;flex-direction:row;gap:14px;align-items:stretch;max-width:calc(100% - 510px - 16px)}
.service-card{
  flex:1;
  background:#fff;
  border:1.5px solid var(--gray-200);
  border-radius:var(--radius);
  padding:20px 10px;
  text-align:center;
  display:flex;flex-direction:column;
  box-shadow:var(--sh);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--blue-light)}
.service-icon-wrap{width:58px;height:58px;margin:0 auto 12px}
.service-icon-wrap img{width:100%;height:100%}
.service-card h3{color:var(--navy);font-size:1rem;font-weight:800;margin-bottom:12px;letter-spacing:-.01em}
.service-features{display:flex;flex-direction:column;gap:8px;text-align:left}
.service-features li{display:flex;align-items:flex-start;gap:8px;font-size:.84rem;color:var(--gray-700);line-height:1.4;font-weight:500}
.service-features li::before{
  content:'';width:17px;height:17px;min-width:17px;margin-top:1px;
  background:var(--blue-light);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='9' viewBox='0 0 24 24' fill='none' stroke='%230c2461' stroke-width='3.5' stroke-linecap='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* ── PROCESS + ABOUT ── */
.process-about-section{padding:32px 0 32px;background:#fff}
.process-about-inner{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;align-items:stretch}

.process-col{display:flex;flex-direction:column}
.process-title{
  color:var(--navy);
  font-size:1.65rem;
  font-weight:900;
  text-align:center;
  margin-bottom:32px;
  line-height:1.15;
  letter-spacing:-.02em;
}
.process-steps{display:flex;align-items:center;gap:0}
.process-step{flex:1;display:flex;flex-direction:row;align-items:center;gap:14px;text-align:left}
.step-icon-wrap{
  width:74px;height:74px;min-width:74px;
  border-radius:50%;
  background:var(--blue-light);
  display:flex;align-items:center;justify-content:center;
  position:relative;flex-shrink:0;
  box-shadow:0 2px 12px rgba(12,36,97,.12);
}
.step-icon-wrap img{width:40px;height:40px}
.step-number{
  position:absolute;top:-3px;right:-3px;
  background:var(--navy);color:#fff;
  width:26px;height:26px;border-radius:50%;
  font-size:.78rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 6px rgba(12,36,97,.3);
}
.step-body{padding-top:0}
.step-title{color:var(--navy);font-size:1.05rem;font-weight:800;margin-bottom:7px;letter-spacing:-.01em}
.step-text{color:var(--gray-600);font-size:.85rem;line-height:1.55}
.step-arrow{color:var(--gray-400);display:flex;align-items:center;flex-shrink:0;padding:0 6px;align-self:center}
.step-arrow svg{width:28px;height:28px}

/* About box */
.about-col{display:flex}
.about-box{
  position:relative;overflow:hidden;
  border-radius:var(--radius);
  background:linear-gradient(135deg,#dceeff 0%,#e8f3ff 100%);
  border:1.5px solid #b3d4f5;
  width:100%;min-height:220px;
}
.about-bg-img{
  position:absolute;bottom:0;right:0;
  width:100%;height:100%;
  object-fit:cover;object-position:right bottom;
  opacity:0.5;pointer-events:none;
}
.about-content{position:relative;z-index:2;padding:28px 28px;max-width:72%}
.about-content h2{color:var(--navy);font-size:1.5rem;font-weight:900;margin-bottom:12px;letter-spacing:-.02em}
.about-location{display:flex;align-items:center;gap:7px;color:var(--gray-700);font-size:.9rem;margin-bottom:14px;font-weight:500}
.about-location svg{color:var(--gold);flex-shrink:0}
.about-content>p{color:var(--gray-700);font-size:.93rem;line-height:1.7;font-weight:400}
.about-content strong{color:var(--navy);font-weight:700}

/* ── CTA STRIP – gold background ── */
.cta-strip{
  padding:28px 0;
  background:#ffffff;
  border-top:1.5px solid var(--gray-200);
  border-bottom:1.5px solid var(--gray-200);
}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.cta-strip-left{display:flex;align-items:center;gap:22px;flex:1}
.cta-strip-icon{
  width:62px;height:62px;flex-shrink:0;
  background:var(--blue-light);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);
}
.cta-strip-title{color:var(--navy);font-size:1.3rem;font-weight:900;margin-bottom:4px;letter-spacing:-.02em}
.cta-strip-sub{color:var(--gray-600);font-size:.95rem}
.cta-strip-btn{
  white-space:nowrap;flex-shrink:0;
  background:var(--gold) !important;
  color:#fff !important;
  box-shadow:0 4px 16px rgba(217,119,6,.3) !important;
  font-size:1rem !important;
  padding:16px 30px !important;
  will-change:transform;
}
.cta-strip-btn:hover{
  background:var(--gold-dark) !important;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(217,119,6,.42) !important;
}

/* ── BUTTONS ── */
.btn-cta,.btn.btn-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--gold);color:#fff;
  font-weight:700;font-size:.95rem;
  padding:14px 26px;border-radius:10px;border:none;cursor:pointer;
  text-decoration:none;
  transition:background var(--t),transform var(--t),box-shadow var(--t);
  box-shadow:0 4px 16px rgba(217,119,6,.32);
}
.btn-cta:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(217,119,6,.45);color:#fff}
.btn-cta svg{width:20px;height:20px}

/* ── FOOTER ── */
.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.78);padding:48px 0 28px}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:36px}
.footer-brand img{height:52px;width:auto;margin-bottom:16px}
.footer-brand p{font-size:.86rem;color:rgba(255,255,255,.52);line-height:1.7;margin-top:6px}
.footer-col h4{
  color:#fff;font-size:.78rem;font-weight:700;
  margin-bottom:18px;text-transform:uppercase;letter-spacing:.1em;
  padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:.87rem;color:rgba(255,255,255,.72);margin-bottom:14px;line-height:1.5}
.footer-contact-item svg{flex-shrink:0;margin-top:2px;color:var(--gold)}
.footer-contact-item a{color:rgba(255,255,255,.85);transition:color var(--t)}
.footer-contact-item a:hover{color:#fff}
.footer-contact-item address{font-style:normal}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.87rem;color:rgba(255,255,255,.65);transition:opacity var(--t);display:flex;align-items:center;gap:6px}
.footer-links a::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold);opacity:.7;flex-shrink:0}
.footer-links a:hover{color:#fff;opacity:1}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:22px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.4)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:.8rem;color:rgba(255,255,255,.52);transition:color var(--t)}
.footer-legal a:hover{color:#fff}

/* ── LEGAL ── */
.legal-page{padding:60px 0 80px}
.legal-back{display:inline-flex;align-items:center;gap:7px;color:var(--navy);font-size:.9rem;font-weight:600;margin-bottom:28px;transition:gap var(--t)}
.legal-back:hover{gap:12px}
.legal-back svg{width:16px;height:16px}
.legal-body{max-width:760px}
.legal-body h1{color:var(--navy);margin-bottom:32px;font-size:2.2rem}
.legal-body h2{color:var(--navy);font-size:1.2rem;margin-top:36px;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--blue-light)}
.legal-body h3{color:var(--navy-mid);font-size:1rem;margin-top:22px;margin-bottom:10px}
.legal-body p{color:var(--gray-700);margin-bottom:14px;font-size:.95rem;line-height:1.75}
.legal-body ul,.legal-body ol{margin:0 0 16px 22px;display:flex;flex-direction:column;gap:6px}
.legal-body li{color:var(--gray-700);font-size:.95rem;line-height:1.6}
.legal-body ul li{list-style:disc}
.legal-body ol li{list-style:decimal}
.legal-body a{color:var(--navy);text-decoration:underline}
.legal-body hr{border:none;border-top:1px solid var(--gray-200);margin:28px 0}
.legal-body strong{color:var(--gray-800)}

/* ── CONTACT ── */
.contact-page{padding:0 0 72px;background:var(--gray-50)}
.contact-container{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start;padding-top:52px}
.contact-info h1{color:var(--navy);margin-bottom:14px}
.contact-intro{color:var(--gray-600);font-size:1rem;margin-bottom:32px;line-height:1.7}
.contact-details{display:flex;flex-direction:column;gap:16px}
.contact-details li{display:flex;align-items:flex-start;gap:14px;color:var(--gray-700);font-size:.94rem}
.contact-details svg{flex-shrink:0;margin-top:2px}
.contact-details address{font-style:normal;line-height:1.6}
.contact-details a{color:var(--navy)}
.contact-form-wrap{
  background:#fff;border:1.5px solid var(--gray-200);
  border-radius:var(--radius);padding:40px;
  box-shadow:var(--sh-md);
}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:.86rem;font-weight:600;color:var(--gray-700);margin-bottom:7px}
.form-group input,.form-group textarea{
  width:100%;padding:12px 15px;
  border:1.5px solid var(--gray-200);border-radius:9px;
  font-family:inherit;font-size:.95rem;color:var(--gray-800);background:#fff;
  transition:border-color var(--t),box-shadow var(--t);outline:none;
}
.form-group input:focus,.form-group textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(12,36,97,.09)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-checkbox{display:flex;align-items:flex-start;gap:10px;margin-bottom:22px}
.form-checkbox input[type="checkbox"]{width:18px;height:18px;min-width:18px;margin-top:1px;accent-color:var(--navy);cursor:pointer}
.form-checkbox label{font-size:.85rem;color:var(--gray-600);font-weight:400;line-height:1.5;cursor:pointer}
.form-checkbox a{color:var(--navy);text-decoration:underline}
.form-submit{width:100%;justify-content:center;font-size:1rem;padding:15px !important}
.form-note{font-size:.78rem;color:var(--gray-500);margin-top:10px;text-align:center}
.form-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;border-radius:8px;font-size:.9rem;margin-bottom:16px}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .combined-row{flex-wrap:wrap}
  .why-block{flex:0 0 100%}
  .why-cards-grid{flex-direction:row}
  .services-block{flex:0 0 100%}
  .process-about-inner{grid-template-columns:1fr}
  .about-content{max-width:100%}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;padding:48px 0 0}
  .hero-visual{position:relative;width:100%;height:320px;justify-content:center}
  .hero-content{padding-bottom:32px}
  .hero-img{object-position:center center}
}
@media(max-width:768px){
  .menu-toggle{display:flex}
  .site-nav{display:none}
  .site-header.nav-open .site-nav{
    display:flex;flex-direction:column;
    position:absolute;top:72px;left:0;right:0;
    background:#fff;border-top:1px solid var(--gray-200);
    padding:16px 24px 20px;gap:4px;
    box-shadow:0 8px 24px rgba(12,36,97,.1);
  }
  .site-header.nav-open .site-nav a{width:100%;padding:10px 14px}
  /* Hero: subtitle and badges white on mobile */
  .hero-subtitle{color:#fff}
  .hero-badge{color:#fff}
  .hero-badge svg{color:rgba(255,255,255,.8)}

  .combined-row{flex-direction:column;gap:20px}

  /* Why block: heading full width, cards side by side */
  .why-block{flex:none;width:100%}
  .why-heading-text{font-size:1.3rem;margin-bottom:12px}
  .why-cards-grid{flex-direction:row;gap:12px}
  .why-card{flex:1;padding:14px 12px;gap:10px}
  .why-card h3{font-size:.88rem}
  .why-card p{font-size:.78rem}
  .why-icon-inline{width:36px;height:36px;min-width:36px}
  .why-icon-inline img{width:20px;height:20px}

  .services-block{flex:none;width:100%}
  .process-steps{flex-direction:column;align-items:flex-start;gap:20px}
  .step-arrow{display:none}
  .cta-strip-inner{flex-direction:column;text-align:center}
  .cta-strip-left{flex-direction:column;text-align:center;gap:14px}
  .cta-strip-icon{display:none}
  .contact-container{grid-template-columns:1fr;gap:36px}
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .container{padding:0 18px}
  .contact-form-wrap{padding:24px 18px}
  .service-card{flex:1 1 100%}
  .why-cards-grid{flex-direction:column}
}



/* ── ANCHOR SCROLL OFFSET (sticky header fix) ── */
#warum,#leistungen,#prozess,#ueber-uns,#kontakt{
  scroll-margin-top:88px;
}

/* ── SERVICE CARD: "Mehr erfahren" Button ── */
.service-card-footer{
  margin-top:auto;
  padding-top:16px;
  border-top:1px solid var(--gray-200);
}
.btn-service-more{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--navy);font-weight:600;font-size:.88rem;
  text-decoration:none;
  transition:gap var(--t),color var(--t);
}
.btn-service-more svg{width:15px;height:15px;transition:transform var(--t)}
.btn-service-more:hover{color:var(--gold)}
.btn-service-more:hover svg{transform:translateX(4px)}
