/* ===== Tisza Élménypart - webshop demó (megosztott stílus, v3 animated) ===== */
:root{
  --bg:#fbfaf7; --ink:#15231f; --sub:#647069; --line:#e7ebe7; --card:#fff;
  --teal:#0b5d57; --teal-d:#073f3b; --accent:#0c8f84; --gold:#c0902f; --gold-l:#e3b85a; --ok:#1c9d6b; --cream:#f3efe6;
  --shadow:0 10px 34px rgba(11,93,87,.10); --shadow-lg:0 24px 60px rgba(8,40,37,.22); --r:16px; --rs:11px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1160px;margin:0 auto;padding:0 20px}
h1,h2,h3{letter-spacing:-.02em}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--teal);color:#fff;border:none;border-radius:12px;padding:13px 22px;font-weight:700;font-size:.95rem;cursor:pointer;transition:transform .14s var(--ease),box-shadow .2s,filter .15s;font-family:inherit;position:relative;overflow:hidden}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(11,93,87,.28)}
.btn:active{transform:translateY(0)}
.btn.lg{padding:16px 28px;font-size:1.04rem}
.btn.block{width:100%}
.btn.gold{background:linear-gradient(120deg,var(--gold),var(--gold-l))}
.btn.ghost{background:#eaf5f2;color:var(--teal)}
.btn.outline{background:transparent;border:1.5px solid rgba(255,255,255,.6);color:#fff}
.btn.outline:hover{background:rgba(255,255,255,.12)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
/* shimmer sweep on primary CTA */
.btn.shine::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);animation:shine 3.6s var(--ease) infinite}
@keyframes shine{0%{left:-120%}55%{left:140%}100%{left:140%}}
.muted{color:var(--sub)}
.demo-flag{background:linear-gradient(90deg,var(--gold),var(--gold-l));color:#241a05;text-align:center;font-size:.78rem;font-weight:700;padding:7px 12px}

/* ===== HEADER (responsive + mobile menu) ===== */
header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hbar{display:flex;align-items:center;gap:14px;padding:12px 0;min-width:0}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.16rem;white-space:nowrap;min-width:0;flex-shrink:0}
.brand .mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--accent));display:grid;place-items:center;color:#fff;font-size:19px;flex:none;box-shadow:0 6px 16px rgba(11,93,87,.3)}
.brand .bt{display:flex;flex-direction:column;line-height:1.05}
.brand .bt b{font-weight:800}
.brand small{font-weight:500;color:var(--sub);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase}
.hnav{display:flex;gap:20px;margin-left:10px}
.hnav a{font-size:.9rem;font-weight:600;color:var(--sub);padding:6px 0;border-bottom:2px solid transparent;transition:color .15s}
.hnav a:hover,.hnav a.on{color:var(--teal);border-color:var(--teal)}
.hspace{flex:1}
.lang{display:flex;border:1px solid var(--line);border-radius:9px;overflow:hidden;flex:none}
.lang button{background:#fff;border:none;padding:7px 9px;font-size:.74rem;font-weight:800;color:var(--sub);cursor:pointer;font-family:inherit;transition:background .15s}
.lang button.on{background:var(--teal);color:#fff}
.cartlink{position:relative;background:var(--teal);color:#fff;border-radius:11px;padding:10px 14px;font-weight:700;font-size:.86rem;display:inline-flex;align-items:center;gap:7px;flex:none;transition:transform .12s}
.cartlink:hover{transform:translateY(-1px)}
.cartlink .badge{position:absolute;top:-7px;right:-7px;background:var(--gold);color:#241a05;border-radius:999px;min-width:21px;height:21px;font-size:.72rem;display:grid;place-items:center;font-weight:800;padding:0 5px}
.burger{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--teal);padding:4px 6px;flex:none}
.mmenu{display:none;border-top:1px solid var(--line);background:#fff}
.mmenu.open{display:block;animation:fadeUp .3s var(--ease)}
.mmenu a{display:block;padding:13px 20px;font-weight:600;border-bottom:1px solid var(--line)}
.mmenu a:last-child{border-bottom:none}
@media(max-width:780px){
  .hnav{display:none}
  .burger{display:block}
  .brand{font-size:1.02rem}
  .brand small{display:none}
  .cartlink{display:none}  /* mobilon a fejléc-kosár helyett lebegő FAB (lásd .cartfab) */
  .lang button{padding:6px 7px;font-size:.7rem}
}
/* Mobil kosár: lebegő, könnyen elérhető gomb a bal alsó sarokban (a chat FAB párja a jobb oldalon).
   A body-ra kerül (NEM a fejlécbe), mert a fejléc backdrop-filter-e elrontaná a fixed pozíciót. */
.cartfab{display:none}
@media(max-width:780px){
  .cartfab{display:grid;place-items:center;position:fixed;left:16px;bottom:20px;z-index:76;width:58px;height:58px;border-radius:999px;background:var(--teal);color:#fff;font-size:24px;text-decoration:none;box-shadow:0 10px 28px rgba(11,93,87,.45)}
  .cartfab .badge{position:absolute;top:-4px;right:-4px;background:var(--gold);color:#241a05;border-radius:999px;min-width:22px;height:22px;font-size:.74rem;display:grid;place-items:center;font-weight:800;padding:0 5px}
  body.has-cookie .cartfab{bottom:120px}
}
@media(max-width:520px){body.has-cookie .cartfab{bottom:180px}}

/* ===== reveal on scroll ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}.reveal[data-d="5"]{transition-delay:.4s}.reveal[data-d="6"]{transition-delay:.48s}

/* ===== HERO (landing) ===== */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--teal-d)}
.hero .bg{position:absolute;inset:0;background:url('img/hero-poster.webp') center/cover;animation:kenburns 22s ease-in-out infinite alternate;will-change:transform}
.hero .ov{position:absolute;inset:0;background:linear-gradient(105deg,rgba(7,63,59,.86) 0%,rgba(7,63,59,.55) 55%,rgba(7,63,59,.25) 100%)}
.hero .in{position:relative;z-index:2;padding:64px 0}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:7px 14px;font-size:.8rem;font-weight:700;letter-spacing:.04em;margin-bottom:18px;backdrop-filter:blur(4px)}
.hero h1{margin:0 0 16px;font-size:clamp(2.1rem,6vw,3.6rem);line-height:1.07;max-width:16ch;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero p{margin:0 0 28px;font-size:clamp(1rem,2.4vw,1.2rem);color:#e7f4f0;max-width:52ch}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.qrchip{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:12px 16px;font-size:.92rem;cursor:pointer;color:#fff;font-family:inherit;transition:background .2s,transform .12s}
.qrchip:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.qrchip .qi{font-size:1.3rem;animation:floaty 3s ease-in-out infinite}
.scrolld{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.8);font-size:1.6rem;animation:bob 1.8s ease-in-out infinite}

/* ===== generic sections ===== */
section.block{padding:64px 0}
section.tint{background:var(--cream)}
.sec-head{text-align:center;max-width:640px;margin:0 auto 38px}
.sec-head .kick{color:var(--gold);font-weight:800;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase}
.sec-head h2{font-size:clamp(1.6rem,4vw,2.3rem);margin:8px 0 10px}
.sec-head p{color:var(--sub);font-size:1.04rem;margin:0}
.sec-h{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:0 0 22px}
.sec-h h2{font-size:1.55rem;margin:0}
.sec-h a{font-size:.9rem;font-weight:700;color:var(--teal)}

/* feature tiles (categories on landing) */
.feats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.feat{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow);transition:transform .25s var(--ease),box-shadow .25s}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.feat:hover img{transform:scale(1.08)}
.feat .fov{position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(7,40,37,.82))}
.feat .fc{position:relative;padding:18px;z-index:2}
.feat .fc b{font-size:1.18rem;display:block}
.feat .fc span{font-size:.84rem;opacity:.9}
/* 6-card category grid (landing + catalog home) */
.feats6{grid-template-columns:repeat(3,1fr)}
.feat--soon{cursor:default;background:linear-gradient(135deg,#0b5d57,#0c8f84)}
.feat--soon:hover{transform:none;box-shadow:var(--shadow)}
.feat .feat-soon{position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 14px,rgba(255,255,255,.08) 14px 28px)}
.feat--soon .fov{background:linear-gradient(transparent 35%,rgba(7,40,37,.5))}
@media(max-width:980px){.feats6{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.feats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feats6{grid-template-columns:1fr}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px;text-align:center;transition:transform .2s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step .n{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--accent));color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.1rem;margin:0 auto 14px}
.step h3{margin:0 0 6px;font-size:1.12rem}
.step p{margin:0;color:var(--sub);font-size:.92rem}
@media(max-width:780px){.steps{grid-template-columns:1fr}}

/* stat band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat .v{font-size:2.1rem;font-weight:800;color:var(--teal);letter-spacing:-.02em}
.stat .l{color:var(--sub);font-size:.9rem}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr);gap:26px}}

/* testimonials */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}
.tcard .stars{color:var(--gold);letter-spacing:2px;margin-bottom:8px}
.tcard p{margin:0 0 14px;font-size:.98rem}
.tcard .who{font-weight:700;font-size:.9rem}
.tcard .who span{display:block;color:var(--sub);font-weight:500;font-size:.82rem}
@media(max-width:860px){.tcards{grid-template-columns:1fr}}

/* CTA band */
.ctaband{position:relative;border-radius:24px;overflow:hidden;color:#fff;padding:54px 30px;text-align:center;background:linear-gradient(120deg,var(--teal),var(--accent))}
.ctaband h2{font-size:clamp(1.6rem,4vw,2.3rem);margin:0 0 10px}
.ctaband p{margin:0 0 22px;color:#e7f4f0}

/* ===== PRODUCT GRID ===== */
.catbar{display:flex;gap:9px;flex-wrap:wrap;margin:0 0 24px;justify-content:center}
.catbar a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 17px;font-weight:600;font-size:.88rem;color:var(--ink);cursor:pointer;transition:all .15s}
.catbar a:hover{border-color:var(--teal);color:var(--teal)}
.catbar a.on{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 6px 16px rgba(11,93,87,.25)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(244px,1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .16s var(--ease),box-shadow .2s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card .imgwrap{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--cream)}
.card .imgwrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .imgwrap img{transform:scale(1.07)}
.card .cat{position:absolute;top:11px;left:11px;background:rgba(255,255,255,.94);color:var(--teal);font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;border-radius:7px;padding:4px 9px;backdrop-filter:blur(4px)}
.card .cb{padding:15px 16px 17px;display:flex;flex-direction:column;flex:1}
.card .nm{font-weight:700;font-size:1.03rem;line-height:1.3}
.card .ds{color:var(--sub);font-size:.83rem;margin:4px 0 13px;flex:1}
.card .row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .pr{font-weight:800;color:var(--teal);font-size:1.14rem;white-space:nowrap}
.card .pr small{color:var(--sub);font-weight:600;font-size:.72rem}
.card .addmini{background:var(--teal);color:#fff;border:none;border-radius:10px;padding:9px 14px;font-weight:700;cursor:pointer;font-size:.82rem;font-family:inherit;transition:transform .12s,filter .15s}
.card .addmini:hover{filter:brightness(1.1);transform:translateY(-1px)}
/* EUR ár a HUF mellett (tájékoztató) */
.eurv{color:var(--sub);font-weight:600;font-size:.8em;white-space:nowrap;margin-left:2px}

/* breadcrumb */
.crumb{font-size:.83rem;color:var(--sub);padding:20px 0 0}
.crumb a:hover{color:var(--teal)}

/* product detail */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:44px;padding:26px 0 10px}
.pd .gallery{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--cream);aspect-ratio:1/1;box-shadow:var(--shadow)}
.pd .gallery img{width:100%;height:100%;object-fit:cover}
.pd .cat{display:inline-block;background:var(--cream);color:var(--teal);font-size:.68rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;border-radius:7px;padding:4px 9px;margin-bottom:10px}
.pd h1{font-size:clamp(1.6rem,4vw,2.1rem);margin:0 0 8px;line-height:1.15}
.pd .price{font-size:1.8rem;font-weight:800;color:var(--teal);margin:6px 0 16px}
.pd .price small{font-size:.9rem;color:var(--sub);font-weight:600}
.pd .long{color:#384842;font-size:1.02rem;margin:0 0 22px}
.pd .opt{margin:0 0 16px}
.pd .opt label{display:block;font-size:.82rem;font-weight:700;margin-bottom:6px}
.pd .opt input,.pd .opt select{border:1px solid var(--line);border-radius:10px;padding:11px 13px;font:inherit;font-size:.95rem;width:180px}
.qtybox{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:10px;overflow:hidden;vertical-align:middle}
.qtybox button{background:#fff;border:none;width:44px;height:46px;font-size:1.2rem;cursor:pointer;color:var(--teal);font-weight:800}
.qtybox button:hover{background:var(--cream)}
.qtybox span{min-width:42px;text-align:center;font-weight:700}
.pd .buyrow{display:flex;gap:12px;align-items:center;margin-top:6px}
@media(max-width:800px){.pd{grid-template-columns:1fr;gap:24px}}

/* cart */
.cartlayout{display:grid;grid-template-columns:1fr 350px;gap:32px;padding:24px 0 64px;align-items:start}
.crow{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center}
.crow .ci{width:90px;height:90px;border-radius:12px;overflow:hidden;flex:none;background:var(--cream)}
.crow .ci img{width:100%;height:100%;object-fit:cover}
.crow .cinfo{flex:1;min-width:0}
.crow .cn{font-weight:700}
.crow .cmeta{color:var(--sub);font-size:.84rem;margin-top:2px}
.crow .cprice{font-weight:800;color:var(--teal);white-space:nowrap;min-width:90px;text-align:right}
.crow .rm{background:none;border:none;color:#b3382f;cursor:pointer;font-size:.8rem;margin-top:6px;padding:0}
.summary{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;position:sticky;top:88px;box-shadow:var(--shadow)}
.summary h3{margin:0 0 14px;font-size:1.18rem}
.sline{display:flex;justify-content:space-between;margin:9px 0;font-size:.92rem;color:var(--sub)}
.stotal{display:flex;justify-content:space-between;font-size:1.32rem;font-weight:800;margin:14px 0 18px;border-top:1px solid var(--line);padding-top:14px}
.stotal b{color:var(--teal)}
.cart-empty{text-align:center;padding:80px 20px;color:var(--sub)}
@media(max-width:800px){.cartlayout{grid-template-columns:1fr}.summary{position:static}}

/* checkout */
.cols{display:grid;grid-template-columns:1fr 370px;gap:32px;padding:24px 0 64px;align-items:start}
.formcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.formcard h2{margin:0 0 4px;font-size:1.32rem}
.fld{margin-bottom:14px}
.fld label{display:block;font-size:.82rem;font-weight:700;margin-bottom:6px}
.fld input,.fld textarea,.fld select{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 13px;font:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s}
.fld input:focus,.fld textarea:focus,.fld select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(11,93,87,.12)}
.fld textarea{min-height:76px;resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.err{background:#fdeceb;color:#a3261f;border-radius:10px;padding:11px 14px;font-size:.88rem;margin-bottom:14px;display:none}
.miniitem{display:flex;gap:10px;align-items:center;font-size:.88rem;margin:9px 0}
.miniitem img{width:44px;height:44px;border-radius:8px;object-fit:cover;flex:none}
@media(max-width:800px){.cols{grid-template-columns:1fr}.frow{grid-template-columns:1fr}}

/* confirm */
.confirm{text-align:center;max-width:560px;margin:0 auto;padding:70px 20px}
.confirm .big{font-size:70px;animation:pop .5s var(--ease)}
.confirm h1{font-size:2rem;margin:10px 0 8px}
.confirm .ref{display:inline-block;background:var(--cream);border-radius:10px;padding:9px 18px;font-weight:800;color:var(--teal);letter-spacing:.04em;margin:8px 0 20px}

/* contact */
.contactgrid{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:10px 0 30px;align-items:start}
.infoblock{display:flex;gap:13px;margin-bottom:18px;align-items:flex-start}
.infoblock .ic{width:42px;height:42px;border-radius:11px;background:var(--cream);display:grid;place-items:center;font-size:19px;flex:none}
.infoblock b{display:block}
.mapwrap{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:4/3}
.mapwrap iframe{width:100%;height:100%;border:0}
@media(max-width:780px){.contactgrid{grid-template-columns:1fr}}

/* ===== QR MODAL ===== */
.modal{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(8,24,21,.55);backdrop-filter:blur(3px)}
.modal.open{display:flex;animation:fadeIn .25s}
.modal .box{background:#fff;border-radius:20px;max-width:430px;width:100%;max-height:94vh;overflow-y:auto;padding:24px;text-align:center;animation:pop .3s var(--ease)}
.modal .box h3{margin:4px 0 6px;font-size:1.35rem}
.modal .box p{color:var(--sub);font-size:.9rem;margin:0 0 16px}
.modal .x{float:right;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--sub);line-height:1}
.qrtabs{display:flex;gap:8px;justify-content:center;margin:0 0 16px}
.qrtabs button{background:var(--cream);border:none;border-radius:9px;padding:9px 14px;font-weight:700;font-size:.85rem;cursor:pointer;color:var(--teal);font-family:inherit}
.qrtabs button.on{background:var(--teal);color:#fff}
.qrimg{width:240px;height:240px;margin:0 auto;border-radius:16px;border:1px solid var(--line);padding:10px;background:#fff}
#qrCam{width:100%;max-width:320px;border-radius:14px;background:#000;aspect-ratio:1/1;object-fit:cover;margin:0 auto;display:none}
.scanline{position:relative}

/* ===== FOOTER ===== */
footer.site{background:#0b1513;color:#9fb3ad;margin-top:0;padding:50px 0 30px}
footer.site .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
footer.site h4{color:#fff;margin:0 0 12px;font-size:1rem}
footer.site a{display:block;padding:4px 0;font-size:.9rem}
footer.site a:hover{color:#fff}
footer.site .fbrand b{color:#fff;font-size:1.1rem}
footer.site .copy{border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:18px;font-size:.82rem;opacity:.7}
@media(max-width:780px){footer.site .fgrid{grid-template-columns:1fr;gap:22px}}

/* ===== CHATBOT ===== */
.fab{position:fixed;right:20px;bottom:20px;z-index:75;background:linear-gradient(135deg,var(--teal),var(--accent));color:#fff;border:none;border-radius:999px;width:62px;height:62px;font-size:26px;cursor:pointer;box-shadow:0 10px 28px rgba(11,93,87,.45);display:grid;place-items:center;transition:transform .15s,bottom .25s var(--ease)}
.fab:hover{transform:scale(1.06)}
body.has-cookie .fab{bottom:120px}
@media(max-width:520px){body.has-cookie .fab{bottom:180px}}
.fab .fdot{position:absolute;top:3px;right:3px;width:14px;height:14px;background:var(--gold);border-radius:50%;border:2px solid #fff;animation:pulse 2s infinite}
.chat{position:fixed;right:20px;bottom:20px;z-index:85;width:min(390px,calc(100vw - 24px));height:min(580px,calc(100vh - 32px));background:#fff;border-radius:18px;box-shadow:0 22px 56px rgba(8,20,18,.4);display:none;flex-direction:column;overflow:hidden}
.chat.open{display:flex;animation:pop .3s var(--ease)}
.chat .ch{background:linear-gradient(135deg,var(--teal),var(--accent));color:#fff;padding:13px 15px;display:flex;align-items:center;gap:10px}
.chat .ch .av{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:18px;flex:none}
.chat .ch .who{flex:1;min-width:0}.chat .ch .who b{font-size:.95rem;display:block}.chat .ch .who span{font-size:.71rem;color:#cdeee8}
.chat .ch .x{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;line-height:1}
.msgs{flex:1;overflow-y:auto;padding:14px;background:#f3f7f6;display:flex;flex-direction:column;gap:9px}
.msgs>*{flex-shrink:0}
.m{max-width:86%;padding:10px 13px;border-radius:14px;font-size:.9rem;line-height:1.45;animation:fadeUp .3s var(--ease)}
.m.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.m.me{background:var(--teal);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.botcard{align-self:flex-start;max-width:90%;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;text-align:left;animation:fadeUp .3s var(--ease)}
.botcard .bt{width:64px;flex:none;background:var(--cream)}
.botcard .bt img{width:64px;height:74px;object-fit:cover}
.botcard .bb{padding:9px 11px;flex:1;min-width:0}
.botcard .bn{font-weight:700;font-size:.85rem;line-height:1.25}
.botcard .bp{color:var(--teal);font-weight:800;font-size:.83rem;margin:2px 0 7px}
.botcard .ba{display:flex;gap:6px;flex-wrap:wrap}
.botcard .ba button{background:var(--teal);color:#fff;border:none;border-radius:7px;padding:6px 9px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit}
.botcard .ba button.ghost{background:#eaf5f2;color:var(--teal)}
.msgs .chips{display:flex;flex-wrap:wrap;gap:6px;padding:2px 0;background:none;border:none}
.chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;background:#f3f7f6;border-top:1px solid var(--line)}
.chips button{background:#fff;border:1px solid var(--teal);color:var(--teal);border-radius:999px;padding:6px 11px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit}
.cin{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--line);background:#fff}
.cin input{flex:1;border:1px solid var(--line);border-radius:999px;padding:9px 14px;font:inherit;font-size:.88rem;min-width:0}
.cin button{background:var(--teal);color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.05rem;cursor:pointer;flex:none}
.typing{align-self:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:11px 14px}
.typing span{display:inline-block;width:7px;height:7px;background:#9bb3ad;border-radius:50%;margin:0 1px;animation:bl 1s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}

/* footer 4-oszlop + hírlevél */
footer.site .fgrid4{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:30px}
@media(max-width:880px){footer.site .fgrid4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){footer.site .fgrid4{grid-template-columns:1fr}}
.nl{margin-top:18px}
.nl b{display:block;color:#fff;margin-bottom:8px;font-size:.95rem}
.nl .nlrow{display:flex;gap:8px;flex-wrap:wrap}
.nl input{flex:1;min-width:150px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;border-radius:9px;padding:10px 12px;font:inherit;font-size:.88rem}
.nl input::placeholder{color:#9fb3ad}
.nl .btn{padding:10px 16px}
.nl .nlmsg{display:block;color:#a7e0d6;font-size:.82rem;margin-top:8px}
/* cookie banner */
.cookie{position:fixed;left:14px;right:14px;bottom:14px;z-index:70;background:#0b1513;color:#dfe9e6;border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:15px 18px;display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;box-shadow:0 16px 40px rgba(0,0,0,.4);max-width:780px;margin:0 auto;animation:fadeUp .4s var(--ease)}
.cookie p{margin:0;font-size:.86rem;flex:1;min-width:220px}
.cookie a{color:#a7e0d6;text-decoration:underline}
.cookie .cbtns{display:flex;gap:9px;flex-wrap:wrap}
.cookie .cbtns button{border:none;border-radius:9px;padding:10px 16px;font-weight:700;cursor:pointer;font-family:inherit;font-size:.85rem}
.cookie .acc{background:var(--gold);color:#241a05}
.cookie .dec{background:rgba(255,255,255,.12);color:#fff}
/* jogi/doc oldal */
.doc{max-width:800px;margin:0 auto}
.doc h2{margin:26px 0 8px;font-size:1.22rem}
.doc p,.doc li{color:#384842;font-size:.98rem;line-height:1.7}
.doc ul{padding-left:20px}
.doc .note{background:var(--cream);border-left:3px solid var(--gold);padding:12px 14px;border-radius:8px;font-size:.9rem;margin:0 0 22px}
.doc table{width:100%;border-collapse:collapse;margin:8px 0}
.doc td{border:1px solid var(--line);padding:9px 11px;font-size:.92rem;vertical-align:top}
/* nagy QR a belépő modalban */
.qrbig{text-align:center}
.qrbig .qrimg{width:230px;height:230px;margin:6px auto}
.qrbig .phone{font-size:2rem;margin-bottom:2px}
.qradv{margin-top:14px;font-size:.84rem;color:var(--teal);cursor:pointer;text-decoration:underline;background:none;border:none;font-family:inherit}
/* mobil görgetés-simítás + vízszintes overflow védelem */
html{overflow-x:hidden}
@media(max-width:780px){
  .hero{min-height:74vh}
  .hero .bg{animation:none;transform:none}
}
/* chat: Powered by Apex Web */
.chat .pby{display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 10px;border-top:1px solid var(--line);background:#fff;font-size:.74rem;color:var(--sub);text-decoration:none}
.chat .pby:hover{color:var(--teal);background:#f3f7f6}
.chat .pby img{width:17px;height:17px;border-radius:4px;object-fit:cover}
.chat .pby b{color:var(--ink);font-weight:800}
/* FAB figyelemfelkeltő buborék + lüktetés */
.fab{animation:fabpulse 2.8s ease-in-out infinite}
@keyframes fabpulse{0%,100%{box-shadow:0 10px 28px rgba(11,93,87,.45)}50%{box-shadow:0 10px 28px rgba(11,93,87,.45),0 0 0 12px rgba(11,93,87,.10)}}
.fabhint{position:fixed;right:92px;bottom:32px;z-index:74;background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:14px;border-bottom-right-radius:4px;padding:11px 14px;font-size:.87rem;font-weight:600;max-width:215px;cursor:pointer;animation:popIn .4s var(--ease);transition:bottom .25s var(--ease)}
body.has-cookie .fabhint{bottom:132px}
@media(max-width:520px){body.has-cookie .fabhint{bottom:192px}}
.fabhint .fx{position:absolute;top:-9px;right:-9px;background:var(--ink);color:#fff;border-radius:50%;width:21px;height:21px;font-size:.85rem;line-height:1;display:grid;place-items:center;border:none;cursor:pointer}
@keyframes popIn{from{opacity:0;transform:translateY(10px) scale(.9)}to{opacity:1;transform:none}}
@media(max-width:560px){.fabhint{right:88px;max-width:170px;font-size:.8rem}}
/* ===== keyframes ===== */
@keyframes kenburns{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.12) translate(-2%,-1%)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pop{0%{opacity:0;transform:scale(.94)}100%{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(192,144,47,.6)}50%{box-shadow:0 0 0 6px rgba(192,144,47,0)}}
@keyframes bl{0%,60%,100%{opacity:.3}30%{opacity:1}}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}

/* a11y: látható billentyűzet-fókusz + .pm gomb-reset (akadálymentesség) */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--teal,#0b5d57);outline-offset:2px;border-radius:6px}
button.pm{font-family:inherit;width:100%}
