:root{
    --pink1:#d45fa1;
    --pink2:#b13c8c
}
*{
    margin:0;
    padding:0;
    box-sizing:border-box
}
body,html{
    width:100%;
    height:100%!important;
    font-family:'Playfair Display',serif
}
a{
    text-decoration:none;
    color:#fff
}
body{
    font-family:'Segoe UI',Arial,sans-serif;
    background:#f8f8f8;
    color:#222;
    margin:0;
    padding:0;
    line-height:1.7
}
.container{
    max-width:900px;
    margin:0 auto;
    padding:32px 16px
}
header{
    background:#fff;
    box-shadow:0 2px 10px rgba(0,0,0,.07);
    position:sticky;
    top:0;
    z-index:100
}
header h1{
    margin:0;
    padding:16px 0 8px 0;
    font-size:2.4rem
}
nav ul{
    list-style:none;
    display:flex;
    gap:24px;
    padding:0;
    margin:0
}
nav a{
    text-decoration:none;
    color:var(--pink1);
    font-weight:500
}
section{
    color:#fff;
    margin:32px 0;
    border-radius:16px;
    box-shadow:0 1px 5px rgba(0,0,0,.04)
}
#omnie{
    margin:0
}
section h2{
    color:var(--pink1);
    margin-bottom:18px
}
ul{
    padding-left:20px
}
form{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-top:18px;
    margin-bottom:16px
}
input,textarea{
    padding:8px;
    border:1px solid #ccc;
    border-radius:8px
}
button{
    background:var(--pink1);
    color:#fff;
    padding:10px 22px;
    border:none;
    border-radius:8px;
    font-size:1rem;
    cursor:pointer;
    transition:background .2s
}
footer{
    background:#222;
    color:#fff;
    text-align:center;
    padding:20px 0;
    font-size:1rem;
    margin-top:40px
}
.map-responsive{
    overflow:hidden;
    padding-bottom:56.25%;
    position:relative;
    height:0
}
.map-responsive iframe{
    left:0;
    top:0;
    height:100%;
    width:100%;
    position:absolute;
    border:0
}
@media (max-width:700px){
    .container{
        padding:18px 8px
    }
    nav ul{
        flex-direction:column;
        gap:12px
    }
    header h1{
        font-size:1.2rem
    }
}
.hero-header{
    position:relative;
    width:100%;
    min-height:unset;
    height:100dvh;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center
}
.hero-header video{
    position:absolute;
    top:0;
    left:0;
    width:100vw;
    height:100vh;
    min-width:100%;
    min-height:100%;
    object-fit:cover;
    z-index:1;
    pointer-events:none
}
@media (max-width:700px){
    .hero-header{
        height:var(--header-h,100dvh)
    }
    .hero-header video{
        height:100svh
    }
    .header-content h1{
        font-size:1.4rem
    }
    .header-content p{
        font-size:1rem
    }
}
.header-content{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center
}

main{
    position:relative
}
main::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:80px;
    z-index:2;
    pointer-events:none;
    background:linear-gradient(to bottom,#142016 0,rgba(20,32,22,.7) 30%,rgba(20,32,22,0) 100%)
}
header::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    height:80px;
    z-index:2;
    pointer-events:none;
    background:linear-gradient(to top,#142016 0,rgba(20,32,22,.7) 30%,rgba(20,32,22,0) 100%)
}
.header-logo{
    width:80%;
    height:auto;
    filter:drop-shadow(0 2px 16px #2228)
}
.header-nav{
    display:flex;
    gap:32px;
    display:flex;
    flex-direction:column
}
.header-nav .nav-link{
    color:#fff;
    background:rgba(0,0,0,.24);
    text-decoration:none;
    font-size:1.15rem;
    padding:8px 22px;
    border-radius:16px;
    transition:background .2s,color .2s
}
.header-nav .nav-link:hover{
    background:#fff4;
    color:var(--pink1)
}
.visit-btn{
    display:inline-block;
    background:var(--pink1);
    color:#fff;
    font-weight:700;
    padding:12px 30px;
    border:none;
    border-radius:22px;
    font-size:1.2rem;
    text-decoration:none;
    box-shadow:0 3px 18px var(--pink1);
    transition:background .2s,color .2s
}
.visit-btn:hover{
    background:#fff;
    color:var(--pink1);
    box-shadow:0 3px 30px var(--pink1)
}
@media (max-width:700px){
    .header-content{
        min-height:50vh
    }
    .header-logo{
        width:70%
    }
    .header-nav{
        gap:14px
    }
    .visit-btn{
        font-size:1rem;
        padding:10px 18px
    }
}
.background-fixed{
    position:fixed;
    top:0;
    left:0;
    width:100vw;
    height:100vh;
    background:url(tlo.webp) center center/cover no-repeat;
    z-index:-999;
    pointer-events:none;
    user-select:none
}
@media (max-width:768px){
    body{
        background-attachment:scroll!important
    }
    .background-fixed{
        background:url(tlo2.webp) calc(50% + 40px) center/cover no-repeat
    }
}
.about-me-section{
    padding:70px 20px;
    display:flex;
    justify-content:center
}
.about-me-container,.circle-img{
    align-items:center;
    display:flex
}
.about-me-container{
    max-width:1100px;
    width:100%;
    gap:60px
}
.about-me-photo{
    flex:0 0 260px;
    display:flex;
    align-items:center;
    justify-content:center
}
.about-me-photo img{
    width:240px;
    height:340px;
    object-fit:cover;
    border-radius:24px;
    border:4px solid #e9b9d6;
    box-shadow:0 8px 32px rgba(0,0,0,.12);
    background:#fff
}
.about-me-content{
    flex:1;
    color:#fff
}
.about-me-content h2{
    color:#d45fa1;
    font-size:2.1rem;
    margin-bottom:20px
}
.about-me-content p{
    font-size:1.15rem;
    line-height:1.8;
    color:#fff
}
@media (max-width:900px){
    .about-me-container{
        flex-direction:column;
        gap:32px;
        text-align:center
    }
    .about-me-photo img{
        width:350px;
        height:350px
    }
    .about-me-content h2{
        font-size:1.3rem
    }
    .about-me-section{
        padding:40px 10px
    }
}
.packages-section{
    padding:60px 40px;
    color:#fff
}
.packages-header{
    text-align:center;
    margin-bottom:50px
}
.packages-header h2{
    font-family:'Playfair Display',serif;
    font-size:2.5rem;
    color:#fff;
    margin-bottom:15px
}
.packages-header .packages-description{
    font-size:1rem;
    color:#fff;
    max-width:700px;
    margin:0 auto;
    line-height:1.6
}
.packages-container{
    display:flex;
    justify-content:center;
    gap:40px;
    flex-wrap:wrap
}
.package-card{
    width:300px;
    border-radius:8px;
    box-shadow:0 2px 8px rgba(0,0,0,.1);
    overflow:hidden;
    display:flex;
    flex-direction:column;
    transition:transform .2s,box-shadow .2s
}
.package-card:hover{
    transform:translateY(-5px);
    box-shadow:0 4px 12px rgba(0,0,0,.15)
}
.package-image{
    width:100%;
    height:200px;
    overflow:hidden
}
.package-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block
}
.package-title{
    font-size:1.4rem;
    color:#d45fa1;
    margin:20px 15px 10px
}
.package-text{
    font-size:.95rem;
    color:#fff;
    margin:0 15px 15px;
    line-height:1.5;
    flex-grow:1
}
.package-price{
    margin:0 15px 20px;
    color:#fff;
    font-weight:700;
    font-size:1.1rem
}
.package-button{
    display:inline-block;
    padding:10px 20px;
    background-color:#d45fa1;
    text-decoration:none;
    font-size:1rem;
    border-radius:4px;
    text-align:center;
    transition:background-color .2s,transform .2s;
    margin:0 15px 20px;
    color:#fff;
    font-weight:700
}
.package-button:hover{
    background-color:#b33791;
    transform:translateY(-2px)
}
@media (max-width:768px){
    .packages-section{
        padding:50px 20px
    }
    .packages-header h2{
        font-size:2rem
    }
    .packages-header .packages-description{
        font-size:.95rem;
        max-width:90%
    }
    .packages-container{
        gap:30px
    }
    .package-card{
        width:100%;
        max-width:350px
    }
    .package-image{
        height:180px
    }
    .package-title{
        font-size:1.3rem;
        margin:15px 10px 8px
    }
    .package-text{
        font-size:.9rem;
        margin:0 10px 12px
    }
    .package-price{
        font-size:1rem;
        margin:0 10px 15px
    }
    .package-button{
        padding:8px 18px;
        font-size:.95rem;
        margin:0 10px 15px
    }
}
.site-footer{
    color:#eee;
    font-family:Arial,sans-serif;
    padding:60px 40px 20px;
    margin-left:auto;
    margin-right:auto;
    position:relative;
    z-index:2;
    background:rgba(50,50,50,.5);
    backdrop-filter:blur(4px)
}
.footer-container{
    display:flex;
    flex-wrap:wrap;
    gap:40px;
    justify-content:space-between;
    max-width:1200px;
    margin:0 auto;
    text-align:center
}
.footer-col{
    flex:1;
    min-width:200px;
    color:#eee
}
.footer-logo-col .footer-logo img{
    max-height:90px;
    width:auto;
    margin-bottom:15px
}
.footer-logo-col .footer-tagline{
    font-size:.95rem;
    line-height:1.6;
    color:#ccc
}
.footer-contact-col h4,.footer-nav-col h4,.footer-social-col h4{
    font-family:'Playfair Display',serif;
    font-size:1.3rem;
    margin-bottom:15px;
    color:#fff
}
.footer-contact-col a,.footer-nav-list a,.social-list a{
    color:#ccc;
    transition:color .2s;
    text-decoration:none
}
.footer-nav-list,.social-list{
    list-style:none;
    padding:0
}
.footer-nav-list li+li,.social-list li+li{
    margin-top:10px
}
.footer-nav-list a,.social-list a{
    font-size:.95rem
}
.footer-contact-col a:hover,.footer-nav-list a:hover,.social-list a:hover{
    color:#fff
}
.footer-contact-col p{
    font-size:.95rem;
    line-height:1.6;
    margin-bottom:10px
}
.social-list{
    margin-bottom:20px
}
.footer-credit p{
    font-size:.85rem;
    color:#fff;
    margin-top:20px
}
@media (max-width:768px){
    .site-footer{
        padding:50px 20px 20px
    }
    .footer-col{
        min-width:100%
    }
    .footer-contact-col p,.footer-credit p,.footer-logo-col .footer-tagline,.footer-nav-list a,.social-list a{
        font-size:.95rem
    }
}
.problems-section{
    padding:65px 20px 50px
}
.problems-header{
    text-align:center;
    margin-bottom:36px
}
.problems-header h2{
    color:#d45fa1;
    font-size:2.3rem;
    margin-bottom:10px
}
.problems-header p{
    font-size:1.1rem;
    color:#fff
}
.problems-circles{
    display:flex;
    justify-content:center;
    gap:40px;
    flex-wrap:wrap
}
.problem-circle{
    width:142px;
    display:flex;
    flex-direction:column;
    align-items:center;
    cursor:pointer;
    transition:transform .16s,box-shadow .18s;
    position:relative;
    border:none;
    background:0 0;
    padding:0
}
.circle-img{
    width:120px;
    height:120px;
    border-radius:50%;
    overflow:hidden;
    box-shadow:0 4px 24px rgba(212,95,161,.1);
    border:4px solid #ffe0f5;
    margin-bottom:12px;
    background:#fff6e3;
    transition:box-shadow .18s,border .18s;
    justify-content:center;
    display:flex;
    align-items:center
}
.problem-circle span{
    color:#a83b8e;
    font-size:1rem;
    text-align:center;
    font-weight:500;
    line-height:1.25;
    margin-top:0;
    font-weight:700
}
.problem-circle:focus .circle-img,.problem-circle:hover .circle-img{
    box-shadow:0 8px 34px 0 #d45fa135,0 0 0 6px #ffb8ea50;
    border:4px solid #d45fa1
}
.problem-circle:focus,.problem-circle:hover{
    transform:scale(1.07) translateY(-6px);
    z-index:2;
    outline:0
}
@media (max-width:900px){
    .problems-circles{
        gap:20px
    }
    .problem-circle{
        width:110px
    }
    .circle-img{
        width:85px;
        height:85px;
        margin-bottom:9px
    }
}
.contact-section{
    padding:60px 40px;
    color:#fff;
    font-family:Arial,sans-serif
}
.contact-header{
    text-align:center;
    margin-bottom:40px
}
.contact-header h2{
    font-size:2.5rem;
    color:#fff;
    margin-bottom:15px;
    font-family:'Playfair Display',serif
}
.contact-description{
    font-size:1rem;
    color:#fff;
    max-width:600px;
    margin:0 auto;
    line-height:1.6
}
.contact-container{
    display:flex;
    gap:0;
    justify-content:center;
    align-items:flex-start;
    flex-wrap:wrap
}
.contact-info{
    flex:1;
    min-width:280px;
    max-width:350px
}
.info-item{
    margin-bottom:25px
}
.info-item h3{
    font-size:1.3rem;
    color:#fff;
    margin-bottom:8px
}
.info-item p{
    font-size:1rem;
    color:#fff;
    line-height:1.5
}
.info-item a{
    color:#fff;
    text-decoration:none;
    transition:color .2s
}
.info-item a:hover{
    color:#000
}
.contact-form{
    flex:1;
    min-width:280px;
    max-width:450px;
    display:flex;
    flex-direction:column
}
.contact-form label{
    font-size:1.05rem;
    color:#d45fa1;
    margin-bottom:6px;
    margin-top:12px;
    display:block;
    font-weight:700
}
.contact-form input,.contact-form textarea{
    width:100%;
    padding:12px 15px;
    margin-bottom:20px;
    border:1px solid #fec5f6;
    border-radius:4px;
    font-size:1rem;
    color:#000;
    background-color:#db8dd0;
    transition:border-color .2s,background-color .2s
}
.contact-form input:focus,.contact-form textarea:focus{
    border-color:#777;
    background-color:#db8dd0;
    outline:0
}
.contact-form select{
    padding:12px 15px;
    border:1px solid #ccc;
    border-radius:4px;
    font-size:1rem;
    background-color:#db8dd0;
    margin-bottom:18px;
    margin-top:4px;
    width:100%;
    color:#fff;
    transition:border-color .2s,background-color .2s
}
.contact-form select:focus{
    border:1px solid #e0b3e6;
    background:#db8dd0
}
.contact-form textarea{
    resize:vertical;
    min-height:120px
}
.contact-form input[type=file]{
    background:#db8dd0;
    border:1.5px solid #f4c5e0;
    padding:10px 12px;
    color:#b13c8c;
    font-size:.98rem
}
.contact-form .checkbox-label{
    display:flex;
    align-items:flex-start;
    font-size:.97rem;
    color:#fff;
    gap:7px;
    margin:10px 0 22px;
    font-family:Arial,sans-serif
}
.contact-form input[type=checkbox]{
    accent-color:#d45fa1;
    width:18px;
    height:18px;
    margin-right:7px
}
.contact-form button{
    align-self:flex-start;
    background:#d45fa1;
    color:#fff;
    font-size:1.09rem;
    font-weight:600;
    border-radius:5px;
    padding:13px 32px;
    border:none;
    margin-top:8px;
    cursor:pointer;
    box-shadow:0 4px 20px #d45fa122;
    transition:background .17s,transform .13s
}
.contact-form button:hover{
    background:#b13c8c;
    transform:translateY(-2px) scale(1.04)
}
@media (max-width:768px){
    .contact-section{
        padding:40px 20px
    }
    .contact-header h2{
        font-size:2rem
    }
    .contact-description{
        font-size:.95rem;
        max-width:90%
    }
    .contact-container{
        flex-direction:column;
        gap:30px;
        align-items:center
    }
    .contact-form,.contact-info{
        max-width:100%
    }
    .contact-form{
        align-items:center;
        text-align:center
    }
    .contact-form input,.contact-form textarea{
        font-size:.95rem;
        padding:10px 12px;
        width:85%
    }
    .contact-form select{
        width:85%
    }
    .contact-form button{
        padding:10px 25px;
        font-size:1rem;
        align-self:auto
    }
}
.nails-section{
    padding:60px 40px
}
.nails-header{
    text-align:center;
    margin-bottom:40px
}
.nails-header h2{
    color:#d45fa1;
    font-size:2.3rem;
    margin-bottom:12px;
    font-family:'Playfair Display',serif
}
.nails-description{
    font-size:1.08rem;
    color:#fff;
    max-width:600px;
    margin:0 auto;
    line-height:1.6
}
.nails-container{
    display:flex;
    gap:40px;
    justify-content:center;
    flex-wrap:wrap;
    margin-bottom:40px
}
.nail-card{
    border-radius:12px;
    box-shadow:0 4px 18px #d45fa122;
    width:280px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    align-items:center;
    transition:box-shadow .2s,transform .2s
}
.nail-card:hover{
    box-shadow:0 6px 26px #d45fa155;
    transform:translateY(-4px) scale(1.03)
}
.nail-image img{
    width:100%;
    height:170px;
    object-fit:cover;
    display:block
}
.nail-title{
    font-size:1.2rem;
    color:#b13c8c;
    margin:18px 0 8px;
    font-family:'Playfair Display',serif;
    font-weight:700
}
.nail-text{
    font-size:.98rem;
    color:#fff;
    padding:0 14px 10px;
    text-align:center
}
.nail-price{
    color:#d45fa1;
    font-weight:700;
    font-size:1.07rem;
    margin-bottom:14px
}
.nails-booking-link{
    text-align:center
}
.nails-booking-link a{
    display:inline-block;
    padding:12px 30px;
    background:#d45fa1;
    color:#fff;
    font-size:1.08rem;
    font-weight:600;
    border-radius:7px;
    text-decoration:none;
    transition:background .18s,transform .13s
}
.nails-booking-link a:hover{
    background:#b13c8c;
    transform:translateY(-2px) scale(1.04)
}
@media (max-width:768px){
    .nails-section{
        padding:40px 10px
    }
    .nails-header h2{
        font-size:1.7rem
    }
    .nails-container{
        gap:18px;
        margin-bottom:20px
    }
    .nail-card{
        width:98vw;
        max-width:340px;
        margin-left:auto;
        margin-right:auto
    }
    .nail-image img{
        height:120px
    }
    .nail-title{
        font-size:1.05rem;
        margin:12px 0 7px
    }
    .nail-text{
        font-size:.93rem;
        padding:0 8px 8px
    }
    .nail-price{
        font-size:1rem;
        margin-bottom:10px
    }
    .nails-booking-link a{
        padding:10px 18px;
        font-size:.98rem
    }
}
.problems-section{
    padding:65px 20px 50px
}
.problems-header{
    text-align:center;
    margin-bottom:36px
}
.problems-header h2{
    color:#d45fa1;
    font-size:2.3rem;
    margin-bottom:10px
}
.problems-header p{
    font-size:1.1rem;
    color:#fff
}
.problems-circles{
    display:flex;
    justify-content:center;
    gap:40px;
    flex-wrap:wrap
}
.problem-circle{
    width:142px;
    display:flex;
    flex-direction:column;
    align-items:center;
    cursor:pointer;
    transition:transform .16s,box-shadow .18s;
    position:relative;
    border:none;
    background:0 0;
    padding:0
}
.circle-img{
    width:120px;
    height:120px;
    border-radius:50%;
    overflow:hidden;
    box-shadow:0 4px 24px rgba(212,95,161,.1);
    border:4px solid #ffe0f5;
    margin-bottom:12px;
    background:#fff6e3;
    transition:box-shadow .18s,border .18s;
    justify-content:center;
    display:flex;
    align-items:center
}
.problem-circle span{
    color:#a83b8e;
    font-size:1rem;
    text-align:center;
    font-weight:500;
    line-height:1.25;
    margin-top:0
}
.problem-circle:focus .circle-img,.problem-circle:hover .circle-img{
    box-shadow:0 8px 34px 0 #d45fa135,0 0 0 6px #ffb8ea50;
    border:4px solid #d45fa1
}
.problem-circle:focus,.problem-circle:hover{
    transform:scale(1.07) translateY(-6px);
    z-index:2;
    outline:0
}
@media (max-width:900px){
    .problems-circles{
        gap:20px
    }
    .problem-circle{
        width:110px
    }
    .circle-img{
        width:85px;
        height:85px;
        margin-bottom:9px
    }
        .footer-container{
        flex-direction:column;
        gap:30px
    }
}
.modal-box{
    color:#d45fa1
}
.problem-modal{
    display:none;
    position:fixed;
    z-index:99;
    left:0;
    top:0;
    right:0;
    bottom:0
}
.problem-modal-overlay{
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background:rgba(0,0,0,.44);
    z-index:1
}
.problem-modal-content{
    position:relative;
    z-index:2;
    background:#1a3b2f;
    border-radius:24px;
    padding:38px 28px 30px;
    min-width:310px;
    max-width:50vw;
    box-shadow:0 10px 60px 0 #d45fa155;
    text-align:left;
    animation:.26s cubic-bezier(.43,.03,.28,.97) fadeinmodal
}
@keyframes fadeinmodal{
    0%{
        opacity:0;
        transform:scale(.92)
    }
    100%{
        opacity:1;
        transform:scale(1)
    }
}
.problem-modal-body h3{
    color:#d45fa1;
    font-size:1.35rem;
    margin-bottom:14px
}
.problem-modal-body p{
    color:#fff;
    font-size:1.06rem;
    margin-bottom:13px;
    line-height:1.7
}
