/* ============================================================
   MFB — design tokens (Material Design + arculati kézikönyv)
   ============================================================ */








/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-ext-italic.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-italic.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}








/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}








/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}








/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}








/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/open-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


:root{
  /* Elsődleges márkaszínek */
  --mfb-kek:#004564;
  --mfb-turkiz:#00BCB5;          /* az EGYETLEN zöld a designban */
  --mfb-turkiz-melyebb:#00BCB5;  /* zárolva ugyanarra a zöldre */
  --mfb-szurke:#A3A4A6;
  --mfb-kek-tonus:#1F6972;
  --mfb-kek-melyebb:#003049;
  --szoveg:#262626;
  --szoveg-halvany:#5b6b73;
  --homok:#EAE5C3;
  --feher:#FFFFFF;

  /* derivált felületek */
  --bg:#f4f7f8;
  --vonal:#e2e9ec;
  --vonal-eros:#cdd8dd;

  /* kategória / chip színek (csak címkékhez) */
  --kat-sajto:#0A90AD;
  --kat-tarsadalmi:#06AB71;
  --kat-program:#477FB9;
  --kat-csoport:#6A899F;

  /* Tipográfia */
  --font:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  /* Material elevation – lágy, alacsony-blur árnyékok */
  --e1:0 1px 2px rgba(0,69,100,.08), 0 1px 3px rgba(0,69,100,.05);
  --e2:0 2px 8px rgba(0,69,100,.08), 0 1px 3px rgba(0,69,100,.06);
  --e4:0 10px 28px rgba(0,69,100,.13), 0 3px 8px rgba(0,69,100,.07);
  --e8:0 20px 48px rgba(0,69,100,.20), 0 6px 16px rgba(0,69,100,.10);

  /* Sarkok */
  --r-card:8px;
  --r-btn:4px;

  /* Spacing skála (8px alapegység) */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px;

  --max:1280px;
  --gutter:24px;

  /* mozgás */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(0,0,.2,1);

  /* tweakelhető betűskála */
  --type-scale:1;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font);
  font-weight:400;
  color:var(--szoveg);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

.wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gutter);}

/* ---- tipográfia osztályok ---- */
.eyebrow{
  font-size:calc(13px * var(--type-scale));
  font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mfb-turkiz-melyebb);
}
.section-title{
  font-size:calc(34px * var(--type-scale));
  font-weight:800;letter-spacing:-.015em;line-height:1.1;color:var(--mfb-kek);
  margin:0;
}
.section-title.center{text-align:center;}
.title-rule{width:56px;height:4px;background:var(--mfb-turkiz);border-radius:2px;margin-top:var(--s2);}
.title-rule.center{margin-inline:auto;}

.section{padding-block:var(--s7);}
@media(max-width:760px){ .section{padding-block:var(--s6);} }

/* ---- gombok ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;white-space:nowrap;
  font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  font-size:calc(15px * var(--type-scale));
  padding:14px 26px;border-radius:var(--r-btn);
  position:relative;overflow:hidden;isolation:isolate;
  transition:box-shadow .25s var(--ease), transform .2s var(--ease), background .2s var(--ease);
}
.btn .arw{transition:transform .25s var(--ease);}
.btn:hover .arw{transform:translateX(4px);}
.btn-primary{background:var(--mfb-turkiz);color:#fff;box-shadow:var(--e2);}
.btn-primary:hover{box-shadow:var(--e8);transform:translateY(-1px);}
.btn-secondary{background:transparent;color:var(--mfb-kek);box-shadow:inset 0 0 0 2px var(--mfb-kek);}
.btn-secondary:hover{background:var(--mfb-kek);color:#fff;}
.btn-on-dark{background:var(--mfb-turkiz);color:#fff;box-shadow:var(--e2);}
.btn-on-dark:hover{box-shadow:var(--e8);transform:translateY(-1px);}
.btn-ghost-dark{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.55);}
.btn-ghost-dark:hover{box-shadow:inset 0 0 0 2px #fff;background:rgba(255,255,255,.08);}

/* material ripple */
.ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.4);
  animation:ripple .6s var(--ease-out);pointer-events:none;z-index:-1;}
.btn-ghost-dark .ripple,.btn-secondary:hover .ripple{background:rgba(255,255,255,.35);}
@keyframes ripple{to{transform:scale(2.6);opacity:0;}}

/* text link türkiz */
.tlink{
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  color:var(--mfb-turkiz-melyebb);font-weight:800;
  font-size:calc(14px * var(--type-scale));letter-spacing:.02em;
}
.tlink .arw{transition:transform .25s var(--ease);}
.tlink:hover{color:var(--mfb-kek);}
.tlink:hover .arw{transform:translateX(4px);}

/* ---- belépő animáció (staggered fade-up) ---- */
.reveal{opacity:0;transform:translateY(22px);}
.reveal.in{opacity:1;transform:none;transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;}
}


/* ============================================================
   MFB — komponensek
   ============================================================ */

/* ---------- Utility bar ---------- */
.utilbar{background:var(--mfb-kek-melyebb);color:rgba(255,255,255,.82);
  font-size:13px;letter-spacing:.01em;}
.utilbar .wrap{display:flex;align-items:center;gap:var(--s3);height:40px;}
.utilbar .date{font-weight:600;color:rgba(255,255,255,.9);}
.utilbar .spacer{flex:1;}
.utilbar .langs{display:flex;align-items:center;gap:2px;padding-left:var(--s2);
  border-left:1px solid rgba(255,255,255,.18);}
.utilbar .langs button{
  color:rgba(255,255,255,.7);font-weight:700;font-size:12px;letter-spacing:.06em;
  padding:5px 8px;border-radius:3px;transition:.2s var(--ease);
}
.utilbar .langs button.active,.utilbar .langs button:hover{color:#fff;background:rgba(255,255,255,.12);}
.utilbar .ulinks{display:flex;gap:var(--s2);}
.utilbar .ulinks a{font-weight:700;letter-spacing:.04em;font-size:12px;transition:.2s;color:rgba(255,255,255,.78);}
.utilbar .ulinks a:hover{color:var(--mfb-turkiz);}
.utilbar .social{display:flex;gap:10px;align-items:center;padding-left:var(--s2);
  border-left:1px solid rgba(255,255,255,.18);}
.utilbar .social a{color:rgba(255,255,255,.7);transition:.2s;display:grid;place-items:center;width:22px;height:22px;}
.utilbar .social a svg{display:block;}
.utilbar .social a:hover{color:var(--mfb-turkiz);transform:translateY(-1px);}
@media(max-width:900px){ .utilbar .ulinks,.utilbar .social{display:none;} }

/* ---------- Főnav ---------- */
.nav{position:sticky;top:0;z-index:100;background:#fff;box-shadow:var(--e1);
  transition:box-shadow .3s var(--ease);}
.nav.scrolled{box-shadow:var(--e4);}
.nav .wrap{display:flex;align-items:center;gap:var(--s4);height:84px;}
.nav .logo{display:block;padding:8px 0;flex-shrink:0;}
.nav .logo img{height:40px;width:auto;}   /* teljes logó, eredeti színek + biztonsági zóna a paddinggal */
.nav .menu{display:flex;align-items:center;gap:2px;margin-left:auto;}
.nav .menu a{
  position:relative;font-weight:700;font-size:calc(15px * var(--type-scale));
  color:var(--mfb-kek);padding:10px 16px;letter-spacing:.005em;border-radius:4px;
  transition:color .2s var(--ease);
}
.nav .menu a::after{
  content:"";position:absolute;left:16px;right:16px;bottom:6px;height:2px;border-radius:2px;
  background:var(--mfb-turkiz);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav .menu a:hover,.nav .menu a.active{color:var(--mfb-turkiz-melyebb);}
.nav .menu a:hover::after,.nav .menu a.active::after{transform:scaleX(1);}
.nav .search{margin-left:var(--s1);width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  color:var(--mfb-kek);transition:.2s var(--ease);flex-shrink:0;}
.nav .search:hover{background:var(--bg);color:var(--mfb-turkiz-melyebb);}
.nav .burger{display:none;margin-left:var(--s1);width:44px;height:44px;border-radius:8px;
  color:var(--mfb-kek);place-items:center;flex-shrink:0;}
@media(max-width:1080px){
  .nav .menu{display:none;}
  .nav .search{margin-left:auto;}
  .nav .burger{display:grid;}
}

/* ---------- Kereső popup ---------- */
.search-overlay{position:fixed;inset:0;z-index:200;display:flex;justify-content:center;
  align-items:flex-start;padding:0 24px;
  background:rgba(0,40,58,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility 0s linear .3s;}
.search-overlay.open{opacity:1;visibility:visible;transition:opacity .3s var(--ease),visibility 0s linear 0s;}
.search-modal{width:100%;max-width:680px;margin-top:14vh;
  transform:translateY(-18px);transition:transform .35s var(--ease);}
.search-overlay.open .search-modal{transform:none;}
.search-box{display:flex;align-items:center;gap:12px;background:#fff;border-radius:12px;
  box-shadow:var(--e8);padding:6px 6px 6px 20px;}
.search-box-ico{color:var(--mfb-turkiz-melyebb);display:grid;place-items:center;flex-shrink:0;}
.search-box input{flex:1;min-width:0;border:none;outline:none;font-family:inherit;
  font-size:19px;font-weight:600;color:var(--szoveg);padding:18px 0;background:none;}
.search-box input::placeholder{color:var(--mfb-szurke);font-weight:400;}
.search-close{width:48px;height:48px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
  color:var(--mfb-kek);background:var(--bg);transition:.2s var(--ease);}
.search-close:hover{background:var(--mfb-kek);color:#fff;}
.search-suggest{margin-top:20px;}
.search-suggest-lbl{display:block;font-size:12px;font-weight:800;letter-spacing:.09em;
  text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:12px;}
.search-chips{display:flex;flex-wrap:wrap;gap:10px;}
.search-chips a{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  color:#fff;font-weight:700;font-size:14px;padding:9px 16px;border-radius:var(--r-btn);
  transition:.2s var(--ease);}
.search-chips a:hover{background:var(--mfb-turkiz);border-color:transparent;color:#fff;}
@media(max-width:560px){
  .search-modal{margin-top:84px;}
  .search-box input{font-size:16px;padding:15px 0;}
  .search-box{padding-left:16px;}
}

/* ---------- Mobil menü ---------- */
.mobile-nav{position:fixed;inset:0;z-index:150;
  background:rgba(0,40,58,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility 0s linear .3s;}
.mobile-nav.open{opacity:1;visibility:visible;transition:opacity .3s var(--ease),visibility 0s linear 0s;}
.mobile-nav-panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,360px);
  background:#fff;box-shadow:var(--e8);padding:20px 24px 32px;
  display:flex;flex-direction:column;gap:2px;overflow-y:auto;
  transform:translateX(100%);transition:transform .35s var(--ease);}
.mobile-nav.open .mobile-nav-panel{transform:none;}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;gap:16px;
  margin:0 0 14px;padding-bottom:16px;border-bottom:1px solid var(--vonal);}
.mobile-nav-logo{height:34px;width:auto;}
.mobile-nav-close{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
  color:var(--mfb-kek);background:var(--bg);transition:.2s var(--ease);}
.mobile-nav-close:hover{background:var(--mfb-kek);color:#fff;}
.mobile-nav-panel > a{font-size:16px;font-weight:700;color:var(--mfb-kek);padding:12px 0;
  border-bottom:1px solid var(--vonal);transition:color .2s var(--ease);}
.mobile-nav-panel > a:hover,.mobile-nav-panel > a.active{color:var(--mfb-turkiz-melyebb);}
.mobile-nav-sub{display:flex;flex-direction:column;gap:2px;margin-top:16px;}
.mobile-nav-sub a{font-size:14px;font-weight:600;color:var(--szoveg-halvany);padding:7px 0;}
.mobile-nav-sub a:hover{color:var(--mfb-turkiz-melyebb);}
.mobile-nav-langs{display:flex;gap:8px;margin-top:22px;}
.mobile-nav-langs button{flex:1;padding:10px 0;border-radius:var(--r-btn);font-weight:800;
  font-size:12px;letter-spacing:.05em;color:var(--mfb-kek);background:var(--bg);
  border:1px solid var(--vonal);transition:.2s var(--ease);}
.mobile-nav-langs button.active{background:var(--mfb-kek);color:#fff;border-color:transparent;}
.mobile-nav-social{display:flex;gap:10px;margin-top:24px;padding-top:20px;
  border-top:1px solid var(--vonal);}
.mobile-nav-social a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  color:var(--mfb-kek);background:var(--bg);border:1px solid var(--vonal);transition:.2s var(--ease);}
.mobile-nav-social a:hover{background:var(--mfb-kek);color:#fff;border-color:transparent;}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;background:var(--mfb-kek);}
.hero-track{display:flex;transition:transform .8s var(--ease);}
.hero-slide{min-width:100%;position:relative;overflow:hidden;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;
  -webkit-mask-image:linear-gradient(to right, transparent 34%, rgba(0,0,0,.45) 46%, #000 62%, #000 100%);
          mask-image:linear-gradient(to right, transparent 34%, rgba(0,0,0,.45) 46%, #000 62%, #000 100%);}
/* bal oldal tömör márkakék (szöveg-olvashatóság), jobb oldal átlátszóbb (fotó látszik) */
/* bal oldal tömör márkakék (szöveg-olvashatóság), jobb oldal átlátszóbb (fotó látszik) */
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,
    rgba(0,69,100,var(--hero-ov-l,.80)) 0%,
    rgba(0,69,100,var(--hero-ov-l,.80)) 28%,
    rgba(0,69,100,calc((var(--hero-ov-l,.80) + var(--hero-ov-r,.30)) / 2)) 55%,
    rgba(0,69,100,var(--hero-ov-r,.30)) 100%);}
.hero.vector .hero-media img{opacity:0;}
.hero.vector .hero-media{background:
   radial-gradient(120% 130% at 22% 50%, rgba(0,188,181,.22), transparent 55%),
   var(--mfb-kek);}
.hero.vector .hero-pattern{opacity:.5;}

/* vektoros kör-minta — a jobb oldalon, a slide jobb széléhez igazítva (minden slide-on azonos) */
.hero-pattern{position:absolute;z-index:1;top:50%;left:60%;right:auto;transform:translateY(-50%);
  width:62vw;max-width:1100px;min-width:740px;opacity:.5;pointer-events:none;}
@media(max-width:860px){ .hero-pattern{left:46%;width:92vw;min-width:0;opacity:.28;} }

.hero-inner{position:relative;z-index:2;}
.hero-inner .wrap{display:flex;align-items:center;min-height:540px;padding-block:var(--s6);}
@media(max-width:860px){ .hero-inner .wrap{min-height:auto;padding-block:var(--s5);} }
.hero-copy{max-width:640px;color:#fff;position:relative;z-index:5;text-shadow:0 1px 16px rgba(0,40,58,.35);}
.hero-chip{display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,188,181,.18);border:1px solid rgba(0,188,181,.5);
  color:#aef3ef;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  font-size:12px;padding:7px 14px;border-radius:var(--r-btn);margin-bottom:var(--s3);}
.hero-h1{font-size:calc(56px * var(--type-scale));font-weight:800;line-height:1.04;
  letter-spacing:-.025em;margin:0 0 var(--s2);}
.hero-h1 .accent{color:var(--mfb-turkiz);}
.hero-sub{font-size:calc(20px * var(--type-scale));font-weight:400;line-height:1.5;
  color:rgba(255,255,255,.9);margin:0 0 var(--s3);max-width:560px;}
.hero-prog{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700;
  color:rgba(255,255,255,.78);letter-spacing:.04em;margin-bottom:var(--s4);
  border-left:3px solid var(--mfb-turkiz);padding-left:14px;}
.hero-actions{display:flex;gap:var(--s2);flex-wrap:wrap;}
@media(max-width:560px){
  .hero-h1{font-size:calc(38px * var(--type-scale));}
  .hero-sub{font-size:calc(17px * var(--type-scale));}
}
/* hero controls */
.hero-dots{position:absolute;z-index:3;bottom:28px;left:0;right:0;
  display:flex;justify-content:center;gap:10px;}
.hero-dots button{width:34px;height:5px;border-radius:3px;background:rgba(255,255,255,.4);transition:.3s var(--ease);}
.hero-dots button.active{background:#fff;width:52px;}
.hero-arrow{position:absolute;z-index:3;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.12);color:#fff;backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.25);transition:.2s var(--ease);}
.hero-arrow:hover{background:var(--mfb-turkiz);color:var(--mfb-kek);border-color:transparent;}
.hero-arrow.prev{left:24px;} .hero-arrow.next{right:24px;}
@media(max-width:860px){ .hero-arrow{display:none;} }

/* ---------- szekció fej ---------- */
.sec-head{margin-bottom:var(--s5);}
.sec-head.center{text-align:center;}

/* ---------- Hírek (sajtó balra, többi jobbra egy oszlopban) ---------- */
.hirek-split{display:grid;grid-template-columns:1.12fr 1fr;gap:var(--s3);align-items:start;}
@media(max-width:860px){ .hirek-split{grid-template-columns:1fr;} }
.hirek-left{display:flex;flex-direction:column;gap:var(--s3);}
.hirek-right{display:flex;flex-direction:column;gap:var(--s3);}
.card{background:#fff;border-radius:var(--r-card);box-shadow:var(--e2);overflow:hidden;
  transition:box-shadow .3s var(--ease),transform .3s var(--ease);display:flex;flex-direction:column;}
.card:hover{box-shadow:var(--e4);transform:translateY(-4px);}
.card .body{padding:var(--s3);display:flex;flex-direction:column;gap:14px;flex:1;}
.chip{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  color:#fff;background:var(--kat-sajto);padding:5px 11px 5px 9px;border-radius:3px;}
.chip svg{width:13px;height:13px;stroke-width:2.2;}
.chip.sajto{background:var(--kat-sajto);}
.chip.tarsadalmi{background:var(--kat-tarsadalmi);}
.chip.program{background:var(--kat-program);}
.card h3{margin:0;font-size:calc(17px * var(--type-scale));font-weight:800;line-height:1.3;
  letter-spacing:-.01em;color:var(--mfb-kek);text-wrap:pretty;}
.card.feat h3{font-size:calc(22px * var(--type-scale));line-height:1.22;}
.card.mini h3{font-size:calc(15.5px * var(--type-scale));
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card.mini p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card .date{font-size:13px;font-weight:700;color:var(--mfb-szurke);letter-spacing:.03em;}
.card p{margin:0;font-size:calc(14.5px * var(--type-scale));color:var(--szoveg-halvany);line-height:1.6;}
.card.feat p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;}
.card.mini{position:relative;}
.card.mini .body{padding:18px 20px;gap:9px;}
.card.mini .date{margin:0;font-size:12px;}
.card.mini p{display:none;}
.card .tlink{margin-top:auto;padding-top:4px;}
.hirek-foot{display:flex;justify-content:center;margin-top:var(--s5);}

/* ---------- CTA band ---------- */
.ctaband{position:relative;background:var(--mfb-kek);color:#fff;overflow:hidden;border-radius:0;}
.cta-media{position:absolute;inset:0;z-index:0;}
.cta-media img{width:100%;height:100%;object-fit:cover;object-position:center 35%;}
.cta-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,69,100,.96) 0%, rgba(0,69,100,.88) 40%, rgba(0,69,100,.74) 75%, rgba(0,69,100,.62) 100%);}
.ctaband .inner{position:relative;z-index:2;text-align:center;padding-block:var(--s6);}
.ctaband .pat{position:absolute;z-index:1;opacity:.42;mix-blend-mode:screen;pointer-events:none;}
.ctaband .pat.c{left:50%;top:50%;transform:translate(-50%,-50%);width:min(1400px,135%);max-width:none;}
.ctaband h2{font-size:calc(38px * var(--type-scale));font-weight:800;letter-spacing:-.02em;margin:0 0 14px;}
.ctaband p{font-size:calc(19px * var(--type-scale));color:rgba(255,255,255,.85);margin:0 0 var(--s4);}

/* ---------- 2 oszlopos blokkok ---------- */
.two-col{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s6);align-items:start;}
@media(max-width:920px){ .two-col{grid-template-columns:1fr;gap:var(--s5);} }

/* Periszkóp */
.peri-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--e2);padding:var(--s4);
  border-top:5px solid var(--mfb-turkiz);}
.peri-card .kicker{font-size:13px;font-weight:800;letter-spacing:.04em;color:var(--mfb-turkiz-melyebb);}
.peri-card h3{font-size:calc(24px * var(--type-scale));font-weight:800;color:var(--mfb-kek);margin:6px 0 14px;letter-spacing:-.01em;}
.peri-card p{font-size:calc(15px * var(--type-scale));color:var(--szoveg-halvany);line-height:1.7;margin:0 0 var(--s3);}

/* Material list */
.mlist{display:flex;flex-direction:column;gap:14px;}
.mlist a{display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:#fff;border-radius:var(--r-card);box-shadow:var(--e1);padding:20px 24px;
  font-weight:700;font-size:calc(16px * var(--type-scale));color:var(--mfb-kek);
  border-left:4px solid transparent;
  transition:box-shadow .25s var(--ease),transform .25s var(--ease),border-color .25s var(--ease);}
.mlist a:hover{box-shadow:var(--e4);transform:translateX(4px);border-left-color:var(--mfb-turkiz);}
.mlist a .chev{color:var(--mfb-turkiz);transition:transform .25s var(--ease);}
.mlist a:hover .chev{transform:translateX(4px);}

/* Társadalmi két kártya */
.tars-stack{display:flex;flex-direction:column;gap:var(--s3);}

/* Árfolyam tábla */
.fx{background:#fff;border-radius:var(--r-card);box-shadow:var(--e2);overflow:hidden;}
.fx .fx-head{background:var(--mfb-kek);color:#fff;padding:18px 22px;display:flex;align-items:baseline;gap:12px;}
.fx .fx-head .d{font-size:calc(22px * var(--type-scale));font-weight:800;letter-spacing:.01em;}
.fx .fx-head .lbl{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mfb-turkiz);}
.fx table{width:100%;border-collapse:collapse;}
.fx th,.fx td{padding:13px 22px;text-align:right;font-size:calc(15px * var(--type-scale));}
.fx th{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--mfb-szurke);
  border-bottom:2px solid var(--vonal);}
.fx th:first-child,.fx td:first-child{text-align:left;font-weight:800;color:var(--mfb-kek);}
.fx td{color:var(--szoveg);font-variant-numeric:tabular-nums;border-bottom:1px solid var(--vonal);}
.fx tbody tr:nth-child(odd){background:#f7fafb;}
.fx tbody tr{transition:background .2s;}
.fx tbody tr:hover{background:#eef6f6;}
.fx .fx-foot{padding:16px 22px;}
/* deviza-jel\u00f6l\u0151 + trend */
.fx .cur{display:inline-flex;align-items:center;gap:11px;}
.fx .cur-badge{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:var(--mfb-kek);color:#fff;font-size:13px;font-weight:800;flex-shrink:0;letter-spacing:0;}
.fx .mid{display:inline-flex;align-items:center;gap:7px;justify-content:flex-end;}
.fx .mid svg{width:15px;height:15px;stroke-width:2.4;}
.fx .mid.up svg{color:var(--mfb-turkiz);}
.fx .mid.down svg{color:var(--mfb-szurke);}

/* ---------- MFB Pontok + térkép ---------- */
.pontok{display:grid;grid-template-columns:600px 1fr;min-height:480px;}
@media(max-width:980px){ .pontok{grid-template-columns:480px 1fr;} }
@media(max-width:860px){ .pontok{grid-template-columns:1fr;} }
.pontok .panel{position:relative;background:var(--mfb-kek);color:#fff;padding:var(--s6) var(--s6);overflow:hidden;}
.pont-logo-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--s3);z-index:2;}
.pont-logo-wrap .pat{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:360px;max-width:none;opacity:.5;mix-blend-mode:screen;pointer-events:none;}
.pont-logo-wrap .pont-logo{width:92px;height:auto;position:relative;z-index:2;}
.pontok .panel h2{position:relative;z-index:2;font-size:calc(32px * var(--type-scale));font-weight:800;
  letter-spacing:-.02em;line-height:1.1;margin:0 0 14px;}
.pontok .panel p{position:relative;z-index:2;color:rgba(255,255,255,.85);margin:0 0 var(--s4);
  font-size:calc(16px * var(--type-scale));}
.pontok .search-field{position:relative;z-index:2;display:flex;gap:0;background:#fff;border-radius:var(--r-btn);
  box-shadow:var(--e2);overflow:hidden;}
.pontok .search-field input{flex:1;border:none;outline:none;padding:16px 18px;font-family:inherit;
  font-size:15px;color:var(--szoveg);}
.pontok .search-field input::placeholder{color:var(--mfb-szurke);}
.pontok .search-field button{background:var(--mfb-turkiz);color:#fff;font-weight:800;text-transform:uppercase;
  padding:0 22px;letter-spacing:.06em;display:flex;align-items:center;gap:8px;transition:.2s;}
.pontok .search-field button:hover{background:var(--mfb-turkiz);filter:brightness(1.08);}
#map{width:100%;height:100%;min-height:420px;background:#dfe8ea;z-index:0;}
.leaflet-control-attribution{display:none;}
.leaflet-pin{cursor:pointer;}
.leaflet-pin .pin-shape{fill:none;stroke:var(--mfb-kek);stroke-width:2;stroke-linejoin:round;
  transition:fill .2s var(--ease),stroke .2s var(--ease);}
.leaflet-pin:hover .pin-shape,.leaflet-pin.active .pin-shape{fill:var(--mfb-kek);stroke:var(--mfb-kek);}

/* térkép popup — nyitvatartás kártya */
.leaflet-popup-content-wrapper{border-radius:10px;box-shadow:var(--e4);}
.leaflet-popup-content{margin:0;}
.pp{font-family:var(--font);padding:15px 16px 14px;}
.pp-title{font-size:15px;font-weight:800;color:var(--mfb-kek);letter-spacing:-.01em;line-height:1.25;}
.pp-addr{display:flex;align-items:flex-start;gap:7px;margin-top:7px;color:var(--szoveg-halvany);font-size:12.5px;line-height:1.4;}
.pp-addr svg{flex-shrink:0;margin-top:1px;}
.pp-hh{margin-top:12px;border-top:1px solid var(--vonal);padding-top:11px;}
.pp-hh-head{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;letter-spacing:.07em;
  text-transform:uppercase;color:var(--mfb-turkiz-melyebb);margin-bottom:8px;}
.pp-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:3px 0;
  font-size:12.5px;color:var(--szoveg);}
.pp-day{color:var(--szoveg-halvany);display:flex;align-items:center;gap:6px;}
.pp-time{font-weight:700;color:var(--mfb-kek);font-variant-numeric:tabular-nums;}
.pp-lunch{margin-top:6px;padding-top:8px;border-top:1px dashed var(--vonal);}
.pp-lunch .pp-day{font-weight:700;color:var(--szoveg);}
.pp-lunch .pp-time{color:var(--szoveg-halvany);font-weight:700;}

/* ---------- Footer ---------- */
.footer{background:var(--mfb-kek-melyebb);color:rgba(255,255,255,.7);}
.foot-top{border-bottom:1px solid rgba(255,255,255,.1);}
.foot-top .wrap{display:flex;align-items:center;gap:var(--s4);flex-wrap:wrap;padding-block:var(--s3);}
.foot-top .logo{display:inline-flex;}
.foot-top .logo img{height:46px;}
.foot-top .contact{margin-left:auto;display:flex;gap:var(--s4);flex-wrap:wrap;}
.foot-top .contact a{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:15px;transition:.2s;}
.foot-top .contact a:hover{color:var(--mfb-turkiz);}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5);padding-block:var(--s6);}
@media(max-width:760px){ .foot-cols{grid-template-columns:1fr;gap:var(--s4);} }
.foot-cols h4{color:#fff;font-size:14px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin:0 0 var(--s3);}
.foot-cols ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px;}
.foot-cols a{display:flex;align-items:center;gap:11px;font-size:15px;color:rgba(255,255,255,.7);transition:.2s;line-height:1.4;}
.foot-cols a svg{width:16px;height:16px;flex-shrink:0;color:var(--mfb-turkiz);stroke-width:2;}
.foot-cols a:hover{color:#fff;padding-left:4px;}
.foot-legal{border-top:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.28);}
.foot-legal .wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;flex-wrap:wrap;padding-block:var(--s3);font-size:13px;}
.foot-legal .links{display:flex;gap:var(--s3);flex-wrap:wrap;justify-content:center;}
.foot-legal .links a:hover{color:var(--mfb-turkiz);}
.foot-legal .copy{color:rgba(255,255,255,.5);white-space:nowrap;}

/* ---------- Széchenyi Terv Plusz — jobb alsó sarok, padding nélkül ---------- */
.szb{position:fixed;right:0;bottom:0;z-index:9000;
  display:inline-block;line-height:0;
  box-shadow:-2px -2px 16px rgba(0,40,58,.18);
  animation:szbIn .5s var(--ease-out) both;}
.szb.hidden{display:none;}
.szb-link{display:block;line-height:0;cursor:pointer;transition:opacity .2s var(--ease);}
.szb-link:hover{opacity:.92;}
.szb-img{height:auto;width:auto;max-width:42vw;display:block;}
@media(min-width:861px){ .szb-img{width:440px;} }
.szb-close{position:absolute;top:-13px;left:-13px;
  width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  color:#fff;background:var(--mfb-kek);box-shadow:var(--e2);transition:.2s var(--ease);}
.szb-close:hover{background:var(--mfb-kek-melyebb);transform:scale(1.08);}
@keyframes szbIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
@media(max-width:560px){ .szb-img{max-width:72vw;} }












/* ============================================================
   RESZPONZÍV — tablet + mobil
   ============================================================ */

/* ---- Tablet (≤1024px) ---- */
@media(max-width:1024px){
  .hero-h1{font-size:calc(46px * var(--type-scale));}
  .hero-sub{font-size:calc(18px * var(--type-scale));}
  .hero-inner .wrap{min-height:460px;}
  .section-title{font-size:calc(30px * var(--type-scale));}
  .ctaband h2{font-size:calc(32px * var(--type-scale));}
  .pontok{grid-template-columns:1fr;}
  .pontok .panel{padding:var(--s5) var(--s5);}
}

/* ---- Tablet portré / nagy mobil (≤768px) ---- */
@media(max-width:768px){
  :root{ --gutter:20px; }
  .section{padding-block:var(--s5);}
  .sec-head{margin-bottom:var(--s4);}
  .hero-inner .wrap{min-height:420px;padding-block:var(--s5);}
  .hero-h1{font-size:calc(40px * var(--type-scale));}
  .hero-copy{max-width:none;}
  /* árfolyam tábla kompaktabb */
  .fx th,.fx td{padding:11px 14px;font-size:calc(13.5px * var(--type-scale));}
  .fx .cur{gap:8px;}
  .fx .cur-badge{width:26px;height:26px;font-size:12px;}
  .fx .fx-head{padding:15px 16px;}
  /* footer-top stack */
  .foot-top .wrap{flex-direction:column;align-items:flex-start;gap:var(--s2);}
  .foot-top .contact{margin-left:0;gap:var(--s2) var(--s3);}
}

/* ---- Mobil (≤560px) ---- */
@media(max-width:560px){
  :root{ --gutter:16px; }
  .utilbar .wrap{gap:var(--s2);}
  .utilbar .date{font-size:12px;}
  .nav .wrap{height:68px;gap:var(--s2);}
  .nav .logo img{height:34px;}
  .hero-h1{font-size:calc(33px * var(--type-scale));}
  .hero-sub{font-size:calc(16px * var(--type-scale));}
  .hero-chip{font-size:11px;}
  /* mobilon egységes, függőleges réteg: szöveg+gomb olvasható, háttér átdereng */
  .hero-media::after{background:linear-gradient(180deg,
    rgba(0,69,100,.86) 0%,
    rgba(0,69,100,.72) 52%,
    rgba(0,69,100,.62) 100%);}
  .hero-actions{width:100%;}
  .hero-actions .btn{flex:1;justify-content:center;}
  .btn{font-size:calc(13px * var(--type-scale));padding:13px 18px;letter-spacing:.04em;}
  .section-title{font-size:calc(26px * var(--type-scale));}
  .ctaband h2{font-size:calc(27px * var(--type-scale));}
  .ctaband p{font-size:calc(16px * var(--type-scale));}
  .peri-card,.pontok .panel{padding:var(--s4);}
  .card.feat h3{font-size:calc(20px * var(--type-scale));}
  .mlist a{padding:16px 18px;}
  /* árfolyam: rejtsük a Vétel/Eladás oszlopot, közép marad — kompakt mobilnézet */
  .fx th:nth-child(2),.fx td:nth-child(2),
  .fx th:nth-child(4),.fx td:nth-child(4){display:none;}
  .fx th,.fx td{padding:12px 16px;font-size:14px;}
  .pontok .search-field{flex-direction:column;}
  .pontok .search-field button{padding:14px;justify-content:center;}
  #map{min-height:340px;}
}


/* required styles */

.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
	position: absolute;
	left: 0;
	top: 0;
	}
.leaflet-container {
	overflow: hidden;
	}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow {
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	  -webkit-user-drag: none;
	}
/* Prevents IE11 from highlighting tiles in blue */
.leaflet-tile::selection {
	background: transparent;
}
/* Safari renders non-retina tile on retina better with this, but Chrome is worse */
.leaflet-safari .leaflet-tile {
	image-rendering: -webkit-optimize-contrast;
	}
/* hack that prevents hw layers "stretching" when loading new tiles */
.leaflet-safari .leaflet-tile-container {
	width: 1600px;
	height: 1600px;
	-webkit-transform-origin: 0 0;
	}
.leaflet-marker-icon,
.leaflet-marker-shadow {
	display: block;
	}
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
.leaflet-container .leaflet-overlay-pane svg {
	max-width: none !important;
	max-height: none !important;
	}
.leaflet-container .leaflet-marker-pane img,
.leaflet-container .leaflet-shadow-pane img,
.leaflet-container .leaflet-tile-pane img,
.leaflet-container img.leaflet-image-layer,
.leaflet-container .leaflet-tile {
	max-width: none !important;
	max-height: none !important;
	width: auto;
	padding: 0;
	}

.leaflet-container img.leaflet-tile {
	/* See: https://bugs.chromium.org/p/chromium/issues/detail?id=600120 */
	mix-blend-mode: plus-lighter;
}

.leaflet-container.leaflet-touch-zoom {
	-ms-touch-action: pan-x pan-y;
	touch-action: pan-x pan-y;
	}
.leaflet-container.leaflet-touch-drag {
	-ms-touch-action: pinch-zoom;
	/* Fallback for FF which doesn't support pinch-zoom */
	touch-action: none;
	touch-action: pinch-zoom;
}
.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
	-ms-touch-action: none;
	touch-action: none;
}
.leaflet-container {
	-webkit-tap-highlight-color: transparent;
}
.leaflet-container a {
	-webkit-tap-highlight-color: rgba(51, 181, 229, 0.4);
}
.leaflet-tile {
	filter: inherit;
	visibility: hidden;
	}
.leaflet-tile-loaded {
	visibility: inherit;
	}
.leaflet-zoom-box {
	width: 0;
	height: 0;
	-moz-box-sizing: border-box;
	     box-sizing: border-box;
	z-index: 800;
	}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg {
	-moz-user-select: none;
	}

.leaflet-pane         { z-index: 400; }

.leaflet-tile-pane    { z-index: 200; }
.leaflet-overlay-pane { z-index: 400; }
.leaflet-shadow-pane  { z-index: 500; }
.leaflet-marker-pane  { z-index: 600; }
.leaflet-tooltip-pane   { z-index: 650; }
.leaflet-popup-pane   { z-index: 700; }

.leaflet-map-pane canvas { z-index: 100; }
.leaflet-map-pane svg    { z-index: 200; }

.leaflet-vml-shape {
	width: 1px;
	height: 1px;
	}
.lvml {
	behavior: url(#default#VML);
	display: inline-block;
	position: absolute;
	}


/* control positioning */

.leaflet-control {
	position: relative;
	z-index: 800;
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}
.leaflet-top,
.leaflet-bottom {
	position: absolute;
	z-index: 1000;
	pointer-events: none;
	}
.leaflet-top {
	top: 0;
	}
.leaflet-right {
	right: 0;
	}
.leaflet-bottom {
	bottom: 0;
	}
.leaflet-left {
	left: 0;
	}
.leaflet-control {
	float: left;
	clear: both;
	}
.leaflet-right .leaflet-control {
	float: right;
	}
.leaflet-top .leaflet-control {
	margin-top: 10px;
	}
.leaflet-bottom .leaflet-control {
	margin-bottom: 10px;
	}
.leaflet-left .leaflet-control {
	margin-left: 10px;
	}
.leaflet-right .leaflet-control {
	margin-right: 10px;
	}


/* zoom and fade animations */

.leaflet-fade-anim .leaflet-popup {
	opacity: 0;
	-webkit-transition: opacity 0.2s linear;
	   -moz-transition: opacity 0.2s linear;
	        transition: opacity 0.2s linear;
	}
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
	opacity: 1;
	}
.leaflet-zoom-animated {
	-webkit-transform-origin: 0 0;
	    -ms-transform-origin: 0 0;
	        transform-origin: 0 0;
	}
svg.leaflet-zoom-animated {
	will-change: transform;
}

.leaflet-zoom-anim .leaflet-zoom-animated {
	-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
	   -moz-transition:    -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
	        transition:         transform 0.25s cubic-bezier(0,0,0.25,1);
	}
.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile {
	-webkit-transition: none;
	   -moz-transition: none;
	        transition: none;
	}

.leaflet-zoom-anim .leaflet-zoom-hide {
	visibility: hidden;
	}


/* cursors */

.leaflet-interactive {
	cursor: pointer;
	}
.leaflet-grab {
	cursor: -webkit-grab;
	cursor:    -moz-grab;
	cursor:         grab;
	}
.leaflet-crosshair,
.leaflet-crosshair .leaflet-interactive {
	cursor: crosshair;
	}
.leaflet-popup-pane,
.leaflet-control {
	cursor: auto;
	}
.leaflet-dragging .leaflet-grab,
.leaflet-dragging .leaflet-grab .leaflet-interactive,
.leaflet-dragging .leaflet-marker-draggable {
	cursor: move;
	cursor: -webkit-grabbing;
	cursor:    -moz-grabbing;
	cursor:         grabbing;
	}

/* marker & overlays interactivity */
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-image-layer,
.leaflet-pane > svg path,
.leaflet-tile-container {
	pointer-events: none;
	}

.leaflet-marker-icon.leaflet-interactive,
.leaflet-image-layer.leaflet-interactive,
.leaflet-pane > svg path.leaflet-interactive,
svg.leaflet-image-layer.leaflet-interactive path {
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}

/* visual tweaks */

.leaflet-container {
	background: #ddd;
	outline-offset: 1px;
	}
.leaflet-container a {
	color: #0078A8;
	}
.leaflet-zoom-box {
	border: 2px dotted #38f;
	background: rgba(255,255,255,0.5);
	}


/* general typography */
.leaflet-container {
	font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
	font-size: 12px;
	font-size: 0.75rem;
	line-height: 1.5;
	}


/* general toolbar styles */

.leaflet-bar {
	box-shadow: 0 1px 5px rgba(0,0,0,0.65);
	border-radius: 4px;
	}
.leaflet-bar a {
	background-color: #fff;
	border-bottom: 1px solid #ccc;
	width: 26px;
	height: 26px;
	line-height: 26px;
	display: block;
	text-align: center;
	text-decoration: none;
	color: black;
	}
.leaflet-bar a,
.leaflet-control-layers-toggle {
	background-position: 50% 50%;
	background-repeat: no-repeat;
	display: block;
	}
.leaflet-bar a:hover,
.leaflet-bar a:focus {
	background-color: #f4f4f4;
	}
.leaflet-bar a:first-child {
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
	}
.leaflet-bar a:last-child {
	border-bottom-left-radius: 4px;
	border-bottom-right-radius: 4px;
	border-bottom: none;
	}
.leaflet-bar a.leaflet-disabled {
	cursor: default;
	background-color: #f4f4f4;
	color: #bbb;
	}

.leaflet-touch .leaflet-bar a {
	width: 30px;
	height: 30px;
	line-height: 30px;
	}
.leaflet-touch .leaflet-bar a:first-child {
	border-top-left-radius: 2px;
	border-top-right-radius: 2px;
	}
.leaflet-touch .leaflet-bar a:last-child {
	border-bottom-left-radius: 2px;
	border-bottom-right-radius: 2px;
	}

/* zoom control */

.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
	font: bold 18px 'Lucida Console', Monaco, monospace;
	text-indent: 1px;
	}

.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out  {
	font-size: 22px;
	}


/* layers control */

.leaflet-control-layers {
	box-shadow: 0 1px 5px rgba(0,0,0,0.4);
	background: #fff;
	border-radius: 5px;
	}
.leaflet-control-layers-toggle {
	background-image: url("../img/bg-1.png");
	width: 36px;
	height: 36px;
	}
.leaflet-retina .leaflet-control-layers-toggle {
	background-image: url("../img/bg-2.png");
	background-size: 26px 26px;
	}
.leaflet-touch .leaflet-control-layers-toggle {
	width: 44px;
	height: 44px;
	}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
	display: none;
	}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
	display: block;
	position: relative;
	}
.leaflet-control-layers-expanded {
	padding: 6px 10px 6px 6px;
	color: #333;
	background: #fff;
	}
.leaflet-control-layers-scrollbar {
	overflow-y: scroll;
	overflow-x: hidden;
	padding-right: 5px;
	}
.leaflet-control-layers-selector {
	margin-top: 2px;
	position: relative;
	top: 1px;
	}
.leaflet-control-layers label {
	display: block;
	font-size: 13px;
	font-size: 1.08333em;
	}
.leaflet-control-layers-separator {
	height: 0;
	border-top: 1px solid #ddd;
	margin: 5px -10px 5px -6px;
	}

/* Default icon URLs */
.leaflet-default-icon-path { /* used only in path-guessing heuristic, see L.Icon.Default */
	background-image: url("../img/bg-3.png");
	}


/* attribution and scale controls */

.leaflet-container .leaflet-control-attribution {
	background: #fff;
	background: rgba(255, 255, 255, 0.8);
	margin: 0;
	}
.leaflet-control-attribution,
.leaflet-control-scale-line {
	padding: 0 5px;
	color: #333;
	line-height: 1.4;
	}
.leaflet-control-attribution a {
	text-decoration: none;
	}
.leaflet-control-attribution a:hover,
.leaflet-control-attribution a:focus {
	text-decoration: underline;
	}
.leaflet-attribution-flag {
	display: inline !important;
	vertical-align: baseline !important;
	width: 1em;
	height: 0.6669em;
	}
.leaflet-left .leaflet-control-scale {
	margin-left: 5px;
	}
.leaflet-bottom .leaflet-control-scale {
	margin-bottom: 5px;
	}
.leaflet-control-scale-line {
	border: 2px solid #777;
	border-top: none;
	line-height: 1.1;
	padding: 2px 5px 1px;
	white-space: nowrap;
	-moz-box-sizing: border-box;
	     box-sizing: border-box;
	background: rgba(255, 255, 255, 0.8);
	text-shadow: 1px 1px #fff;
	}
.leaflet-control-scale-line:not(:first-child) {
	border-top: 2px solid #777;
	border-bottom: none;
	margin-top: -2px;
	}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
	border-bottom: 2px solid #777;
	}

.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	box-shadow: none;
	}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	border: 2px solid rgba(0,0,0,0.2);
	background-clip: padding-box;
	}


/* popup */

.leaflet-popup {
	position: absolute;
	text-align: center;
	margin-bottom: 20px;
	}
.leaflet-popup-content-wrapper {
	padding: 1px;
	text-align: left;
	border-radius: 12px;
	}
.leaflet-popup-content {
	margin: 13px 24px 13px 20px;
	line-height: 1.3;
	font-size: 13px;
	font-size: 1.08333em;
	min-height: 1px;
	}
.leaflet-popup-content p {
	margin: 17px 0;
	margin: 1.3em 0;
	}
.leaflet-popup-tip-container {
	width: 40px;
	height: 20px;
	position: absolute;
	left: 50%;
	margin-top: -1px;
	margin-left: -20px;
	overflow: hidden;
	pointer-events: none;
	}
.leaflet-popup-tip {
	width: 17px;
	height: 17px;
	padding: 1px;

	margin: -10px auto 0;
	pointer-events: auto;

	-webkit-transform: rotate(45deg);
	   -moz-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	        transform: rotate(45deg);
	}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
	background: white;
	color: #333;
	box-shadow: 0 3px 14px rgba(0,0,0,0.4);
	}
.leaflet-container a.leaflet-popup-close-button {
	position: absolute;
	top: 0;
	right: 0;
	border: none;
	text-align: center;
	width: 24px;
	height: 24px;
	font: 16px/24px Tahoma, Verdana, sans-serif;
	color: #757575;
	text-decoration: none;
	background: transparent;
	}
.leaflet-container a.leaflet-popup-close-button:hover,
.leaflet-container a.leaflet-popup-close-button:focus {
	color: #585858;
	}
.leaflet-popup-scrolled {
	overflow: auto;
	}

.leaflet-oldie .leaflet-popup-content-wrapper {
	-ms-zoom: 1;
	}
.leaflet-oldie .leaflet-popup-tip {
	width: 24px;
	margin: 0 auto;

	-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
	filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
	}

.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip {
	border: 1px solid #999;
	}


/* div icon */

.leaflet-div-icon {
	background: #fff;
	border: 1px solid #666;
	}


/* Tooltip */
/* Base styles for the element that has a tooltip */
.leaflet-tooltip {
	position: absolute;
	padding: 6px;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 3px;
	color: #222;
	white-space: nowrap;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	pointer-events: none;
	box-shadow: 0 1px 3px rgba(0,0,0,0.4);
	}
.leaflet-tooltip.leaflet-interactive {
	cursor: pointer;
	pointer-events: auto;
	}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	position: absolute;
	pointer-events: none;
	border: 6px solid transparent;
	background: transparent;
	content: "";
	}

/* Directions */

.leaflet-tooltip-bottom {
	margin-top: 6px;
}
.leaflet-tooltip-top {
	margin-top: -6px;
}
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-top:before {
	left: 50%;
	margin-left: -6px;
	}
.leaflet-tooltip-top:before {
	bottom: 0;
	margin-bottom: -12px;
	border-top-color: #fff;
	}
.leaflet-tooltip-bottom:before {
	top: 0;
	margin-top: -12px;
	margin-left: -6px;
	border-bottom-color: #fff;
	}
.leaflet-tooltip-left {
	margin-left: -6px;
}
.leaflet-tooltip-right {
	margin-left: 6px;
}
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	top: 50%;
	margin-top: -6px;
	}
.leaflet-tooltip-left:before {
	right: 0;
	margin-right: -12px;
	border-left-color: #fff;
	}
.leaflet-tooltip-right:before {
	left: 0;
	margin-left: -12px;
	border-right-color: #fff;
	}

/* Printing */

@media print {
	/* Prevent printers from removing background-images of controls. */
	.leaflet-control {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
		}
	}
