/* ==================================================
ОСНОВНОЙ КОНТЕЙНЕР
MAIN WRAP
================================================== */
.ticket-wrap{
position:relative;
width:100%;
max-width:1100px;
min-width:320px;
margin:0 auto;
overflow:visible;
aspect-ratio:1200 / 340;
flex-shrink:0;
/* 🔥 теперь всё адаптируется от ширины контейнера */
container-type:inline-size;
padding-right:40px;
}
/* ==================================================
SVG
================================================== */
.ticket-svg{
position:absolute;
top:0;
height:100%;
display:block;
}
.ticket-svg.left{
left:0;
width:68%;
z-index:1;
}
/* ==================================================
ПРАВАЯ ЧАСТЬ
================================================== */
.ticket-right-wrap{
position:absolute;
top:0;
right:0;
width:32%;
height:100%;
z-index:2;
transform-origin:left center;
transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.ticket-right-wrap .ticket-svg{
width:100%;
height:100%;
}
/* ==================================================
HOVER DESKTOP
================================================== */
@media (hover:hover) and (pointer:fine){
.ticket-wrap:hover .ticket-right-wrap{
transform:translateX(40px) rotate(6deg);
}
}
/* ==================================================
CONTENT
================================================== */
.ticket-content{
position:absolute;
top:50%;
left:5%;
transform:translateY(-50%);
width:45%;
z-index:5;
}
/* ==================================================
TITLE
================================================== */
.ticket-content h2{
margin:0;
color:#55adf5;
font-weight:700;
line-height:1;
white-space:nowrap;
/* 🔥 адаптация от контейнера */
font-size:clamp(14px,7cqw,52px);
}
/* ==================================================
PRICE
================================================== */
.ticket-content .price{
margin-top:10px;
margin-bottom:20px;
color:#55adf5;
line-height:1.2;
font-weight:500;
/* 🔥 адаптация от контейнера */
font-size:clamp(10px,2.5cqw,22px);
}
/* ==================================================
BUTTON
================================================== */
.ticket-btn{
display:inline-flex;
align-items:center;
justify-content:space-between;
text-decoration:none;
background:#55adf5;
border-radius:999px;
box-sizing:border-box;
/* 🔥 адаптация */
width:clamp(90px,18cqw,170px);
height:clamp(28px,5.5cqw,50px);
padding-left:clamp(10px,2.5cqw,20px);
padding-right:clamp(3px,0.5cqw,6px);
flex-shrink:0;
-webkit-font-smoothing:antialiased;
}
.ticket-btn span{
color:#FFF
;
font-weight:500;
white-space:nowrap;
/* 🔥 адаптация */
font-size:clamp(9px,2cqw,15px);
}
/* ==================================================
PLUS
================================================== */
.ticket-btn .plus{
position:relative;
width:clamp(18px,4cqw,38px);
height:clamp(18px,4cqw,38px);
min-width:clamp(18px,3cqw,38px);
min-height:clamp(18px,3cqw,38px);
border-radius:999px;
background:#FFF
;
flex-shrink:0;
overflow:hidden;
transform:translateZ(0);
backface-visibility:hidden;
will-change:transform;
transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.ticket-wrap:hover .ticket-btn .plus{
transform:rotate(180deg);
}
/* ==================================================
PLUS LINES
================================================== */
.ticket-btn .plus::before,
.ticket-btn .plus::after{
content:"";
position:absolute;
top:50%;
left:50%;
background:#55adf5;
transform:translate(-50%,-50%);
}
.ticket-btn .plus::before{
width:38%;
height:2px;
}
.ticket-btn .plus::after{
width:2px;
height:38%;
}
/* ==================================================
IMAGE
================================================== */
.ticket-img{
--img-right:20%;
--img-top:50%;
--img-width:58%;
position:absolute;
right:var(--img-right);
top:var(--img-top);
transform:translateY(-50%);
width:var(--img-width);
aspect-ratio:5 / 6;
background-size:contain;
background-repeat:no-repeat;
background-position:center;
z-index:5;
}
/* ==================================================
LAPTOP
================================================== */
@media (max-width:1200px){
.ticket-content{
width:48%;
}
.ticket-img{
--img-right:18%;
--img-width:60%;
}
}
/* ==================================================
TABLET
================================================== */
@media (max-width:1024px){
.ticket-wrap{
aspect-ratio:1200 / 360;
}
.ticket-content{
width:50%;
}
.ticket-img{
--img-right:16%;
--img-width:64%;
}
}
/* ==================================================
PHONE
================================================== */
@media (max-width:767px){
.ticket-wrap{
aspect-ratio:1200 / 420;
}
.ticket-content{
left:6%;
width:54%;
}
.ticket-img{
--img-right:20%;
--img-width:70%;
}
.ticket-right-wrap,
.ticket-wrap:hover .ticket-right-wrap{
transform:none !important;
transition:none !important;
}
}
/* ==================================================
SMALL PHONE
================================================== */
@media (max-width:420px){
.ticket-wrap{
aspect-ratio:1200 / 470;
}
.ticket-content{
width:56%;
}
.ticket-img{
--img-right:20%;
--img-width:62%;
}
}
/* ==================================================
ULTRA SMALL
================================================== */
@media (max-width:320px){
.ticket-wrap{
aspect-ratio:1200 / 620;
}
.ticket-content{
left:14px;
width:58%;
}
.ticket-img{
--img-right:4%;
--img-width:58%;
}
.ticket-right-wrap{
width:30%;
}
}