/* MAISQUEMIL - Premium Stylesheet */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800;900&family=Inter:wght@400;500;700&display=swap');

:root {
  --color-orange: #FF5722;
  --color-orange-glow: rgba(255, 87, 34, 0.4);
  --color-dark: #0F172A;
  --color-midnight: #0B0F19;
  --color-white: #FFFFFF;
}

body {
  font-family: 'Inter', sans-serif;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, .font-display {
  font-family: 'Outfit', sans-serif;
}

/* Sharp UI overrides */
.sharp {
  border-radius: 0px !important;
}

/* --- ANIMATIONS --- */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in-up {
  animation: fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
}

.delay-100 { animation-delay: 100ms; }
.delay-200 { animation-delay: 200ms; }
.delay-300 { animation-delay: 300ms; }

/* Pulse Glow (For CTAs) */
@keyframes pulseGlow {
  0% { box-shadow: 0 0 0 0 var(--color-orange-glow); }
  70% { box-shadow: 0 0 0 15px rgba(255, 87, 34, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 87, 34, 0); }
}

.btn-glow {
  position: relative;
  transition: all 0.3s ease;
}

.btn-glow:hover {
  animation: pulseGlow 1.5s infinite;
  transform: translateY(-2px);
}

/* Neo-Brutalism & Cards */
.card-neo {
  background: var(--color-white);
  border: 2px solid var(--color-dark);
  box-shadow: 4px 4px 0px var(--color-dark);
  transition: all 0.2s ease-in-out;
}

.card-neo:hover {
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0px var(--color-dark);
}

/* Inputs & Form Elements */
.input-premium {
  background: transparent;
  border: none;
  border-bottom: 2px solid #CBD5E1;
  padding: 12px 0;
  width: 100%;
  transition: all 0.3s ease;
}

.input-premium:focus {
  outline: none;
  border-bottom-color: var(--color-orange);
  box-shadow: 0 4px 6px -1px var(--color-orange-glow);
}

/* Dark Mode Sidebar */
.sidebar-dark {
  background-color: var(--color-midnight);
  border-right: 1px solid rgba(255, 255, 255, 0.05);
}

.sidebar-link {
  color: #94A3B8;
  transition: all 0.3s ease;
  border-left: 3px solid transparent;
}

.sidebar-link:hover {
  color: var(--color-white);
  background: rgba(255, 255, 255, 0.05);
  border-left-color: var(--color-orange);
}

.sidebar-link.active {
  color: var(--color-white);
  background: rgba(255, 87, 34, 0.1);
  border-left-color: var(--color-orange);
}

/* Massive Typographic Hero Adjustments */
.hero-massive {
  font-size: clamp(2.5rem, 7vw, 8rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: var(--color-dark);
}

.text-accent {
  color: var(--color-orange);
}

.bg-accent {
  background-color: var(--color-orange) !important;
}

.border-accent {
  border-color: var(--color-orange) !important;
}

.text-dark {
  color: var(--color-dark) !important;
}

.bg-dark {
  background-color: var(--color-dark) !important;
}

.border-dark {
  border-color: var(--color-dark) !important;
}

.bg-midnight {
  background-color: var(--color-midnight) !important;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: #F1F5F9;
}
::-webkit-scrollbar-thumb {
  background: #94A3B8;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--color-orange);
}

/* iOS Safari 100vh fix */
@supports (-webkit-touch-callout: none) {
  html, body {
    min-height: -webkit-fill-available;
  }
}