:root{
/* colors */
--safety-orange:hsl(25,100%,50%);
--levandar-gray:hsl(230,19%,81%);
--persian-rose:hsl(328,100%,59%);
--red-crayola:hsl(341,100%,49%);
--eeria-black:hsl(240,6%,10%);
--light-gray:hsl(0,0%,80%);
--cultured-2:hsl(210,60%,98%);
--platinum:hsl(0,0%,90%);
--gray-wave:hsl(220,5%,49%);
--cultured:hsl(0,0%,93%);
--black_10:hsla(0,0%,0%,0.1);
--black_5:hsla(0,0%,0%,0.05);
--white-1:hsl(0,0%,100%);
--white-2:hsl(0,14%,98%);
--black:hsl(0,0%,0%);

/* gradient color */
--gradient:linear-gradient(to left top,var(--persian-rose),var(--safety-orange));
/* typograpy */
--ff-roboto:'Roboto',sans-serif;
--ff-league-spartan:'League Spartan',sans-serif;
--fs-1:3.5rem;
--fs-2:3rem;
--fs-3:2.1rem;
--fs-4:1.7rem;
--fs-5:1.4rem;
--fs-6:1.3rem;
--fw-700:700;
--fw-500:500;

/* spacing */
--section-padding:60px;
/* shadow */
--shadow-1:0 6px 24px var(--black_5);
--shadow-2:0 2px 28px var(--black_10);
/* border-radius */
--radius-2:2px;
--radius-5:5px;
--radius-8:8px;
--radius-16:16px;
--radius-4:4px;
/* transition */
--transition-1: 0.25s ease;
--transition-2: 0.5s ease;
--cubic-out: cubic-bezier(0.33,0.85,0.4,0.96);
}

*,
*::before,
*::after{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
   
}
li{ list-style: none;}
a{
    text-decoration: none;
    color: inherit;
}
a,img,span,time,label,input,button,textarea,i{ display: block;}
img{height: auto;}
input,button,textarea{
    background: none;
    border: none;
    font: inherit;
}
input,textarea{ width: 100%;}
button{cursor: pointer;}
i{pointer-events:none;}
address{font-style: normal;}
html{
    font-family: var(--ff-roboto);
    font-size: 10px;
    scroll-behavior: smooth;
}
body{
    background-color: var(--white-1);
    color: var(--gray-wave);
    font-size: 1.6rem;
    line-height: 1.8;
   
}
::-webkit-scrollbar{width: 10px;}
::-webkit-scrollbar-track{background-color: hsl(0,0%,98%);}
::-webkit-scrollbar-thumb{background-color: hsl(0,0%,80%);}
::-webkit-scrollbar-thumb:hover{background-color: hsl(0,0%,70%);}
:focus-visible{outline-offset: 4px;}
/* reused style */
.container{padding-inline: 15px;  overflow: hidden;}
.btn{
    font-family: var(--ff-league-spartan);
    max-width: max-content;
    color: var(--white-1);
    font-size: var(--fs-5);
    font-weight: var(--fw-700);
    padding: 10px 30px;
    border-radius:var(--radius-16) var(--radius-4);
    transition: var(--transition-1);
}
.btn-primary{
    background-image: var(--gradient);
    background-size: 1000%;
}
.btn-primary:is(:hover, :focus) {background-position: bottom right;}

.btn-secondary{
    background-color: var(--white-1);
   color: var(--eeria-black);
}
.btn-secondary:is(:hover, :focus) {
    background-color: var(--eeria-black);
    color: var(--white-1);
}
.section{
    padding-block: var(--section-padding);
}
.h1,
.h2,
.h3{
    color: var(--eeria-black);
    font-family: var(--ff-league-spartan);
    line-height: 1.2;
}
.h1{
    font-size: var(--fs-1);
}
.h2{
    font-size: var(--fs-2);
}
.h3{
    font-size: var(--fs-3);
}
.w-100{
    width: 100%;
}
.section-title,
.section-text{text-align: center;}

.section-title .span{
    display: inline-block;
    color: var(--safety-orange);
}

.section-text{font-size: var(--fs-6);}

.grid-list{
    display: grid;
    gap: 30px;
}
.grid-list1 li{
  
   margin-bottom: 3rem;
}
.img-holder{
    aspect-ratio: var(--width)/var(--height);
    background-color: var(--light-gray);
}
.img-cover{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* #header */

.header{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: var(--white-1);
    padding-block: 15px;
    border-block-end: 1px solid var(--cultured);
    z-index: 4;
    transition: var(--transition-1);
}
.header.active{filter: drop-shadow(var(--shadow-2));}
.header > .container{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.logo{
    font-family: var(--ff-league-spartan);
    color:var(--black);
    font-size: 2.5rem;
    font-weight: var(--fw-700);
    line-height: 1;
}
.logo .span1{
    display: inline-block;
    color: var(--safety-orange);
}
.nav-toggle-btn{font-size: 30px;color: var(--red-crayola);}
.nav-toggle-btn.active .open,
.nav-toggle-btn .close{display: none;}

.nav-toggle-btn .open,
.nav-toggle-btn.active .close{display: block;}

.navbar{
    background-color: var(--white-1);
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    max-width: calc(100% - 30px);
    width: 100%;
    padding-inline: 0;
    border: 1px solid var(--cultured);
    transition: 0.3s var(--cubic-out);
    min-height: 0;
    visibility: hidden;
    overflow: hidden;
}
.navbar.active{
    max-height: 350px;
    visibility: visible;
    transition-duration: 0.5s;
}
.navbar-list{
    padding: 20px 15px;
    padding-block-start: 10px;
    opacity: 0;
    transition: var(--transition-1);
}
.navbar.active .navbar-list{opacity: 1;}
.navbar-link{
    color: var(--eeria-black);
    font-family: var(--ff-league-spartan);
    font-size: var(--fs-4);
    line-height: 1.2;
    padding-block: 8px;
    transition: var(--transition-1);
}
.navbar-link:is(:hover, :focus) {color:var(--red-crayola);}
.header .btn{margin-block-start:10px;}
/* hero */
.has-bg-image{
    background-repeat: no-repeat;
    background-size: cover;
    /* background-position: center; */
    position: relative;
  
  }
  
.hero{
    padding-block: calc(var(--section-padding) + 50px);
    text-align: center;
}
.hero-content{
    margin-block-end: 30px;
}
.hero-subtitle{
    color: var(--eeria-black);
    font-size: var(--fs-5);
    font-weight: var(--fw-500);
}
.hero-title{
    margin-block: 12px 8px;
}
.hero-title .span{
    display: inline-block;
    color: var(--safety-orange);
    }
.hero-text{
    font-size: var(--fs-5);
}
.hero .btn{
    margin-inline: auto;
    margin-block-start: 20px;
}
.hero-banner{
    animation:  rotate 20s linear infinite;
  
}
@keyframes rotate {
    from{
        transform: rotate(360deg);
       
    }
    to{
        transform: rotate(0deg);
       
    }
}
/* service */

.service .service-text{margin-block: 5px 35px;}
.service-card{
    background-color:var(--white-1) ;
    padding: 20px 15px;
    border: 1px solid var(--platinum);
    border-radius: 45px var(--radius-5);
    text-align: center;
    box-shadow: var(--shadow-1);
    transition: var(--transition-2);
}
.service-card:is(:hover, :focus-within) {transform: translateY(-10px);}

.service-card .card-icon{
    color: var(--white-1);
    font-size: 25px;
    max-width: max-content;
    margin-inline: auto;
    padding: 18px;
    border-radius: 50%;
    line-height: 1;
}
.service-card .card-title{ margin-block: 20px 8px; }
.service-card .card-text{ font-size: var(--fs-6);}
/* project */
.project{ background-color: var(--white-2);}
.project .section-text{margin-block: 5px 35px;}
.project-card{
    position: relative;
    border-radius: 45px var(--radius-5);
    overflow: hidden;
}
.project-card::after{
    content: " ";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--black);
    opacity: 0.3;
    transition: var(--transition-2);
}
.project-card:is(:hover,:focus-within)::after{opacity: 0.5;}

.project-card .card-content{
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px;
    z-index: 1;
    transition: var(--transition-2);
}
.project-card:is(:hover,:focus-within) .card-content{transform: translateY(-20px);}
.project-card .card-subtitle{
    color: var(--levandar-gray);
    font-size: var(--fs-6);
    line-height: 1;
}
.project-card .card-title{
color: var(--white-1);
margin-block: 12px 15px;
}
/* about */
.about{background-color: var(--white-2);}
.about-banner{
    position: relative;
    border-radius: var(--radius-5);
    overflow: hidden;
    margin-block-end: 25px;
}
.play-btn{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    background-color: var(--white-1);
    color: var(--red-crayola);
    font-size: 32px;
    padding: 16px;
    line-height:1;
    border-radius: 50%;
    animation: pulse 1.5s ease-out infinite;
}
@keyframes pulse {
    0%{box-shadow: 0 0 0 1px var(--white-1);}
    100%{
        box-shadow: 0 0 0 25px transparent;
    }
}
.about :is(.section-title, .section-text){text-align: left;}
.about .section-title{
    margin-block-end: 5px;
}
.about .section-text:not(:last-child){margin-block-end: 18px;}
.about .h3{
    margin-block-end: 8px;
}
.about-list{
    margin-block: 15px 18px;
}
.about-item{
    display: flex;
    align-items: flex-start;
    gap: 5px;
}
.about-item i{
    color: var(--red-crayola);
    flex-shrink: 0;
    margin-block-start: 2px;
}
.about-item:not(:last-child){margin-block-end: 12px;}
/* cta */
.cta{
    position: relative;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    z-index: 1;
}
.cta::after{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: var(--gradient);
    opacity: 0.95;
    z-index: -1;
}
.cta-subtitle,
.cta .section-title{color: var(--white-1);}

.cta-subtitle{
    font-size: var(--fs-6);
    font-weight: var(--fw-500);
    text-align: center;
}
.cta .section-title{margin-block:12px 18px;}
.cta .btn{ margin-inline: auto;}

.blog .section-text{ margin-block: 5px 35px;}

.blog-card{ background-color: var(--white-2);}

.blog-card .card-banner{ overflow: hidden;}

.blog-card .card-banner img{ transition: var(--transition-2);}

.blog-card:is(:hover,:focus-within) .card-banner img{transform: scale(1.05);}

.blog-card .card-content{padding: 15px;}

.blog-card .time{
    color: var(--red-crayola);
    font-size: var(--fs-6);
    line-height: 1;
    margin-block-end: 10px;
}
.blog-card .card-title{ transition: var(--transition-1);}

.blog-card .card-title:is(:hover,:focus-within) {color: var(--red-crayola);}

/* contact */
.contact { background-image: url('image/hero-banner1.jpg');background-repeat: no-repeat;background-attachment: fixed;background-size: cover;}
.contact .section-text { margin-block:5px 35px;}

.contact-form{
    background-color: var(--white-1);
    padding: 20px;
    border-radius: var(--radius-2);
    box-shadow: var(--shadow-1);
    margin-block-end:30px;
}
.input-field{
    background-color: var(--white-2);
    color: var(--eeria-black);
    font-size: var(--fs-5);
    padding: 15px;
    border-radius: var(--radius-2);
    outline: 1px solid transparent;
    outline-offset: 0;
    margin-block-end: 15px;
}
.input-field::-webkit-inner-spin-button {display: none;}

.input-field:focus{ outline-color: var(--red-crayola);}

.input-field::placeholder {transition: var(--transition-1);}
.input-field:focus::placeholder {opacity: 0;}

textarea.input-field{
    resize: vertical;
    min-height: 80px;
    height: 100px;
    max-height: 200px;
    overscroll-behavior: contain;
}
.checkbox{
    width: max-content;
    margin-block-start: 5px;
    accent-color: var(--red-crayola);
}
.label-link{
    display: inline-block;
    color: var(--red-crayola);
}
.label-link:is(hover,:focus){text-decoration: underline;}
.checkbox-wrapper{
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-block-end: 15px;
}
.checkbox-wrapper .label {font-size: var(--fs-6);}

.contact-list{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px 25px;
}

.contact-item { min-width: 100%;}

.contact-card{
    background-color: var(--white-1);
    padding: 20px;
    border-radius: var(--radius-2);
    box-shadow: var(--shadow-1);
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.contact-card .card-icon{
    background-color: var(--cultured-2);
    color: var(--red-crayola);
    font-size: 25px;
    padding: 13px;
    border-radius: 50%;
    transition: var(--transition-1);
    line-height: 1;
}
.contact-card:is(:hover,:focus) .card-icon{
    background-color: var(--red-crayola);
    color: var(--white-1);
}
.contact-card .card-title {margin-block-end: 5px;}

.contact-card .card-title .span{
    display: inline-block;
    color: var(--safety-orange);
}

.contact-card :is(.card-link, .card-address) {
    font-size: var(--fs-6);
    transition: var(--transition-1);
}
.contact-card .card-link:is(:hover,:focus) {color: var(--red-crayola);}

/* desc */

.desc-banner{
    position: relative;
    border-radius: var(--radius-5);
    overflow: hidden;
    margin-block-end: 25px;
}

.desc :is(.section-title, .section-text){text-align: left;}
.desc .section-title{
    margin-block-end: 5px;
}
.desc .section-text:not(:last-child){margin-block-end: 18px;}
.desc .h3{
    margin-block-end: 8px;
}
.desc-list{
    margin-block: 15px 18px;
}
.desc-item{
    display: flex;
    align-items: flex-start;
    gap: 5px;
}
.desc-item i{
    color: var(--red-crayola);
    flex-shrink: 0;
    margin-block-start: 2px;
    animation: fade-in 2s  infinite;
}
@keyframes fade-in {
    0%{opacity: 1;transform: scale(1);}
    50%{opacity: 0.8;transform: scale(1.4);}
    100%{transform: scale(1);opacity: 1;}
}
.desc-item:not(:last-child){margin-block-end: 12px;}

/* review */
.review { background-image: url('image/review-bg.jpg');background-repeat: no-repeat;background-attachment: fixed;background-size: cover;}
.review .review-text{margin-block: 5px 35px;}
.review-card{
    background-color:var(--white-1) ;
    padding: 20px 15px;
    border: 1px solid var(--platinum);
    border-radius: 45px var(--radius-5);
    text-align: center;
    box-shadow: var(--shadow-1);
   
}

.review-card .card-text:is(:hover, :focus-within) {transform: scale(1.09);}


.review-card .card-title{ margin-block: 20px 8px; }
.review-card .card-text{ font-size: var(--fs-6); transition: var(--transition-2);}

/* footer */
.footer{
    background: var(--gradient);
    padding-block: 20px;
}
.copyright{
    font-size: var(--fs-6);
    text-align: center;
    color: var(--white-2);
}
.copyright-link{
    color: var(--eeria-black);
    font-weight: var(--fw-500);
    display: inline-block;
}

/* back to top */
.back-top-btn{
    position: fixed;
    bottom: 10px;
    right: 20px;
    background-color: var(--eeria-black);
    color: var(--white-1);
    padding: 12px;
    border-radius: 50%;
    box-shadow: var(--shadow-2);
    z-index: 4;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-1);
    line-height: 1;
    animation: pulse1 1.5s ease-out infinite;
}
@keyframes pulse1 {
    0%{box-shadow: 0 0 0 1px var(--eeria-black);}
    100%{
        box-shadow: 0 0 0 25px transparent;
    }
}
.back-top-btn.active{
    opacity: 1;
    visibility: visible;
    transform: translateY(-10px);
}

.back-top-btn:is(:hover,:focus) {opacity: 0.9;}

/* document */

.document .document-text{margin-block: 5px 35px;}
.document-card{
    background-color:var(--white-1) ;
    padding: 20px 15px;
    border: 1px solid var(--platinum);
    border-radius: 45px var(--radius-5);
    box-shadow: var(--shadow-1);
    transition: var(--transition-2);
}
.document-card:is(:hover, :focus-within) {transform: translateY(-10px);}

.document-card .h3{color: var(--red-crayola);}
.document-card .card-title{ margin-block: 20px 8px; }
.document-card .card-text{ font-size: var(--fs-6);}

/* responsive  for larger 575px screen*/
@media(min-width:575px)
{
    /* reuse style */
    .container{
        max-width: 540px;
        width: 100%;
        margin-inline: auto;
    }
    .grid-list{
        grid-template-columns: 1fr 1fr;
        column-gap: 25px;
    }
    /* blog */
    .blog .grid-list{
        grid-template-columns: 1fr;
    }
    .blog-card.grid{
        display: grid;
        grid-template-columns: 0.47fr 1fr;
        align-items: center;
        gap: 10px;
    }
     /* contact */
     .input-wrapper{
        display: flex;
        gap: 15px;
     }
    .contact-item{
        min-width:calc(50% - 18px);
    }
    /* document */
    .grid-list1{
        grid-template-columns: 1fr;
        column-gap: 25px;
    }
}

/* responsive  for larger 768px screen*/
@media(min-width:768px)
{
    /*  custom property */
    :root{
        --fs-1:4.5rem;
        --fs-2:3.7rem;
        --fs-3:2.3rem;
        --fs-4:1.8rem;
        --fs-5:1.5rem;
        --fs-6:1.4rem;
    }
      /* reuse style */
      .container{
        max-width: 720px;
      }
      .section-text{
        max-width: 65ch;
        margin-inline:auto;
      }
       /* hero */
      .hero-text{
        max-width:60ch;
        margin-inline:auto;
      }
        /* about */
      .about-banner{
        max-width: 550px;
      }
      .about .section-text{
        max-width: unset;
        margin-inline: 0;
      }
       /* contact */
       .contact-form{
        padding: 30px;
       }
       .contact-item{
        min-width: calc(50% - 12.5px);
       }
         /* desc */
      .desc-banner{
        max-width: 550px;
      }
      .desc .section-text{
        max-width: unset;
        margin-inline: 0;
      }
}

/* responsive  for larger 992px screen*/
@media(min-width:992px)
{
    /*  custom property */
    :root{
        --fs-1:5rem;
        --fs-2:4rem;
        --fs-3:2.5rem;
        /* spacing */
        --section-padding:100px;
    }
      /* reuse style */
      .container{
        max-width: 960px;
      }
      .grid-list{
        grid-template-columns:repeat(3,1fr);
      } 
      .grid-list1{
        grid-template-columns:1fr;
      }
      /* header */
      .nav-toggle-btn{
        display: none;
      }
      .navbar,
      .navbar.active{all: unset;}

      .navbar-list{
        all:unset;
        display: flex;
        justify-content: center;
        gap: 30px;
    }
    .navbar-link{
        position: relative;
    }
    .navbar-link:is(:hover, :focus) {color: var(--eeria-black);}
    .navbar-link::after{
        content: "";
        position: absolute;
        bottom: 5px;
        left: 0;
        width: 100%;
        height: 2px;
        background-image: var(--gradient);
        transform: scaleX(0);
        transform-origin: left;
        transition: var(--transition-2);
    }
    .navbar-link:is(:hover, :focus)::after{transform: scaleX(1);}
    .header .btn{margin-block-start: 0px;
    }
    /* hero */
    .hero .container{
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        gap: 30px;
        text-align: left;
    }
    .hero-content { margin-block-end: 0;}
    .hero-subtitle{
        position: relative;
        padding-inline-start: 15px;
    }
    .hero-subtitle::before{
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 2px;
        height: 100%;
        background-color: var(--red-crayola);
    }
    .hero-text,
    .hero .btn{ margin-inline: 0;}
    /* service */
    .service-card{ padding: 20px;}
    .service-card .h3{--fs-3:2.3rem;}

    /* project */
    .project-card .card-subtitle {--fs-6:1.5rem;}
    /* about */
    .about .container{
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        gap: 30px;
    }
    .about-banner{ margin-block-end: 0;}
     /* blog */
   .blog .grid-list{
    grid-template-columns: 1fr 1fr;
    row-gap: 20px;
   }
   .blog .grid-list>li:first-child{
    grid-column: 1/2;
    grid-row: 1/5;
   }
   .blog-card:not(.grid){height: 100%;}
   .blog-card .card-content { padding-block:10px;}
   .blog-card:not(grid) .card-content {padding: 25px;}
   .blog-card.grid .h3 {--fs-3:2rem;}
   .blog-card .time{ --fs-6:1.6rem;}

   /* contact */
   .checkbox-wrapper {margin-block: 20px;}

   .contact-item {min-width: calc(33.33% - 16.66px);}
   .contact-card .card-icon{ font-size: 32px;}

    /* desc */
    .desc .container{
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        gap: 30px;
    }
    .desc-banner{ margin-block-end: 0;}

     /* review */
     .review-card{ padding: 20px;}
     .review-card .h3{--fs-3:2.3rem;}

     /* document */
    .document-card{ padding: 20px;}
    .document-card .h3{--fs-3:2.3rem;}
}

/* responsive  for larger 992px screen*/
@media(min-width:1200px)
{
    /*  custom property */
    :root{
        --fs-1:6.8rem;
        --fs-2:4.5rem;
        --fs-4:1.9rem;
        --fs-5:1.6rem;
        --fs-6:1.6rem;
      
    }
      /* reused style */
      .container {max-width: 1140px;}
      .btn{ --fs-6:1.5rem;}
    /* service */
    .service-card{padding: 30px;}
    .service-card .h3{ --fs-3:2.5rem;}

    /* project */
    .project-card .card-content{padding: 30px;}
    .project-card .card-subtitle {--fs-6: 1.6rem;}

    /* about */
    .about .container{ gap:60px;}

    .about.about-item {gap: 7px;}
    .about-item .fas{font-size: 20px;}
      /* cta */
      .cta .section-title{margin-block: 15px 24px;}

      /* blog */
      .blog-card .time{ --fs-6:1.6rem;}

      .blog-card.grid .h3{--fs-3:2.4rem;}

      /* contact */
      .contact-form {padding: 50px;}
      .contact-card{gap: 20px;}
      .contact-card .card-icon {padding: 15px;}
     /* desc */
     .desc .container{ gap:60px;}

     .desc.desc-item {gap: 7px;}
     .desc-item .fas{font-size: 20px;}

     /* review */
    .review-card{padding: 30px;}
    .review-card .h3{ --fs-3:2.5rem;}

    /* document */
    .document-card{padding: 30px;}
    .document-card .h3{ --fs-3:2.5rem;color: var(--red-crayola);}
}



  .about--tight{padding-top:2rem; padding-bottom:2rem;}

  
  .about .container.about-wrap{display:block !important;}

  
  .about-float{max-width:clamp(280px,34vw,420px); margin:0 0 .75rem;}
  .about-float .img-cover{display:block; width:100%; height:auto; border-radius:18px; object-fit:cover;}

 
  @media (min-width:992px){
    .about-float{float:right; margin:0 0 .75rem 1.75rem; shape-outside: inset(0 round 18px); shape-margin:12px;}
  }
  
  @media (max-width:991.98px){
    .about-float{float:none; margin:0 auto .75rem;}
  }

  
  .about-content h2,
  .about-content h3,
  .about-content p,
  .about-content ul{clear:none !important;}

 
  .about .container.about-wrap::after{content:""; display:block; clear:both;}

  
  .about-cta .btn{margin-right:.75rem; margin-top:.5rem;}
  .btn.btn-outline{border:2px solid currentColor; background:transparent; padding:.8rem 1.2rem; border-radius:14px; display:inline-block;}


.about .img-holder,
.about .img-holder::before {
  background: transparent !important;   
  box-shadow: none;
}


.about .img-holder .img-cover {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 18px;           
}


  
  .online .section-title { margin-bottom: .75rem; }
  .online .lead { max-width: 880px; }
  .online .cta-row .btn { margin-right:.75rem; margin-top:.5rem; }

  .online-grid{
    display:grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    margin-top: 1.25rem;
  }
  @media (min-width: 992px){
    .online-grid{ grid-template-columns: repeat(3, 1fr); }
  }

  .online-card{
    background: rgba(255,255,255,0.08); 
    backdrop-filter: blur(2px);
    border-radius: 16px;
    padding: 1rem 1.1rem;
  }

  .online .icon-list{ margin: .5rem 0 0; }
  .online .icon-list li{ display:flex; align-items:flex-start; gap:.5rem; margin:.35rem 0; }
  .online .icon-list i{ margin-top:.15rem; }

  .bullet-2col{ 
    columns: 2; column-gap: 1.25rem; margin: .5rem 0 .25rem;
    list-style: disc inside;
  }
  @media (max-width: 576px){ .bullet-2col{ columns:1; } }

  .online .micro-note{ font-size:.9rem; opacity:.85; margin-top:.25rem; }

  .trust-block{
    margin-top: 1.5rem;
    background: rgba(255,255,255,0.06);
    padding: 1rem 1.1rem;
    border-radius: 16px;
  }

  
  .btn.btn-outline{
    border:2px solid currentColor; background:transparent;
    padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
  }
  
 
.section.cta.has-bg-image{
  background-image: var(--cta-bg) !important; 
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff; 
}


.section.cta.has-bg-image::before,
.section.cta.has-bg-image::after{
  content: none !important;
  background: none !important;
}


.section.cta .section-title,
.section.cta .cta-subtitle,
.section.cta .cta-bonus,
.section.cta a,
.section.cta .btn{ color:#fff; }


.btn.btn-outline.btn-outline-white{
  border: 2px solid #fff;
  background: transparent;
  color: #fff;
  padding: .8rem 1.25rem;
  border-radius: 14px;
}


.section.cta .section-title,
.section.cta .cta-subtitle,
.section.cta .cta-bonus{
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
}

 .games .grid-games{
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, 1fr);
    list-style: none;
    padding: 0;
    margin: 0;
  }
  @media (min-width: 576px){
    .games .grid-games{ grid-template-columns: repeat(3, 1fr); }
  }
  @media (min-width: 768px){
    .games .grid-games{ grid-template-columns: repeat(4, 1fr); }
  }
  @media (min-width: 1200px){
    .games .grid-games{ grid-template-columns: repeat(6, 1fr); }
  }

  
  .game-card{
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    background: #0e0e12;              
    border: 1px solid rgba(255,255,255,.06);
  }
  .game-card .thumb{
    position: relative;
    width: 100%;
    aspect-ratio: 3 / 4;              
    overflow: hidden;
  }
  .game-card .game-img{
    width: 100%; height: 100%;
    object-fit: cover; display:block;
    transition: transform .35s ease;
  }
  .game-card:hover .game-img,
  .game-card:focus-within .game-img{
    transform: scale(1.04);
  }

 
  .game-overlay{
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: radial-gradient(ellipse at center, rgba(0,0,0,.05), rgba(0,0,0,.55) 70%);
    opacity: 0; transition: opacity .25s ease;
  }
  .game-card:hover .game-overlay,
  .game-card:focus-within .game-overlay{ opacity: 1; }

  
  .game-overlay .btn{ pointer-events: auto; }
  
   .promos .lead{max-width:980px;}
  .promo-hero{
    background: rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:16px;
    padding:1rem 1.25rem;
    margin-block: .75rem 1.25rem;
  }
  .promo-hero .big{font-size:1.1rem; margin:.25rem 0 .5rem;}
  .promo-bullets{list-style:disc inside; margin:.25rem 0 .75rem;}
  .cta-row .btn{margin-right:.75rem; margin-top:.5rem;}
  .btn.btn-outline{border:2px solid currentColor; background:transparent; padding:.8rem 1.25rem; border-radius:14px; display:inline-block;}

  .promo-grid{display:grid; grid-template-columns:1fr; gap:12px; margin-top:.5rem;}
  @media (min-width:768px){ .promo-grid{ grid-template-columns:repeat(3,1fr); } }

  .promo-card{
    background: rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:14px;
    padding: .9rem 1rem;
  }
  .promo-card .mini-list{list-style:disc inside; opacity:.95; margin:.35rem 0 0;}

  .loyalty{ margin-top:1.25rem; }
  .tier-grid{ display:grid; grid-template-columns:1fr; gap:12px; }
  @media (min-width:768px){ .tier-grid{ grid-template-columns:repeat(4,1fr); } }
  .tier{
    background: rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:14px; padding:.9rem 1rem;
  }
  .tier .tier-text{ opacity:.95; }

  .claim{ margin-top:1.25rem; }
  .claim-steps{ counter-reset: step; list-style:none; padding:0; margin:.25rem 0 .75rem;}
  .claim-steps li{
    position:relative; padding-left:2.1rem; margin:.4rem 0;
  }
  .claim-steps li::before{
    counter-increment: step; content: counter(step);
    position:absolute; left:0; top:.1rem;
    width:1.4rem; height:1.4rem; line-height:1.4rem; text-align:center;
    border-radius:50%;
    background: rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.18);
  }

  .terms, .faq{ margin-top:1rem; }
  .faq-item{ background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:12px; padding:.7rem .85rem; margin:.4rem 0; }
  .faq-item[open]{ background: rgba(255,255,255,0.06); }
  
   
  .promo-hero{
    background: rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:16px;
    padding:1rem 1.25rem;
    margin-block:.75rem 1.25rem;
  }
  .promo-hero--with-media{
    display:grid;
    grid-template-columns: 1fr;
    gap: 16px;
    align-items: center;
  }
  @media (min-width: 992px){
    .promo-hero--with-media{
      grid-template-columns: 1fr minmax(360px, 480px);
      gap: 20px;
      padding-right: 1.25rem;
    }
  }

  .promo-hero-media{
    margin: 0;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .promo-hero-img{
    display:block;
    width:100%;
    height:auto;
    max-height: 520px;
    border-radius: 14px;
    object-fit: contain; 
    filter: drop-shadow(0 10px 24px rgba(0,0,0,.25));
  }

  
  .gaming-wrap{
    display:grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }
  @media (min-width: 992px){
    .gaming-wrap{
      grid-template-columns: minmax(440px, 1fr) 1fr;
      align-items: start;
    }
  }

  /* Intro column */
  .gaming-intro .lead{ margin-bottom:.6rem; max-width: 60ch; }
  .gaming-usps{ list-style:none; padding:0; margin:.25rem 0 .75rem; }
  .gaming-usps li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
  .gaming-usps i{ margin-top:.15rem; }
  .gaming-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
  .btn.btn-outline{ border:2px solid currentColor; background:transparent; padding:.8rem 1.25rem; border-radius:14px; display:inline-block; }

  /* Category grid */
  .gaming-grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    list-style:none; padding:0; margin:0;
  }
  @media (max-width: 680px){
    .gaming-grid{ grid-template-columns: 1fr; }
  }

  .g-card{
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: .9rem 1rem;
    display:flex; flex-direction:column; min-height: 100%;
  }
  .g-head{ display:flex; align-items:center; gap:.6rem; margin-bottom:.25rem; }
  .g-head i{ font-size:1.25rem; }
  .g-text{ margin:.25rem 0 .5rem; flex:0 0 auto; }
  .g-meta{
    display:flex; flex-wrap:wrap; gap:.5rem .75rem; margin-bottom:.6rem; opacity:.95;
  }
  .g-meta span{ display:inline-flex; align-items:center; gap:.35rem; font-size:.95rem; }
  .g-btn{ margin-top:auto; } 

 
  .popular .container.pop-wrap{ display:block !important; }

  
  .pop-media{
    max-width: clamp(300px, 32vw, 440px);
    margin: 0 0 .75rem;
  }
  .pop-img{ display:block; width:100%; height:auto; border-radius:18px; object-fit:contain; }
  @media (min-width: 992px){
    .pop-media{ float:right; margin: .1rem 0 .9rem 1.75rem; shape-outside: inset(0 round 18px); shape-margin: 12px; }
  }
  @media (max-width: 991.98px){
    .pop-media{ float:none; margin: 0 auto .75rem; }
  }

  /* Text tweaks */
  .popular .lead{ max-width: 70ch; margin-bottom:.6rem; }
  .pop-points{ list-style:none; padding:0; margin:.35rem 0 .8rem; }
  .pop-points li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
  .pop-points i{ margin-top:.15rem; }

  /* Rating strip */
  .pop-rating{
    display:flex; align-items:center; gap:.6rem;
    background: rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:12px; padding:.5rem .75rem; margin:.5rem 0 .8rem;
  }
  .pop-rating .stars i{ color: #ffd166; } 
  .pop-rating .score{ font-weight:600; }
  .pop-rating .votes{ opacity:.9; }

  /* Two-column bullets */
  .bullet-2col{
    columns: 2; column-gap: 1.25rem; list-style: disc inside;
    margin: .25rem 0 .75rem;
  }
  @media (max-width: 576px){ .bullet-2col{ columns:1; } }

  /* Mini grid highlights */
  .pop-mini-grid{
    display:grid; grid-template-columns: 1fr; gap:12px; margin:.5rem 0 .9rem;
  }
  @media (min-width:768px){ .pop-mini-grid{ grid-template-columns: repeat(3,1fr); } }
  .mini{
    background: rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:14px; padding:.8rem 1rem;
  }

  /* CTA */
  .pop-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
  .btn.btn-outline{ border:2px solid currentColor; background:transparent; padding:.8rem 1.25rem; border-radius:14px; display:inline-block; }

  /* FAQ */
  .pop-faq .faq-item{
    background: rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:12px; padding:.7rem .85rem; margin:.4rem 0;
  }
  .pop-faq .faq-item[open]{ background: rgba(255,255,255,0.07); }

  
  .pop-content h2, .pop-content h3, .pop-content p, .pop-content ul, .pop-content .pop-rating, .pop-content .pop-mini-grid,
  .pop-content .pop-cta, .pop-content .pop-faq{ clear:none !important; }

 
  .pop-wrap::after{ content:""; display:block; clear:both; }
  
  /* ===== Jackpots & Bonus Buy (standalone styles) ===== */


.jackpots .container.jp-wrap{ display:block !important; }


.jp-media{
  max-width: clamp(300px, 32vw, 440px);
  margin: 0 0 .75rem;
}
.jp-img{
  display:block; width:100%; height:auto;
  border-radius:18px; object-fit:contain;
}
@media (min-width: 992px){
  .jp-media{
    float:left;
    margin: .1rem 1.75rem .9rem 0;
    shape-outside: inset(0 round 18px);
    shape-margin: 12px;
  }
}
@media (max-width: 991.98px){
  .jp-media{ float:none; margin: 0 auto .75rem; }
}

/* text blocks */
.jackpots .lead{ max-width:70ch; margin-bottom:.6rem; }
.jp-points{ list-style:none; padding:0; margin:.35rem 0 .8rem; }
.jp-points li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
.jp-points i{ margin-top:.15rem; }

/* mini feature grid */
.jp-meta-grid{
  display:grid; grid-template-columns:1fr; gap:12px; margin:.5rem 0 .9rem;
}
@media (min-width:768px){ .jp-meta-grid{ grid-template-columns:repeat(3,1fr); } }
.mini{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}

/* two-column bullets */
.bullet-2col{
  columns:2; column-gap:1.25rem; list-style:disc inside;
  margin:.25rem 0 .75rem;
}
@media (max-width:576px){ .bullet-2col{ columns:1; } }

/* ctas */
.jp-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}

/* faq */
.jp-faq .faq-item{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px; padding:.7rem .85rem; margin:.4rem 0;
}
.jp-faq .faq-item[open]{ background: rgba(255,255,255,0.07); }


.jp-content h2, .jp-content h3, .jp-content p, .jp-content ul,
.jp-content .jp-meta-grid, .jp-content .jp-cta, .jp-content .jp-faq{ clear:none !important; }


.jp-wrap::after{ content:""; display:block; clear:both; }

/* ===== Live Casino & Table Games (standalone styles) ===== */


.live .container.live-wrap{ display:block !important; }


.live-media{
  max-width: clamp(300px, 32vw, 440px);
  margin: .25rem 0 .9rem;
}
.live-img{
  display:block; width:100%; height:auto;
  border-radius:18px; object-fit:contain;
}
@media (min-width: 992px){
  .live-media{
    float:right;                     
    margin: .2rem 0 .9rem 1.75rem;   
    shape-outside: inset(0 round 18px);
    shape-margin: 12px;
  }
}
@media (max-width: 991.98px){
  .live-media{ float:none; margin: 0 auto .75rem; }
}

/* text & lists */
.live .lead{ max-width:70ch; margin-bottom:.6rem; }
.live-points{ list-style:none; padding:0; margin:.35rem 0 .8rem; }
.live-points li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
.live-points i{ margin-top:.15rem; }

/* mini feature grid */
.live-meta-grid{
  display:grid; grid-template-columns:1fr; gap:12px; margin:.5rem 0 .9rem;
}
@media (min-width:768px){ .live-meta-grid{ grid-template-columns: repeat(3,1fr); } }
.mini{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}

/* two-column bullets */
.bullet-2col{
  columns: 2; column-gap: 1.25rem; list-style: disc inside;
  margin: .25rem 0 .75rem;
}
@media (max-width:576px){ .bullet-2col{ columns:1; } }

/* ctas */
.live-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}

/* faq */
.live-faq .faq-item{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px; padding:.7rem .85rem; margin:.4rem 0;
}
.live-faq .faq-item[open]{ background: rgba(255,255,255,0.07); }


.live-content h2, .live-content h3, .live-content p, .live-content ul,
.live-content .live-meta-grid, .live-content .live-cta, .live-content .live-faq{
  clear:none !important;
}


.live-wrap::after{ content:""; display:block; clear:both; }

/* ===== Sportsbook — standalone styles ===== */


.sportsbook .container.sb-wrap{ display:block !important; }


.sb-media{
  max-width: clamp(300px, 32vw, 440px);
  margin: .2rem 0 .9rem;
}
.sb-img{
  display:block; width:100%; height:auto;
  border-radius:18px; object-fit:contain;
}
@media (min-width: 992px){
  .sb-media{
    float:right;
    margin: .25rem 0 .9rem 1.75rem;  
    shape-outside: inset(0 round 18px);
    shape-margin: 12px;
  }
}
@media (max-width: 991.98px){
  .sb-media{ float:none; margin: 0 auto .75rem; }
}

/* text blocks */
.sportsbook .lead{ max-width:70ch; margin-bottom:.6rem; }
.sb-points{ list-style:none; padding:0; margin:.35rem 0 .8rem; }
.sb-points li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
.sb-points i{ margin-top:.15rem; }

/* mini feature grid */
.sb-meta-grid{
  display:grid; grid-template-columns:1fr; gap:12px; margin:.5rem 0 .9rem;
}
@media (min-width:768px){ .sb-meta-grid{ grid-template-columns: repeat(3,1fr); } }
.mini{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}

/* two-column bullets */
.bullet-2col{
  columns: 2; column-gap: 1.25rem; list-style: disc inside;
  margin: .25rem 0 .75rem;
}
@media (max-width:576px){ .bullet-2col{ columns:1; } }

/* CTAs */
.sb-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}

/* FAQ */
.sb-faq .faq-item{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px; padding:.7rem .85rem; margin:.4rem 0;
}
.sb-faq .faq-item[open]{ background: rgba(255,255,255,0.07); }


.sb-content h2, .sb-content h3, .sb-content p, .sb-content ul,
.sb-content .sb-meta-grid, .sb-content .sb-cta, .sb-content .sb-faq{
  clear:none !important;
}


.sb-wrap::after{ content:""; display:block; clear:both; }

/* ===== Login & Registration (standalone styles) ===== */

.account .lead{ max-width: 80ch; }
.acc-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}

/* Grid of quick-start cards */
.acc-grid{
  display:grid; grid-template-columns:1fr; gap:12px; list-style:none; padding:0; margin:.75rem 0 1rem;
}
@media (min-width: 992px){
  .acc-grid{ grid-template-columns: repeat(3, 1fr); }
}
.acc-card{
  background: rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding:1rem 1.1rem;
}
.acc-steps{
  counter-reset: step; list-style:none; padding:0; margin:.4rem 0 .6rem;
}
.acc-steps li{
  position:relative; padding-left:2.1rem; margin:.45rem 0;
}
.acc-steps li::before{
  counter-increment: step; content: counter(step);
  position:absolute; left:0; top:.15rem;
  width:1.4rem; height:1.4rem; line-height:1.4rem; text-align:center;
  border-radius:50%;
  background: rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.18);
}
.acc-points{ list-style:none; padding:0; margin:.35rem 0 .6rem; }
.acc-points li{ display:flex; gap:.5rem; align-items:flex-start; margin:.35rem 0; }
.acc-points i{ margin-top:.15rem; }


.acc-reset{
  display:grid; grid-template-columns:1fr; gap:12px;
  margin-top: 1rem;
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding:1rem 1.1rem;
}
@media (min-width: 992px){
  .acc-reset{ grid-template-columns: 2fr minmax(280px, 1fr); }
}
.acc-reset .micro{ opacity:.9; }

.acc-mini-grid{
  display:grid; grid-template-columns:1fr; gap:10px; margin-top:.5rem;
}
@media (min-width:768px){
  .acc-mini-grid{ grid-template-columns: repeat(3, 1fr); }
}
.mini{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}

.acc-reset-aside{
  background: rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.9rem 1rem;
}


.acc-troubleshoot{
  margin-top: 1rem;
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding:1rem 1.1rem;
}

/* Header spacing */
.acc-header .section-title{ margin-bottom:.5rem; }

/* ===== Aseneskak Online Casino App (standalone styles) ===== */


.app .container.app-wrap{ display:block !important; }


.app-media{
  max-width: clamp(300px, 34vw, 460px);
  margin: 0 0 .9rem;
}
.app-img{
  display:block; width:100%; height:auto;
  border-radius:18px; object-fit:contain;
}
@media (min-width: 992px){
  .app-media{
    float:right;                         
    margin: .1rem 0 1rem 1.75rem;
    shape-outside: inset(0 round 18px);
    shape-margin: 12px;
  }
}
@media (max-width: 991.98px){
  .app-media{ float:none; margin: 0 auto .75rem; }
}

/* text */
.app .lead{ max-width: 70ch; margin-bottom:.6rem; }

/* USPs with icons */
.app-usp{
  display:grid; grid-template-columns:1fr; gap:10px; margin:.5rem 0 .9rem;
}
@media (min-width:768px){ .app-usp{ grid-template-columns: repeat(3,1fr); } }
.usp{
  display:flex; gap:.7rem; align-items:flex-start;
  background: rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}
.usp i{ font-size:1.25rem; margin-top:.15rem; }

/* Navigation mini grid */
.app-navgrid{
  display:grid; grid-template-columns:1fr; gap:10px; margin:.5rem 0 .9rem;
}
@media (min-width:768px){ .app-navgrid{ grid-template-columns: repeat(3,1fr); } }
.mini{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:.8rem 1rem;
}

/* store badges */
.app-badges{ display:flex; flex-wrap:wrap; gap:.6rem .9rem; align-items:center; margin:.5rem 0 .9rem; }
.app-badges img{ display:block; height:auto; }

/* how-to cards */
.app-howto{
  display:grid; grid-template-columns:1fr; gap:12px; margin:.4rem 0 .9rem;
}
@media (min-width:992px){ .app-howto{ grid-template-columns: repeat(2,1fr); } }
.howto-card{
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding: .9rem 1rem;
}
.steps{ counter-reset: step; list-style:none; padding:0; margin:.35rem 0 .45rem; }
.steps li{
  position:relative; padding-left:2.1rem; margin:.4rem 0;
}
.steps li::before{
  counter-increment: step; content: counter(step);
  position:absolute; left:0; top:.1rem;
  width:1.4rem; height:1.4rem; line-height:1.4rem; text-align:center;
  border-radius:50%;
  background: rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.18);
}
.micro{ opacity:.9; }

/* app bonus card */
.app-bonus{
  background: rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px; padding:1rem 1.1rem;
}
.mini-list{ list-style: disc inside; margin:.35rem 0 .2rem; }

.acc-cta .btn{ margin-right:.75rem; margin-top:.5rem; }
.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}


.app-content h2, .app-content h3, .app-content p, .app-content ul, .app-content .app-usp,
.app-content .app-navgrid, .app-content .app-badges, .app-content .app-howto, .app-content .app-bonus{
  clear:none !important;
}


.app-wrap::after{ content:""; display:block; clear:both; }

/* ===== Payments (standalone styles) ===== */
.pay-tabs{ display:flex; gap:.5rem; margin:.5rem 0 1rem; }
.pay-tab{ cursor:pointer; }
.pay-tab.is-active{ pointer-events:none; }

.table-wrap{ overflow:auto; border-radius:12px; border:1px solid rgba(255,255,255,.08); }
.pay-table{ width:100%; border-collapse:separate; border-spacing:0; }
.pay-table thead th{
  text-align:left; font-weight:700; padding:.75rem .9rem;
  background: rgba(255,255,255,.06);
}
.pay-table tbody td{ padding:.7rem .9rem; border-top:1px solid rgba(255,255,255,.08); }
.pay-table tbody tr:nth-child(odd){ background: rgba(255,255,255,.03); }

.pay-note{ opacity:.9; margin:.5rem 0 1rem; }
.pay-help{ margin-top:1rem; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:.9rem 1rem; }

/* keep buttons consistent with template */
.btn.btn-outline{ border:2px solid currentColor; background:transparent; padding:.8rem 1.25rem; border-radius:14px; display:inline-block; }


.payments .pay-tabs .pay-tab{
  background: transparent;
  color: #111;                         
  border: 2px solid rgba(0,0,0,.55);   
  border-radius: 12px;
  padding: .65rem 1.1rem;
}

.payments .pay-tabs .pay-tab:hover{
  background: rgba(0,0,0,.06);
}

.payments .pay-tabs .pay-tab.is-active{
 
  background: linear-gradient(90deg, #ff7a18, #ff3d77);
  color: #fff;
  border-color: transparent;
}


@media (prefers-color-scheme: dark){
  .payments .pay-tabs .pay-tab{
    color: #fff;
    border-color: rgba(255,255,255,.55);
  }
  .payments .pay-tabs .pay-tab:hover{
    background: rgba(255,255,255,.08);
  }
}

/* ===== Trust, Security & Platform Overview (standalone styles) ===== */
.platform .lead{ max-width: 80ch; }

.platform-grid{
  display:grid; grid-template-columns:1fr; gap:12px;
  list-style:none; padding:0; margin:.75rem 0 1rem;
}
@media (min-width: 992px){
  .platform-grid{ grid-template-columns: repeat(3, 1fr); }
}

.p-card{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 1rem 1.1rem;
  height: 100%;
  display: flex; flex-direction: column;
}
.p-head{ display:flex; align-items:center; gap:.6rem; margin-bottom:.25rem; }
.p-head i{ font-size:1.25rem; }

.p-points{ list-style: disc inside; margin:.35rem 0 0; opacity:.95; }
.platform-cta .btn{ margin-right:.75rem; margin-top:.5rem; }

.btn.btn-outline{
  border:2px solid currentColor; background:transparent;
  padding:.8rem 1.25rem; border-radius:14px; display:inline-block;
}

/* ===== FAQ (2-column layout, template-friendly) ===== */
.faq .lead{ max-width: 80ch; }

.faq-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: .5rem;
}
@media (min-width: 992px){
  .faq-grid{ grid-template-columns: 1fr 1fr; }
}

.faq-item{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: .8rem 1rem;
}
.faq-item summary{
  cursor: pointer;
  font-weight: 700;
  outline: none;
  list-style: none;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item[open]{ background: rgba(255,255,255,.07); }
.faq-item p{ margin-top: .45rem; }


/* ===== Casino Footer (trusty, compact, responsive) ===== */
.casino-footer{
  background:#0f1014; color:#fff;
  padding-top: 1.25rem; padding-bottom: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: 0.98rem;
}
.casino-footer a{ color:#fff; opacity:.95; }
.casino-footer a:hover{ opacity:1; text-decoration:underline; }

/* top row */
.casino-footer .f-top{
  display:flex; align-items:center; justify-content:space-between;
  gap: 1rem; margin-bottom: .75rem;
}
.casino-footer .f-logo{ font-size:1.35rem; font-weight:800; }
.casino-footer .f-trust{
  display:flex; flex-wrap:wrap; gap:.6rem 1rem; list-style:none; margin:0; padding:0;
  opacity:.95;
}
.casino-footer .f-trust li{ display:flex; align-items:center; gap:.45rem; }

/* link grid */
.casino-footer .f-grid{
  display:grid; grid-template-columns:1fr 1fr; gap: 12px;
  margin-bottom:.75rem;
}
@media (min-width: 992px){
  .casino-footer .f-grid{ grid-template-columns: repeat(4, 1fr); }
}
.casino-footer .f-col{ background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:.75rem .9rem; }
.casino-footer .f-title{ font-weight:800; margin:0 0 .35rem; }
.casino-footer .f-links{ list-style:none; padding:0; margin:0; }
.casino-footer .f-links li{ margin:.25rem 0; }

/* payments strip */
.casino-footer .f-payments{
  display:flex; align-items:center; gap:.75rem; flex-wrap:wrap;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06);
  border-radius:12px; padding:.6rem .9rem; margin-bottom:.75rem;
}
.casino-footer .f-pay-title{ font-weight:700; margin-right:.25rem; }
.casino-footer .f-pay-list{ display:flex; gap:.9rem 1.1rem; flex-wrap:wrap; list-style:none; padding:0; margin:0; }
.casino-footer .f-pay-list li{ display:inline-flex; align-items:center; gap:.35rem; opacity:.95; }

/* bottom */
.casino-footer .f-bottom{ opacity:.95; }
.casino-footer .f-disclaimer{ font-size:.92rem; margin:0 0 .5rem; line-height:1.45; }
.casino-footer .copyright{ margin:0; font-size:.95rem; }

/* mobile tweaks */
@media (
