/* =========================================
   OTTONOWMY IDEA — NEO BRUTAL UI
   Compatible avec TON HTML
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;700;800;900&display=swap');

:root{

    --primary:#6366f1;
    --primary-light:#818cf8;

    --accent:#ff3e8d;

    --dark:#111827;

    --white:#ffffff;

    --gray:#f3f4f6;

    --gray-2:#e5e7eb;

    --success:#00d26a;

    --danger:#ff4d4d;

    --gold:#ffb800;

    --radius:28px;

    --brutal:
        4px solid var(--dark);

    --shadow:
        8px 8px 0px var(--dark);

    --shadow-hover:
        14px 14px 0px var(--dark);

}

/* =========================================
   RESET
   ========================================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    font-family:'Outfit',sans-serif;

    background:
        linear-gradient(
            135deg,
            rgba(99,102,241,0.15) 0%,
            rgba(99,102,241,0.08) 25%,
            rgba(255,62,141,0.08) 75%,
            rgba(255,62,141,0.12) 100%
        ),
        radial-gradient(
            ellipse at top left,
            rgba(255,184,0,0.08),
            transparent 60%
        ),
        radial-gradient(
            ellipse at bottom right,
            rgba(0,210,106,0.08),
            transparent 60%
        ),
        #f9fafb;

    color:var(--dark);

    overflow-x:hidden;

    line-height:1.5;

    background-attachment:fixed;
}

/* =========================================
   GLOBAL
   ========================================= */

.container{

    width:min(100%,1100px);

    margin:auto;

    padding:0 5%;
}

section{
    position:relative;
}

h1,h2,h3{
    letter-spacing:-2px;
}

img{
    display:block;
    max-width:100%;
}

/* =========================================
   HEADER
   ========================================= */

.header{

    position:sticky;
    top:0;

    z-index:999;

    background:
        rgba(255,255,255,0.8);

    backdrop-filter:blur(12px);

    border-bottom:
        2px solid rgba(0,0,0,0.06);

    padding:18px 0;
    
    overflow:hidden;
}

.header-content{

    display:flex;
    align-items:center;
    gap:16px;
}

.btn {
    display: inline-block;

    width: auto;

    padding: 20px;

    border: var(--brutal);
    border-radius: 999px;

    background: var(--primary);
    color: white;

    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    font-weight: 900;
    text-transform: uppercase;

    text-decoration: none;
    text-align: center;

    cursor: pointer;

    transition: 0.35s cubic-bezier(.16, 1, .3, 1);

    box-shadow: var(--shadow);
}

.btn:hover {
    background: var(--accent);

    transform:
        translate(-6px, -6px)
        rotate(-1deg);

    box-shadow: var(--shadow-hover);
}

.logo{

    width:58px;
    height:58px;

    object-fit:cover;

    border-radius:20px;

    border:var(--brutal);

    box-shadow:
        5px 5px 0px var(--dark);

    background:white;
}

.header h1{

    font-size:1.1rem;

    font-weight:900;

    text-transform:uppercase;
    
    letter-spacing:-1px;
}

/* =========================================
   HERO
   ========================================= */

.hero{

    padding:
        120px 0
        100px;

    overflow:hidden;
}

.hero::before{

    content:"";

    position:absolute;

    inset:-20%;

    background:
        linear-gradient(
            135deg,
            var(--primary),
            var(--accent)
        );

    opacity:0.12;

    filter:blur(120px);

    animation:bgMove 12s linear infinite;

    z-index:-1;
}

.hero-progress{

    margin-bottom:60px;
}

.hero-progress-label{

    font-size:1.1rem;
    
    font-weight:700;
    
    text-transform:uppercase;
    
    letter-spacing:2px;
    
    margin-bottom:16px;
    
    color:var(--dark);
}

.hero-progress-display{

    display:flex;
    gap:24px;
    align-items:center;
}

.hero-progress-bar{

    flex:1;
    height:60px;
    
    background:var(--gray);
    
    border-radius:999px;
    
    overflow:hidden;
    
    box-shadow:inset 0 2px 8px rgba(0,0,0,0.1);
    
    border:var(--brutal);
}

.hero-progress-fill{

    height:100%;
    width:0%;
    
    background:linear-gradient(
        90deg,
        var(--primary),
        var(--accent)
    );
    
    transition:1s cubic-bezier(.16,1,.3,1);
    
    box-shadow:0 0 40px var(--primary),
                inset 0 1px 0 rgba(255,255,255,0.5);
    
    position:relative;
}

.hero-progress-fill::after{

    content:"";
    
    position:absolute;
    
    inset:0;
    
    background:linear-gradient(
        120deg,
        transparent,
        rgba(255,255,255,0.4),
        transparent
    );
    
    animation:shine 2s linear infinite;
}

.hero-progress-counter{

    font-size:1.4rem;
    
    font-weight:900;
    
    color:var(--primary);
    
    letter-spacing:-1px;
    
    white-space:nowrap;
    
    min-width:80px;
}

.tagline{
    margin-top: -4%;

    font-size:
        clamp(3rem,4vw,4rem);

    line-height:0.95;

    font-weight:900;

    max-width:900px;

    text-transform:uppercase;

    letter-spacing:-3px;
}

.tagline::after{

    content:"";

    display:block;

    width:120px;
    height:10px;

    background:var(--accent);

    margin-top:28px;

    border-radius:999px;
}

/* =========================================
   PROGRESS SECTION
   ========================================= */

.progress-section{

    padding-bottom:100px;
}

.progress-card{

    background:transparent;

    border:none;

    border-radius:0;

    padding:40px 0;

    box-shadow:none;

    transition:0.35s ease;
}

.progress-card:hover{

    transform:none;

    box-shadow:none;
}

.progress-header{

    display:flex;
    justify-content:space-between;
    align-items:center;

    margin-bottom:24px;
}

.progress-header h2{

    font-size:3rem;

    text-transform:uppercase;

    font-weight:900;
    
    letter-spacing:-2px;
}

.progress-counter{

    background:var(--primary);

    color:white;

    padding:12px 20px;

    border-radius:999px;

    border:var(--brutal);

    font-weight:900;

    box-shadow:
        4px 4px 0px var(--dark);

    font-size:1.1rem;
}

.separator{
    opacity:0.7;
}

.progress-bar{

    width:100%;

    height:40px;

    background:var(--gray);

    border-radius:999px;

    overflow:hidden;

    margin-bottom:18px;
    
    box-shadow:inset 2px 2px 4px rgba(0,0,0,0.1);
}

.progress-fill{

    width:0%;

    height:100%;

    background:
        linear-gradient(
            90deg,
            var(--primary),
            var(--accent)
        );

    transition:
        1s cubic-bezier(.16,1,.3,1);

    position:relative;
}

.progress-fill::after{

    content:"";

    position:absolute;

    inset:0;

    background:
        linear-gradient(
            120deg,
            transparent,
            rgba(255,255,255,0.4),
            transparent
        );

    animation:shine 2s linear infinite;
}

.progress-text{

    font-size:1.1rem;

    font-weight:700;
}

/* =========================================
   ABOUT
   ========================================= */

.about-section{

    padding-bottom:100px;
}

.about-section h2,
.testimonial-form-section h2,
.testimonials-section h2{

    font-size:
        clamp(2.2rem,5vw,4rem);

    font-weight:900;

    text-transform:uppercase;

    margin-bottom:20px;
}

.about-section p{

    font-size:1.2rem;

    max-width:700px;

    margin-bottom:50px;
}

.features{

    display:grid;

    grid-template-columns:
        repeat(auto-fit,minmax(250px,1fr));

    gap:28px;
}

.feature{

    background:var(--white);

    border:var(--brutal);

    border-radius:var(--radius);

    padding:36px;

    transition:
        0.35s cubic-bezier(.16,1,.3,1);

    box-shadow:var(--shadow);
}

.feature:hover{

    transform:
        translate(-8px,-8px)
        rotate(-1deg);

    box-shadow:var(--shadow-hover);
}

.feature h3{

    font-size:2rem;

    margin-bottom:12px;

    color:var(--primary);

    font-weight:900;

    text-transform:uppercase;
}

.feature p{

    margin:0;

    font-size:1rem;
}

/* =========================================
   FORM
   ========================================= */

.testimonial-form-section{

    padding-bottom:100px;
}

.form{

    background:white;

    border:var(--brutal);

    border-radius:var(--radius);

    padding:32px;

    box-shadow:var(--shadow);
    
    max-width:700px;
    
    margin:0 auto;
}

.form-group{

    margin-bottom:28px;
}

.form-group label{

    display:block;

    margin-bottom:10px;

    font-size:1rem;

    font-weight:800;

    text-transform:uppercase;
}

.form-group input,
.form-group select,
.form-group textarea{

    width:100%;

    padding:18px 20px;

    border:var(--brutal);

    border-radius:20px;

    font-family:'Outfit',sans-serif;

    font-size:1rem;

    background:var(--gray);

    transition:0.25s ease;
}

.form-group textarea{

    min-height:180px;

    resize:vertical;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{

    outline:none;

    background:white;

    transform:
        translate(-3px,-3px);

    box-shadow:
        6px 6px 0px var(--dark);
}

/* Checkbox */

.form-group.checkbox{

    display:flex;
    align-items:flex-start;

    gap:14px;
}

.form-group.checkbox input{

    width:20px;
    height:20px;

    margin-top:4px;

    accent-color:var(--primary);
}

.form-group.checkbox label{

    font-size:0.95rem;

    line-height:1.5;
}

/* Star Rating */

.star-rating{

    display:flex;
    gap:12px;
    
    margin-top:12px;
}

.star{

    font-size:2.5rem;
    
    cursor:pointer;
    
    color:#d4d4d8;
    
    transition:0.2s ease;
    
    user-select:none;
}

.star:hover,
.star.active{

    color:var(--gold);
    
    transform:scale(1.15);
}

.star.active{

    animation:twinkle 0.3s ease;
}

@keyframes twinkle{
    0%{ transform:scale(1); }
    50%{ transform:scale(1.3); }
    100%{ transform:scale(1.15); }
}

/* Hide the hidden input */

#stars{
    display:none;
}

.btn-submit{

    width:100%;

    padding:20px;

    border:none;

    border-radius:999px;

    background:var(--primary);

    color:white;

    font-family:'Outfit',sans-serif;

    font-size:1rem;

    font-weight:900;

    text-transform:uppercase;

    cursor:pointer;

    transition:
        0.35s cubic-bezier(.16,1,.3,1);

    border:var(--brutal);

    box-shadow:var(--shadow);
}

.btn-submit:hover{

    background:var(--accent);

    transform:
        translate(-6px,-6px)
        rotate(-1deg);

    box-shadow:var(--shadow-hover);
}

/* =========================================
   ALERTS
   ========================================= */

.message{

    padding:20px;

    border-radius:20px;

    margin-bottom:24px;

    font-weight:800;

    border:var(--brutal);

    display:none;
}

.success-message{

    background:
        rgba(0,210,106,0.15);

    color:var(--dark);
}

.error-message{

    background:
        rgba(255,77,77,0.15);

    color:var(--dark);
}

/* =========================================
   TESTIMONIALS
   ========================================= */

.testimonials-section{

    padding-bottom:120px;
}

.testimonials-list{

    display:grid;

    gap:28px;
}

.testimonial-card{

    background:white;

    border:var(--brutal);

    border-radius:var(--radius);

    padding:32px;

    box-shadow:var(--shadow);

    transition:0.3s ease;
}

.testimonial-card:hover{

    transform:
        translate(-8px,-8px);

    box-shadow:var(--shadow-hover);
}

.testimonial-header{

    display:flex;
    justify-content:space-between;
    align-items:center;

    margin-bottom:18px;
}

.testimonial-author{

    font-size:1.2rem;

    font-weight:900;

    text-transform:uppercase;
}

.testimonial-stars{

    color:var(--gold);

    font-size:1.1rem;

    letter-spacing:2px;
}

.testimonial-body{

    font-size:1rem;

    line-height:1.7;
}

.empty-state{

    background:white;

    border:var(--brutal);

    border-radius:var(--radius);

    padding:60px 30px;

    text-align:center;

    box-shadow:var(--shadow);

    font-weight:800;

    text-transform:uppercase;
}

/* =========================================
   FOOTER
   ========================================= */

.footer{

    background:var(--primary);

    color:white;

    padding:60px 0;

    text-align:center;

    text-transform:uppercase;

    font-weight:900;

    letter-spacing:2px;
}

/* =========================================
   ANIMATIONS
   ========================================= */

@keyframes shine{

    from{
        transform:translateX(-100%);
    }

    to{
        transform:translateX(100%);
    }
}

@keyframes bgMove{

    0%{
        transform:
            translate(0,0)
            rotate(0deg);
    }

    50%{
        transform:
            translate(-40px,40px)
            rotate(8deg);
    }

    100%{
        transform:
            translate(0,0)
            rotate(0deg);
    }
}

/* =========================================
   RESPONSIVE
   ========================================= */

@media(max-width:768px){

    .tagline{

        font-size:3.2rem;

        line-height:1;
    }

    .progress-header{

        flex-direction:column;
        align-items:flex-start;

        gap:18px;
    }

    .form{
        padding:30px;
    }

    .feature h3{
        font-size:1.5rem;
    }

}

@media(max-width:480px){

    .tagline{
        font-size:2.5rem;
    }

    .header h1{
        font-size:1.2rem;
    }

    .logo{

        width:48px;
        height:48px;
    }

    .progress-card,
    .feature,
    .testimonial-card{
        padding:24px;
    }

}

