/* ==========================================================================
   Rascasse Marketing — Base / Reset / Typography
   ========================================================================== */

*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

body {
    font-family: var(--rm-font-body);
    font-size: var(--rm-text-base);
    line-height: 1.6;
    color: var(--rm-text-1);
    background: var(--rm-bg);
}

h1, h2, h3, h4, h5, h6 {
    line-height: 1.15;
    font-weight: 700;
}

h1 { font-size: var(--rm-text-6xl); }
h2 { font-size: var(--rm-text-4xl); }
h3 { font-size: var(--rm-text-2xl); }
h4 { font-size: var(--rm-text-xl); }

.display {
    font-family: var(--rm-font-display);
    font-weight: 400;
}

.display-xl {
    font-family: var(--rm-font-display);
    font-weight: 400;
    font-size: var(--rm-text-7xl);
    line-height: 1.05;
    letter-spacing: -0.02em;
}

a {
    color: var(--rm-primary);
    text-decoration: none;
    transition: color var(--rm-duration) var(--rm-ease);
}

a:hover {
    color: var(--rm-primary-hover);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

::selection {
    background: var(--rm-primary-light);
    color: var(--rm-primary);
}

/* Scroll reveal base state */
[data-reveal] {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity var(--rm-duration-slow) var(--rm-ease-out),
                transform var(--rm-duration-slow) var(--rm-ease-out);
}

[data-reveal="fade-in"] {
    transform: none;
}

[data-reveal="scale"] {
    transform: scale(0.95);
}

[data-reveal].revealed {
    opacity: 1;
    transform: none;
}

/* Stagger delays */
[data-reveal-delay="100"] { transition-delay: 0.1s; }
[data-reveal-delay="200"] { transition-delay: 0.2s; }
[data-reveal-delay="300"] { transition-delay: 0.3s; }
[data-reveal-delay="400"] { transition-delay: 0.4s; }
[data-reveal-delay="500"] { transition-delay: 0.5s; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
    [data-reveal] {
        opacity: 1;
        transform: none;
    }
    html { scroll-behavior: auto; }
}

/* Responsive type scale */
@media (max-width: 1024px) {
    h1 { font-size: var(--rm-text-5xl); }
    h2 { font-size: var(--rm-text-3xl); }
    .display-xl { font-size: var(--rm-text-6xl); }
}

@media (max-width: 768px) {
    h1 { font-size: var(--rm-text-4xl); }
    h2 { font-size: var(--rm-text-2xl); }
    h3 { font-size: var(--rm-text-xl); }
    .display-xl { font-size: var(--rm-text-4xl); }
}

@media (max-width: 480px) {
    h1 { font-size: var(--rm-text-3xl); }
    .display-xl { font-size: var(--rm-text-3xl); }
}
