/* Body */
body {
    background-color: #010101 !important;
    font-family: 'DM Sans', sans-serif;
    text-transform: uppercase !important;
    color: #cacaca;
    font-size: 0.9rem !important;
}

.text-fluid {
    font-size: 0.9rem !important;
}

/* Base text styling for the form */
.tattoo-form input,
.tattoo-form textarea {
    font-weight: thin;
    font-size: 1rem !important;
    background-color: transparent !important;
    border: 1px solid #3c3c3c;
    font-style: normal;
    line-height: 140%;
    letter-spacing: -0.004em;
    border-radius: 2px;
    color: #f0f0f0;
}

.tattoo-form input:focus,
.tattoo-form textarea:focus {
    border: 1px solid white;
}

.tattoo-form button,
.tattoo-form label,
.tattoo-form .step-title {
    font-weight: thin;
    font-size: 0.9rem !important;
    font-style: normal;
    line-height: 140%;
    letter-spacing: -0.004em;
    border-radius: 2px;
}

.tattoo-form input,
.tattoo-form textarea {
    background-color: #f0efed;
}

/* Placeholder styling */
.tattoo-form input::placeholder,
.tattoo-form textarea::placeholder {
    opacity: 1;
    color: rgb(50, 50, 50);
    font-weight: 400;
}

/* Step labels */
.form-label {
    display: block;
    margin-bottom: 5px;
    font-weight: 300;
    line-height: 140%;
}

/* Add this to styles.css */
.tattoo-form label.upload-btn {
    display: flex !important;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 6rem;
    border-radius: 2px;
    cursor: pointer;
    border: 1px solid #3c3c3c;
}

.tattoo-form label.upload-btn:hover {
    border: 1px solid white;
}

/* Step title */
.step-title {
    font-weight: 900;
    margin-bottom: 1.5rem;
    text-align: left;
    line-height: 1;

    /* Mobile */
    font-size: 1.75rem;
    /* ~28px */

    /* Tablet */
    @media (min-width: 640px) {
        font-size: 2.25rem;
        /* ~36px */
    }

    /* Desktop */
    @media (min-width: 1024px) {
        font-size: 3rem;
        /* ~48px */
    }
}

/* Primary body part & specific area buttons */
.tattoo-form .option-btn {
    text-align: center;
}

/* Full width inputs for size/style */
.tattoo-form .full-width-input {
    width: 100%;
}

.error-text {
    color: #ff6600;
    font-size: 0.75rem;
    margin-top: 0.25rem;
    font-weight: 100;
}

@media (min-width: 640px) {

    .tattoo-form input,
    .tattoo-form textarea,
    .tattoo-form button,
    .tattoo-form label {
        font-size: 1rem;
        /* text-base */
    }
}

@media (min-width: 768px) {

    .tattoo-form input,
    .tattoo-form textarea,
    .tattoo-form button,
    .tattoo-form label {
        font-size: 1.125rem;
        /* text-lg */
    }
}

/* --- Step transition styles --- */
.step-panels {
    position: relative;
    overflow: hidden;
    transition: height 320ms ease;
}

/* Each panel sits on top of each other; we animate transform + opacity */
.step-panel {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transform: translateX(20px);
    transition: transform 360ms cubic-bezier(.22, .9, .3, 1), opacity 260ms ease;
    pointer-events: none;
}

/* Visible panel */
.step-panel.active {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
    z-index: 2;
}

/* Panels that are before the active (we slide them left) */
.step-panel.left {
    transform: translateX(-20px);
}

/* Panels that are after the active (we slide them right) */
.step-panel.right {
    transform: translateX(20px);
}

/* Accessibility: hide inactive panels from screen readers */
.step-panel[aria-hidden="true"] {
    pointer-events: none;
    visibility: visible;
    /* remain visible for measurement; opacity handles display */
}

.card {
    border: 1px solid #3c3c3c;
    padding: 1rem;
    border-radius: 2px;
}

/* Image hover effect */
.artist-image-wrapper {
    overflow: hidden;
}

.artist-image {
    transition: transform 0.3s ease, filter 0.3s ease;
    border-radius: 2px;
}

.artist-image-wrapper:hover .artist-image {
    transform: scale(1.05);
    filter: brightness(0.9);
}

.hide-scrollbar::-webkit-scrollbar {
    display: none;
}

.hide-scrollbar {
    -ms-overflow-style: none;
    /* IE and Edge */
    scrollbar-width: none;
    /* Firefox */
}

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #010101 inset !important;
    /* custom bg */
    -webkit-text-fill-color: #f0f0f0 !important;
    /* custom text */
}

.footer button {
    font-family: 'DM Sans', sans-serif;
    font-weight: thin;
    font-size: 0.9rem;
    letter-spacing: -0.004em;
    text-transform: uppercase;
}

@keyframes marquee {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(-50%);
    }

}

.animate-marquee {
    display: inline-flex;
    animation: marquee 20s linear infinite;
    align-items: center;
    /* vertically center logo and text */
}

/* Hide scrollbar for Chrome, Safari and Opera */
::-webkit-scrollbar {
    display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
.scrollbar-hide {
    -ms-overflow-style: none;
    /* IE and Edge */
    scrollbar-width: none;
    /* Firefox */
}

/* container: dimension + smooth interaction */
/* container: responsive size for desktop and mobile */
.container {
    position: relative;
    aspect-ratio: 1 / 1;
    width: 100%;
    /* fill parent width */
    height: auto;
    /* fill parent height */
    aspect-ratio: 2200 / 1480;
    transition: 200ms;
    opacity: 0.8;
}

.container:active {
    transform: scale(0.95);
}

/* card (use absolute so it fills the container and can be transformed in 3D) */
#card {
    position: absolute;
    inset: 0;
    z-index: 1;
    /* keep below trackers but above background */
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 700ms;
    overflow: hidden;
    padding: 0;
    /* ensure no internal spacing */
    margin: 0;
    /* remove outer spacing */

    /* improve 3D behavior & performance hints */
    transform-style: preserve-3d;
    will-change: transform, filter;
}

/* colorful blurred glow behind the card — use numeric opacity */
#card::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    transition: 200ms;
}

/* logo inside card — remove gap */
/* logo inside card — fully visible, no cropping */
.logo {
    width: 100%;
    height: 100%;
    object-fit: contain;
    /* preserves aspect ratio, no cropping */
    object-position: center;
    /* center the image in the container */
    pointer-events: none;
}

/* trackers: make them grid items (NOT absolute) so each fills its cell */
.tracker {
    position: relative;
    /* so z-index works and they remain grid children */
    z-index: 3;
    /* sit above the card to capture hover */
    width: 100%;
    height: 100%;
    background: transparent;
    /* no pointer events disabling — we want them to catch hover */
}

/* pointer on hover */
.tracker:hover {
    cursor: pointer;
}

/* when any tracker is hovered, slightly brighten the card */
.tracker:hover~#card {
    transition: 300ms;
    filter: brightness(1.08);
}

/* canvas: grid of 5x5 and perspective for 3D tilt */
.canvas {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(5, 1fr);
    perspective: 800px;
}

/* Hover tilt transforms - scoped to the card container to avoid accidental global matches */
.container .tr-1:hover~#card {
    transform: rotateX(20deg) rotateY(-10deg);
}

.container .tr-2:hover~#card {
    transform: rotateX(20deg) rotateY(-5deg);
}

.container .tr-3:hover~#card {
    transform: rotateX(20deg) rotateY(0deg);
}

.container .tr-4:hover~#card {
    transform: rotateX(20deg) rotateY(5deg);
}

.container .tr-5:hover~#card {
    transform: rotateX(20deg) rotateY(10deg);
}

.container .tr-6:hover~#card {
    transform: rotateX(10deg) rotateY(-10deg);
}

.container .tr-7:hover~#card {
    transform: rotateX(10deg) rotateY(-5deg);
}

.container .tr-8:hover~#card {
    transform: rotateX(10deg) rotateY(0deg);
}

.container .tr-9:hover~#card {
    transform: rotateX(10deg) rotateY(5deg);
}

.container .tr-10:hover~#card {
    transform: rotateX(10deg) rotateY(10deg);
}

.container .tr-11:hover~#card {
    transform: rotateX(0deg) rotateY(-10deg);
}

.container .tr-12:hover~#card {
    transform: rotateX(0deg) rotateY(-5deg);
}

.container .tr-13:hover~#card {
    transform: rotateX(0deg) rotateY(0deg);
}

.container .tr-14:hover~#card {
    transform: rotateX(0deg) rotateY(5deg);
}

.container .tr-15:hover~#card {
    transform: rotateX(0deg) rotateY(10deg);
}

.container .tr-16:hover~#card {
    transform: rotateX(-10deg) rotateY(-10deg);
}

.container .tr-17:hover~#card {
    transform: rotateX(-10deg) rotateY(-5deg);
}

.container .tr-18:hover~#card {
    transform: rotateX(-10deg) rotateY(0deg);
}

.container .tr-19:hover~#card {
    transform: rotateX(-10deg) rotateY(5deg);
}

.container .tr-20:hover~#card {
    transform: rotateX(-10deg) rotateY(10deg);
}

.container .tr-21:hover~#card {
    transform: rotateX(-20deg) rotateY(-10deg);
}

.container .tr-22:hover~#card {
    transform: rotateX(-20deg) rotateY(-5deg);
}

.container .tr-23:hover~#card {
    transform: rotateX(-20deg) rotateY(0deg);
}

.container .tr-24:hover~#card {
    transform: rotateX(-20deg) rotateY(5deg);
}

.container .tr-25:hover~#card {
    transform: rotateX(-20deg) rotateY(10deg);
}

/* block text selection for this component only */
.noselect {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}

.animate-float {
  animation: float 4s ease-in-out infinite;
}

@keyframes floatInUp {
  0% {
    transform: translateY(30px);
  }
  100% {
    transform: translateY(0);
  }
}

.animate-float-in-up {
  animation: floatInUp 1s ease-out forwards;
}

/* Zoom in/out animation for mobile */
@keyframes zoomInOut {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}

/* Apply only on mobile screens */
@media (max-width: 768px) {
  .animate-zoom {
    animation: zoomInOut 2s ease-in-out infinite;
  }
}

.terms-slide {
  position: relative;
  transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
}

.slide-in-right {
  transform: translateX(100%);
  opacity: 0;
  animation: slideInRight 0.5s forwards;
}

.slide-in-left {
  transform: translateX(-100%);
  opacity: 0;
  animation: slideInLeft 0.5s forwards;
}

@keyframes slideInRight {
  from { transform: translateX(100%); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

@keyframes slideInLeft {
  from { transform: translateX(-100%); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
