*{margin:0;padding:0;box-sizing:border-box;scroll-behavior:smooth}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:#000;color:#ffffff;overflow-x:hidden}
:root{
    --white:#fff;
    --default-color:#303030;
    --default-blue:#0196D8;
    --default-blue-hover:#50c7ff;
    --dark-blue:#094c6b;
}
/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:20px}
::-webkit-scrollbar-track{background:#151515}
::-webkit-scrollbar-thumb{background:var(--default-blue);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--default-blue-hover)}
/* Pour Firefox */
*{scrollbar-width:thin;scrollbar-color:var(--default-blue) #151515}
/*-- ===== GLOBAL ===== --*/
.hidden{display:none}
.fullWidth{width:100%}
.fullVWidth{width:100vw}
.fullVHeight{height:100vh}
.flex{display:flex}
.spaceBetween{justify-content:space-between}
.fixed{position:fixed}
.sticky{position:sticky}
.flexCol{flex-direction:column}
.flexRow{flex-direction:row}
.alignCenter{align-items:center}
.justifyCenter{justify-content:center}
.p10{padding:10px}.p20{padding:20px}.p30{padding:30px}
.m10{margin:10px}.m20{margin:20px}.m30{margin:30px}
.cp{cursor:pointer}
.textCenter{text-align:center}
.textLeft{text-align:left}
.transi{transition:.3s all ease}
.relative{position:relative}
.absolute{position:absolute}
.br3{border-radius:3px}.br5{border-radius:5px}.br10{border-radius:10px}
.flexWrap{flex-wrap:wrap}
/*-- ===== HEADER ===== --*/
#header{top:0px;height:80px;background:#101010;z-index:1000;border-bottom:1px solid #151515}
#logo img{height:50px}
#navigation{margin-right:30px}
#navigation a{width:140px;color:var(--default-blue);text-decoration:none}
#navigation a:hover{color:var(--default-blue-hover)}
#responsiveNavigation{display:none}
#hamburgerButton{width:50px;height:36px;transition:transform .3s ease}
#hamburgerButton span{width:20px;height:3px;background:var(--default-blue);transition:all .3s ease;transform-origin:center}
#hamburger:checked ~ #header #hamburgerButton span:nth-child(2){opacity:0;transform:translateX(-20px)}
#responsiveMenu{display:flex;z-index:10000;background:#151515;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}
#hamburger:checked ~ #responsiveMenu{opacity:1;visibility:visible}
#responsiveMenu a{opacity:0;transform:translateY(-20px);transition:all .4s ease}
#hamburger:checked ~ #responsiveMenu a:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.1s}
#hamburger:checked ~ #responsiveMenu a:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.2s}
#hamburger:checked ~ #responsiveMenu a:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.3s}
#hamburger:checked ~ #responsiveMenu a:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.4s}
/*-- ===== SECTIONS ===== --*/
section{min-height:100vh;}
.sectionTitle{color:var(--white);font-size:2rem;font-weight:700;margin-bottom:40px}
.sectionTitle::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:var(--default-blue);border-radius:2px}
/*-- ===== HERO ===== --*/
#heroBg{z-index:-1;background:url("../image/broken-smartphone.jpg")no-repeat center/cover;filter:brightness(20%);will-change:transform,filter}
#heroContent{z-index:1;margin-top:-150px;will-change:transform,filter}
#heroContent h1{font-size:40px}
#heroButton{max-width:600px;margin-top:30px}
#heroButton a{width:240px;padding:20px 10px;margin:20px;border:2px solid var(--default-blue);color:var(--white);text-decoration:none;font-size:16px;font-weight:bold;letter-spacing:1px}
#heroButton a:hover{letter-spacing:1.2px;box-shadow:rgba(1,150,216,.4)0px 4px 20px;}
/*-- ===== SERVICES ===== --*/
.servicesCards{margin-top:100px;gap:30px;max-width:1200px}
.serviceCard{width:270px;border:1px solid var(--dark-blue);padding:100px 20px 30px}
.serviceCardIcon{top:-75px;left:50%;transform:translateX(-50%);width:150px;height:150px;border-radius:50%;}
.smallCardTitle{font-size:16px !important}
.serviceCardIcon img{width:100%;height:100%;object-fit:contain}
.serviceCard h1{margin-bottom:15px;font-size:1.5rem;color:var(--default-blue)}
.serviceCard p{line-height:1.6;font-size:.95rem}
.device{width:150px;margin-left:10px;color:var(--default-blue)}
.device::after{content:"smartphone";animation:rotate 12s infinite;display:inline-block}
.rotating-text{color:var(--white);font-size:2rem;font-weight:700;margin-top:-50px;margin-bottom:20px}
.rotating-text::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:var(--default-blue);border-radius:2px}
@keyframes rotate{
    0%,20%{content:"smartphone";opacity:1}
    22%,23%{opacity:0}
    25%,45%{content:"tablette";opacity:1}
    47%,48%{opacity:0}
    50%,70%{content:"ordinateur";opacity:1}
    72%,73%{opacity:0}
    75%,95%{content:"console";opacity:1}
    97%,100%{opacity:0}
}
/*-- ===== SHOPS ===== --*/
#shops{padding:100px 20px;min-height:100vh;gap:40px}
.maps-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:30px;max-width:1400px}
.map-card{background:#242424;overflow:hidden;box-shadow:0 10px 40px rgba(0,0,0,.3)}
.map-header{background:var(--dark-blue);color:var(--white)}
.map-header h3{margin:0 0 8px 0;font-size:1.3rem;font-weight:600}
.reviewLink{padding:10px 30px;background:var(--default-blue);color:var(--white);text-decoration:none;text-shadow:1px 1px 6px rgba(0,0,0,.9)}
.reviewLink:hover{box-shadow:0px 0px 10px rgba(0,0,0,.9)}
.mapContainer{height:400px;border:none;display:block;filter:grayscale(100%) brightness(.5)}
.map-card:hover .mapContainer{filter:grayscale(20%) brightness(.95)}
/*-- ===== BOOKING ===== --*/
input[type="radio"]{display:none}
.step{display:none}
#step1:checked ~ .steps .step[data-step="1"],
#step2:checked ~ .steps .step[data-step="2"],
#step3:checked ~ .steps .step[data-step="3"],
#step4:checked ~ .steps .step[data-step="4"],
#step5:checked ~ .steps .step[data-step="5"],
#step6:checked ~ .steps .step[data-step="6"]{display:block;animation:fadeIn .3s}
@keyframes fadeIn{
    from{opacity:0;transform:translateY(10px)}
    to{opacity:1;transform:translateY(0)}
}
#booking{max-width:700px;padding:100px 20px;min-height:100vh;margin:0 auto}
h1{text-align:center}
h2{margin-bottom:1rem}
.form-group{margin-bottom:1.5rem}
.form-group label{margin-bottom:10px}
label.choice{display:block;padding:1rem;background:#252525;border:2px solid #333;margin-bottom:10px}
label.choice:hover{border-color:var(--default-blue);background:rgba(74,158,255,.05)}
.choice-title{font-size:1.1rem;font-weight:500;margin-bottom:5px}
.choice-subtitle{font-size:.85rem;color:#999}
input[type="radio"]:checked + label.choice,
input[name="location"]:checked ~ .steps label.choice[for*="location"],
input[name="device"]:checked ~ .steps label.choice[for*="device"]{border-color:#4a9eff;background:rgba(74,158,255,.1)}
input[type="text"],
input[type="email"],
input[type="tel"],
select,
textarea{background:#252525;border:2px solid #333;color:#e0e0e0;font-family:inherit}
input:focus,
select:focus,
textarea:focus{outline:none;border-color:var(--default-blue)}
.btn-group{gap:1rem;margin-top:2rem}
.btn{flex:1;padding:.75rem;border:none;font-size:1rem;font-weight:500}
.btn-primary{background:var(--default-blue);color:var(--white)}
.btn-primary:hover{background:var(--default-blue-hover)}
.btn-secondary{background:transparent;border:2px solid #333;color:#e0e0e0}
.recap{background:#252525;margin-bottom:1.5rem}
.recap-item{border-bottom:1px solid #333}
.recap-item:last-child{border-bottom:none}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:2rem}
.calendar-day{aspect-ratio:1;background:#252525;border:2px solid#333}
.calendar-day:hover:not(.disabled):not(.past){border-color:var(--default-blue);background:rgba(74,158,255,.05)}
.calendar-day.selected{border-color:var(--default-blue);background:rgba(74,158,255,.1)}
.calendar-day.disabled,
.calendar-day.past{opacity:.3;cursor:not-allowed}
.day-name{font-size:.75rem;color:#999;margin-bottom:4px;text-transform:uppercase}
.day-number{font-size:1.1rem;font-weight:600}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:2rem}
.time-slot{background:#252525;border:2px solid #333;font-weight:500}
.time-slot:hover:not(.disabled){border-color:var(--default-blue);background:rgba(74,158,255,.05)}
.time-slot.selected{border-color:var(--default-blue-hover);background:rgba(74,158,255,.1);color:var(--default-blue)}
.time-slot.disabled{opacity:.3;cursor:not-allowed}
/*-- PORTFOLIO --*/
#bodyBackground{position:fixed;width:100vw;height:100vh;top:0;left:0;z-index:-1;background:url("../image/broken-smartphone.jpg") top center / 100% auto no-repeat;filter:brightness(10%);will-change:transform,filter}
#portfolioSection{max-width:1400px;margin:0 auto;padding:50px 20px}
.masonry-grid{column-count:3;column-gap:20px;margin-top:50px}
.masonry-item{break-inside:avoid;margin-bottom:20px;position:relative;border-radius:8px;overflow:hidden;background:rgba(0,0,0,.4)}
.media-wrapper{position:relative;width:100%}
.media-wrapper img{width:100%;display:block;border-radius:8px 8px 0 0}
.media-wrapper iframe{width:100%;height:280px;display:block;border-radius:8px 8px 0 0}
.media-info{padding:20px;color:var(--text-color)}
.media-info h3{font-size:1.3rem;font-weight:600;margin-bottom:10px;color:var(--heading-color)}
.media-info p{font-size:0.95rem;line-height:1.6;opacity:.9}
.video-badge{position:absolute;top:15px;right:15px;background:rgba(0,0,0,.8);color:#fff;padding:8px 12px;border-radius:5px;font-size:.85rem;display:flex;align-items:center;gap:5px}
.empty-state{text-align:center;padding:100px 20px;color:var(--text-color);opacity:.7}
.empty-state p{font-size:1.2rem}
/*-- ABOUT --*/
#bodyBackground{position:fixed;width:100vw;height:100vh;top:0;left:0;z-index:-1;background:url("../image/broken-smartphone.jpg") top center / 100% auto no-repeat;filter:brightness(10%);will-change:transform,filter}
#aboutSection{max-width:1000px;margin:0 auto;padding:50px 20px;text-align:justify}
#aboutSection h2{color:var(--heading-color);font-size:1.7rem;font-weight:600;margin:40px 0 20px;position:relative}
#aboutSection h2::before{content:"";position:absolute;left:0;bottom:-10px;height:3px;width:100px;background:var(--default-blue);border-radius:2px}
#aboutSection p{margin:15px 0;font-size:1.1rem}
#aboutSection ul{margin:10px 0 20px 40px;list-style:disc}
#aboutSection ul li{margin-bottom:8px}
/*-- ===== FOOTER ===== --*/
footer{background:#101010;border-top:1px solid #151515}
.footerSectionBloc{min-width:280px;width:calc((100% / 3) - 20px)}
.borderBottom{border-bottom:1px solid #303030}
.bigIcon{height:35px}
.smallText{color:#808080;font-size:14px}
.socialIcons{margin-right:15px;width:35px;height:35px;padding:5px}
.socialIcons:hover{transform:translateY(-2px)}
.rounded{height:35px;width:35px;border-radius:50%;background:var(--default-blue)}
.rounded img{height:20px}
.underlineTitle{margin-bottom:40px}
.underlineTitle,.bigText{color:var(--white);font-size:20px;font-weight:600;position:relative}
.underlineTitle::before{content:"";position:absolute;left:0;bottom:-15px;height:2px;width:50px;background:var(--default-blue)}
.footerLinks a{margin-bottom:8px;color:#505050}
.footerLinks a:hover{color:var(--default-blue)}
.subscribeForm{overflow:hidden}
.subscribeInput{padding:14px 28px;background:#2E2E2E;border:1px solid #2E2E2E;color:var(--white);outline:var(--default-blue)}
.subscribeIcon{right:0;background:var(--default-blue);padding:13px 20px;border:1px solid var(--default-blue);top:0}
.subscribeIcon img{height:22px}
.copyright{background:#202020;color:#606060}
.copyrightLinks a{color:var(--default-blue);text-decoration:none}
.bottomLink{color:#606060;margin-right:15px}
.bottomLink:hover{color:var(--default-blue)}
.spacer{background:#202020;height:2px}
/*-- FAQ --*/
#bodyBackground{position:fixed;width:100vw;height:100vh;top:0;left:0;z-index:-1;background:url("../image/broken-smartphone.jpg") top center / 100% auto no-repeat;filter:brightness(10%);will-change:transform,filter}
#faqSection{max-width:1000px;margin:0 auto;padding:50px 20px}
.faq-item{margin-bottom:20px;border-radius:8px;overflow:hidden;background:rgba(255,255,255,0.05);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1)}
.faq-question{padding:20px;cursor:pointer;position:relative;transition:all 0.3s ease;display:flex;justify-content:space-between;align-items:center}
.faq-question:hover{background:rgba(255,255,255,0.08)}
.faq-question h3{color:var(--heading-color);font-size:1.2rem;font-weight:600;margin:0;flex:1;padding-right:20px}
.faq-icon{color:var(--default-blue);font-size:1.5rem;transition:transform 0.3s ease;font-weight:bold}
.faq-item.active .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease;padding:0 20px}
.faq-item.active .faq-answer{max-height:1000px;padding:0 20px 20px}
.faq-answer p{margin:10px 0;font-size:1.05rem;line-height:1.6;text-align:justify}
.faq-answer ul{margin:10px 0 10px 20px;list-style:disc}
.faq-answer ul li{margin-bottom:8px}
.faq-category{margin-bottom:50px}
.faq-category h2{color:var(--heading-color);font-size:1.7rem;font-weight:600;margin:40px 0 30px;position:relative}
.faq-category h2::before{content:"";position:absolute;left:0;bottom:-10px;height:3px;width:100px;background:var(--default-blue);border-radius:2px}
/*-- ===== RESPONSIVE ===== --*/
@media(max-width:1200px){
    /*-- Services --*/
    .servicesCards{max-width:600px}
    .serviceCard{width:calc(50% - 15px);min-width:250px;margin-bottom:50px}
    /*-- Shops --*/
    .maps-container{grid-template-columns:1fr;max-width:700px}
    /*-- Portfolio --*/
    .masonry-grid{column-count:2}
}
@media (max-width:900px){
    #navigation{display:none}
    #responsiveNavigation{display:flex}
}
@media(max-width:768px){
    /*-- Navigation --*/
    #responsiveMenu a{width:60%;margin-bottom:20px;padding:10px 20px;background:var(--default-blue);color:white;text-shadow:0 0 6px .9;text-decoration:none;border-radius:3px}
    #responsiveMenu a:hover{background:var(--default-blue-hover);text-shadow:0 0 6px .9}
    /*-- Services --*/
    .servicesCards{max-width:300px}
    .serviceCard{width:100%;min-width:auto;margin-bottom:50px}
    .serviceCardIcon{width:120px;height:120px;top:-60px}
    .serviceCard{padding:80px 20px 30px}
    /*--  Shops --*/
    .shops-title{font-size:2rem}
    .maps-container{grid-template-columns:1fr;gap:20px}
    .mapContainer{height:350px}
    /*-- Booking --*/
    .calendar{gap:5px}
    .time-slots{grid-template-columns:repeat(2,1fr)}
    /*-- About --*/
    #bodyBackground{background:url("../image/broken-smartphone.jpg") top center / auto 100% no-repeat;}
    #aboutSection {padding:30px 15px}
    #aboutSection h2{font-size:1.4rem}
    #aboutSection p{font-size:.95rem}
    /*-- FAQ --*/
    #bodyBackground{background:url("../image/broken-smartphone.jpg") top center / auto 100% no-repeat}
    #faqSection{padding:30px 15px}
    #faqSection h1{font-size:1.6rem;margin-bottom:30px}
    .faq-category h2{font-size:1.4rem}
    .faq-question h3{font-size:1.05rem}
    .faq-answer p{font-size:0.95rem}
    /*-- Portfolio --*/
    #bodyBackground{background:url("../image/broken-smartphone.jpg") top center / auto 100% no-repeat}
    #portfolioSection{padding:30px 15px}
    #portfolioSection h1{font-size:1.8rem}
    .masonry-grid{column-count:1;margin-top:30px}
    .masonry-item{margin-bottom:15px}
    .media-wrapper iframe{height:220px}
    .media-info{padding:15px}
    .media-info h3{font-size:1.1rem}
    .media-info p{font-size:.9rem}
}