/* =========================================================
   REVUCZKY SZERVIZ — fő stíluslap
   Betűk: assets/css/fonts.css  |  Ikonok: assets/css/fontawesome.min.css
   ========================================================= */
:root{
  --red:#E22B16;
  --red-dark:#b81f0e;
  --red-light:rgba(226,43,22,.1);
  --ink:#14161a;
  --ink2:#1f232b;
  --paper:#ffffff;
  --smoke:#f3f4f6;
  --smoke2:#e9ebef;
  --body:#5b6470;
  --hazard:#F5C518;
  --line:#e4e7ec;
  --disp:'Oswald',sans-serif;
  --body-font:'Inter',sans-serif;
  --tr:.3s ease;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body-font);color:var(--body);font-size:16px;line-height:1.7;background:var(--paper);overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--red)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.05;margin:0 0 .5em;color:var(--ink);text-transform:uppercase;letter-spacing:.5px}
p{margin:0 0 1em}p:last-child{margin-bottom:0}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
section{position:relative}
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important;scroll-behavior:auto !important}}

/* ---- HAZARD CSÍK ---- */
.hazard-strip{height:14px;width:100%;background:repeating-linear-gradient(-45deg,var(--hazard) 0,var(--hazard) 22px,var(--ink) 22px,var(--ink) 44px)}
.hazard-strip.thin{height:8px}

/* ---- PRELOADER ---- */
#preloader{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:rgba(20,22,26,.55);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);transition:backdrop-filter .8s ease,background .8s ease,opacity .6s ease,visibility .6s ease}
.pl-logo{position:relative;width:min(320px,68vw);opacity:0;transform:scale(1.08);filter:blur(8px);animation:plIn 1.05s cubic-bezier(.2,.7,.2,1) forwards}
.pl-logo img{width:100%}
@keyframes plIn{0%{opacity:0;transform:scale(1.08);filter:blur(8px)}60%{opacity:1;transform:scale(1);filter:blur(0)}100%{opacity:1;transform:scale(1);filter:blur(0)}}
.pl-glow{position:absolute;inset:-40px;z-index:-1;background:radial-gradient(circle,rgba(226,43,22,.35) 0%,transparent 65%);border-radius:50%;animation:plPulse 1.6s ease-in-out infinite}
@keyframes plPulse{0%,100%{opacity:.4;transform:scale(.92)}50%{opacity:.9;transform:scale(1.04)}}
.pl-logo .glitch-layer{position:absolute;top:0;left:0;width:100%;height:100%;background-size:contain;background-repeat:no-repeat;background-position:center;opacity:0;mix-blend-mode:screen;pointer-events:none}
#preloader.glitching .pl-glow{animation:none;opacity:0;transition:opacity .2s}
#preloader.glitching .pl-logo>img{animation:glMain .55s steps(2) forwards}
#preloader.glitching .glitch-layer.r{opacity:.8;animation:glR .55s steps(2) forwards}
#preloader.glitching .glitch-layer.c{opacity:.8;animation:glC .55s steps(2) forwards}
@keyframes glMain{0%{clip-path:inset(0 0 0 0);transform:translate(0)}15%{clip-path:inset(10% 0 80% 0);transform:translate(-12px,0)}30%{clip-path:inset(70% 0 5% 0);transform:translate(10px,0)}45%{clip-path:inset(35% 0 45% 0);transform:translate(-18px,0)}60%{clip-path:inset(85% 0 2% 0);transform:translate(14px,0)}75%{clip-path:inset(20% 0 65% 0);transform:translate(-8px,0);opacity:.6}100%{clip-path:inset(0 0 100% 0);transform:translate(0);opacity:0}}
@keyframes glR{0%{transform:translate(0)}20%{transform:translate(-14px,2px)}40%{transform:translate(12px,-3px)}60%{transform:translate(-20px,1px)}100%{transform:translate(-30px,0);opacity:0}}
@keyframes glC{0%{transform:translate(0)}20%{transform:translate(14px,-2px)}40%{transform:translate(-12px,3px)}60%{transform:translate(20px,-1px)}100%{transform:translate(30px,0);opacity:0}}
#preloader.glitching::after{content:'';position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(226,43,22,.08) 0px,rgba(226,43,22,.08) 2px,transparent 2px,transparent 5px);animation:scan .55s linear forwards}
@keyframes scan{0%{opacity:.9;transform:translateY(0)}100%{opacity:0;transform:translateY(40px)}}
#preloader.done{background:rgba(20,22,26,0);backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);opacity:0;visibility:hidden;pointer-events:none}

/* ---- SCROLL TOP ---- */
#scrollTop{position:fixed;bottom:28px;right:24px;z-index:9000;width:46px;height:46px;border:none;background:var(--red);color:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(16px);transition:all var(--tr);box-shadow:0 6px 20px rgba(226,43,22,.4);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
#scrollTop.show{opacity:1;visibility:visible;transform:none}
#scrollTop:hover{background:var(--red-dark)}

/* ---- HEADER ---- */
.hdr-top{background:var(--ink);padding:9px 0}
.hdr-top .inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.hdr-tagline{font-size:12px;color:rgba(255,255,255,.45);font-family:var(--disp);letter-spacing:1.5px;text-transform:uppercase}
.hdr-phone{display:flex;align-items:center;gap:8px;color:var(--hazard);font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1px}
.hdr-phone:hover{color:#fff}
.hdr-info{background:var(--ink2);padding:15px 0}
.hdr-info .inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap}
/* logó + REVUCZKY felirat */
.brand-lockup{display:flex;align-items:center;gap:14px}
.brand-lockup img{height:54px}
.brand-name{font-family:var(--disp);font-weight:700;font-size:30px;letter-spacing:2px;color:#fff;text-transform:uppercase;line-height:1}
.hdr-contacts{display:flex;gap:28px;flex-wrap:wrap;margin-left:auto}
.hdr-contact-item{display:flex;align-items:center;gap:12px}
.hdr-ci-icon{width:42px;height:42px;flex-shrink:0;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px)}
.hdr-ci-label{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1.5px;font-family:var(--disp)}
.hdr-ci-val{font-size:14px;color:#fff;font-weight:600;font-family:var(--disp);letter-spacing:.5px}
.hdr-ci-val a{color:#fff}.hdr-ci-val a:hover{color:var(--hazard)}

.hdr-nav{background:var(--paper);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--line);transition:box-shadow var(--tr),padding var(--tr)}
.hdr-nav.stuck{box-shadow:0 4px 24px rgba(0,0,0,.1)}
.hdr-nav .inner{display:flex;align-items:center;justify-content:space-between}
.hdr-nav-logo{display:none;align-items:center;gap:10px}
.hdr-nav-logo img{height:38px}
.hdr-nav-logo .brand-name{color:var(--ink);font-size:22px}
.hdr-nav.stuck .hdr-nav-logo{display:flex}
.main-nav ul{display:flex}
.main-nav ul li a{display:block;padding:20px 20px;color:var(--ink);font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1px;text-transform:uppercase;position:relative}
.main-nav ul li a::after{content:'';position:absolute;bottom:0;left:20px;right:20px;height:3px;background:var(--red);transform:scaleX(0);transition:transform .25s}
.main-nav ul li a:hover{color:var(--red)}
.main-nav ul li a:hover::after{transform:scaleX(1)}
.nav-btn{background:var(--red);color:#fff !important;padding:13px 26px !important;margin-left:12px;font-family:var(--disp) !important;font-size:14px !important;font-weight:600 !important;letter-spacing:1.5px !important;text-transform:uppercase !important;clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px);transition:background var(--tr)}
.nav-btn::after{display:none !important}
.nav-btn:hover{background:var(--red-dark) !important;color:#fff !important}
.hamburger{display:none;background:none;border:none;color:var(--ink);font-size:24px;cursor:pointer;padding:8px}
.hamburger:hover{color:var(--red)}
.nav-actions{display:flex;align-items:center}

/* mobil menü panel */
.mob-overlay{display:none;position:fixed;inset:0;z-index:5000;background:rgba(0,0,0,.6);opacity:0;transition:opacity .3s}
.mob-overlay.open{display:block;opacity:1}
.mob-panel{position:fixed;top:0;left:-340px;bottom:0;width:320px;max-width:85vw;background:var(--ink);z-index:5001;transition:left .35s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.mob-panel.open{left:0}
.mob-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.1)}
.mob-head .brand-lockup img{height:42px}
.mob-head .brand-name{color:#fff;font-size:22px}
.mob-close{background:none;border:none;color:#fff;font-size:20px;cursor:pointer}
.mob-close:hover{color:var(--red)}
.mob-nav ul li a{display:flex;align-items:center;gap:12px;padding:16px 24px;color:rgba(255,255,255,.75);font-family:var(--disp);font-size:15px;font-weight:500;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgba(255,255,255,.07);transition:all var(--tr)}
.mob-nav ul li a i{color:var(--red);width:18px}
.mob-nav ul li a:hover{color:#fff;padding-left:32px;background:rgba(226,43,22,.1)}
.mob-cta{display:block;margin:24px;background:var(--red);color:#fff;text-align:center;padding:14px;font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}
.mob-cta:hover{background:var(--red-dark);color:#fff !important}

/* ---- SZEKCIÓ CÍM ---- */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--disp);font-size:14px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.eyebrow::before{content:'';width:34px;height:3px;background:var(--red)}
.eyebrow.center{justify-content:center}
.h-title{font-family:var(--disp);font-size:clamp(30px,4.5vw,52px);font-weight:700;line-height:1.02;color:var(--ink);text-transform:uppercase}
.h-title span{color:var(--red)}

/* ---- REVEAL ---- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ---- HERO ---- */
.hero{background:var(--ink);position:relative;overflow:hidden;color:#fff}
.hero-grid-bg{position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:54px 54px}
.hero-track{position:absolute;left:0;right:0;bottom:0;height:90px;z-index:1;opacity:.5;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.07) 0,rgba(255,255,255,.07) 26px,transparent 26px,transparent 52px);mask-image:linear-gradient(to top,#000,transparent);-webkit-mask-image:linear-gradient(to top,#000,transparent)}
.hero-glow{position:absolute;right:-150px;top:40%;transform:translateY(-50%);width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(226,43,22,.22) 0%,transparent 65%);z-index:0;pointer-events:none}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:70px 0 110px;min-height:calc(100vh - 200px)}
.hero-hazard{display:inline-flex;align-items:stretch;margin-bottom:26px;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}
.hero-hazard .hz-bars{width:18px;background:repeating-linear-gradient(-45deg,var(--hazard) 0,var(--hazard) 7px,var(--ink) 7px,var(--ink) 14px)}
.hero-hazard .hz-txt{background:var(--hazard);color:var(--ink);font-family:var(--disp);font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;padding:8px 18px;display:flex;align-items:center;gap:8px}
.hero h1{font-family:var(--disp);font-size:clamp(44px,7vw,86px);font-weight:700;line-height:.95;color:#fff;margin-bottom:22px;text-transform:uppercase}
.hero h1 span{color:var(--red)}
.hero h1 .outline{color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.5)}
.hero-sub{font-size:16px;color:rgba(255,255,255,.55);line-height:1.75;max-width:480px;margin-bottom:34px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-red{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:16px 32px;font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;clip-path:polygon(11px 0,100% 0,100% calc(100% - 11px),calc(100% - 11px) 100%,0 100%,0 11px);transition:background var(--tr),transform var(--tr)}
.btn-red:hover{background:var(--red-dark);color:#fff !important;transform:translateY(-3px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;border:2px solid rgba(255,255,255,.25);color:#fff;padding:14px 28px;font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:all var(--tr)}
.btn-ghost:hover{border-color:var(--hazard);color:var(--hazard)}
.hero-stats{display:flex;gap:36px;margin-top:46px;flex-wrap:wrap}
.hero-stat .num{font-family:var(--disp);font-size:42px;font-weight:700;color:#fff;line-height:1}
.hero-stat .num span{color:var(--red)}
.hero-stat .lbl{font-size:11px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px;font-family:var(--disp)}
.hero-visual{position:relative}
.hero-frame{position:relative;clip-path:polygon(28px 0,100% 0,100% calc(100% - 28px),calc(100% - 28px) 100%,0 100%,0 28px);overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.5)}
.hero-frame img{width:100%;height:520px;object-fit:cover}
.hero-frame::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 40%,rgba(226,43,22,.25))}
.hero-corner{position:absolute;width:46px;height:46px;border:3px solid var(--hazard);z-index:3}
.hero-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.hero-corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.hero-badge{position:absolute;z-index:4;background:rgba(20,22,26,.9);backdrop-filter:blur(8px);border-left:3px solid var(--red);padding:14px 18px;display:flex;align-items:center;gap:13px;animation:floatY 4s ease-in-out infinite}
.hero-badge.b1{bottom:30px;left:-22px}
.hero-badge.b2{top:30px;right:-18px;animation-delay:1.5s}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hb-ic{width:40px;height:40px;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;font-size:17px;flex-shrink:0}
.hb-num{font-family:var(--disp);font-size:22px;font-weight:700;color:#fff;line-height:1}
.hb-lbl{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px}
.brands{background:var(--ink2);border-top:1px solid rgba(255,255,255,.06);padding:20px 0;position:relative;z-index:2;overflow:hidden}
.brands-track{display:flex;gap:56px;align-items:center;width:max-content;animation:marquee 22s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.brand-item{font-family:var(--disp);font-size:18px;font-weight:600;color:rgba(255,255,255,.28);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:color var(--tr)}
.brand-item:hover{color:var(--hazard)}

/* ---- ÁLTALÁNOS SZEKCIÓ ---- */
.sec{padding:100px 0}
.sec-head{margin-bottom:60px}
.sec-head.center{text-align:center}

/* ---- SZOLGÁLTATÁS KÁRTYÁK ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{position:relative;background:var(--paper);border:1px solid var(--line);padding:36px 30px;overflow:hidden;transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 24px 50px rgba(0,0,0,.1);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-num{position:absolute;top:18px;right:22px;font-family:var(--disp);font-size:54px;font-weight:700;color:var(--smoke2);line-height:1;z-index:0;transition:color var(--tr)}
.svc-card:hover .svc-num{color:var(--red-light)}
.svc-ic{width:64px;height:64px;background:var(--ink);display:flex;align-items:center;justify-content:center;color:var(--hazard);font-size:28px;margin-bottom:22px;position:relative;z-index:1;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);transition:background var(--tr)}
.svc-card:hover .svc-ic{background:var(--red);color:#fff}
.svc-card h3{font-size:21px;margin-bottom:12px;position:relative;z-index:1}
.svc-card p{font-size:14.5px;line-height:1.7;position:relative;z-index:1}

/* ---- ABOUT ---- */
.sec-about{background:var(--smoke);position:relative;overflow:hidden}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.about-imgs{position:relative}
.about-main{clip-path:polygon(26px 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%,0 26px);overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.15)}
.about-main img{width:100%;height:440px;object-fit:cover}
.about-sec{position:absolute;bottom:-28px;right:-20px;width:200px;border:5px solid var(--paper);clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);overflow:hidden;box-shadow:0 16px 36px rgba(0,0,0,.2)}
.about-sec img{width:100%;height:150px;object-fit:cover}
.about-exp{position:absolute;top:24px;left:-22px;background:var(--red);padding:18px 24px;z-index:3;text-align:center;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}
.about-exp .num{font-family:var(--disp);font-size:44px;font-weight:700;color:#fff;line-height:1}
.about-exp .lbl{font-size:11px;color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:1.5px}
.about-dots{position:absolute;bottom:-12px;left:-30px;width:120px;height:120px;z-index:0;background-image:radial-gradient(circle,rgba(226,43,22,.3) 1.5px,transparent 1.5px);background-size:13px 13px}
.about-tabs{display:flex;gap:6px;margin:26px 0 22px;flex-wrap:wrap}
.atab{padding:10px 22px;border:1px solid var(--line);background:var(--paper);color:var(--body);font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all var(--tr)}
.atab.active,.atab:hover{background:var(--red);border-color:var(--red);color:#fff}
.tab-c{display:none}.tab-c.active{display:block}
.about-txt{font-size:15px;line-height:1.8;margin-bottom:20px}
.about-checks{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:28px}
.about-check{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink);font-weight:500}
.about-check i{color:var(--red);margin-top:4px}

/* ---- FOLYAMAT ---- */
.sec-process{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.sec-process .h-title{color:#fff}
.proc-bgtxt{position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);font-family:var(--disp);font-size:clamp(90px,16vw,200px);font-weight:700;color:rgba(255,255,255,.025);white-space:nowrap;pointer-events:none;letter-spacing:6px}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.proc-grid::before{content:'';position:absolute;top:60px;left:12.5%;right:12.5%;height:2px;background:repeating-linear-gradient(90deg,var(--red) 0,var(--red) 12px,transparent 12px,transparent 22px);z-index:0}
.proc-card{text-align:center;padding:0 22px;position:relative;z-index:1}
.proc-img{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 20px;border:3px solid rgba(226,43,22,.4);position:relative;transition:border-color var(--tr)}
.proc-img img{width:100%;height:100%;object-fit:cover}
.proc-card:hover .proc-img{border-color:var(--red)}
.proc-num{display:inline-block;font-family:var(--disp);font-size:13px;font-weight:700;color:#fff;background:var(--red);padding:3px 14px;margin-bottom:14px;letter-spacing:1px}
.proc-card h3{font-size:19px;color:#fff;margin-bottom:10px}
.proc-card p{font-size:13.5px;color:rgba(255,255,255,.5);line-height:1.7}

/* ---- WHY ---- */
.sec-why{background:var(--paper);position:relative;overflow:hidden}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.why-feats{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.why-feat{padding:26px 22px;border:1px solid var(--line);position:relative;overflow:hidden;transition:all var(--tr)}
.why-feat::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transition:transform .3s}
.why-feat:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(0,0,0,.09);border-color:transparent}
.why-feat:hover::before{transform:scaleX(1)}
.wf-ic{width:56px;height:56px;background:var(--red-light);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:24px;margin-bottom:16px;transition:all var(--tr)}
.why-feat:hover .wf-ic{background:var(--red);color:#fff}
.why-feat h3{font-size:17px;margin-bottom:8px}
.why-feat p{font-size:13.5px;line-height:1.6}
.why-img{position:relative}
.why-img-main{clip-path:polygon(26px 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%,0 26px);overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.13)}
.why-img-main img{width:100%;height:500px;object-fit:cover}
.why-pill{position:absolute;top:28px;left:-22px;z-index:3;background:var(--ink);padding:14px 22px;display:flex;align-items:center;gap:14px;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}
.wp-c{width:46px;height:46px;background:var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:20px;font-weight:700;color:#fff;flex-shrink:0}
.wp-t1{font-family:var(--disp);font-size:17px;font-weight:600;color:#fff;text-transform:uppercase}
.wp-t2{font-size:11px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1px}
.why-dots{position:absolute;top:-18px;right:-18px;width:110px;height:110px;background-image:radial-gradient(circle,rgba(226,43,22,.35) 1.5px,transparent 1.5px);background-size:13px 13px;z-index:0}

/* ---- CTA ---- */
.sec-cta{background:var(--red);position:relative;overflow:hidden}
.cta-hazard-l{position:absolute;left:0;top:0;bottom:0;width:16px;background:repeating-linear-gradient(-45deg,var(--hazard) 0,var(--hazard) 10px,var(--ink) 10px,var(--ink) 20px);opacity:.9}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:1;padding:70px 0}
.cta-l h2{color:#fff;margin-bottom:10px;font-size:clamp(28px,4vw,44px)}
.cta-l p{color:rgba(255,255,255,.85);max-width:460px;margin:0}
.cta-phone{display:flex;align-items:center;gap:14px;background:rgba(0,0,0,.18);padding:14px 24px;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}
.cp-ic{width:46px;height:46px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--red);font-size:18px;flex-shrink:0}
.cp-lbl{font-size:11px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:1px}
.cp-num{font-family:var(--disp);font-size:20px;font-weight:700;color:#fff}
.cp-num a{color:#fff}.cp-num a:hover{color:var(--ink)}
.btn-dark{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:16px 30px;font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;clip-path:polygon(11px 0,100% 0,100% calc(100% - 11px),calc(100% - 11px) 100%,0 100%,0 11px);transition:background var(--tr),transform var(--tr)}
.btn-dark:hover{background:#000;color:var(--hazard) !important;transform:translateY(-3px)}

/* ---- KAPCSOLAT ---- */
.sec-contact{background:var(--smoke)}
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:54px;align-items:start}
.cform{background:var(--paper);padding:46px 40px;border-top:4px solid var(--red);box-shadow:0 10px 40px rgba(0,0,0,.07)}
.cform-title{font-family:var(--disp);font-size:26px;font-weight:700;color:var(--ink);margin-bottom:26px;text-transform:uppercase;letter-spacing:1px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fgrp{position:relative;margin-bottom:16px}
.fgrp i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#b6bcc6;font-size:14px;pointer-events:none}
.fgrp.ta i{top:18px;transform:none}
.fgrp input,.fgrp select,.fgrp textarea{width:100%;padding:14px 14px 14px 44px;border:1.5px solid var(--line);font-family:var(--body-font);font-size:14px;color:var(--ink);background:var(--paper);outline:none;appearance:none;transition:border-color var(--tr)}
.fgrp input:focus,.fgrp select:focus,.fgrp textarea:focus{border-color:var(--red)}
.fgrp textarea{resize:vertical;min-height:120px}
.chk{display:flex;align-items:flex-start;gap:10px;font-size:13px;margin-bottom:22px}
.chk input{margin-top:3px;accent-color:var(--red);flex-shrink:0}
.chk a{color:var(--red);text-decoration:underline}
.btn-submit{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;border:none;padding:16px 34px;font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;clip-path:polygon(11px 0,100% 0,100% calc(100% - 11px),calc(100% - 11px) 100%,0 100%,0 11px);transition:background var(--tr),transform var(--tr)}
.btn-submit:hover{background:var(--red-dark);transform:translateY(-3px)}
.ci-cards{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.ci-card{display:flex;align-items:center;gap:16px;background:var(--paper);padding:18px;border-left:3px solid var(--red);box-shadow:0 2px 14px rgba(0,0,0,.05);transition:transform var(--tr)}
.ci-card:hover{transform:translateX(5px)}
.ci-ic{width:46px;height:46px;background:var(--red-light);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:18px;flex-shrink:0;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.ci-lbl{font-size:10px;color:var(--body);text-transform:uppercase;letter-spacing:1.5px;font-family:var(--disp)}
.ci-val{font-family:var(--disp);font-size:16px;font-weight:600;color:var(--ink)}
.ci-val a{color:var(--ink)}.ci-val a:hover{color:var(--red)}

/* ---- FOOTER ---- */
.footer{background:var(--ink);color:#fff;padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:70px;padding-bottom:54px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-logo img{height:60px}
.footer-logo .brand-name{color:#fff;font-size:28px}
.footer-about{font-size:14px;color:rgba(255,255,255,.4);line-height:1.8;max-width:380px;margin-bottom:24px}
.footer-phone{display:inline-flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);padding:11px 22px;margin-bottom:22px;clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.fp-ic{width:38px;height:38px;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.fp-lbl{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1px}
.fp-num{font-family:var(--disp);font-size:17px;font-weight:600;color:#fff}
.fp-num a{color:#fff}.fp-num a:hover{color:var(--hazard)}
.footer-social{display:flex;gap:10px}
.footer-social a{width:40px;height:40px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);transition:all var(--tr)}
.footer-social a:hover{background:var(--red);border-color:var(--red);color:#fff !important}
.footer-col h4{font-family:var(--disp);font-size:16px;font-weight:600;color:#fff;letter-spacing:1.5px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--red);display:inline-block}
.footer-info-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:14px;color:rgba(255,255,255,.45)}
.footer-info-item i{color:var(--red);margin-top:4px;width:15px}
.footer-info-item a{color:rgba(255,255,255,.45)}.footer-info-item a:hover{color:var(--hazard)}
.footer-btn{display:inline-block;margin-top:20px;border:2px solid rgba(226,43,22,.5);color:#fff;padding:11px 26px;font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:all var(--tr)}
.footer-btn:hover{background:var(--red);border-color:var(--red);color:#fff !important}
.footer-copy{background:rgba(0,0,0,.3);padding:18px 0}
.footer-copy .inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy p{font-size:13px;color:rgba(255,255,255,.3);margin:0}
.footer-copy a{color:rgba(255,255,255,.45)}.footer-copy a:hover{color:var(--hazard)}
.footer-links{display:flex;gap:18px}

/* ---- SWIPE JELZÉS (görgess + nyíl) — alapból rejtve ---- */
.swipe-hint{display:none;align-items:center;justify-content:center;gap:10px;margin-top:22px;font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--body);opacity:.65}
.swipe-hint .sh-arrow{display:inline-flex;color:var(--red);font-size:15px;animation:swipeArrow 1.3s ease-in-out infinite}
@keyframes swipeArrow{0%,100%{transform:translateX(0)}50%{transform:translateX(8px)}}
.sec-process .swipe-hint{color:rgba(255,255,255,.6)}

/* =========================================================
   RESPONSZÍV — TABLET és MOBIL (max 991px)
   ========================================================= */
@media(max-width:991px){
  /* header: kontaktok + asztali menü rejtése, hamburger be */
  .hdr-contacts,.main-nav{display:none}
  .hamburger{display:block}
  .hdr-tagline{display:none}

  /* hamburger BAL oldalra: a sticky nav sávban a sorrend ☰ → logó+név → HÍVJ */
  .hdr-nav .inner{justify-content:flex-start;gap:14px}
  .hamburger{order:1;margin-right:2px}
  .hdr-nav-logo{order:2;display:flex !important;margin-right:auto}
  .nav-actions{order:3}
  .nav-actions .nav-btn{margin-left:0}

  /* a felső info sávban a logó+REVUCZKY már látszik nagyban; itt is balra rendezzük */
  .hdr-info .inner{gap:16px}

  /* VÍZSZINTES LAPOZÓ SOROK */
  .svc-grid,
  .proc-grid,
  .why-feats{
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    gap:16px;
    padding-bottom:6px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;            /* Firefox */
    touch-action:pan-x;              /* csak vízszintes scroll, nincs fel-le rángatás */
    overscroll-behavior-x:contain;   /* scroll nem "szivárog" a szülőre */
  }
  .svc-grid::-webkit-scrollbar,
  .proc-grid::-webkit-scrollbar,
  .why-feats::-webkit-scrollbar{display:none}  /* WebKit */

  /* a folyamat összekötő vonalát rejtjük flex módban */
  .proc-grid::before{display:none}

  /* kártyák fix szélességgel, hogy "lapozható" érzet legyen */
  .svc-grid > .svc-card{flex:0 0 78%;scroll-snap-align:center}
  .why-feats > .why-feat{flex:0 0 70%;scroll-snap-align:center}
  .proc-grid > .proc-card{flex:0 0 70%;scroll-snap-align:center;padding:0 10px}

  /* a swipe jelzés megjelenik */
  .swipe-hint{display:flex}
}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:50px 0 90px;min-height:0}
  .hero-visual{display:none}
  .hero-hazard{margin-left:auto;margin-right:auto}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .why-grid{grid-template-columns:1fr;gap:50px}
  .contact-grid{grid-template-columns:1fr}

  /* "Miért engem" szöveges oszlop ne lógjon ki a viewportból */
  .why-content{min-width:0;overflow:hidden}
  .why-content .h-title{font-size:clamp(24px,7vw,40px);word-break:break-word;overflow-wrap:break-word}
  .why-content>p{max-width:100%;word-break:break-word;overflow-wrap:break-word}
}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr;gap:40px}
}

/* nagyon szűk kijelző: a sticky nav elemei ne érjenek össze */
@media(max-width:560px){
  .hdr-nav-logo .brand-name{font-size:18px;letter-spacing:1px}
  .hdr-nav-logo img{height:32px}
  .nav-actions .nav-btn{padding:11px 16px !important;font-size:12px !important;letter-spacing:1px !important}
  .hdr-info .brand-name{font-size:24px}
  .hdr-info .brand-lockup img{height:46px}
}
@media(max-width:380px){
  .nav-actions .nav-btn{padding:10px 12px !important;font-size:11px !important}
  .hdr-nav-logo .brand-name{font-size:16px}
}

@media(max-width:600px){
  .cform{padding:32px 24px}
  .frow{grid-template-columns:1fr}
  .svc-grid > .svc-card{flex-basis:85%}
  .why-feats > .why-feat{flex-basis:80%}
  .proc-grid > .proc-card{flex-basis:80%}
}

@media(max-width:540px){
  .frow{grid-template-columns:1fr}
}

@media(max-width:480px){
  .about-checks{grid-template-columns:1fr}
}
