:root{
  --accent:#0b6e99;
  --accent-2:#0b99a6;
  --muted:#666;
  --bg:#fafafa;
  --max-width:1100px;
  --container-padding:20px;
  --footer-bg: #0b3b4c;
  --footer-text: #e6f7fb;
  --footer-muted: rgba(230,247,251,0.85);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:#111;line-height:1.5}
.container{max-width:var(--max-width);margin:0 auto;padding:var(--container-padding)}

.hero{position:relative;height:60vh;min-height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform-origin:center;transition:transform 0.6s ease-out;will-change:transform;filter:saturate(0.95) brightness(0.82);z-index:0}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.5) 40%, rgba(0,0,0,0.65) 100%);pointer-events:none}
.hero-overlay{position:relative;z-index:2;width:100%}
.hero-title{color:#fff;font-size:2.4rem;margin:0 0 0.5rem 0;opacity:0;transform:translateY(10px);transition:opacity 0.7s ease,transform 0.7s ease;text-shadow:0 8px 28px rgba(0,0,0,0.65);font-weight:700}
.hero--loaded .hero-title{opacity:1;transform:translateY(0)}

.tagline{color:rgba(255,255,255,0.95);margin-bottom:1rem}

.btn{display:inline-block;margin-top:1rem;padding:0.6rem 1rem;background:var(--accent);color:#fff;border-radius:6px;text-decoration:none;font-weight:600}
.btn:hover{background:var(--accent-2)}
.btn.cta{display:inline-block;background:linear-gradient(180deg,#0b6e99,#095f86);color:#fff;padding:0.7rem 1.2rem;border-radius:8px;box-shadow:0 6px 18px rgba(11,110,153,0.18);transition:transform 160ms ease,box-shadow 160ms ease}
.btn.cta:active{transform:translateY(1px)}
.btn.cta.cta--hover{transform:translateY(-2px) scale(1.015);box-shadow:0 8px 22px rgba(11,110,153,0.20)}

@keyframes ctaPulse{
  0%{box-shadow:0 6px 14px rgba(11,110,153,0.08)}
  50%{box-shadow:0 8px 18px rgba(11,110,153,0.10)}
  100%{box-shadow:0 6px 14px rgba(11,110,153,0.08)}
}
.btn.cta{animation:ctaPulse 10s ease-in-out infinite}

main{padding:32px 0}
section{margin-bottom:28px;background:#fff;padding:18px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
section h2{margin-top:0}

.services ul, .advantages ul{list-style:disc;margin:8px 0 0 20px}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.services-grid{align-items:stretch;grid-auto-rows:1fr}

.service-item--wide{grid-column:1 / -1;
  height:auto;
  padding:20px;
  margin-top:12px;
  background:linear-gradient(180deg,#ffffff,#fcfdfe);
  box-shadow:0 10px 30px rgba(11,110,153,0.06);
}

.service-item{background:linear-gradient(180deg,#ffffff,#fbfdff);padding:14px;border-radius:10px;box-shadow:0 6px 18px rgba(11,110,153,0.06);border:1px solid rgba(6,70,86,0.04);transition:transform .16s ease,box-shadow .16s ease;display:flex;flex-direction:column;height:100%}
.service-item{justify-content:space-between}
.service-item:hover{transform:translateY(-6px);box-shadow:0 16px 34px rgba(11,110,153,0.09)}
.service-item:focus{outline:none}
.service-item:focus-visible{box-shadow:0 0 0 4px rgba(11,110,153,0.10), 0 16px 34px rgba(11,110,153,0.09);transform:translateY(-4px)}

.service-item.service-item--wide{
  height: auto !important;
  padding: 20px;
  margin-top: 12px;
  background: linear-gradient(180deg,#ffffff,#fcfdfe);
  box-shadow: 0 10px 30px rgba(11,110,153,0.06);
}

.service-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.service-icon{flex:0 0 40px;color:var(--accent);background:rgba(11,110,153,0.06);padding:6px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center}
.service-title{margin:0 0 0 0;font-size:1.08rem;color:var(--accent);font-weight:700}
.service-desc{margin:8px 0 12px 0;color:#2b3b42;font-size:0.96rem;line-height:1.45}

.service-list{margin:0;padding-left:18px;color:#222;font-size:0.95rem}
.service-list li{margin-bottom:6px}

.service-figure{margin-top:auto;border-radius:10px;overflow:hidden;background:#fff;border:1px solid rgba(0,0,0,0.04);box-shadow:0 6px 16px rgba(11,110,153,0.04);position:relative;display:flex;flex-direction:column}
.service-figure picture{display:block;flex:1 1 auto;min-height:0}
.service-figure img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transform:translateY(6px);transition:opacity .45s ease,transform .45s ease}
.service-figure img.img-loaded{opacity:1;transform:translateY(0)}
.service-figure figcaption{display:none}

.service-figure{height:220px}
@media (max-width:1000px){
  .service-figure{height:180px}
}
@media (max-width:640px){
  .service-figure{height:160px}
}

@media (min-width:1000px){
}

@media (max-width:1000px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .services-grid{grid-template-columns:1fr}
  .service-item{padding:12px}
}

.contact-grid{display:grid;grid-template-columns:360px 1fr;gap:28px;align-items:start}
.contact-info{padding-right:20px;border-right:1px solid rgba(0,0,0,0.06)}
.contact-panel{padding-left:20px}
.contact-item{padding:8px 0;border-bottom:1px solid #f4f7f9}
.contact-item:last-child{border-bottom:none}
.contact-label{color:#233;letter-spacing:0.2px}
.contact-number{color:#073b4c}
.contact-number:hover{ text-decoration:underline }
.contact-item--no-bg{background:transparent}
.contact-number{transition:transform 150ms ease,box-shadow 150ms ease}
.contact-number:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(7,59,76,0.08)}

@media (max-width:800px){
  .contact-grid{grid-template-columns:1fr;}
  .contact-info{border-right:none;border-bottom:1px solid rgba(0,0,0,0.06);padding-bottom:18px;margin-bottom:18px}
  .contact-panel{padding-left:0}
}

footer{padding:18px 0;margin-top:18px;background:var(--footer-bg);color:var(--footer-text)}
.footer-inner{display:flex;flex-direction:column;gap:8px;color:var(--footer-muted);font-size:0.9rem;align-items:stretch}
.footer-inner p{margin:0}
.footer-top{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%}
.footer-copy{color:var(--footer-text);font-weight:600}
.footer-ids{color:var(--footer-muted);font-size:0.95rem;margin:0}
.footer-bottom{display:flex;width:100%;justify-content:center;margin-top:10px}
.footer-inner a{color:var(--footer-text);text-decoration:none;opacity:0.95}
.footer-inner a:hover{text-decoration:underline;opacity:1}
.footer-privacy .footer-link{display:inline;color:var(--footer-muted);font-weight:400;padding:0;border:0;background:transparent;text-decoration:none;transition:color .12s ease,opacity .12s ease}
.footer-privacy .footer-link:hover{color:var(--footer-text);text-decoration:underline;opacity:1}

@media (max-width:420px){
  .hero{min-height:280px}
  .container{padding:12px}
  .footer-top{flex-direction:column;align-items:flex-start;gap:6px}
  .footer-bottom{justify-content:flex-start}
  .footer-inner{flex-direction:column}
}

.contact-list{
  list-style:none;
  margin:12px 0 0 0;
  padding:6px 0 0 0;
  display:flex;
  flex-direction:column;
  gap:0;
}
.contact-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 0;
  border-radius:0;
  background: transparent;
  color: #111;
  transition: none;
  cursor: default;
  border-bottom: 1px solid #f1f5f8;
}
.contact-item:last-child{border-bottom: none}

.contact-meta{display:flex;flex-direction:column;align-items:flex-start}
.contact-label{font-size:0.95rem;color:#333;font-weight:600}
.contact-number{font-size:1rem;color:#044a5e;font-weight:700;text-decoration:none;margin-top:4px;text-align:left}

.contact-icon{display:none !important}

@media (max-width:800px){
  .contact-list{gap:8px}
  .contact-item{padding:10px 0}
}

.contact-item--no-bg:focus-within{
  transform: none !important;
  box-shadow: none !important;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form textarea {
  width:100%;
  padding:12px 14px;
  border:1px solid rgba(0,0,0,0.12);
  border-radius:8px;
  background:#fff;
  transition:box-shadow .15s ease, border-color .15s ease, transform .08s ease;
  font-size:0.95rem;
  color: #111;
}
.contact-form textarea{min-height:120px;resize:vertical}
.contact-form input:focus, .contact-form textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 8px 20px rgba(11,110,153,0.08);
  transform:translateY(-1px);
}

.btn, .btn-outline, .contact-form button, .contact-panel .btn-outline {
  display:inline-block;
  padding:0.7rem 1.2rem;
  border-radius:8px;
  background:linear-gradient(180deg,#0b6e99,#095f86);
  color:#fff;
  border:0;
  text-decoration:none;
  font-weight:700;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(11,110,153,0.18);
  transition:transform 160ms ease, box-shadow 160ms ease, opacity 120ms ease;
}
.btn:hover, .btn-outline:hover, .contact-form button:hover{transform:translateY(-2px) scale(1.015);box-shadow:0 8px 22px rgba(11,110,153,0.20)}
.btn:active, .contact-form button:active{transform:translateY(1px)}
.btn:focus, .btn-outline:focus, .contact-form button:focus{outline:none;box-shadow:0 0 0 4px rgba(11,110,153,0.08)}

.btn-outline{display:inline-flex;align-items:center;justify-content:center}

.contact-hours .btn-outline{margin-top:8px}

.btn.cta{animation:ctaPulse 10s ease-in-out infinite}

.cookie-banner{
  position:fixed;
  left:16px;
  right:16px;
  bottom:18px;
  background:linear-gradient(180deg, rgba(11,110,153,0.95), rgba(10,95,135,0.95));
  color:#fff;
  padding:14px 16px;
  border-radius:10px;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  z-index:9999;
  box-shadow:0 12px 30px rgba(3,23,28,0.35);
}
.cookie-banner p{margin:0;font-size:0.95rem;line-height:1.3}
.cookie-actions{display:flex;gap:8px;align-items:center}
.cookie-accept{background:#fff;color:var(--accent);padding:8px 12px;border-radius:8px;font-weight:700}
.cookie-manage{background:transparent;border:1px solid rgba(255,255,255,0.18);color:#fff;padding:8px 12px;border-radius:8px}
@media (max-width:720px){
  .cookie-banner{flex-direction:column;align-items:flex-start;padding:12px}
  .cookie-actions{width:100%;justify-content:flex-end}
}

.recruit-banner{background:#ffb000;color:#082032;padding:14px 8px;font-weight:700;box-shadow:0 2px 6px rgba(0,0,0,.12);}
.recruit-banner__inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;min-height:56px;padding:6px 12px;will-change:transform,opacity;animation:recruitFadeSlide 700ms cubic-bezier(.2,.8,.2,1) both}
.recruit-banner__lead{display:flex;align-items:center;gap:10px;flex:1;min-width:220px}
.recruit-banner__lead svg{flex:0 0 auto}
.recruit-banner__lead span{font-size:1.05rem;line-height:1.1;display:inline-flex;align-items:center}
.recruit-banner__actions{display:flex;gap:10px;align-items:center;flex-shrink:0;align-self:center}
.recruit-banner__actions .btn, .recruit-banner__actions .btn-outline{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:6px;line-height:1;margin-top:0}
.recruit-banner__actions .btn{background:#082032;color:#fff}
.recruit-banner__actions .btn-outline{background:transparent;border:2px solid #082032;color:#082032}

@keyframes recruitFadeSlide{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}

@media (prefers-reduced-motion: reduce){
  .recruit-banner__inner,.recruit-banner__actions .btn,.recruit-banner__actions .btn-outline{animation:none !important;transition:none !important}
}

@media (max-width:640px){
  .recruit-banner__inner{justify-content:center;padding:10px 12px}
  .recruit-banner__lead{justify-content:center;text-align:center}
  .recruit-banner__actions{flex-direction:column;gap:8px;width:100%;align-items:stretch}
  .recruit-banner__actions .btn, .recruit-banner__actions .btn-outline{width:100%;padding:10px 12px}
}

.recruit-banner__actions .btn:focus, .recruit-banner__actions .btn-outline:focus{outline:none;box-shadow:0 0 0 4px rgba(8,32,50,0.12)}
