*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body { font-family: 'DM Sans', sans-serif; background: #FAF7F4; color: #0D0D0D; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
    img { display: block; }
    button, input, textarea, select { font-family: inherit; }
    @keyframes heroReveal {
      from { opacity: 0; transform: translateY(28px); }
      to { opacity: 1; transform: translateY(0); }
    }
    @keyframes progressFill {
      from { width: 0%; }
      to { width: 16%; }
    }
    @keyframes floatLine {
      0%, 100% { transform: translateY(0) translateX(-50%); opacity: 0.9; }
      50% { transform: translateY(10px) translateX(-50%); opacity: 0.4; }
    }
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(20px); }
      to { opacity: 1; transform: translateY(0); }
    }
    ::-webkit-scrollbar { width: 5px; }
    ::-webkit-scrollbar-track { background: #F0EBE3; }
    ::-webkit-scrollbar-thumb { background: #8B1C1C; }
