﻿/* ==========================================================
   DJ YOYO ANIMATION
   DEVIS V2
========================================================== */
/* ==========================================================
   BLOC 1
   STRUCTURE
========================================================== */
/* ==========================
   SECTION
========================== */

.devis-v2{

    position:relative;

    overflow:hidden;

    isolation:isolate;

    padding:70px 40px;

    background:
        linear-gradient(
            rgba(5,8,20,.82),
            rgba(0,0,0,.92)
        ),
        url("../img/devis-background2.webp") center center / cover no-repeat;

}

/* ==========================
   HALOS
========================== */

.devis-v2::before,
.devis-v2::after{

    content:"";

    position:absolute;

    border-radius:50%;

    filter:blur(75px);

    pointer-events:none;

}

.devis-v2::before{

    width:650px;
    height:650px;

    top:40px;
    left:-180px;

    background:
        radial-gradient(circle,
        rgba(0,217,255,.28),
        transparent 70%);

}

.devis-v2::after{

    width:650px;
    height:650px;

    right:-220px;
    bottom:-150px;

    background:
        radial-gradient(circle,
        rgba(255,46,168,.25),
        transparent 70%);

}

/* ==========================
   CONTENEUR
========================== */

.devis-container{

    position:relative;

    z-index:2;

    max-width:1450px;

    margin:auto;

    display:grid;

    grid-template-columns:40% 60%;

    gap:50px;

    align-items:start;

}

/* ==========================
   COLONNE GAUCHE
========================== */

.devis-left{

    display:flex;

    justify-content:center;

    align-items:flex-start;

    position:relative;

}

/* ==========================
   PHOTO
========================== */

.photo-wrapper{

    position:relative;

    display:flex;

    justify-content:center;

    margin-top:55px;

    align-items:flex-end;

    transition:.45s;

}
.photo-wrapper::before{

    content:"";

    position:absolute;

    inset:-40px;

    border-radius:50%;

    background:
        radial-gradient(
            circle,
            rgba(0,0,0,.18),
            transparent 70%
        );

    z-index:-1;

    pointer-events:none;

}
.photo-wrapper:hover{

    transform:translateY(-8px) scale(1.02);

}

.photo-yoyo{

    display:block;

    width:100%;

    max-width:360px;

    height:auto;

    position:relative;

    z-index:2;

    user-select:none;

    -webkit-user-drag:none;

    transition:
        transform .45s,
        filter .45s;

    filter:

        drop-shadow(0 0 30px rgba(0,217,255,.35))
        drop-shadow(0 0 70px rgba(255,46,168,.22));

}

/* ==========================================================
   BLOC 1B
   LOGO + COLONNE DROITE
========================================================== */


/* ==========================
   LOGO DJ YOYO
========================== */

.logo-yoyo{

    position:absolute;

    left:-15px;

    bottom:50px;

    z-index:10;

    transform:scale(.80);

    transform-origin:left bottom;

    user-select:none;

}

.logo-yoyo .dj{

    color:#00d9ff;

    font-size:68px;

    font-weight:900;

    line-height:1;

    text-shadow:
        0 0 10px #00d9ff,
        0 0 25px #00d9ff;

    transition:.35s;

}

.logo-yoyo .yoyo{

    color:#ff2ea8;

    font-size:68px;

    font-weight:900;

    margin-left:10px;

    line-height:1;

    text-shadow:
        0 0 10px #ff2ea8,
        0 0 25px #ff2ea8;

    transition:.35s;

}

.logo-yoyo .animation{

    display:block;

    margin-top:-3px;

    margin-left:4px;

    letter-spacing:8px;

    font-size:20px;

    font-weight:700;

    color:#ffffff;

}


/* ==========================
   COLONNE DROITE
========================== */

.devis-right{

    position:relative;

    z-index:5;

}


/* ==========================
   EN-TÊTE
========================== */

.devis-header{

    margin-bottom:22px;

}

.devis-header h2{

    margin:0;

    font-size:50px;

    font-weight:900;

    line-height:1.05;

    text-transform:uppercase;

    letter-spacing:1px;

    color:#ffffff;

    text-rendering:optimizeLegibility;

}

.devis-header h2 span{

    display:inline-block;

    color:#ff2ea8;

    text-shadow:
        0 0 12px rgba(255,46,168,.70),
        0 0 30px rgba(255,46,168,.35);

}

.devis-header h2::after{

    content:"";

    display:block;

    width:860px;

    height:4px;

    margin-top:16px;

    border-radius:50px;

    background:linear-gradient(
        90deg,
        #00d9ff,
        #ff2ea8
    );

    box-shadow:
        0 0 15px #00d9ff,
        0 0 30px #ff2ea8;

}


/* ==========================
   INTRODUCTION
========================== */

.devis-intro{

    margin:12px 0 18px;

    font-size:18px;

    line-height:1.5;

    font-style:italic;

    font-weight:500;

    color:rgba(255,255,255,.92);

    max-width:100%;

}

/* ==========================================================
   BLOC 2
   FORMULAIRE • BADGES • BOUTON
========================================================== */


/* ==========================
   BLOC FORMULAIRE
========================== */

.formulaire-glass{

    position:relative;

    padding:16px;

    border-radius:30px;

    background:rgba(18,22,40,.45);

    backdrop-filter:blur(20px);

    border:1px solid rgba(0,217,255,.20);

    margin-top:-15px;

    transition:.35s;

    box-shadow:

    0 30px 70px rgba(0,0,0,.45),

    inset 0 1px 0 rgba(255,255,255,.08),

    0 0 25px rgba(0,217,255,.08);

}


/* Halo interne */

.formulaire-glass::before{

    content:"";

    position:absolute;

    inset:0;

    border-radius:30px;

    padding:1px;

    background:linear-gradient(
        135deg,
        rgba(0,217,255,.45),
        rgba(255,46,168,.35)
    );

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);

    -webkit-mask-composite:xor;

            mask-composite:exclude;

    pointer-events:none;

}


/* ==========================
   FORMULAIRE
========================== */

.devis-form{

    display:flex;

    flex-direction:column;

    gap:18px;

    width:100%;

    max-width:none;

}


/* Ligne simple */

.form-row{

    width:100%;

}


/* Ligne double */

.two-cols{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:18px;

}


/* ==========================
   INPUTS
========================== */

.devis-form input:not([type="checkbox"]),
.devis-form textarea,
.devis-form select{

    width:100%;

    box-sizing:border-box;

    border:none;

    outline:none;

    border-radius:16px;

    padding:14px 18px;

    font-size:16px;

    font-family:inherit;

    color:#ffffff;

    background:rgba(255,255,255,.07);

    border:1px solid rgba(255,255,255,.10);

    transition:.35s;

}


/* Placeholder */

.devis-form input::placeholder,
.devis-form textarea::placeholder{

    color:rgba(255,255,255,.65);

}


/* Focus */

.devis-form input:focus,
.devis-form select:focus,
.devis-form textarea:focus{

    border-color:#00d9ff;

    box-shadow:

        0 0 0 3px rgba(0,217,255,.12),

        0 0 18px rgba(0,217,255,.35);
    
    background:rgba(255,255,255,.10);

    transform:translateY(-2px);
}


/* Textarea */

.devis-form textarea{

    min-height:50px;

    height:55px;

    resize:vertical;

    line-height:1.5;

}


/* Select */

.devis-form select{

    cursor:pointer;

}

/* ==========================
   BADGES
========================== */

.badges{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:12px;

    margin:14px 0 22px;

}

.badge{

    position:relative;

    display:flex;

    align-items:center;

    gap:12px;

    min-height:68px;

    padding:12px 16px;

    border-radius:18px;

    background:rgba(255,255,255,.05);

    border:1px solid rgba(255,255,255,.08);

    backdrop-filter:blur(12px);

    overflow:hidden;

    transition:.35s;

    cursor:default;

}

.badge:hover{

    transform:translateY(-4px);

    border-color:#00d9ff;

    box-shadow:
        0 0 20px rgba(0,217,255,.22);

}

.badge::before{

    content:"";

    position:absolute;

    top:0;

    left:-120%;

    width:70%;

    height:100%;

    background:linear-gradient(
        90deg,
        transparent,
        rgba(255,255,255,.15),
        transparent
    );

    transition:.8s;

}

.badge:hover::before{

    left:140%;

}

.badge-icon{

    font-size:28px;

    flex-shrink:0;

    transition:.35s;

}
.badge:nth-child(1) .badge-icon{

    color:#ffd53d;
    text-shadow:0 0 12px #ffd53d;

}

.badge:nth-child(2) .badge-icon{

    color:#8fefff;
    text-shadow:0 0 12px #00d9ff;

}

.badge:nth-child(3) .badge-icon{

    color:#ff5cd2;
    text-shadow:0 0 12px #ff2ea8;

}
.badge:hover .badge-icon{

    transform:scale(1.12);

}

.badge-text{

    font-size:14px;

    line-height:1.35;

    color:#fff;

}


/* ==========================
   FORMULAIRE
========================== */

.formulaire-glass:hover{

    box-shadow:
        0 25px 70px rgba(0,0,0,.50),
        0 0 30px rgba(0,217,255,.15);

}

.devis-form input:hover,
.devis-form textarea:hover,
.devis-form select:hover{

    border-color:rgba(0,217,255,.45);

}

.devis-form input,
.devis-form textarea,
.devis-form select{

    appearance:none;

    -webkit-appearance:none;

    transition:
        border-color .30s,
        box-shadow .30s,
        background .30s,
        transform .20s;

}

.devis-form input:focus,
.devis-form textarea:focus,
.devis-form select:focus{

    transform:translateY(-1px);

}

.devis-form textarea{

    line-height:1.6;

}


/* ==========================
   BOUTON
========================== */

.btn-devis-v2{

    position:relative;

    overflow:hidden;

    margin-top:0px;

    width:100%;

    display:flex;

    justify-content:center;

    align-items:center;

    gap:12px;

    min-height:60px;

    padding:15px 22px;

    border:none;

    border-radius:18px;

    cursor:pointer;

    font-size:18px;

    font-weight:700;

    color:#ffffff;

    letter-spacing:.4px;

    background:linear-gradient(
    90deg,
    #00bfff,
    #ff2ea8

    );

    background-size:200%;
    animation:boutonGradient 8s linear infinite;
    
    transition:.35s;

    box-shadow:
        0 12px 35px rgba(255,46,168,.25);

}

.btn-devis-v2::before{

    content:"";

    position:absolute;

    top:0;

    left:-150%;

    width:80%;

    height:100%;

    background:linear-gradient(
        90deg,
        transparent,
        rgba(255,255,255,.30),
        transparent
    );

    transition:.8s;

}

.btn-devis-v2:hover::before{

    left:150%;

}

.btn-devis-v2:hover{

    filter:brightness(1.05);

}

.btn-devis-v2:focus{

    outline:none;

    box-shadow:
        0 0 0 4px rgba(0,217,255,.18),
        0 0 30px rgba(0,217,255,.35);

}
/* ==========================================================
   BLOC 3
   RGPD
========================================================== */


/* ==========================
   RGPD
========================== */

.rgpd{

    display:flex;

    align-items:flex-start;

    gap:15px;

    margin-top:2px;

    margin-bottom:-8px;

}

.rgpd input[type="checkbox"]{

    appearance:auto;
    -webkit-appearance:checkbox;

    width:22px;
    height:22px;

    cursor:pointer;

    accent-color:#00d9ff;

}

.rgpd label{

    color:rgba(255,255,255,.88);

    font-size:14px;

    line-height:1.6;

}


/* ==========================
   HONEYPOT
========================== */

.honeypot{

    display:none;

}


/* ==========================
   BOUTON
========================== */

.btn-devis-v2:hover{

    transform:translateY(-4px);

    box-shadow:
        0 20px 45px rgba(255,46,168,.40);

}

.btn-devis-v2:active{

    transform:scale(.98);

}

.btn-icon{

    font-size:22px;

}

.btn-text{

    letter-spacing:.5px;

}


/* ==========================
   PETITES FINITIONS
========================== */


.devis-form select option{

    color:#222;

}

.devis-form input[type="date"]{

    color:#ffffff;

}
.date-mobile label{

    display:none;

}
.devis-form input[type="date"]::-webkit-calendar-picker-indicator{

    cursor:pointer;

    filter:invert(1);

}
/* ==========================================================
   BLOC 4
   ANIMATIONS
========================================================== */

/* ==========================
   ANIMATIONS D'APPARITION
========================== */

.devis-left,
.devis-right{

    animation:fadeUp .8s ease both;

}

.devis-right{

    animation-delay:.15s;

}

@keyframes fadeUp{

    from{

        opacity:0;
        transform:translateY(35px);

    }

    to{

        opacity:1;
        transform:translateY(0);

    }

}


/* ==========================
   ANIMATIONS PHOTO
========================== */

.photo-wrapper:hover .photo-yoyo{

    transform:scale(1.015);

    filter:
        drop-shadow(0 0 55px rgba(0,217,255,.45))
        drop-shadow(0 0 130px rgba(255,46,168,.30));

}

.photo-wrapper:hover .dj{

    text-shadow:
        0 0 18px #00d9ff,
        0 0 45px #00d9ff;

}

.photo-wrapper:hover .yoyo{

    text-shadow:
        0 0 18px #ff2ea8,
        0 0 45px #ff2ea8;

}


/* ==========================
   QUALITÉ D'AFFICHAGE
========================== */

.devis-v2 img{

    display:block;

    max-width:100%;

}

.devis-v2 input,
.devis-v2 textarea,
.devis-v2 select,
.devis-v2 button{

    font-family:inherit;

}

.devis-v2 ::selection{

    background:#00d9ff;

    color:#ffffff;

}

.form-row:last-child{

    margin-bottom:0;

}


/* ==========================
   ACCESSIBILITÉ
========================== */

.devis-form input:focus-visible,
.devis-form textarea:focus-visible,
.devis-form select:focus-visible,
.btn-devis-v2:focus-visible{

    outline:none;

}
/* ==========================================================
   BLOC 5
   RESPONSIVE
========================================================== */


/* ==========================
   TABLETTES
========================== */

@media (max-width:1200px){

    .devis-container{

        grid-template-columns:1fr;

        gap:50px;

    }

    .devis-left{

        justify-content:center;

    }

    .photo-yoyo{

        max-width:340px;

    }

    .logo-yoyo{

        left:50%;

        bottom:35px;

        transform:
            translateX(-50%)
            scale(.80);

        text-align:center;

    }

    .devis-header{

        text-align:center;

    }

    .devis-header h2{

        font-size:48px;

    }

    .devis-header h2::after{

        margin:18px auto 0;

    }

    .devis-intro{

        text-align:center;

    }

    .badges{

        grid-template-columns:repeat(2,1fr);

    }

}


/* ==========================
   SMARTPHONES
========================== */

@media (max-width:768px){

    .devis-v2{

        padding:60px 20px;

    }

    .devis-form textarea{

    min-height:90px;

    height:90px;

}

    .devis-container{

        gap:35px;

    }

    .photo-yoyo{

        max-width:280px;

    }

    .logo-yoyo{

        position:relative;

        left:auto;

        bottom:auto;

        transform:none;

        margin-top:-20px;

        text-align:center;

    }

    .logo-yoyo .dj,
    .logo-yoyo .yoyo{

        font-size:48px;

    }

    .logo-yoyo .animation{

        font-size:16px;

        letter-spacing:5px;

    }
    .date-mobile label{

    display:block;

    color:#ffffff;

    font-size:15px;

    font-weight:600;

    margin-bottom:8px;

}
    .devis-header{

        text-align:center;

    }

    .devis-header h2{

        font-size:36px;

    }

    .devis-header h2::after{

        width:320px;

        margin-inline:auto;

    }

    .devis-intro{

        text-align:center;

        font-size:17px;

    }

    .badges{

        grid-template-columns:1fr;

    }

    .badge{

        min-height:60px;

    }

    .two-cols{

        grid-template-columns:1fr;

    }

    .formulaire-glass{

        padding:22px;

    }

    .btn-devis-v2{

    min-height:56px;

    padding:14px 18px;

    font-size:16px;

    gap:8px;

}
.btn-text{

    line-height:1.25;

    text-align:center;

    white-space:normal;

}
.btn-icon{

    font-size:18px;

    flex-shrink:0;

}

}


/* ==========================
   PETITS SMARTPHONES
========================== */

@media (max-width:480px){

    .photo-yoyo{

        max-width:230px;

    }

    .devis-header h2{

        font-size:30px;

    }

    .devis-intro{

        font-size:16px;

    }

    .badge{

        padding:12px;

    }

    .badge-icon{

        font-size:20px;

    }

    .badge-text{

        font-size:13px;

    }

    .formulaire-glass{

        padding:18px;

        border-radius:22px;

    }

    .devis-form input,
    .devis-form textarea,
    .devis-form select{

        font-size:15px;

        padding:15px;

    }

}
@keyframes boutonGradient{

    0%{
        background-position:0% 50%;
    }

    100%{
        background-position:200% 50%;
    }

}