html{
  scroll-behavior:smooth;
}
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

body{
  font-family: Arial, sans-serif;
  background:#000;
  color:white;
  overflow-x:hidden;
}

/* GREEN GLOW BACKGROUND */
body::before{
  content:"";
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:
    linear-gradient(360deg,
    rgba(0, 255, 0, 0.438) 0%,
    rgba(0, 255, 0, 0.226) 30%,
    rgba(0,255,0,0.05) 55%,
    transparent 80%);
  filter:blur(120px);
  z-index:-1;
}

/* HEADER */
.header{
  position:fixed;
  top:25px;
  left:50%;
  transform:translateX(-50%);
  width:70%;
  padding:5px 40px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:10px;
  z-index:1000;
}
.hero-box h1{
  margin-bottom:20px;
  line-height:2;
}

.hero-box p{
  margin-bottom:16px;
  line-height:1.6;
}
.nav-container{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

/* LOGO AREA */
.logo-area{
  display:flex;
  align-items:center;
  gap:15px;
}

.logo-area img{
  width:60px;
  height:60px;          /* square */
  object-fit:contain;   /* distortion হবে না */
  background:rgba(255,255,255,0.05);
  padding:8px;
  border-radius:12px;
}

.brand-name{
  font-size:25px;
  font-weight:700;
}

/* MENU */
.menu a{
  margin:0 15px;
  text-decoration:none;
  color:white;
  font-size:18px;
  opacity:0.8;
}

.menu a:hover{
  opacity:2;
}

/* BUTTON */
.btn{
  background:white;
  color:black;
  padding:10px 30px;
  border-radius:10px;
  text-decoration:none;
  font-size:20px;
  font-weight:700;
  transition:0.3s ease;
}

.btn:hover{
  background:#00c800;   /* green glow tone */
  color:white;
}

.hero-box{
  margin-bottom:30px;
}
/* HERO */
.hero{
  margin-top:120px;
  text-align:center;
  padding:40px;
}

.hero-box{
  margin:0 auto;
  margin-bottom:60px;   /* নিচে gap */
  width:80%;
  padding:150px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:20px;
}
.small-btn{
  display:inline-block;
  margin-bottom:5px;  /* video থেকে gap */
}
.hero-box h1{
  font-size:45px;
}
.hero-box p{
  font-size:30px;
}
.video-box{
  margin:60px auto;
  width:640px;     /* 1080 এর scaled version */
  height:360px;    /* 1920 এর scaled version */
  background:black;
  border-radius:20px;
  overflow:hidden;
}

.video-box video{
  width:100%;
  height:100%;
  object-fit:cover;
}
*{
margin:0;
padding:0;
box-sizing:border-box;
}

body{
background:#000;
color:#fff;
font-family:'Poppins',sans-serif;
overflow-x:hidden;
}

section{
padding:140px 8%;
}

.section-title{
text-align:center;
font-size:36px;
margin-bottom:90px;
opacity:0;
transform:translateY(60px);
transition:1s;
}

.section-title.show{
opacity:1;
transform:translateY(0);
}

/* GLASS */

.glass{
background:rgba(255,255,255,0.05);
backdrop-filter:blur(30px);
border:1px solid rgba(255,255,255,0.15);
border-radius:35px;
padding:60px;
box-shadow:0 0 40px rgba(0,255,150,0.15);
opacity:0;
transform:translateY(80px);
transition:1s;
}

.glass.show{
opacity:1;
transform:translateY(0);
}

/* REVIEW SECTION */
/* রিভিউ গ্লাস বক্স - মাঝখানে আনা এবং নিচের স্পেস ঠিক করা */
.review-wrapper.glass {
    max-width: 420px; /* বক্সের চওড়া একটু কমানো হয়েছে যাতে দেখতে স্মার্ট লাগে */
    margin: 40px auto;
    padding: 30px 20px 60px 20px; /* নিচে ৬০ পিক্সেল প্যাডিং দেওয়া হয়েছে যাতে কন্ট্রোল বার দেখা যায় */
    display: flex;
    flex-direction: column;
    align-items: center;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(20px);
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    height: auto; 
    position: relative; /* অ্যারো বাটনের সুবিধার জন্য */
}

/* টাইটেল এবং সাবটেক্সট সেকশন (ভিডিওর ওপরে আলাদা জায়গা) */
.reviewer-header {
    width: 100%;
    text-align: center;
    margin-bottom: 40px; /* ভিডিওর সাথে গ্যাপ */
}

.review-slider {
    width: 100%;
    position: relative;
}

.review-item {
    display: none; /* সব স্লাইড প্রথমে হাইড থাকবে */
    text-align: center;
    width: 100%;
}

.review-item.active {
    display: block; /* শুধু একটি স্লাইড দেখা যাবে */
    animation: fadeIn 0.5s ease-in;
}

.reviewer-name {
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    text-transform: uppercase;
    margin: 0;
}

.reviewer-subtext {
    color: #ffffff;
    font-size: 18px;
    margin-top: 5px;
}

/* ভিডিও কন্টেইনার */
.video-container {
    width: 80%; /* গ্লাস বক্সের চেয়ে একটু ছোট রাখা হয়েছে */
    max-width: 450px;
    aspect-ratio: 9 / 16;
    border-radius: 20px;
    overflow: hidden;
    margin: 0 auto; 
}

.video-container video {
    width: 100%;
    height:100%; /* হাইট ১০০% যাতে নিচের কন্ট্রোল বার ঢেকে না যায় */
    object-fit: cover; 
    display: block;
}

/* স্লাইডার বাটন */
.slider-btn {
    position: absolute;
    top: 55%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: white;
    font-size: 20px;
    padding: 10px 15px;
    cursor: pointer;
    border-radius: 50%;
    z-index: 100;
    transition: 0.3s;
}

.slider-btn:hover {
    background: #73ff00;
    color: #000;
}

.prev { left: -25px; }
.next { right: -25px; }

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}


/* ================= PORTFOLIO CLEAN GRID ================= */

.portfolio-wrapper{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(350px,1fr));
  gap:50px;
  max-width:1400px;
  margin:auto;
}

.portfolio-item{
  overflow:hidden;
  border-radius:25px;
  position:relative;
  transition:.4s ease;
}

.portfolio-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:.5s ease;
}

/* Aspect Ratios */

.landscape{
  aspect-ratio:1500/1080;
}

.square{
  aspect-ratio:1/1;
}

/* Hover Effect */

.portfolio-item:hover{
  transform:translateY(-12px);
  box-shadow:0 0 30px #09ff00;
}

.portfolio-item:hover img{
  transform:scale(1.05);
}

/* ================= SERVICE ================= */

.service-wrapper{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:60px;
  max-width:1400px;
  margin:auto;
}

.service-card{
  background:rgba(255,255,255,0.05);
  backdrop-filter:blur(10px);
  border-radius:25px;
  padding:25px;
  text-decoration:none;
  color:#fff;
  transition:.4s ease;
  display:block;
}

.service-card:hover{
  transform:translateY(-15px);
  box-shadow:0 0 30px #1eff00;
}

.service-img{
  width:100%;
  aspect-ratio:1080/1080;
  overflow:hidden;
  border-radius:20px;
  margin-bottom:25px;
}

.service-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.service-card h3{
  margin-bottom:20px;
}

.service-card p{
  font-size:15px;
  line-height:1.6;
  opacity:.8;
}

/* SERVICE DETAILS PAGE */

.service-details{
  padding:120px 20px 80px;
}

.details-container{
  max-width:900px;
  margin:auto;
  text-align:center;
}

/* TITLE */

.details-container h1{
  font-size:360px;
  margin-bottom:20px;
}

/* TEXT */

.details-container p{
  font-size:250px;
  line-height:1.8;
  opacity:10;
  text-align:center;
}

/* ABOUT */

.about-wrapper{
max-width:900px;
margin:auto;
text-align:center;
font-size:20px;
line-height:2;
}

/* ================= INBOX ================= */

.inbox-wrapper{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:60px;
  padding:80px 40px;
  flex-wrap:wrap;
}

.contact-btn{
  padding:18px 50px;
  border-radius:40px;
  background:rgb(255, 255, 255);
  border:1px solid rgb(0, 255, 0);
  color:#000000;
  font-size:18px;
  font-weight:600;
  text-decoration:none;
  transition:.3s ease;
}

.contact-btn:hover{
  background:rgba(0,180,80,0.7);
  box-shadow:0 0 30px rgb(81, 255, 0);
}

/* FOOTER */

footer {
    background: #111;
    padding: 60px 10%;
    text-align: center;
    
    /* ওপরের দিকে চিকন সাদা বর্ডার */
    border-top: 2px solid rgb(255, 255, 255); 
    
    /* নিচে হালকা সাদা গ্লো ইফেক্ট */
    box-shadow: 0px -15px 50px rgba(255, 255, 255, 0.05); 
    
    position: relative;
    overflow: hidden;
}

/* ফুটারের একদম নিচে একটি হালকা গ্লোয়িং লাইন যোগ করার জন্য */
footer::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgb(255, 255, 255), transparent);
    box-shadow: 0px 0px 20px rgb(255, 255, 255);
}

.footer-logo {
    width: 50px;
    margin-bottom: 40px;
    /* লোগোতেও হালকা গ্লো দিতে পারো */
    filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.226));
}

.brand-name {
    color: white;
    font-weight: bold;
    letter-spacing: 2px;
}

.footer-links {
    margin: 40px 0;
}

.footer-links a {
    margin: 0 30px;
    color: rgb(255, 255, 255);
    text-decoration: none;
    font-size: 14px;
    transition: 0.3s;
}

footer p {
    opacity: .9;
    margin-top: 40px;
    font-size: 20px;
}
html {
  scroll-behavior: smooth;
}

/* ব্র্যান্ড নেম যাতে নীল না হয়ে যায় তার জন্য */
footer a {
  color: inherit;
  display: inline-block;
}


/* FOOTER LAYOUT */

.footer-container{
display:flex;
justify-content:space-between;
align-items:center;
flex-wrap:wrap;
}

.footer-left{
max-width:600px;
}

/* SOCIAL ICON RIGHT SIDE */

.footer-social{
position:absolute;
right:80px;
top:100px;
display:flex;
gap:20px;
}

.footer-social img{
width:30px;
height:30px;
transition:0.3s;
}

.footer-social img:hover{
transform:scale(1.2);
}


/* RESPONSIVE */

@media(max-width:768px){

.video-box{
width:250px;
height:450px;
}

section{
padding:100px 6%;
}

}/* ================= SERVICE DETAILS PAGE ================= */

.service-details{
  padding:120px 20px;
  text-align:center;
}

.details-container{
  max-width:850px;
  margin:auto;
}

.details-container img{
  width:100%;
  max-width:600px;
  border-radius:25px;
  margin-bottom:50px;   /* Image নিচে বড় gap */
}

.details-container h1{
  font-size:32px;
  margin-bottom:25px;   /* Headline নিচে clean 1 line gap */
}

.details-container p{
  font-size:16px;
  line-height:1.8;
  margin-bottom:20px;   /* paragraph spacing */
}
/* Hero Horizontal Video */
.video-box-horizontal {
    margin: 60px auto;
    width: 100%;
    max-width: 1000px; /* স্ক্রিন অনুযায়ী অ্যাডজাস্ট হবে */
    aspect-ratio: 16 / 9; /* 1920x1080 এর জন্য */
    background: #000;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.video-box-horizontal video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Review Vertical Slider */
.review-container {
    position: relative;
    max-width: 450px; /* গ্লাস বক্সের সাইজ */
    margin: auto;
    padding: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.review-slider {
    width: 300px; /* ভিডিওর প্রস্থ */
    height: 533px; /* 1080x1920 রেশিও অনুযায়ী */
    position: relative;
    overflow: hidden;
    border-radius: 20px;
}

.review-item {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

.review-item.active {
    opacity: 1;
    position: relative;
}

.review-item video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Slider Arrows */
.slider-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    font-size: 24px;
    padding: 15px;
    cursor: pointer;
    border-radius: 50%;
    transition: 0.3s;
    z-index: 10;
}

.slider-btn:hover {
    background: rgba(0, 255, 150, 0.5);
}

.prev { left: -20px; }
.next { right: -20px; }

@media (max-width: 600px) {
    .prev { left: 10px; }
    .next { right: 10px; }
}
/* REVIEW SLIDER এর জন্য প্রয়োজনীয় স্টাইল */

.review-item {
    display: none; /* প্রথমে সব ভিডিও লুকিয়ে রাখবে */
}

.review-item.active {
    display: block; /* শুধু যে ভিডিওটি 'active' সেটি দেখাবে */
    opacity: 1;
    animation: fadeIn 0.5s ease-in-out; /* ভিডিও আসার সময় হালকা এনিমেশন হবে */
}

/* ভিডিও আসার সময় সুন্দর একটি ইফেক্ট */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}