 /* ================= RESET ================= */


 body {
   margin: 0;
   padding: 0;
   font-family: 'Inter', sans-serif;

   overflow-x: hidden;
   background-color: #f2eae6;



 }

 #whiteback {
   background-color: white;
 }

 .irodai-masszázs-office-massage-p {
   text-align: center;
 }


 p {
   font-size: clamp(16px, 1.5vw, 18px);
   line-height: 1.6;
 }


 .irodai-masszázs-office-massage-justify {
   text-align: justify;
 }

 .irodai-masszázs-office-massage-h2 {
   text-align: center;
   color: black;
   text-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
   font-size: 36px;
 }

 /* ================= HEADER ================= */

 header {
   position: sticky;
   top: 0;
   z-index: 700;
 }

 header.scrolled nav {
   box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
 }


 nav {
   height: 64px;
   padding: 0 5%;
   display: flex;
   align-items: center;
   justify-content: space-between;
   background: white;
   position: relative;
   transition: box-shadow 0.25s ease;


   z-index: 400;
 }

 .irodai-masszázs-office-massage-logo img {
   height: 42px;
 }

 /* ================= DESKTOP NAV ================= */
 .irodai-masszázs-office-massage-nav-links {
   display: flex;
   gap: 1.5rem;
   list-style: none;
 }

 .irodai-masszázs-office-massage-nav-links a {
   display: inline-block;
   text-decoration: none;
   color: #000;
   font-size: 0.95rem;
   transition: transform 0.3s;
 }

 .irodai-masszázs-office-massage-nav-links a:hover {
   transform: scale(1.07);
 }

 /* ================= HAMBURGER ================= */
 .irodai-masszázs-office-massage-hamburger {
   display: none;
   width: 30px;
   height: 22px;
   background: none;
   border: none;
   cursor: pointer;
   position: relative;
   /* NEM fixed */
   z-index: 600;
 }



 .irodai-masszázs-office-massage-hamburger span {
   position: absolute;
   left: 0;
   width: 100%;
   height: 2px;
   background: black;
   transition: transform .3s ease, opacity .2s ease;

 }

 .irodai-masszázs-office-massage-hamburger span:nth-child(1) {
   top: 0;
 }

 .irodai-masszázs-office-massage-hamburger span:nth-child(2) {
   top: 10px;
 }

 .irodai-masszázs-office-massage-hamburger span:nth-child(3) {
   top: 20px;
 }

 .irodai-masszázs-office-massage-hamburger.active span:nth-child(1) {
   transform: translateY(10px) rotate(45deg);
 }

 .irodai-masszázs-office-massage-hamburger.active span:nth-child(2) {
   opacity: 0;
 }

 .irodai-masszázs-office-massage-hamburger.active span:nth-child(3) {
   transform: translateY(-10px) rotate(-45deg);
 }

 #office-massage-icons {

   width: 100%;
   max-width: 100%;
   margin: 2rem 0 2rem 0;

   background-color: white;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
 }

 #office-massage-about-myself {
   scroll-margin-top: 2rem;
 }

 #office-massage-video,
 #office-massage-event,
 #office-massage-icons,
 #office-massage-form {
   scroll-margin-top: 5rem;
 }

 #office-massage-form {
   background-color: white;
 }

 #office-massage-icons {
   background-color: white;
 }

 /* ================= OVERLAY ================= */
 .overlay {
   position: fixed;
   inset: 0;
   background: rgba(0, 0, 0, .45);
   backdrop-filter: blur(4px);
   opacity: 0;
   pointer-events: none;
   transition: opacity .3s ease;
   z-index: 150;
   /* növeltem, hogy a hamburger fölé kerüljön */
 }

 .overlay.active {
   opacity: 1;
   pointer-events: all;
 }

 /* ================= MOBILE MENU ================= */
 .irodai-masszázs-office-massage-mobile-menu {
   position: fixed;
   top: 64px;
   right: 0;
   width: 60%;
   height: calc(100dvh - 64px);
   background: white;
   transform: translateX(100%);
   transition: transform .35s ease;
   padding: 40px 30px;
   z-index: 550;
 }

 .irodai-masszázs-office-massage-mobile-menu.active {
   transform: translateX(0);
 }

 .irodai-masszázs-office-massage-hamburger.active span {
   background: #000;
   /* vagy fehér, ha sötét hátteret akarsz */
 }


 .irodai-masszázs-office-massage-mobile-menu ul {
   list-style: none;
   padding: 0;
   margin: 0;
 }

 .irodai-masszázs-office-massage-mobile-menu li {
   margin-bottom: 24px;
 }

 .irodai-masszázs-office-massage-mobile-menu a {
   text-decoration: none;
   color: #000;
   font-size: 1.3rem;
 }

 /* ================= RESPONSIVE ================= */
 @media (max-width: 850px) {
   .irodai-masszázs-office-massage-nav-links {
     display: none;
   }

   .irodai-masszázs-office-massage-hamburger {
     display: block;
   }
 }

 @media (min-width: 851px) {

   .irodai-masszázs-office-massage-mobile-menu,
   .overlay {
     display: none;
   }
 }

 /*MAIN*/

 .hero-centered {
   padding-top: 120px;
   position: relative;
   width: 100%;
   height: 90dvh;
   background-image: url('assets/office_massage_irodai_massage_hero_centered.png');
   background-size: cover;
   background-position: center;
   background-repeat: no-repeat;
   display: flex;
   justify-content: center;
   /* vízszintesen középre */
   align-items: center;
   /* függőlegesen középre */
   text-align: center;
   overflow: hidden;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);

 }

 /* finom overlay – nem túl sötét */
 .hero-centered::before {
   content: "";
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: linear-gradient(rgba(0, 0, 0, 0.35),
       rgba(0, 0, 0, 0.35));
   z-index: 1;
 }

 .hero-centered-content {
   position: relative;
   z-index: 2;
   display: flex;
   flex-direction: column;
   /* egymás alá */
   align-items: center;
   gap: 18px;
   /* szép távolság az elemek között */
   color: white;
   text-shadow: 0 3px 8px rgba(0, 0, 0, 0.5);
 }

 .hero-centered-content h1 {
   font-size: 48px;
   margin: 0;
 }

 .hero-centered-content p {
   font-size: 20px;
   margin: 0;
 }

 /* mobil optimalizáció */
 /* mobil optimalizáció */
 @media (max-width: 768px) {
   .hero-centered {
     height: 60dvh;
     background-position: center 40%;
     /* kép tetejéből kevesebb látszik */
   }

   .hero-centered-content h1 {
     font-size: 32px;
   }

   .hero-centered-content p {
     font-size: 18px;
   }
 }

 main {
   padding: 0;
   margin: 0;

 }

 video {
   width: 100%;
   max-height: 700px;
   /* nagyobb videó */
   object-fit: cover;
   border-radius: 8px;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
 }


 .btn {
   display: inline-flex;
   padding: 14px 28px;
   background: black;
   color: white;
   border-radius: 30px;
   margin-top: 20px;
   text-decoration: none;
   transition: 0.3s;
 }

 .btn:hover {
   background: #444;
   transform: translateY(-3px);
 }

 section {
   padding: 20px 0 20px 0;

   width: 100%;
   margin: auto;

 }

 .office-massage-section {
   padding: 20px 0 20px 0;

   width: 100%;
   margin: auto;

 }

 .office-massage-container {
   width: 85%;
   margin: auto
 }


 /* teljes szelessegu hatter szinezes */


 /* teljes szelessegu hatter szinezes */


 .video-container {
   width: 100%;
   max-width: 900px;
   margin: 40px auto;
 }

 .video-container video {
   width: 100%;
   border-radius: 12px;
 }

 .icon-grid {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   /* max 3 oszlop */
   gap: 20px;
   margin-top: 40px;
   justify-items: center;
   /* ikonok középre */
   max-width: 900px;
   /* ne legyen túl széles */
   margin-left: auto;
   margin-right: auto;
 }


 .icon-box {
   text-align: center;


 }

 .icon-box img {
   width: 120px;
   margin-bottom: 5px;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
   transition: transform .3s ease;
 }

 .szineshatter {
   background-color: whitesmoke;
   width: 100%;
   margin: 0;

   padding: 0;
 }

 .icon-box img:hover {
   transform: scale(1.05);
 }

 @media (max-width: 900px) {
   .icon-grid {
     grid-template-columns: repeat(2, 1fr);
   }
 }

 @media (max-width: 500px) {
   .icon-grid {
     grid-template-columns: 1fr;
   }
 }

 /* ABOUT MYSELF START */
 .about {
   display: flex;
   gap: 20px;
   align-items: center;
 }

 .content-massage-image {
   margin-top: 1rem;
   margin: auto;
   display: block;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);

 }

 .about img {
   width: 50%;
   border-radius: 12px;
 }

 @media (max-width: 900px) {
   .about {
     flex-direction: column;
   }

   .about img {
     width: 100%;
   }
 }

 /* ABOUT MYSELF END */

 /* FOOTER START */
 footer {
   padding: 60px;
   background-color: white;
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
   gap: 40px;
   padding-left: 15%;
   padding-right: 12%;
   margin-top: 80px;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);

 }

 footer a {
   text-decoration: none;
   color: #222;
 }

 #footerlogoimg {
   height: 15rem;
   width: auto;
   margin-right: 10px;
 }

 /* FOOTER END*/


 /* ======= SOCIAL IKONS START ======= */

 .social-icons {
   display: flex;
   gap: 15px;
   margin-top: 10px;
   flex-wrap: wrap;
   /* <<< Megengedi a törést */
 }

 .social-icons img {
   width: 25px;
   height: 25px;
   transition: transform 0.3s ease;
   cursor: pointer;
 }

 .social-icons img:hover {
   transform: scale(1.18);
 }

 /* ======= SOCIAL IKONS END ======= */

 /* ======= ALJEGYZET ======= */

 .footer-bottom {
   text-align: center;
   margin-top: 30px;
   border-top: 1px solid #333;
   padding-top: 15px;
   color: #888;
 }

 .office-massage-footer-li {
   list-style-type: none;
   padding-left: 0;
 }

 .office-massage-footer-li li {
   padding-bottom: 5px;

 }

 @media (max-width: 250px) {
   .social-icons {
     flex-direction: column;
     /* <<< Egymás alá kerülnek */
     align-items: center;
     gap: 10px;
   }
 }

 @media (max-width: 768px) {
   .footer-container {
     flex-direction: column;
     text-align: center;
     align-items: center;
   }

   .footer-about p {
     max-width: 100%;
   }
 }

 @media (max-width: 600px) {
   .social-icons img {
     width: 30px;
   }
 }



 /* FROM CSS KEZDETE*/
 .premium-form {
   width: 80%;
   max-width: 600px;
   margin: auto;
   display: flex;
   flex-direction: column;
   gap: 0.5rem;
   padding: 2rem;
   border-radius: 12px;
   background: rgba(255, 255, 255, 0.0);
   /* átlátszó */
   box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
   /* modern lebegő hatás */
   backdrop-filter: blur(8px);
   transition: transform 0.2s;
   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
 }

 .premium-form:hover {
   transform: translateY(-2px);
 }

 .premium-form label {
   font-weight: 500;
   color: #1e293b;
   margin-top: 0.5rem;
   margin-bottom: 0.25rem;
   margin-left: 1rem;
 }

 .premium-form input,
 .premium-form select,
 .premium-form textarea {
   padding: 0.85rem 1rem;
   border: 1px solid #cbd5e1;
   border-radius: 8px;
   font-size: 1rem;
   width: 100%;
   box-sizing: border-box;
   outline: none;
   transition: border-color 0.2s, box-shadow 0.2s;
   background: rgba(255, 255, 255, 0.95);
   margin: auto;
 }

 .premium-form input:focus,
 .premium-form select:focus,
 .premium-form textarea:focus {
   border-color: #64748b;
   box-shadow: 0 0 0 3px rgba(100, 116, 139, 0.2);
 }

 .premium-form textarea {
   resize: vertical;
   min-height: 80px;
 }

 .checkbox-container {
   display: flex;
   align-items: center;

   text-align: left;
   justify-content: flex-start;
   margin-left: 1.5rem;
 }

 .checkbox-container input {
   width: auto;
   height: 1rem;
   margin: 0;
   cursor: pointer;
 }

 .premium-button {
   padding: 0.9rem 2rem;
   border: none;
   border-radius: 8px;
   background: #1e293b;
   color: white;
   font-size: 1rem;
   font-weight: 600;
   cursor: pointer;
   box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
   transition: all 0.2s;
 }

 .premium-button:hover {
   background: #0f172a;
   transform: translateY(-2px);
   box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
 }

 /* Reszponzív */
 @media (max-width: 600px) {
   .premium-form {
     padding: 1.5rem;
   }
 }

 /* FROM CSS VEGE*/

 /* animalt ajanletkero gomb*/
 .cta-button {
   display: inline-flex;
   align-items: center;
   justify-content: center;

   /* reszponzív méretezés */
   padding: clamp(12px, 8vw, 18px) clamp(36px, 15vw, 80px);
   font-size: clamp(20px, 4vw, 30px);
   font-weight: 600;
   letter-spacing: 0.4px;

   text-decoration: none;
   color: #ffffff;

   background: black;
   border-radius: 999px;

   box-shadow: 0 10px 25px rgba(253, 255, 254, 0.35);
   position: relative;
   overflow: hidden;

   transition:
     transform 0.3s ease,
     box-shadow 0.3s ease;

   -webkit-tap-highlight-color: transparent;
 }

 /* folyamatos, lágy shine */
 .cta-button::before {
   content: "";
   position: absolute;
   top: 0;
   left: -60%;
   width: 40%;
   height: 100%;
   background: rgba(248, 248, 248, 0.25);
   transform: skewX(-20deg);
   animation: shineLoop 3.8s ease-in-out infinite;
   pointer-events: none;
 }

 .cta-button:focus-visible {
   outline: 3px solid rgba(245, 245, 245, 0.9);
   outline-offset: 4px;
 }


 /* hover lift – csak ahol van kurzor */
 @media (hover: hover) {
   .cta-button:hover {
     transform: translateY(-3px);
     box-shadow: 0 16px 35px rgba(177, 178, 178, 0.45);
   }
 }

 /* aktív állapot (mobil tap) */
 .cta-button:active {
   transform: scale(0.98);
   box-shadow: 0 8px 20px rgba(216, 222, 221, 0.4);
 }

 @keyframes shineLoop {
   0% {
     left: -60%;
     opacity: 0;
   }

   20% {
     opacity: 1;
   }

   50% {
     left: 120%;
     opacity: 0;
   }

   100% {
     left: 120%;
     opacity: 0;
   }
 }

 /* animalt ajanletkero gomb*/